Skip to content

Commit

Permalink
fix: add integerate test for client (#753)
Browse files Browse the repository at this point in the history
  • Loading branch information
numb3r3 authored Jun 14, 2022
1 parent b5c339f commit eca1e70
Showing 1 changed file with 57 additions and 0 deletions.
57 changes: 57 additions & 0 deletions tests/test_client.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
import os
import random
import time
import pytest
import numpy as np
from docarray import Document, DocumentArray
from jina import Flow, Executor, requests


class Exec1(Executor):
@requests
async def aencode(self, docs, **kwargs):
time.sleep(random.random() * 1)
docs.embeddings = np.random.rand(len(docs), 10)


class Exec2(Executor):
def __init__(self, server_host: str = '', **kwargs):
super().__init__(**kwargs)
from clip_client.client import Client

self._client = Client(server=server_host)

@requests
async def process(self, docs, **kwargs):
results = await self._client.aencode(docs, request_size=2)
return results


def test_client_concurrent_requests(port_generator):

f1 = Flow(port=port_generator()).add(uses=Exec1)

f2 = Flow(protocol='http').add(
uses=Exec2, uses_with={'server_host': f'grpc://0.0.0.0:{f1.port}'}
)

with f1, f2:
import jina
from multiprocessing.pool import ThreadPool

def run_post(docs):
c = jina.clients.Client(port=f2.port, protocol='http')
results = c.post(on='/', inputs=docs, request_size=2)
# assert set([d.id for d in results]) != set([d.id for d in docs])
return results

def generate_docs(tag):
return DocumentArray(
[Document(id=f'{tag}_{i}', text='hello') for i in range(20)]
)

with ThreadPool(5) as p:
results = p.map(run_post, [generate_docs(f't{k}') for k in range(5)])

for r in results:
assert len(set([d.id[:2] for d in r])) == 1

0 comments on commit eca1e70

Please sign in to comment.