TestCafe에 대해 다양한
「Selenium」이외에도 사용할 수 있는 GUI 테스트 툴이 없는지, 또 Wait등의 대기 처리를 잘 할 수 없기 때문에 도중에 에러 종료해 버린다.
그리고, 조사한 곳 「Testcafe」가 발견되었다.
그렇지만, 잘 모르고, 툴명인가, 어딘가의 커피 점포명인가 생각해 버리는 시말.
Selenium에서는 「설정」이 많았던 만큼, 편해진 것 같습니다. 환경 구축에 시간이 걸렸다.
그러나 언어는 "Javascript"의 선택입니다.
#Windows판
TestCafe Studio를 사용하여 시작
무려 무료 기간이 30일로 유료란? 어느새 변했어요.
data:image/s3,"s3://crabby-images/72a5b/72a5b8247ffd4157d1193d24814304cacde4f405" alt=""
data:image/s3,"s3://crabby-images/88dad/88dade04f5e7618f1fe0474ba11f1d0229ee3239" alt=""
DevExpressTestCafeStudio-win-0.2.0을 실행합니다.
"설치 중"
data:image/s3,"s3://crabby-images/a1759/a175930cd93c42631b0cf8a8c647ee919c619bdf" alt=""
마침 버튼을 클릭합니다.
data:image/s3,"s3://crabby-images/105ef/105ef42f80639299e68b7dbda2d69f16e5e73893" alt=""
스플래시 화면
환경에 따라서는 이 화면 그대로 진행하지 않는다.
설정 미스 : 환경 변수 (Path) 설정의 재검토도 필요하다.
PATH=$PATH:./node_modules/.bin
경로를 제대로 설정한 후 다시 시작한다.data:image/s3,"s3://crabby-images/55a66/55a665fb217f6a73c2f1dac553128c052caa62bb" alt=""
TestCafe Studio 화면
레코드 구성 이름
Run Configuration 이름
MozillaFirefox
MozillaFirefox
Google 크롬
Google 크롬
Internet Explorer
Internet Explorer
Microsoft Edge
Microsoft Edge
여기에서는, 「Internet Explorer」를 설정해 움직여 보자.
data:image/s3,"s3://crabby-images/c5c84/c5c84afbf02eee5a6cd58d225dd71d4ec3bd25b8" alt=""
SeleniumIDE에 있던 「Recording 기능」도 붙어 있다.
data:image/s3,"s3://crabby-images/23101/2310135ef9e0fc7d22202b97dfe525d1b68cf333" alt=""
화살표 버튼을 클릭합니다.
data:image/s3,"s3://crabby-images/f5f61/f5f615fdf33ce1b497f471b5f898bc017c0ed1e1" alt=""
로드가 시작됩니다.
data:image/s3,"s3://crabby-images/732a6/732a6f5029faa81cb45fa70eb4e92650cc07357d" alt=""
"스플래시 화면"과 같은 "시작 브라우저 이름"과 "OS"가 표시됩니다.
data:image/s3,"s3://crabby-images/e2e39/e2e39a99c8e16632726c398b46a89c6ab103c74b" alt=""
「Recording 기능」하면서 움직여 본다.
"Yahoo! Top"시작
data:image/s3,"s3://crabby-images/e4210/e421015c8446afd2d3172ef89055e08d9278e3fe" alt=""
data:image/s3,"s3://crabby-images/6fc1a/6fc1a088a8d427216327d4f6fcfbaff69de08028" alt=""
꽤 좋은 느낌으로 Wait 해줍니다.
OK인 경우
테스트 결과가 "PASSED"입니다.
data:image/s3,"s3://crabby-images/1318e/1318eb219a5461086784a6b430ffd2b21851088a" alt=""
NG의 경우
테스트 결과가 「FAIL」이 되고 있다.
#AWS Linux 가상 머신
AWS Linux에 TestCafe 설치
cmd
data:image/s3,"s3://crabby-images/0c549/0c54925295d28d28609b1204979eaffb2f965844" alt=""
vagrant up
data:image/s3,"s3://crabby-images/7aac6/7aac6576e1863356adf9e67fb9d12bd8d105035d" alt=""
vagrant ssh
data:image/s3,"s3://crabby-images/1b838/1b8386e6d87d52739305e16946a9cf4fb398072f" alt=""
nodebrew 설치
[vagrant@localhost ~]$curl -L git.io/nodebrew | perl - setup
[vagrant@localhost ~]$set -o noclobber
[vagrant@localhost ~]$echo export PATH='$HOME/.nodebrew/current/bin:$PATH' >> ~/.bashrc
[vagrant@localhost ~]$source ~/.bashrc
nodebrew 버전 확인[vagrant@localhost ~]$ nodebrew -v
nodebrew 1.0.0
nodebrewを使ってNode.jsをインストール
[vagrant@localhost ~]$ nodebrew install-binary latest
[vagrant@localhost ~]$ nodebrew use latest
[vagrant@localhost ~]$ node -v
v10.1.0
[vagrant@localhost ~]$ npm -v
6.1.0
[vagrant@localhost ~]$ npm install -g testcafe
실행 test1.js 준비test1.js
import { Selector } from 'testcafe';
fixture `test`
.page `https://XXXXXXXXXXXXXX/login`;
test('New Test', async t => {
await t
.click(Selector('.notice-wrapper'))
.typeText(Selector('#login').find('[name="login_address"]'), 'd')
.pressKey('backspace')
.typeText(Selector('#login').find('[name="login_address"]'), 'XXXXXXX .pressKey('tab')
.typeText(Selector('#password'), 'XXXXXX')
.click(Selector('.btn-blue-lg'))
.click(Selector('.login'))
.selectText(Selector('#login').find('[name="login_address"]'), 22, 0)
.pressKey('delete');
});
헤드리스 Chrome을 실행합니다.[vagrant@localhost ~]$ testcafe "chrome:headless" test1.js
실행하면 빨간색 프레임과 같은 표시가 된다.data:image/s3,"s3://crabby-images/2a6d1/2a6d11e9a8f286b1439dd65088c0e62ec82cbc07" alt=""
실행 결과이지만 잘 모르겠습니다.
그렇지만 「OK」인 것은 「passed」로부터 알 수 있다
実行結果
Running tests in:
- HeadlessChrome 67.0.3396 / Linux 0.0.0
First fixture
✓ First test
1 passed (10s)
Reference
이 문제에 관하여(TestCafe에 대해 다양한), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/jun2014/items/e95dbfa01eddabf3c8d7텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)