הסבר על התכונות

Sofia Emelianova
Sofia Emelianova

מגלים דרכים לשתף תהליכי עבודה של משתמשים, לערוך אותם ואת השלבים שלהם במאמרי העזרה המקיפים האלה בנושא תכונות בחלונית מכשיר ההקלטה של Chrome.

מידע בסיסי על העבודה עם החלונית מכשיר ההקלטה זמין במאמר הקלטה, הפעלה מחדש ומדידה של תהליכים של משתמשים.

הסבר והתאמה אישית של מקשי הקיצור

אפשר להשתמש במקשי קיצור כדי לנווט מהר יותר במכשיר ההקלטה. ניתן לראות רשימה של מקשי הקיצור שמוגדרים כברירת מחדל במאמר בנושא מקשי קיצור בחלונית מכשיר ההקלטה.

כדי לפתוח רמז עם רשימה של כל קיצורי הדרך ישירות מתוך מכשיר ההקלטה, לוחצים על עזרה הצגת קיצורי דרך בפינה השמאלית העליונה.

הלחצן 'הצגת קיצורי דרך'.

כדי להתאים אישית את מקשי הקיצור של מכשיר ההקלטה:

  1. פתיחת הגדרות. הגדרות > קיצורי דרך.
  2. גוללים למטה אל הקטע מכשיר הקלטה.
  3. פועלים לפי השלבים שמפורטים בקטע התאמה אישית של קיצורי דרך.

עריכה של תהליכי העבודה של המשתמשים

בחלונית 'מכשיר ההקלטה' של כלי הפיתוח יש תפריט נפתח בכותרת, שמאפשר לבחור את המסלול שהמשתמש רוצה לערוך.

בחלק העליון של החלונית מכשיר ההקלטה יש אפשרויות:

  1. הוספת הקלטה חדשההוספה. לוחצים על הסמל + כדי להוסיף הקלטה חדשה.
  2. הצגת כל ההקלטותהרחבה. בתפריט הנפתח מוצגת הרשימה של ההקלטות השמורות. בוחרים באפשרות [מספר] ההקלטות כדי להרחיב ולנהל את רשימת ההקלטות השמורות. הצגת כל ההקלטות.
  3. ייצוא הקלטההורדת הקובץ.. כדי להתאים אישית את הסקריפט או לשתף אותו למטרות דיווח על באגים, ניתן לייצא את זרימת המשתמשים באחד מהפורמטים הבאים:

    למידע נוסף על הפורמטים, אפשר לעיין במאמר ייצוא תהליך של משתמש.

  4. ייבוא הקלטההעלאת קובץ.. רק בפורמט JSON.

  5. מחיקת הקלטהמחיקה.. מחיקת ההקלטה שנבחרה.

כדי לערוך את שם ההקלטה, אפשר ללחוץ על לחצן העריכה עריכה. שלצידה.

שיתוף תהליכי עבודה של משתמשים

ניתן לייצא ולייבא תהליכים של משתמשים במכשיר ההקלטה. האפשרות הזו שימושית לדיווח על באגים, כי אפשר לשתף תיעוד מדויק של השלבים שמשחזרים באג. תוכלו גם לייצא את הקובץ ולהפעיל אותו מחדש באמצעות ספריות חיצוניות.

ייצוא תהליך המשתמש

כדי לייצא תהליך של משתמש:

  1. פותחים את תהליך העבודה של המשתמשים שרוצים לייצא.
  2. לוחצים על הורדת הקובץ. ייצוא בחלק העליון של החלונית מכשיר ההקלטה. אפשרויות הפורמט של ייצוא.
  3. בוחרים אחד מהפורמטים הבאים מהרשימה הנפתחת:
    • קובץ JSON. מורידים את ההקלטה כקובץ JSON.
    • @puppeteer/replay. מורידים את ההקלטה כתסריט להפעלה חוזרת של בובות.
    • בובנית. הורד את ההקלטה כתסריט של Puppeteer.
    • בובה (כולל ניתוח Lighthouse). מורידים את ההקלטה כתסריט של Puppeteer עם ניתוח מוטמע של Lighthouse.
    • אחת או יותר מהאפשרויות שסופקו על ידי התוספים לייצוא של מכשיר ההקלטה.
  4. שומרים את הקובץ.

