முக்கிய உள்ளடக்கத்திற்குச் செல்லவும்

படம் ஒப்பிடுதல் (காட்சி சோதனை) சேவை

@wdio/visual-service என்பது ஒரு மூன்றாம் தரப்பு தொகுப்பு, மேலும் தகவலுக்கு தயவுசெய்து GitHub | npm ஐப் பார்க்கவும்

WebdriverIO உடன் காட்சி சோதனைக்கான ஆவணங்களுக்கு, docs ஐப் பார்க்கவும். இந்த திட்டம் WebdriverIO உடன் காட்சி சோதனைகளை இயக்குவதற்கான அனைத்து தொடர்புடைய தொகுதிகளையும் கொண்டுள்ளது. ./packages அடைவில் நீங்கள் பின்வருவனவற்றைக் காணலாம்:

  • @wdio/visual-testing: காட்சி சோதனையை ஒருங்கிணைப்பதற்கான WebdriverIO சேவை
  • webdriver-image-comparison: WebDriver நெறிமுறையை ஆதரிக்கும் வெவ்வேறு NodeJS சோதனை ஆட்டோமேஷன் பிரேம்வொர்க்குகளுக்கு பயன்படுத்தக்கூடிய படம் ஒப்பிடும் தொகுதி

ஸ்டோரிபுக் இயக்கி (BETA)

ஸ்டோரிபுக் இயக்கி பீட்டா பற்றிய மேலும் ஆவணங்களைக் காண கிளிக் செய்யவும்

ஸ்டோரிபுக் இயக்கி இன்னும் BETA நிலையில் உள்ளது, ஆவணங்கள் பின்னர் WebdriverIO ஆவண பக்கங்களுக்கு மாற்றப்படும்.

இந்த தொகுதி இப்போது ஒரு புதிய காட்சி இயக்கியுடன் ஸ்டோரிபுக்கை ஆதரிக்கிறது. இந்த இயக்கி உள்ளூர்/தொலைநிலை ஸ்டோரிபுக் உதாரணத்தை தானாகவே ஸ்கேன் செய்து, ஒவ்வொரு கூறுக்கும் உறுப்பு ஸ்கிரீன்ஷாட்களை உருவாக்கும். இதை பின்வருமாறு சேர்க்கலாம்

export const config: WebdriverIO.Config = {
// ...
services: ["visual"],
// ....
};

உங்கள் services க்கு மற்றும் npx wdio tests/configs/wdio.local.desktop.storybook.conf.ts --storybook ஐ கட்டளை வரி மூலம் இயக்குதல். இது இயல்புநிலையாக ஹெட்லெஸ் முறையில் Chrome ஐப் பயன்படுத்தும்.

[!NOTE]

  • பெரும்பாலான காட்சி சோதனை விருப்பங்கள் ஸ்டோரிபுக் இயக்கிக்கும் செயல்படும், WebdriverIO ஆவணத்தைப் பார்க்கவும்.
  • ஸ்டோரிபுக் இயக்கி உங்கள் அனைத்து திறன்களையும் மேலெழுதும் மற்றும் அது ஆதரிக்கும் உலாவிகளில் மட்டுமே இயங்க முடியும், --browsers ஐப் பார்க்கவும்.
  • ஸ்டோரிபுக் இயக்கி Multiremote திறன்களைப் பயன்படுத்தும் ஏற்கனவே உள்ள கட்டமைப்பை ஆதரிக்காது மற்றும் பிழை செய்தியை காட்டும்.
  • ஸ்டோரிபுக் இயக்கி டெஸ்க்டாப் வெப் மட்டுமே ஆதரிக்கிறது, மொபைல் வெப் அல்ல.

ஸ்டோரிபுக் இயக்கி சேவை விருப்பங்கள்

சேவை விருப்பங்கள் இவ்வாறு வழங்கப்படலாம்

