test_flash_awq_sharded.py 1.41 KB
Newer Older
1
2
import pytest

OlivierDehaene's avatar
OlivierDehaene committed
3

4
5
@pytest.fixture(scope="module")
def flash_llama_awq_handle_sharded(launcher):
OlivierDehaene's avatar
OlivierDehaene committed
6
7
8
9
10
    with launcher(
        "abhinavkulkarni/codellama-CodeLlama-7b-Python-hf-w4-g128-awq",
        num_shard=2,
        quantize="awq",
    ) as handle:
11
12
        yield handle

OlivierDehaene's avatar
OlivierDehaene committed
13

14
15
16
17
18
@pytest.fixture(scope="module")
async def flash_llama_awq_sharded(flash_llama_awq_handle_sharded):
    await flash_llama_awq_handle_sharded.health(300)
    return flash_llama_awq_handle_sharded.client

OlivierDehaene's avatar
OlivierDehaene committed
19

20
21
22
23
24
25
26
@pytest.mark.asyncio
async def test_flash_llama_awq_sharded(flash_llama_awq_sharded, response_snapshot):
    response = await flash_llama_awq_sharded.generate(
        "What is Deep Learning?", max_new_tokens=10, decoder_input_details=True
    )

    assert response.details.generated_tokens == 10
OlivierDehaene's avatar
OlivierDehaene committed
27
28
29
30
    assert (
        response.generated_text
        == "\nWhat is the difference between Deep Learning and Machine"
    )
31
32
    assert response == response_snapshot

OlivierDehaene's avatar
OlivierDehaene committed
33

34
35
36
37
38
39
40
41
42
@pytest.mark.asyncio
async def test_flash_llama_awq_load_sharded(
    flash_llama_awq_sharded, generate_load, response_snapshot
):
    responses = await generate_load(
        flash_llama_awq_sharded, "What is Deep Learning?", max_new_tokens=10, n=4
    )

    assert len(responses) == 4
OlivierDehaene's avatar
OlivierDehaene committed
43
44
45
46
47
48
49
    assert all(
        [
            r.generated_text
            == "\nWhat is the difference between Deep Learning and Machine"
            for r in responses
        ]
    )
50
51

    assert responses == response_snapshot