Vedro는 플러그인 시스템을 통해 강력한 확장성을 제공하므로 다양한 프로젝트와 팀에서 공유할 수 있는 강력하고 재사용 가능한 솔루션을 만들 수 있습니다. 하지만 단지 코드베이스를 실험하거나, 개념을 프로토타입화하거나, 약간의 수정을 추가하는 중이라면 어떻게 될까요? 전체 플러그인을 작성하는 것은 지나친 것처럼 느껴질 수 있습니다. 이것이 vedro-hooks가 들어오는 곳입니다.
vedro-hooks는 다양한 Vedro 이벤트에 맞춤형 후크를 연결할 수 있는 경량 라이브러리입니다. 테스트 실행 전에 모의 서버를 시작하든, 엔드투엔드 테스트를 위해 브라우저를 시작하든, 사용자 정의 로깅을 설정하든 vedro-hooks를 사용하면 최소한의 상용구로 기능을 주입할 수 있습니다.
스위트에서 느린 테스트를 식별하고 싶다고 가정해 보겠습니다. 실행하는 데 1초 이상 걸리는 테스트를 "느림"으로 정의해 보겠습니다. 일반적으로 이를 위해서는 사용자 정의 플러그인을 만들어야 합니다. 그 모습은 다음과 같습니다.
from vedro.core import Dispatcher, Plugin, PluginConfig from vedro.events import ScenarioFailedEvent, ScenarioPassedEvent class SlowTestPlugin(Plugin): def subscribe(self, dispatcher: Dispatcher): dispatcher.listen(ScenarioPassedEvent, self.on_scenario_end) dispatcher.listen(ScenarioFailedEvent, self.on_scenario_end) def on_scenario_end(self, event: ScenarioPassedEvent | ScenarioFailedEvent): elapsed = event.scenario_result.elapsed if elapsed > 1.0: event.scenario_result.add_extra_details("⚠️ Slow test!") class SlowTestPluginConfig(PluginConfig): plugin = SlowTestPlugin
이 접근 방식은 효과적이지만 완전한 플러그인을 만들려면 더 많은 설정과 추가 상용구가 필요합니다. 재사용 가능한 솔루션에는 좋지만 빠른 실험에는 번거로울 수 있습니다.
vedro-hooks를 사용하면 단 몇 줄의 코드만으로 동일한 기능을 얻을 수 있습니다.
from vedro_hooks import on_scenario_passed, on_scenario_failed @on_scenario_passed @on_scenario_failed def highlight_slow_tests(event): elapsed = event.scenario_result.elapsed if elapsed > 1.0: event.scenario_result.add_extra_details("⚠️ Slow test!")
이 코드는 데코레이터를 사용하여 시나리오가 성공하거나 실패할 때 호출되는 함수를 등록합니다. 경과 시간을 확인하고 시나리오가 1초 이상 소요된 경우 세부 정보를 추가합니다.
Scenarios * ✔ retrieve user info (0.52s) ✔ retrieve user repos (1.02s) |> ⚠️ Slow test! # 2 scenarios, 2 passed, 0 failed, 0 skipped (1.54s)
이런 방식으로 후크를 사용할 때의 한 가지 단점은 프로젝트의 어느 곳에서나 등록할 수 있어 나중에 추적하기가 더 어려워질 수 있다는 것입니다. 반면, Vedro의 플러그인은 vedro.cfg.py 파일에 등록되어 모든 플러그인 구성을 위한 중앙 위치를 제공합니다.
코드베이스 전체에 등록되는 후크의 단점을 완화하기 위해 vedro-hooks는 --hooks-show 명령줄 인수를 제공합니다. 활성화되면 테스트 프로세스가 완료된 후 등록된 모든 후크의 요약과 해당 소스 위치가 표시됩니다. 이는 활성화된 후크를 디버깅하고 확인하는 데 유용합니다.
Scenarios * ✔ retrieve user repos # [vedro-hooks] Hooks: # - 'highlight_slow_tests' (ScenarioFailedEvent) vedro.cfg.py:26 # - 'highlight_slow_tests' (ScenarioPassedEvent) vedro.cfg.py:26 # 1 scenario, 1 passed, 0 failed, 0 skipped (0.55s)
--hooks-show가 도움이 되지만 디버깅 중에도 사용해야 한다는 점을 기억해야 합니다. 플러그인 구성의 명확성과 일관성을 유지하려면 vedro.cfg.py와 같은 중앙 위치에 후크를 등록하는 것이 여전히 모범 사례입니다.
vedro-hooks는 사용자 정의 플러그인을 만드는 오버헤드 없이 Vedro 테스트를 향상할 수 있는 환상적인 도구입니다. 기능 확장을 위해 빠르고 집중적인 솔루션이 필요할 때 빛을 발합니다. 현명하게 사용하고 구성을 체계적으로 유지하면 단순성과 유지 관리성이라는 두 가지 장점을 모두 누릴 수 있습니다.
위 내용은 베드로 후크의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!