crawlo 1.3.6__py3-none-any.whl → 1.3.7__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of crawlo might be problematic. Click here for more details.
- crawlo/__init__.py +87 -87
- crawlo/__version__.py +1 -1
- crawlo/cli.py +75 -75
- crawlo/commands/__init__.py +14 -14
- crawlo/commands/check.py +594 -594
- crawlo/commands/genspider.py +151 -151
- crawlo/commands/help.py +138 -138
- crawlo/commands/list.py +155 -155
- crawlo/commands/run.py +341 -341
- crawlo/commands/startproject.py +436 -436
- crawlo/commands/stats.py +187 -187
- crawlo/commands/utils.py +196 -196
- crawlo/config.py +312 -312
- crawlo/config_validator.py +277 -277
- crawlo/core/__init__.py +45 -45
- crawlo/core/engine.py +439 -439
- crawlo/core/processor.py +40 -40
- crawlo/core/scheduler.py +257 -257
- crawlo/crawler.py +638 -638
- crawlo/data/__init__.py +5 -5
- crawlo/data/user_agents.py +194 -194
- crawlo/downloader/__init__.py +273 -273
- crawlo/downloader/aiohttp_downloader.py +228 -228
- crawlo/downloader/cffi_downloader.py +245 -245
- crawlo/downloader/httpx_downloader.py +259 -259
- crawlo/downloader/hybrid_downloader.py +212 -212
- crawlo/downloader/playwright_downloader.py +402 -402
- crawlo/downloader/selenium_downloader.py +472 -472
- crawlo/event.py +11 -11
- crawlo/exceptions.py +81 -81
- crawlo/extension/__init__.py +39 -39
- crawlo/extension/health_check.py +141 -141
- crawlo/extension/log_interval.py +57 -57
- crawlo/extension/log_stats.py +81 -81
- crawlo/extension/logging_extension.py +61 -61
- crawlo/extension/memory_monitor.py +104 -104
- crawlo/extension/performance_profiler.py +133 -133
- crawlo/extension/request_recorder.py +107 -107
- crawlo/factories/__init__.py +27 -27
- crawlo/factories/base.py +68 -68
- crawlo/factories/crawler.py +103 -103
- crawlo/factories/registry.py +84 -84
- crawlo/filters/__init__.py +154 -154
- crawlo/filters/aioredis_filter.py +257 -257
- crawlo/filters/memory_filter.py +269 -269
- crawlo/framework.py +292 -292
- crawlo/initialization/__init__.py +39 -39
- crawlo/initialization/built_in.py +425 -425
- crawlo/initialization/context.py +141 -141
- crawlo/initialization/core.py +193 -193
- crawlo/initialization/phases.py +148 -148
- crawlo/initialization/registry.py +145 -145
- crawlo/items/__init__.py +23 -23
- crawlo/items/base.py +23 -23
- crawlo/items/fields.py +52 -52
- crawlo/items/items.py +104 -104
- crawlo/logging/__init__.py +37 -37
- crawlo/logging/config.py +96 -96
- crawlo/logging/factory.py +128 -128
- crawlo/logging/manager.py +111 -111
- crawlo/middleware/__init__.py +21 -21
- crawlo/middleware/default_header.py +132 -132
- crawlo/middleware/download_delay.py +104 -104
- crawlo/middleware/middleware_manager.py +135 -135
- crawlo/middleware/offsite.py +123 -123
- crawlo/middleware/proxy.py +386 -386
- crawlo/middleware/request_ignore.py +86 -86
- crawlo/middleware/response_code.py +163 -163
- crawlo/middleware/response_filter.py +136 -136
- crawlo/middleware/retry.py +124 -124
- crawlo/middleware/simple_proxy.py +65 -65
- crawlo/mode_manager.py +212 -212
- crawlo/network/__init__.py +21 -21
- crawlo/network/request.py +379 -379
- crawlo/network/response.py +359 -359
- crawlo/pipelines/__init__.py +21 -21
- crawlo/pipelines/bloom_dedup_pipeline.py +156 -156
- crawlo/pipelines/console_pipeline.py +39 -39
- crawlo/pipelines/csv_pipeline.py +316 -316
- crawlo/pipelines/database_dedup_pipeline.py +222 -222
- crawlo/pipelines/json_pipeline.py +218 -218
- crawlo/pipelines/memory_dedup_pipeline.py +115 -115
- crawlo/pipelines/mongo_pipeline.py +131 -131
- crawlo/pipelines/mysql_pipeline.py +325 -325
- crawlo/pipelines/pipeline_manager.py +76 -76
- crawlo/pipelines/redis_dedup_pipeline.py +166 -166
- crawlo/project.py +327 -327
- crawlo/queue/pqueue.py +42 -42
- crawlo/queue/queue_manager.py +522 -503
- crawlo/queue/redis_priority_queue.py +367 -326
- crawlo/settings/__init__.py +7 -7
- crawlo/settings/default_settings.py +321 -321
- crawlo/settings/setting_manager.py +214 -214
- crawlo/spider/__init__.py +657 -657
- crawlo/stats_collector.py +73 -73
- crawlo/subscriber.py +129 -129
- crawlo/task_manager.py +138 -138
- crawlo/templates/crawlo.cfg.tmpl +10 -10
- crawlo/templates/project/__init__.py.tmpl +3 -3
- crawlo/templates/project/items.py.tmpl +17 -17
- crawlo/templates/project/middlewares.py.tmpl +118 -118
- crawlo/templates/project/pipelines.py.tmpl +96 -96
- crawlo/templates/project/settings.py.tmpl +170 -167
- crawlo/templates/project/settings_distributed.py.tmpl +169 -166
- crawlo/templates/project/settings_gentle.py.tmpl +166 -166
- crawlo/templates/project/settings_high_performance.py.tmpl +167 -167
- crawlo/templates/project/settings_minimal.py.tmpl +65 -65
- crawlo/templates/project/settings_simple.py.tmpl +164 -164
- crawlo/templates/project/spiders/__init__.py.tmpl +9 -9
- crawlo/templates/run.py.tmpl +34 -34
- crawlo/templates/spider/spider.py.tmpl +143 -143
- crawlo/templates/spiders_init.py.tmpl +9 -9
- crawlo/tools/__init__.py +200 -200
- crawlo/tools/anti_crawler.py +268 -268
- crawlo/tools/authenticated_proxy.py +240 -240
- crawlo/tools/data_formatter.py +225 -225
- crawlo/tools/data_validator.py +180 -180
- crawlo/tools/date_tools.py +289 -289
- crawlo/tools/distributed_coordinator.py +388 -388
- crawlo/tools/encoding_converter.py +127 -127
- crawlo/tools/network_diagnostic.py +364 -364
- crawlo/tools/request_tools.py +82 -82
- crawlo/tools/retry_mechanism.py +224 -224
- crawlo/tools/scenario_adapter.py +262 -262
- crawlo/tools/text_cleaner.py +232 -232
- crawlo/utils/__init__.py +34 -34
- crawlo/utils/batch_processor.py +259 -259
- crawlo/utils/class_loader.py +25 -25
- crawlo/utils/controlled_spider_mixin.py +439 -439
- crawlo/utils/db_helper.py +343 -343
- crawlo/utils/enhanced_error_handler.py +356 -356
- crawlo/utils/env_config.py +142 -142
- crawlo/utils/error_handler.py +165 -165
- crawlo/utils/func_tools.py +82 -82
- crawlo/utils/large_scale_config.py +286 -286
- crawlo/utils/large_scale_helper.py +344 -344
- crawlo/utils/log.py +79 -79
- crawlo/utils/performance_monitor.py +285 -285
- crawlo/utils/queue_helper.py +175 -175
- crawlo/utils/redis_connection_pool.py +388 -388
- crawlo/utils/redis_key_validator.py +198 -198
- crawlo/utils/request.py +267 -267
- crawlo/utils/request_serializer.py +225 -225
- crawlo/utils/spider_loader.py +61 -61
- crawlo/utils/system.py +11 -11
- crawlo/utils/tools.py +4 -4
- crawlo/utils/url.py +39 -39
- {crawlo-1.3.6.dist-info → crawlo-1.3.7.dist-info}/METADATA +1199 -1126
- crawlo-1.3.7.dist-info/RECORD +292 -0
- examples/__init__.py +7 -7
- tests/__init__.py +7 -7
- tests/advanced_tools_example.py +275 -275
- tests/authenticated_proxy_example.py +106 -106
- tests/baidu_performance_test.py +108 -108
- tests/baidu_test.py +59 -59
- tests/cleaners_example.py +160 -160
- tests/comprehensive_framework_test.py +212 -212
- tests/comprehensive_test.py +81 -81
- tests/comprehensive_testing_summary.md +186 -186
- tests/config_validation_demo.py +142 -142
- tests/controlled_spider_example.py +205 -205
- tests/date_tools_example.py +180 -180
- tests/debug_configure.py +69 -69
- tests/debug_framework_logger.py +84 -84
- tests/debug_log_config.py +126 -126
- tests/debug_log_levels.py +63 -63
- tests/debug_pipelines.py +66 -66
- tests/detailed_log_test.py +233 -233
- tests/distributed_test.py +66 -66
- tests/distributed_test_debug.py +76 -76
- tests/dynamic_loading_example.py +523 -523
- tests/dynamic_loading_test.py +104 -104
- tests/env_config_example.py +133 -133
- tests/error_handling_example.py +171 -171
- tests/final_comprehensive_test.py +151 -151
- tests/final_log_test.py +260 -260
- tests/final_validation_test.py +182 -182
- tests/fix_log_test.py +142 -142
- tests/framework_performance_test.py +202 -202
- tests/log_buffering_test.py +111 -111
- tests/log_generation_timing_test.py +153 -153
- tests/optimized_performance_test.py +211 -211
- tests/performance_comparison.py +245 -245
- tests/queue_blocking_test.py +113 -113
- tests/queue_test.py +89 -89
- tests/redis_key_validation_demo.py +130 -130
- tests/request_params_example.py +150 -150
- tests/response_improvements_example.py +144 -144
- tests/scrapy_comparison/ofweek_scrapy.py +138 -138
- tests/scrapy_comparison/scrapy_test.py +133 -133
- tests/simple_command_test.py +119 -119
- tests/simple_crawlo_test.py +127 -127
- tests/simple_log_test.py +57 -57
- tests/simple_log_test2.py +137 -137
- tests/simple_optimization_test.py +128 -128
- tests/simple_queue_type_test.py +41 -41
- tests/simple_spider_test.py +49 -49
- tests/simple_test.py +47 -47
- tests/spider_log_timing_test.py +177 -177
- tests/test_advanced_tools.py +148 -148
- tests/test_all_commands.py +230 -230
- tests/test_all_redis_key_configs.py +145 -145
- tests/test_authenticated_proxy.py +141 -141
- tests/test_batch_processor.py +178 -178
- tests/test_cleaners.py +54 -54
- tests/test_component_factory.py +174 -174
- tests/test_comprehensive.py +146 -146
- tests/test_config_consistency.py +80 -80
- tests/test_config_merge.py +152 -152
- tests/test_config_validator.py +182 -182
- tests/test_controlled_spider_mixin.py +79 -79
- tests/test_crawlo_proxy_integration.py +108 -108
- tests/test_date_tools.py +123 -123
- tests/test_default_header_middleware.py +158 -158
- tests/test_distributed.py +65 -65
- tests/test_double_crawlo_fix.py +204 -207
- tests/test_double_crawlo_fix_simple.py +124 -124
- tests/test_download_delay_middleware.py +221 -221
- tests/test_downloader_proxy_compatibility.py +268 -268
- tests/test_dynamic_downloaders_proxy.py +124 -124
- tests/test_dynamic_proxy.py +92 -92
- tests/test_dynamic_proxy_config.py +146 -146
- tests/test_dynamic_proxy_real.py +109 -109
- tests/test_edge_cases.py +303 -303
- tests/test_enhanced_error_handler.py +270 -270
- tests/test_enhanced_error_handler_comprehensive.py +245 -245
- tests/test_env_config.py +121 -121
- tests/test_error_handler_compatibility.py +112 -112
- tests/test_factories.py +252 -252
- tests/test_final_validation.py +153 -153
- tests/test_framework_env_usage.py +103 -103
- tests/test_framework_logger.py +66 -66
- tests/test_framework_startup.py +64 -64
- tests/test_get_component_logger.py +83 -83
- tests/test_integration.py +169 -169
- tests/test_item_dedup_redis_key.py +122 -122
- tests/test_large_scale_config.py +112 -112
- tests/test_large_scale_helper.py +235 -235
- tests/test_logging_system.py +282 -282
- tests/test_mode_change.py +72 -72
- tests/test_mode_consistency.py +51 -51
- tests/test_offsite_middleware.py +221 -221
- tests/test_parsel.py +29 -29
- tests/test_performance.py +327 -327
- tests/test_performance_monitor.py +115 -115
- tests/test_proxy_api.py +264 -264
- tests/test_proxy_health_check.py +32 -32
- tests/test_proxy_middleware.py +121 -121
- tests/test_proxy_middleware_enhanced.py +216 -216
- tests/test_proxy_middleware_integration.py +136 -136
- tests/test_proxy_middleware_refactored.py +184 -184
- tests/test_proxy_providers.py +56 -56
- tests/test_proxy_stats.py +19 -19
- tests/test_proxy_strategies.py +59 -59
- tests/test_queue_empty_check.py +41 -41
- tests/test_queue_manager_double_crawlo.py +173 -173
- tests/test_queue_manager_redis_key.py +179 -176
- tests/test_queue_naming.py +155 -0
- tests/test_queue_type.py +106 -106
- tests/test_random_user_agent.py +72 -72
- tests/test_real_scenario_proxy.py +195 -195
- tests/test_redis_config.py +28 -28
- tests/test_redis_connection_pool.py +294 -294
- tests/test_redis_key_naming.py +181 -181
- tests/test_redis_key_validator.py +123 -123
- tests/test_redis_queue.py +224 -224
- tests/test_redis_queue_name_fix.py +176 -0
- tests/test_request_ignore_middleware.py +182 -182
- tests/test_request_params.py +111 -111
- tests/test_request_serialization.py +70 -70
- tests/test_response_code_middleware.py +349 -349
- tests/test_response_filter_middleware.py +427 -427
- tests/test_response_improvements.py +152 -152
- tests/test_retry_middleware.py +241 -241
- tests/test_scheduler.py +252 -252
- tests/test_scheduler_config_update.py +133 -133
- tests/test_simple_response.py +61 -61
- tests/test_telecom_spider_redis_key.py +205 -205
- tests/test_template_content.py +87 -87
- tests/test_template_redis_key.py +134 -134
- tests/test_tools.py +159 -159
- tests/test_user_agents.py +96 -96
- tests/tools_example.py +260 -260
- tests/untested_features_report.md +138 -138
- tests/verify_debug.py +51 -51
- tests/verify_distributed.py +117 -117
- tests/verify_log_fix.py +111 -111
- crawlo-1.3.6.dist-info/RECORD +0 -290
- {crawlo-1.3.6.dist-info → crawlo-1.3.7.dist-info}/WHEEL +0 -0
- {crawlo-1.3.6.dist-info → crawlo-1.3.7.dist-info}/entry_points.txt +0 -0
- {crawlo-1.3.6.dist-info → crawlo-1.3.7.dist-info}/top_level.txt +0 -0
tests/test_queue_type.py
CHANGED
|
@@ -1,107 +1,107 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
# -*- coding: utf-8 -*-
|
|
3
|
-
"""
|
|
4
|
-
测试 QUEUE_TYPE 配置获取
|
|
5
|
-
"""
|
|
6
|
-
|
|
7
|
-
import sys
|
|
8
|
-
import os
|
|
9
|
-
|
|
10
|
-
# 添加项目根目录到路径
|
|
11
|
-
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..'))
|
|
12
|
-
|
|
13
|
-
from crawlo.framework import CrawloFramework
|
|
14
|
-
from crawlo.config import CrawloConfig
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
def test_queue_type_standalone():
|
|
18
|
-
"""测试单机模式下的 QUEUE_TYPE"""
|
|
19
|
-
print("=== 测试单机模式下的 QUEUE_TYPE ===")
|
|
20
|
-
|
|
21
|
-
# 创建单机模式配置
|
|
22
|
-
config = CrawloConfig.standalone(concurrency=4)
|
|
23
|
-
|
|
24
|
-
# 创建框架实例
|
|
25
|
-
framework = CrawloFramework(config.to_dict())
|
|
26
|
-
|
|
27
|
-
# 获取 QUEUE_TYPE
|
|
28
|
-
queue_type = framework.settings.get('QUEUE_TYPE', 'not found')
|
|
29
|
-
run_mode = framework.settings.get('RUN_MODE', 'not found')
|
|
30
|
-
|
|
31
|
-
print(f"RunMode: {run_mode}")
|
|
32
|
-
print(f"QueueType: {queue_type}")
|
|
33
|
-
|
|
34
|
-
# 验证是否正确
|
|
35
|
-
assert queue_type == 'memory', f"期望 'memory',实际得到 '{queue_type}'"
|
|
36
|
-
assert run_mode == 'standalone', f"期望 'standalone',实际得到 '{run_mode}'"
|
|
37
|
-
|
|
38
|
-
print("✅ 单机模式测试通过")
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
def test_queue_type_distributed():
|
|
42
|
-
"""测试分布式模式下的 QUEUE_TYPE"""
|
|
43
|
-
print("\n=== 测试分布式模式下的 QUEUE_TYPE ===")
|
|
44
|
-
|
|
45
|
-
# 创建分布式模式配置
|
|
46
|
-
config = CrawloConfig.distributed(
|
|
47
|
-
redis_host='127.0.0.1',
|
|
48
|
-
redis_port=6379,
|
|
49
|
-
project_name='test_project',
|
|
50
|
-
concurrency=4
|
|
51
|
-
)
|
|
52
|
-
|
|
53
|
-
# 创建框架实例
|
|
54
|
-
framework = CrawloFramework(config.to_dict())
|
|
55
|
-
|
|
56
|
-
# 获取 QUEUE_TYPE
|
|
57
|
-
queue_type = framework.settings.get('QUEUE_TYPE', 'not found')
|
|
58
|
-
run_mode = framework.settings.get('RUN_MODE', 'not found')
|
|
59
|
-
|
|
60
|
-
print(f"RunMode: {run_mode}")
|
|
61
|
-
print(f"QueueType: {queue_type}")
|
|
62
|
-
|
|
63
|
-
# 验证是否正确
|
|
64
|
-
assert queue_type == 'redis', f"期望 'redis',实际得到 '{queue_type}'"
|
|
65
|
-
assert run_mode == 'distributed', f"期望 'distributed',实际得到 '{run_mode}'"
|
|
66
|
-
|
|
67
|
-
print("✅ 分布式模式测试通过")
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
def test_queue_type_auto():
|
|
71
|
-
"""测试自动模式下的 QUEUE_TYPE"""
|
|
72
|
-
print("\n=== 测试自动模式下的 QUEUE_TYPE ===")
|
|
73
|
-
|
|
74
|
-
# 创建自动模式配置
|
|
75
|
-
config = CrawloConfig.auto(concurrency=4)
|
|
76
|
-
|
|
77
|
-
# 创建框架实例
|
|
78
|
-
framework = CrawloFramework(config.to_dict())
|
|
79
|
-
|
|
80
|
-
# 获取 QUEUE_TYPE
|
|
81
|
-
queue_type = framework.settings.get('QUEUE_TYPE', 'not found')
|
|
82
|
-
run_mode = framework.settings.get('RUN_MODE', 'not found')
|
|
83
|
-
|
|
84
|
-
print(f"RunMode: {run_mode}")
|
|
85
|
-
print(f"QueueType: {queue_type}")
|
|
86
|
-
|
|
87
|
-
# 验证是否正确
|
|
88
|
-
assert queue_type == 'auto', f"期望 'auto',实际得到 '{queue_type}'"
|
|
89
|
-
assert run_mode == 'auto', f"期望 'auto',实际得到 '{run_mode}'"
|
|
90
|
-
|
|
91
|
-
print("✅ 自动模式测试通过")
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
if __name__ == "__main__":
|
|
95
|
-
print("开始测试 QUEUE_TYPE 配置获取...")
|
|
96
|
-
|
|
97
|
-
try:
|
|
98
|
-
test_queue_type_standalone()
|
|
99
|
-
test_queue_type_distributed()
|
|
100
|
-
test_queue_type_auto()
|
|
101
|
-
|
|
102
|
-
print("\n🎉 所有测试通过!可以成功获取到 QUEUE_TYPE 配置。")
|
|
103
|
-
|
|
104
|
-
except Exception as e:
|
|
105
|
-
print(f"\n❌ 测试失败: {e}")
|
|
106
|
-
import traceback
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
# -*- coding: utf-8 -*-
|
|
3
|
+
"""
|
|
4
|
+
测试 QUEUE_TYPE 配置获取
|
|
5
|
+
"""
|
|
6
|
+
|
|
7
|
+
import sys
|
|
8
|
+
import os
|
|
9
|
+
|
|
10
|
+
# 添加项目根目录到路径
|
|
11
|
+
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..'))
|
|
12
|
+
|
|
13
|
+
from crawlo.framework import CrawloFramework
|
|
14
|
+
from crawlo.config import CrawloConfig
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
def test_queue_type_standalone():
|
|
18
|
+
"""测试单机模式下的 QUEUE_TYPE"""
|
|
19
|
+
print("=== 测试单机模式下的 QUEUE_TYPE ===")
|
|
20
|
+
|
|
21
|
+
# 创建单机模式配置
|
|
22
|
+
config = CrawloConfig.standalone(concurrency=4)
|
|
23
|
+
|
|
24
|
+
# 创建框架实例
|
|
25
|
+
framework = CrawloFramework(config.to_dict())
|
|
26
|
+
|
|
27
|
+
# 获取 QUEUE_TYPE
|
|
28
|
+
queue_type = framework.settings.get('QUEUE_TYPE', 'not found')
|
|
29
|
+
run_mode = framework.settings.get('RUN_MODE', 'not found')
|
|
30
|
+
|
|
31
|
+
print(f"RunMode: {run_mode}")
|
|
32
|
+
print(f"QueueType: {queue_type}")
|
|
33
|
+
|
|
34
|
+
# 验证是否正确
|
|
35
|
+
assert queue_type == 'memory', f"期望 'memory',实际得到 '{queue_type}'"
|
|
36
|
+
assert run_mode == 'standalone', f"期望 'standalone',实际得到 '{run_mode}'"
|
|
37
|
+
|
|
38
|
+
print("✅ 单机模式测试通过")
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
def test_queue_type_distributed():
|
|
42
|
+
"""测试分布式模式下的 QUEUE_TYPE"""
|
|
43
|
+
print("\n=== 测试分布式模式下的 QUEUE_TYPE ===")
|
|
44
|
+
|
|
45
|
+
# 创建分布式模式配置
|
|
46
|
+
config = CrawloConfig.distributed(
|
|
47
|
+
redis_host='127.0.0.1',
|
|
48
|
+
redis_port=6379,
|
|
49
|
+
project_name='test_project',
|
|
50
|
+
concurrency=4
|
|
51
|
+
)
|
|
52
|
+
|
|
53
|
+
# 创建框架实例
|
|
54
|
+
framework = CrawloFramework(config.to_dict())
|
|
55
|
+
|
|
56
|
+
# 获取 QUEUE_TYPE
|
|
57
|
+
queue_type = framework.settings.get('QUEUE_TYPE', 'not found')
|
|
58
|
+
run_mode = framework.settings.get('RUN_MODE', 'not found')
|
|
59
|
+
|
|
60
|
+
print(f"RunMode: {run_mode}")
|
|
61
|
+
print(f"QueueType: {queue_type}")
|
|
62
|
+
|
|
63
|
+
# 验证是否正确
|
|
64
|
+
assert queue_type == 'redis', f"期望 'redis',实际得到 '{queue_type}'"
|
|
65
|
+
assert run_mode == 'distributed', f"期望 'distributed',实际得到 '{run_mode}'"
|
|
66
|
+
|
|
67
|
+
print("✅ 分布式模式测试通过")
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
def test_queue_type_auto():
|
|
71
|
+
"""测试自动模式下的 QUEUE_TYPE"""
|
|
72
|
+
print("\n=== 测试自动模式下的 QUEUE_TYPE ===")
|
|
73
|
+
|
|
74
|
+
# 创建自动模式配置
|
|
75
|
+
config = CrawloConfig.auto(concurrency=4)
|
|
76
|
+
|
|
77
|
+
# 创建框架实例
|
|
78
|
+
framework = CrawloFramework(config.to_dict())
|
|
79
|
+
|
|
80
|
+
# 获取 QUEUE_TYPE
|
|
81
|
+
queue_type = framework.settings.get('QUEUE_TYPE', 'not found')
|
|
82
|
+
run_mode = framework.settings.get('RUN_MODE', 'not found')
|
|
83
|
+
|
|
84
|
+
print(f"RunMode: {run_mode}")
|
|
85
|
+
print(f"QueueType: {queue_type}")
|
|
86
|
+
|
|
87
|
+
# 验证是否正确
|
|
88
|
+
assert queue_type == 'auto', f"期望 'auto',实际得到 '{queue_type}'"
|
|
89
|
+
assert run_mode == 'auto', f"期望 'auto',实际得到 '{run_mode}'"
|
|
90
|
+
|
|
91
|
+
print("✅ 自动模式测试通过")
|
|
92
|
+
|
|
93
|
+
|
|
94
|
+
if __name__ == "__main__":
|
|
95
|
+
print("开始测试 QUEUE_TYPE 配置获取...")
|
|
96
|
+
|
|
97
|
+
try:
|
|
98
|
+
test_queue_type_standalone()
|
|
99
|
+
test_queue_type_distributed()
|
|
100
|
+
test_queue_type_auto()
|
|
101
|
+
|
|
102
|
+
print("\n🎉 所有测试通过!可以成功获取到 QUEUE_TYPE 配置。")
|
|
103
|
+
|
|
104
|
+
except Exception as e:
|
|
105
|
+
print(f"\n❌ 测试失败: {e}")
|
|
106
|
+
import traceback
|
|
107
107
|
traceback.print_exc()
|
tests/test_random_user_agent.py
CHANGED
|
@@ -1,73 +1,73 @@
|
|
|
1
|
-
#!/usr/bin/env python
|
|
2
|
-
# -*- coding: utf-8 -*-
|
|
3
|
-
"""
|
|
4
|
-
测试随机User-Agent功能
|
|
5
|
-
"""
|
|
6
|
-
|
|
7
|
-
import sys
|
|
8
|
-
import os
|
|
9
|
-
|
|
10
|
-
# 添加项目根目录到Python路径
|
|
11
|
-
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..'))
|
|
12
|
-
|
|
13
|
-
from crawlo.data.user_agents import get_random_user_agent
|
|
14
|
-
from crawlo.middleware.default_header import DefaultHeaderMiddleware
|
|
15
|
-
from crawlo.settings.setting_manager import SettingManager
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
def test_random_user_agent_function():
|
|
19
|
-
"""测试随机User-Agent函数"""
|
|
20
|
-
print("=== 随机User-Agent函数测试 ===")
|
|
21
|
-
|
|
22
|
-
# 测试各种设备类型的随机User-Agent
|
|
23
|
-
device_types = ["desktop", "mobile", "all", "chrome", "firefox", "safari", "edge", "opera"]
|
|
24
|
-
|
|
25
|
-
for device_type in device_types:
|
|
26
|
-
print(f"\n{device_type}类型随机User-Agent:")
|
|
27
|
-
for i in range(3):
|
|
28
|
-
ua = get_random_user_agent(device_type)
|
|
29
|
-
print(f" {i+1}. {ua}")
|
|
30
|
-
|
|
31
|
-
print()
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
def test_default_header_middleware_with_random_ua():
|
|
35
|
-
"""测试DefaultHeaderMiddleware与随机User-Agent"""
|
|
36
|
-
print("=== DefaultHeaderMiddleware与随机User-Agent测试 ===")
|
|
37
|
-
|
|
38
|
-
# 创建设置管理器
|
|
39
|
-
settings = SettingManager()
|
|
40
|
-
settings.set("LOG_LEVEL", "INFO")
|
|
41
|
-
settings.set("RANDOM_USER_AGENT_ENABLED", True)
|
|
42
|
-
settings.set("USER_AGENT_DEVICE_TYPE", "all")
|
|
43
|
-
# 添加一个默认请求头以启用中间件
|
|
44
|
-
settings.set("DEFAULT_REQUEST_HEADERS", {"Accept": "text/html"})
|
|
45
|
-
|
|
46
|
-
# 创建中间件实例
|
|
47
|
-
middleware = DefaultHeaderMiddleware(settings, "INFO")
|
|
48
|
-
|
|
49
|
-
print(f"随机User-Agent功能已启用: {middleware.random_user_agent_enabled}")
|
|
50
|
-
print(f"User-Agent设备类型: {middleware.user_agent_device_type}")
|
|
51
|
-
print(f"内置User-Agent列表数量: {len(middleware.user_agents)}")
|
|
52
|
-
|
|
53
|
-
# 测试获取随机User-Agent
|
|
54
|
-
print("\n随机User-Agent测试:")
|
|
55
|
-
for i in range(5):
|
|
56
|
-
random_ua = middleware._get_random_user_agent()
|
|
57
|
-
print(f" {i+1}. {random_ua}")
|
|
58
|
-
|
|
59
|
-
print()
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
def main():
|
|
63
|
-
"""主测试函数"""
|
|
64
|
-
print("开始测试随机User-Agent功能...\n")
|
|
65
|
-
|
|
66
|
-
test_random_user_agent_function()
|
|
67
|
-
test_default_header_middleware_with_random_ua()
|
|
68
|
-
|
|
69
|
-
print("所有测试完成!")
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
if __name__ == "__main__":
|
|
1
|
+
#!/usr/bin/env python
|
|
2
|
+
# -*- coding: utf-8 -*-
|
|
3
|
+
"""
|
|
4
|
+
测试随机User-Agent功能
|
|
5
|
+
"""
|
|
6
|
+
|
|
7
|
+
import sys
|
|
8
|
+
import os
|
|
9
|
+
|
|
10
|
+
# 添加项目根目录到Python路径
|
|
11
|
+
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..'))
|
|
12
|
+
|
|
13
|
+
from crawlo.data.user_agents import get_random_user_agent
|
|
14
|
+
from crawlo.middleware.default_header import DefaultHeaderMiddleware
|
|
15
|
+
from crawlo.settings.setting_manager import SettingManager
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
def test_random_user_agent_function():
|
|
19
|
+
"""测试随机User-Agent函数"""
|
|
20
|
+
print("=== 随机User-Agent函数测试 ===")
|
|
21
|
+
|
|
22
|
+
# 测试各种设备类型的随机User-Agent
|
|
23
|
+
device_types = ["desktop", "mobile", "all", "chrome", "firefox", "safari", "edge", "opera"]
|
|
24
|
+
|
|
25
|
+
for device_type in device_types:
|
|
26
|
+
print(f"\n{device_type}类型随机User-Agent:")
|
|
27
|
+
for i in range(3):
|
|
28
|
+
ua = get_random_user_agent(device_type)
|
|
29
|
+
print(f" {i+1}. {ua}")
|
|
30
|
+
|
|
31
|
+
print()
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
def test_default_header_middleware_with_random_ua():
|
|
35
|
+
"""测试DefaultHeaderMiddleware与随机User-Agent"""
|
|
36
|
+
print("=== DefaultHeaderMiddleware与随机User-Agent测试 ===")
|
|
37
|
+
|
|
38
|
+
# 创建设置管理器
|
|
39
|
+
settings = SettingManager()
|
|
40
|
+
settings.set("LOG_LEVEL", "INFO")
|
|
41
|
+
settings.set("RANDOM_USER_AGENT_ENABLED", True)
|
|
42
|
+
settings.set("USER_AGENT_DEVICE_TYPE", "all")
|
|
43
|
+
# 添加一个默认请求头以启用中间件
|
|
44
|
+
settings.set("DEFAULT_REQUEST_HEADERS", {"Accept": "text/html"})
|
|
45
|
+
|
|
46
|
+
# 创建中间件实例
|
|
47
|
+
middleware = DefaultHeaderMiddleware(settings, "INFO")
|
|
48
|
+
|
|
49
|
+
print(f"随机User-Agent功能已启用: {middleware.random_user_agent_enabled}")
|
|
50
|
+
print(f"User-Agent设备类型: {middleware.user_agent_device_type}")
|
|
51
|
+
print(f"内置User-Agent列表数量: {len(middleware.user_agents)}")
|
|
52
|
+
|
|
53
|
+
# 测试获取随机User-Agent
|
|
54
|
+
print("\n随机User-Agent测试:")
|
|
55
|
+
for i in range(5):
|
|
56
|
+
random_ua = middleware._get_random_user_agent()
|
|
57
|
+
print(f" {i+1}. {random_ua}")
|
|
58
|
+
|
|
59
|
+
print()
|
|
60
|
+
|
|
61
|
+
|
|
62
|
+
def main():
|
|
63
|
+
"""主测试函数"""
|
|
64
|
+
print("开始测试随机User-Agent功能...\n")
|
|
65
|
+
|
|
66
|
+
test_random_user_agent_function()
|
|
67
|
+
test_default_header_middleware_with_random_ua()
|
|
68
|
+
|
|
69
|
+
print("所有测试完成!")
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
if __name__ == "__main__":
|
|
73
73
|
main()
|