export const config: WebdriverIO.Config  = {
// ...
services: [
[
'visual',
{
// சில இயல்புநிலை விருப்பங்கள்
baselineFolder: join(process.cwd(), './__snapshots__/'),
debug: true,
// ஸ்டோரிபுக் விருப்பங்கள், விளக்கத்திற்கு cli விருப்பங்களைப் பார்க்கவும்
storybook: {
additionalSearchParams: new URLSearchParams({foo: 'bar', abc: 'def'}),
clip: false,
clipSelector: ''#some-id,
numShards: 4,
// `skipStories` ஒரு சரம் ('example-button--secondary'),
// ஒரு மாதிரி (['example-button--secondary', 'example-button--small'])
// அல்லது ஒரு regex, இது ஒரு சரமாக வழங்கப்பட வேண்டும் ("/.*button.*/gm")
skipStories: ['example-button--secondary', 'example-button--small'],
url: 'https://www.bbc.co.uk/iplayer/storybook/',
version: 6,
// விருப்பமானது - அடிப்படைகளின் பாதையை மேலெழுத அனுமதிக்கிறது. இயல்பாக இது அடிப்படைகளை வகை மற்றும் கூறு மூலம் குழுவாக்கும் (எ.கா. forms/input/baseline.png)
getStoriesBaselinePath: (category, component) => `path__${category}__${component}`,
},
},
],
],
// ....
}

ஸ்டோரிபுக் இயக்கி CLI விருப்பங்கள்

--additionalSearchParams

  • வகை: string
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: ''
  • உதாரணம்: npx wdio tests/configs/wdio.local.desktop.storybook.conf.ts --storybook --additionalSearchParams="foo=bar&abc=def"

இது ஸ்டோரிபுக் URL க்கு கூடுதல் தேடல் அளவுருக்களைச் சேர்க்கும். மேலும் தகவலுக்கு URLSearchParams ஆவணத்தைப் பார்க்கவும். சரம் செல்லுபடியாகும் URLSearchParams சரமாக இருக்க வேண்டும்.

[!NOTE] & ஐ கட்டளை பிரிப்பானாக பொருள்கொள்வதைத் தடுக்க இரட்டை மேற்கோள்கள் தேவை. எடுத்துக்காட்டாக --additionalSearchParams="foo=bar&abc=def" என்பது பின்வரும் ஸ்டோரிபுக் URL ஐ கதைகள் சோதனைக்கு உருவாக்கும்: http://storybook.url/iframe.html?id=story-id&foo=bar&abc=def.

--browsers

  • வகை: string
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: chrome, நீங்கள் chrome|firefox|edge|safari இலிருந்து தேர்ந்தெடுக்கலாம்
  • உதாரணம்: npx wdio tests/configs/wdio.local.desktop.storybook.conf.ts --storybook --browsers=chrome,firefox,edge,safari
  • குறிப்பு: CLI மூலம் மட்டுமே கிடைக்கும்

இது கூறு ஸ்கிரீன்ஷாட்களை எடுக்க வழங்கப்பட்ட உலாவிகளைப் பயன்படுத்தும்

[!NOTE] நீங்கள் இயக்க விரும்பும் உலாவிகள் உங்கள் உள்ளூர் கணினியில் நிறுவப்பட்டுள்ளதா என்பதை உறுதிப்படுத்திக் கொள்ளுங்கள்

--clip

  • வகை: boolean
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: true
  • உதாரணம்: npx wdio tests/configs/wdio.local.desktop.storybook.conf.ts --storybook --clip=false

முடக்கப்பட்டிருக்கும்போது காட்சி திரை ஸ்கிரீன்ஷாட்டை உருவாக்கும். இயக்கப்பட்டிருக்கும்போது --clipSelector அடிப்படையில் உறுப்பு ஸ்கிரீன்ஷாட்களை உருவாக்கும், இது கூறு ஸ்கிரீன்ஷாட்டைச் சுற்றியுள்ள வெள்ளை இடத்தைக் குறைக்கும் மற்றும் ஸ்கிரீன்ஷாட் அளவைக் குறைக்கும்.

--clipSelector

  • வகை: string
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: #storybook-root > :first-child ஸ்டோரிபுக் V7க்கு மற்றும் #root > :first-child:not(script):not(style) ஸ்டோரிபுக் V6க்கு, --version ஐயும் பார்க்கவும்
  • உதாரணம்: npx wdio tests/configs/wdio.local.desktop.storybook.conf.ts --storybook --clipSelector="#some-id"

இந்த தேர்வி பின்வருவனவற்றிற்குப் பயன்படுத்தப்படும்:

  • ஸ்கிரீன்ஷாட் எடுக்க உறுப்பைத் தேர்ந்தெடுக்க
  • ஸ்கிரீன்ஷாட் எடுக்கப்படும் முன் தெரியும் உறுப்புக்காக காத்திருக்க

