Angular2+ 使用 Protractor 与 Modify Header Value (HTTP Headers) 插件 完成 Windows Authorization 验证

入职新公司第二周,接到了一个E2E测试的任务,两天的时间把所有的测试条件都写完了,结果剩下三天都卡在了Windows Authorization验证这里。

先说一下公司项目Authorize的逻辑

第一步,输入网址后,将重定向到公司统一的登录网站,需要Windows Authorization。

第二部,验证成功的话,将跳转到公司SSO网站,返回相对应网站的cookie

第三部,使用cookie访问用户想访问的网站

失败想法一:

刚开始很偷懒的想用Protractor去抓输入框和登录按钮就好了么。事实证明,这个想法还是太天真。因为浏览器里面的 Windows Authorization 对话框是不存在于DOM上的,所以Protractor是抓不到这个窗口的。

那这个可以理解,换方案。

失败想法二:

stackoverflow.com大法好,搜索了一圈之后,找到第二种方法是在URL中输入http://username:[email protected]。

结果发现不好用,仔细看了看帖子,发现这都是2017年之前的帖子,于是我去Chrome官网查了相关资料,发现这个方法在V59就被禁止了。

好吧,下一个方案

失败想法三:

这是时候,就要想我能不能绕过认证,直接拿cookie去进行验证呢?

在做这个方案的时候,我可悲的发现,Protractor做不了这件事,没有方法去配置header里面的cookie,即使配置了,也没有按照逻辑去运行。

比如browser.manage().addCookie(),这个方法一直没有按照我的预想去运行,不知道有没有大神能指导我一下

也许我没找到这个正确的方法吧……

失败想法四:

依然是stackoverflow.com,这个方法(Link)我是没有成功,不知道国外那帮大神是怎么干的,理论上应该可行。这里我可以跟大家说这个解决方法的思路,这个思路是成功的,之后我会说解决方案。

这个方法的核心是加了一层proxy,当Protractor启动后,chrome启动并访问我们去测试的网站,那么在中间加一层来配置header并加上Cookie就可以了。

这里面的http-proxy就是这么做的,当Protractor启动之后,所有发出的信息都经过Proxy添加了相应的header,这样就实现了绕过验证页面登录网站。

结果……太复杂,我的大脑已经宕机……

所以换方案

失败想法五:

这时候,我想反正Windows Authrization窗口就跳出来了,那我就模拟键盘敲击:

1. 输入账号

2. 按下Tab键

3. 输入密码

4. 按下Tab键

5. 这时候login按钮得到焦点,按下Enter键就可以了

于是我试了robotjs与robot-js,结果是悲剧的,唉,这时候的感觉就是绝望,真的绝望。

成功方案的摸索过程

这周就剩一天了,在吃了根香蕉(程序猿需要吃香蕉减轻压力啊)

在同事的关怀与鼓励下,我还没有被击倒的情况下发现了另一种解决方案。

那就是借助Chrome的插件来完成这个挑战,这个方案也是一波多折,但是总算解决问题了。

配置的过程:

因为我们访问网站,如果想跳过验证界面的话,直接添加一个带有合法Cookie的header就好了。

1. 于是我下载了一个Chrome扩展差件 Modify Header Value (HTTP Headers)

2. 在添加完成之后,打开插件,url那列添加网址,header那列写cookie,value那列填入cookie的值,点最右边的加号按钮保存

3. 之后插件一定要启动起来,访问我们想要测试的网站,发现不用输入密码就可以进入网站了

发现问题:

用angular-cli运行命令ng e2e的时候,chrome正常启动,但是发现并没有载入插件,所以测试不成功。

调查问题:

这个问题的原因是protractor只是启动了selenium里面的chrome.exe,所以他是很干净的环境,只是加载了一个automation的插件。我们之前在chrome配置的插件根本就没有加载进来

解决问题:

依然通过stackoverflow搜索到加载插件的方法

修改protractor.conf.js里面的代码,在exports.config里面添加这些代码。

exports.config = {

  allScriptsTimeout: 11000,

  specs: [

    ‘./e2e/**/*.e2e-spec.ts‘

  ],

  capabilities: {

    ‘browserName‘: ‘chrome‘,

    ‘chromeOptions‘: {

      ‘args‘: [‘--load-extension=C:/Users/<User Name>/AppData/Local/Google/Chrome/User Data/Profile 1/Extensions/cbdibdfhahmknbkkojljfncpnhmacdek/0.1.4_0‘,

            ‘--user-data-dir=C:/Users/<User Name>/AppData/Local/Google/Chrome/User Data‘]

    }

  },

  directConnect: true,

  ...

}

--load-extension是指定了extention的路径,后面的cbdibdfhahmknbkkojljfncpnhmacdek是加密的扩展插件名称

--user-data-dir是指定了我们使用的chrome记录的历史记录,如果不指定这个文件的话,你会发现,当protractor启动浏览器后,即使加载了插件,那么插件里面的之前保存的数据也读取不到


这时运行e2e测试时,会发现插件已经加载,并且里面能看到我们之前设置的cookie。

