mirror of
https://github.com/microsoft/playwright.git
synced 2025-01-06 03:16:17 +03:00
parent
0fba4d5611
commit
b8f96a9411
@ -325,9 +325,9 @@ export class JavaLocatorFactory implements LocatorFactory {
|
|||||||
const attrString = attrs.length ? `, new ${clazz}.GetByRoleOptions()${attrs.join('')}` : '';
|
const attrString = attrs.length ? `, new ${clazz}.GetByRoleOptions()${attrs.join('')}` : '';
|
||||||
return `getByRole(AriaRole.${toSnakeCase(body as string).toUpperCase()}${attrString})`;
|
return `getByRole(AriaRole.${toSnakeCase(body as string).toUpperCase()}${attrString})`;
|
||||||
case 'has-text':
|
case 'has-text':
|
||||||
return `filter(new ${clazz}.LocatorOptions().setHasText(${this.toHasText(body)}))`;
|
return `filter(new ${clazz}.FilterOptions().setHasText(${this.toHasText(body)}))`;
|
||||||
case 'has':
|
case 'has':
|
||||||
return `filter(new ${clazz}.LocatorOptions().setHas(${body}))`;
|
return `filter(new ${clazz}.FilterOptions().setHas(${body}))`;
|
||||||
case 'test-id':
|
case 'test-id':
|
||||||
return `getByTestId(${this.quote(body as string)})`;
|
return `getByTestId(${this.quote(body as string)})`;
|
||||||
case 'text':
|
case 'text':
|
||||||
|
@ -271,21 +271,21 @@ it('reverse engineer locators with regex', async ({ page }) => {
|
|||||||
it('reverse engineer hasText', async ({ page }) => {
|
it('reverse engineer hasText', async ({ page }) => {
|
||||||
expect.soft(generate(page.getByText('Hello').filter({ hasText: 'wo"rld\n' }))).toEqual({
|
expect.soft(generate(page.getByText('Hello').filter({ hasText: 'wo"rld\n' }))).toEqual({
|
||||||
csharp: `GetByText("Hello").Filter(new() { HasText = "wo\\"rld\\n" })`,
|
csharp: `GetByText("Hello").Filter(new() { HasText = "wo\\"rld\\n" })`,
|
||||||
java: `getByText("Hello").filter(new Locator.LocatorOptions().setHasText("wo\\"rld\\n"))`,
|
java: `getByText("Hello").filter(new Locator.FilterOptions().setHasText("wo\\"rld\\n"))`,
|
||||||
javascript: `getByText('Hello').filter({ hasText: 'wo"rld\\n' })`,
|
javascript: `getByText('Hello').filter({ hasText: 'wo"rld\\n' })`,
|
||||||
python: `get_by_text("Hello").filter(has_text="wo\\"rld\\n")`,
|
python: `get_by_text("Hello").filter(has_text="wo\\"rld\\n")`,
|
||||||
});
|
});
|
||||||
|
|
||||||
expect.soft(generate(page.getByText('Hello').filter({ hasText: /wo\/\srld\n/ }))).toEqual({
|
expect.soft(generate(page.getByText('Hello').filter({ hasText: /wo\/\srld\n/ }))).toEqual({
|
||||||
csharp: `GetByText("Hello").Filter(new() { HasTextRegex = new Regex("wo\\\\/\\\\srld\\\\n") })`,
|
csharp: `GetByText("Hello").Filter(new() { HasTextRegex = new Regex("wo\\\\/\\\\srld\\\\n") })`,
|
||||||
java: `getByText("Hello").filter(new Locator.LocatorOptions().setHasText(Pattern.compile("wo\\\\/\\\\srld\\\\n")))`,
|
java: `getByText("Hello").filter(new Locator.FilterOptions().setHasText(Pattern.compile("wo\\\\/\\\\srld\\\\n")))`,
|
||||||
javascript: `getByText('Hello').filter({ hasText: /wo\\/\\srld\\n/ })`,
|
javascript: `getByText('Hello').filter({ hasText: /wo\\/\\srld\\n/ })`,
|
||||||
python: `get_by_text("Hello").filter(has_text=re.compile(r"wo/\\srld\\n"))`,
|
python: `get_by_text("Hello").filter(has_text=re.compile(r"wo/\\srld\\n"))`,
|
||||||
});
|
});
|
||||||
|
|
||||||
expect.soft(generate(page.getByText('Hello').filter({ hasText: /wor"ld/ }))).toEqual({
|
expect.soft(generate(page.getByText('Hello').filter({ hasText: /wor"ld/ }))).toEqual({
|
||||||
csharp: `GetByText("Hello").Filter(new() { HasTextRegex = new Regex("wor\\"ld") })`,
|
csharp: `GetByText("Hello").Filter(new() { HasTextRegex = new Regex("wor\\"ld") })`,
|
||||||
java: `getByText("Hello").filter(new Locator.LocatorOptions().setHasText(Pattern.compile("wor\\"ld")))`,
|
java: `getByText("Hello").filter(new Locator.FilterOptions().setHasText(Pattern.compile("wor\\"ld")))`,
|
||||||
javascript: `getByText('Hello').filter({ hasText: /wor"ld/ })`,
|
javascript: `getByText('Hello').filter({ hasText: /wor"ld/ })`,
|
||||||
python: `get_by_text("Hello").filter(has_text=re.compile(r"wor\\"ld"))`,
|
python: `get_by_text("Hello").filter(has_text=re.compile(r"wor\\"ld"))`,
|
||||||
});
|
});
|
||||||
@ -294,7 +294,7 @@ it('reverse engineer hasText', async ({ page }) => {
|
|||||||
it('reverse engineer has', async ({ page }) => {
|
it('reverse engineer has', async ({ page }) => {
|
||||||
expect.soft(generate(page.getByText('Hello').filter({ has: page.locator('div').getByText('bye') }))).toEqual({
|
expect.soft(generate(page.getByText('Hello').filter({ has: page.locator('div').getByText('bye') }))).toEqual({
|
||||||
csharp: `GetByText("Hello").Filter(new() { Has = Locator("div").GetByText("bye") })`,
|
csharp: `GetByText("Hello").Filter(new() { Has = Locator("div").GetByText("bye") })`,
|
||||||
java: `getByText("Hello").filter(new Locator.LocatorOptions().setHas(locator("div").getByText("bye")))`,
|
java: `getByText("Hello").filter(new Locator.FilterOptions().setHas(locator("div").getByText("bye")))`,
|
||||||
javascript: `getByText('Hello').filter({ has: locator('div').getByText('bye') })`,
|
javascript: `getByText('Hello').filter({ has: locator('div').getByText('bye') })`,
|
||||||
python: `get_by_text("Hello").filter(has=locator("div").get_by_text("bye"))`,
|
python: `get_by_text("Hello").filter(has=locator("div").get_by_text("bye"))`,
|
||||||
});
|
});
|
||||||
@ -306,7 +306,7 @@ it('reverse engineer has', async ({ page }) => {
|
|||||||
.filter({ has: page.locator('a') });
|
.filter({ has: page.locator('a') });
|
||||||
expect.soft(generate(locator)).toEqual({
|
expect.soft(generate(locator)).toEqual({
|
||||||
csharp: `Locator("section").Filter(new() { Has = Locator("div").Filter(new() { Has = Locator("span") }) }).Filter(new() { HasText = "foo" }).Filter(new() { Has = Locator("a") })`,
|
csharp: `Locator("section").Filter(new() { Has = Locator("div").Filter(new() { Has = Locator("span") }) }).Filter(new() { HasText = "foo" }).Filter(new() { Has = Locator("a") })`,
|
||||||
java: `locator("section").filter(new Locator.LocatorOptions().setHas(locator("div").filter(new Locator.LocatorOptions().setHas(locator("span"))))).filter(new Locator.LocatorOptions().setHasText("foo")).filter(new Locator.LocatorOptions().setHas(locator("a")))`,
|
java: `locator("section").filter(new Locator.FilterOptions().setHas(locator("div").filter(new Locator.FilterOptions().setHas(locator("span"))))).filter(new Locator.FilterOptions().setHasText("foo")).filter(new Locator.FilterOptions().setHas(locator("a")))`,
|
||||||
javascript: `locator('section').filter({ has: locator('div').filter({ has: locator('span') }) }).filter({ hasText: 'foo' }).filter({ has: locator('a') })`,
|
javascript: `locator('section').filter({ has: locator('div').filter({ has: locator('span') }) }).filter({ hasText: 'foo' }).filter({ has: locator('a') })`,
|
||||||
python: `locator("section").filter(has=locator("div").filter(has=locator("span"))).filter(has_text="foo").filter(has=locator("a"))`,
|
python: `locator("section").filter(has=locator("div").filter(has=locator("span"))).filter(has_text="foo").filter(has=locator("a"))`,
|
||||||
});
|
});
|
||||||
@ -343,7 +343,7 @@ it.describe(() => {
|
|||||||
`);
|
`);
|
||||||
expect.soft(await generateForNode(page, '[mark="1"]')).toEqual({
|
expect.soft(await generateForNode(page, '[mark="1"]')).toEqual({
|
||||||
csharp: 'Locator("div").Filter(new() { HasText = "Goodbye world" }).Locator("span")',
|
csharp: 'Locator("div").Filter(new() { HasText = "Goodbye world" }).Locator("span")',
|
||||||
java: 'locator("div").filter(new Locator.LocatorOptions().setHasText("Goodbye world")).locator("span")',
|
java: 'locator("div").filter(new Locator.FilterOptions().setHasText("Goodbye world")).locator("span")',
|
||||||
javascript: `locator('div').filter({ hasText: 'Goodbye world' }).locator('span')`,
|
javascript: `locator('div').filter({ hasText: 'Goodbye world' }).locator('span')`,
|
||||||
python: 'locator("div").filter(has_text="Goodbye world").locator("span")',
|
python: 'locator("div").filter(has_text="Goodbye world").locator("span")',
|
||||||
});
|
});
|
||||||
@ -355,7 +355,7 @@ it('parse locators strictly', () => {
|
|||||||
|
|
||||||
// Exact
|
// Exact
|
||||||
expect.soft(parseLocator('csharp', `Locator("div").Filter(new() { HasText = "Goodbye world" }).Locator("span")`)).toBe(selector);
|
expect.soft(parseLocator('csharp', `Locator("div").Filter(new() { HasText = "Goodbye world" }).Locator("span")`)).toBe(selector);
|
||||||
expect.soft(parseLocator('java', `locator("div").filter(new Locator.LocatorOptions().setHasText("Goodbye world")).locator("span")`)).toBe(selector);
|
expect.soft(parseLocator('java', `locator("div").filter(new Locator.FilterOptions().setHasText("Goodbye world")).locator("span")`)).toBe(selector);
|
||||||
expect.soft(parseLocator('javascript', `locator('div').filter({ hasText: 'Goodbye world' }).locator('span')`)).toBe(selector);
|
expect.soft(parseLocator('javascript', `locator('div').filter({ hasText: 'Goodbye world' }).locator('span')`)).toBe(selector);
|
||||||
expect.soft(parseLocator('python', `locator("div").filter(has_text="Goodbye world").locator("span")`)).toBe(selector);
|
expect.soft(parseLocator('python', `locator("div").filter(has_text="Goodbye world").locator("span")`)).toBe(selector);
|
||||||
|
|
||||||
@ -365,13 +365,13 @@ it('parse locators strictly', () => {
|
|||||||
|
|
||||||
// Whitespace
|
// Whitespace
|
||||||
expect.soft(parseLocator('csharp', `Locator("div") . Filter (new ( ) { HasText = "Goodbye world" }).Locator( "span" )`)).toBe(selector);
|
expect.soft(parseLocator('csharp', `Locator("div") . Filter (new ( ) { HasText = "Goodbye world" }).Locator( "span" )`)).toBe(selector);
|
||||||
expect.soft(parseLocator('java', ` locator("div" ). filter( new Locator. LocatorOptions ( ) .setHasText( "Goodbye world" ) ).locator( "span")`)).toBe(selector);
|
expect.soft(parseLocator('java', ` locator("div" ). filter( new Locator. FilterOptions ( ) .setHasText( "Goodbye world" ) ).locator( "span")`)).toBe(selector);
|
||||||
expect.soft(parseLocator('javascript', `locator\n('div')\n\n.filter({ hasText : 'Goodbye world'\n }\n).locator('span')\n`)).toBe(selector);
|
expect.soft(parseLocator('javascript', `locator\n('div')\n\n.filter({ hasText : 'Goodbye world'\n }\n).locator('span')\n`)).toBe(selector);
|
||||||
expect.soft(parseLocator('python', `\tlocator(\t"div").filter(\thas_text="Goodbye world"\t).locator\t("span")`)).toBe(selector);
|
expect.soft(parseLocator('python', `\tlocator(\t"div").filter(\thas_text="Goodbye world"\t).locator\t("span")`)).toBe(selector);
|
||||||
|
|
||||||
// Extra symbols
|
// Extra symbols
|
||||||
expect.soft(parseLocator('csharp', `Locator("div").Filter(new() { HasText = "Goodbye world" }).Locator("span"))`)).not.toBe(selector);
|
expect.soft(parseLocator('csharp', `Locator("div").Filter(new() { HasText = "Goodbye world" }).Locator("span"))`)).not.toBe(selector);
|
||||||
expect.soft(parseLocator('java', `locator("div").filter(new Locator.LocatorOptions().setHasText("Goodbye world"))..locator("span")`)).not.toBe(selector);
|
expect.soft(parseLocator('java', `locator("div").filter(new Locator.FilterOptions().setHasText("Goodbye world"))..locator("span")`)).not.toBe(selector);
|
||||||
expect.soft(parseLocator('javascript', `locator('div').filter({ hasText: 'Goodbye world' }}).locator('span')`)).not.toBe(selector);
|
expect.soft(parseLocator('javascript', `locator('div').filter({ hasText: 'Goodbye world' }}).locator('span')`)).not.toBe(selector);
|
||||||
expect.soft(parseLocator('python', `locator("div").filter(has_text=="Goodbye world").locator("span")`)).not.toBe(selector);
|
expect.soft(parseLocator('python', `locator("div").filter(has_text=="Goodbye world").locator("span")`)).not.toBe(selector);
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user