--devices

  • வகை: string
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: deviceDescriptors.ts இலிருந்து தேர்ந்தெடுக்கலாம்
  • உதாரணம்: npx wdio tests/configs/wdio.local.desktop.storybook.conf.ts --storybook --devices="iPhone 14 Pro Max","Pixel 3 XL"
  • குறிப்பு: CLI மூலம் மட்டுமே கிடைக்கும்

இது கூறு ஸ்கிரீன்ஷாட்களை எடுக்க deviceDescriptors.ts உடன் பொருந்தும் வழங்கப்பட்ட சாதனங்களைப் பயன்படுத்தும்

[!NOTE]

  • உங்களுக்கு ஒரு சாதன கட்டமைப்பு தவறினால், Feature request சமர்ப்பிக்கவும்
  • இது Chrome உடன் மட்டுமே வேலை செய்யும்:
    • நீங்கள் --devices வழங்கினால், அனைத்து Chrome உதாரணங்களும் Mobile Emulation முறையில் இயங்கும்
    • Chrome ஐத் தவிர மற்ற உலாவிகளையும் வழங்கினால், எ.கா. --devices --browsers=firefox,safari,edge என்றால் அது தானாகவே Chrome ஐ மொபைல் எமுலேஷன் முறையில் சேர்க்கும்
  • ஸ்டோரிபுக் இயக்கி இயல்பாக உறுப்பு ஸ்னாப்ஷாட்களை உருவாக்கும், முழு மொபைல் எமுலேட் செய்யப்பட்ட ஸ்கிரீன்ஷாட்டைப் பார்க்க விரும்பினால், கட்டளை வரி மூலம் --clip=false வழங்கவும்
  • கோப்பு பெயர் எடுத்துக்காட்டாக __snapshots__/example/button/desktop_chrome/example-button--large-local-chrome-iPhone-14-Pro-Max-430x932-dpr-3.png போல் தோன்றும்
  • SRC: மொபைல் எமுலேஷனைப் பயன்படுத்தி டெஸ்க்டாப்பில் மொபைல் வலைதளத்தை சோதிப்பது பயனுள்ளதாக இருக்கும், ஆனால் சோதனையாளர்கள் பின்வரும் சிறிய வேறுபாடுகளை அறிந்திருக்க வேண்டும்:
    • முற்றிலும் வித்தியாசமான GPU, இது பெரிய செயல்திறன் மாற்றங்களுக்கு வழிவகுக்கலாம்;
    • மொபைல் UI எமுலேட் செய்யப்படவில்லை (குறிப்பாக, url பட்டியை மறைப்பது பக்க உயரத்தை பாதிக்கிறது);
    • பதளிப்பு பாப்-அப் (ஒரு சில தொடு இலக்குகளில் ஒன்றைத் தேர்ந்தெடுக்கும் இடம்) ஆதரிக்கப்படவில்லை;
    • பல வன்பொருள் API கள் (எடுத்துக்காட்டாக, orientationchange நிகழ்வு) கிடைக்கவில்லை.

--headless

  • வகை: boolean
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: true
  • உதாரணம்: npx wdio tests/configs/wdio.local.desktop.storybook.conf.ts --storybook --headless=false
  • குறிப்பு: CLI மூலம் மட்டுமே கிடைக்கும்

இது இயல்பாக சோதனைகளை ஹெட்லெஸ் முறையில் இயக்கும் (உலாவி ஆதரிக்கும்போது) அல்லது முடக்கப்படலாம்

--numShards

  • வகை: number
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: true
  • உதாரணம்: npx wdio tests/configs/wdio.local.desktop.storybook.conf.ts --storybook --numShards=10

இது கதைகளை இயக்க பயன்படுத்தப்படும் இணை உதாரணங்களின் எண்ணிக்கையாக இருக்கும். இது உங்கள் wdio.conf-கோப்பில் உள்ள maxInstances ஆல் வரம்பிடப்படும்.

[!IMPORTANT] headless-முறையில் இயக்கும்போது, வள கட்டுப்பாடுகள் காரணமாக நிலையற்ற தன்மையைத் தடுக்க எண்ணிக்கையை 20க்கு மேல் அதிகரிக்க வேண்டாம்

