웹 프론트엔드 JS 튜토리얼 Angular 단위 테스트 작성을 위한 4가지 팁, 와서 살펴보세요!

Angular 단위 테스트 작성을 위한 4가지 팁, 와서 살펴보세요!

Aug 11, 2022 pm 08:22 PM
angular 단위 테스트

Angular단위 테스트를 수행하는 방법은 무엇입니까? 이 기사에서는 Angular 단위 테스트 작성을 위한 4가지 고급 기술을 공유하겠습니다. 이것이 도움이 되기를 바랍니다.

Angular 단위 테스트 작성을 위한 4가지 팁, 와서 살펴보세요!

테스트 아이디어:

  • 1. 단위 테스트가 가능하다면 단위 테스트를 우선적으로 시도하세요
  • 2. 단위 테스트가 불가능하다면, 테스트를 캡슐화하는 등의 캡슐화 레이어를 통해 테스트하세요. 하지만 통합 테스트보다 약한 부분이 있습니다.
  • 4. E2E 테스트
테스트의 난이도가 점점 높아지고 시간이 더 많이 걸립니다. 테스트를 간단하게 만들고 싶다면 개발 중에 의식적으로 아이디어를 명확하게 하고 간단하고 효율적인 코드를 작성해야 합니다~.

이 문서에 사용된 테스트 기술 스택:
Angular12

+Jasmine 다른 테스트 기술의 구문은 다르지만 전체적인 아이디어는 유사합니다. [관련 튜토리얼 추천: "angular tutorial"]

Tips: Jasmine 테스트 케이스 결정, 방법은 무엇인지 여기에서 찾을 수 있습니다.
Poke me

Unit test

컴포넌트, 기본값은 구성 요소입니다. Angular에서 다음 구문을 사용하여 생성한 테스트할 객체의 인스턴스

beforeEach(() => { 
  fixture = TestBed.createComponent(BannerComponent); 
  component = fixture.componentInstance; 
  fixture.detectChanges(); 
});
로그인 후 복사
Function test

1. 반환 값이 없는 함수 호출

function test(index:number ,fn:Function){
 if(fn){
     fn(index);
 }
}
로그인 후 복사

테스트 방법은 무엇입니까?

카운터 예: 정의되지 않은 반환 값을 직접 테스트

  const res = component.test(1,() => {}));
  expect(res).tobeUndefined();
로그인 후 복사
권장 사례:

 # 利用Jasmine
 it('should get correct data when call test',() =>{
     const param = {
       fn:() => {}
    }
   spyOn(param,'fn')
   component.test(1,param.fn);
   expect(param.fn).toHaveBeenCalled();
 })
로그인 후 복사
구조 지침 HostListener 테스트

구조 지침, 일반 용어 숨기기, 표시 및 이러한 기능을 표시하는 for 루프

 # code
 @Directive({ selector: '[ImageURlError]' })
export class ImageUrlErrorDirective implements OnChanges {
  constructor(private el: ElementRef) {}
  
  @HostListener('error')
  public error() { 
      this.el.nativeElement.style.display = 'none';
  } 
}
로그인 후 복사
테스트 방법은?

테스트 아이디어:

이미지 로딩 오류가 발생하면 오류를 발생시키는 방법을 찾으세요
  • 명령은 일반적으로 구성 요소 이미지 요소에 연결되어 있으며 dispath
  • #1.添加一个自定义组件, 并添加上自定义指令
    @Component({
      template: `<div>
        <image src="https://xxx.ss.png" ImageURlError></image>
      </div>`
    })
    class TestHostComponent {
    
    }
    
    #2.把自定义组件视图实例化,并派发errorEvent
    beforeEach(waitForAsync(() => {
        TestBed.configureTestingModule({
            declarations: [
                TestHostComponent,
                ImageURlError
            ]
        });
    }));
    
    beforeEach(() => { 
     fixture = TestBed.createComponent(TestHostComponent); 
     component = fixture.componentInstance; 
     fixture.detectChanges();
    });
      
    it('should allow numbers only', () => {
        const event = new ErrorEvent('error', {} as any);
        const image = fixture.debugElement.query(By.directive(ImageURlError));
        image.nativeElement.dispatchEvent(event); //派发事件即可,此时error()方法就会被执行到
    });
    로그인 후 복사
    에서 errorEvent를 사용하세요.
