다음을 통해 공유


데이터베이스 단위 테스트의 스크립트

각 데이터베이스 단위 테스트에는 하나의 테스트 전 작업, 테스트 작업 및 테스트 후 작업이 있습니다. 이러한 각 작업에는 다음이 포함되어 있습니다.

  • 데이터베이스에 대해 실행되는 Transact-SQL 스크립트

  • 스크립트 실행에서 반환된 결과를 평가하는 0개 이상의 테스트 조건

테스트 작업의 Transact-SQL 테스트 스크립트는 모든 데이터베이스 단위 테스트에 포함해야 하는 유일한 구성 요소입니다. 테스트 스크립트 자체 외에도 테스트 조건을 지정하여 테스트 스크립트에서 예상한 값 또는 값 집합을 반환했는지 여부를 확인할 수 있습니다. 테스트 작업은 해당 데이터베이스의 특정 개체를 연습하거나 변경한 다음 변경 내용을 평가합니다.

각 테스트 작업에 대해 테스트 전 작업과 테스트 후 작업을 하나씩 포함할 수 있습니다. 테스트 작업과 마찬가지로 각 테스트 전 작업과 테스트 후 작업에는 하나의 Transact-SQL 스크립트와 0개 이상의 테스트 조건이 있습니다. 테스트 전 작업을 사용하여 데이터베이스가 테스트 작업을 실행하고 의미 있는 결과를 반환할 수 있는 상태인지 확인할 수 있습니다. 예를 들어 테스트 스크립트에서 해당 데이터에 대해 작업을 수행하기 전에 테스트 전 작업을 사용하여 테이블에 데이터가 있는지 확인할 수 있습니다. 테스트 전 작업에서 데이터베이스를 준비하고 테스트 작업에서 의미 있는 결과를 반환한 후 테스트 후 작업은 데이터베이스를 테스트 전 작업이 실행되기 전의 상태로 되돌립니다. 경우에 따라 테스트 후 작업을 사용하여 테스트 작업 결과의 유효성을 검사할 수도 있습니다. 이는 테스트 후 작업의 데이터베이스 권한이 테스트 작업보다 더 클 수 있기 때문입니다. 자세한 내용은 연결 문자열 및 권한 개요를 참조하십시오.

이러한 세 가지 작업 외에도 데이터베이스 단위 테스트가 실행되기 전후에 실행되는 두 개의 테스트 스크립트(일반 스크립트)가 있습니다. 따라서 데이터베이스 단위 테스트 하나를 실행하는 동안 최대 5개의 Transact-SQL 스크립트가 실행될 수 있습니다. 테스트 작업에 포함된 Transact-SQL 스크립트만 필수 사항이고, 일반 스크립트와 테스트 전 및 테스트 후 작업 스크립트는 선택 사항입니다.

다음 표에서는 데이터베이스 단위 테스트와 연결된 전체 스크립트 목록을 제공합니다.

작업

스크립트 형식

설명

TestInitialize

일반 스크립트(초기화)

(선택 사항) 이 스크립트는 단위 테스트에 있는 모든 테스트 전 및 테스트 작업보다 우선합니다. TestInitialize 스크립트는 지정된 테스트 클래스의 각 단위 테스트보다 먼저 실행됩니다. 이 스크립트는 권한 있는 컨텍스트를 사용하여 실행됩니다.

테스트 전

테스트 스크립트

(선택 사항) 이 스크립트는 단위 테스트의 일부입니다. 테스트 전 스크립트는 단위 테스트 내의 테스트 작업보다 먼저 실행됩니다. 이 스크립트는 권한 있는 컨텍스트를 사용하여 실행됩니다.

테스트

테스트 스크립트

(필수 사항) 이 스크립트는 단위 테스트의 일부입니다. 테스트 스크립트는 데이터베이스에 대해 실행됩니다. 예를 들어 이 스크립트는 테이블 값을 가져오거나 삽입 또는 업데이트하는 저장 프로시저를 실행할 수 있습니다. 이 스크립트는 실행 컨텍스트를 사용하여 실행됩니다.

테스트 후

테스트 스크립트