--skipStories

  • வகை: string|regex
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: null
  • உதாரணம்: npx wdio tests/configs/wdio.local.desktop.storybook.conf.ts --storybook --skipStories="/.*button.*/gm"

இவை இருக்கலாம்:

  • ஒரு சரம் (example-button--secondary,example-button--small)
  • அல்லது ஒரு regex ("/.*button.*/gm")

சில கதைகளைத் தவிர்க்க. கதையின் URL இல் காணப்படும் id ஐப் பயன்படுத்தவும். எடுத்துக்காட்டாக, http://localhost:6006/?path=/story/example-page--logged-out என்ற URL இல் id என்பது example-page--logged-out

--url

  • வகை: string
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: http://127.0.0.1:6006
  • உதாரணம்: npx wdio tests/configs/wdio.local.desktop.storybook.conf.ts --storybook --url="https://example.com"

உங்கள் ஸ்டோரிபுக் இன்ஸ்டன்ஸ் ஹோஸ்ட் செய்யப்பட்ட URL.

--version

  • வகை: number
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: 7
  • உதாரணம்: npx wdio tests/configs/wdio.local.desktop.storybook.conf.ts --storybook --version=6

இது ஸ்டோரிபுக்கின் பதிப்பு, இயல்பாக 7. V6 clipSelector பயன்படுத்த வேண்டியுள்ளதா என்பதை அறிய இது தேவை.

ஸ்டோரிபுக் இன்டராக்ஷன் சோதனை

ஸ்டோரிபுக் இன்டராக்ஷன் சோதனை WDIO கட்டளைகளுடன் தனிப்பயன் ஸ்கிரிப்டுகளை உருவாக்குவதன் மூலம் ஒரு கூறுக்கு குறிப்பிட்ட நிலையை அமைக்க உங்கள் கூறுடன் தொடர்புகொள்ள அனுமதிக்கிறது. எடுத்துக்காட்டாக, கீழே உள்ள குறியீட்டு துணுக்கைப் பார்க்கவும்:

import { browser, expect } from "@wdio/globals";

describe("Storybook Interaction", () => {
it("should create screenshots for the logged in state when it logs out", async () => {
const componentId = "example-page--logged-in";
await browser.waitForStorybookComponentToBeLoaded({ id: componentId });

await expect($("header")).toMatchElementSnapshot(
`${componentId}-logged-in-state`
);
await $("button=Log out").click();
await expect($("header")).toMatchElementSnapshot(
`${componentId}-logged-out-state`
);
});

it("should create screenshots for the logged out state when it logs in", async () => {
const componentId = "example-page--logged-out";
await browser.waitForStorybookComponentToBeLoaded({ id: componentId });

await expect($("header")).toMatchElementSnapshot(
`${componentId}-logged-out-state`
);
await $("button=Log in").click();
await expect($("header")).toMatchElementSnapshot(
`${componentId}-logged-in-state`
);
});
});

இரண்டு சோதனைகள் இரண்டு வெவ்வேறு கூறுகளில் செயல்படுத்தப்படுகின்றன. ஒவ்வொரு சோதனையும் முதலில் ஒரு நிலையை அமைத்து பின்னர் ஸ்கிரீன்ஷாட் எடுக்கிறது. ஒரு புதிய தனிப்பயன் கட்டளை அறிமுகப்படுத்தப்பட்டுள்ளதையும் நீங்கள் கவனிப்பீர்கள், அதை இங்கே காணலாம்.

மேலே உள்ள ஸ்பெக் கோப்பை ஒரு கோப்புறையில் சேமித்து பின்வரும் கட்டளையுடன் கட்டளை வரிக்கு சேர்க்கலாம்:

pnpm run test.local.desktop.storybook.localhost -- --spec='tests/specs/storybook-interaction/*.ts'

