Protrator 官網和下載工具稍慢 , 但能使用. Angular CLI 內置 官方推薦 TS的 demo 不明顯 , 並且依賴沒法安裝














npm uninstall -g protractor  && c npm install -g protractor && protractor --version

複製 驅動等到指定位置

 &&  webdriver-manager update  &&  webdriver-manager start

protractor --version
Version 5.2.0

卸載的時候區分大小寫
npm uninstall -g protractor

webdriver-manager 工具和以前下載好的包都沒了
C:\Users\pc\AppData\Roaming\npm\node_modules\protractor\node_modules\_webdriver-manager@12.0.6@webdriver-manager\selenium


cnpm install -g protractor
完美不報錯 , 也沒有警告
C:\Users\pc>cnpm install -g protractor
Downloading protractor to C:\Users\pc\AppData\Roaming\npm\node_modules\protractor_tmp
Copying C:\Users\pc\AppData\Roaming\npm\node_modules\protractor_tmp\_protractor@5.2.0@protractor to C:\Users\pc\AppData\Roaming\npm\node_modules\protractor
Installing protractor's dependencies to C:\Users\pc\AppData\Roaming\npm\node_modules\protractor/node_modules
[1/15] q@1.4.1 installed at node_modules\_q@1.4.1@q
[2/15] jasminewd2@^2.1.0 installed at node_modules\_jasminewd2@2.2.0@jasminewd2
[3/15] @types/q@^0.0.32 installed at node_modules\_@types_q@0.0.32@@types\q
[4/15] optimist@~0.6.0 installed at node_modules\_optimist@0.6.1@optimist
[5/15] @types/node@^6.0.46 installed at node_modules\_@types_node@6.0.92@@types\node
[6/15] chalk@^1.1.3 installed at node_modules\_chalk@1.1.3@chalk
[7/15] blocking-proxy@0.0.5 installed at node_modules\_blocking-proxy@0.0.5@blocking-proxy
[8/15] @types/selenium-webdriver@~2.53.39 installed at node_modules\_@types_selenium-webdriver@2.53.43@@types\selenium-webdriver
[9/15] jasmine@^2.5.3 installed at node_modules\_jasmine@2.8.0@jasmine
[10/15] glob@^7.0.3 installed at node_modules\_glob@7.1.2@glob
[11/15] saucelabs@~1.3.0 installed at node_modules\_saucelabs@1.3.0@saucelabs
[12/15] source-map-support@~0.4.0 installed at node_modules\_source-map-support@0.4.18@source-map-support
[13/15] webdriver-manager@^12.0.6 installed at node_modules\_webdriver-manager@12.0.6@webdriver-manager
[14/15] selenium-webdriver@3.6.0 installed at node_modules\_selenium-webdriver@3.6.0@selenium-webdriver
[15/15] webdriver-js-extender@^1.0.0 installed at node_modules\_webdriver-js-extender@1.0.0@webdriver-js-extender
Recently updated (since 2017-11-27): 3 packages (detail see file C:\Users\pc\AppData\Roaming\npm\node_modules\protractor\node_modules\.recently_updates.txt)
  2017-12-02
    → webdriver-manager@12.0.6 › request@2.83.0 › har-validator@5.0.3 › ajv@^5.1.0(5.5.1) (20:48:13)
  2017-12-01
    → webdriver-manager@12.0.6 › request@2.83.0 › http-signature@1.2.0 › jsprim@1.4.1 › verror@1.10.0 › extsprintf@^1.2.0(1.4.0) (05:26:44)
  2017-11-30
    → webdriver-manager@12.0.6 › del@2.2.2 › is-path-in-cwd@1.0.0 › is-path-inside@^1.0.0(1.0.1) (18:34:52)
All packages installed (137 packages installed from npm registry, used 27s, speed 210.86kB/s, json 127(254.64kB), tarball 5.29MB)
[protractor@5.2.0] link C:\Users\pc\AppData\Roaming\npm\protractor@ -> C:\Users\pc\AppData\Roaming\npm\node_modules\protractor\bin\protractor
[protractor@5.2.0] link C:\Users\pc\AppData\Roaming\npm\webdriver-manager@ -> C:\Users\pc\AppData\Roaming\npm\node_modules\protractor\bin\webdriver-manager


npm uninstall -g webdriver-manager
沒得卸載 , 由於它不是單獨的工具
C:\Users\pc>npm uninstall -g webdriver-manager
up to date in 0.035s

