我刚刚开始使用Bryntum Siesta和ExtJs进行自动化测试。
我的第一个非常简单的测试工作像我期望的那样。
现在我遇到了DRY代码的问题。

我正在尝试为登录测试编写DRY代码。

实际上,这里有两种情况:
-具有有效数据的登录名
-使用无效数据的登录名(错误的AND和/或用户名)

在Java中,它将与全局变量/函数一起使用。
而且我认为,我之前做过类似javascript全局变量的操作。
但这是行不通的。

所以我有我的试用功能:

    var testFunction = function(){
    console.log("I am a global function, and i am working!");
};


我的目标是在Testfile的t.chain()中调用它:

{
            type: LoginUsername,
            target: ">>#loginviewIdemId #loginForm #pwTriggerForm #fldName",
            desc: 'Type in Username',
        },

        function(next) {
            testFunction();
            next();
        },


当我调用在链上方的此测试文件中创建的函数时,它确实起作用。
我很抱歉,如果它有一些基本的javascript问题,但我被毁了:D

提前致谢!

最佳答案

您可以扩展Test类以添加实用程序方法,并避免违反DRY。本指南对此进行了总结:https://www.bryntum.com/docs/siesta/#!/guide/extending_test_class

让我们创建2个特殊的断言,它们将检查传递的数字的奇数奇偶校验。通常,断言需要检查其语句并使用{@link Siesta.Test#pass}或{@link Siesta.Test#fail}方法报告结果。

Class('MyProject.MyTestClass', {
    isa     : Siesta.Test.ExtJS,

    methods : {

        isOdd : function (number, description) {
            if (number % 2) {
                this.pass(description);
            } else {
                this.fail(description, {
                    assertionName   : 'isOdd',
                    got             : number,
                    annotation      : 'Need odd number'
                });
            }
        },

        isEven : function (number, description) {
            if (!(number % 2)) {
                this.pass(description);
            } else {
                this.fail(description, {
                    assertionName   : 'isEven',
                    got             : number,
                    annotation      : 'Need even number'
                });
            }
        }
    }
})


失败时,请尝试提供尽可能多的有关失败的信息,并以可读形式格式化失败消息。请参考{@link Siesta.Test#fail}
方法文档中的其他选项。

要使线束使用新的测试类,您必须通过设置{@link Siesta.Harness#testClass}配置选项来指定要使用的测试类:

harness.configure({
    title       : 'Awesome Test Suite',

    testClass   : MyProject.MyTestClass,

    preload     : [
        ...
    ]
})


应该在siesta-all.js文件之后立即加载测试类:

<!DOCTYPE html>
<html>
    <head>
        <link rel="stylesheet" type="text/css" href="__path_to_siesta__/resources/css/siesta-all.css">
        <script type="text/javascript" src="__path_to_siesta__/siesta-all.js"></script>

        <!-- The file with new test class -->
        <script type="text/javascript" src="lib/MyTestClass.js"></script>

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

    <body>
    </body>
</html>


现在,您可以在所有测试中使用自定义断言或实用程序方法:

describe('My test', function(t) {
    var nbr = 1;

    t.isEven(nbr); // Will fail
})

09-17 23:05