אתם יכולים לבצע את הפעולות הבאות בכל אפשרות ייצוא שמוגדרת כברירת מחדל:

  • JSON. עורכים את אובייקט ה-JSON קריא לאנשים ומייבאים את קובץ ה-JSON חזרה אל מכשיר ההקלטה.
  • @puppeteer/replay. מפעילים מחדש את התסריט באמצעות הספרייה Puppeteer Replay. כשמייצאים כסקריפט @puppeteer/replay, השלבים נשארים כאובייקט JSON. זו האפשרות המתאימה ביותר אם רוצים לשלב את צינור עיבוד הנתונים של CI/CD, אבל עדיין יש לכם את הגמישות לערוך את השלבים כ-JSON, להמיר אותם ולייבא אותם בחזרה אל מכשיר ההקלטה.
  • הסקריפט של הבובה. מפעילים מחדש את התסריט באמצעות Puppeteer. מאחר שהשלבים מומרים ל-JavaScript, תוכלו לבצע התאמה אישית פרטנית יותר, לדוגמה, לחזור על השלבים בלופ. אזהרה אחת: לא ניתן לייבא את הסקריפט הזה חזרה אל מכשיר ההקלטה.
  • בובה (כולל ניתוח Lighthouse). אפשרות הייצוא הזו זהה לאפשרות הקודמת, אבל היא כוללת קוד שיוצר ניתוח מסוג Lighthouse.

    מריצים את הסקריפט ובודקים את הפלט בקובץ flow.report.html:

    # npm i puppeteer lighthouse
    node your_export.js
    

    הדוח Lighthouse נפתח ב-Chrome.

ייצוא בפורמט מותאם אישית על ידי התקנת תוסף

ראו תוספים של מכשיר ההקלטה.

ייבוא תהליך של משתמש

כדי לייבא תהליך של משתמש:

  1. לוחצים על הלחצן ייבואהעלאת קובץ. בחלק העליון של החלונית מכשיר ההקלטה. ייבוא ההקלטה.
  2. בוחרים את קובץ ה-JSON עם תיעוד התהליך של המשתמש.
  3. לוחצים על הלחצן הפעלה מחדש.הפעלה מחדש כדי להפעיל את זרימת המשתמשים שיובאה.

הפעלה מחדש באמצעות ספריות חיצוניות

Puppeteer Replay הוא ספריית קוד פתוח שמנוהלת על ידי צוות כלי הפיתוח ל-Chrome. הוא בנוי על מעל הבובה. זהו כלי שורת פקודה, שמאפשר להפעיל מחדש קובצי JSON באמצעותו.

מלבד זאת, אפשר לבצע טרנספורמציה ולהפעיל מחדש קובצי JSON באמצעות הספריות הבאות של צדדים שלישיים.

שינוי תהליכים של משתמש ב-JSON לסקריפטים מותאמים אישית:

  • Cypress Chrome Recorder אפשר להשתמש בו כדי להמיר קובצי JSON של זרימת משתמשים לסקריפטים של בדיקה של Cypress. אפשר לצפות בהדגמה הזו כדי לראות אותה בפעולה.
  • מכשיר הקלטה של Chrome לשעון לילה אפשר להשתמש בו כדי להמיר קובצי JSON של זרימת משתמשים לסקריפטים לבדיקה של שעון הלילה.
  • CodeceptJS ל-Chrome Recorder. אפשר להשתמש בו כדי להמיר קובצי JSON של זרימת משתמשים לסקריפטים לבדיקה של CodeceptJS.

הפעלה מחדש של זרימות משתמש ב-JSON:

ניפוי באגים בתהליכים של משתמשים

כמו כל קוד, לפעמים צריך לנפות באגים בתהליכים הרשומים של המשתמש.

כדי לעזור לכם לנפות באגים, החלונית Recorder מאפשרת להאט את ההפעלות החוזרות, להגדיר נקודות עצירה, לבצע את כל השלבים ולבדוק את הקוד בפורמטים שונים במקביל לשלבים.

