KR101073816B1 - 시나리오 기반의 데이터베이스 시험 자동화 방법 및 시스템 - Google Patents

시나리오 기반의 데이터베이스 시험 자동화 방법 및 시스템 Download PDF

Info

Publication number
KR101073816B1
KR101073816B1 KR1020080129390A KR20080129390A KR101073816B1 KR 101073816 B1 KR101073816 B1 KR 101073816B1 KR 1020080129390 A KR1020080129390 A KR 1020080129390A KR 20080129390 A KR20080129390 A KR 20080129390A KR 101073816 B1 KR101073816 B1 KR 101073816B1
Authority
KR
South Korea
Prior art keywords
scenario
database
test
result
verification result
Prior art date
Application number
KR1020080129390A
Other languages
English (en)
Other versions
KR20100070713A (ko
Inventor
김동진
Original Assignee
주식회사 코아로직
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 주식회사 코아로직 filed Critical 주식회사 코아로직
Priority to KR1020080129390A priority Critical patent/KR101073816B1/ko
Publication of KR20100070713A publication Critical patent/KR20100070713A/ko
Application granted granted Critical
Publication of KR101073816B1 publication Critical patent/KR101073816B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • G06F30/20Design optimisation, verification or simulation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3668Software testing
    • G06F11/3672Test management
    • G06F11/3692Test management for test results analysis
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3668Software testing
    • G06F11/3696Methods or tools to render software testable

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Quality & Reliability (AREA)
  • Evolutionary Computation (AREA)
  • Geometry (AREA)
  • Debugging And Monitoring (AREA)

Abstract

본 발명은 데이터베이스 시험에 관한 것으로서, 더욱 상세하게는, 시나리오를 기반으로 데이터베이스의 엔진이 정상적으로 기능하는지에 대한 시험을 자동화하는 시스템 및 방법에 관한 것이다. 시나리오 데이터베이스 서버는 시험 대상 데이터베이스를 시험하기 위한 시나리오들 및 이에 대응하는 검증 결과들이 등록될 수 있는 시나리오 데이터베이스를 포함한다. 상기 시험 대상 데이터베이스의 시험을 자동화하기 위한 적어도 하나의 데이터베이스 시험 자동화 장치는 상기 시나리오 데이터베이스 서버와 상기 시험 대상 데이터베이스에 네트워크를 통해 연결되며, 상기 시나리오들 및 상기 검증 결과들을 상기 시나리오 데이터베이스에 등록하기 위한 시나리오 등록부, 및 상기 시나리오들을 이용하여 상기 시험 대상 데이터베이스를 시험하기 위한 데이터베이스 시험부를 포함한다.

Description

시나리오 기반의 데이터베이스 시험 자동화 방법 및 시스템{Method and system for automatically testing database system based on scenario}
본 발명은 데이터베이스 시험에 관한 것으로서, 더욱 상세하게는, 시나리오를 기반으로 데이터베이스의 엔진이 정상적으로 기능하는지에 대한 시험을 자동화하는 시스템 및 방법에 관한 것이다.
데이터베이스는 여러 응용 시스템들의 통합된 정보들을 저장하여 운영할 수 있는 데이터들의 묶음이다. 정보가 기하 급수적으로 증가함에 따라, 이러한 정보들을 구조적으로 그리고 효율적으로 저장할 수 있는 데이터베이스에 대한 수요도 함께 증가하고 있으며, 다양한 데이터베이스들이 개발되고 있다. 새롭게 개발되는 데이터베이스는 데이터베이스에 관한 표준안을 만족하여야 한다. 뿐만 아니라 표준안이 새롭게 패치 됨에 따라서 새롭게 패치된 표준안을 만족하는지에 대한 시험도 많이 필요하게 되었다.
종래에는 이러한 시험을 일일이 수동으로 수행하였다. 이미 개발 완료되었거나 이미 새로운 표준안이 패치된 검증된 데이터베이스와 새롭게 개발되거나 새로운 표준안을 패치할 시험 대상 데이터베이스에 동일한 데이터들을 입력한 후 동일 한 질문을 수행하고, 그 결과가 일치하는지 비교하였다. 시험 대상 데이터베이스 하나를 시험하기 위해서 검증된 데이터베이스 하나가 필요하여, 검증된 데이터베이스에 문제가 생기면 시험을 수행할 수 없었으며, 시험 대상 데이터베이스가 많으면 그 수에 비례하여 시간과 인력이 필요하였다. 뿐만 아니라, 시험에 사용되는 동일한 데이터들과 질문은 시험 운용자의 노하우로 남게 되어 다른 시험 운용자와 공유하기 어려웠으며, 시험 결과가 통합적으로 관리되기 어려웠다.
이하에서, 시험 대상 데이터베이스의 특정 기능을 시험하기 위해 데이터를 입력하고 질문을 수행하는 과정들을 일련의 텍스트들로 작성된 것을 시나리오로 언급한다.
따라서, 본 발명이 이루고자 하는 기술적 과제는, 데이터베이스의 시험을 자동화하기 위한 방법 및 시스템을 제공하는 것이다.
또한, 본 발명이 이루고자 하는 다른 기술적 과제는, 데이터베이스를 개발하는 다수의 개발자들이 효율적으로 시험하기 위한 시스템을 제공하는 것이다.
또한, 본 발명이 이루고자 하는 또 다른 기술적 과제는, 데이터베이스의 시험 결과를 통합적으로 관리하여, 성능 변화 추이나 버그 추적 등에 이용될 수 있는 시스템을 제공하는 것이다.
상기 기술적 과제를 달성하기 위한 본 발명의 일 태양에 따른 데이터베이스 시험 자동화 방법이 제공된다. 시나리오 등록 단계에서, 시험 대상 데이터베이스를 시험하기 위한 시나리오, 및 상기 시나리오에 대응하고 검증된 데이터베이스를 이용하여 생성된 검증 결과가 원격 시나리오 데이터베이스에 등록된다. 데이터베이스 시험 단계에서, 상기 시나리오를 이용하여 상기 시험 대상 데이터베이스가 시험된다. 여기서, 상기 시험 대상 데이터베이스, 상기 검증된 데이터베이스 및 상기 시험 대상 데이터베이스는 네트워크를 통해 연결된다.
상기 데이터베이스 시험 자동화 방법의 일 예에 따르면, 상기 시나리오 등록 단계는, 상기 시나리오를 작성하는 시나리오 작성 단계; 상기 검증된 데이터베이스에 접속하여, 상기 시나리오를 상기 검증된 데이터베이스에 대해 수행하고, 수행한 결과를 검증 결과로서 수신하는 검증 결과 생성 단계; 및 상기 시나리오와 상기 검증 결과를 상기 원격 시나리오 데이터베이스에 접속하여 등록하는 시나리오 및 검증 결과 등록 단계를 포함할 수 있다. 또한, 상기 데이터베이스 시험 단계는, 상기 원격 시나리오 데이터베이스에 접속하여, 상기 시나리오와 상기 검증 결과를 언로드하는 시나리오 언로드 단계; 상기 시험 대상 데이터베이스에 접속하여, 상기 언로드한 시나리오를 상기 시험 대상 데이터베이스에 대해 수행하고, 수행한 결과를 시험 결과로서 수신하는 시나리오 수행 단계; 및 상기 시험 결과와 상기 언로드한 검증 결과를 비교하고, 최종 결과를 상기 원격 시나리오 데이터베이스에 접속하여 등록하는 최종 결과 생성 단계를 포함할 수 있다.상기 데이터베이스 시험 자동화 방법의 다른 예에 따르면, 상기 시나리오 등록 단계와 상기 데이터베이스 시험 단계는 서로 다른 데이터베이스 시험 자동화 장치들에서 실행될 수 있다.
상기 데이터베이스 시험 자동화 방법의 또 다른 예에 따르면, 상기 데이터베이스 시험 단계는 다수의 시험 대상 데이터베이스들에 대해 다수의 데이터베이스 시험 자동화 장치들에서 독립적으로 실행될 수 있다.
상기 데이터베이스 시험 자동화 방법의 또 다른 예에 따르면, 상기 시나리오는 시험 대상 데이터베이스가 SQL 표준을 만족하는지의 여부를 시험하기 위한 시나리오를 포함할 수 있다.
상기 데이터베이스 시험 자동화 방법의 또 다른 예에 따르면, 상기 시나리오 등록 단계는, 상기 시나리오를 작성하는 시나리오 작성 단계; 상기 시나리오에 대응하는 검증 결과를 생성하는 검증 결과 생성 단계; 및 상기 시나리오와 상기 검증 결과를 상기 원격 시나리오 데이터베이스에 접속하여 등록하는 시나리오 및 검증 결과 등록 단계를 포함할 수 있다. 상기 시나리오 등록 단계를 반복함에 따라, 상기 원격 시나리오 데이터베이스에는 다수의 시나리오들 및 이들에 대응하는 다수의 검증 결과들이 등록될 수 있으며, 상기 데이터베이스 시험 단계는, 상기 원격 시나리오 데이터베이스에 접속하여, 상기 원격 시나리오 데이터베이스에 등록된 상기 다수의 시나리오들 중에서 상기 시험 대상 데이터베이스를 시험할 시나리오를 선택하는 시나리오 선택 단계; 상기 선택된 시나리오와 이에 대응하는 검증 결과를 언로드하여 로컬 저장 장치에 저장하는 시나리오 언로드 단계; 상기 시험 대상 데이터베이스에 접속하여, 상기 언로드한 시나리오를 상기 시험 대상 데이터베이스에 대해 수행하고 수행한 결과를 시험 결과로서 수신하는 시나리오 수행 단계; 및 상기 시험 결과와 상기 언로드한 검증 결과를 비교하고, 최종 결과를 상기 원격 시나리오 데이터베이스에 접속하여 등록하는 최종 결과 생성 단계를 포함할 수 있다.
상기 데이터베이스 시험 자동화 방법의 또 다른 예에 따르면, 상기 검증 결과 생성 단계는, 상기 검증된 데이터베이스에 접속하여, 상기 시나리오를 상기 검증된 데이터베이스에 대해 수행하고, 수행된 결과를 상기 검증 결과로서 수신하는 단계를 포함할 수 있다.
상기 데이터베이스 시험 자동화 방법의 또 다른 예에 따르면, 상기 시나리오 선택 단계에서 상기 다수의 시나리오들 중에서 복수개의 시나리오들이 선택될 수 있으며, 그에 따라, 상기 시나리오 언로드 단계에서 상기 복수개의 시나리오들이 언로드될 수 있으며, 상기 시나리오 수행 단계에서 상기 복수개의 시나리오들이 상 기 시험 대상 데이터베이스에 대해 연속하여 수행될 수 있다.
상기 데이터베이스 시험 자동화 방법의 또 다른 예에 따르면, 상기 데이터베이스 시험 단계를 반복함에 따라, 상기 로컬 저장 장치에는 다수의 언로드된 시나리오들 및 이들에 대응하는 다수의 언로드된 검증 결과들이 저장된다. 이 경우, 상기 시나리오 선택 단계와 상기 시나리오 언로드 단계 사이에, 상기 시나리오 선택 단계에서 선택된 시나리오가 상기 로컬 저장 장치에 저장되어 있는지, 그리고 상기 로컬 저장 장치에 저장된 시나리오와 일치하는지를 확인하는 단계를 더 포함할 수 있으며, 상기 로컬 저장 장치에 존재하지 않거나 상기 로컬 저장 장치에 존재하는 시나리오와 일치하지 않는 경우에만, 상기 시나리오 언로드 단계에서 상기 선택된 시나리오와 이에 대응하는 검증 결과를 언로드하여 로컬 저장 장치에 저장할 수 있다. 또한, 상기 시나리오 선택 단계에서 선택된 시나리오가 상기 로컬 저장 장치에 저장된 시나리오와 일치하는 경우, 상기 로컬 저장 장치에 저장된 상기 시나리오와 이에 대응하는 검증 결과를 이용하여 상기 시나리오 수행 단계 및 상기 최종 결과 생성 단계를 실행할 수 있다.
상기 기술적 과제를 달성하기 위한 본 발명의 일 태양에 따른 컴퓨터에 상기 데이터베이스 시험 자동화 방법을 실행시키기 위한 프로그램을 기록한 컴퓨터로 읽을 수 있는 매체가 제공된다
상기 기술적 과제를 달성하기 위한 본 발명의 일 태양에 따른 데이터베이스 시험 자동화 시스템이 제공된다. 시나리오 데이터베이스 서버는 시험 대상 데이터베이스를 시험하기 위한 시나리오들 및 이에 대응하는 검증 결과들이 등록될 수 있 는 시나리오 데이터베이스를 포함한다. 상기 시험 대상 데이터베이스의 시험을 자동화하기 위한 적어도 하나의 데이터베이스 시험 자동화 장치는 상기 시나리오 데이터베이스 서버와 상기 시험 대상 데이터베이스에 네트워크를 통해 연결되며, 상기 시나리오들 및 상기 검증 결과들을 상기 시나리오 데이터베이스에 등록하기 위한 시나리오 등록부; 및 상기 시나리오들을 이용하여 상기 시험 대상 데이터베이스를 시험하기 위한 데이터베이스 시험부를 포함한다.
상기 데이터베이스 시험 자동화 시스템의 일 예에 따르면, 상기 시나리오 등록부는, 상기 시나리오들을 작성하기 위한 인터페이스를 제공하는 시나리오 작성 인터페이스 모듈; 상기 작성된 시나리오들에 대응하는 검증 결과들을 생성하기 위한 검증 결과 생성 모듈; 및 상기 작성된 시나리오들 및 상기 검증 결과들을 상기 시나리오 데이터베이스에 접속하여 등록하기 위한 시나리오 등록 모듈을 포함할 수 있다. 또한, 상기 데이터베이스 시험부는, 상기 시나리오 데이터베이스에 접속하여 상기 시나리오 데이터베이스에 등록된 상기 시나리오들 중에서 상기 시험 대상 데이터베이스를 시험할 시나리오를 선택하기 위한 인터페이스를 제공하는 시험 시나리오 선택 인터페이스 모듈; 상기 시나리오 데이터베이스에 접속하여 상기 선택된 시나리오와 이에 대응하는 검증 결과를 상기 시나리오 데이터베이스로부터 언로드하기 위한 시나리오 언로드 모듈; 상기 시험 대상 데이터베이스에 접속하여, 상기 언로드한 시나리오를 상기 시험 대상 데이터베이스에 대해 수행하고 수행한 결과를 시험 결과로서 수신하기 위한 데이터베이스 시험 모듈; 및 상기 시험 결과와 상기 언로드한 검증 결과를 비교하여 최종 결과를 생성하는 비교 모듈을 포함할 수 있다.
상기 데이터베이스 시험 자동화 시스템의 다른 예에 따르면, 상기 적어도 하나의 데이터베이스 시험 자동화 장치들과 상기 네트워크를 통해 연결되는 검증된 데이터베이스를 더 포함할 수 있으며, 상기 검증 결과 생성 모듈은 상기 검증된 데이터베이스에 접속하여 상기 작성된 적어도 일부의 시나리오들을 상기 검증된 데이터베이스에 대해 수행하고 수행한 결과들을 상기 적어도 일부의 검증 결과들로서 수신할 수 있다.
본 발명의 세부 사항 및 개선 사항은 종속항에 개시된다.
본 발명의 데이터베이스 시험 자동화 방법 및 시스템은, 시험 대상 데이터베이스의 시험을 자동으로 수행할 수 있는 방법 및 시스템을 제공한다. 또한, 시험 대상 데이터베이스를 시험하기 위한 시나리오 및 이에 대응하는 검증 결과를 데이터베이스로 관리함으로써, 다수의 시험 운영자들 각자가 개발하고 있는 신규한 데이터베이스들을 효율적으로 동시에 시험할 수 있다. 또한, 개발 중인 데이터베이스의 시험 결과를 데이터베이스에 저장하여 관리함으로써, 데이터베이스의 성능 변화 추이나 버그 추적 등에 이용할 수 있다.
본 발명의 실시예들은 해당 기술 분야에서 통상의 지식을 가진 자에게 본 발명을 더욱 완전하게 설명하기 위한 목적으로 제공되는 것이며, 하기 실시예들은 여러 가지 다른 형태로 변형될 수 있고, 본 발명의 범위가 하기 실시예들로 한정되는 것으로 해석되어서는 아니 된다.
이하, 첨부한 도면들을 참조하여, 본 발명의 실시예를 보다 상세하게 설명하고자 한다. 설명의 편이와 명확성을 위하여 도면에서 각 구성 요소의 구조나 크기는 과장되었고 도면 상의 동일한 구성요소에 대해서는 동일한 참조부호가 사용되었으며 설명과 관계없는 부분이나 동일한 구성요소에 대한 중복된 설명은 생략되었다. 한편, 사용되는 용어들은 단지 본 발명을 설명하기 위한 목적으로 사용된 것일 뿐, 의미를 한정하거나 특허청구범위에 기재된 본 발명의 범위를 제한하기 위하여 사용된 것은 아니다.
도 1은 본 발명의 다양한 실시예에 따른 데이터베이스 시험 자동화 시스템을 대략적으로 도시한 개념도이다.
도 1을 참조하면, 시험 자동화 장치(100), 시나리오 데이터베이스 서버(202), 시험 대상 데이터베이스(300) 및 검증된 데이터베이스(400)는 각각 네트워크 어댑터(미 도시)를 포함하며, 상기 네트워크 어댑터를 이용하여 네트워크(10)에 연결될 수 있다. 네트워크(10)는 유선 또는 무선 통신망 중 적어도 하나일 수 있으며, 예컨대 통신망(LAN), 광대역 통신망(WAN), 공중 전화망(PSTN), 패킷 교체망(PSDN), 비대칭 디지털 가입자선(ADSL), 종합 통신망(ISDN), 코드분할다중접속(CDMA) 및 이더넷(ETHERNET) 중 적어도 하나를 포함할 수 있다. 또한, 시나리오 데이터베이스 서버(202), 시험 대상 데이터베이스(300) 및 검증된 데이터베이스(400)는 서로 연결되지 않을 수 있으며, 오직 시험 자동화 장치(100)에만 연결될 수 있다.
시나리오 데이터베이스 서버(202)는 시나리오 데이터베이스(200)를 포함할 수 있으며, 상기 시나리오 데이터베이스(200)는 시나리오, 검증 결과 및 최종 결과가 저장될 수 있는 예컨대 오라클(oracle), MS-SQL, 인포믹스(Informix)와 같은 범용 데이터베이스 일 수 있다.
시험 대상 데이터베이스(300)는 네트워크 어댑터를 구비한 시험 대상 데이터베이스 서버(미 도시)에 포함되어 네트워크(10)에 연결될 수 있다. 시험 대상 데이터베이스(300)는 개발자에 의해 새롭게 개발되고 있는 시험용 데이터베이스로서, 아직 표준화된 기능을 모두 제공하지 못할 수 있으며, 또는 기존의 표준화된 기능은 제공하지만 아직 새로운 표준화가 적용되지 못한 데이터베이스 일 수 있다. 상기 시험 대상 데이터베이스(300)는 시험 자동화 장치(100)에 직접 연결될 수 있다.
검증된 데이터베이스(400)는 검증된 데이터베이스 서버(미 도시)에 포함되어 네트워크(10)에 연결될 수 있다. 검증된 데이터베이스(400)는 현재의 표준화된 기능을 모두 제공하는 오라클(oracle), MS-SQL, 인포믹스(Informix)와 같은 범용 데이터베이스 일 수 있다. 그리고 검증된 데이터베이스(400)는 새로운 표준화를 반영한 데이터베이스일 수 있다.
시험 자동화 장치(100)는 컴퓨터에 본 발명의 다양한 실시예에 따른 데이터 시험 자동화 방법을 실행시키기 위한 프로그램을 기록한 컴퓨터로 읽을 수 있는 기록 매체를 포함할 수 있으며, 또한 상기 매체의 판독 및 상기 프로그램의 구동이 가능한 컴퓨터로서, 예컨대 개인용 컴퓨터(PC), 랩탑(노트북), 피디에이(PDA), 대형 컴퓨터, 워크스테이션, 서버 또는 특수용 컴퓨터를 포함할 수 있다. 시험 자동화 장치(100)는 시나리오 데이터베이스(200), 시험 대상 데이터베이스(300) 및 검증된 데이터베이스(400)에 접속하여 데이터를 입력, 출력, 삭제, 수정, 이동 및 편집과 같은 기능을 수행할 수 있는 데이터베이스 인터페이스부(미 도시)을 포함할 수 있다.
도 1에 단독으로 구성된 시험 자동화 장치(100)가 도시되어 있지만, 다수의 시험 자동화 장치(100)들이 상기 네트워크(10)에 연결되어 시나리오 데이터베이스(200), 시험 대상 데이터베이스(300) 및 검증된 데이터베이스(400)에 접속할 수 있으며, 독립적으로 동일한 기능을 수행할 수 있으며 동시에 동작할 수 있다. 또한, 시험 대상 데이터베이스(300)가 단독으로 구성된 것으로 도시되어 있지만, 다수의 시험 대상 데이터베이스(300)가 상기 네트워크(10)에 연결되어 하나 이상의 시험 자동화 장치(100)들에 의해 시험이 수행될 수 있다. 따라서, 상기 네트워크(10)에 다수의 시험 자동화 장치들(100)이 연결될 수 있으며, 상기 다수의 시험 자동화 장치들(100) 각각에 다수의 시험 대상 데이터 베이스(200)가 연결되어, 다수의 시험 대상 데이터베이스(200)에 대한 시험이 다수의 시험 자동화 장치들(100)에 의해 동시에 수행될 수 있다.
시험 자동화 장치(100)의 세부 사항은 이하 도 2를 참조로 설명한다.
도 2는 본 발명의 일 실시예에 따른 데이터베이스 시험 자동화 시스템의 데이터베이스 시험 자동화 장치의 기능을 예시적으로 도시한 블록도이다.
도 1과 함께 도 2를 참조하면, 데이터 시험 자동화 장치(100)는 네트워크 어댑터(160), 데이터베이스 인터페이스부(130), 로컬 저장 장치(140), 사용자 인터페 이스(150), 시나리오 등록부(110) 및 데이터베이스 시험부(120)를 포함한다.
데이터베이스 시험 자동화 장치(100)는 네트워크 어댑터(160)를 통해 네트워크(10)에 연결되며, 상기 네트워크(10)를 통해 시나리오 데이터베이스(200), 시험 대상 데이터베이스(300) 및 검증된 데이터베이스(400)와 연결될 수 있다. 예컨대 네트워크(10)가 LAN 기반의 유선 망인 경우, 네트워크 어댑터는 랜 카드일 수 있다.
데이터베이스 인터페이스부(130)는 상기 시나리오 등록부(110)와 상기 데이터베이스 시험부(120)에 포함된 다양한 모듈들(111-115 및 121-126)이 시나리오 데이터베이스(200), 시험 대상 데이터베이스(300) 및 검증된 데이터베이스(400)에 접속하여, 각자의 기능을 수행할 수 있게 한다. 데이터베이스 인터페이스부(130)는 도 2에 도시된 바와 같이 하나의 통합 인터페이스부로 구성될 수 있으며, 또는 데이터베이스(200, 300 및 400)에 각각 접속할 수 있는 다수의 개별 인터페이스부로 구성될 수도 있다.
로컬 저장 장치(140)는 상기 데이터베이스 시험 자동화 장치(100)에서 사용되는 시나리오와 같은 정보들을 저장하기 위해 사용될 수 있다. 로컬 저장 장치(140)는 상기 데이터베이스 시험 자동화 장치(100) 내에 장착된 하드 디스크일 수 있으며, 또는 플로피 디스크 및 플래시 메모리와 같은 비휘발성 저장 장치일 수 있다. 로컬 저장 장치(140)는 시나리오 및 이에 대응하는 검증 결과들을 파일 형태로 저장할 수 있다.
시나리오는 시험 운영자가 시험 대상 데이터베이스의 특정 기능을 시험하기 위해 작성한 일련의 논리적 테스트 셋을 의미한다. 예컨대 시나리오는 상기 시험 대상 데이터베이스(100)가 SQL 표준을 만족하는지의 여부를 시험하기 위한 시나리오일 수 있다. 예를 들어, 시나리오는 상기 시험 대상 데이터베이스에 저장된 기존 데이터베이스를 제거하기 위한 SQL문(예컨대 DROP), 상기 시험 대상 데이터베이스에 새로운 데이터베이스를 생성하기 위한 SQL문(예컨대 CREATE), 상기 새로운 데이터베이스에 데이터들을 입력하기 위한 SQL문(예컨대 INSERT), 및 상기 새로운 데이터베이스로부터 선택하고자 하는 데이터를 검색하기 위한 SQL문(예컨대 SELECT)을 포함할 수 있다.
검증된 결과는 상기 시나리오를 수행한 올바른 결과를 의미한다. 예컨대 최대 값을 구하는 함수(예컨대 MAX)를 시험하기 위한 시나리오에서, 5, 2, 0.9란 데이터들을 입력한 후, 상기 최대 값을 구하는 함수를 시행한 결과, 즉 5가 검증된 결과이다. 이러한 검증된 결과는 시나리오, 즉 입력되는 데이터 및 시험하고자 하는 기능 또는 함수가 변경됨에 따라 종속적으로 변할 것이다. 또한, 예를 들어 복수개의 기능 또는 함수를 시험하는 시나리오의 경우, 검증된 결과는 상기 복수개가 될 수 있다.
시나리오는 다수의 시험 운영자들에 의해 변경될 수 있으며, 그에 따라 검증 결과들도 변경될 수 있다. 변경된 시나리오와 검증 결과들은 시나리오 데이터베이스(200)에 저장된 것이 최신 버전으로 간주될 수 있으며, 로컬 저장 장치(140)에 저장된 시나리오와 검증 결과들은 최신 버전이 아닌 경우 최신 버전으로 업그레이드 되어야 할 필요가 있다.
사용자 인터페이스(140)는 시험 운영자들이 시나리오를 작성하고, 시나리오 데이터베이스(200)에 저장된 시나리오와 검증 결과들을 관리하고, 시험 대상 데이터베이스(300)을 시험할 시나리오를 선택하고, 최종 결과를 표시하기 위해 제공될 수 있다. 예컨대 사용자 인터페이스(140)는 키보드, 마우스, 모니터 등과 같은 입출력장치들을 포함할 수 있다.
데이터베이스 시험 자동화 방법은, 크게 두 단계로 구분될 수 있다. 그 중 한 단계는 새로운 시나리오를 작성하고, 그 시나리오에 해당하는 검증 결과를 생성하고, 작성된 시나리오와 생성된 검증 결과를 데이터베이스에 등록하는 단계이다. 다른 단계는 시나리오와 검증 결과가 등록된 데이터베이스에서 시험에 사용할 시나리오를 선택하여, 그 시나리오를 수행한 시험 결과를 얻어, 검증 결과와 비교하여 최종 결과를 생성하는 단계이다.
시나리오 등록부(110)는 상기 새로운 시나리오와 이에 대응하는 검증 결과를 시나리오 데이터베이스(110)에 등록하는 단계를 실행하기 위해 제공될 수 있다.
시나리오 작성 인터페이스 모듈(111)은 시험 운영자가 사용자 인터페이스(150)를 통해 시험 대상 데이터베이스(100)를 시험하기 위한 시나리오를 새로 작성하기 위한 인터페이스를 제공할 수 있다. 시나리오 작성 인터페이스 모듈(111)은 윈도우의 메모장과 같은 텍스트 작성 프로그램에서 작성된 텍스트를 불러올 수 있으며, 시나리오 텍스트를 작성할 수 있는 에디터를 제공할 수 있다.
시나리오 검증 모듈(112)은 상기 작성된 시나리오의 문법적 오류를 검증하기 위해 제공될 수 있다. 예컨대 오탈자가 있거나 정의되지 않은 변수를 사용하는 등 의 문법적 오류가 있는 경우 이러한 오류를 시나리오 작성자에게 보고하여 수정하도록 할 수 있다.
검증 결과 생성 모듈(113)은 시나리오 작성 인터페이스 모듈(111)에서 작성된 시나리오 또는 시나리오 검증 모듈(112)에 의해 검증된 시나리오에 대응하는 검증 결과를 생성하기 위해 제공될 수 있다. 상술된 바와 같이, 검증 결과는 시나리오에 대응하는 올바른 결과이며, 이러한 검증 결과는 시나리오 작성자가 수동으로 입력할 수 있다. 그러나, 시나리오에 사용되는 데이터가 방대한 경우 시험 운영자는 일일이 수동으로 상기 시나리오의 검증 결과를 생성할 수 없다. 이 경우, 시험 운영자는 시나리오를 검증된 데이터베이스(400)에 대해 수행하고, 그 수행 결과를 검증 결과로 간주할 수 있다. 이를 위해 검증 결과 생성 모듈(113)은 데이터베이스 인터페이스부(130)를 통해 검증된 데이터베이스(400)에 접속하여, 검증 결과를 생성할 시나리오를 수행할 수 있다. 수행 결과가 출력될 것이며, 그 수행 결과를 검증 결과로서 수신함으로써 검증 결과를 생성할 수 있다. 새로운 표준안이 제정됨에 따라, 시나리오가 변하지 않았음에도 검증 결과가 변경될 수 있다. 이 경우에 시험 운영자는 위와 동일한 방식으로 검증 결과를 생성할 수 있다.
시나리오 등록 모듈(114)은 검증 결과 생성 모듈(113)에서 생성된 검증 결과와 이에 대응하는 시나리오를 시나리오 데이터베이스(200)에 등록하기 위해 제공될 수 있다. 시나리오 등록 모듈(114)은 데이터베이스 인터페이스부(130)를 통해 시나리오 데이터베이스(200)에 접속할 수 있다. 각각의 시나리오들을 식별하기 위해 시험 운영자는 시나리오와 검증 결과를 연결하는 시나리오 아이디와 함께 등록할 수 있다. 또한, 시나리오 등록 시, 시나리오 생성자의 아이디 및 접근 권한도 함께 시험 운영자에 의해 등록될 수 있다. 도 3에 예시적으로 도시된 바와 같이, 시나리오 데이터베이스(200)는 시나리오 테이블(210)과 검증 결과 테이블(220)을 가질 수 있으며, 시나리오와 검증 결과를 각각의 테이블(210, 220)에 저장할 수 있다. 시나리오 데이터베이스(200)에 대해서는 도 3을 참조로 자세히 후술한다.
시나리오 관리 인터페이스 모듈(115)은 시험 운영자가 사용자 인터페이스(150)를 통해 시나리오 데이터베이스(200)에 등록된 시나리오 및 검증 결과를 입력, 출력, 변경, 삭제, 복사, 이동 등과 같은 작업을 수행하기 위해 제공될 수 있다. 예를 들어, 시나리오들은 계층적으로 구성될 수 있는데, 계층 레벨을 변경하거나, 시나리오가 위치한 계층을 변경하기 위해 상기 시나리오 관리 인터페이스 모듈(115)이 이용될 수 있다. 또는 특정 시나리오를 삭제하거나, 편집하는데도 상기 시나리오 관리 인터페이스 모듈(115)이 이용될 수 있다.
시나리오 등록부(110)는 상술한 모듈들(111-115), 또는 이들의 일부를 선택적으로 포함할 수 있다. 상기 모듈들(111-115)은 기능적으로 구분한 것으로, 상술한 모듈들(111-115) 중 일부는 한 모듈로 통합될 수 있다.
데이터베이스 시험부(120)는 시나리오 등록부(110)에 의해 시나리오 데이터베이스(200)에 등록된 시나리오 및 검증 결과를 이용하여 시험 대상 데이터베이스(300)를 시험하기 위해 제공될 수 있다.
도 2에 도시되지는 않았지만, 다수의 시험 대상 데이터베이스(300)들이 네트워크(10)에 연결되어 있는 경우, 시험할 시험 대상 데이터베이스(300)를 선택하기 위한 시험 대상 데이터베이스 선택 인터페이스 모듈(미 도시)가 제공될 수 있다. 시험 운용자는 상기 시험 대상 데이터베이스 선택 인터페이스 모듈을 통해 시험 대상 데이터베이스(300)를 선택할 수 있으며, 필요에 따라, 복수개의 시험 대상 데이터베이스(300)들을 선택하여 시험할 수 있다. 시험 대상 데이터베이스 선택 인터페이스 모듈은 시험 운용자에게 현재 연결되어 있는 시험 대상 데이터베이스(300)들을 표시할 수 있다. 시험 운용자는 표시된 시험 대상 데이터베이스들(300)의 목록을 보고 시험할 시험 대상 데이터베이스(300)를 선택할 수 있으며, 경우에 따라, 복수개의 시험 대상 데이터베이스(300)를 선택할 수 있다.
데이터베이스 선택 인터페이스 모듈(121)은 시험 운영자가 사용자 인터페이스(150)를 통해 시나리오 데이터베이스(200)에 등록된 시나리오들 중 시험 대상 데이터베이스(300)를 시험할 시나리오를 선택하기 위한 인터페이스를 제공할 수 있다. 데이터베이스 선택 인터페이스 모듈(121)은 데이터베이스 인터페이스부(130)를 통해 시나리오 데이터베이스(200)에 접속할 수 있다. 시나리오 데이터베이스(200)에 등록된 모든 시나리오들을 시험 운영자에게 표시할 수 있으며, 시험 운영자는 시험 대상 데이터베이스(300)를 시험할 시나리오를 선택할 수 있다. 선택할 수 있는 시나리오는 복수개일 수 있으며, 예컨대 시나리오가 계층적으로 구성된 경우, 상위 계층의 시나리오를 선택하면 이에 종속되어 하위에 위치한 모든 시나리오들이 선택될 수 있다. 이 경우, 선택된 복수개의 시나리오들은 연속하여 시험 대상 데이터베이스(300)에 대해 수행될 수 있다.
데이터베이스 선택 인터페이스 모듈(121)은 시험 운영자가 로컬 저장 장 치(140)에 저장된 시나리오 중에서 선택하기 위한 인터페이스를 제공할 수도 있다. 특정 기능을 데이터베이스에 구현하는 경우, 그 기능이 구현되었는지를 시험하기 위해 시험 자동화 장치(100)는 반복적으로 그 기능을 시험하기 위한 시나리오를 수행하여야 할 것이다. 이 경우, 데이터베이스 선택 인터페이스 모듈(121)은 매 번 원격에 위치한 시나리오 데이터베이스(200)에 접속하지 않고, 로컬 저장 장치(140)에 저장하여, 이로부터 선택할 수 있다.
시나리오 접근 인증 모듈(122)은 시나리오 데이터베이스(200)에 등록된 시나리오들에 대한 접근의 허용 여부를 인증하기 위해 제공될 수 있다. 경우에 따라 시나리오는 비밀로 보호해야 할 필요가 있으므로, 시나리오 생성자는 시나리오 생성자만이 이후에 시나리오에 접근할 수 있다거나, 시나리오 생성자가 허용한 일부 그룹만이 접근할 수 있다거나 하는 등의 접근 권한을 부여할 수 있다. 시나리오 접근 인증 모듈(122)은 데이터베이스 인터페이스부(130)를 통해 시나리오 데이터베이스(200)에 접속할 수 있으며, 시나리오 접근 허용 데이터를 수신하여, 현재 사용자가 시나리오를 수행 가능한지의 여부를 결정할 수 있다. 도 3에 도시되지 않았지만, 시험 운용자를 식별하기 위해 로그인하는 과정이 추가될 수 있다.
시나리오 언로드 모듈(123)은 시나리오 선택 인터페이스 모듈(121)에서 선택된 시나리오와 이의 검증 결과를 로컬로 언로드하기 위해 제공될 수 있다. 시나리오 언로드 모듈(123)은 데이터베이스 인터페이스부(130)를 통해 시나리오 데이터베이스(200)에 접속하여, 상기 선택된 시나리오와 이의 검증 결과를 로컬로 언로드할 수 있다. 언로드된 시나리오는 파일 형식으로 로컬 저장 장치에 저장될 수 있다.
시나리오 동기화 모듈(124)은 시나리오 데이터베이스(200)에 등록된 시나리오 및 검증 결과를 로컬 저장 장치(140)에 동기화 시키기 위해 제공될 수 있다. 시나리오 언로드 모듈(123)에서 언로드된 시나리오와 검증 결과는 로컬 저장 장치(140)에 저장될 수 있다. 상기 데이터베이스 시험 자동화 시스템을 운영하다 보면, 시나리오 데이터베이스(200)에 등록된 시나리오 및 검증 결과는 다른 운용자에 의해 변경될 수 있으며, 그에 따라 시나리오 데이터베이스(200)에 등록된 시나리오 및 검증 결과는 로컬 저장 장치(140)에 저장된 시나리오 및 검증 결과와 일치하지 않을 수 있다. 서로 일치하지 않는 시나리오와 검증 결과를 일치시키기 위해 시나리오 동기화 모듈(124)이 필요할 수 있다.
상기 시나리오 동기화 모듈(124)은 시나리오 접근 인증 모듈(122)에 연결되어 선택된 시나리오에 대해 시나리오 데이터베이스(200)에 등록된 정보와 로컬 저장 장치(140)에 저장된 정보를 비교할 수 있으며, 비교 결과 동일하면, 로컬 저장 장치(140)에 저장된 시나리오와 검증 결과를 이용하여 이후 작업을 수행할 수 있다. 비교 결과 차이가 있으면, 상기 시나리오 동기화 모듈(124)은 시나리오 언로드 모듈(123)을 이용하여 로컬 저장 장치에 언로드할 수 있다.
도 2에는 시나리오 언로드 모듈(123)과 시나리오 동기화 모듈(124)이 별개의 모듈로 도시되어 있지만, 하나의 모듈로 통합하여 구성될 수 있다. 시나리오 언로드 모듈(123)과 시나리오 동기화 모듈(124)이 하나로 통합된 모듈(미 도시)은 시나리오 선택 인터페이스 모듈(121)에서 선택된 시나리오에 대해, 로컬 저장 장치(140)에 동일한 시나리오가 있는지 검색한 후, 동일한 시나리오와 검증 결과가 있는 경우에는 로컬 저장 장치(140)로부터 상기 시나리오와 검증 결과를 불러올 수 있다. 만약 상기 시나리오와 검증 결과가 없거나 서로 상이한 경우, 상기 통합 모듈은 시나리오 데이터베이스(200)에 접속하여 상기 시나리오와 검증 결과를 언로드할 수 있다.
데이터베이스 시험 모듈(125)은 상기 시나리오 언로드 모듈(123)에서 언로딩된 시나리오를 시험 대상 데이터베이스(300)에 대해 수행하여 시험 결과를 얻기 위해 제공될 수 있다. 데이터베이스 시험 모듈(125)은 데이터베이스 인터페이스부(130)를 통해 시험 대상 데이터베이스(300)에 접속할 수 있다. 그 후, 시험 대상 데이터베이스(300)에 대해 상기 시나리오를 수행하고, 수행 결과를 시험 결과로서 수신할 수 있다. 그리고 이를 비교 모듈(126)에 제공할 수 있다.
비교 모듈(126)은 데이터베이스 시험 모듈(125)에서 제공된 시험 결과와 시나리오 언로드 모듈(123)이 언로딩한 검증 결과를 비교하기 위해 제공될 수 있다. 상기 시험 결과와 상기 검증 결과가 동일한 경우, 상기 시험 대상 데이터베이스(300)가 상기 시나리오가 시험하고자 하는 기능을 정상적으로 수행하였다는 것이므로 비교 모듈(126)은 성공을 의미하는 신호를 데이터베이스 인터페이스부(130)를 통해 시나리오 데이터베이스(200)에 등록한다. 반대로, 상기 시험 결과와 상기 검증 결과가 일치하지 않는 경우, 상기 시험 대상 데이터베이스(300) 가 상기 기능을 정상적으로 수행하지 못하였다는 것이므로 비교 모듈(126)은 실패를 의미하는 신호와 함께 시험 결과를 시나리오 데이터베이스(200)에 등록할 수 있다. 시험 결과가 너무 긴 경우, 비교 모듈(126)은 검증 결과와 차이가 나는 부분만을 시나리오 데이 터베이스(200)에 등록할 수도 있다.
데이터베이스 시험부(120)는 상술한 모듈들(121-126), 또는 이들의 일부를 선택적으로 포함할 수 있다. 상기 모듈들(121-126)은 기능적으로 구분한 것이며, 상술한 모듈들(121-126) 중 일부는 한 모듈로 통합될 수 있다.
도 2에 도시된 데이터베이스 시험 자동화 장치(100)는 예시적이며, 이와 동일한 또는 유사한 기능을 수행하는 모듈, 함수 또는 요소들로 구성될 수 있다. 또한 도 2에 도시된 연결 관계들도 예시적인 것으로, 도시된 것과 다르게 연결될 수도 있음에 주의하여야 한다.
도 3은 본 발명의 일 실시예에 따른 데이터베이스 시험 자동화 시스템에서 사용될 수 있는 시나리오 데이터베이스와 이에 저장된 테이블들을 예시적으로 도시한다. 시나리오 데이터베이스(200)의 테이블들은 실제로 운영되는 환경과 시험 대상에 따라 변경될 수 있다.
시나리오 테이블(210)은 시나리오들을 저장하기 위해 제공될 수 있다. 시나리오 테이블(210)은 도 3에 도시된 바와 같이, 시나리오 아이디(211)과 시나리오(212) 필드를 포함할 수 있다. 시나리오 아이디(211)는 시나리오를 식별하기 위한 번호로서 동일한 번호가 존재할 수 없다. 시나리오(212)는 실제 시나리오가 저장된다. 상술한 바와 같이, 시나리오(212)는 SQL문으로 구성될 수 있으며, 예를 들어 데이터베이스를 생성하고, 데이터들을 입력하고, 그 데이터들에 대해 특정 기능을 수행하는 구문을 포함할 수 있다. 이 이외에도, 시나리오 이름, 시나리오 버전 등과 같은 정보가 포함될 수 있다.
시나리오 인증 테이블(240)은 시나리오에 접근 할 수 있는 운용자, 또는 그룹 등의 속성을 저장하기 위해 제공될 수 있다. 시나리오 인증 테이블(240)은 도 3에 도시된 바와 같이, 시나리오 아이디(241), 생성자(242) 및 접근 권한(243) 필드를 포함할 수 있다. 시나리오 인증 테이블(240)은 시나리오 아이디(241)에 의해 상기 시나리오 테이블(210)의 시나리오(212) 필드와 연결될 수 있다. 상기 필드들(241, 242, 243) 외에도, 시나리오 인증 테이블(240)에는 시나리오 생성일자, 시나리오 최근 변경일자, 시나리오 최근 사용자 등과 같은 정보가 포함될 수 있다.
시나리오 계층 테이블(250)은 시나리오를 그룹화하여 용이한 시험 수행을 위해 제공될 수 있다. 데이터베이스의 성능 및 기능들은 그룹화될 수 있으며, 시험 운용자들은 그룹화된 일련의 시나리오들을 연속하여 수행할 필요가 있다. 또한, 시험 운용자가 시나리오를 선택하기 위해서는 시나리오들이 표시되어야 한다. 시나리오들이 윈도우 탐색기와 같이 계층적으로 표시된다면 시험 운용자는 용이하게 시나리오들을 쉽게 선택할 수 있다.
이를 위해, 도 3에 도시된 바와 같이, 시나리오 계층 테이블(250)은 시나리오 아이디(251), 계층 레벨(252), 폴더/파일(253) 및 상위 시나리오 아이디(254) 필드를 포함할 수 있다. 계층 레벨(252)은 예컨대 루트를 0으로 보고, 루트에 위치한 시나리오를 1, 루트에 위치한 폴더에 포함된 시나리오를 2와 같이, 시나리오가 위치하는 계층 레벨을 나타낸다. 폴더/파일(253)은 해당 시나리오가 폴더인지 아니면 파일인지를 의미한다. 시나리오는 하위 시나리오들을 포함하는 폴더일 수 있다. 하위 시나리오들이 유사한 기능을 시험하기 위한 시나리오인 경우, 이들은 그룹화될 수 있으며, 상위 시나리오 폴더에 포함된 것으로 표현될 수 있다. 상위 시나리오 아이디(254)는 상위 시나리오를 식별하기 위한 필드이다.
검증 결과 테이블(220)은 시나리오를 수행한 정상적인 결과를 저장하기 위해 제공될 수 있다. 도 3에 도시된 바와 같이, 검증 결과 테이블(220)은 시나리오 아이디(221) 및 검증 결과(222) 필드를 포함할 수 있다. 검증 결과 테이블(220)은 시나리오 아이디(221)를 통해 시나리오 테이블(210)의 시나리오(212) 필드와 연결될 수 있다. 검증 결과(222) 필드는 시나리오 아이디(221)에 해당하는 시나리오(212)를 수행한 올바른 결과가 저장될 수 있다. 시나리오(212)가 하나의 시험을 포함하는 경우, 상기 시나리오(212)에 해당하는 결과는 하나일 수 있으며, 또는 시나리오(212)가 여러 시험들을 포함하면, 상기 시나리오(212)에 해당하는 결과도 여러 개일 수 있다. 이를 위해 하나의 시나리오 내에 포함된 여러 시험을 구분하기 위한 하위 아이디(미 도시) 필드가 검증 결과 테이블(220)에 포함될 수 있으며, 검증 결과(222) 필드는 상기 하위 아이디에 해당하는 시험의 정상적인 결과를 저장할 수 있다.
최종 결과 테이블(230)은 시험 대상 데이터베이스에 대해 시나리오를 수행한 결과를 검증 결과와 비교한 최종 결과를 저장하기 위해 제공될 수 있다. 도 3에 도시된 바와 같이, 시험 대상 데이터베이스 아이디(231), 시험 일시(232), 시나리오 아이디(233), 성공/실패(234) 및 시험 결과(235)가 최종 결과 테이블(230)에 포함될 수 있다.
시험 대상 데이터베이스 아이디(231)는 시나리오를 수행한, 시험의 대상이 된 데이터베이스를 식별하기 위한 필드이다. 시험 일시(232)는 시험을 시행한 날짜와 시간을 저장하기 위한 필드로서, 해당 데이터베이스의 성능 변화 추이나 버그 추적 등에 이용될 수 있다. 시나리오 아이디(233)는 시험을 수행한 시나리오를 식별하기 위한 필드이다. 성공/실패(234)는 시나리오를 수행한 시험 결과가 검증 결과와 일치하였는지의 여부를 기록하기 위한 필드이다. 시험 결과(235)는 실패한 경우의 시험 결과(235)를 저장하기 위한 필드이며, 검증 결과와 차이가 나는 부분만 저장될 수 있다. 상술한 필드들(231-235) 외에도, 시험 수행자, 시험을 수행한 데이터베이스 시험 자동화 장치 아이디 등의 정보가 최종 결과 테이블(230)에 추가로 저장될 수 있다.
예를 들어, 하나의 시나리오가 여러 하위 시험들을 포함하여 검증 결과 테이블(220)가 하위 아이디 필드를 포함하고 있는 경우에는, 최종 결과 테이블(230)도 하위 아이디(미 도시) 필드를 포함하고, 각각의 하위 시험에 대응한 시험 결과가 저장되어야 할 것이다.
상술한 테이블들(210, 220, 230, 240, 250)은 예시적이며, 이중 일부는 하나의 테이블로 통합되거나, 둘 이상의 테이블로 분리될 수도 있다. 또한 상술한 테이블들(210, 220, 230, 240, 250) 외에도, 시나리오 데이터베이스(200)에는 시험 운용자에 관한 테이블, 시험 운용자 그룹에 관한 테이블 등이 포함될 수 있다.
도 4는 상술한 데이터베이스 시험 자동화 시스템을 이용하여 데이터베이스 시험을 자동화하는 방법을 개략적으로 나타낸 순서도이다.
도 4를 참조하면, 데이터베이스 시험을 자동화 하는 방법은, 시험 대상 데이 터베이스를 시험하기 위한 시나리오, 및 이에 대응하는 검증 결과를 원격 시나리오 데이터베이스에 등록하는 단계(S402)와 상기 시나리오를 이용하여 시험 대상 데이터베이스를 시험하는 단계(S404)로 크게 구분될 수 있다.
도 5와 도 6은 도 4의 데이터베이스 시험 자동화 방법을 구체적으로 서술한 예시적인 순서도이다. 이 중 도 5는 시나리오를 등록하는 과정에 대한 순서도이며, 도 6는 데이터베이스를 시험하는 과정에 대한 순서도이다. 이러한 순서는 예시적인 것으로, 하나 이상의 단계들이 추가될 수 있으며, 또는 일부 단계들이 생략되거나 통합되어 한 단계로 구성될 수 있음에 주의해야 한다.
도 1 내지 3과 함께 도 5를 참조하면, 단계 S502에서 시험 운용자는 시나리오를 작성할 수 있다. 시험 운용자는 데이터베이스 시험 자동화 장치(100)의 사용자 인터페이스(150)를 이용하여 시나리오 텍스트를 작성할 수 있다. 시나리오 작성 인터페이스 모듈(111)은 작성된 시나리오 텍스트를 시나리오로 인식할 수 있다.
단계 S504에서 작성된 시나리오를 검증할 수 있다. 이 단계는 시나리오 검증 모듈(112)에서 이루어질 수 있다.
단계 S506에서 검증 결과를 생성할 수 있다. 검증 결과 생성 모듈(113)은 상기 작성된 시나리오를 검증된 데이터베이스(400)에 대해 수행하고 그 결과를 검증 결과로서 수신함으로써 검증 결과를 생성할 수 있다. 이 단계(S506)를 구체적으로 설명하자면, 검증 결과 생성 모듈(113)은 단계 S502에서 작성된 시나리오를 수신한다. 그 후, 검증 결과 생성 모듈(113)은 데이터베이스 인터페이스부(130)를 통해 검증된 데이터베이스(400)에 접속한다. 그 후, 검증 결과 생성 모듈(113)은 상기 시나리오를 검증된 데이터베이스(400)에 대해 수행하고, 그 결과를 수신한다. 상기 시나리오를 수행한 결과는 검증 결과로 간주될 수 있다.
단계 S508에서, 상기 시나리오와 상기 검증 결과가 시나리오 데이터베이스(200)에 등록될 수 있다. 이 단계(S508)를 구체적으로 설명하자면, 시나리오 등록 모듈(114)은 단계 S502에서 작성된 시나리오와 단계 S506에서 생성된 검증 결과를 수신한다. 그 후, 시나리오 등록 모듈(114)은 데이터베이스 인터페이스부(130)를 통해 시나리오 데이터베이스(400)에 접속한다. 그 후, 시나리오 등록 모듈(114)은 상기 시나리오와 상기 검증 결과에 해당하는 시나리오 아이디를 부여하고, 상기 시나리오 아이디와 함께 도 3의 시나리오 테이블(210)과 검증 결과 테이블(220)에 등록한다. 그리고 시나리오 등록 모듈(114)은 시나리오 인증 테이블(240)과 시나리오 계층 테이블(250)에 시나리오 생성자 정보를 포함하는 정보들을 등록한다.
상기 단계 S502 내지 S508을 반복함에 따라, 시나리오 데이터베이스(200)에는 다수의 시나리오 정보와 이에 대응하는 검증 결과 정보들이 등록될 것이다. 그리고 이렇게 작성된 시나리오와 검증 결과에 오류가 있거나, 새로운 표준안이 적용됨에 따라 상기 시나리오와 검증 결과는 변경될 필요가 있을 수 있다. 이러한 경우, 시험 운용자는 시나리오 관리 인터페이스 모듈(115)을 통해 시나리오를 수정하거나, 이동시키거나, 삭제하는 등의 기본적인 데이터베이스 작업을 수행할 수 있다.
이러한 작업은 복수개의 데이터베이스 시험 자동화 장치(100)에서 수행될 수 있음에 주의해야 한다. 예를 들어, 제 1, 4 및 5 시나리오와 검증 결과는 제 1 데이터베이스 시험 자동화 장치(100)에서 생성된 것일 수 있으며, 제 2 및 3 시나리오와 검증 결과는 제 2 데이터베이스 시험 자동화 장치(100)에서 생성될 수 있다. 뿐만 아니라, 제 1 데이터베이스 시험 자동화 장치(100)에서 생성된 시나리오 및 검증 결과가 제 2 데이터베이스 시험 자동화 장치(100)에서 수정될 수도 있다.
이제, 도 1 내지 3과 함께 도 6을 참조하면, 단계 S602에서, 시험 운용자는 시험 대상 데이터베이스(300)를 시험할 시나리오를 선택할 수 있다. 시나리오 선택 인터페이스 모듈(121)은 데이터베이스 인터페이스부(130)를 통해 시나리오 데이터베이스(200)에 접속하여, 시나리오 데이터베이스(200)의 시나리오 테이블(210)에 저장된 시나리오 목록들을 디스플레이 화면에 표시한다. 시나리오 선택 인터페이스 모듈(121)은 시나리오 계층 테이블(250)를 이용하여 계층화하여 표시할 수 있다. 시험 운용자가 시나리오의 목적 또는 시험하고자 하는 기능을 알 수 있도록, 시나리오 선택 인터페이스 모듈(121)은 시나리오의 명칭이나 간단한 요약을 함께 표시할 수 있다. 시험 운용자는 표시된 시나리오 목록에서 시험할 시나리오를 선택할 수 있다. 복수개의 시나리오를 선택할 수도 있으며, 이 경우 상기 복수개의 시나리오들이 연속적으로 시험 대상 데이터베이스(300)에 대해 수행될 것이다.
단계 S604에서, 시나리오에 접근할 수 있는 권한이 시험 운용자에게 있는지 확인할 수 있다. 시나리오 접근 인증 모듈(122)은 시나리오 데이터베이스(200)에 접속하여, 시나리오 데이터베이스(200)의 시나리오 인증 테이블(240)을 통해 현재 시험 운용자가 선택된 시나리오에 대한 접근 권한을 보유하는지에 대해 검사할 수 있다. 검사 결과 접근 권한을 보유하는 경우, 시나리오 접근 인증 모듈(122)은 선택된 시나리오 목록을 시나리오 언로드 모듈(123) 및 시나리오 동기화 모듈(124) 중 적어도 하나에 제공한다.
단계 S606에서, 선택된 시나리오에 대해 동기화가 수행될 수 있다. 시나리오 동기화 모듈(124)은 선택된 시나리오에 대해 시나리오 데이터베이스(200)에 저장된 정보와 로컬 저장 장치(140)에 저장된 정보가 일치하는지 확인하여, 일치하는 경우에는 로컬 저장 장치(140)로부터 상기 선택된 시나리오와 이에 대응하는 검증 결과를 각각 데이터베이스 시험 모듈(125)과 비교 모듈(126)에 제공할 수 있다. 시나리오 동기화 모듈(124)은 일치하는지를 검사하기 위해, 양 시나리오들의 데이터 크기, 변경된 일시, 버전 정보 등을 비교할 수 있다. 그러나 일치하지 않는 경우, 시나리오 동기화 모듈(124)은 일치하지 않는 시나리오 목록을 시나리오 언로드 모듈(123)에 제공할 수 있다.
단계 S608에서, 데이터베이스 시험 자동화 장치(100)는 상기 선택된 시나리오를 언로드 할 수 있다. 시나리오 언로드 모듈(123)은 시나리오 데이터베이스(200)에 접속하여, 상기 선택된 시나리오, 및 이에 대응하는 검증 결과를 언로드할 수 있다. 또한 시나리오 언로드 모듈(123)은 언로드된 상기 시나리오 및 검증 결과를 로컬 저장 장치(140)에 저장할 수 있다. 시나리오 언로드 모듈(123)은 언로드된 상기 시나리오 및 검증 결과를 각각 데이터베이스 시험 모듈(125)과 비교 모듈(126)에 제공할 수 있다.
단계 S610에서, 데이터베이스 시험 자동화 장치(100)는 언로드된 시나리오를 시험 대상 데이터베이스(300)에 대해 수행할 수 있다. 데이터베이스 시험 모듈(125)은 데이터베이스 인터페이스부(130)를 통해 시험 대상 데이터베이스(300)에 접속한다. 그 후, 상기 언로드된 시나리오를 수행할 수 있다. 수행 결과가 표시될 수 있다.
단계 S612에서, 상기 데이터베이스 시험 모듈(125)은 상기 수행 결과를 시험 결과로서 수신할 수 있다. 그 후, 상기 시험 결과를 비교 모듈(126)에 제공하고, 시험 대상 데이터베이스(300)와의 연결을 해제할 수 있다.
단계 S614에서, 비교 모둘(126)은 단계 S606 또는 S608에서 제공한 검증 결과와 단계 S612에서 제공한 시험 결과를 비교할 수 있다. 상기 시험 결과와 상기 검증 결과는 모두 문자열로 이루어질 수 있으며, 시험하고자 하는 기능 또는 성능에 따라서, 수행 시간일 수도 있다.
단계 S616에서, 상기 비교 모듈(126)은 비교 결과를 최종 결과로서 시나리오 데이터베이스(200)에 등록할 수 있다. 비교 결과는 성공 또는 실패를 의미하는 신호를 포함할 수 있으며, 또한 실패 시, 차이가 나는 부분의 문자열과 위치를 포함할 수 있다. 비교 모듈(126)은 시나리오 데이터베이스(200)에 접속하여, 시험을 수행한 일시 및 시험을 수행한 시험 대상 데이터베이스 아이디와 함께, 상기 신호와 상기 문자열 및 위치를 시나리오 데이터베이스(200)의 최종 결과 테이블(230)에 등록할 수 있다.
여기서, 발명을 쉽게 이해시키기 위해, 단수의 데이터베이스 시험 자동화 장치(100)에서 단수의 시험 대상 데이터베이스(300)에 대해 시험하는 것으로 설 명하였지만, 시험 운용자들은 복수의 데이터베이스 시험 자동화 장치들(100)에서 동시에 그리고 서로 독립적으로 시험을 수행할 수 있다. 또한, 상기 복수의 데이터베이스 시험 자동화 장치들(100)의 각각은 복수의 시험 대상 데이터베이스들(300)에 대해 시험을 수행할 수 있다.
그리고 상기 단계들(S602-S616)은 각각 독립적인 단계들로 표시되었지만, 일체를 이루어 동시에 수행될 수도 있다. 예컨대 시나리오를 동기화 하는 단계(S606)와 시나리오 및 검증 결과를 언로드하는 단계(S608)는 통합하여 수행될 수 있다. 또한, 총 시험 수행 시간을 줄이기 위해, 데이터베이스 시험 자동화 장치(100)는 시나리오 데이터베이스(200)로부터 시나리오를 언로드하여 시험 대상 데이터베이스(300)에 대해 수행하면서, 상기 시나리오에 대응하는 검증 결과를 시나리오 데이터베이스(200)로부터 언로드할 수 있다.
도 7은 본 발명의 일 실시예에 따른 데이터베이스 시험 자동화 시스템의 운용예를 도시한다. 본 실시예는 예시적이며, 용이한 이해를 위해 중복되는 설명이나 구성요소에 대해서는 도시하지 않는다.
도 7을 참조하면, 4개의 데이터베이스 시험 자동화 장치들(710a-d), 시나리오 데이터베이스(720) 및 4개의 시험 대상 데이터베이스들(730a-d) 및 검증된 데이터베이스(740)이 네트워크(701)에 연결되어 있다.
예를 들면, 4개의 데이터베이스 시험 자동화 장치들(710a-d) 중 제 1 데이터베이스 시험 자동화 장치(710a)에서 시나리오가 작성되어 시나리오 데이터베이스(720)에 등록될 수 있다. 그리고 제 4 데이터베이스 시험 자동화 장치(710d)는 시나리오 데이터베이스(720)에 등록되어 있는 다수의 시나리오들(721a-c) 및 다수의 검증 결과들(722a-c)을 이용하여 제 3 시험 대상 데이터베이스(730c)를 시험할 수 있다. 이와 동시에, 제 2 데이터베이스 시험 자동화 장치(710b)는 새로운 시나리오 및 이에 대응하는 검증 결과를 시나리오 데이터베이스(720)에 등록한 후, 상기 시나리오 및 검증 결과를 이용하여 2개 이상의 시험 대상 데이터베이스(730a,c,d)를 시험 할 수도 있다. 또한, 이와 동시에, 제 3 데이터베이스 시험 자동화 장치(710c)는 시나리오 데이터베이스(720)에 등록되어 있는 다수의 시나리오들(721a-c) 및 다수의 검증 결과들(722a-c)을 언로드하여 수정 또는 편집하여 새로운 버전으로 업데이트할 수도 있다.
상술한 바와 같이, 본 데이터베이스 시험 자동화 시스템(700)은 네트워크(701)을 기반으로 서로 연결되어, 동시에, 독립적으로 시험 대상 데이터베이스들(730a-d)을 시험할 수 있으며, 그 시험 결과를 체계적으로 관리할 수 있다.
도 8은 상술한 도 7의 데이터베이스 시험 자동화 시스템(700)에서의 데이터 흐름을 도식적으로 도시한다. 본 실시예에서, 제 1 데이터베이스 시험 자동화 장치(710a)는 시나리오 데이터베이스(720)에 새로운 시나리오 및 이에 대응하는 검증 결과를 등록하고 있으며, 제 4 데이터베이스 시험 자동화 장치(710d)는 시나리오 데이터베이스(720)에 등록된 다수의 시나리오들(721a-c) 및 다수의 검증 결과들(722a-c)을 이용하여 제 3 시험 대상 데이터베이스(730c)를 시험하고 있다. 본 실시예는 예시적이다.
우선, 제 1 데이터베이스 시험 자동화 장치(710a)가 시나리오 및 이에 대응 하는 검증 결과를 시나리오 데이터베이스(720)에 등록하는 단계를 먼저 설명한다. 데이터베이스 시험 자동화 장치(710a)에서 새로운 시나리오가 작성될 수 있다. 이 새로운 시나리오에 대응하는 검증 결과를 생성하기 위해서, 데이터베이스 시험 자동화 장치(710a)는 검증된 데이터베이스(740)에 대해 상기 시나리오를 수행하여, 검증 결과를 수신할 수 있다. 그 후, 데이터베이스 시험 자동화 장치(710a)는 상기 시나리오와 검증 결과를 시나리오 데이터베이스(720)에 등록할 수 있다.
다음으로, 제 4 데이터베이스 시험 자동화 장치(710d)가 시나리오 데이터베이스(720)에 등록된 시나리오들 및 검증 결과들을 이용하여 제 3 시험 대상 데이터베이스(730c)를 시험하는 단계를 설명한다. 제 4 데이터베이스 시험 자동화 장치(710d)는 시나리오 데이터베이스(720)로부터 제 3 시험 대상 데이터베이스(730c)를 시험할 시나리오 및 이에 대응하는 검증 결과를 언로드할 수 있다. 그 후, 언로드한 시나리오를 제 3 시험 대상 데이터베이스(730c)에 대해 수행하고, 시나리오를 수행한 결과인 시험 결과를 수신한다. 그 후, 언로드한 검증 결과와 시험 결과를 비교하여 최종 결과를 생성하여, 이 최종 결과를 시나리오 데이터베이스(720)에 등록한다.
위의 설명에서, 제 1 데이터베이스 시험 자동화 장치(710a)가 시나리오 및 이에 대응하는 검증 결과를 시나리오 데이터베이스(720)에 등록하는 단계가 제 4 데이터베이스 시험 자동화 장치(710d)가 시나리오 데이터베이스(720)에 등록된 시나리오들 및 검증 결과들을 이용하여 제 3 시험 대상 데이터베이스(730c)를 시험하는 단계보다 선행하는 것으로 도시되어 있지만, 본 기술분야의 당업자는 상기 순서 는 바뀌거나 심지어 동시에 진행될 수 있다는 것을 이해할 수 있을 것이다. 또한, 당업자는 상기 데이터베이스 시험 자동화 장치들(710a-d)은 서로 동일한 기능을 수행하는 장치로서 서로 대체될 수 있다는 것도 이해할 것이다.
도 9와 도 10은 도 8의 데이터 흐름을 보다 상세히 설명하기 위한 도면이다. 이 중 도 9는 제 1 데이터베이스 시험 자동화 장치(710a)가 시나리오 및 이에 대응하는 검증 결과를 시나리오 데이터베이스(720)에 등록하는 단계에 관한 것이며, 도 10은 제 4 데이터베이스 시험 자동화 장치(710d)가 시나리오 데이터베이스(720)에 등록된 시나리오들 및 검증 결과들을 이용하여 제 3 시험 대상 데이터베이스(730c)를 시험하는 단계에 관한 것이다.
도 9 및 10에서는, 용이한 이해를 위해, 일부 구성요소들 만을 도시한 것임에 유의해야 한다. 또한, 실제로는 구성요소들이 메모리와 같은 주기억장치에 저장되어 있는 데이터들을 판독하거나 기록하는 것으로 실시될 수 있지만, 도 9 및 10에서는, 데이터베이스 시험 자동화 장치(710a-d)의 구성요소들 간에 데이터들이 송수신되는 것으로 도시되어 있음에 유의해야 한다.
굵은 실선은 네트워크를 통해 데이터가 실제로 송수신됨을 의미한다. 얇은 실선은 데이터베이스 시험 자동화 장치(710a, d) 내의 각각의 모듈 간의 데이터 흐름을 의미하는데, 여기서는 실제로 데이터가 송수신되지 않고, 메모리에 저장된 데이터들을 판독 및 기록하여 구현할 수 있다. 파선은 실제로 데이터가 송수신되는 것은 아니지만, 시나리오를 수행하고 그 결과를 받는다는 것을 의미한다.
또한, 제 1 데이터베이스 시험 자동화 장치(710a), 시나리오 데이터베이 스(720) 및 검증된 데이터베이스(740)가 네트워크에 연결되어 있지만, 용이한 이해를 위해 네트워크를 생략한다.
도 9를 참조하면, 제 1 데이터베이스 시험 자동화 장치(710a)는 시나리오 작성 인터페이스 모듈(711), 검증 결과 생성 모듈(712) 및 시나리오 및 검증 결과 등록 모듈(713)을 포함한다. 그리고, 시나리오 데이터베이스(720)에는 다수의 시나리오, 다수의 검증 결과, 및 다수의 최종 결과들이 등록되어 있다.
우선, 시나리오 작성 인터페이스 모듈(711)에서 시나리오 생성자에 의해 새로운 시나리오가 작성될 수 있다.
그 후, 검증 결과 생성 모듈(712)은 시나리오 작성 인터페이스 모듈(711)에서 작성된 새로운 시나리오를 수신할 수 있다. 그 후, 검증 결과 생성 모듈(712)은 상기 시나리오를 검증된 데이터베이스(740)에 대해 수행하고, 그 수행 결과를 검증 결과로서 수신할 수 있다.
그 후, 시나리오 및 검증 결과 등록 모듈(713)은 시나리오 작성 인터페이스 모듈(711)로부터 새로 작성된 시나리오를 수신하고, 또한 검증 결과 생성 모듈(712)로부터 새로 생성된 검증 결과를 수신할 수 있다. 그 후, 시나리오 및 검증 결과 등록 모듈(713)은 상기 시나리오와 검증 결과를 시나리오 데이터베이스(720)에 등록할 수 있다.
도 10을 참조하면, 제 4 데이터베이스 시험 자동화 장치(710d)는 시험 대상 데이터베이스 선택 인터페이스 모듈(714), 시나리오 선택 인터페이스 모듈(715), 시나리오 언로드 모듈(716), 시나리오 수행 모듈(717) 및 최종 결과 등록 모듈을 포함하고, 또한 시나리오들 및 검증 결과들을 저장할 수 있는 로컬 저장 장치(719)를 포함한다. 상기 로컬 저장 장치(719)에는 다수의 시나리오들 및 다수의 검증 결과들이 저장되어 있다. 그리고, 시나리오 데이터베이스(720)에는 다수의 시나리오, 다수의 검증 결과, 및 다수의 최종 결과들이 등록되어 있다. 그리고 다수의 시험 대상 데이터베이스(730a-d)들이 네트워크(미 도시)에 연결되어 있다. 본 실시예에서는 다수의 시험 대상 데이터베이스(730a-d)들 중에서 제 3 시험 대상 데이터베이스(730c)에 대해 시험이 수행되는 실시예를 설명한다.
우선, 시험 대상 데이터베이스 선택 인터페이스 모듈(714)을 이용하여, 시험 운용자는 다수의 시험 대상 데이터베이스(730a-d)들 중에서 시험을 수행할 시험 대상 데이터베이스를 선택할 수 있다. 시험 대상 데이터베이스 선택 인터페이스 모듈(714)은 네트워크(미 도시)에 연결된, 또는 제 3 시험 대상 데이터베이스(730c)가 접속할 수 있는 시험 대상 데이터베이스들(730a-d)의 목록을 시험 운용자에게 표시할 수 있다. 시험 운용자는 표시된 연결 가능한 시험 대상 데이터베이스들(730a-d)의 목록을 통해 시험할 시험 대상 데이터베이스(730c)를 선택할 수 있다. 금번 실시예에서는, 제 3 시험 대상 데이터베이스(730c)가 선택된 것으로 설명할 것이다. 그러나, 복수개의 시험 대상 데이터베이스(730a-d)가 선택될 수도 있다. 시험 대상 데이터베이스 선택 인터페이스 모듈(714)은 상기 시험 운용자로부터 선택된 시험 대상 데이터베이스의 정보를 시나리오 수행 모듈(717)에 제공할 수 있다.
도 10에 도시되어 있진 않지만, 제 4 데이터베이스 시험 자동화 장치(710d) 는 시험 운용자를 식별하기 위한 로그인 모듈(미 도시)을 포함할 수 있다. 시험 운용자는 시험을 수행할 시험 대상 데이터베이스(730a-d)를 선택하기 전에, 로그인하는 과정을 거쳐, 제 4 데이터베이스 시험 자동화 장치(710d)를 이용하여 시험하고자 하는 시험 운용자가 식별될 수 있다. 로그인 과정을 거쳐 식별된 시험 운용자 정보를 이용하여, 시험 대상 데이터베이스 선택 인터페이스 모듈(714)은 상기 시험 운용자가 접근 가능한 시험 대상 데이터베이스들(730a-d)의 목록만을 표시할 수 있다.
그 후, 시험 운용자는 시나리오 선택 인터페이스 모듈(715)을 이용하여 제 3 시험 대상 데이터베이스(730c)에 대해 수행할 시나리오를 선택할 수 있다. 시나리오 선택 인터페이스 모듈(715)은 시나리오 데이터베이스(720)로부터 시나리오 데이터베이스(720)에 등록된 시나리오들의 목록을 수신하여, 시험 운용자에게 표시할 수 있다. 로그인 과정을 거쳐 시험 운용자 정보가 식별된 경우, 시나리오 선택 인터페이스 모듈(715)은 상기 시험 운용자가 접근 권한을 가진 시나리오들의 목록만을 표시할 수 있다. 시험 운용자는 표시된 시나리오들의 목록을 통해 제 3 시험 대상 데이터베이스(730c)에 대해 수행할 시나리오를 선택할 수 있다. 상술한 바와 같이, 다수개의 시나리오를 선택할 수도 있다. 시나리오 선택 인터페이스 모듈(715)은 선택된 시나리오 정보를 시나리오 언로드 모듈(716)에 제공할 수 있다.
그 후, 시나리오 언로드 모듈(716)은 시나리오 선택 인터페이스 모듈(715)로부터 선택된 시나리오 정보를 수신할 수 있다. 시나리오 언로드 모듈(716)은 수신된 시나리오 정보에 따라 해당 시나리오가 로컬 저장 장치(719)에 존재하는지 검색 할 수 있다. 만약 존재하는 경우, 시나리오 언로드 모듈(716)은 로컬 저장 장치(719)에 저장된 해당 시나리오가 시나리오 데이터베이스(720)에 등록된 해당 시나리오와 일치하는지 확인할 수 있다. 확인 결과, 해당 시나리오가 서로 일치하고, 이에 대응하는 검증 결과도 서로 일치하는 경우, 일점 쇄선으로 표시한 바와 같이, 시나리오 언로드 모듈(716)은 해당 시나리오가 로컬 저장 장치(719)에 있다는 시나리오 정보를 시나리오 수행 모듈(717)에 제공하고, 해당 시나리오에 대응하는 검증 결과가 로컬 저장 장치(719)에 있다는 검증 결과 정보를 최종 결과 등록 모듈(718)에 제공할 수 있다.
만약 해당 시나리오가 로컬 저장 장치(719)에 존재하지 않거나, 설령 존재하더라도, 로컬 저장 장치(719)에 저장된 해당 시나리오와 시나리오 데이터베이스(720)에 등록된 해당 시나리오와 서로 일치하지 않는 경우에는, 시나리오 언로드 모듈(716)은 시나리오 데이터베이스(720)에 등록된 해당 시나리오와 이에 해당하는 검증 결과를 언로드할 수 있다. 그 후, 시나리오언로드 모듈(716)은 실선으로 표시한 바와 같이, 언로드한 시나리오와 검증 결과를 각각 시나리오 수행 모듈(717) 및 최종 결과 등록 모듈(718)에 제공할 수 있으며, 또한 언로드한 시나리오와 검증 결과를 로컬 저장 장치(719)에 저장할 수 있다.
그 후, 시나리오 수행 모듈(717)은, 경우에 따라, (일점 쇄선의 경우와 같이) 시나리오 언로드 모듈(716)로부터 시나리오 정보를 수신하여 로컬 저장 장치(719)로부터 시나리오를 읽어 오거나, (실선의 경우와 같이) 시나리오 언로드 모듈(716)로부터 시나리오를 수신할 수 있다. 그리고 시나리오 수행 모듈(717)은 시 험 대상 데이터베이스 선택 인터페이스 모듈(714)로부터 시험을 수행할 시험 대상 데이터베이스 정보를 수신하여 시험을 수행할 시험 대상 데이터베이스(730c)를 결정할 수 있다. 그 후, 시나리오 수행 모듈(717)은 시험을 수행하도록 결정된 제 3 시험 대상 데이터베이스(730c)에 대해, 상기 시나리오를 수행할 수 있다. 그리고 시나리오 수행 모듈(717)은 시나리오를 수행한 결과인 시험 결과를 수신할 수 있다. 시나리오 수행 모듈(717)은 수신된 시험 결과를 최종 결과 등록 모듈(718)에 제공할 수 있다.
그 후, 최종 결과 등록 모듈(718)은 시나리오 수행 모듈(717)로부터 시험 결과를 수신할 수 있다. 그리고 최종 결과 등록 모듈(718)은 경우에 따라, (일점 쇄선의 경우와 같이) 시나리오 언로드 모듈(716)로부터 검증 결과 정보를 수신하여 로컬 저장 장치(719)로부터 검증 결과를 읽어 오거나, (실선의 경우와 같이) 시나리오 언로드 모듈(716)로부터 검증 결과를 수신할 수 있다. 그 후, 최종 결과 등록 모듈(718)은 상기 시험 결과와 상기 검증 결과를 비교하여, 성공 여부를 포함하는 최종 결과를 생성할 수 있다. 최종 결과 등록 모듈(718)는 최종 결과를 시험 운용자에게 표시할 수 있으며, 또한 최종 결과를 시나리오 데이터베이스(720)에 등록할 수 있다.
본 발명이 속한 기술 분야에서 통상의 지식을 가진 자는 추가적으로, 다양한 예시적인 논리 블록들, 구성들, 회로들 및 본 명세서에 개시된 실시예와 연관하여 설명된 단계들이 전자 하드웨어, 컴퓨터 소프트웨어, 혹은 이들 모두의 조합으로서 구현될 수 있다는 점을 이해할 것이다. 이러한 하드웨어와 소프트웨어의 상호교환 가능성을 명확하게 예시하기 위해, 다양한 예시적인 컴포넌트들, 블록들, 구성들, 모듈들, 회로들, 및 단계들이 이들의 기능성의 견지에서 일반적으로 위에서 설명되었다. 이러한 기능성들이 하드웨어로 구현될지 혹은 소프트웨어로 구현될 지의 여부는 전체 시스템에 부과된 특정 어플리케이션 및 설계 제약들에 의존한다. 본 발명이 속한 기술 분야에서 통상의 지식을 가진 자들은 각 특정 어플리케이션에 대한 각기 다른 방법들로 상기 설명된 기능성을 구현할 수 있지만, 이러한 구현 결정들은 본 발명의 범위로부터 벗어나게 하는 것으로서 해석되지 않아야 한다.
본 명세서에서 개시된 상기 실시예들과 연관하여 설명된 방법 또는 단계들은 하드웨어로, 또는 프로세서에 의해 실행되는 소프트웨어 모듈로, 혹은 이들 둘의 조합으로 직접 구현될 수 있다. 소프트웨어 모듈은 RAM 메모리, 플래시 메모리, ROM 메모리, PROM 메모리, EPROM 메모리, EEPROM 메모리, 레지스터들, 하드 디스크, 이동식 디스크, CD-ROM, 혹은 당해 분야에 알려진 임의의 다른 형태의 저장 매체에 상주할 수 있다. 예시적인 저장 매체는 프로세서가 상기 저장 매체로부터 정보를 판독하고 이 저장 매체로 정보를 기록할 수 있도록 상기 프로세서에 연결된다. 대안적으로, 상기 저장 매체는 상기 프로세서에 일체화될 수 있다. 상기 프로세서 및 상기 저장 매체는 ASIC에 상주할 수 있다. 상기 ASIC은 무선 디바이스 혹은 사용자 터미널에 상주할 수 있다. 대안적으로, 상기 프로세서 및 상기 저장 매체는 무선 디바이스 혹은 사용자 터미널에서 이산 컴포넌트들로서 상주할 수 있다.
상기 개시된 실시예들의 이전 설명은 본 발명이 속한 기술분야에서 통상의 지식을 가진 자가 본 발명을 제조하거나 사용하도록 제공될 수 있다. 이들 실시예들에 대한 다양한 수정이 본 발명이 속한 기술분야에서 통상의 지식을 가진 자들에게는 즉시 명백할 것이며, 본 명세서에서 한정된 일반 원리들은 본 발명의 범위 혹은 사상에서 벗어남이 없이 다른 실시예들에 적용될 수 있다. 따라서, 본 발명은 본 명세서에서 보여진 상기 실시예들에 제한되지 않는 것으로 의도되지만, 후속하는 청구항들에 의해 한정되는 바와 같은 원리들 및 신규한 특징들과 일치하는 가장 넓은 범위에 따른다.
도 1은 본 발명의 일 실시예에 따른 데이터베이스 시험 자동화 시스템을 대략적으로 도시한 개념도이다.
도 2는 본 발명의 일 실시예에 따른 데이터베이스 시험 자동화 시스템의 데이터베이스 시험 자동화 장치의 기능을 예시적으로 도시한 블록도이다.
도 3은 본 발명의 일 실시예에 따른 데이터베이스 시험 자동화 시스템의 시나리오 데이터베이스를 예시적으로 도시한 도면이다.
도 4는 본 발명의 일 실시예에 따른 데이터베이스 시험 자동화 방법을 대략적으로 도시한 순서도이다.
도 5는 도 4의 데이터베이스 시험 자동화 방법 중 시나리오 및 검증 결과를 등록하는 단계를 예시적으로 도시한 순서도이다.
도 6은 도 4의 데이터베이스 시험 자동화 방법 중 시험 대상 데이터베이스를 시험하는 단계를 예시적으로 도시한 순서도이다.
도 7은 본 발명의 일 실시예에 따른 데이터베이스 시험 자동화 시스템이 운용되고 있는 네트워크 연결도를 예시적으로 도시한다.
도 8은 도 7의 네트워크 연결도에서 송수신되고 있는 데이터의 흐름을 예시적으로 도시한 데이터 흐름도이다..
도 9는 도 8의 데이터 흐름도 중 시나리오 및 검증 결과를 등록하는 단계를 예시적으로 더욱 상세히 도시한다.
도 10은 도 8의 데이터 흐름도 중 데이터베이스를 시험하는 단계를 예시적으 로 더욱 상세히 도시한다.

Claims (23)

  1. 삭제
  2. 시험 대상 데이터베이스를 시험하기 위한 시나리오, 및 상기 시나리오에 대응하고 검증된 데이터베이스를 이용하여 생성된 검증 결과를 원격 시나리오 데이터베이스에 등록하는 시나리오 등록 단계; 및
    상기 시나리오를 이용하여 상기 시험 대상 데이터베이스를 시험하는 데이터베이스 시험 단계를 포함하며,
    상기 시나리오 등록 단계는, 상기 시나리오를 작성하는 시나리오 작성 단계; 상기 검증된 데이터베이스에 접속하여, 상기 시나리오를 상기 검증된 데이터베이스에 대해 수행하고, 수행한 결과를 검증 결과로서 수신하는 검증 결과 생성 단계; 및 상기 시나리오와 상기 검증 결과를 상기 원격 시나리오 데이터베이스에 접속하여 등록하는 시나리오 및 검증 결과 등록 단계를 포함하고,
    상기 데이터베이스 시험 단계는, 상기 원격 시나리오 데이터베이스에 접속하여, 상기 시나리오와 상기 검증 결과를 언로드하는 시나리오 언로드 단계; 상기 시험 대상 데이터베이스에 접속하여, 상기 언로드한 시나리오를 상기 시험 대상 데이터베이스에 대해 수행하고, 수행한 결과를 시험 결과로서 수신하는 시나리오 수행 단계; 및 상기 시험 결과와 상기 언로드한 검증 결과를 비교하고, 최종 결과를 상기 원격 시나리오 데이터베이스에 접속하여 등록하는 최종 결과 생성 단계를 포함하며,
    상기 시험 대상 데이터베이스, 상기 검증된 데이터베이스 및 상기 원격 시나리오 데이터베이스는 네트워크를 통해 연결되는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  3. 제 2 항에 있어서,
    상기 시나리오 작성 단계와 상기 검증 결과 생성 단계 사이에, 상기 시나리오 작성 단계에서 작성된 상기 시나리오를 검증하는 단계를 더 포함하는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  4. 제 2 항에 있어서,
    상기 최종 결과 생성 단계에서, i) 상기 시험 결과와 상기 언로드한 검증 결과가 동일한 경우에는, 시험 일시, 상기 시험 대상 데이터베이스의 식별번호 및 성공을 의미하는 정보가 상기 최종 결과와 함께 상기 원격 시나리오 데이터베이스에 등록되고, ii) 상기 시험 결과와 상기 언로드한 검증 결과가 동일하지 않은 경우에는, 시험 일시, 상기 시험 대상 데이터베이스의 식별번호, 실패를 의미하는 정보 및 상기 시험 결과와 상기 언로드한 검증 결과 중에서 서로 다른 부분이 상기 원격 시나리오 데이터베이스에 등록되는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  5. 제 4 항에 있어서,
    상기 식별번호에 의해 식별될 수 있는 상기 시험 대상 데이터베이스에 대해, 상기 시험 일시에 따른 상기 최종 결과들을 표시하는 단계를 더 포함하는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  6. 제 2 항에 있어서,
    상기 시나리오 등록 단계는 제 1 데이터베이스 시험 자동화 장치에서 실행되고, 상기 데이터베이스 시험 단계는 제 2 데이터베이스 시험 자동화 장치에서 실행될 수 있는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  7. 제 2 항에 있어서,
    상기 데이터베이스 시험 단계는, 서로 다른 시험 대상 데이터베이스들에 대해 동시에 실행될 수 있고, 서로 다른 데이터베이스 시험 자동화 장치들에서 동시에 실행될 수 있는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  8. 제 2 항에 있어서,
    상기 시나리오는 상기 시험 대상 데이터베이스가 SQL 표준을 만족하는지의 여부를 시험하기 위한 시나리오를 포함하는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  9. 제 2 항에 있어서,
    상기 시나리오는 상기 시험 대상 데이터베이스에 저장된 기존 데이터베이스를 제거하기 위한 SQL문, 상기 시험 대상 데이터베이스에 새로운 데이터베이스를 생성하기 위한 SQL문, 상기 새로운 데이터베이스에 데이터들을 입력하기 위한 SQL문, 상기 새로운 데이터베이스로부터 선택하고자 하는 데이터를 검색하는 SQL문 또는 이들의 조합을 포함하는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  10. 시험 대상 데이터베이스를 시험하기 위한 시나리오, 및 상기 시나리오에 대응하고 검증된 데이터베이스를 이용하여 생성된 검증 결과를 원격 시나리오 데이터베이스에 등록하는 시나리오 등록 단계; 및
    상기 시나리오를 이용하여 상기 시험 대상 데이터베이스를 시험하는 데이터베이스 시험 단계를 포함하며,
    상기 시나리오 등록 단계는, 상기 시나리오를 작성하는 시나리오 작성 단계; 상기 시나리오에 대응하는 검증 결과를 생성하는 검증 결과 생성 단계; 및 상기 시나리오와 상기 검증 결과를 상기 원격 시나리오 데이터베이스에 접속하여 등록하는 시나리오 및 검증 결과 등록 단계를 포함하며, 상기 시나리오 등록 단계를 반복함에 따라, 상기 원격 시나리오 데이터베이스에는 다수의 시나리오들 및 이들에 대응하는 다수의 검증 결과들이 등록되고,
    상기 데이터베이스 시험 단계는, 상기 원격 시나리오 데이터베이스에 접속하여, 상기 원격 시나리오 데이터베이스에 등록된 상기 다수의 시나리오들 중에서 상기 시험 대상 데이터베이스를 시험할 시나리오를 선택하는 시나리오 선택 단계; 상기 선택된 시나리오와 이에 대응하는 검증 결과를 언로드하여 로컬 저장 장치에 저장하는 시나리오 언로드 단계; 상기 시험 대상 데이터베이스에 접속하여, 상기 언로드한 시나리오를 상기 시험 대상 데이터베이스에 대해 수행하고 수행한 결과를 시험 결과로서 수신하는 시나리오 수행 단계; 및 상기 시험 결과와 상기 언로드한 검증 결과를 비교하고, 최종 결과를 상기 원격 시나리오 데이터베이스에 접속하여 등록하는 최종 결과 생성 단계를 포함하며,
    상기 시험 대상 데이터베이스, 상기 검증된 데이터베이스 및 상기 원격 시나리오 데이터베이스는 네트워크를 통해 연결되는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  11. 제 10 항에 있어서,
    상기 검증 결과 생성 단계는, 상기 검증된 데이터베이스에 접속하여, 상기 시나리오를 상기 검증된 데이터베이스에 대해 수행하고, 수행된 결과를 상기 검증 결과로서 수신하는 단계를 포함하는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  12. 제 10 항에 있어서,
    상기 시나리오 선택 단계에서 상기 다수의 시나리오들 중에서 복수개의 시나리오들이 선택되며, 상기 시나리오 언로드 단계에서 상기 복수개의 시나리오들이 언로드되고, 상기 시나리오 수행 단계에서 상기 복수개의 시나리오들이 상기 시험 대상 데이터베이스에 대해 연속하여 수행되는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  13. 제 10 항에 있어서,
    상기 시나리오 및 검증 결과 등록 단계에서, 상기 시나리오 및 상기 검증 결과는 상기 시나리오에 해당하는 접근 권한 정보와 함께 상기 원격 시나리오 데이터 베이스에 등록되며, 상기 시나리오 선택 단계와 상기 시나리오 언로드 단계 사이에, 상기 선택된 시나리오에 해당하는 상기 접근 권한 정보를 이용하여, 상기 선택된 시나리오에 대해 접근 권한이 있는지를 인증하는 단계를 더 포함하는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  14. 제 10 항에 있어서,
    상기 데이터베이스 시험 단계를 반복함에 따라, 상기 로컬 저장 장치에는 다수의 언로드된 시나리오들 및 이들에 대응하는 다수의 언로드된 검증 결과들이 저장되며,
    상기 시나리오 선택 단계와 상기 시나리오 언로드 단계 사이에, 상기 시나리오 선택 단계에서 선택된 시나리오가 상기 로컬 저장 장치에 저장되어 있는지, 그리고 상기 로컬 저장 장치에 저장된 시나리오와 일치하는지를 확인하는 단계를 더 포함하며, 상기 로컬 저장 장치에 존재하지 않거나 상기 로컬 저장 장치에 존재하는 시나리오와 일치하지 않는 경우에만, 상기 시나리오 언로드 단계에서 상기 선택된 시나리오와 이에 대응하는 검증 결과를 언로드하여 로컬 저장 장치에 저장하는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  15. 제 14 항에 있어서,
    상기 시나리오 선택 단계에서 선택된 시나리오가 상기 로컬 저장 장치에 저장된 시나리오와 일치하는 경우, 상기 로컬 저장 장치에 저장된 상기 시나리오와 이에 대응하는 검증 결과를 이용하여 상기 시나리오 수행 단계 및 상기 최종 결과 생성 단계를 실행하는 것을 특징으로 하는 데이터베이스 시험 자동화 방법.
  16. 컴퓨터에 제 2 항 내지 제 15항 중 어느 한 항의 데이터베이스 시험 자동화 방법을 실행시키기 위한 프로그램을 기록한 컴퓨터로 읽을 수 있는 매체.
  17. 시험 대상 데이터베이스를 시험하기 위한 시나리오들 및 이에 대응하는 검증 결과들이 등록될 수 있는 시나리오 데이터베이스를 포함하는 시나리오 데이터베이스 서버; 및
    상기 시나리오 데이터베이스 서버와 상기 시험 대상 데이터베이스에 네트워크를 통해 연결되어, 상기 시험 대상 데이터베이스의 시험을 자동화하기 위한 적어도 하나의 데이터베이스 시험 자동화 장치를 포함하며, 상기 데이터베이스 시험 자동화 장치는, 상기 시나리오들 및 상기 검증 결과들을 상기 시나리오 데이터베이스에 등록하기 위한 시나리오 등록부; 및 상기 시나리오들을 이용하여 상기 시험 대상 데이터베이스를 시험하기 위한 데이터베이스 시험부를 포함하며,
    상기 시나리오 등록부는, 상기 시나리오들을 작성하기 위한 인터페이스를 제공하는 시나리오 작성 인터페이스 모듈; 상기 작성된 시나리오들에 대응하는 검증 결과들을 생성하기 위한 검증 결과 생성 모듈; 및 상기 작성된 시나리오들 및 상기 검증 결과들을 상기 시나리오 데이터베이스에 접속하여 등록하기 위한 시나리오 등록 모듈을 포함하고,
    상기 데이터베이스 시험부는, 상기 시나리오 데이터베이스에 접속하여 상기 시나리오 데이터베이스에 등록된 상기 시나리오들 중에서 상기 시험 대상 데이터베이스를 시험할 시나리오를 선택하기 위한 인터페이스를 제공하는 시험 시나리오 선택 인터페이스 모듈; 상기 시나리오 데이터베이스에 접속하여 상기 선택된 시나리오와 이에 대응하는 검증 결과를 상기 시나리오 데이터베이스로부터 언로드하기 위한 시나리오 언로드 모듈; 상기 시험 대상 데이터베이스에 접속하여, 상기 언로드한 시나리오를 상기 시험 대상 데이터베이스에 대해 수행하고 수행한 결과를 시험 결과로서 수신하기 위한 데이터베이스 시험 모듈; 및 상기 시험 결과와 상기 언로드한 검증 결과를 비교하여 최종 결과를 생성하는 비교 모듈을 포함하는 것을 특징으로 하는 데이터베이스 시험 자동화 시스템.
  18. 삭제
  19. 제 17 항에 있어서,
    상기 적어도 하나의 데이터베이스 시험 자동화 장치들과 상기 네트워크를 통해 연결되는 검증된 데이터베이스를 더 포함하며, 상기 검증 결과 생성 모듈은 상기 검증된 데이터베이스에 접속하여 상기 작성된 시나리오들을 상기 검증된 데이터베이스에 대해 수행하고 수행한 결과들을 상기 검증 결과들로서 수신하는 것을 특징으로 하는 데이터베이스 시험 자동화 시스템.
  20. 제 17 항에 있어서,
    상기 시나리오 등록부는 상기 시나리오 데이터베이스에 접속하여 상기 시나리오 데이터베이스에 등록된 상기 시나리오들 및 이들에 대응하는 상기 검증 결과들에 대해 입력, 출력, 변경, 삭제, 복사, 이동 또는 이들의 조합을 수행하기 위한 인터페이스를 제공하기 위한 시나리오 관리 인터페이스 모듈을 더 포함하는 것을 특징으로 하는 데이터베이스 시험 자동화 시스템.
  21. 제 17 항에 있어서,
    상기 시나리오 데이터베이스에 등록된 시나리오들은 계층적으로 구성되며, 상위 계층의 시나리오를 선택함에 따라, 상기 상위 계층의 시나리오에 종속된 하위 계층의 시나리오들이 상기 시험 대상 데이터베이스에 대해 수행되는 것을 특징으로 하는 데이터베이스 시험 자동화 시스템.
  22. 제 17 항에 있어서,
    상기 데이터베이스 시험 자동화 장치는 상기 언로드한 시나리오 및 이에 대응하는 검증 결과를 저장하기 위한 로컬 저장 장치를 더 포함하며, 상기 시험 대상 데이터베이스를 시험할 시나리오를 선택함에 따라, 상기 선택된 시나리오와 이에 대응하는 검증 결과에 대해 상기 시나리오 데이터베이스를 기준으로 상기 로컬 저장 장치를 동기화하기 위한 시나리오 동기화 모듈을 더 포함하는 것을 특징으로 하 는 데이터베이스 시험 자동화 시스템.
  23. 제 17 항에 있어서,
    상기 시나리오 데이터베이스 서버에 복수의 상기 데이터베이스 시험 자동화 장치들이 연결되며, 상기 복수의 데이터베이스 시험 자동화 장치들 각각은 상기 시나리오 데이터베이스 서버를 이용하여 복수의 상기 시험 대상 데이터베이스를 시험하는 것을 특징으로 하는 데이터베이스 시험 자동화 시스템.
