shiplightai 0.1.67 → 0.1.69
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/debugger-pw.cjs +1 -1
- package/dist/cjs/fixture.cjs +2 -2
- package/dist/cjs/index.cjs +3 -3
- package/dist/cjs/reporter.cjs +49 -39
- package/dist/cli.js +106 -92
- package/dist/debugger-pw.js +1 -1
- package/dist/fixture.js +2 -2
- package/dist/index.js +3 -3
- package/dist/reporter.js +49 -39
- package/dist/static-embedded/assets/{index-BWxVoO39.js → index-Bosp2pQJ.js} +501 -58
- package/dist/static-embedded/assets/{index-erD65tBc.js → index-Eah7879k.js} +2 -2
- package/dist/static-embedded/assets/{index-B7_79VfZ.css → index-uF1WN2rG.css} +18 -4
- package/dist/static-embedded/index.html +2 -2
- package/package.json +4 -4
package/dist/cjs/fixture.cjs
CHANGED
|
@@ -4544,6 +4544,6 @@ await page.waitForTimeout(2000);
|
|
|
4544
4544
|
`;let n=t.trim().split(`
|
|
4545
4545
|
`);for(let o of n)e+=` // ${o}
|
|
4546
4546
|
`;return e}generatePostlude(){return""}}});function xd(e){if(!e)return"desktop";for(let t of Xp)if(t.test(e))return"mobile";return"desktop"}var Xp,vd=y(()=>{"use strict";Xp=[/iphone/i,/ipad/i,/android/i,/pixel/i,/galaxy/i,/mobile/i,/nexus/i,/blackberry/i,/kindle/i]});function _d(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let r=a.startsWith("$")?a.slice(1):a,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o}var kd=y(()=>{"use strict"});function Ja(e){let t=e.match(/\.getByRole\(['"]([^'"]+)['"]/);if(t&&t[1]){let p=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(p&&p[1]){let S=p[1].replace(/\\(.)/g,"$1");return`${t[1]} element with text "${S}"`}let f=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(f&&f[1]){let S=f[1].replace(/^\/|\/$/g,""),_=S.length>30?`${S.substring(0,27)}...`:S;return`${t[1]} element with text matching "${_}"`}return`${t[1]} element`}let i=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(i&&i[1]){let p=It(e),f=i[1].replace(/\\(.)/g,"$1");return`${p} with text "${f}"`}let n=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(n&&n[1])return`${It(e)} with text matching ${n[1]}`;let o=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(o&&o[1]){let p=It(e),f=o[1].replace(/\\(.)/g,"$1");return`${p} containing "${f}"`}let a=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(a&&a[1]){let p=It(e),f=a[1].replace(/\\(.)/g,"$1");return`${p} containing "${f}"`}let r=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(r&&r[1]){let p=It(e),f=r[1].replace(/\\(.)/g,"$1");return`${p} not containing "${f}"`}let s=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(s&&s[1]){let p=It(e),f=s[1].replace(/\\(.)/g,"$1");return`${p} not containing "${f}"`}let l=e.match(/name:\s*'((?:[^'\\]|\\.)*)'/);if(l&&l[1])return`"${l[1].replace(/\\(.)/g,"$1")}"`;let d=e.match(/name:\s*"((?:[^"\\]|\\.)*)"/);if(d&&d[1])return`"${d[1].replace(/\\(.)/g,"$1")}"`;let c=e.match(/getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(c&&c[1])return`"${c[1].replace(/\\(.)/g,"$1")}"`;let u=e.match(/getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(u&&u[1])return`"${u[1].replace(/\\(.)/g,"$1")}"`;let m=e.match(/getByPlaceholder\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(m&&m[1])return`input with placeholder "${m[1].replace(/\\(.)/g,"$1")}"`;let g=e.match(/getByPlaceholder\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(g&&g[1])return`input with placeholder "${g[1].replace(/\\(.)/g,"$1")}"`;let w=e.match(/getByLabel\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(w&&w[1])return`"${w[1].replace(/\\(.)/g,"$1")}"`;let v=e.match(/getByLabel\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(v&&v[1])return`"${v[1].replace(/\\(.)/g,"$1")}"`;let x=e.match(/getByRole\(['"]([^'"]+)['"]/);return x&&x[1]?`${x[1]} element`:e.length>50?`${e.substring(0,47)}...`:e}function qa(e,t){if(!e||!t)return null;let i=t.replace(/^ref=/,""),n=e.split(`
|
|
4547
|
-
`);for(let o of n){if(!o.includes(`[ref=${i}]`))continue;let s=o.replace(/\s+\[[^\]]+\](?:\s*\[[^\]]+\])*.*$/,"").trim().replace(/^[-–—]\s*/,"").trim().replace(/\\"/g,'"');return s.length>0?s:null}return null}function Za(e,t=""){let i=e.match(/page\d*\.(.+?)\.(click|fill|press|check|uncheck|hover|selectOption|dragTo|dblclick|screenshot|setInputFiles|locator|frameLocator)/);if(i&&i[1])return i[1].trim();let n=e.match(/page\d*\.locator\(([^)]+)\)/);if(n&&n[1])return`locator(${n[1]})`;let o=e.match(/page\d*\.frameLocator\(([^)]+)\)/);return o&&o[1]?`frameLocator(${o[1]})`:t}function It(e){let t=e.match(/^locator\(['"]([^'"]+)['"]\)/);if(t&&t[1]){let o=t[1],a=o.match(/^([a-zA-Z][\w-]*)/);return a?a[1]:o.length>20?`${o.substring(0,17)}...`:o}let i=e.match(/getByRole\(['"]([^'"]+)['"]/);if(i&&i[1])return i[1];let n=e.match(/getByTestId\(['"]([^'"]+)['"]/);return n&&n[1]?`element with testId "${n[1]}"`:"element"}function Ya(e){let t=e.match(/\.fill\(['"]([^'"]*)['"]\)/);if(t&&t[1]!==void 0)return t[1];let i=e.match(/\.press\(['"]([^'"]+)['"]\)/);if(i&&i[1])return i[1];let n=e.match(/\.selectOption\(['"]([^'"]+)['"]\)/);return n&&n[1]?n[1]:""}function Yp(e){let t=e.match(/button:\s*['"]([^'"]+)['"]/);return t?t[1]:void 0}function Jp(e){let t=e.match(/modifiers:\s*\[([^\]]+)\]/);if(t&&t[1])return t[1].split(",").map(i=>i.trim().replace(/['"]/g,""))}function Td(e,t){let i=e.name||"unknown",n=Za(t,e.selector||""),o=e.ariaSnapshot??e.arIAaSnapshot??"",a=e.ref,r=/getByTestId\s*\(/.test(n),l=(a&&o&&r?qa(o,a):null)??Ja(n),d,c,u={};switch(i){case"click":{let m=Yp(t),g=Jp(t);m==="right"?(d="right_click_on_element",c=`Right click on ${l}`):(d="click_element",c=`Click on ${l}`),u={index:0},m&&m!=="left"&&(u.button=m),g&&(u.modifiers=g);break}case"fill":{let m=e.text||e.value||Ya(t)||"";d="fill",c=m?`Fill ${l} with '${m}'`:`Fill ${l}`,u={value:m,index:0};break}case"press":{let m=e.key||Ya(t)||"";d="press",c=`Press '${m}' on ${l}`,u={keyComb:m,index:0};break}case"selectOption":{let m=e.options?.[0]||Ya(t)||"";d="select_dropdown_option",c=`Select '${m}' from ${l}`,u={text:m,index:0};break}case"check":d="click_element",c=`Check ${l}`,u={index:0};break;case"uncheck":d="click_element",c=`Uncheck ${l}`,u={index:0};break;case"setInputFiles":{let m=e.files||[];d="upload_file",c=m.length>0?`Upload file(s) to ${l}`:`Upload file to ${l}`,u={paths:m,index:0};break}case"navigate":case"goto":d="go_to_url",c=`Navigate to ${e.url||"URL"}`,u={url:e.url||"",new_tab:!1};break;case"dblclick":d="double_click_on_element",c=`Double click on ${l}`,u={index:0};break;case"hover":d="hover",c=`Hover over ${l}`,u={index:0};break;case"wheel":case"scroll":d="scroll",c=`Scroll on ${l}`,u={x:e.deltaX||0,y:e.deltaY||0,index:e.selector?0:-1};break;case"dragTo":d="drag_drop",c=`Drag ${l} to target`,u={index:0};break;case"screenshot":d="wait",c="Take screenshot",u={seconds:.5};break;case"wait":d="wait",c=`Wait for ${e.timeout||1e3}ms`,u={seconds:(e.timeout||1e3)/1e3};break;default:d="click_element",c=`${i} on ${l}`,u={index:0};break}return{locator:n,xpath:e.xpath||"",css_selector:e.css_selector||"",unique_selector:e.selector||e.css_selector||"",frame_path:e.frame_path||[],action_data:{action_name:d,args:[],kwargs:u},action_description:c,url:"",feedback:""}}var Sd,Ed,Ad=y(()=>{"use strict";Sd=require("uuid"),Ed=()=>(0,Sd.v4)()});var A,Qa,Ao,er,Qe,tr,ir,nr,ne,or,Bi,Mo,ar=y(()=>{"use strict";A=require("zod"),Qa=A.z.enum(["JS_CODE","AI_MODE"]),Ao=A.z.object({type:Qa,expression:A.z.string()}),er=A.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Qe=A.z.object({uid:A.z.string(),type:er,comment:A.z.string().optional()}),tr=A.z.object({action_data:A.z.object({action_name:A.z.string(),kwargs:A.z.record(A.z.any()).optional(),args:A.z.array(A.z.any()).optional()}),action_description:A.z.string().optional(),url:A.z.string().optional(),xpath:A.z.string().nullable().optional(),locator:A.z.string().nullable().optional(),css_selector:A.z.string().nullable().optional(),unique_selector:A.z.string().nullable().optional(),element_index:A.z.number().nullable().optional(),frame_path:A.z.array(A.z.any()).optional(),artifacts:A.z.record(A.z.any()).optional(),feedback:A.z.string().optional(),original_browser_use_action:A.z.any().optional()}).passthrough(),ir=Qe.extend({type:A.z.literal("DRAFT"),description:A.z.string()}),nr=Qe.extend({type:A.z.literal("ACTION"),description:A.z.string(),action_entity:tr.optional(),locator:A.z.string().optional(),use_pure_vision:A.z.boolean().optional()}),ne=A.z.lazy(()=>A.z.union([ir,nr,Qe.extend({type:A.z.literal("STEP"),description:A.z.string().optional().default(""),statements:A.z.array(ne),reference_id:A.z.number().optional(),template_path:A.z.string().optional(),template_params:A.z.record(A.z.string()).optional()}),Qe.extend({type:A.z.literal("IF_ELSE"),description:A.z.string().optional(),condition:Ao,then:A.z.array(ne),else:A.z.array(ne).optional()}),Qe.extend({type:A.z.literal("WHILE_LOOP"),description:A.z.string().optional(),condition:Ao,body:A.z.array(ne),timeout_ms:A.z.number().optional()})])),or=A.z.object({name:A.z.string(),statements:A.z.array(ne),teardown:A.z.array(ne).optional(),skip:A.z.union([A.z.boolean(),A.z.string()]).optional(),timeout:A.z.number().optional(),fail:A.z.union([A.z.boolean(),A.z.string()]).optional(),only:A.z.boolean().optional(),slow:A.z.boolean().optional()}),Bi=A.z.object({tests:A.z.array(or).min(1),beforeAll:A.z.array(ne).optional(),afterAll:A.z.array(ne).optional(),beforeEach:A.z.array(ne).optional(),afterEach:A.z.array(ne).optional()}),Mo=A.z.object({comment:A.z.string().optional(),version:A.z.string().optional(),goal:A.z.string().optional(),url:A.z.string().optional(),baseURL:A.z.string().optional(),final_feedback:A.z.string().optional(),completed:A.z.boolean().optional(),success:A.z.boolean().optional(),statements:A.z.array(ne).optional(),teardown:A.z.array(ne).optional(),last_modified_at:A.z.string().optional(),testGroup:Bi.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"})});function sr(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},goal:e.goal??"",url:e.url,base_url:e.baseURL,...t?.timeout!==void 0?{timeout:t.timeout}:{},...t?.settings&&Object.keys(t.settings).length>0?{settings:t.settings}:{},statements:(e.statements??[]).map(le)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(le)),i}function Pd(e,t){if(e.testGroup)return lr(e,t);let i=sr(e,t),n=new L.Document(i);return e.comment&&(n.commentBefore=e.comment),Md(n,e.statements??[]),e.teardown&&Md(n,e.teardown,"teardown"),n.toString(Pt)}function Md(e,t,i="statements"){let n=e.contents;if(!n||!(0,L.isMap)(n))return;let o=n.get(i,!0);(0,L.isSeq)(o)&&Ui(o,t)}function Ui(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],o=e.items[i];if(i>0&&(o.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:o.commentBefore=n.comment),(0,L.isMap)(o)){let a=o;if(n.type==="STEP"){let r=a.get("statements",!0);(0,L.isSeq)(r)&&Ui(r,n.statements)}else if(n.type==="IF_ELSE"){let r=a.get("THEN",!0);(0,L.isSeq)(r)&&Ui(r,n.then);let s=a.get("ELSE",!0);(0,L.isSeq)(s)&&n.else&&Ui(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=a.get("DO",!0);(0,L.isSeq)(r)&&Ui(r,n.body)}}}}function lr(e,t){let i=e.testGroup;if(!i)throw new Error("suiteToYaml requires a TestFlow with testGroup");let n={};t?.test_case_id!==void 0&&(n.test_case_id=t.test_case_id),t?.name&&(n.name=t.name),t?.tags&&t.tags.length>0&&(n.tags=t.tags),t?.use&&Object.keys(t.use).length>0&&(n.use=t.use),t?.settings&&Object.keys(t.settings).length>0&&(n.settings=t.settings);let o={};return e.baseURL&&(o.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(o.beforeAll=i.beforeAll.map(le)),i.beforeEach&&i.beforeEach.length>0&&(o.beforeEach=i.beforeEach.map(le)),i.afterEach&&i.afterEach.length>0&&(o.afterEach=i.afterEach.map(le)),i.afterAll&&i.afterAll.length>0&&(o.afterAll=i.afterAll.map(le)),o.tests=i.tests.map(a=>{let r={name:a.name};return a.skip!==void 0&&(r.skip=a.skip),a.timeout!==void 0&&(r.timeout=a.timeout),a.fail!==void 0&&(r.fail=a.fail),a.only!==void 0&&(r.only=a.only),a.slow!==void 0&&(r.slow=a.slow),r.statements=a.statements.map(le),a.teardown&&a.teardown.length>0&&(r.teardown=a.teardown.map(le)),r}),n.suite=o,(0,L.stringify)(n,Pt)}function $d(e){return e.map(t=>(0,L.stringify)(t,Pt)).join(`---
|
|
4548
|
-
`)}function le(e){switch(e.type){case"DRAFT":return qp(e);case"ACTION":return Ld(e);case"STEP":return Qp(e);case"IF_ELSE":return eg(e);case"WHILE_LOOP":return tg(e)}}function qp(e){return{intent:e.description}}function Ld(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,i=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let s=i?.statement;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"?{VERIFY:s,js:l}:{VERIFY:s}}}if(t==="go_to_url"){let s=i?.url;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:s};return i?.new_tab===!0&&(l.new_tab=!0),typeof i?.timeout_seconds=="number"&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="js_action"){let s=i?.code;if(typeof s=="string"&&e.description)return{description:e.description,js:s}}if(t==="ai_wait_until"){let s=i?.condition;if(typeof s=="string"){let l={WAIT_UNTIL:s};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let s=i?.seconds,d={WAIT:e.description||`Wait ${s}s`};return typeof s=="number"&&(d.seconds=s),d}if(t==="js_code"){let s=i?.code;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{description:e.description||"Code block",js:s}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let o={intent:e.description,action:n.action_name},a=e.locator??e.action_entity.locator;a&&(o.locator=a);let r=e.action_entity.xpath;if(r&&(o.xpath=r),e.use_pure_vision&&(o.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[s,l]of Object.entries(n.kwargs))o[s]=l;return n.args&&n.args.length>0&&(o.args=n.args),o}function Dd(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},o=Ld(n);if(typeof o=="object"&&o!==null){let a={...o};return delete a.intent,delete a.description,delete a.VERIFY,delete a.WAIT_UNTIL,delete a.WAIT,delete a.statement,Object.keys(a).length>0?(0,L.stringify)(a,Pt).trim():""}return(0,L.stringify)(o,Pt).trim()}function Od(e){let t=(0,L.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),u=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...u?{code:u}:{}}}}}}if("URL"in t){let c=String(t.URL),u={url:c};return t.new_tab===!0&&(u.new_tab=!0),typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:u}}}}if("CODE"in t){let c=String(t.CODE);return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:c}}}}}if("js"in t&&typeof t.js=="string"&&!("VERIFY"in t)&&!("action"in t)){let c=typeof t.description=="string"?t.description:typeof t.intent=="string"?t.intent:"";return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:t.js}}}}}if("WAIT_UNTIL"in t){let c=String(t.WAIT_UNTIL),u={condition:c};return typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:u}}}}if("WAIT"in t){let c=String(t.WAIT),u={};return typeof t.seconds=="number"&&(u.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:u}}}}let i=typeof t.intent=="string"?t.intent:void 0,n=typeof t.action=="string"?t.action:void 0,o=typeof t.locator=="string"?t.locator:void 0,a=typeof t.xpath=="string"?t.xpath:void 0,r=Array.isArray(t.frame_path)?t.frame_path:void 0,s=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,u]of Object.entries(t))Zp.has(c)||(l[c]=u);return n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...s&&s.length>0?{args:s}:{}},...o?{locator:o}:{},...a?{xpath:a}:{},...r?{frame_path:r}:{}},description:i,locator:o}:{description:i,actionEntity:{action_description:i||""}}}function Qp(e){if(e.template_path){let i={template:e.template_path};return e.template_params&&Object.keys(e.template_params).length>0&&(i.params=e.template_params),i}let t={STEP:e.description,statements:e.statements.map(le)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function eg(e){let t={IF:Nd(e.condition),THEN:e.then.map(le)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(le)),t}function tg(e){let t={WHILE:Nd(e.condition),DO:e.body.map(le)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function Nd(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function Rd(e){let t=(0,L.parseAllDocuments)(e),i;if(t.length>1||t.length===1&&!Array.isArray(t[0]?.toJSON()))i=t.map((n,o)=>n.errors.length>0?{__parseError:`Document ${o+1}: ${n.errors[0].message}`}:n.toJSON());else{let n;try{n=(0,L.parse)(e)}catch(o){throw new Error(`Invalid YAML: ${o instanceof Error?o.message:String(o)}`)}if(!Array.isArray(n))throw new Error("Expected a YAML array or multi-document YAML (separated by ---)");i=n}return i.map((n,o)=>{try{if(n&&typeof n=="object"&&"__parseError"in n)return{error:n.__parseError};if(!n||typeof n!="object")return{error:`Item ${o+1}: expected an object`};let a=n,r=typeof a.name=="string"&&a.name.trim()||void 0,s=typeof a.goal=="string"?a.goal.trim():"";if(!s)return{error:`Item ${o+1}: missing "goal" field`};if(Array.isArray(a.statements))try{let l=(0,L.stringify)(a,Pt),d=et(l);return{name:r,goal:d.goal??s,testFlow:d}}catch{}return{name:r,goal:s}}catch(a){return{error:`Item ${o+1}: ${a instanceof Error?a.message:String(a)}`}}})}function Fd(e){try{let t=(0,L.parse)(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),typeof t.timeout=="number"&&Number.isFinite(t.timeout)&&(i.timeout=t.timeout),t.settings&&typeof t.settings=="object"&&!Array.isArray(t.settings)&&(i.settings=t.settings),i}catch{return{}}}function rr(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(rr);let t=e,i=Object.keys(t);if(i.length===1){let o=i[0];if(o.startsWith("{ ")&&o.endsWith(" }")&&t[o]===null)return`{{${o.slice(2,-2)}}}`}let n={};for(let[o,a]of Object.entries(t))n[o]=rr(a);return n}function et(e){if(e.length>Id)throw new Error(`YAML input too large (${e.length} bytes, max ${Id})`);let t=rr((0,L.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return ig(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:ce(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=ce(t.teardown));let n=Mo.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let o=n.data;return cr(e,o),o}function ig(e){let t=e.suite;if(!t||typeof t!="object")throw new Error("Invalid suite: expected an object");let i=t.tests;if(!Array.isArray(i)||i.length===0)throw new Error('Suite must have a non-empty "tests" array');let o={tests:i.map(s=>{if(!s.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(s.statements)||s.statements.length===0)throw new Error(`Suite test "${s.name}" must have a non-empty "statements" array`);let l={name:s.name,statements:ce(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=ce(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(o.beforeAll=ce(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(o.afterAll=ce(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(o.beforeEach=ce(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(o.afterEach=ce(t.afterEach));let a=Bi.safeParse(o);if(!a.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(a.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:a.data}}function ce(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(ng)}function ng(e){if(typeof e=="string")throw new Error(`Plain string statements are not supported. Use an object with a "desc" key instead. Example: { "desc": "${e}" }`);if(typeof e!="object"||e===null)throw new Error(`Invalid statement: expected object, got ${typeof e}`);let t=e;if("IF"in t)return og(t);if("WHILE"in t)return ag(t);if("STEP"in t)return rg(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:(0,se.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,o=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,a={url:typeof i=="string"?i:String(i)};return n&&(a.new_tab=!0),o!==void 0&&(a.timeout_seconds=o),{uid:(0,se.v4)(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:a}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:(0,se.v4)(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,se.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');let n=typeof t.description=="string"?t.description:"Code block";return{uid:(0,se.v4)(),type:"ACTION",description:n,action_entity:{action_description:n,action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&!("VERIFY"in t)&&!("action"in t)){if("intent"in t||"desc"in t)throw new Error("A `js:` statement uses `description:`, not `intent:`. Raw JS does not self-heal \u2014 use `description: + js:` for code, or express it as a structured action (`intent:` + `action:`/`locator:`) to keep self-healing.");let i=typeof t.description=="string"&&t.description.trim()!==""?t.description:"Code block",n=t.js;return{uid:(0,se.v4)(),type:"ACTION",description:i,action_entity:{action_description:i,action_data:{action_name:"js_code",kwargs:{code:typeof n=="string"?n:String(n)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return Cd({...n,action:"function",functionName:i})}if("action"in t)return Cd(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:(0,se.v4)(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Hd(e){if(typeof e!="string")throw new Error(`Condition must be a string, got ${typeof e}`);return e.startsWith("js:")?{type:"JS_CODE",expression:e.slice(3)}:{type:"AI_MODE",expression:e}}function og(e){let t=Hd(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:(0,se.v4)(),type:"IF_ELSE",condition:t,then:ce(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=ce(e.ELSE)),n}function ag(e){let t=Hd(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:(0,se.v4)(),type:"WHILE_LOOP",condition:t,body:ce(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function rg(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:(0,se.v4)(),type:"STEP",description:t,statements:ce(e.statements)};if(typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),typeof e.template_path=="string"&&(i.template_path=e.template_path),e.template_params&&typeof e.template_params=="object"&&!Array.isArray(e.template_params)){let n=e.template_params,o={};for(let[a,r]of Object.entries(n))o[a]=String(r);i.template_params=o}return i}function Cd(e){let t=typeof e.action=="string"?e.action:String(e.action),i=typeof e.intent=="string"?e.intent:typeof e.desc=="string"?e.desc:"",n=typeof e.locator=="string"?e.locator:void 0,o=typeof e.xpath=="string"?e.xpath:void 0,a=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[d,c]of Object.entries(e))sg.has(d)||(r[d]=c);t==="verify"&&typeof r.js=="string"&&(r.code=r.js,delete r.js);let s={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(s.locator=n),o&&(s.xpath=o);let l={uid:(0,se.v4)(),type:"ACTION",description:i,action_entity:s};return a&&(l.use_pure_vision=!0),l}function cr(e,t){let i;try{i=(0,L.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,L.isMap)(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=n.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let o=n,a=o.get("statements",!0);(0,L.isSeq)(a)&&t.statements&&Ct(a,t.statements);let r=o.get("teardown",!0);(0,L.isSeq)(r)&&t.teardown&&Ct(r,t.teardown)}function Ct(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let o=t[i];if(o.type==="STEP"&&(0,L.isMap)(n)){let a=n.get("statements",!0);(0,L.isSeq)(a)&&Ct(a,o.statements)}else if(o.type==="IF_ELSE"&&(0,L.isMap)(n)){let a=n.get("THEN",!0);(0,L.isSeq)(a)&&Ct(a,o.then);let r=n.get("ELSE",!0);(0,L.isSeq)(r)&&o.else&&Ct(r,o.else)}else if(o.type==="WHILE_LOOP"&&(0,L.isMap)(n)){let a=n.get("DO",!0);(0,L.isSeq)(a)&&Ct(a,o.body)}}}var L,se,Pt,Zp,Id,sg,Io=y(()=>{"use strict";ar();L=require("yaml"),se=require("uuid");Pt={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};Zp=new Set(["intent","description","action","locator","xpath","frame_path","args","js"]);Id=1024*1024;sg=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});function dr(e,t){let i=[];t.version!=="1.0"&&i.push(`Unsupported patch version: ${t.version}`),(!Array.isArray(t.operations)||t.operations.length===0)&&i.push("Patch must have at least one operation");for(let n=0;n<t.operations.length;n++){let o=t.operations[n],a=`operations[${n}]`;switch(o.reason||i.push(`${a}: missing reason`),o.op){case"remove":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`);break}case"modify":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}case"insert":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),o.position!=="before"&&o.position!=="after"&&i.push(`${a}: position must be 'before' or 'after'`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}default:i.push(`${a}: unknown operation type "${o.op}"`)}}return{valid:i.length===0,errors:i}}function ur(e,t){let i=dr(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],o=t.operations.map((s,l)=>({...s,originalOrder:l})),a={remove:0,modify:1,insert:2},r=[...o].sort((s,l)=>s.index!==l.index?l.index-s.index:a[s.op]-a[l.op]);for(let s of r)switch(s.op){case"remove":n.splice(s.index,1);break;case"modify":n[s.index]=s.statement;break;case"insert":s.position==="before"?n.splice(s.index,0,s.statement):n.splice(s.index+1,0,s.statement);break}return n}function Wd(e,t){let i=(0,Co.parse)(e);if(!i||typeof i!="object")throw new Error("Invalid YAML: expected an object at root level");let n=i.statements;if(!Array.isArray(n))throw new Error('YAML must have a "statements" array');let o=ur(n,t);i.statements=o;let a=(0,Co.stringify)(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return et(a),{modifiedYaml:a,modifiedStatements:o}}var Co,Bd=y(()=>{"use strict";Io();Co=require("yaml")});function hr(e){for(let t of e){if(t.type==="STEP"){let n=t;if(n.reference_id||n.template_path)return!0}let i=Ce(t);for(let n of i)if(hr(n.statements))return!0}return!1}function Kd(e){let t=new Set;function i(n){for(let o of n){if(o.type==="STEP"){let r=o;r.reference_id&&t.add(r.reference_id)}let a=Ce(o);for(let r of a)i(r.statements)}}return i(e),Array.from(t)}function Vd(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return Be(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&Be(e.teardown,"teardown",t),t}function Re(e,t,i){let n=e+".",o=t.filter(([c])=>c===e||c.startsWith(n));if(o.length===0)return[];let a=[],r=new Set;for(let[c]of o){let u=c===e?"":c.slice(n.length);if(!u)continue;let m=u.split(".")[0];r.has(m)||r.add(m)}let s=Array.from(r);s.sort((c,u)=>{let m=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(u)?parseInt(u,10):-1;return m>=0&&g>=0?m-g:c==="then"&&u==="else"?-1:c==="else"&&u==="then"||c==="body"?1:u==="body"?-1:c.localeCompare(u)});function l(c){return i[c]}function d(c){let u=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(u?u[2].trim():c)||"true"}}for(let c of s){let u=e?`${e}.${c}`:c,m=l(u),g=m?.description??"",w=u;if(c==="then"){let _=`${e}.then`,k=`${e}.else`,E=Re(_,t,i),I=Re(k,t,i),C=l(e),$=C?d(C.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"IF_ELSE",condition:$,then:E,...I.length>0?{else:I}:{}});continue}if(c==="else")continue;if(c==="body"){let _=`${e}.body`,k=Re(_,t,i),E=l(e),I=E?d(E.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"WHILE_LOOP",condition:I,body:k});continue}let v=`${e}.${c}`,x=t.some(([_])=>_.startsWith(v+".then.")||_===v+".then"),p=t.some(([_])=>_.startsWith(v+".else.")||_===v+".else"),f=t.some(([_])=>_.startsWith(v+".body.")||_===v+".body"),S=t.filter(([_])=>{if(!_.startsWith(v+"."))return!1;let E=_.slice(v.length+1).split(".")[0];return/^\d+$/.test(E)&&E!=="then"&&E!=="else"&&E!=="body"});if(x||p){let _=v+".then",k=v+".else",E=Re(_,t,i),I=Re(k,t,i),C=m?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:u,type:"IF_ELSE",condition:C,then:E,...I.length>0?{else:I}:{}})}else if(f){let _=v+".body",k=Re(_,t,i),E=m?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:u,type:"WHILE_LOOP",condition:E,body:k})}else if(S.length>0){let _=Re(v,t,i);a.push({uid:u,type:"STEP",description:g||"Group",statements:_})}else a.push({uid:u,type:"ACTION",description:g||"Action",action_entity:m?.action_entity})}return a}function Xd(e){let t=Object.entries(e),i=n=>{let o=n+".";return t.some(([r])=>r===n||r.startsWith(o))?Re(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Ce,oe,Fe,He,We,Gi,Ud,Gd,lg,cg,jd,zd,Be,Po=y(()=>{"use strict";Ce=e=>{let t=[];switch(e.type){case"STEP":e.statements&&t.push({key:"statements",statements:e.statements});break;case"IF_ELSE":e.then&&t.push({key:"then",statements:e.then}),e.else&&t.push({key:"else",statements:e.else});break;case"WHILE_LOOP":e.body&&t.push({key:"body",statements:e.body});break}return t},oe=(e,t,i=void 0,n="root")=>{for(let o=0;o<e.length;o++){let a=e[o],r=a.uid;if(r===t)return{stableId:r,path:[o],statement:a,parent:i,containerKey:n,index:o};let s=Ce(a);for(let l of s){let d=oe(l.statements,t,a,l.key);if(d)return{...d,path:[o,l.key,...d.path]}}}return null},Fe=(e,t,i)=>{let n=oe(e,t);if(!n)return null;let{statement:o,parent:a,containerKey:r,index:s}=n,l=null;switch(o.type){case"DRAFT":case"ACTION":l=He(e,n)||We(e,n);break;case"STEP":if(o.statements&&o.statements.length>0)return o.statements[0];l=He(e,n)||We(e,n);break;case"IF_ELSE":if(i===!0&&o.then&&o.then.length>0)return o.then[0];if(i===!1&&o.else&&o.else.length>0)return o.else[0];l=He(e,n)||We(e,n);break;case"WHILE_LOOP":if(i===!0&&o.body&&o.body.length>0)return o.body[0];l=He(e,n)||We(e,n);break;default:l=He(e,n)||We(e,n);break}if(a&&a.type==="WHILE_LOOP"&&r==="body"){if(!l)return a;let d=oe(e,l.uid);if(!d||d.parent!==a)return a}return l},He=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Ce(t.parent).find(o=>o.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},We=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=oe(e,i);return n?He(e,n)||We(e,n):null},Gi=e=>{let t=[],i=n=>{for(let o of n){t.push(o);let a=Ce(o);for(let r of a)i(r.statements)}};return i(e),t},Ud=e=>{switch(e.type){case"DRAFT":case"ACTION":return!0;case"STEP":return!0;case"IF_ELSE":case"WHILE_LOOP":return!0;default:return!1}},Gd=(e,t,i)=>{if(!oe(e,t))return null;if(i===null){let s=[],l=t;for(;l!==null&&oe(e,l);)if(s.push(l),l=Fe(e,l)?.uid||null,s.length>1e3)return null;return s}if(!oe(e,i))return null;if(t===i)return[];let a=[],r=t;for(;r&&r!==i;){let s=oe(e,r);if(!s)break;if(a.push(r),s.statement.type==="IF_ELSE"){let l=lg(s.statement,i);l?r=Fe(e,r,l==="then")?.uid||null:r=Fe(e,r)?.uid||null}else s.statement.type==="WHILE_LOOP"?cg(s.statement,i)?r=Fe(e,r,!0)?.uid||null:r=Fe(e,r,!1)?.uid||null:r=Fe(e,r)?.uid||null;if(a.length>1e3)return null}return r===i?a:null},lg=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&oe(i.then,t)?"then":i.else&&oe(i.else,t)?"else":null},cg=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&oe(i.body,t))};jd=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),zd=e=>!["js_code","function","assert","ai_assert","verify","ai_extract","ai_wait_until","upload_file","login","extract_activation_code","extract_email_content","ai_step"].includes(e),Be=(e,t,i)=>{e.forEach((n,o)=>{let a=`${t}.${o}`;n.type==="DRAFT"?i[a]={description:n.description||"Draft",action_entity:void 0}:n.type==="ACTION"?i[a]={description:n.description||"Action",action_entity:n.action_entity,locator:n.locator}:n.type==="STEP"&&n.statements?Be(n.statements,a,i):n.type==="IF_ELSE"?(i[a]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&Be(n.then,`${a}.then`,i),n.else&&Be(n.else,`${a}.else`,i)):n.type==="WHILE_LOOP"&&(i[a]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&Be(n.body,`${a}.body`,i))})}});function pr(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let o=n.action_entity?.action_data?.action_name??"";mr.has(o)||t++}return{action:t,draft:i}}function ug(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function qd(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function hg(e){let t=e.split(/\r?\n/).map(a=>a.trim()).filter(a=>a.length>0&&!a.startsWith("//")),i=t.length,n=t.join(`
|
|
4547
|
+
`);for(let o of n){if(!o.includes(`[ref=${i}]`))continue;let s=o.replace(/\s+\[[^\]]+\](?:\s*\[[^\]]+\])*.*$/,"").trim().replace(/^[-–—]\s*/,"").trim().replace(/\\"/g,'"');return s.length>0?s:null}return null}function Za(e,t=""){let i=e.match(/page\d*\.(.+?)\.(click|fill|press|check|uncheck|hover|selectOption|dragTo|dblclick|screenshot|setInputFiles|locator|frameLocator)/);if(i&&i[1])return i[1].trim();let n=e.match(/page\d*\.locator\(([^)]+)\)/);if(n&&n[1])return`locator(${n[1]})`;let o=e.match(/page\d*\.frameLocator\(([^)]+)\)/);return o&&o[1]?`frameLocator(${o[1]})`:t}function It(e){let t=e.match(/^locator\(['"]([^'"]+)['"]\)/);if(t&&t[1]){let o=t[1],a=o.match(/^([a-zA-Z][\w-]*)/);return a?a[1]:o.length>20?`${o.substring(0,17)}...`:o}let i=e.match(/getByRole\(['"]([^'"]+)['"]/);if(i&&i[1])return i[1];let n=e.match(/getByTestId\(['"]([^'"]+)['"]/);return n&&n[1]?`element with testId "${n[1]}"`:"element"}function Ya(e){let t=e.match(/\.fill\(['"]([^'"]*)['"]\)/);if(t&&t[1]!==void 0)return t[1];let i=e.match(/\.press\(['"]([^'"]+)['"]\)/);if(i&&i[1])return i[1];let n=e.match(/\.selectOption\(['"]([^'"]+)['"]\)/);return n&&n[1]?n[1]:""}function Yp(e){let t=e.match(/button:\s*['"]([^'"]+)['"]/);return t?t[1]:void 0}function Jp(e){let t=e.match(/modifiers:\s*\[([^\]]+)\]/);if(t&&t[1])return t[1].split(",").map(i=>i.trim().replace(/['"]/g,""))}function Td(e,t){let i=e.name||"unknown",n=Za(t,e.selector||""),o=e.ariaSnapshot??e.arIAaSnapshot??"",a=e.ref,r=/getByTestId\s*\(/.test(n),l=(a&&o&&r?qa(o,a):null)??Ja(n),d,c,u={};switch(i){case"click":{let m=Yp(t),g=Jp(t);m==="right"?(d="right_click_on_element",c=`Right click on ${l}`):(d="click_element",c=`Click on ${l}`),u={index:0},m&&m!=="left"&&(u.button=m),g&&(u.modifiers=g);break}case"fill":{let m=e.text||e.value||Ya(t)||"";d="fill",c=m?`Fill ${l} with '${m}'`:`Fill ${l}`,u={value:m,index:0};break}case"press":{let m=e.key||Ya(t)||"";d="press",c=`Press '${m}' on ${l}`,u={keyComb:m,index:0};break}case"selectOption":{let m=e.options?.[0]||Ya(t)||"";d="select_dropdown_option",c=`Select '${m}' from ${l}`,u={text:m,index:0};break}case"check":d="click_element",c=`Check ${l}`,u={index:0};break;case"uncheck":d="click_element",c=`Uncheck ${l}`,u={index:0};break;case"setInputFiles":{let m=e.files||[];d="upload_file",c=m.length>0?`Upload file(s) to ${l}`:`Upload file to ${l}`,u={paths:m,index:0};break}case"navigate":case"goto":d="go_to_url",c=`Navigate to ${e.url||"URL"}`,u={url:e.url||"",new_tab:!1};break;case"dblclick":d="double_click_on_element",c=`Double click on ${l}`,u={index:0};break;case"hover":d="hover",c=`Hover over ${l}`,u={index:0};break;case"wheel":case"scroll":d="scroll",c=`Scroll on ${l}`,u={x:e.deltaX||0,y:e.deltaY||0,index:e.selector?0:-1};break;case"dragTo":d="drag_drop",c=`Drag ${l} to target`,u={index:0};break;case"screenshot":d="wait",c="Take screenshot",u={seconds:.5};break;case"wait":d="wait",c=`Wait for ${e.timeout||1e3}ms`,u={seconds:(e.timeout||1e3)/1e3};break;default:d="click_element",c=`${i} on ${l}`,u={index:0};break}return{locator:n,xpath:e.xpath||"",css_selector:e.css_selector||"",unique_selector:e.selector||e.css_selector||"",frame_path:e.frame_path||[],action_data:{action_name:d,args:[],kwargs:u},action_description:c,url:"",feedback:""}}var Sd,Ed,Ad=y(()=>{"use strict";Sd=require("uuid"),Ed=()=>(0,Sd.v4)()});var A,Qa,Ao,er,Qe,tr,ir,nr,ne,or,Bi,Mo,ar=y(()=>{"use strict";A=require("zod"),Qa=A.z.enum(["JS_CODE","AI_MODE"]),Ao=A.z.object({type:Qa,expression:A.z.string()}),er=A.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Qe=A.z.object({uid:A.z.string(),type:er,comment:A.z.string().optional()}),tr=A.z.object({action_data:A.z.object({action_name:A.z.string(),kwargs:A.z.record(A.z.any()).optional(),args:A.z.array(A.z.any()).optional()}),action_description:A.z.string().optional(),url:A.z.string().optional(),xpath:A.z.string().nullable().optional(),locator:A.z.string().nullable().optional(),css_selector:A.z.string().nullable().optional(),unique_selector:A.z.string().nullable().optional(),element_index:A.z.number().nullable().optional(),frame_path:A.z.array(A.z.any()).optional(),artifacts:A.z.record(A.z.any()).optional(),feedback:A.z.string().optional(),original_browser_use_action:A.z.any().optional()}).passthrough(),ir=Qe.extend({type:A.z.literal("DRAFT"),description:A.z.string()}),nr=Qe.extend({type:A.z.literal("ACTION"),description:A.z.string(),action_entity:tr.optional(),locator:A.z.string().optional(),use_pure_vision:A.z.boolean().optional()}),ne=A.z.lazy(()=>A.z.union([ir,nr,Qe.extend({type:A.z.literal("STEP"),description:A.z.string().optional().default(""),statements:A.z.array(ne),reference_id:A.z.number().optional(),template_path:A.z.string().optional(),template_params:A.z.record(A.z.string()).optional()}),Qe.extend({type:A.z.literal("IF_ELSE"),description:A.z.string().optional(),condition:Ao,then:A.z.array(ne),else:A.z.array(ne).optional()}),Qe.extend({type:A.z.literal("WHILE_LOOP"),description:A.z.string().optional(),condition:Ao,body:A.z.array(ne),timeout_ms:A.z.number().optional()})])),or=A.z.object({name:A.z.string(),statements:A.z.array(ne),teardown:A.z.array(ne).optional(),skip:A.z.union([A.z.boolean(),A.z.string()]).optional(),timeout:A.z.number().optional(),fail:A.z.union([A.z.boolean(),A.z.string()]).optional(),only:A.z.boolean().optional(),slow:A.z.boolean().optional()}),Bi=A.z.object({tests:A.z.array(or).min(1),beforeAll:A.z.array(ne).optional(),afterAll:A.z.array(ne).optional(),beforeEach:A.z.array(ne).optional(),afterEach:A.z.array(ne).optional()}),Mo=A.z.object({comment:A.z.string().optional(),version:A.z.string().optional(),goal:A.z.string().optional(),url:A.z.string().optional(),baseURL:A.z.string().optional(),final_feedback:A.z.string().optional(),completed:A.z.boolean().optional(),success:A.z.boolean().optional(),statements:A.z.array(ne).optional(),teardown:A.z.array(ne).optional(),last_modified_at:A.z.string().optional(),testGroup:Bi.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"})});function sr(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},...t?.tags&&t.tags.length>0?{tags:t.tags}:{},...t?.skip!==void 0?{skip:t.skip}:{},...t?.fail!==void 0?{fail:t.fail}:{},...t?.only?{only:t.only}:{},...t?.slow?{slow:t.slow}:{},goal:e.goal??"",url:e.url,base_url:e.baseURL,...t?.timeout!==void 0?{timeout:t.timeout}:{},...t?.settings&&Object.keys(t.settings).length>0?{settings:t.settings}:{},...t?.use&&Object.keys(t.use).length>0?{use:t.use}:{},...t?.beforeEach&&t.beforeEach.length>0?{beforeEach:t.beforeEach}:{},...t?.afterEach&&t.afterEach.length>0?{afterEach:t.afterEach}:{},...t?.parameters&&t.parameters.length>0?{parameters:t.parameters}:{},statements:(e.statements??[]).map(le)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(le)),i}function Pd(e,t){if(e.testGroup)return lr(e,t);let i=sr(e,t),n=new L.Document(i);return e.comment&&(n.commentBefore=e.comment),Md(n,e.statements??[]),e.teardown&&Md(n,e.teardown,"teardown"),n.toString(Pt)}function Md(e,t,i="statements"){let n=e.contents;if(!n||!(0,L.isMap)(n))return;let o=n.get(i,!0);(0,L.isSeq)(o)&&Ui(o,t)}function Ui(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],o=e.items[i];if(i>0&&(o.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:o.commentBefore=n.comment),(0,L.isMap)(o)){let a=o;if(n.type==="STEP"){let r=a.get("statements",!0);(0,L.isSeq)(r)&&Ui(r,n.statements)}else if(n.type==="IF_ELSE"){let r=a.get("THEN",!0);(0,L.isSeq)(r)&&Ui(r,n.then);let s=a.get("ELSE",!0);(0,L.isSeq)(s)&&n.else&&Ui(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=a.get("DO",!0);(0,L.isSeq)(r)&&Ui(r,n.body)}}}}function lr(e,t){let i=e.testGroup;if(!i)throw new Error("suiteToYaml requires a TestFlow with testGroup");let n={};t?.test_case_id!==void 0&&(n.test_case_id=t.test_case_id),t?.name&&(n.name=t.name),t?.tags&&t.tags.length>0&&(n.tags=t.tags),t?.use&&Object.keys(t.use).length>0&&(n.use=t.use),t?.settings&&Object.keys(t.settings).length>0&&(n.settings=t.settings);let o={};return e.baseURL&&(o.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(o.beforeAll=i.beforeAll.map(le)),i.beforeEach&&i.beforeEach.length>0&&(o.beforeEach=i.beforeEach.map(le)),i.afterEach&&i.afterEach.length>0&&(o.afterEach=i.afterEach.map(le)),i.afterAll&&i.afterAll.length>0&&(o.afterAll=i.afterAll.map(le)),o.tests=i.tests.map(a=>{let r={name:a.name};return a.skip!==void 0&&(r.skip=a.skip),a.timeout!==void 0&&(r.timeout=a.timeout),a.fail!==void 0&&(r.fail=a.fail),a.only!==void 0&&(r.only=a.only),a.slow!==void 0&&(r.slow=a.slow),r.statements=a.statements.map(le),a.teardown&&a.teardown.length>0&&(r.teardown=a.teardown.map(le)),r}),n.suite=o,(0,L.stringify)(n,Pt)}function $d(e){return e.map(t=>(0,L.stringify)(t,Pt)).join(`---
|
|
4548
|
+
`)}function le(e){switch(e.type){case"DRAFT":return qp(e);case"ACTION":return Ld(e);case"STEP":return Qp(e);case"IF_ELSE":return eg(e);case"WHILE_LOOP":return tg(e)}}function qp(e){return{intent:e.description}}function Ld(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,i=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let s=i?.statement;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"&&l.trim()?{VERIFY:s,js:l}:{VERIFY:s}}}if(t==="go_to_url"){let s=i?.url;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:s};return i?.new_tab===!0&&(l.new_tab=!0),typeof i?.timeout_seconds=="number"&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="js_action"){let s=i?.code;if(typeof s=="string"&&s.trim()&&e.description)return{description:e.description,js:s}}if(t==="ai_wait_until"){let s=i?.condition;if(typeof s=="string"){let l={WAIT_UNTIL:s};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let s=i?.seconds,d={WAIT:e.description||`Wait ${s}s`};return typeof s=="number"&&(d.seconds=s),d}if(t==="js_code"){let s=i?.code;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{description:e.description||"Code block",js:s}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let o={intent:e.description,action:n.action_name},a=e.locator??e.action_entity.locator;a&&(o.locator=a);let r=e.action_entity.xpath;if(r&&(o.xpath=r),e.use_pure_vision&&(o.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[s,l]of Object.entries(n.kwargs))s!=="uid"&&(s==="statement"&&(t==="ai_action"||t==="ai_step")||(o[s]=l));return n.args&&n.args.length>0&&(o.args=n.args),o}function Dd(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},o=Ld(n);if(typeof o=="object"&&o!==null){let a={...o};return delete a.intent,delete a.description,delete a.VERIFY,delete a.WAIT_UNTIL,delete a.WAIT,delete a.statement,Object.keys(a).length>0?(0,L.stringify)(a,Pt).trim():""}return(0,L.stringify)(o,Pt).trim()}function Od(e){let t=(0,L.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),u=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...u?{code:u}:{}}}}}}if("URL"in t){let c=String(t.URL),u={url:c};return t.new_tab===!0&&(u.new_tab=!0),typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:u}}}}if("CODE"in t){let c=String(t.CODE);return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:c}}}}}if("js"in t&&typeof t.js=="string"&&!("VERIFY"in t)&&!("action"in t)){let c=typeof t.description=="string"?t.description:typeof t.intent=="string"?t.intent:"";return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:t.js}}}}}if("WAIT_UNTIL"in t){let c=String(t.WAIT_UNTIL),u={condition:c};return typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:u}}}}if("WAIT"in t){let c=String(t.WAIT),u={};return typeof t.seconds=="number"&&(u.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:u}}}}let i=typeof t.intent=="string"?t.intent:void 0,n=typeof t.action=="string"?t.action:void 0,o=typeof t.locator=="string"?t.locator:void 0,a=typeof t.xpath=="string"?t.xpath:void 0,r=Array.isArray(t.frame_path)?t.frame_path:void 0,s=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,u]of Object.entries(t))Zp.has(c)||(l[c]=u);return n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...s&&s.length>0?{args:s}:{}},...o?{locator:o}:{},...a?{xpath:a}:{},...r?{frame_path:r}:{}},description:i,locator:o}:{description:i,actionEntity:{action_description:i||""}}}function Qp(e){if(e.template_path){let i={template:e.template_path};return e.template_params&&Object.keys(e.template_params).length>0&&(i.params=e.template_params),i}let t={STEP:e.description,statements:e.statements.map(le)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function eg(e){let t={IF:Nd(e.condition),THEN:e.then.map(le)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(le)),t}function tg(e){let t={WHILE:Nd(e.condition),DO:e.body.map(le)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function Nd(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function Rd(e){let t=(0,L.parseAllDocuments)(e),i;if(t.length>1||t.length===1&&!Array.isArray(t[0]?.toJSON()))i=t.map((n,o)=>n.errors.length>0?{__parseError:`Document ${o+1}: ${n.errors[0].message}`}:n.toJSON());else{let n;try{n=(0,L.parse)(e)}catch(o){throw new Error(`Invalid YAML: ${o instanceof Error?o.message:String(o)}`)}if(!Array.isArray(n))throw new Error("Expected a YAML array or multi-document YAML (separated by ---)");i=n}return i.map((n,o)=>{try{if(n&&typeof n=="object"&&"__parseError"in n)return{error:n.__parseError};if(!n||typeof n!="object")return{error:`Item ${o+1}: expected an object`};let a=n,r=typeof a.name=="string"&&a.name.trim()||void 0,s=typeof a.goal=="string"?a.goal.trim():"";if(!s)return{error:`Item ${o+1}: missing "goal" field`};if(Array.isArray(a.statements))try{let l=(0,L.stringify)(a,Pt),d=et(l);return{name:r,goal:d.goal??s,testFlow:d}}catch{}return{name:r,goal:s}}catch(a){return{error:`Item ${o+1}: ${a instanceof Error?a.message:String(a)}`}}})}function Fd(e){try{let t=(0,L.parse)(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),typeof t.timeout=="number"&&Number.isFinite(t.timeout)&&(i.timeout=t.timeout),t.settings&&typeof t.settings=="object"&&!Array.isArray(t.settings)&&(i.settings=t.settings),t.use&&typeof t.use=="object"&&!Array.isArray(t.use)&&(i.use=t.use),Array.isArray(t.tags)&&t.tags.every(n=>typeof n=="string")&&(i.tags=t.tags),(typeof t.skip=="boolean"||typeof t.skip=="string")&&(i.skip=t.skip),(typeof t.fail=="boolean"||typeof t.fail=="string")&&(i.fail=t.fail),t.only===!0&&(i.only=!0),t.slow===!0&&(i.slow=!0),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(i.beforeEach=t.beforeEach),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(i.afterEach=t.afterEach),Array.isArray(t.parameters)&&t.parameters.length>0&&(i.parameters=t.parameters),i}catch{return{}}}function rr(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(rr);let t=e,i=Object.keys(t);if(i.length===1){let o=i[0];if(o.startsWith("{ ")&&o.endsWith(" }")&&t[o]===null)return`{{${o.slice(2,-2)}}}`}let n={};for(let[o,a]of Object.entries(t))n[o]=rr(a);return n}function et(e){if(e.length>Id)throw new Error(`YAML input too large (${e.length} bytes, max ${Id})`);let t=rr((0,L.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return ig(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:ce(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=ce(t.teardown));let n=Mo.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let o=n.data;return cr(e,o),o}function ig(e){let t=e.suite;if(!t||typeof t!="object")throw new Error("Invalid suite: expected an object");let i=t.tests;if(!Array.isArray(i)||i.length===0)throw new Error('Suite must have a non-empty "tests" array');let o={tests:i.map(s=>{if(!s.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(s.statements)||s.statements.length===0)throw new Error(`Suite test "${s.name}" must have a non-empty "statements" array`);let l={name:s.name,statements:ce(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=ce(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(o.beforeAll=ce(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(o.afterAll=ce(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(o.beforeEach=ce(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(o.afterEach=ce(t.afterEach));let a=Bi.safeParse(o);if(!a.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(a.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:a.data}}function ce(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(ng)}function ng(e){if(typeof e=="string")throw new Error(`Plain string statements are not supported. Use an object with a "desc" key instead. Example: { "desc": "${e}" }`);if(typeof e!="object"||e===null)throw new Error(`Invalid statement: expected object, got ${typeof e}`);let t=e;if("IF"in t)return og(t);if("WHILE"in t)return ag(t);if("STEP"in t)return rg(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:(0,se.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,o=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,a={url:typeof i=="string"?i:String(i)};return n&&(a.new_tab=!0),o!==void 0&&(a.timeout_seconds=o),{uid:(0,se.v4)(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:a}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:(0,se.v4)(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,se.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');let n=typeof t.description=="string"?t.description:"Code block";return{uid:(0,se.v4)(),type:"ACTION",description:n,action_entity:{action_description:n,action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&!("VERIFY"in t)&&!("action"in t)){if("intent"in t||"desc"in t)throw new Error("A `js:` statement uses `description:`, not `intent:`. Raw JS does not self-heal \u2014 use `description: + js:` for code, or express it as a structured action (`intent:` + `action:`/`locator:`) to keep self-healing.");let i=typeof t.description=="string"&&t.description.trim()!==""?t.description:"Code block",n=t.js;return{uid:(0,se.v4)(),type:"ACTION",description:i,action_entity:{action_description:i,action_data:{action_name:"js_code",kwargs:{code:typeof n=="string"?n:String(n)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return Cd({...n,action:"function",functionName:i})}if("action"in t)return Cd(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:(0,se.v4)(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Hd(e){if(typeof e!="string")throw new Error(`Condition must be a string, got ${typeof e}`);return e.startsWith("js:")?{type:"JS_CODE",expression:e.slice(3)}:{type:"AI_MODE",expression:e}}function og(e){let t=Hd(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:(0,se.v4)(),type:"IF_ELSE",condition:t,then:ce(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=ce(e.ELSE)),n}function ag(e){let t=Hd(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:(0,se.v4)(),type:"WHILE_LOOP",condition:t,body:ce(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function rg(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:(0,se.v4)(),type:"STEP",description:t,statements:ce(e.statements)};if(typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),typeof e.template_path=="string"&&(i.template_path=e.template_path),e.template_params&&typeof e.template_params=="object"&&!Array.isArray(e.template_params)){let n=e.template_params,o={};for(let[a,r]of Object.entries(n))o[a]=String(r);i.template_params=o}return i}function Cd(e){let t=typeof e.action=="string"?e.action:String(e.action),i=typeof e.intent=="string"?e.intent:typeof e.desc=="string"?e.desc:"",n=typeof e.locator=="string"?e.locator:void 0,o=typeof e.xpath=="string"?e.xpath:void 0,a=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[d,c]of Object.entries(e))sg.has(d)||(r[d]=c);t==="verify"&&typeof r.js=="string"&&(r.code=r.js,delete r.js),(t==="ai_action"||t==="ai_step")&&r.statement===void 0&&(r.statement=i);let s={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(s.locator=n),o&&(s.xpath=o);let l={uid:(0,se.v4)(),type:"ACTION",description:i,action_entity:s};return a&&(l.use_pure_vision=!0),l}function cr(e,t){let i;try{i=(0,L.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,L.isMap)(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=n.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let o=n,a=o.get("statements",!0);(0,L.isSeq)(a)&&t.statements&&Ct(a,t.statements);let r=o.get("teardown",!0);(0,L.isSeq)(r)&&t.teardown&&Ct(r,t.teardown)}function Ct(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let o=t[i];if(o.type==="STEP"&&(0,L.isMap)(n)){let a=n.get("statements",!0);(0,L.isSeq)(a)&&Ct(a,o.statements)}else if(o.type==="IF_ELSE"&&(0,L.isMap)(n)){let a=n.get("THEN",!0);(0,L.isSeq)(a)&&Ct(a,o.then);let r=n.get("ELSE",!0);(0,L.isSeq)(r)&&o.else&&Ct(r,o.else)}else if(o.type==="WHILE_LOOP"&&(0,L.isMap)(n)){let a=n.get("DO",!0);(0,L.isSeq)(a)&&Ct(a,o.body)}}}var L,se,Pt,Zp,Id,sg,Io=y(()=>{"use strict";ar();L=require("yaml"),se=require("uuid");Pt={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};Zp=new Set(["intent","description","action","locator","xpath","frame_path","args","js"]);Id=1024*1024;sg=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});function dr(e,t){let i=[];t.version!=="1.0"&&i.push(`Unsupported patch version: ${t.version}`),(!Array.isArray(t.operations)||t.operations.length===0)&&i.push("Patch must have at least one operation");for(let n=0;n<t.operations.length;n++){let o=t.operations[n],a=`operations[${n}]`;switch(o.reason||i.push(`${a}: missing reason`),o.op){case"remove":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`);break}case"modify":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}case"insert":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),o.position!=="before"&&o.position!=="after"&&i.push(`${a}: position must be 'before' or 'after'`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}default:i.push(`${a}: unknown operation type "${o.op}"`)}}return{valid:i.length===0,errors:i}}function ur(e,t){let i=dr(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],o=t.operations.map((s,l)=>({...s,originalOrder:l})),a={remove:0,modify:1,insert:2},r=[...o].sort((s,l)=>s.index!==l.index?l.index-s.index:a[s.op]-a[l.op]);for(let s of r)switch(s.op){case"remove":n.splice(s.index,1);break;case"modify":n[s.index]=s.statement;break;case"insert":s.position==="before"?n.splice(s.index,0,s.statement):n.splice(s.index+1,0,s.statement);break}return n}function Wd(e,t){let i=(0,Co.parse)(e);if(!i||typeof i!="object")throw new Error("Invalid YAML: expected an object at root level");let n=i.statements;if(!Array.isArray(n))throw new Error('YAML must have a "statements" array');let o=ur(n,t);i.statements=o;let a=(0,Co.stringify)(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return et(a),{modifiedYaml:a,modifiedStatements:o}}var Co,Bd=y(()=>{"use strict";Io();Co=require("yaml")});function hr(e){for(let t of e){if(t.type==="STEP"){let n=t;if(n.reference_id||n.template_path)return!0}let i=Ce(t);for(let n of i)if(hr(n.statements))return!0}return!1}function Kd(e){let t=new Set;function i(n){for(let o of n){if(o.type==="STEP"){let r=o;r.reference_id&&t.add(r.reference_id)}let a=Ce(o);for(let r of a)i(r.statements)}}return i(e),Array.from(t)}function Vd(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return Be(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&Be(e.teardown,"teardown",t),t}function Re(e,t,i){let n=e+".",o=t.filter(([c])=>c===e||c.startsWith(n));if(o.length===0)return[];let a=[],r=new Set;for(let[c]of o){let u=c===e?"":c.slice(n.length);if(!u)continue;let m=u.split(".")[0];r.has(m)||r.add(m)}let s=Array.from(r);s.sort((c,u)=>{let m=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(u)?parseInt(u,10):-1;return m>=0&&g>=0?m-g:c==="then"&&u==="else"?-1:c==="else"&&u==="then"||c==="body"?1:u==="body"?-1:c.localeCompare(u)});function l(c){return i[c]}function d(c){let u=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(u?u[2].trim():c)||"true"}}for(let c of s){let u=e?`${e}.${c}`:c,m=l(u),g=m?.description??"",w=u;if(c==="then"){let _=`${e}.then`,k=`${e}.else`,E=Re(_,t,i),I=Re(k,t,i),C=l(e),$=C?d(C.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"IF_ELSE",condition:$,then:E,...I.length>0?{else:I}:{}});continue}if(c==="else")continue;if(c==="body"){let _=`${e}.body`,k=Re(_,t,i),E=l(e),I=E?d(E.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"WHILE_LOOP",condition:I,body:k});continue}let v=`${e}.${c}`,x=t.some(([_])=>_.startsWith(v+".then.")||_===v+".then"),p=t.some(([_])=>_.startsWith(v+".else.")||_===v+".else"),f=t.some(([_])=>_.startsWith(v+".body.")||_===v+".body"),S=t.filter(([_])=>{if(!_.startsWith(v+"."))return!1;let E=_.slice(v.length+1).split(".")[0];return/^\d+$/.test(E)&&E!=="then"&&E!=="else"&&E!=="body"});if(x||p){let _=v+".then",k=v+".else",E=Re(_,t,i),I=Re(k,t,i),C=m?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:u,type:"IF_ELSE",condition:C,then:E,...I.length>0?{else:I}:{}})}else if(f){let _=v+".body",k=Re(_,t,i),E=m?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:u,type:"WHILE_LOOP",condition:E,body:k})}else if(S.length>0){let _=Re(v,t,i);a.push({uid:u,type:"STEP",description:g||"Group",statements:_})}else a.push({uid:u,type:"ACTION",description:g||"Action",action_entity:m?.action_entity})}return a}function Xd(e){let t=Object.entries(e),i=n=>{let o=n+".";return t.some(([r])=>r===n||r.startsWith(o))?Re(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Ce,oe,Fe,He,We,Gi,Ud,Gd,lg,cg,jd,zd,Be,Po=y(()=>{"use strict";Ce=e=>{let t=[];switch(e.type){case"STEP":e.statements&&t.push({key:"statements",statements:e.statements});break;case"IF_ELSE":e.then&&t.push({key:"then",statements:e.then}),e.else&&t.push({key:"else",statements:e.else});break;case"WHILE_LOOP":e.body&&t.push({key:"body",statements:e.body});break}return t},oe=(e,t,i=void 0,n="root")=>{for(let o=0;o<e.length;o++){let a=e[o],r=a.uid;if(r===t)return{stableId:r,path:[o],statement:a,parent:i,containerKey:n,index:o};let s=Ce(a);for(let l of s){let d=oe(l.statements,t,a,l.key);if(d)return{...d,path:[o,l.key,...d.path]}}}return null},Fe=(e,t,i)=>{let n=oe(e,t);if(!n)return null;let{statement:o,parent:a,containerKey:r,index:s}=n,l=null;switch(o.type){case"DRAFT":case"ACTION":l=He(e,n)||We(e,n);break;case"STEP":if(o.statements&&o.statements.length>0)return o.statements[0];l=He(e,n)||We(e,n);break;case"IF_ELSE":if(i===!0&&o.then&&o.then.length>0)return o.then[0];if(i===!1&&o.else&&o.else.length>0)return o.else[0];l=He(e,n)||We(e,n);break;case"WHILE_LOOP":if(i===!0&&o.body&&o.body.length>0)return o.body[0];l=He(e,n)||We(e,n);break;default:l=He(e,n)||We(e,n);break}if(a&&a.type==="WHILE_LOOP"&&r==="body"){if(!l)return a;let d=oe(e,l.uid);if(!d||d.parent!==a)return a}return l},He=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Ce(t.parent).find(o=>o.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},We=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=oe(e,i);return n?He(e,n)||We(e,n):null},Gi=e=>{let t=[],i=n=>{for(let o of n){t.push(o);let a=Ce(o);for(let r of a)i(r.statements)}};return i(e),t},Ud=e=>{switch(e.type){case"DRAFT":case"ACTION":return!0;case"STEP":return!0;case"IF_ELSE":case"WHILE_LOOP":return!0;default:return!1}},Gd=(e,t,i)=>{if(!oe(e,t))return null;if(i===null){let s=[],l=t;for(;l!==null&&oe(e,l);)if(s.push(l),l=Fe(e,l)?.uid||null,s.length>1e3)return null;return s}if(!oe(e,i))return null;if(t===i)return[];let a=[],r=t;for(;r&&r!==i;){let s=oe(e,r);if(!s)break;if(a.push(r),s.statement.type==="IF_ELSE"){let l=lg(s.statement,i);l?r=Fe(e,r,l==="then")?.uid||null:r=Fe(e,r)?.uid||null}else s.statement.type==="WHILE_LOOP"?cg(s.statement,i)?r=Fe(e,r,!0)?.uid||null:r=Fe(e,r,!1)?.uid||null:r=Fe(e,r)?.uid||null;if(a.length>1e3)return null}return r===i?a:null},lg=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&oe(i.then,t)?"then":i.else&&oe(i.else,t)?"else":null},cg=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&oe(i.body,t))};jd=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),zd=e=>!["js_code","function","assert","ai_assert","verify","ai_extract","ai_wait_until","upload_file","login","extract_activation_code","extract_email_content","ai_step"].includes(e),Be=(e,t,i)=>{e.forEach((n,o)=>{let a=`${t}.${o}`;n.type==="DRAFT"?i[a]={description:n.description||"Draft",action_entity:void 0}:n.type==="ACTION"?i[a]={description:n.description||"Action",action_entity:n.action_entity,locator:n.locator}:n.type==="STEP"&&n.statements?Be(n.statements,a,i):n.type==="IF_ELSE"?(i[a]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&Be(n.then,`${a}.then`,i),n.else&&Be(n.else,`${a}.else`,i)):n.type==="WHILE_LOOP"&&(i[a]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&Be(n.body,`${a}.body`,i))})}});function pr(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let o=n.action_entity?.action_data?.action_name??"";mr.has(o)||t++}return{action:t,draft:i}}function ug(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function qd(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function hg(e){let t=e.split(/\r?\n/).map(a=>a.trim()).filter(a=>a.length>0&&!a.startsWith("//")),i=t.length,n=t.join(`
|
|
4549
4549
|
`).match(/\bawait\b/g),o=n?n.length:0;return i<=Yd&&o<=Jd?null:`${i} non-blank line(s), ${o} await(s) \u2014 limits are ${Yd} lines and ${Jd} awaits. The VERIFY js: field is a cache for one natural-language assertion, not a place for multi-step logic. Break this into multiple statements \u2014 one VERIFY per assertion \u2014 so each step is visible in the debugger and self-healable. For freeform setup code (mocking, storage), use the description: + js: escape hatch, which has no complexity cap.`}function Zd(e,t){let i=t?.coverageThreshold??dg,n=[],o=[],a;try{a=et(e)}catch(m){return{valid:!1,errors:[`Invalid YAML: ${m.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}a.goal||n.push('Missing required field: "goal"'),a.statements?.length||n.push('Missing required field: "statements"');let r=[...Gi(a.statements??[]),...a.teardown?Gi(a.teardown):[]],{action:s,draft:l}=pr(r),d="Hint: in YAML double-quoted strings, backslashes are escape characters \u2014 use \\\\/ instead of \\/ for regex, or use single quotes.";for(let m of r){let g=m;if(g.reference_id!==void 0){let w=g.description||m.uid;n.push(`Unresolved cloud template reference on statement "${w}" (reference_id: ${g.reference_id}). Local YAML tests cannot use reference_id \u2014 inline the template statements or use the local "template:" key instead.`)}if(m.type==="ACTION"){let w=m,v=w.action_entity?.action_data?.action_name??"";if(v==="js_code"||v==="js_action"||v==="verify"||v==="ai_assert"){let x=w.action_entity?.action_data?.kwargs?.code;if(typeof x=="string"){let p=ug(x);if(p){let f=w.description||v;n.push(`Invalid JS in "${f}": ${p}. ${d}`)}else if(v==="verify"){let f=hg(x);if(f){let S=w.description||v;n.push(`JS cache for "${S}" is too complex: ${f}`)}}}}}if(m.type==="IF_ELSE"){let w=m;if(w.condition.type==="JS_CODE"){let v=qd(w.condition.expression);v&&n.push(`Invalid JS in IF condition "${w.condition.expression}": ${v}. ${d}`)}}if(m.type==="WHILE_LOOP"){let w=m;if(w.condition.type==="JS_CODE"){let v=qd(w.condition.expression);v&&n.push(`Invalid JS in WHILE condition "${w.condition.expression}": ${v}. ${d}`)}}}let c=s+l,u=c>0?Math.round(s/c*100):0;return c>0&&u/100<i&&o.push(`Low action coverage: ${s}/${c} statements (${u}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:n.length===0,errors:n,warnings:o,stats:{total:c,action:s,draft:l,coverage:u}}}var dg,Yd,Jd,mr,Qd=y(()=>{"use strict";Io();Po();dg=.5,Yd=5,Jd=3,mr=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"])});function eu(e){return e?e.startsWith(he)?"android":e.startsWith(me)?"ios":"web":"web"}function tu(e){return e?e.startsWith(he)||e.startsWith(me):!1}function iu(e){return!!e&&e.startsWith(he)}function nu(e){return!!e&&e.startsWith(me)}function ou(e){return e.startsWith(he)?e.slice(he.length):e.startsWith(me)?e.slice(me.length):e}function au(e){return`${he}${e}`}function ru(e){return`${me}${e}`}function $o(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function su(e){return e?!$o(e):!1}function gr(e){return e?$o(e)?["web"]:["android","ios"]:["web","android","ios"]}function lu(e,t){if(!t)return!0;let i=gr(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var he,me,Lo=y(()=>{"use strict";he="android:",me="ios:"});function cu(e){return e.startsWith(me)?e:`${me}${e}`}function du(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function uu(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var hu=y(()=>{"use strict";Lo()});var fr,Do,wr,br,yr,xr,vr,_r,kr,Sr,tt,Er,Ki,Tr,Ar,$t,mu,ji,pu,gu,Oo,fu,wu,bu,yu,xu=y(()=>{"use strict";fr="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",Do=112,wr=1920,br=1080,yr=1920,xr=1080-Do,vr=1280,_r=720,kr=500,Sr=500,tt="Desktop Chrome",Er=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Er||{}),Ki={"Blackberry PlayBook":{name:"Blackberry PlayBook",userAgent:"Mozilla/5.0 (PlayBook; U; RIM Tablet OS 2.1.0; en-US) AppleWebKit/536.2+ (KHTML like Gecko) Version/26.0 Safari/536.2+",screen:{width:600,height:1024},viewport:{width:600,height:1024},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"BlackBerry Z30":{name:"BlackBerry Z30",userAgent:"Mozilla/5.0 (BB10; Touch) AppleWebKit/537.10+ (KHTML, like Gecko) Version/26.0 Mobile Safari/537.10+",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note 3":{name:"Galaxy Note 3",userAgent:"Mozilla/5.0 (Linux; U; Android 4.3; en-us; SM-N900T Build/JSS15J) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note II":{name:"Galaxy Note II",userAgent:"Mozilla/5.0 (Linux; U; Android 4.1; en-us; GT-N7100 Build/JRO03C) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S III":{name:"Galaxy S III",userAgent:"Mozilla/5.0 (Linux; U; Android 4.0; en-us; GT-I9300 Build/IMM76D) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S5":{name:"Galaxy S5",userAgent:"Mozilla/5.0 (Linux; Android 5.0; SM-G900P Build/LRX21T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S8":{name:"Galaxy S8",userAgent:"Mozilla/5.0 (Linux; Android 7.0; SM-G950U Build/NRD90M) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:740},viewport:{width:360,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S9+":{name:"Galaxy S9+",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; SM-G965U Build/R16NW) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:320,height:658},viewport:{width:320,height:658},deviceScaleFactor:4.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S24":{name:"Galaxy S24",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-S921U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:780},viewport:{width:360,height:780},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy A55":{name:"Galaxy A55",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-A556B) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:480,height:1040},viewport:{width:480,height:1040},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S4":{name:"Galaxy Tab S4",userAgent:"Mozilla/5.0 (Linux; Android 8.1.0; SM-T837A) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:712,height:1138},viewport:{width:712,height:1138},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S9":{name:"Galaxy Tab S9",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-X710) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:640,height:1024},viewport:{width:640,height:1024},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"iPad (gen 5)":{name:"iPad (gen 5)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 6)":{name:"iPad (gen 6)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 7)":{name:"iPad (gen 7)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:810,height:1080},viewport:{width:810,height:1080},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 11)":{name:"iPad (gen 11)",userAgent:"Mozilla/5.0 (iPad; CPU OS 18_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/604.1",screen:{width:656,height:944},viewport:{width:656,height:944},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Mini":{name:"iPad Mini",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Pro 11":{name:"iPad Pro 11",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:834,height:1194},viewport:{width:834,height:1194},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6":{name:"iPhone 6",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6 Plus":{name:"iPhone 6 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7":{name:"iPhone 7",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7 Plus":{name:"iPhone 7 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8":{name:"iPhone 8",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8 Plus":{name:"iPhone 8 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE":{name:"iPhone SE",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_1 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/14E304 Safari/602.1",screen:{width:320,height:568},viewport:{width:320,height:568},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE (3rd gen)":{name:"iPhone SE (3rd gen)",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 18_5 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/602.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone X":{name:"iPhone X",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:812},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone XR":{name:"iPhone XR",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:896},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11":{name:"iPhone 11",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro":{name:"iPhone 11 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:635},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro Max":{name:"iPhone 11 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12":{name:"iPhone 12",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro":{name:"iPhone 12 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro Max":{name:"iPhone 12 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Mini":{name:"iPhone 12 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13":{name:"iPhone 13",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro":{name:"iPhone 13 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro Max":{name:"iPhone 13 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Mini":{name:"iPhone 13 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14":{name:"iPhone 14",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Plus":{name:"iPhone 14 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro":{name:"iPhone 14 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:660},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro Max":{name:"iPhone 14 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15":{name:"iPhone 15",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Plus":{name:"iPhone 15 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro":{name:"iPhone 15 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro Max":{name:"iPhone 15 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Kindle Fire HDX":{name:"Kindle Fire HDX",userAgent:"Mozilla/5.0 (Linux; U; en-us; KFAPWI Build/JDQ39) AppleWebKit/535.19 (KHTML, like Gecko) Silk/3.13 Safari/535.19 Silk-Accelerated=true",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"LG Optimus L70":{name:"LG Optimus L70",userAgent:"Mozilla/5.0 (Linux; U; Android 4.4.2; en-us; LGMS323 Build/KOT49I.MS32310c) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:1.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 550":{name:"Microsoft Lumia 550",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 550) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 950":{name:"Microsoft Lumia 950",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 950) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:4,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 10":{name:"Nexus 10",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 10 Build/MOB31T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 4":{name:"Nexus 4",userAgent:"Mozilla/5.0 (Linux; Android 4.4.2; Nexus 4 Build/KOT49H) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5":{name:"Nexus 5",userAgent:"Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5X":{name:"Nexus 5X",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 5X Build/OPR4.170623.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6":{name:"Nexus 6",userAgent:"Mozilla/5.0 (Linux; Android 7.1.1; Nexus 6 Build/N6F26U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6P":{name:"Nexus 6P",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 6P Build/OPP3.170518.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 7":{name:"Nexus 7",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 7 Build/MOB30X) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:600,height:960},viewport:{width:600,height:960},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia Lumia 520":{name:"Nokia Lumia 520",userAgent:"Mozilla/5.0 (compatible; MSIE 10.0; Windows Phone 8.0; Trident/6.0; IEMobile/10.0; ARM; Touch; NOKIA; Lumia 520)",screen:{width:320,height:533},viewport:{width:320,height:533},deviceScaleFactor:1.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia N9":{name:"Nokia N9",userAgent:"Mozilla/5.0 (MeeGo; NokiaN9) AppleWebKit/534.13 (KHTML, like Gecko) NokiaBrowser/8.5.0 Mobile Safari/534.13",screen:{width:480,height:854},viewport:{width:480,height:854},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Pixel 2":{name:"Pixel 2",userAgent:"Mozilla/5.0 (Linux; Android 8.0; Pixel 2 Build/OPD3.170816.012) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:731},viewport:{width:411,height:731},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 2 XL":{name:"Pixel 2 XL",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Pixel 2 XL Build/OPD1.170816.004) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:823},viewport:{width:411,height:823},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 3":{name:"Pixel 3",userAgent:"Mozilla/5.0 (Linux; Android 9; Pixel 3 Build/PQ1A.181105.017.A1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:786},viewport:{width:393,height:786},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4":{name:"Pixel 4",userAgent:"Mozilla/5.0 (Linux; Android 10; Pixel 4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:353,height:745},viewport:{width:353,height:745},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4a (5G)":{name:"Pixel 4a (5G)",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 4a (5G)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:892},viewport:{width:412,height:765},deviceScaleFactor:2.63,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 5":{name:"Pixel 5",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:851},viewport:{width:393,height:727},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 7":{name:"Pixel 7",userAgent:"Mozilla/5.0 (Linux; Android 14; Pixel 7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:915},viewport:{width:412,height:839},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Moto G4":{name:"Moto G4",userAgent:"Mozilla/5.0 (Linux; Android 7.0; Moto G (4)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Desktop Chrome HiDPI":{name:"Desktop Chrome HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge HiDPI":{name:"Desktop Edge HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Firefox HiDPI":{name:"Desktop Firefox HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"},"Desktop Safari":{name:"Desktop Safari",userAgent:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Safari/605.1.15",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"webkit"},"Desktop Chrome":{name:"Desktop Chrome",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome Medium Resolution":{name:"Desktop Chrome Medium Resolution",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome (Branded)":{name:"Desktop Chrome (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Chrome Medium Resolution (Branded)":{name:"Desktop Chrome Medium Resolution (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Edge":{name:"Desktop Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge (Branded)":{name:"Desktop Edge (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Edge Medium Resolution (Branded)":{name:"Desktop Edge Medium Resolution (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Firefox":{name:"Desktop Firefox",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"}},Tr=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Tr||{}),Ar={desktop:["Desktop Chrome","Desktop Chrome Medium Resolution","Desktop Chrome (Branded)","Desktop Chrome Medium Resolution (Branded)","Desktop Edge (Branded)","Desktop Edge Medium Resolution (Branded)","Desktop Safari"],mobile:["iPhone 15 Pro Max","iPhone 15 Pro","iPhone 15 Plus","iPhone 15","iPhone 14 Pro Max","iPhone 14 Pro","iPhone 14 Plus","iPhone 14","iPhone 13 Pro Max","iPhone 13 Pro","iPhone 13","iPhone 13 Mini","iPhone 12 Pro Max","iPhone 12 Pro","iPhone 12","iPhone 12 Mini","iPhone 11 Pro Max","iPhone 11 Pro","iPhone 11","iPhone XR","iPhone X","iPhone SE (3rd gen)","iPhone SE","iPhone 8 Plus","iPhone 8","iPhone 7 Plus","iPhone 7","iPhone 6 Plus","iPhone 6","Galaxy S24","Galaxy A55","Galaxy S9+","Galaxy S8","Galaxy S5","Galaxy Note 3","Galaxy Note II","Galaxy S III","Pixel 7","Pixel 5","Pixel 4a (5G)","Pixel 4","Pixel 3","Pixel 2 XL","Pixel 2","Nexus 6P","Nexus 6","Nexus 5X","Nexus 5","Nexus 4","Moto G4","LG Optimus L70","Microsoft Lumia 950","Microsoft Lumia 550","Nokia Lumia 520","Nokia N9","BlackBerry Z30"]},$t=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Ar[e].map(n=>Ki[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},mu=()=>Object.keys(Ki),ji=e=>Ki[e],pu={desktop:{label:"Desktop",type:"desktop",devices:$t("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:$t("mobile")}},gu={desktop:{label:"Desktop",type:"desktop",devices:$t("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:$t("mobile",!0)}},Oo=(e,t=!1)=>{let i={userAgent:fr,viewport:{width:yr,height:xr},isMobile:!1,hasTouch:!1};if(!e||e===tt)return i;let n=ji(e);if(!n)return i;let{width:o,height:a}=n.viewport,r=Math.max(kr/o,1),s=Math.max(Sr/a,1),l=Math.max(r,s),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},fu=e=>{let t={width:wr,height:br};if(!e||e===tt)return t;let i=Oo(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+Do}:t},wu=e=>{let t={width:vr,height:_r};if(!e||e===tt)return t;let i=Oo(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},bu=e=>!e||e===tt?void 0:ji(e)?.channel,yu=e=>!e||e===tt?"chromium":ji(e)?.defaultBrowserType??"chromium"});var Mr,Ir,vu=y(()=>{"use strict";Mr=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Mr||{}),Ir=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Ir||{})});function _u(){return{version:"1.0",entries:{}}}function ku(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function Su(e,t){let i=t?.entries[e.uid],n=i?.action_entity??e.action_entity;return e.locator&&n?{...n,locator:e.locator}:i?i.action_entity:e.action_entity?e.action_entity:null}function Eu(e,t,i,n){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:n},e}function Tu(e,t){let i=e??{version:"1.0",entries:{}};for(let[n,o]of t)i.entries[n]=o;return i}function Au(e){return e?Object.keys(e.entries).length===0:!0}function Mu(e){return e?Object.keys(e.entries).length:0}function Iu(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=Cr(e.statements??[],t),n=e.teardown?Cr(e.teardown,t):void 0;return{...e,statements:i,teardown:n}}function Cr(e,t){return e.map(i=>mg(i,t))}function mg(e,t){if(e.type==="ACTION"){let o=e,a=t.entries[o.uid];return a?{...o,action_entity:a.action_entity}:o}let i=Ce(e);if(i.length===0)return e;let n={};for(let o of i)n[o.key]=Cr(o.statements,t);return{...e,...n}}var Cu=y(()=>{"use strict";Po()});var Pr,$r,Pu,$u=y(()=>{"use strict";Pr=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(Pr||{}),$r=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))($r||{}),Pu=18e4});var Lu,Ou=y(()=>{"use strict";Lu=class Du{data={};sensitive=new Set;get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new Du;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}}});function Nu(e,t=pg()){return{copilot:e?.models?.copilot||t.COPILOT_MODEL||Fo,webagent:e?.models?.webagent||t.WEB_AGENT_MODEL||Nr,computer_use:e?.models?.computer_use||t.COMPUTER_USE_MODEL||Rr}}function Ru(e){if(e){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.GOOGLE_API_KEY)return No;if(e.ANTHROPIC_API_KEY)return Lr;if(e.OPENAI_API_KEY)return Dr;if(e.SHIPLIGHT_API_TOKEN)return Fo}}function Fu(e){if(e){if(e.COMPUTER_USE_MODEL)return e.COMPUTER_USE_MODEL;if(e.GOOGLE_API_KEY)return Ro;if(e.OPENAI_API_KEY)return Or}}var Lr,No,Dr,Ro,Or,Fo,Nr,Rr,pg,Hu=y(()=>{"use strict";Lr="claude-haiku-4-5",No="gemini-3.1-flash-lite-preview",Dr="gpt-5.4-mini",Ro="gemini-3-flash-preview",Or="gpt-5.4",Fo="claude-sonnet-4-6",Nr=No,Rr=Ro,pg=()=>typeof process<"u"?process.env:{}});var Fr,Wu=y(()=>{"use strict";Fr=(e=>(e.INITIALIZING="initializing",e.READY="ready",e.PROCESSING="processing",e.STOPPING="stopping",e.WAITING_USER="waiting_user",e.COMPLETED="completed",e.FAILED="failed",e))(Fr||{})});function Bu(e){let t=e.trim();if(!t||t.startsWith("List of devices"))return null;let i=t.split(/\s+/);if(i.length<2)return null;let n=i[0],o=i[1],a="usb";return n.startsWith("emulator-")?a="emulator":n.includes(":")&&(a="wifi"),{id:n,state:o,connectionType:a}}function Uu(e){return e.startsWith(he)?e:`${he}${e}`}function Gu(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var Ku=y(()=>{"use strict";Lo()});var Hr={};Ke(Hr,{ADDRESS_BAR_HEIGHT:()=>Do,ANDROID_DEVICE_PREFIX:()=>he,ActionEntitySchema:()=>tr,ActionSchema:()=>nr,AgentStatus:()=>Fr,BaseStatementSchema:()=>Qe,BrowserType:()=>Er,ConditionSchema:()=>Ao,ConditionType:()=>$r,ConditionTypeSchema:()=>Qa,DEFAULT_ANTHROPIC_MODEL:()=>Lr,DEFAULT_COMPUTER_USE_MODEL:()=>Rr,DEFAULT_COPILOT_MODEL:()=>Fo,DEFAULT_DEVICE_NAME:()=>tt,DEFAULT_GEMINI_COMPUTER_USE_MODEL:()=>Ro,DEFAULT_GOOGLE_MODEL:()=>No,DEFAULT_OPENAI_COMPUTER_USE_MODEL:()=>Or,DEFAULT_OPENAI_MODEL:()=>Dr,DEFAULT_WEBAGENT_MODEL:()=>Nr,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>Pu,DEVICE_CATEGORIES:()=>Ar,DeviceType:()=>Tr,DraftSchema:()=>ir,IOS_DEVICE_PREFIX:()=>me,LoginType:()=>Mr,MIN_WINDOW_HEIGHT:()=>Sr,MIN_WINDOW_WIDTH:()=>kr,NON_INTENT_ACTIONS:()=>mr,NodeJSCodeCommon:()=>bd,PLAYWRIGHT_DEVICES:()=>Ki,RECORD_VIDEO_HEIGHT:()=>_r,RECORD_VIDEO_WIDTH:()=>vr,StatementSchema:()=>ne,StatementType:()=>Pr,StatementTypeSchema:()=>er,TestFlowSchema:()=>Mo,TestGroupEntrySchema:()=>or,TestGroupSchema:()=>Bi,TwoFactorAuthType:()=>Ir,UI_DEVICE_CATEGORIES:()=>pu,UI_DEVICE_CATEGORIES_ELECTRON:()=>gu,USER_AGENT:()=>fr,VIEWPORT_HEIGHT:()=>xr,VIEWPORT_WIDTH:()=>yr,VariableStore:()=>Lu,WINDOW_HEIGHT:()=>br,WINDOW_WIDTH:()=>wr,actionEntityToYaml:()=>Dd,actionStepsMapToTestFlowSections:()=>Xd,allowPureVisionAction:()=>zd,applyPatchToYaml:()=>ur,applyPatchToYamlString:()=>Wd,collectActionSteps:()=>Be,convertPlaywrightActionToEntity:()=>Td,countIntentStatements:()=>pr,createAndroidDeviceName:()=>au,createEmptyStore:()=>_u,createIOSDeviceName:()=>ru,createRunnerStoreEntry:()=>ku,extractActionStepsFromTestFlow:()=>Vd,extractAndAttachComments:()=>cr,extractDeviceIdentifier:()=>ou,extractElementDescription:()=>Ja,extractElementDescriptionFromAriaSnapshot:()=>qa,extractLocatorFromCode:()=>Za,extractYamlMetadata:()=>Fd,findNextAfterContainer:()=>We,findNextSibling:()=>He,findNextStatement:()=>Fe,findPathBetweenStatements:()=>Gd,findStatementPathById:()=>oe,generateUid:()=>Ed,getAllDeviceNames:()=>mu,getAllReferenceIds:()=>Kd,getAllStatementsInOrder:()=>Gi,getAndroidDeviceDisplayName:()=>Gu,getBrowserWindowSize:()=>fu,getCompatiblePlatforms:()=>gr,getDeviceBrowserType:()=>yu,getDeviceByName:()=>ji,getDeviceChannel:()=>bu,getDeviceOptions:()=>Oo,getDevicesByCategory:()=>$t,getIOSDeviceDisplayName:()=>du,getLoginConfigPlatform:()=>xd,getRecordVideoSize:()=>wu,getStatementContainers:()=>Ce,getStoreSize:()=>Mu,getTestPlatformFromDeviceName:()=>eu,hasReferenceIds:()=>hr,isAndroidDevice:()=>iu,isAppPackage:()=>su,isDynamicAction:()=>jd,isExecutableStatement:()=>Ud,isIOSDevice:()=>nu,isNativeDevice:()=>tu,isPhysicalDeviceUDID:()=>uu,isPlatformCompatibleWithUrl:()=>lu,isStoreEmpty:()=>Au,isWebUrl:()=>$o,mergeActionEntitiesIntoTestFlow:()=>Iu,mergeStoreUpdates:()=>Tu,parseAdbDeviceLine:()=>Bu,parseYamlArrayItems:()=>Rd,replaceVariables:()=>_d,resolveActionEntity:()=>Su,resolveComputerUseModelFromEnv:()=>Fu,resolveModels:()=>Nu,resolveWebAgentModelFromEnv:()=>Ru,suiteToYaml:()=>lr,testFlowToYaml:()=>Pd,testFlowToYamlObject:()=>sr,toAndroidDeviceName:()=>Uu,toIOSDeviceName:()=>cu,updateStoreEntry:()=>Eu,validatePatch:()=>dr,validateTestYaml:()=>Zd,yamlObjectsToString:()=>$d,yamlToActionEntity:()=>Od,yamlToTestFlow:()=>et});var Wr=y(()=>{"use strict";yd();vd();kd();Ad();Bd();Qd();Io();ar();hu();xu();vu();Cu();Po();$u();Ou();Hu();Wu();Ku();Lo()});var wg={};Ke(wg,{SDK_ENV_ALLOWLIST:()=>Zu,buildSdkEnv:()=>Qu,createTestContext:()=>qu,expect:()=>Lt.expect,resolveAuthState:()=>Yu,test:()=>fg});module.exports=ah(wg);var Ue=R(require("path"),1),Xu=R(require("fs"),1),Lt=require("@playwright/test");var ee=R(require("fs"),1),nt=R(require("path"),1),Wo=require("crypto"),Bo=require("os");function Kr(e){return[`--disable-extensions-except=${e}`,`--load-extension=${e}`,"--no-first-run","--disable-default-apps"]}function jr(e){if(!ee.existsSync(e))return console.warn(`[fixture] extensionStorageState file not found: ${e}`),null;let t;try{t=JSON.parse(ee.readFileSync(e,"utf-8"))}catch(a){throw new Error(`[fixture] Failed to parse extensionStorageState at ${e}: ${a}`)}let i=t;if(!Array.isArray(i.cookies))return null;let n=(Date.now()+365*24*60*60*1e3)/1e3,o=i.cookies.filter(a=>a&&typeof a=="object"&&typeof a.name=="string"&&typeof a.domain=="string");return o.length<i.cookies.length&&console.warn(`[fixture] Skipped ${i.cookies.length-o.length} malformed cookies (missing name or domain)`),o.map(a=>({...a,expires:n}))}function zr(e){if(e){let i=nt.resolve(process.cwd(),e),n=nt.join((0,Bo.tmpdir)(),`ext-profile-${(0,Wo.randomUUID)()}`);if(ee.existsSync(i)){try{ee.cpSync(i,n,{recursive:!0})}catch(a){try{ee.rmSync(n,{recursive:!0,force:!0})}catch(r){console.warn("[fixture] Failed to clean up partial profile copy:",n,r)}throw new Error(`[fixture] Failed to copy extension profile from ${i}: ${a}`)}let o=nt.join(n,"SingletonLock");ee.existsSync(o)&&ee.rmSync(o,{force:!0})}else ee.mkdirSync(n,{recursive:!0});return n}let t=nt.join((0,Bo.tmpdir)(),`ext-profile-${(0,Wo.randomUUID)()}`);return ee.mkdirSync(t,{recursive:!0}),t}Va();var jp=R(require("dotenv"),1),zp="__shiplightDotenvCache__";function Vp(){return globalThis[zp]}function Xa(){let e=Vp();return e===void 0?process.env:e}async function Yu(e){let i=await import(Ue.resolve(process.cwd(),e.auth)),n=i.login||i.default;if(typeof n!="function")throw new Error(`auth module "${e.auth}" must export a login(args) function that returns a storageState file path`);let o=await n(e.args||{});if(typeof o!="string")throw new Error(`auth module "${e.auth}" login() must return a storageState file path (got ${typeof o})`);return o}function ju(e){return!(!e||e==="off")}function Ju(e,t){return!e||e==="off"?!1:e==="on"?!0:e==="retain-on-failure"?t.status!==t.expectedStatus:e==="on-first-retry"?t.retry>0:typeof e=="object"&&e!==null&&"mode"in e?Ju(e.mode,t):!0}async function zu(e,t,i){let n=Ju(t,i);for(let o of e)try{if(n){let a=await o.path();await i.attach("video",{path:a,contentType:"video/webm"})}else await o.delete()}catch(a){console.warn("[fixture] Failed to process video:",a)}}var Ho;async function Vu(){return Ho||(Ho=await Promise.resolve().then(()=>(Va(),wd)),Ho)}var gg=new Set(["get","set","getAll","has","__variableStore"]);function qu(e){let t={__variableStore:e,get(i){return e.get(i)},set(i,n,o=!1){e.set(i,n,o)},getAll(){return e.getAll()}};return new Proxy(t,{get(i,n,o){if(n in i)return Reflect.get(i,n,o);if(typeof n=="string")return i.get(n)},set(i,n,o){return typeof n!="string"||gg.has(n)?Reflect.set(i,n,o):(i.set(n,o),!0)},has(i,n){return n in i?!0:typeof n=="string"?e.has?.(n)??!1:!1}})}var Zu=["GOOGLE_API_KEY","ANTHROPIC_API_KEY","OPENAI_API_KEY","OPENAI_BASE_URL","ANTHROPIC_MODELS_USE_VERTEXAI","GOOGLE_GENAI_USE_VERTEXAI","GOOGLE_CLOUD_PROJECT","GOOGLE_CLOUD_LOCATION","MAILGUN_API_KEY","MAILGUN_DOMAIN","SHIPLIGHT_API_TOKEN","SHIPLIGHT_API_URL"];function Qu(e=Xa()){let t={};for(let i of Zu)t[i]=e[i]??"";return t}var fg=Lt.test.extend({account:[void 0,{option:!0}],autoDismissModal:[!1,{option:!0}],extensionDir:[void 0,{option:!0}],userDataDir:[void 0,{option:!0}],extensionStorageState:[void 0,{option:!0}],launchOptions:async({launchOptions:e},t)=>{if(!process.env.SHIPLIGHT_REGISTRY_URL){await t(e);return}let i=e?.args??[],n={...e,args:[...i,"--remote-debugging-port=0"]};await t(n)},browser:async({browser:e},t)=>{let i=null;if(process.env.SHIPLIGHT_REGISTRY_URL)try{let n=await xo(process.pid),o=process.env.TEST_WORKER_INDEX??"?";i=await kt({cdpUrl:n,label:`shiplight test w${o}`,pid:process.pid})}catch{}await t(e),await St(i)},context:async({browser:e,account:t,extensionDir:i,userDataDir:n,extensionStorageState:o},a,r)=>{if(i||n){if(t||r.project.use.auth)throw new Error('Cannot use both "extensionDir"/"userDataDir" and "auth" \u2014 persistent context tests manage their own context. Use extensionStorageState for authentication instead.');let l=r.project.use?.browserName;l&&l!=="chromium"&&console.warn(`[fixture] Persistent context requires Chromium but project is configured for "${l}". Forcing Chromium.`);let d=process.env.PLAYWRIGHT_HEADLESS==="true";i&&d&&console.warn("[fixture] PLAYWRIGHT_HEADLESS=true with extensionDir \u2014 Chrome extensions will not function in headless mode.");let c=zr(n),u=i?Kr(Ue.resolve(process.cwd(),i)):[],m={...r.project.use},{storageState:g,account:w,extensionDir:v,userDataDir:x,extensionStorageState:p,autoDismissModal:f,video:S,..._}=m,k=ju(S)?{dir:r.outputDir}:void 0,E;try{if(E=await Lt.chromium.launchPersistentContext(c,{..._,headless:d,args:u,viewport:_.viewport??{width:1280,height:720},...k?{recordVideo:k}:{}}),o){let I=Ue.resolve(process.cwd(),o),C=jr(I);C&&await E.addCookies(C)}await a(E)}finally{let I=E?.pages().map(C=>C.video()).filter(C=>C!==null)??[];if(await E?.close().catch(C=>{console.warn("[fixture] Failed to close persistent context:",C)}),await zu(I,S,r),!n)try{Xu.rmSync(c,{recursive:!0,force:!0})}catch(C){console.warn("[fixture] Failed to clean up temp profile dir:",c,C)}}}else{let l={...r.project.use},d=r.project.use,c=d.auth?{auth:d.auth,args:d.args}:t;if(c){if(!c.auth)throw new Error("Auth is declared but missing the script path. Provide auth in playwright.config.ts: use: { auth: './auth.login.ts' }");l.storageState=await Yu(c)}let u=l.video;ju(u)&&!l.recordVideo&&(l.recordVideo={dir:r.outputDir});let m=await e.newContext(l);m.addInitScript(Oe);try{await a(m)}finally{let g=m.pages().map(w=>w.video()).filter(w=>w!==null);await m.close(),await zu(g,u,r)}}},page:async({context:e},t)=>{let i=await e.newPage();await t(i)},testContext:async({},e,t)=>{let{VariableStore:i}=await Vu(),n=new i,o=t.project.use.variables;if(o)for(let[r,s]of Object.entries(o))typeof s=="string"?n.set(r,s,!1):s&&typeof s=="object"&&"value"in s&&n.set(r,s.value,s.sensitive===!0);let a=qu(n);global.testContext=a,global.$=a,global.ctx=a,await e(a),delete global.testContext,delete global.$,delete global.ctx},$:async({testContext:e},t)=>{await t(e)},ctx:async({testContext:e},t)=>{await t(e)},agent:async({page:e,testContext:t,autoDismissModal:i},n,o)=>{let{WebAgent:a,createAgentContext:r,configureSdk:s,parseSdkLogLevelFromEnv:l}=await Vu(),d=l();s({env:Qu(),...d!==void 0&&{logLevel:d}});let{resolveWebAgentModelFromEnv:c,resolveComputerUseModelFromEnv:u}=await Promise.resolve().then(()=>(Wr(),Hr)),m=Xa(),g=c(m);if(!g)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, GOOGLE_API_KEY, ANTHROPIC_API_KEY, OPENAI_API_KEY, or SHIPLIGHT_API_TOKEN in your .env file (or in the runner environment for CI).");let w=u(m),v=t.__variableStore,x=r({model:g,computer_use_model:w,variableStore:v,autoDismissModal:i}),p=Ue.join(o.outputDir,"artifacts");x.stepTracking={results:{},artifactsDir:p};let f=new a(x),S=e.context();f.agentServices.setupPageTracking(S);for(let _ of S.pages())f.setupDownloadTracking(_),f.setupDialogHandling(_);S.on("page",_=>{f.setupDownloadTracking(_),f.setupDialogHandling(_)}),global.agent=f,await n(f),delete global.agent;try{let _=o.outputDir;await f.writeExecutionResults(_);let k=Ue.join(_,"test-results.json");await(await import("fs/promises")).stat(k).catch(()=>null)&&await o.attach("shiplight-results",{path:k,contentType:"application/json"})}catch(_){console.error("[Shiplight] Failed to attach step results:",_)}try{let _=f.getNewActionEntities();if(_.size>0&&o.status==="passed"){let{createEmptyStore:k,createRunnerStoreEntry:E}=await Promise.resolve().then(()=>(Wr(),Hr)),I=await import("fs/promises"),C=k();for(let[K,X]of _)C.entries[K]=E(X,0);let $=Ue.join(o.outputDir,"new-action-entities.json");await I.writeFile($,JSON.stringify(C,null,2)),await o.attach("shiplight-new-action-entities",{path:$,contentType:"application/json"}),console.log(`[Shiplight] ${_.size} healed action entit${_.size===1?"y":"ies"} saved`)}}catch(_){console.warn("[Shiplight] Failed to persist new action entities:",_)}}});0&&(module.exports={SDK_ENV_ALLOWLIST,buildSdkEnv,createTestContext,expect,resolveAuthState,test});
|