האטת ההפעלה החוזרת

כברירת מחדל, מכשיר ההקלטה מפעיל מחדש את זרימת המשתמש במהירות האפשרית. כדי להבין מה קורה בהקלטה, אפשר להאט את מהירות ההקלטה:

  1. פותחים את התפריט הנפתח הפעלה מחדש.הפעלה מחדש.
  2. בוחרים באחת מהאפשרויות של מהירות ההפעלה מחדש:
    • רגילה (ברירת מחדל)
    • מהירות נמוכה
    • איטי מאוד
    • איטית מאוד

הפעלה מחדש איטית.

בדיקת הקוד

כדי לבדוק את הקוד של זרימת משתמש בפורמטים שונים:

  1. פותחים הקלטה בחלונית מכשיר ההקלטה.
  2. לוחצים על הצגת הקוד בפינה השמאלית העליונה של רשימת השלבים. הלחצן 'הצגת הקוד'.
  3. במכשיר ההקלטה מוצגות השלבים והקוד שלהם זה לצד זה. תצוגה זה לצד זה של השלבים והקוד שלהם.
  4. כשמעבירים את העכבר מעל שלב כלשהו, מכשיר ההקלטה מדגיש את הקוד המתאים בכל פורמט, כולל אלה שמסופקים על ידי תוספים.
  5. מרחיבים את הרשימה הנפתחת של הפורמטים כדי לבחור את הפורמט שבו רוצים לייצא תהליכים של משתמשים.

    הרשימה הנפתחת של הפורמטים.

    הוא יכול להיות אחד משלושת הפורמטים שמוגדרים כברירת מחדל (JSON, @puppeteer/replay, Puppeteer script) או פורמט שסופק על-ידי תוסף.

  6. כדי לנפות באגים בהקלטה, עורכים את הפרמטרים והערכים של השלב. לא ניתן לערוך את תצוגת הקוד, אבל היא מתעדכנת בהתאם כשמבצעים שינויים בשלבים שמימין.

הגדרת נקודות עצירה וביצוע שלב אחרי שלב

כדי להגדיר נקודת עצירה ולהפעיל שלב אחרי שלב:

  1. מעבירים את העכבר מעל העיגול שלב. לצד שלב כלשהו בהקלטה. העיגול הופך לסמל של נקודת עצירה (breakpoint) נקודת עצירה..
  2. לוחצים על סמל נקודת העצירה נקודת עצירה. ומפעילים מחדש את ההקלטה. ההפעלות מושהה בנקודת העצירה (breakpoint). השהיית הביצוע.
  3. כדי לעבור את שלב הביצוע, לוחצים על הלחצן מבצעים שלב אחד. ביצוע שלב אחד בסרגל הפעולות שבחלק העליון של החלונית מכשיר ההקלטה.
  4. כדי להפסיק את השידור החוזר, לוחצים על עצרו. ביטול ההקלטה.

עריכת השלבים

כדי לערוך כל שלב בהקלטה, לוחצים על הלחצן הרחבה. שלצידו, גם במהלך ההקלטה וגם לאחר מכן.

אפשר גם להוסיף שלבים חסרים ולהסיר שלבים שנרשמו בטעות.

הוספת שלבים

לפעמים צריך להוסיף שלבים באופן ידני. לדוגמה, מכשיר ההקלטה לא מתעד באופן אוטומטי אירועי hover כי הפעולה הזו מזהמת את ההקלטה ולא כל האירועים מהסוג הזה שימושיים. עם זאת, רכיבי ממשק המשתמש כמו תפריטים נפתחים יכולים להופיע רק ב-hover. אפשר להוסיף באופן ידני שלבים של hover לתהליכים של המשתמשים שתלויים ברכיבים האלה.