從新安裝
C:\Users\pc>webdriver-manager update
[09:44:21] I/update - geckodriver: file exists C:\Users\pc\AppData\Roaming\npm\node_modules\protractor\node_modules\_webdriver-manager@12.0.6@webdriver-manager\selenium\geckodriver-v0.19.1.zip
[09:44:21] I/update - geckodriver: unzipping geckodriver-v0.19.1.zip
[09:44:21] I/update - geckodriver: geckodriver-v0.19.1.exe up to date
events.js:183
      throw er; // Unhandled 'error' event
      ^

Error: read ECONNRESET
    at _errnoException (util.js:1024:11)
    at TLSWrap.onread (net.js:615:25)

相似的報錯



藍燈

設置代理
全局

下載都成功了
我看文件裏面 , 解壓好了
可是一個卡在這裏


要終止再來一次嗎
仍是一直掛機 ?

應該是以前 Protractor 安裝出錯了

由於文件都下載回來了


無效 npm uninstall

set http_proxy=http:localhost: 56138

127.0.0.1

端口
56138

分析一下 , JavaScript  裏 , 是否是解壓的工具壞了  , 是否是要從新安裝 ?

webdriver-manager start
webdriver-manager update

果真天天早點都要更新一次 , start 腳本里面好像有在檢查最新版
webdriver-manager update && webdriver-manager start

D:\>webdriver-manager update --standalone
[09:17:01] I/update - geckodriver: file exists C:\Users\pc\AppData\Roaming\npm\node_modules\protractor\node_modules\webdriver-manager\selenium\geckodriver-v0.19.1.zip
[09:17:01] I/update - geckodriver: unzipping geckodriver-v0.19.1.zip
[09:17:01] I/update - geckodriver: geckodriver-v0.19.1.exe up to date
events.js:183
      throw er; // Unhandled 'error' event
      ^

Error: connect ETIMEDOUT 172.217.24.16:443
    at Object._errnoException (util.js:1024:11)
    at _exceptionWithHostPort (util.js:1046:20)
    at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1182:14)



protractor --version
Version 5.2.0



C:\Users\pc\AppData\Roaming\npm\node_modules\protractor\node_modules\webdriver-manager\selenium
把文件移動當更下一層 , 而後讓它從新下載 , 不是解壓已有的

webdriver-manager update --standalone

又抽筋了 , 沒法啓動


是操做系統作了什麼嗎
在這以前系統升級了一下


個人博客
http://www.cnblogs.com/xiaoCong2016/p/7440741.html

只要 webdriver-manager update 成功後
webdriver-manager start  不會無效的狀況 :{
update 成功後立刻 start 
把所有cmd都關閉再開一個cmd
在 git + cmd
最後重啓電腦後試一下 start 會不會跪了
}

我建立的Protractor 自動化羣
2017-12-01 就只有我一我的
594926460
以前網絡很差 , 連驅動都須要下載不少次才成功
有時候掛機一個晚上驅動也不行 , 最終會報錯 , 說網絡超時

如今能夠了
果真是網絡的問題, 有時候會抽筋


# 安裝驅動
C:\Users\pc>webdriver-manager update
[09:31:56] I/update - chromedriver: file exists C:\Users\pc\AppData\Roaming\npm\node_modules\protractor\node_modules\webdriver-manager\selenium\chromedriver_2.33.zip
[09:31:56] I/update - chromedriver: unzipping chromedriver_2.33.zip
[09:31:56] I/update - chromedriver: chromedriver_2.33.exe up to date
[09:32:22] E/downloader - Connection timeout downloading: https://github.com/mozilla/geckodriver/releases/download/v0.19.1/geckodriver-v0.19.1-win64.zip. Default timeout is 4 minutes.
[09:32:22] I/update - geckodriver: file exists C:\Users\pc\AppData\Roaming\npm\node_modules\protractor\node_modules\webdriver-manager\selenium\geckodriver-v0.19.1.zip
[09:32:22] I/update - geckodriver: unzipping geckodriver-v0.19.1.zip
(node:27460) UnhandledPromiseRejectionWarning: Unhandled promise rejection (rejection id: 1): Invalid or unsupported zip format. No END header found
(node:27460) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.