ஸ்டோரிபுக் இயக்கி முதலில் தானாகவே உங்கள் ஸ்டோரிபுக் இன்ஸ்டன்ஸை ஸ்கேன் செய்து, பின்னர் ஒப்பிட வேண்டிய கதைகளுக்கு உங்கள் சோதனைகளைச் சேர்க்கும். இன்டராக்ஷன் சோதனைக்குப் பயன்படுத்தும் கூறுகளை இரண்டு முறை ஒப்பிட விரும்பவில்லை என்றால், ["default" கதைகளை ஸ்கேனில் இருந்து நீக்க --skipStories வடிப்பானை வழங்குவதன் மூலம் நீங்கள் ஒரு வடிப்பானைச் சேர்க்கலாம். இது இவ்வாறு இருக்கும்:

pnpm run test.local.desktop.storybook.localhost -- --skipStories="/example-page.*/gm" --spec='tests/specs/storybook-interaction/*.ts'

புதிய தனிப்பயன் கட்டளை

browser.waitForStorybookComponentToBeLoaded({ id: 'componentId' }) என்ற புதிய தனிப்பயன் கட்டளை browser/driver-பொருளுக்கு தானாகவே சேர்க்கப்படும், இது தானாகவே கூறுகளை ஏற்றி அது முடிக்கப்படுவதற்காக காத்திருக்கும், எனவே நீங்கள் browser.url('url.com') முறையைப் பயன்படுத்த வேண்டியதில்லை. இதை பின்வருமாறு பயன்படுத்தலாம்

import { browser, expect } from "@wdio/globals";

describe("Storybook Interaction", () => {
it("should create screenshots for the logged in state when it logs out", async () => {
const componentId = "example-page--logged-in";
await browser.waitForStorybookComponentToBeLoaded({ id: componentId });

await expect($("header")).toMatchElementSnapshot(
`${componentId}-logged-in-state`
);
await $("button=Log out").click();
await expect($("header")).toMatchElementSnapshot(
`${componentId}-logged-out-state`
);
});

it("should create screenshots for the logged out state when it logs in", async () => {
const componentId = "example-page--logged-out";
await browser.waitForStorybookComponentToBeLoaded({ id: componentId });

await expect($("header")).toMatchElementSnapshot(
`${componentId}-logged-out-state`
);
await $("button=Log in").click();
await expect($("header")).toMatchElementSnapshot(
`${componentId}-logged-in-state`
);
});
});

விருப்பங்கள்:

additionalSearchParams

  • வகை: URLSearchParams
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: new URLSearchParams()
  • உதாரணம்:
await browser.waitForStorybookComponentToBeLoaded({
additionalSearchParams: new URLSearchParams({ foo: "bar", abc: "def" }),
id: "componentId",
});

இது ஸ்டோரிபுக் URL க்கு கூடுதல் தேடல் அளவுருக்களைச் சேர்க்கும், மேலே உள்ள உதாரணத்தில் URL http://storybook.url/iframe.html?id=story-id&foo=bar&abc=def ஆக இருக்கும். மேலும் தகவலுக்கு URLSearchParams ஆவணத்தைப் பார்க்கவும்.

clipSelector

  • வகை: string
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: #storybook-root > :first-child ஸ்டோரிபுக் V7க்கு மற்றும் #root > :first-child:not(script):not(style) ஸ்டோரிபுக் V6க்கு
  • உதாரணம்:
await browser.waitForStorybookComponentToBeLoaded({
clipSelector: "#your-selector",
id: "componentId",
});

இந்த தேர்வி பின்வருவனவற்றிற்குப் பயன்படுத்தப்படும்:

  • ஸ்கிரீன்ஷாட் எடுக்க உறுப்பைத் தேர்ந்தெடுக்க
  • ஸ்கிரீன்ஷாட் எடுக்கப்படும் முன் தெரியும் உறுப்புக்காக காத்திருக்க

id

  • வகை: string
  • கட்டாயம்: ஆம்
  • உதாரணம்:
await browser.waitForStorybookComponentToBeLoaded({ '#your-selector', id: 'componentId' })

கதையின் URL இல் காணப்படும் id ஐப் பயன்படுத்தவும். எடுத்துக்காட்டாக, http://localhost:6006/?path=/story/example-page--logged-out என்ற URL இல் id என்பது example-page--logged-out

timeout

  • வகை: number
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: 1100 மில்லி வினாடிகள்
  • உதாரணம்:
await browser.waitForStorybookComponentToBeLoaded({
id: "componentId",
timeout: 20000,
});

பக்கத்தில் ஏற்றிய பிறகு ஒரு கூறு தெரியும் வரை நாம் காத்திருக்க விரும்பும் அதிகபட்ச நேரம்

url

  • வகை: string
  • கட்டாயம்: இல்லை
  • இயல்புநிலை: http://127.0.0.1:6006
  • உதாரணம்:
await browser.waitForStorybookComponentToBeLoaded({
id: "componentId",
url: "https://your.url",
});

உங்கள் ஸ்டோரிபுக் இன்ஸ்டன்ஸ் ஹோஸ்ட் செய்யப்பட்ட URL.

பங்களிப்பு

தொகுப்புகளை புதுப்பித்தல்

நீங்கள் தொகுப்புகளை ஒரு எளிய CLI கருவி மூலம் புதுப்பிக்கலாம். அனைத்து சார்புகளையும் நிறுவியுள்ளீர்கள் என்பதை உறுதிப்படுத்திக்கொள்ளுங்கள், பின்னர் இயக்கலாம்

pnpm update.packages

இது ஒரு CLI ஐத் தூண்டும், இது உங்களிடம் பின்வரும் கேள்விகளைக் கேட்கும்

==========================
🤖 Package update Wizard 🧙
==========================

? Which version target would you like to update to? (Minor|Latest)
? Do you want to update the package.json files? (Y/n)
? Do you want to remove all "node_modules" and reinstall dependencies? (Y/n)
? Would you like reinstall the dependencies? (Y/n)

இது பின்வரும் பதிவுகளை வழங்கும்

பதிவுகளின் எடுத்துக்காட்டைப் பார்க்க திறக்கவும்
==========================
🤖 Package update Wizard 🧙
==========================

? Which version target would you like to update to? Minor
? Do you want to update the package.json files? yes
Updating root 'package.json' for minor updates...
Updating packages for minor updates in /Users/wswebcreation/Git/wdio/visual-testing...
Using pnpm
Upgrading /Users/wswebcreation/Git/wdio/visual-testing/package.json
[====================] 38/38 100%

@typescript-eslint/eslint-plugin ^8.7.0 → ^8.8.0
@typescript-eslint/parser ^8.7.0 → ^8.8.0
@typescript-eslint/utils ^8.7.0 → ^8.8.0
@vitest/coverage-v8 ^2.1.1 → ^2.1.2
vitest ^2.1.1 → ^2.1.2

Run pnpm install to install new versions.
Updating packages for minor updates in /Users/wswebcreation/Git/wdio/visual-testing/packages/ocr-service...
Using pnpm
Upgrading /Users/wswebcreation/Git/wdio/visual-testing/packages/ocr-service/package.json
[====================] 11/11 100%

All dependencies match the minor package versions :)
Updating packages for minor updates in /Users/wswebcreation/Git/wdio/visual-testing/packages/visual-reporter...
Using pnpm
Upgrading /Users/wswebcreation/Git/wdio/visual-testing/packages/visual-reporter/package.json
[====================] 11/11 100%

