|
1 | 1 | from time import time
|
2 | 2 |
|
3 |
| -from apify.scrapy.extensions._httpcache import from_gzip, read_gzip_time, to_gzip |
| 3 | +import pytest |
| 4 | + |
| 5 | +from apify.scrapy.extensions._httpcache import from_gzip, get_kvs_name, read_gzip_time, to_gzip |
4 | 6 |
|
5 | 7 | FIXTURE_DICT = {'name': 'Alice'}
|
6 | 8 |
|
@@ -35,3 +37,34 @@ def test_read_gzip_time_non_zero() -> None:
|
35 | 37 | data_bytes = to_gzip(FIXTURE_DICT, mtime=current_time)
|
36 | 38 |
|
37 | 39 | assert read_gzip_time(data_bytes) == current_time
|
| 40 | + |
| 41 | + |
| 42 | +@pytest.mark.parametrize( |
| 43 | + ('spider_name', 'expected'), |
| 44 | + [ |
| 45 | + ('test', 'httpcache-test'), |
| 46 | + ('123', 'httpcache-123'), |
| 47 | + ('test-spider', 'httpcache-test-spider'), |
| 48 | + ('test_spider', 'httpcache-test-spider'), |
| 49 | + ('test spider', 'httpcache-test-spider'), |
| 50 | + ('test👻spider', 'httpcache-test-spider'), |
| 51 | + ('test@spider', 'httpcache-test-spider'), |
| 52 | + (' test spider ', 'httpcache-test-spider'), |
| 53 | + ('testspider.com', 'httpcache-testspider-com'), |
| 54 | + ], |
| 55 | +) |
| 56 | +def test_get_kvs_name(spider_name: str, expected: str) -> None: |
| 57 | + assert get_kvs_name(spider_name) == expected |
| 58 | + |
| 59 | + |
| 60 | +@pytest.mark.parametrize( |
| 61 | + ('spider_name'), |
| 62 | + [ |
| 63 | + '', |
| 64 | + '-', |
| 65 | + '-@-/-', |
| 66 | + ], |
| 67 | +) |
| 68 | +def test_get_kvs_name_raises(spider_name: str) -> None: |
| 69 | + with pytest.raises(ValueError, match='Unsupported spider name'): |
| 70 | + assert get_kvs_name(spider_name) |
0 commit comments