KR1020080129390A 2008-12-18 2008-12-18 시나리오 기반의 데이터베이스 시험 자동화 방법 및 시스템 KR101073816B1 (ko)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020080129390A KR101073816B1 (ko) 2008-12-18 2008-12-18 시나리오 기반의 데이터베이스 시험 자동화 방법 및 시스템

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020080129390A KR101073816B1 (ko) 2008-12-18 2008-12-18 시나리오 기반의 데이터베이스 시험 자동화 방법 및 시스템

Publications (2)

Publication Number Publication Date
KR20100070713A KR20100070713A (ko) 2010-06-28
KR101073816B1 true KR101073816B1 (ko) 2011-10-14

Family

ID=42368416

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020080129390A KR101073816B1 (ko) 2008-12-18 2008-12-18 시나리오 기반의 데이터베이스 시험 자동화 방법 및 시스템

Country Status (1)

Country Link
KR (1) KR101073816B1 (ko)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101158637B1 (ko) * 2010-10-29 2012-06-26 한국과학기술원 효율적 시뮬레이션 정보 수집을 위한 실험 틀 및 이를 이용한 시뮬레이션 방법 및 시스템
US20120239430A1 (en) * 2011-03-14 2012-09-20 Nvoq Incorporated System and Method to Provide Metrics Regarding a Physician's Performance to Protocol and Real-Time Alerts When Performance Deviates
KR101845208B1 (ko) * 2017-12-28 2018-04-03 최영철 데이터베이스와 애플리케이션을 위한 웹기반 성능개선 방법
CN110309052A (zh) * 2019-05-22 2019-10-08 梁俊杰 一种数据校验方法以及相关设备
KR102334923B1 (ko) * 2019-11-06 2021-12-03 주식회사 에이젠글로벌 인공지능을 이용한 대출 확대 가설 검정 시스템 및 이를 이용한 방법
CN114721958A (zh) * 2022-04-18 2022-07-08 四创科技有限公司 一种多数据库系统的接口自动化测试方法及终端