eslint-config-next 14.2.13 → 14.2.14
next 14.2.13 → 14.2.14

Run pnpm install to install new versions.
Updating packages for minor updates in /Users/wswebcreation/Git/wdio/visual-testing/packages/visual-service...
Using pnpm
Upgrading /Users/wswebcreation/Git/wdio/visual-testing/packages/visual-service/package.json
[====================] 5/5 100%

All dependencies match the minor package versions :)
Updating packages for minor updates in /Users/wswebcreation/Git/wdio/visual-testing/packages/webdriver-image-comparison...
Using pnpm
Upgrading /Users/wswebcreation/Git/wdio/visual-testing/packages/webdriver-image-comparison/package.json
[====================] 8/8 100%

All dependencies match the minor package versions :)
? Do you want to remove all "node_modules" and reinstall dependencies? yes
Removing root dependencies in /Users/wswebcreation/Git/wdio/visual-testing...
Removing dependencies in ocr-service...
Removing dependencies in visual-reporter...
Removing dependencies in visual-service...
Removing dependencies in webdriver-image-comparison...
? Would you like reinstall the dependencies? yes
Installing dependencies in /Users/wswebcreation/Git/wdio/visual-testing...

> @wdio/visual-testing-monorepo@ pnpm.install.workaround /Users/wswebcreation/Git/wdio/visual-testing
> pnpm install --shamefully-hoist

Scope: all 5 workspace projects
Lockfile is up to date, resolution step is skipped
Packages: +1274
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Progress: resolved 1274, reused 1265, downloaded 0, added 1274, done

dependencies:

- @wdio/ocr-service 2.0.0 <- packages/ocr-service
- @wdio/visual-service 6.0.0 <- packages/visual-service

