javascript - 如何使用 javascript 更改 javascript 文件中的 url 自动化测试

标签 javascript automation stubbing

我正在尝试在自动化测试中修改 javascript 文件中的 URL。这样我就可以指出服务的 stub 版本。我用于测试的框架是Serenity-js(使用 Protractor )

在我的 HTML DOM 中,我有:

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

main.js

var DataService = (function () {
    function DataService(http) {
        this.http = http;
    }
    DataService.prototype.getStudentDetails = function (id) {
        var parcel = this.http
            .get('http://127.0.0.1/endpoint/' + id)
            .map(function (res) {
            return __WEBPACK_IMPORTED_MODULE_2__student_model__["a"].createStudent(res.json());
        });
        return student;
    };
    return DataService;
}());

我需要更改的部分是 127.0.0.1/endpoint

我知道我使用 $.document.write 冷更改了 HTML DOM或$().append但不知道如何更改/覆盖 DOM 元素。

最佳答案

这很简单,但是有很多方法可以做到!

  1. 作为运行测试之前设置阶段的一部分,您可以使用 sedawk 预处理 main.js 文件> 编写脚本并将所有出现的 127... 字符串替换为其他内容。
  2. 更改生产系统中的代码以从包含所有 url 端点的配置变量中读取。然后您可以在测试脚本中更改该对象。
  3. 使用您的测试脚本将函数替换为其他内容。这是 @alok 在注释中建议的,但是注释缺少 prototype,并且该方法也不应该被调用,因此代码应该如下所示:

#3 的示例:

 const newFnString = DataService.prototype.getStudentDetails.toString()
                         .replace("127.0.0.1", "something.com");
 DataService.prototype.getStudentDetails = new Function(newFnString);

当然,您可以将 DataService.prototype.getStudentDetails 替换为任何给定的函数,因为您可以完全控制它(除非它隐藏在闭包中)。

附注试图通过让 JavaScript 更难被篡改来保护你的系统只是通过默默无闻来实现安全——这不是真实的。任何攻击者都可以读取网络请求,并在 curl 或 Postman 中重放它们。

关于javascript - 如何使用 javascript 更改 javascript 文件中的 url 自动化测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43999017/

相关文章:

javascript - 按值比较数组中的所有对象

algorithm - 轮径和轮距之比对车辆的定位和所需航向有什么影响?

visual-studio - 使用 EnvDTE.Solution - 如何删除源代码管理绑定(bind)

javascript - 如何使用 React Hooks 捕获最后一个输入字母

javascript - JS-如何在 Mouseout 上更改图像

c# - 有没有办法用白色激活一个窗口?

rspec - 创建新的 stub 方法,以检查该方法是否存在于Rspec中

mockito - 在Mockito stub 中传递实际参数

ruby - should_receive 会做一些我不期望的事情吗?

Javascript-用charAt一个字母+一个字母等显示单词