# 運行
C:\Users\pc>webdriver-manager start
[09:35:52] I/start - java -Dwebdriver.chrome.driver=C:\Users\pc\AppData\Roaming\npm\node_modules\protractor\node_modules\webdriver-manager\selenium\chromedriver_2.33.exe -jar C:\Users\pc\AppData\Roaming\npm\node_modules\protractor\node_modules\webdriver-manager\selenium\selenium-server-standalone-3.8.0.jar -port 4444
[09:35:52] I/start - seleniumProcess.pid: 17572
09:35:52.582 INFO - Selenium build info: version: '3.8.0', revision: '924c4067df'
09:35:52.583 INFO - Launching a standalone Selenium Server
2017-12-01 09:35:52.670:INFO::main: Logging initialized @390ms to org.seleniumhq.jetty9.util.log.StdErrLog
09:35:52.696 INFO - Using `new FirefoxOptions()` is preferred to `DesiredCapabilities.firefox()`
09:35:52.705 INFO - Using `new ChromeOptions()` is preferred to `DesiredCapabilities.chrome()`
09:35:52.707 INFO - Using `new EdgeOptions()` is preferred to `DesiredCapabilities.edge()`
09:35:52.707 INFO - Driver class not found: com.opera.core.systems.OperaDriver
09:35:52.707 INFO - Using `new OperaOptions()` is preferred to `DesiredCapabilities.operaBlink()`
09:35:52.710 INFO - Using `new SafariOptions()` is preferred to `DesiredCapabilities.safari()`
09:35:52.712 INFO - Driver class not found: org.openqa.selenium.phantomjs.PhantomJSDriver
09:35:52.741 INFO - Driver provider class org.openqa.selenium.safari.SafariDriver registration is skipped:
 registration capabilities Capabilities {browserName: safari, platform: MAC, version: } does not match the current platform WIN10
09:35:52.772 INFO - Using `new ChromeOptions()` is preferred to `DesiredCapabilities.chrome()`
09:35:52.773 INFO - Using `new EdgeOptions()` is preferred to `DesiredCapabilities.edge()`
09:35:52.777 INFO - Using `new FirefoxOptions()` is preferred to `DesiredCapabilities.firefox()`
09:35:52.781 INFO - Using `new OperaOptions()` is preferred to `DesiredCapabilities.operaBlink()`
09:35:52.783 INFO - Using `new SafariOptions()` is preferred to `DesiredCapabilities.safari()`
09:35:52.791 INFO - Using the passthrough mode handler
2017-12-01 09:35:52.809:INFO:osjs.Server:main: jetty-9.4.7.v20170914
2017-12-01 09:35:52.825:WARN:osjs.SecurityHandler:main: ServletContext@o.s.j.s.ServletContextHandler@2db7a79b{/,null,STARTING} has uncovered http methods for path: /
2017-12-01 09:35:52.829:INFO:osjsh.ContextHandler:main: Started o.s.j.s.ServletContextHandler@2db7a79b{/,null,AVAILABLE}2017-12-01 09:35:52.862:INFO:osjs.AbstractConnector:main: Started ServerConnector@652d2fa2{HTTP/1.1,[http/1.1]}{0.0.0.0:4444}
2017-12-01 09:35:52.868:INFO:osjs.Server:main: Started @588ms
09:35:52.871 INFO - Selenium Server is up and running







todo


Protractor 提供的測試頁面 , 計算器
http://juliemr.github.io/protractor-demo/
 
控制檯正常 , 只是 有個圖標沒有加載到 , 不要緊
 

面向頁面的試試

http://blog.csdn.net/github_39212680/article/details/73433870
寫得很詳細

http://www.protractortest.org/#/


文檔
http://www.protractortest.org/#/typescript

例子
https://github.com/angular/protractor/tree/5.2.0/exampleTypescript



簡介


官網
http://www.protractortest.org/

github
https://github.com/angular/protractor

官網稍慢 , 但能打得開  Angular CLI 內置  官方推薦

可用於 AngularJS 和 Angular 的 端到端 web 自動化測試
能夠根據 模型 和 bind 來找元素很方便


E2E test framework for Angular apps
Protractor is an end-to-end test framework for Angular and AngularJS applications.
Protractor is a Node.js program built on top of WebDriverJS.



 

安裝


在國內極可能安裝失敗 , 因此我建議用阿里提供的 cnpm 工具
npm install -g cnpm
後面的操做 , 用到 npm install 的命令都建議用 cnpm install 替代 , 就是最前面加個 c 字母

npm install -g protractor
會自動安裝兩個工具:protractor 和 webdriver-manager

看是否安裝成功, 成功的話 :  {
先確認 protractor , 命令行裏執行 :
protractor
**you must either specify a configuration file or at least 3 options. See below for the options:

Usage: protractor [configFile] [options]
configFile defaults to protractor.conf.js
The [options] object will override values from the config file.
See the reference config for a full list of options.

Options:
  --help                                 Print Protractor help menu
( 如下省略  )

其次確認 webdriver-manager  , 命令行裏執行 :
webdriver-manager
Usage: webdriver-manager <command> [options]

Commands:
  clean      removes all downloaded driver files from the out_dir
  start      start up the selenium server
  shutdown   shut down the selenium server
  status     list the current available drivers
  update     install or update selected binaries
  version    get the current version
( 如下省略 )
}