devDependencies:

- @changesets/cli 2.27.8
- @inquirer/prompts 5.5.0
- @tsconfig/node20 20.1.4
- @types/eslint 9.6.1
- @types/jsdom 21.1.7
- @types/node 20.16.4
- @types/react 18.3.5
- @types/react-dom 18.3.0
- @types/xml2js 0.4.14
- @typescript-eslint/eslint-plugin 8.8.0
- @typescript-eslint/parser 8.8.0
- @typescript-eslint/utils 8.8.0
- @vitest/coverage-v8 2.1.2
- @wdio/appium-service 9.1.2
- @wdio/cli 9.1.2
- @wdio/globals 9.1.2
- @wdio/local-runner 9.1.2
- @wdio/mocha-framework 9.1.2
- @wdio/sauce-service 9.1.2
- @wdio/shared-store-service 9.1.2
- @wdio/spec-reporter 9.1.2
- @wdio/types 9.1.2
- eslint 9.11.1
- eslint-plugin-import 2.30.0
- eslint-plugin-unicorn 55.0.0
- eslint-plugin-wdio 9.0.8
- husky 9.1.6
- jsdom 25.0.1
- pnpm-run-all2 6.2.3
- release-it 17.6.0
- rimraf 6.0.1
- saucelabs 8.0.0
- ts-node 10.9.2
- typescript 5.6.2
- vitest 2.1.2
- webdriverio 9.1.2

. prepare$ husky
└─ Done in 204ms
Done in 9.5s
All packages updated!

கேள்விகள்

இந்த திட்டத்திற்கு பங்களிப்பதில் உங்களுக்கு ஏதேனும் கேள்விகள் அல்லது சிக்கல்கள் இருந்தால், எங்கள் Discord சேவையகத்தில் சேரவும். பங்களிப்பாளர்களை 🙏-contributing சேனலில் பிடிக்கவும்.

சிக்கல்கள்

உங்களுக்கு கேள்விகள், பிழைகள் அல்லது அம்ச கோரிக்கைகள் இருந்தால், தயவுசெய்து ஒரு சிக்கலைத் தாக்கல் செய்யவும். ஒரு சிக்கலைச் சமர்ப்பிக்கும் முன், நகல்களைக் குறைக்க உதவ சிக்கல் காப்பகத்தைத் தேடவும், மற்றும் FAQ ஐப் படிக்கவும்.

அங்கு உங்களால் கண்டுபிடிக்க முடியாவிட்டால், நீங்கள் சமர்ப்பிக்கக்கூடிய ஒரு சிக்கலை சமர்ப்பிக்கலாம்:

  • 🐛பிழை அறிக்கை: எங்களை மேம்படுத்த ஒரு அறிக்கையை உருவாக்கவும்
  • 📖ஆவணம்: முன்னேற்றங்களை பரிந்துரைக்கவும் அல்லது தவறான/தெளிவற்ற ஆவணங்களை அறிக்கையிடவும்.
  • 💡அம்ச கோரிக்கை: இந்த தொகுதிக்கான ஒரு யோசனையை பரிந்துரைக்கவும்.
  • 💬கேள்வி: கேள்விகள் கேட்கவும்.

உருவாக்க ஓட்டம்

இந்த திட்டத்திற்கான PR ஐ உருவாக்கி பங்களிக்கத் தொடங்க இந்த படிப்படியான வழிகாட்டியைப் பின்பற்றவும்:

  • திட்டத்தை fork செய்யவும்.

  • உங்கள் கணினியில் எங்காவது திட்டத்தை clone செய்யவும்

    $ git clone https://github.com/webdriverio/visual-testing.git
  • அடைவுக்குச் சென்று திட்டத்தை அமைக்கவும்

    $ cd visual-testing
    $ corepack enable
    $ pnpm pnpm.install.workaround
  • குறியீட்டை தானாகவே மாற்றும் கண்காணிப்பு முறையை இயக்கவும்

    $ pnpm watch

    திட்டத்தை build செய்ய:

    $ pnpm build
  • உங்கள் மாற்றங்கள் எந்த சோதனைகளையும் உடைக்கவில்லை என்பதை உறுதிசெய்யவும், இயக்கவும்:

    $ pnpm test

இந்த திட்டம் changesets ஐப் பயன்படுத்தி தானாகவே changelogs மற்றும் வெளியீடுகளை உருவாக்குகிறது.