Also Published As

Publication number Publication date
KR20100070713A (ko) 2010-06-28

Similar Documents

Publication Publication Date Title
CN110309071B (zh) 测试代码的生成方法及模块、测试方法及系统
KR101073816B1 (ko) 시나리오 기반의 데이터베이스 시험 자동화 방법 및 시스템
Verbeek et al. Woflan 2.0 A petri-net-based workflow diagnosis tool
US6182245B1 (en) Software test case client/server system and method
CN103176973B (zh) 用于生成数据库的测试工作负载的系统和方法
CN109325030A (zh) 报文处理方法、装置、计算机设备和存储介质
US20070240154A1 (en) System and method for software integration and factory deployment
CN105144088A (zh) 元数据与源代码的关联以及基于其的应用和服务
CN110083340A (zh) 代码生成方法、装置、计算机设备及存储介质
US20220035847A1 (en) Information retrieval
US20090006493A1 (en) Method For Enabling Traceability And Recovery From Errors During Migration Of Software Applications
CN115039084A (zh) 数据流图的部件的单元测试
CN112364049B (zh) 数据同步脚本生成方法、系统、终端及存储介质
CN109753289B (zh) 一种美术资源合并方法、装置、电子设备和存储介质
US11914574B2 (en) Generation of inconsistent testing data
CN111694612A (zh) 配置检查方法、装置、计算机系统及存储介质
CN111737227A (zh) 数据修改方法及系统
US7908249B1 (en) Closed-loop feedback control system for online services
CN108984337A (zh) 一种数据同步异常的修复方法、修复装置、介质和计算设备
US10963227B2 (en) Technique for transforming a standard messaging component to a customized component
CN111737148A (zh) 自动回归测试方法、装置、计算机设备及存储介质
Rozinat et al. Process mining of test processes: A case study
CN114328278A (zh) 分布式仿真测试方法、系统、可读存储介质及计算机设备
Ostrand et al. A Tool for Mining Defect-Tracking Systems to Predict Fault-Prone Files.
CN112288567A (zh) 银行账目信息处理方法、装置及可读介质

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant
FPAY Annual fee payment

Payment date: 20141007

Year of fee payment: 4

FPAY Annual fee payment

Payment date: 20151006

Year of fee payment: 5

FPAY Annual fee payment

Payment date: 20161005

Year of fee payment: 6

FPAY Annual fee payment

Payment date: 20180207

Year of fee payment: 7

FPAY Annual fee payment

Payment date: 20180928

Year of fee payment: 8

FPAY Annual fee payment

Payment date: 20190930

Year of fee payment: 9