Example #1
0
    async def receive_file(self, receiver):
        self.progress_update.start()
        parent, child = AioPipe(False)
        start_time = time()
        receive_process = AioProcess(target=receiver.fetch_data,
                                     args=(self.pipe[1], child))
        receive_process.start()
        await receive_process.coro_join()
        end_time = time() - start_time

        self.progress_update.wait()

        message = QMessageBox()
        message.information(
            self, "Information",
            f"Download complete, time taken {round(end_time / 60, 2)} minutes")

        receiver.save_location = parent.recv()

        self.ui.label_4.setText("Writing File")
        self.ui.progressBar.setValue(0)

        path = await receiver.write_data(receiver.save_location, self)
        rmtree(path)

        self.ui.receiveButton.setEnabled(True)
        self.ui.label_4.setVisible(False)
        self.ui.progressBar.setVisible(False)
        self.ui.label_4.setText("Download in Progress")
        self.ui.progressBar.setValue(0)
Example #2
0
def test_basic_q_with_pipe_async():
    import asyncio
    from aioprocessing import AioPipe

    class Node(Process):
        def __init__(self, pipe=None):
            super().__init__()
            # assert mp structures are in place
            assert pipe is not None, 'A pipe must be provided.'

            # set queue
            self.pipe = pipe

        def run(self, *args):
            super().run()

            self.loop()

        def loop(self):
            print(
                'node entering loop where it will non-block check zmq and local queue'
            )
            loop = asyncio.new_event_loop()
            asyncio.set_event_loop(loop)

            tasks = [
                asyncio. async (self.get_from_pipe(self.pipe)),
            ]
            loop.run_until_complete(asyncio.wait(tasks))
            loop.close()

        async def get_from_pipe(self, pipe):
            while True:
                pipe.send(pipe.recv())

    p_parent_pipe, p_child_pipe = AioPipe()
    p = Node(pipe=p_child_pipe)
    p.start()
    sleep(1)

    p_parent_pipe.send(b'hello world')

    sleep(1)
    print('q is empty...' if not p_parent_pipe.poll() else
          'q is not empty. got: {}'.format(p_parent_pipe.recv()))

    p.terminate()
Example #3
0
def test_basic_q_and_zmq_with_pipe_async():
    import zmq
    from cilantro import Constants
    import asyncio
    from aioprocessing import AioPipe

    class Node(Process):
        def __init__(self, pipe=None, sub_port=9999, pub_port=9998):
            super().__init__()
            # assert mp structures are in place
            assert pipe is not None, 'A pipe must be provided.'

            # establish base url
            self.base_url = Constants.BaseNode.BaseUrl

            # setup subscriber constants
            self.subscriber_port = sub_port
            self.subscriber_url = 'tcp://{}:{}'.format(self.base_url,
                                                       self.subscriber_port)

            # setup publisher constants
            self.publisher_port = pub_port
            self.publisher_url = 'tcp://{}:{}'.format(self.base_url,
                                                      self.publisher_port)

            # set context and sockets to none until process starts because multiprocessing zmq is funky
            self.context = None
            self.sub_socket = None
            self.pub_socket = None

            # set pipe
            self.pipe = pipe

        def run(self, *args):
            super().run()

            self.context = zmq.Context()

            self.sub_socket = self.context.socket(socket_type=zmq.SUB)

            self.sub_socket.bind(self.subscriber_url)
            self.sub_socket.setsockopt(zmq.SUBSCRIBE, b'')

            self.pub_socket = self.context.socket(socket_type=zmq.PUB)
            self.pub_socket.connect(self.publisher_url)

            loop = asyncio.new_event_loop()
            asyncio.set_event_loop(loop)

            loop.run_until_complete(self.listen())

        async def listen(self):
            loop = asyncio.get_event_loop()
            tasks = [
                loop.run_in_executor(None, self.receive_from_pipe, self.pipe),
                loop.run_in_executor(None, self.receive_from_socket,
                                     self.sub_socket)
            ]
            await asyncio.wait(tasks)

        def receive_from_socket(self, socket):
            print('zmq')
            while True:
                self.zmq_callback(socket.recv())

        def receive_from_pipe(self, pipe):
            print('pipe')
            while True:
                self.pipe_callback(pipe.recv())

        def zmq_callback(self, msg):
            raise NotImplementedError

        def pipe_callback(self, msg):
            raise NotImplementedError

    class Subscriber(Node):
        def zmq_callback(self, msg):
            print('received message from publisher. putting it on the queue:',
                  msg)
            self.pipe.send(msg)
            print('done')

        def pipe_callback(self, msg):
            pass

    class Publisher(Node):
        def zmq_callback(self, msg):
            pass

        def pipe_callback(self, msg):
            print('received a message on the queue. publishing it:', msg)
            self.pub_socket.send(msg)

    s_parent_pipe, s_child_pipe = AioPipe()
    s = Subscriber(pipe=s_child_pipe)
    s.start()
    sleep(1)

    p_parent_pipe, p_child_pipe = AioPipe()
    p = Publisher(pipe=p_child_pipe, pub_port=9999, sub_port=9997)
    p.start()
    sleep(1)

    print('publishing message')
    p_parent_pipe.send(b'hello world')

    sleep(1)
    print('q is empty...' if not s_parent_pipe.poll() else
          'q is not empty. got: {}'.format(s_parent_pipe.recv()))

    p.terminate()
    s.terminate()