(선택 사항) 이 스크립트는 단위 테스트의 일부입니다. 테스트 후 스크립트는 개별 단위 테스트 이후에 실행됩니다. 이 스크립트는 권한 있는 컨텍스트를 사용하여 실행됩니다.

TestCleanup

일반 스크립트(정리)

(선택 사항) 이 스크립트는 단위 테스트 이후에 실행됩니다. TestCleanup 스크립트는 지정된 테스트 클래스의 모든 단위 테스트 이후에 실행됩니다. 이 스크립트는 권한 있는 컨텍스트를 사용하여 실행됩니다.

이러한 각 스크립트가 실행되는 여러 보안 컨텍스트에 대한 자세한 내용은 연결 문자열 및 권한 개요Visual Studio의 데이터베이스 기능에 필요한 권한의 데이터베이스 단위 테스트 권한 단원을 참조하십시오.

스크립트가 실행되는 순서

각 스크립트가 실행되는 순서를 이해하는 것이 중요합니다. 이 순서를 변경할 수는 없지만 실행할 스크립트를 결정할 수 있습니다. 다음 그림에서는 두 개의 데이터베이스 단위 테스트가 포함된 테스트 실행에서 사용할 수 있는 스크립트 및 이러한 스크립트가 실행되는 순서를 보여 줍니다.

두 개의 데이터베이스 단위 테스트

참고

데이터 생성 및 데이터베이스 배포 변경 내용은 스크립트가 실행되기 전, 테스트 실행 시작 시 적용됩니다. 이러한 변경 내용은 권한 있는 컨텍스트 연결 문자열을 사용하여 적용됩니다. 자세한 내용은 방법: 데이터베이스 단위 테스트 실행 구성을 참조하십시오.

초기화 및 정리 스크립트

데이터베이스 단위 테스트 디자이너에서 TestInitialize 및 TestCleanup 스크립트는 일반 스크립트라고 합니다. 앞의 예제에서는 두 개의 단위 테스트가 동일한 테스트 클래스에 속해 있다고 가정합니다. 따라서 두 테스트는 같은 TestInitialize 및 TestCleanup 스크립트를 공유합니다. 이는 단일 테스트 클래스 내의 모든 단위 테스트에 항상 적용됩니다. 하지만 테스트 실행에 여러 테스트 클래스의 단위 테스트가 포함된 경우 연결된 테스트 클래스에 대한 일반 스크립트가 단위 테스트 실행 전후에 실행됩니다.

데이터베이스 단위 테스트 디자이너만 사용하여 단위 테스트를 작성하는 경우 테스트 클래스의 개념을 잘 모를 수도 있습니다. 테스트 메뉴를 열고 새 테스트를 클릭하여 단위 테스트를 만들 때마다 Visual Studio Premium에서 테스트 클래스를 생성합니다. 테스트 클래스는 지정한 테스트 이름으로 솔루션 탐색기에 나타나고, 뒤에 .cs 또는 .vb 확장명이 있습니다. 각 테스트 클래스 내에서 개별 단위 테스트는 테스트 메서드로 저장됩니다. 하지만 테스트 메서드(즉, 단위 테스트) 수에 관계없이 각 테스트 클래스에는 0개 또는 하나의 TestInitialize 및 TestCleanup 스크립트가 있을 수 있습니다.

TestInitialize 스크립트를 사용하여 테스트 데이터베이스를 준비할 수 있고 TestCleanup 스크립트를 사용하여 테스트 데이터베이스를 알려진 상태로 되돌릴 수 있습니다. 예를 들어 TestInitialize를 사용하여 도우미 저장 프로시저를 만들고 나중에 테스트 스크립트에서 이 프로시저를 실행하여 다른 저장 프로시저를 테스트할 수 있습니다.

테스트 전 및 테스트 후 스크립트

테스트 전 및 테스트 후 작업과 연결된 스크립트는 단위 테스트마다 달라집니다. 이러한 스크립트를 사용하여 데이터베이스에 대한 증분 변경 내용을 설정한 다음 변경 내용을 정리할 수 있습니다.

참고 항목

개념

데이터베이스 단위 테스트에서 테스트 조건 사용