更新瀏覽器驅動
webdriver-manager update 


確保本地安裝好的谷歌瀏覽器的版本 是 59 以上


個人當前版本 (  58.0  ) 太舊 , 要更新 . 否則在運行腳本的時候會 提示 Chrome version must be >= 59.0.3071.0 ,
也就是建議升級谷歌瀏覽器到 59.0 以上

以前的  :


查看谷歌瀏覽器的版本 , 在URL地址欄輸入
chrome://settings/help

在瀏覽器裏自動更新就行 , 不行的話再百度安裝包
更新好後 : 

版本 : 60.0.3112.113(正式版本) (64 位)



執行測試代碼以前要開啓服務
webdriver-manager start


學習資料




api 文檔
http://www.protractortest.org/#/api

推酷上搜不到

主要是官網
http://www.protractortest.org/

快速入門
http://www.protractortest.org/#/tutorial

總的教程目錄
http://www.protractortest.org/#/toc
並且能夠用 TypeScript 寫

還有調試 自動化測試代碼 的技巧

對應的代碼
https:// github.com/angular/protractor/tree/5.1.2/exampleTypescript



第三方文章

端對端的 自動化測試

自動化端對端測試-Protrator Tutorial
https://my.oschina.net/u/658505/blog/665158

http://juliemr.github.io/protractor-demo/


實踐 /嘗試  本身試一下


國人翻譯的
http://www.cnblogs.com/haogj/p/4815673.html

被測試的網站 http://juliemr.github.io/protractor-demo/  , 官方搭建的

安裝成功 : 步驟
安裝 Protractor 軟件
更新 webdriver-manager



在任意位置開服務 ,  不是 serve 或者 server
webdriver-manager start

到當前目錄
cd /d G:\autoTest\Protractor\First

protractor + 配置文件.js
protractor config.js
config.js 裏面配置裏要執行 example_spec.js 測試用例文件 , 能夠配置多個

腳本啓動正常 :
G:\autoTest\Protractor\First>protractor config.js
[10:47:41] I/launcher - Running 1 instances of WebDriver
[10:47:41] I/hosted - Using the selenium server at http://localhost:4444/wd/hub
Started

出現Chrome瀏覽器

腳本自動運行

過段時間自動退出 , 控制檯顯示報錯 , 這個沒事

清理 cmd
cls




知識點


beforeEach
每一個方法 ( 測試用例 ) 執行前都會執行這個方法 , 很經常使用的場景 :
beforeEach( function() {
        browser. get('http://juliemr.github.io/protractor-demo/');
    }
);
每次都打開網址

it 是什麼

爲何有兩個 嵌套的 描述 ?

問題



webdriver-manager update 沒法安裝


PS C:\Windows\system32> webdriver-manager update
events.js:183
      throw er; // Unhandled 'error' event
      ^

Error: read ECONNRESET
    at _errnoException (util.js:1024:11)
    at TLSWrap.onread (net.js:615:25)



C:\Users\pc\AppData\Roaming\npm\node_modules\protractor\node_modules\webdriver-manager\selenium
文件夾建立成功



pc>webdriver-manager update
[20:55:45] I/file_manager - creating folder C:\Users\pc\AppData\Roaming\npm\node_modules\protractor\node_modules\webdriver-manager\selenium
events.js:183
      throw er; // Unhandled 'error' event
      ^

Error: connect ETIMEDOUT 172.217.27.144:443
    at Object._errnoException (util.js:1024:11)
    at _exceptionWithHostPort (util.js:1046:20)
    at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1182:14)




現象 :
{
不安裝的話啓動服務的時候會提示


根據提示執行命令
webdriver-manager update --standalone
以前是報錯


而後是

}

npm un install -g protractor
重裝

npm install -g protractor

由於須要建立文件夾
須要我用管理員權限打開cmd嗎

111



開了藍燈 , 一直重試

能單獨下載到






webdriver-manager start 沒法啓動服務 , 以前能夠


以前能夠的
E:\autoTest\Protractor\Protractor-source>webdriver-manager start
[15:56:31] I/start - java -Dwebdriver.chrome.driver=C:\Users\zhangqiang\AppData\Roaming\npm\node_modules\protractor\node_modules\webdriver-manager\selenium\chromedriver_2.32.exe -jar C:\Users\zhangqiang\AppData\Roaming\np
m\node_modules\protractor\node_modules\webdriver-manager\selenium\selenium-server-standalone-3.5.3.jar -port 4444
[15:56:31] I/start - seleniumProcess.pid: 17148
Error: Unable to access jarfile C:\Users\zhangqiang\AppData\Roaming\npm\node_modules\protractor\node_modules\webdriver-manager\selenium\selenium-server-standalone-3.5.3.jar
[15:56:32] I/start - Selenium Standalone has exited with code 1