כדי להוסיף שלב באופן ידני:

  1. פותחים את דף ההדגמה ומתחילים הקלטה חדשה. מתחילים הקלטה כדי לתעד אירוע של העברת העכבר.
  2. מעבירים את העכבר מעל הרכיב באזור התצוגה. יופיע תפריט פעולות. מעבירים את העכבר מעל הרכיב.
  3. בוחרים פעולה מהתפריט ומסיימים את ההקלטה. מכשיר ההקלטה מתעד רק את האירוע מסוג קליק. לחיצה על פעולה וסיום ההקלטה.
  4. כדי להפעיל מחדש את ההקלטה, לוחצים על הפעלה מחדש. הפעלה חוזרת. ההפעלה החוזרת נכשלת אחרי שעבר הזמן הקצוב לתפוגה כי מכשיר ההקלטה לא יכול לגשת לרכיב שבתפריט. ההפעלה החוזרת נכשלה.
  5. לוחצים על לחצן שלוש הנקודות לחצן שלוש הנקודות. שלצד השלב לחיצה ובוחרים באפשרות הוספת שלב לפני. הוספת שלב לפני הקליק.
  6. מרחיבים את השלב החדש. כברירת מחדל הוא מסוג waitForElement. לוחצים על הערך שליד type ובוחרים באפשרות hover. מתבצעת בחירה של העברת העכבר.
  7. לאחר מכן, מגדירים בורר מתאים לשלב החדש. לוחצים על הסמל בחירה. בחירה, ואז לוחצים על אזור ברכיב Hover over me! שנמצא מחוץ לתפריט הקופץ. הבורר מוגדר ל#clickable. הגדרת הבורר.
  8. מנסים להשמיע מחדש את ההקלטה. לאחר השלב של העברת העכבר שנוסף, מכשיר ההקלטה מפעיל מחדש את התהליך. ההפעלה מחדש בוצעה בהצלחה.

הוספה של טענות נכוֹנוּת (assertions)

במהלך ההקלטה, אתם יכולים להצהיר בעלות, למשל על מאפייני HTML ומאפייני JavaScript. כדי להוסיף טענת נכוֹנוּת (assertion):

  1. מתחילים הקלטה, למשל, בדף ההדגמה הזה.
  2. לוחצים על Add assertion (הוספת טענת נכוֹנוּת) (assertion).

    הלחצן 'הוספה של טענת נכונות'.

    מכשיר ההקלטה יוצר שלב waitForElement שניתן להגדרה.

  3. מציינים בוררים לשלב הזה.

  4. מגדירים את השלב, אבל לא משנים את סוג ה-waitForElement שלו. לדוגמה, אפשר לציין:

    • מאפיין HTML. לוחצים על הוספת מאפיינים ומקלידים את השם והערך של המאפיין שבו משתמשים הרכיבים בדף הזה. לדוגמה, data-test: <value>.
    • נכס JavaScript. לוחצים על הוספת נכסים ומקלידים את השם והערך של הנכס בפורמט JSON. לדוגמה, {".innerText":"<text>"}.
    • מאפייני שלבים אחרים לדוגמה, visible: true.
  5. ממשיכים להקליט את המשך התהליך של המשתמש ומפסיקים את ההקלטה.

  6. לוחצים על הפעלה מחדש. הפעלה מחדש. אם טענת נכוֹנוּת (assertion) נכשלת, מכשיר ההקלטה יציג שגיאה לאחר זמן קצוב לתפוגה.

כדי לראות איך פועל תהליך העבודה הזה, צפו בסרטון הבא.

העתקת השלבים

במקום לייצא את כל תהליך המשתמש, אפשר להעתיק שלב אחד ללוח:

  1. לוחצים לחיצה ימנית על השלב שרוצים להעתיק או לוחצים על סמל שלוש הנקודות תפריט שלוש הנקודות שלצידו.
  2. בתפריט הנפתח, בוחרים באחת מהאפשרויות של העתקה בשם ....

בוחרים אפשרות העתקה מהתפריט הנפתח.

אפשר להעתיק את השלבים בפורמטים שונים: JSON, Puppeteer, @puppeteer/replay וכאלה שסופקו על ידי תוספים.

הסרת השלבים

כדי להסיר שלב שתועד בטעות, לוחצים לחיצה ימנית על השלב או לוחצים על סמל שלוש הנקודות תפריט שלוש הנקודות שלצידו ובוחרים באפשרות הסרת השלב.

מסירים שלב.

כמו כן, מכשיר ההקלטה מוסיף באופן אוטומטי שני שלבים נפרדים לתחילת כל הקלטה:

