베드로 후크

Susan Sarandon
풀어 주다: 2024-11-30 13:32:11
원래의
479명이 탐색했습니다.

Vedro Hooks

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
로그인 후 복사

이 접근 방식은 효과적이지만 완전한 플러그인을 만들려면 더 많은 설정과 추가 상용구가 필요합니다. 재사용 가능한 솔루션에는 좋지만 빠른 실험에는 번거로울 수 있습니다.

Hooks로 단순화하기

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)
로그인 후 복사

Hook 관리: 단점과 해결책

이런 방식으로 후크를 사용할 때의 한 가지 단점은 프로젝트의 어느 곳에서나 등록할 수 있어 나중에 추적하기가 더 어려워질 수 있다는 것입니다. 반면, 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