而且验证也已经自动通过了。

更改好的解决方案:

刚刚有了一个想法,进行验证,这个方法是更好的

实际上我们已经打开Chrome, 登录网站,已经选择了保存账号与密码,这个时候我们知道确保protractor启动的Chrome能读取到用户文件就好了。

所以我删除了第三方插件,并且将exports.config修改如下

capabilities: {
    ‘browserName‘: ‘chrome‘,
    ‘chromeOptions‘: {
      ‘args‘: [‘--user-data-dir=C:/Users/YLi135/AppData/Local/Google/Chrome/User Data‘]
    }
  },

这样修改完成后,protractor启动的chrome会读取我们之前的登录信息,跳转到我们想测试的界面。

解决方案只是折中的方案,因为第一次测试的时候,我们需要打开chrome并且输入账号密码并进行保存。

希望有解决这个问题的大神能分享一下经验,谢谢!

希望对大家有帮助

Happy Testing!

原文地址:https://www.cnblogs.com/limark/p/9089746.html

时间: 2024-10-24 09:46:10

Angular2+ 使用 Protractor 与 Modify Header Value (HTTP Headers) 插件 完成 Windows Authorization 验证的相关文章

PHP错误Warning: Cannot modify header information - headers already sent by解决方法

这篇文章主要介绍了PHP错误Warning: Cannot modify header information - headers already sent by解决方法,需要的朋友可以参考下 今天在测试以下代码时遇到该错误: 复制代码代码如下: session_start();$_SESSION['username']=$username;echo "<script language='javascript'>location.href='../admin.php';</sc

出现Warning: Cannot modify header information - headers already sent by ..的解决办法

这个错误的出现,原因是: 出这个错误是因为 header('Content-Type:text/html;charset= UTF-8');发送头之前不能有任何输出. 检查了下我的输出,错误信息如下: Warning: Cannot modify header information - headers already sent by (output started at /data/home/qxu1084910324/htdocs/bw_feature.php:1) in /data/hom

Cannot modify header information问题的解决方法(php)

我做了一个统一的出错提示函数,在函数执行里面,先处理出错的地址写入cookie以方便用户登陆以后可以直接跳转到要执行的这个页面,可是发现在服务器上测试时,竟然提示本地没有出现的错误: Warning: Cannot modify header information - headers already sent by....这样的语句,很显然,造成这个原因是因为setcookie造成的,查了一下网上,有如下的解释: cookie本身在使用上有一些限制,例如:1.呼叫setcookie的敘述必須放

如何解决PHP 出现Warning: Cannot modify header information错误?

其实,出现这种情况一般都是因为程序修改过程中出现以下几个方面的错误操作导致: 原因一.UTF8编码和BOM冲突(最常见) 如果你登录后台出现类似Warning: Cannot modify header information – headers already sent by (output started at /www/wp-content/themes/pozhejun/function.php:1) in /www/wp-includes/pluggable.php on line 8

关于报错:Warning: Cannot modify header information - headers already sent by (output started at

8月5日,第一个项目即将完成,测试时,发现登录功能会出现小问题:记住密码的时候会报错 Warning: Cannot modify header information - headers already sent by (output started at 经过再三在百度上查询,终于查到错误的关键原因:[setcookie之前不可以有html标签内容].导致出现这种错误的方式有很多种,但惟独这种解释最让我理解. (因为百度知道的内容不可以复制了,只能贴出地址,有详细解释)地址[http://z

PHP程序错误Warning: Cannot modify header information - headers already sent by ....

在使用phpmywind程序时出现的问题Warning: Cannot modify header information - headers already sent by .... 检查了许久,居然是编码的问题 请将单纯的utf-8格式改为utf-8无BOM编码格式 在NOTEPAD++的格式菜单可以修改 或者其它工具的

cannot modify header information 关于实现widget页面跳转的问题

查找网上解决此问题的方法多是一样的,不过今天又遇到了这样的问题.试过之后发现可行: 在C盘的WINDOWS或者你的PHP文件夹中找到php.ini 这个配置文件,然后查找一项:output_buffering将其值由原来的off改为on,重新启动Apache就ok了. 详细出处参考:http://www.jb51.net/article/14108.htm http://blog.chinaunix.net/uid-122937-id-142881.html 函数header--页面跳转 can

php Cannot modify header information 和 Cannot send session cache limiter

在php开发中遇到两个问题 (1)Cannot send session cache limiter 解决方式  找到 php.ini        修改php.ini中的 session.auto_start = 0 为 session.auto_start = 1 (2)Cannot modify header information 解决方式  找到 php.ini    修改php.ini中的 output_buffering = on php Cannot modify header

Warning: Cannot modify header information原因及解决方案

相信大多数人在写PHP代码的时候,都遇到过类似"Warning: Cannot send session cookie – headers already sent-"或者"Cannot add/modify header information – headers already sent-"这样的Warning提示.下面我们就来看看发生这个Warning的原因及解决方案. 函数 header(),setcookie() 和 session 函数需要在输出流中增加