הקלטה עם אזור התצוגה ושלבי הניווט שהוגדרו.

  • הגדרת אזור התצוגה. מאפשר לך לשלוט במימדים של אזור התצוגה, בהתאמה לעומס (scaling) ובמאפיינים אחרים.
  • ניווט. מגדיר את כתובת ה-URL ומרענן את הדף באופן אוטומטי בכל הפעלה מחדש.

כדי לבצע אוטומציה בתוך הדף בלי לטעון מחדש את הדף, צריך להסיר את שלב הניווט כפי שמתואר למעלה.

הגדרת השלבים

כדי להגדיר שלב:

  1. מציין את הסוג שלו: click, doubleClick, hover, (קלט) change, keyUp, keyDown, scroll, close, navigate (לדף), waitForElement, waitForExpression או setViewport.

    מאפיינים אחרים תלויים בערך type.

  2. צריך לציין את המאפיינים הנדרשים מתחת ל-type.

    מגדירים שלב.

  3. לוחצים על הלחצנים המתאימים כדי להוסיף מאפיינים אופציונליים וספציפיים לסוג ולפרט אותם.

במאמר מאפייני שלבים יש רשימה של המאפיינים הזמינים.

כדי להסיר מאפיין אופציונלי, לוחצים על הלחצן הסרה. הסרה שלצידו.

כדי להוסיף רכיב לנכס או להסיר ממנו רכיב, לוחצים על הלחצנים + או - שליד הרכיב.

מאפייני שלב

כל שלב יכול לכלול את המאפיינים האופציונליים הבאים:

  • target – כתובת URL של היעד Chrome DevTools Protocol (CDP). מילת המפתח main שמוגדרת כברירת מחדל מתייחסת לדף הנוכחי.
  • assertedEvents יכול להיות כרגע רק אירוע אחד מסוג navigation

מאפיינים נפוצים אחרים שזמינים לרוב סוגי השלבים הם:

  • frame - מערך של אינדקסים מבוססי אפס שמזהים iframe שיכול להיות מקונן. לדוגמה, תוכלו לזהות את ה-iframe הראשון (0) בתוך iframe שני (1) של היעד הראשי בתור [1, 0].
  • timeout – מספר אלפיות השנייה שצריך להמתין לפני שמבצעים שלב. מידע נוסף זמין במאמר התאמת זמן קצוב לתפוגה של שלבים.
  • selectors – מערך של סלקטורים. מידע נוסף זמין במאמר הסבר על סלקטורים.

המאפיינים הספציפיים לסוג הם:

