mirror of
https://github.com/microsoft/playwright.git
synced 2025-01-07 11:46:42 +03:00
fix(inspector): render expect.not correctly (#19125)
Also fixes the same in expect logs. References #19083.
This commit is contained in:
parent
dd18792087
commit
4f72a895e9
@ -36,7 +36,7 @@ export async function toBeTruthy(
|
|||||||
|
|
||||||
const timeout = currentExpectTimeout(options);
|
const timeout = currentExpectTimeout(options);
|
||||||
|
|
||||||
const { matches, log, timedOut } = await query(this.isNot, timeout, captureStackTrace('expect.' + matcherName));
|
const { matches, log, timedOut } = await query(this.isNot, timeout, captureStackTrace(`expect.${this.isNot ? 'not.' : ''}${matcherName}`));
|
||||||
|
|
||||||
const message = () => {
|
const message = () => {
|
||||||
return matcherHint(this, matcherName, undefined, '', matcherOptions, timedOut ? timeout : undefined) + callLogText(log);
|
return matcherHint(this, matcherName, undefined, '', matcherOptions, timedOut ? timeout : undefined) + callLogText(log);
|
||||||
|
@ -327,7 +327,7 @@ export async function toHaveScreenshot(
|
|||||||
maxDiffPixelRatio: undefined,
|
maxDiffPixelRatio: undefined,
|
||||||
};
|
};
|
||||||
|
|
||||||
const customStackTrace = captureStackTrace(`expect.toHaveScreenshot`);
|
const customStackTrace = captureStackTrace(`expect.${this.isNot ? 'not.' : ''}toHaveScreenshot`);
|
||||||
const hasSnapshot = fs.existsSync(helper.snapshotPath);
|
const hasSnapshot = fs.existsSync(helper.snapshotPath);
|
||||||
if (this.isNot) {
|
if (this.isNot) {
|
||||||
if (!hasSnapshot)
|
if (!hasSnapshot)
|
||||||
|
@ -59,7 +59,7 @@ export async function toMatchText(
|
|||||||
|
|
||||||
const timeout = currentExpectTimeout(options);
|
const timeout = currentExpectTimeout(options);
|
||||||
|
|
||||||
const { matches: pass, received, log, timedOut } = await query(this.isNot, timeout, captureStackTrace('expect.' + matcherName));
|
const { matches: pass, received, log, timedOut } = await query(this.isNot, timeout, captureStackTrace(`expect.${this.isNot ? 'not.' : ''}${matcherName}`));
|
||||||
const stringSubstring = options.matchSubstring ? 'substring' : 'string';
|
const stringSubstring = options.matchSubstring ? 'substring' : 'string';
|
||||||
const receivedString = received || '';
|
const receivedString = received || '';
|
||||||
const message = pass
|
const message = pass
|
||||||
|
@ -44,7 +44,7 @@ export const CallLogView: React.FC<CallLogProps> = ({
|
|||||||
const locatorCall = `page.${locator}`;
|
const locatorCall = `page.${locator}`;
|
||||||
let titlePrefix = callLog.title;
|
let titlePrefix = callLog.title;
|
||||||
let titleSuffix = '';
|
let titleSuffix = '';
|
||||||
if (callLog.title.startsWith('expect.to')) {
|
if (callLog.title.startsWith('expect.to') || callLog.title.startsWith('expect.not.to')) {
|
||||||
titlePrefix = 'expect(';
|
titlePrefix = 'expect(';
|
||||||
titleSuffix = `).${callLog.title.substring('expect.'.length)}()`;
|
titleSuffix = `).${callLog.title.substring('expect.'.length)}()`;
|
||||||
} else if (callLog.title.startsWith('locator.')) {
|
} else if (callLog.title.startsWith('locator.')) {
|
||||||
|
@ -230,6 +230,7 @@ it.describe('pause', () => {
|
|||||||
const scriptPromise = (async () => {
|
const scriptPromise = (async () => {
|
||||||
await page.pause();
|
await page.pause();
|
||||||
await expect(page.locator('button')).toHaveText('Submit');
|
await expect(page.locator('button')).toHaveText('Submit');
|
||||||
|
await expect(page.locator('button')).not.toHaveText('Submit2');
|
||||||
await page.pause(); // 2
|
await page.pause(); // 2
|
||||||
})();
|
})();
|
||||||
const recorderPage = await recorderPageGetter();
|
const recorderPage = await recorderPageGetter();
|
||||||
@ -238,6 +239,7 @@ it.describe('pause', () => {
|
|||||||
expect(await sanitizeLog(recorderPage)).toEqual([
|
expect(await sanitizeLog(recorderPage)).toEqual([
|
||||||
'page.pause- XXms',
|
'page.pause- XXms',
|
||||||
'expect(page.locator(\'button\')).toHaveText()- XXms',
|
'expect(page.locator(\'button\')).toHaveText()- XXms',
|
||||||
|
'expect(page.locator(\'button\')).not.toHaveText()- XXms',
|
||||||
'page.pause',
|
'page.pause',
|
||||||
]);
|
]);
|
||||||
await recorderPage.click('[title="Resume (F8)"]');
|
await recorderPage.click('[title="Resume (F8)"]');
|
||||||
|
@ -58,7 +58,7 @@ test.describe('toBeChecked', () => {
|
|||||||
await page.setContent('<input type=checkbox checked></input>');
|
await page.setContent('<input type=checkbox checked></input>');
|
||||||
const locator = page.locator('input');
|
const locator = page.locator('input');
|
||||||
const error = await expect(locator).not.toBeChecked({ timeout: 1000 }).catch(e => e);
|
const error = await expect(locator).not.toBeChecked({ timeout: 1000 }).catch(e => e);
|
||||||
expect(error.message).toContain(`expect.toBeChecked with timeout 1000ms`);
|
expect(error.message).toContain(`expect.not.toBeChecked with timeout 1000ms`);
|
||||||
expect(error.message).toContain(`locator resolved to <input checked type="checkbox"/>`);
|
expect(error.message).toContain(`locator resolved to <input checked type="checkbox"/>`);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -73,7 +73,7 @@ test.describe('toBeChecked', () => {
|
|||||||
await page.setContent('<div>no inputs here</div>');
|
await page.setContent('<div>no inputs here</div>');
|
||||||
const locator2 = page.locator('input2');
|
const locator2 = page.locator('input2');
|
||||||
const error = await expect(locator2).not.toBeChecked({ timeout: 1000 }).catch(e => e);
|
const error = await expect(locator2).not.toBeChecked({ timeout: 1000 }).catch(e => e);
|
||||||
expect(error.message).toContain(`expect.toBeChecked with timeout 1000ms`);
|
expect(error.message).toContain(`expect.not.toBeChecked with timeout 1000ms`);
|
||||||
expect(error.message).toContain('waiting for locator(\'input2\')');
|
expect(error.message).toContain('waiting for locator(\'input2\')');
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -368,7 +368,7 @@ test.describe('toBeHidden', () => {
|
|||||||
await page.setContent('<div></div>');
|
await page.setContent('<div></div>');
|
||||||
const locator = page.locator('button');
|
const locator = page.locator('button');
|
||||||
const error = await expect(locator).not.toBeHidden({ timeout: 1000 }).catch(e => e);
|
const error = await expect(locator).not.toBeHidden({ timeout: 1000 }).catch(e => e);
|
||||||
expect(error.message).toContain(`expect.toBeHidden with timeout 1000ms`);
|
expect(error.message).toContain(`expect.not.toBeHidden with timeout 1000ms`);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('with impossible timeout .not', async ({ page }) => {
|
test('with impossible timeout .not', async ({ page }) => {
|
||||||
|
@ -255,11 +255,11 @@ test.describe('toHaveAttribute', () => {
|
|||||||
await expect(locator).toHaveAttribute('checked', /.*/);
|
await expect(locator).toHaveAttribute('checked', /.*/);
|
||||||
{
|
{
|
||||||
const error = await expect(locator).not.toHaveAttribute('checked', '', { timeout: 1000 }).catch(e => e);
|
const error = await expect(locator).not.toHaveAttribute('checked', '', { timeout: 1000 }).catch(e => e);
|
||||||
expect(error.message).toContain('expect.toHaveAttribute with timeout 1000ms');
|
expect(error.message).toContain('expect.not.toHaveAttribute with timeout 1000ms');
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
const error = await expect(locator).not.toHaveAttribute('checked', /.*/, { timeout: 1000 }).catch(e => e);
|
const error = await expect(locator).not.toHaveAttribute('checked', /.*/, { timeout: 1000 }).catch(e => e);
|
||||||
expect(error.message).toContain('expect.toHaveAttribute with timeout 1000ms');
|
expect(error.message).toContain('expect.not.toHaveAttribute with timeout 1000ms');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user