சோதனை

தொகுதியை சோதிக்க பல சோதனைகள் செயல்படுத்தப்பட வேண்டும். PR சேர்க்கும்போது அனைத்து சோதனைகளும் குறைந்தபட்சம் உள்ளூர் சோதனைகளை தேர்ச்சி பெற வேண்டும். ஒவ்வொரு PR ம் Sauce Labs இல் தானாகவே சோதிக்கப்படுகிறது, எங்கள் GitHub Actions pipeline ஐப் பார்க்கவும். PR ஐ அங்கீகரிப்பதற்கு முன், முக்கிய பங்களிப்பாளர்கள் PR ஐ எமுலேட்டர்கள்/சிமுலேட்டர்கள் / உண்மையான சாதனங்களுக்கு எதிராக சோதிப்பார்கள்.

உள்ளூர் சோதனை

முதலில், ஒரு உள்ளூர் அடிப்படை உருவாக்கப்பட வேண்டும். இதை பின்வருமாறு செய்யலாம்:

// வெப்டிரைவர் நெறிமுறையுடன்
$ pnpm run test.local.init

இந்த கட்டளை அனைத்து அடிப்படை படங்களையும் வைத்திருக்கும் localBaseline என்ற கோப்புறையை உருவாக்கும்.

பின்னர் இயக்கவும்:

// வெப்டிரைவர் நெறிமுறையுடன்
pnpm run test.local.desktop

இது உள்ளூர் கணினியில் Chrome இல் அனைத்து சோதனைகளையும் இயக்கும்.

உள்ளூர் ஸ்டோரிபுக் இயக்கி சோதனை (பீட்டா)

முதலில், ஒரு உள்ளூர் அடிப்படை உருவாக்கப்பட வேண்டும். இதை பின்வருமாறு செய்யலாம்:

pnpm run test.local.desktop.storybook

இது https://govuk-react.github.io/govuk-react/ இல் உள்ள டெமோ ஸ்டோரிபுக் ரெப்போவுக்கு எதிராக ஹெட்லெஸ் முறையில் Chrome உடன் ஸ்டோரிபுக் சோதனைகளை இயக்கும்.

மேலும் உலாவிகளுடன் சோதனைகளை இயக்க, நீங்கள் இயக்கலாம்

pnpm run test.local.desktop.storybook -- --browsers=chrome,firefox,edge,safari

[!NOTE] நீங்கள் இயக்க விரும்பும் உலாவிகள் உங்கள் உள்ளூர் கணினியில் நிறுவப்பட்டுள்ளதா என்பதை உறுதிப்படுத்திக் கொள்ளுங்கள்

Sauce Labs உடன் CI சோதனை (PR க்கு தேவையில்லை)

கீழே உள்ள கட்டளை GitHub Actions இல் build ஐ சோதிக்கப் பயன்படுகிறது, இதை அங்கு மட்டுமே பயன்படுத்த முடியும், உள்ளூர் மேம்பாட்டிற்கு அல்ல.

$ pnpm run test.saucelabs

இது இங்கு காணப்படும் பல கட்டமைப்புகளுக்கு எதிராக சோதிக்கும். அனைத்து PR களும் Sauce Labs க்கு எதிராக தானாகவே சரிபார்க்கப்படுகின்றன.

வெளியீடு

மேலே பட்டியலிடப்பட்ட எந்த தொகுப்புகளின் பதிப்பையும் வெளியிட, பின்வருவனவற்றைச் செய்யவும்:

  • வெளியீட்டு பைப்லைன் ஐத் தூண்டவும்
  • ஒரு வெளியீட்டு PR உருவாக்கப்படுகிறது, இதை மற்றொரு WebdriverIO உறுப்பினரால் மதிப்பாய்வு செய்து அங்கீகரிக்கவும்
  • PR ஐ இணைக்கவும்
  • வெளியீட்டு பைப்லைன் ஐ மீண்டும் தூண்டவும்
  • ஒரு புதிய பதிப்பு வெளியிடப்பட வேண்டும் 🎉

நன்றி

@wdio/visual-testing LambdaTest மற்றும் Sauce Labs இலிருந்து ஓபன் சோர்ஸ் உரிமத்தைப் பயன்படுத்துகிறது.

Welcome! How can I help?

WebdriverIO AI Copilot