סוג נכס חובה תיאור
click
doubleClick
offsetX
offsetY
יש. ביחס לפינה השמאלית העליונה של תיבת תוכן הרכיב, בפיקסלים
click
doubleClick
button לחצן המצביע: ראשי | עזר | שני | חזרה | העברה
change value יש. הערך הסופי
keyDown
keyUp
key יש. שם מפתח
scroll x
y
מיקומים בגלילה מוחלטת בין x ו-y בפיקסלים, ברירת המחדל היא 0
navigate url יש. כתובת אתר של יעד
waitForElement operator >= | == (ברירת מחדל) | &lt;=
waitForElement count מספר הרכיבים שזוהו על ידי בורר
waitForElement attributes מאפיין HTML והערך שלו
waitForElement properties המאפיין של JavaScript והערך שלו ב-JSON
waitForElement visible בוליאני. הערך הוא True אם הרכיב נמצא ב-DOM וגלוי (אין לו display: none או visibility: hidden)
waitForElement
waitForExpression
asserted events כרגע רק type: navigation. אפשר לציין את הכותרת וכתובת ה-URL
waitForElement
waitForExpression
timeout זמן המתנה מקסימלי באלפיות שנייה
waitForExpression expression יש. ביטוי JavaScript שמפנה ל-True
setViewport width
height
יש. הרוחב והגובה של אזור התצוגה בפיקסלים
setViewport deviceScaleFactor יש. דומה ליחס הפיקסלים של המכשיר (DPR), ברירת המחדל 1
setViewport isMobile
hasTouch
isLandscape
יש. דגלים בוליאניים המציינים אם:
  • צריך להביא בחשבון את המטא תג
  • תמיכה באירועי מגע
  • תצוגה בפריסה לרוחב
  • יש שני מאפיינים שגורמים להשהיה של ההפעלה החוזרת:

    • המאפיין waitForElement גורם להמתנה לנוכחות (או להיעדר) של מספר רכיבים שזוהו על ידי בורר. לדוגמה, השלב הבא ממתין להופעת פחות משלושה רכיבים בדף שתואמים לבורר .my-class.

        "type": "waitForElement",
        "selectors": [".my-class"],
        "operator": "<=",
        "count": 2,
      
    • המאפיין waitForExpression גורם להמתנה של השלב עד שביטוי JavaScript יהפוך ל-True. לדוגמה, השלב הבא מושהה למשך שתי שניות ואז משתנה ל-True כדי לאפשר את המשך ההפעלה החוזרת.

        "type": "waitForExpression",
        "expression": "new Promise(resolve => setTimeout(() => resolve(true), 2000))",
      

    התאמת זמן קצוב לתפוגה לצעדים

    אם הדף מכיל בקשות רשת איטיות או אנימציות ארוכות, ההפעלה החוזרת עלולה להיכשל בשלבים שחורגים מהזמן הקצוב לתפוגה שהוגדר כברירת מחדל, שהוא 5000 אלפיות השנייה.

    כדי להימנע מבעיה זו, ניתן לשנות את ברירת המחדל של הזמן הקצוב לתפוגה לכל שלב בבת אחת או להגדיר זמנים קצובים לתפוגה בנפרד עבור שלבים ספציפיים. זמנים קצובים לתפוגה של שלבים ספציפיים יחליפו את ברירת המחדל.

    כדי לשנות את ברירת המחדל של הזמן הקצוב לתפוגה בכל שלב בבת אחת:

    1. לוחצים על הגדרות להפעלה חוזרת כדי לערוך את התיבה זמן קצוב לתפוגה.

      הגדרות להפעלה מחדש.

    2. בתיבה זמן קצוב לתפוגה, מגדירים את ערך הזמן הקצוב באלפיות השנייה.

    3. לוחצים על הפעלה מחדש.הפעלה מחדש כדי לראות בפעולה את ההגדרה החדשה של הזמן הקצוב לתפוגה שמוגדר כברירת מחדל.

    כדי לבטל את הזמן הקצוב לתפוגה שמוגדר כברירת מחדל בשלב מסוים:

    1. מרחיבים את השלב ולוחצים על הוספת זמן קצוב לתפוגה.

      הוספת זמן קצוב לתפוגה.
    2. לוחצים על timeout: <value> ומגדירים את הערך באלפיות השנייה.

      מגדירים את הערך של הזמן הקצוב לתפוגה.
    3. לוחצים על הפעלה מחדש.הפעלה מחדש כדי לראות את השלב שבו הזמן הקצוב לתפוגה פועל.

    כדי להסיר זמן קצוב להחלפה בשלב כלשהו, לוחצים על הלחצן מחיקהמחיקה. שלצידו.

    הסבר על הסלקטורים

    כשמתחילים הקלטה חדשה, אפשר להגדיר את הדברים הבאים:

    מתבצעת הגדרה של הקלטה חדשה.

    • בתיבת הטקסט מאפייני סלקטור, מזינים מאפיין בדיקה מותאם אישית. מכשיר ההקלטה ישתמש במאפיין הזה כדי לזהות סלקטורים, ולא ברשימה של מאפייני בדיקה נפוצים.
    • בקבוצה של תיבות הסימון סוגי סלקטורים להקלטה, בוחרים את סוגי הסלקטורים שיזוהו באופן אוטומטי:

      • תיבת סימון. שירות CSS. בוררים תחביריים.
      • תיבת סימון. ARIA. בוררים סמנטיים.
      • תיבת סימון. טקסט. סלקטורים עם הטקסט הייחודי הקצר ביותר, אם יש כאלה.
      • תיבת סימון. XPath. סלקטורים שמשתמשים בשפת נתיב XML.
      • תיבת סימון. Pierce סלקטורים שדומים לסלקטורים ב-CSS אבל יכולים לחדור ל-DOM של צללים.

    בוררי בדיקה נפוצים

    בדפי אינטרנט פשוטים, מאפייני id ומאפייני CSS class מספיקים כדי שמכשיר ההקלטה יוכל לזהות את הסלקטורים. עם זאת, ייתכן שלא תמיד יהיה זה המצב, מהסיבות הבאות:

    • דפי האינטרנט עשויים להשתמש במחלקות או מזהים דינמיים שמשתנים.
    • יכול להיות שהסלקטורים לא תקינים בגלל שינויים בקוד או במסגרת.

    לדוגמה, יכול להיות שערכי class של CSS ייווצרו באופן אוטומטי לאפליקציות שפותחו עם מסגרות JavaScript מודרניות (לדוגמה, React, Angular, Vue) ו-frameworks של CSS.

    מחלקות CSS שנוצרות באופן אוטומטי עם שמות אקראיים.

    במקרים כאלה, אפשר להשתמש במאפייני data-* כדי ליצור בדיקות עמידות יותר. כבר יש כמה סלקטורים נפוצים של data-* שמפתחים משתמשים בהם לצורך אוטומציה. גם מכשיר ההקלטה תומך בהם.

    אם הגדרתם באתר שלכם את בוררי הבדיקות הנפוצים הבאים, מכשיר ההקלטה מזהה אותם באופן אוטומטי ומשתמש בהם קודם לכן:

    • data-testid
    • data-test
    • data-qa
    • data-cy
    • data-test-id
    • data-qa-id
    • data-testing

    לדוגמה, בידקו את הקפוצ'ינו בדף ההדגמה הזה ולראות את מאפייני הבדיקה:

    בוררי בדיקה מוגדרים.

    מקליטים קליק על קפוצ'ינו, מרחיבים את השלב המתאים בהקלטה ובודקים את הבוררים שזוהו:

    זוהה בורר בדיקות נפוץ.

    התאמה אישית של בורר ההקלטה

    אם הבוררים הנפוצים לבדיקה לא פועלים, אפשר להתאים אישית את הבורר של ההקלטה.

    לדוגמה, בדף ההדגמה הזה נעשה שימוש במאפיין data-automate בתור הבורר. מתחילים הקלטה חדשה ומזינים את הערך data-automate בתור מאפיין הבורר.

    אפשר להתאים אישית את הבורר של ההקלטה.

    מזינים כתובת אימייל ובודקים את ערך הבורר ([data-automate=email-address]).

    התוצאה של בחירת בורר בהתאמה אישית.

    עדיפות הבורר

    הכלי מכשיר ההקלטה מחפש סלקטורים בסדר הבא, בהתאם למה שציינתם מאפיין סלקטור ב-CSS בהתאמה אישית:

    • אם צוין:
      1. סלקטור ב-CSS עם מאפיין ה-CSS המותאם אישית שלכם.
      2. סלקטורים של XPath.
      3. בורר ARIA אם נמצא.
      4. בורר עם הטקסט הייחודי הקצר ביותר, אם נמצא.
    • אם לא צוין:
      1. בורר ARIA אם נמצא.
      2. סלקטורים ב-CSS עם העדיפות הבאה:
        1. המאפיינים הנפוצים ביותר של הבדיקה:
          • data-testid
          • data-test
          • data-qa
          • data-cy
          • data-test-id
          • data-qa-id
          • data-testing
        2. מאפייני מזהה, למשל <div id="some_ID">.
        3. סלקטורים רגילים ב-CSS.
      3. סלקטורים של XPath.
      4. סלקטורים.
      5. בורר עם הטקסט הייחודי הקצר ביותר, אם נמצא.

    יכולים להיות כמה סלקטורים רגילים של CSS, XPath ו-Perce. מכשיר ההקלטה מתעד:

    • סלקטורים רגילים ב-CSS ו-XPath בכל רמת בסיס, כלומר מארחי צללים מקוננים, אם יש כאלה.
    • סלקטורים ייחודיים בין כל הרכיבים בתוך כל שורשי הצל.