Make public, private 및 protected 수정자를 잘 사용하세요

Angular에서는 spec.ts가 공개인 경우에 액세스할 수 있지만 비공개이거나 보호된 경우에는 액세스할 수 없습니다. blackboard

단위 테스팅과 테스트 메소드를 하나씩 할 예정이라면 공개적으로 적절히 활용해주세요 --- 난이도 *

각 메소드 테스트를 할 예정이 아니라면 자료 정리는 입구로 전화주세요 , 통합 테스트를 통해 메서드 전달 -- 난이도 ***

  • 클릭 이벤트 테스트
클릭 이벤트 트리거, 클릭에 대한 직접 js 호출이 있고 클릭 이벤트를 트리거하는 마우스 시뮬레이션도 있습니다.

# xx.component.ts
@Component({
 selecotr: 'dashboard-hero-list'
})
class DashBoardHeroComponent {
    public cards = [{
        click: () => {
            .....
        }
    }]
}
# html
<dashboard-hero-list [cards]="cards"  class="card">
</dashboard-hero-list>`
로그인 후 복사
테스트 방법은?

테스트 아이디어:

Host를 사용하지 않고 구성 요소를 직접 테스트

코드에서 반환된 클릭 이벤트가 포함된 개체 컬렉션을 사용하여 하나씩 클릭을 호출하면 코드 적용 범위가 향상됩니다.

it('should get correct data when call click',() => {
    const cards = component.cards;
    cards?.forEach(card => {
        if(card.click){
            card.click(new Event('click'));
        }
    });
    expect(cards?.length).toBe(1);
});
로그인 후 복사
  • 다른 클릭에 대한 아이디어 참조:
  • 아이디어 1:

TestHostComponent를 사용하여 테스트해야 하는 구성 요소를 래핑합니다.

그런 다음 Fixture.nativeElement.querySelector('.card')를 사용하여 바인딩된 클릭 요소를 찾습니다.

요소에서 dispatchEvent를 트리거합니다. 즉,
  • 아이디어 2:
  • Host

    를 사용하지 않고 직접 구성 요소를 테스트한 다음 Fixture.nativeElement.querySelector('.card')를 사용하여 찾습니다. 바운드 클릭 요소
  • triggerEventHandler 사용

    ('click');

  • 더 많은 프로그래밍 관련 지식을 보려면 프로그래밍 비디오를 방문하세요! !

위 내용은 Angular 단위 테스트 작성을 위한 4가지 팁, 와서 살펴보세요!의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Java의 인터페이스 및 추상 클래스에 대한 단위 테스트 방법 Java의 인터페이스 및 추상 클래스에 대한 단위 테스트 방법 May 02, 2024 am 10:39 AM

Java의 단위 테스트 인터페이스 및 추상 클래스를 위한 단계: 인터페이스에 대한 테스트 클래스를 만듭니다. 인터페이스 메서드를 구현하는 모의 클래스를 만듭니다. Mockito 라이브러리를 사용하여 인터페이스 메소드를 모의하고 테스트 메소드를 작성하십시오. 추상 클래스는 테스트 클래스를 생성합니다. 추상 클래스의 하위 클래스를 만듭니다. 추상 클래스의 정확성을 테스트하는 테스트 메서드를 작성합니다.

Go 언어의 성능 테스트와 단위 테스트의 차이점 Go 언어의 성능 테스트와 단위 테스트의 차이점 May 08, 2024 pm 03:09 PM

성능 테스트는 다양한 로드 하에서 애플리케이션의 성능을 평가하는 반면, 단위 테스트는 단일 코드 단위의 정확성을 확인합니다. 성능 테스트는 응답 시간과 처리량 측정에 중점을 두는 반면, 단위 테스트는 기능 출력 및 코드 적용 범위에 중점을 둡니다. 성능 테스트는 높은 로드 및 동시성으로 실제 환경을 시뮬레이션하는 반면, 단위 테스트는 낮은 로드 및 직렬 조건에서 실행됩니다. 성능 테스트의 목표는 성능 병목 현상을 식별하고 애플리케이션을 최적화하는 것이며, 단위 테스트의 목표는 코드 정확성과 견고성을 보장하는 것입니다.

PHP 단위 테스트 도구의 장점과 단점 분석 PHP 단위 테스트 도구의 장점과 단점 분석 May 06, 2024 pm 10:51 PM

PHP 단위 테스트 도구 분석: PHPUnit: 대규모 프로젝트에 적합하고 포괄적인 기능을 제공하며 설치가 쉽지만 장황하고 느릴 수 있습니다. PHPUnitWrapper: 소규모 프로젝트에 적합하고 사용하기 쉽고 Lumen/Laravel에 최적화되어 있지만 기능이 제한적이고 코드 적용 범위 분석을 제공하지 않으며 커뮤니티 지원이 제한되어 있습니다.

Golang 단위 테스트에서 테이블 기반 테스트 방법을 사용하는 방법은 무엇입니까? Golang 단위 테스트에서 테이블 기반 테스트 방법을 사용하는 방법은 무엇입니까? Jun 01, 2024 am 09:48 AM

테이블 기반 테스트는 테이블을 통해 입력 및 예상 출력을 정의하여 Go 단위 테스트에서 테스트 사례 작성을 단순화합니다. 구문에는 다음이 포함됩니다. 1. 테스트 케이스 구조를 포함하는 슬라이스를 정의합니다. 2. 슬라이스를 반복하고 결과를 예상 출력과 비교합니다. 실제 사례에서는 문자열을 대문자로 변환하는 기능에 대해 테이블 ​​드리븐 테스트를 진행하였고, gotest를 이용하여 테스트를 진행하였고 합격 결과를 출력하였다.

golang 기능 테스트에서 단위 테스트와 통합 테스트의 차이점은 무엇입니까? golang 기능 테스트에서 단위 테스트와 통합 테스트의 차이점은 무엇입니까? Apr 27, 2024 am 08:30 AM

단위 테스트와 통합 테스트는 각각 단일 기능 또는 여러 기능의 상호 작용 및 통합을 확인하는 데 사용되는 두 가지 유형의 Go 기능 테스트입니다. 단위 테스트는 특정 기능의 기본 기능만 테스트하는 반면, 통합 테스트는 여러 기능 간의 상호 작용과 애플리케이션의 다른 부분과의 통합을 테스트합니다.

PHP 단위 테스트: 효과적인 테스트 사례를 설계하는 방법 PHP 단위 테스트: 효과적인 테스트 사례를 설계하는 방법 Jun 03, 2024 pm 03:34 PM

원자성, 간결성, 반복 가능성 및 모호성 없음이라는 원칙을 준수하여 효과적인 단위 테스트 케이스를 설계하는 것이 중요합니다. 단계에는 테스트할 코드 결정, 테스트 시나리오 식별, 어설션 생성 및 테스트 메서드 작성이 포함됩니다. 실제 사례에서는 max() 함수에 대한 테스트 사례 생성을 보여주며 특정 테스트 시나리오와 주장의 중요성을 강조합니다. 이러한 원칙과 단계를 따르면 코드 품질과 안정성을 향상시킬 수 있습니다.

PHP 단위 테스트: 코드 적용 범위를 늘리는 팁 PHP 단위 테스트: 코드 적용 범위를 늘리는 팁 Jun 01, 2024 pm 06:39 PM

PHP 단위 테스트에서 코드 적용 범위를 개선하는 방법: PHPUnit의 --coverage-html 옵션을 사용하여 적용 범위 보고서를 생성합니다. 비공개 메소드와 속성을 재정의하려면 setAccessible 메소드를 사용하세요. 어설션을 사용하여 부울 조건을 재정의합니다. 코드 검토 도구를 사용하여 추가 코드 적용 범위에 대한 통찰력을 얻으세요.

PHP 단위 테스트 및 지속적 전달 통합 PHP 단위 테스트 및 지속적 전달 통합 May 06, 2024 pm 06:45 PM

요약: PHPUnit 단위 테스트 프레임워크와 CI/CD 파이프라인을 통합하면 PHP 코드 품질을 향상하고 소프트웨어 제공을 가속화할 수 있습니다. PHPUnit을 사용하면 구성 요소 기능을 확인하기 위한 테스트 사례를 생성할 수 있으며 GitLabCI 및 GitHubActions와 같은 CI/CD 도구는 이러한 테스트를 자동으로 실행할 수 있습니다. 예: 테스트 케이스로 인증 컨트롤러의 유효성을 검사하여 로그인 기능이 예상대로 작동하는지 확인합니다.

See all articles