2017-05-09 3 views
0

테스트 케이스에서 설치 스크립트를 실행하고 일부 데이터를 준비하려고합니다. 내가 연결 정의한, 글로벌 속성에서 사용자 & 암호는 다음을 참조하십시오 enter image description here설치 스크립트에서 전역 속성을 참조하는 방법은 무엇입니까?

지금 내가 좋아하는 것 대신에 하드 연결, 사용자 및 전역 속성을 참조하는 암호를 코딩하는 것이 가능할까요?

import groovy.sql.Sql 
def jdbcDriver = "net.sourceforge.jtds.jdbc.Driver" 
com.eviware.soapui.support.GroovyUtils.registerJdbcDriver(jdbcDriver) 
def jdbcConnection = "jdbc:jtds:sqlserver://localhost/mydb" 
def jdbcConnectionUser="dbuser" 
def jdbcConnectionPassword="dbpswrd" 
log.info jdbcConnection 
//log.info ${#Global#JDBC_CONNECTION_STRING} <-- this doesn't work ?? 
//${#Global#JDBC_CONNECTION_STRING}, ${#Global#DBUSER}, ${#Global#DBPASS} 
def db = [url:jdbcConnection,user:jdbcConnectionUser,password:jdbcConnectionPassword,driver:jdbcDriver] 
try 
{ 
    def connection = Sql.newInstance(db.url, db.user, db.password, db.driver) 
    context.setProperty("dbconn",connection) 
    log.info "connected to the database" 
}catch(Exception e){ 
    log.error "Could not connect to the database" 
} 
if(context.dbconn) 
{ 
    def sql = context.dbconn  
    log.info "executing setup script" 
    sql.execute "update table_a set column_b = 'S' where column_c = 'something'" 
    sql.close() 
} 

나는 다음과 같은 구문을 사용하여 전역 속성을 참조하지만 작동하는이 발견 아무 소용이

${#Global#JDBC_CONNECTION_STRING} 

답변

0

에 해봤 질문을하기 전에 설명서를 참조해야합니다.

def globalProperty = com.eviware.soapui.SoapUI.globalProperties.getPropertyValue("MyProp") 

https://www.soapui.org/scripting-properties/tips-tricks.html#1-2-Get-and-Set-Settings

:

def jdbcConnection = com.eviware.soapui.SoapUI.globalProperties.getPropertyValue("JDBC_CONNECTION_STRING") 
def jdbcConnectionUser= com.eviware.soapui.SoapUI.globalProperties.getPropertyValue("DBUSER") 
def jdbcConnectionPassword= com.eviware.soapui.SoapUI.globalProperties.getPropertyValue("DBPASS") 

그리고 여기에 내가 대답과 관련 발췌를 볼 수있는 링크입니다