最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - testcafe - how to assert text contains in html body - Stack Overflow

programmeradmin2浏览0评论

I am using testcafe for api testing however our api requires login. Below is my code. I can see json response fine. But i am not sure how to assert on the page.

import { Selector } from 'testcafe';

import Page from './page';
// Page model
const page = new Page();
const url = '';

const elementWithIdOrClassName = Selector(value => {
  return document.getElementById(value) || document.getElementsByTagName(value);
});

fixture `Test`
    .page(url + '/talent/career')
    .beforeEach( async t => {
      await t
      .typeText(page.username, 'gvp50')
      .typeText(page.password, 'password')
      .click(page.login_button)
    });



// Tests
test('Text typing basics', async t => {
    await t
      .navigateTo(url+'/api/learner/learning_items')
      .expect(Selector('html')).contains('learning_items');
});

I am using testcafe for api testing however our api requires login. Below is my code. I can see json response fine. But i am not sure how to assert on the page.

import { Selector } from 'testcafe';

import Page from './page';
// Page model
const page = new Page();
const url = 'https://myexample.';

const elementWithIdOrClassName = Selector(value => {
  return document.getElementById(value) || document.getElementsByTagName(value);
});

fixture `Test`
    .page(url + '/talent/career')
    .beforeEach( async t => {
      await t
      .typeText(page.username, 'gvp50')
      .typeText(page.password, 'password')
      .click(page.login_button)
    });



// Tests
test('Text typing basics', async t => {
    await t
      .navigateTo(url+'/api/learner/learning_items')
      .expect(Selector('html')).contains('learning_items');
});

Testcafe just hangs after i run this code. I tried Selector('body') as well but it doesn't work.

Share Improve this question edited Nov 6, 2018 at 6:59 Alex Skorkin 4,2743 gold badges27 silver badges48 bronze badges asked Oct 10, 2018 at 0:37 GauravGaurav 1512 silver badges14 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 5

You need to specify what element property (state) you'd like to obtain (verify).

After you selected the entire 'html' element (Selector('html')), specify what property (state) you'd like to access (attributes, childNodes, style, size, etc.). See the DOM Node State topic to learn more.

It looks like you wanted to access the text content as follows:

.expect(Selector('html').textContent).contains('learning_items');

However, such selector usage is unlikely to be the cause of the hang as TestCafe will properly display a message about invalid selector usage. You might want to simplify your test and/or debug it to find what causes the hang.

const cellparedata =await Selector('[role="gridcell"]').textContent;
console.log("cellparedata is",cellparedata);

either you can use this.

发布评论

评论列表(0)

  1. 暂无评论