2017-10-02 9 views
0

저는 Sencha ExtJS 6.2 메더 응용 프로그램에 Bryntum Siesta 4.3.2-lite를 구현하고 ExtJS Essentials book을 계속 따르려고합니다.시에 스타 테스트 러너가 정의되지 않은 오류의 '저장소'를 제공합니다.

나는 Siesta Test Runner의 index.htmlindex.js도 만들었습니다. 필요한 Siesta 파일을 수집했습니다. js 및 CSS를 Siesta/resources 폴더에 추가합니다.

siesta-all.js:45330 Uncaught TypeError: Cannot read property 'store' of undefined 
at constructor.initComponent (http://nuri/webex/oweb/test/Siesta/js/siesta-all.js:45330:1458463) 

내가 Bryntum forums에 대답을 발견하고는 ExtJS 파일을 활용하는 포함되지 않습니다 말한다 : 나는 브라우저에서 테스트 러너를 실행하면이 오류를 제공합니다. 나는 똑같이하고 ExtJS 부분을 주석 처리했지만 여전히 오류는 계속됩니다. 어떤 조언을 환영합니다.

일부 발췌 문장 : 테스트 러너 (index.html);

<!DOCTYPE html> 
<html> 
<head> 
    <meta http-equiv="content-type" content="text/html; charset=UTF-8"> 
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"> 
    <title>Siesta Examples</title> 

    <link rel="stylesheet" type="text/css" href="https://cdnjs.cloudflare.com/ajax/libs/extjs/6.2.0/classic/theme-neptune/resources/theme-neptune-all.css"> 
    <!-- Siesta CSS --> 
    <link rel="stylesheet" type="text/css" href="../Siesta/css/siesta-all.css"> 

    <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/extjs/6.2.0/ext-all-debug.js"></script> 
    <!-- Siesta application --> 
    <script type="text/javascript" src="../Siesta/js/siesta-all.js"></script> 

    <!-- Additional Siesta files, not required if you don't use code coverage feature --> 
    <!-- <script type="text/javascript" src="../siesta-coverage-all.js"></script> --> 

    <!-- A sample utility class with convenience methods helping you write your tests more efficiently --> 
    <!-- <script src="lib/Your.Test.Class.js" type="text/javascript"></script> --> 

    <!-- The test harness --> 
    <script type="text/javascript" src="index.js"></script> 
</head> 
<body> 
</body> 
</html> 

하네스 (하는 index.js);

var harness = new Siesta.Harness.Browser.ExtJS(); 
harness.configure({ 
    title: 'OWeb Test', 
    //viewDOM: true, 
    preload: [ 
     //'../../../webex/build/production/OWeb/app.js', 
     //'../../../webex/build/production/OWeb/resources/OWeb-all.css', 
     //'https://cdnjs.cloudflare.com/ajax/libs/extjs/6.2.0/classic/theme-neptune/resources/theme-neptune-all.css', 
     //'https://cdnjs.cloudflare.com/ajax/libs/extjs/6.2.0/ext-all-debug.js' 
    ] 
}); 
harness.start(
    { 
     group: 'Login', 
     items: [ 
      '010_login.t.js' 
     ] 
    } 
); 

테스트 파일 (010_login.t.js);

describe('Testing Login screen', function (t) { 
    t.it('Should to login', function (t) { 
     t.chain(
      {waitForCQ: 'window[title=Login]'}, 
      {click: '>> textfield[itemId=userName]'}, 
      {type: '[email protected]', target:'>> textfield[itemId=userName]'}, 
      {click: '>> textfield[itemId=edtPassword]'}, 
      {type: 'superSecretPass', target:'>> textfield[itemId=edtPassword]'}, 
      {click: '>> button[text=Submit]'}, 
      {waitForCQNotFound: 'window[title=Login]', desc: 'Login window should destroy'} 
     ) 
    }) 
}); 

답변

2

스 니펫에서 - 당신은 여전히 ​​HTML 페이지 (cloudflare의)에 Ext JS 라이브러리 파일을 포함하고 있습니다. 이 파일들을 제거해야합니다. 샘플 하네스 HTML 페이지는 여기에서 찾을 수 있습니다 :

https://www.bryntum.com/docs/siesta/#!/guide/siesta_getting_started

<!DOCTYPE html> 
<html> 
<head> 
    <meta http-equiv="content-type" content="text/html; charset=UTF-8"> 
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"> 

    <title>Sample harness</title> 

    <link rel="stylesheet" type="text/css" href="__SIESTA_FOLDER__/resources/css/siesta-all.css"> 
    <script type="text/javascript" src="__SIESTA_FOLDER__/siesta-all.js"></script> 

    <script type="text/javascript" src="index.js"></script> 
</head> 

<body> 
</body>