解決方法
重裝一下 , webdriver-manager update
由於環境壞了 , 或者不是最新版


服務正常了 : ( 最下面一行沒有結束 , 光標會一直閃爍 ) 提示 Selenium Server is up and running
C:\Users\zhangqiang>webdriver-manager start
[10:26:31] I/start - java -Dwebdriver.chrome.driver=C:\Users\zhangqiang\AppData\Roaming\npm\node_modules\protractor\node_modules\_webdriver-manager@12.0.6@webdriver-manager\selenium\chromedriver_2.33.exe -Dwebdriver.gecko.driver=C:\Users\zhangqiang\AppData\Roaming\npm\node_modules\protractor\node_modules\_webdriver-manager@12.0.6@webdriver-manager\selenium\geckodriver-v0.19.0.exe -jar C:\Users\zhangqiang\AppData\Roaming\npm\node_modules\protractor\node_modules\_webdriver-manager@12.0.6@webdriver-manager\selenium\selenium-server-standalone-3.6.0.jar -port 4444
[10:26:31] I/start - seleniumProcess.pid: 82572
10:26:34.618 INFO - Selenium build info: version: '3.6.0', revision: '6fbf3ec767'
10:26:34.632 INFO - Launching a standalone Selenium Server
2017-10-23 10:26:34.765:INFO::main: Logging initialized @2565ms to org.seleniumhq.jetty9.util.log.StdErrLog
10:26:35.042 INFO - Driver class not found: com.opera.core.systems.OperaDriver
10:26:35.396 INFO - Driver provider class org.openqa.selenium.safari.SafariDriver registration is skipped:
 registration capabilities Capabilities [{browserName=safari, version=, platform=MAC}] does not match the current platform WIN8_1
10:26:35.665 INFO - Using the passthrough mode handler
2017-10-23 10:26:35.815:INFO:osjs.Server:main: jetty-9.4.5.v20170502
2017-10-23 10:26:35.993:WARN:osjs.SecurityHandler:main: ServletContext@o.s.j.s.ServletContextHandler@5a8e6209{/,null,STARTING} has uncovered http methods for path: /
2017-10-23 10:26:36.048:INFO:osjsh.ContextHandler:main: Started o.s.j.s.ServletContextHandler@5a8e6209{/,null,AVAILABLE}
2017-10-23 10:26:36.348:INFO:osjs.AbstractConnector:main: Started ServerConnector@614ddd49{HTTP/1.1,[http/1.1]}{0.0.0.0:4444}
2017-10-23 10:26:36.354:INFO:osjs.Server:main: Started @4154ms
10:26:36.361 INFO - Selenium Server is up and running

腳本也啓動正常





ReferenceError: browser is not defined

要先啓動服務    webdriver-manager start
而後就正常了

備註



自動化測試代碼執行期間 , 能夠作別的事情 , 由於是腳本在操做瀏覽器

不須要在這以前手動啓動瀏覽器 , 但Selenium 代理服務要先啓動


Chrome version must be >= 59.0.3071.0

在WebStorm  run 服務 , 但不行

重裝一次



文件下載到
C:\Users\zhangqiang\AppData\Roaming\npm\node_modules\protractor\node_modules\_webdriver-manager@12.0.6@webdriver-manager\selenium

 7個文件

下載好後

解壓太慢 , 我手動解壓了
 


再執行一次更新
仍舊是7個文件 , 沒有解壓的


仍是不行 , 須要update


這個一直都下載失敗   geckodriver-v0.18.0-win64.zip



I/update - geckodriver: unzipping geckodriver-v0.18.0.zip
(node:2200) UnhandledPromiseRejectionWarning: Unhandled promise rejection (rejection id: 1): Invalid filename

報錯說文件名有問題 , 因此沒法解壓 . 但實際上是由於 0大小 , 沒下載成功 .

本身手動下載 , 而後放到對應的目錄裏


單擊 0 大小的壓縮包
 

成功的 , 用自動下載的
 


http://localhost:4444/wd/hub/static/resource/hub.html


 


update 包下載不下來
服務忘了了
本地的谷歌瀏覽器過久


Protractor 官方在GitHub的 TypeScript 依賴包安裝失敗


重裝試試

其餘的正常

run 起來試試


後面有時間再按照你的需求改UI














相關文章
相關標籤/搜索