shiplightai 0.1.19 → 0.1.21

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.
@@ -0,0 +1,11 @@
1
+ import { createRequire as __createRequire } from "module";
2
+ const require = __createRequire(import.meta.url);
3
+ import{Ka as F,ca as L,ga as b,za as C}from"./chunk-JNRJXAJS.js";import{stringify as G}from"yaml";import{parse as fe,stringify as I}from"yaml";import{readFileSync as ge}from"fs";import{resolve as z,dirname as de}from"path";import{parse as H,stringify as me}from"yaml";import{readFileSync as Le,writeFileSync as Se,mkdirSync as Ae}from"fs";import{dirname as xe}from"path";var T=1e4;function k(e){return e.replace(/\\/g,"\\\\").replace(/'/g,"\\'").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/\t/g,"\\t")}function d(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function X(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Q(e){let t=e.xpath;return typeof t=="string"&&t.trim()?!t.startsWith("xpath=")&&!t.startsWith("/")&&!t.startsWith("//")?`xpath=//${t}`:t.startsWith("xpath=")?t:`xpath=${t}`:null}function O(e){let t=X(e),a=e.locator;if(typeof a=="string"&&a.trim())return a=a.trim(),a.endsWith("first()")?`${t}.${a}`:`${t}.${a}.first()`;let r=Q(e);if(r){let n=JSON.stringify(r);return`${t}.locator(${n}).first()`}return null}var Z=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],ee=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"];function Y(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:Z.includes(t)}function te(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!ee.includes(t)}var m=new Map;function l(e,t){m.set(e,t)}function ae(e){return m.get(e)}function A(e,t,a=[]){let r=[...a];return t.locator?r.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&r.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&r.push(`frame_path: ${JSON.stringify(t.frame_path)}`),r.length===0?[`await agent.execAction("${e}", page, {});`]:[`await agent.execAction("${e}", page, {`,...r.map(n=>` ${n},`),"});"]}l("click",e=>{let t=O(e);return t?[`await ${t}.click({ timeout: ${T} });`]:['await agent.execAction("click", page, {});']});l("click_element",m.get("click"));l("click_element_by_index",m.get("click"));l("double_click",e=>A("double_click",e));l("double_click_on_element",m.get("double_click"));l("right_click",e=>A("right_click",e));l("right_click_on_element",m.get("right_click"));l("hover",e=>A("hover",e));l("hover_element_by_index",m.get("hover"));l("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return A("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});l("fill",m.get("input_text"));l("clear_input",e=>A("clear_input",e));l("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});l("send_keys",m.get("press"));l("send_keys_on_element",e=>{let t=O(e),a=e.action_data?.kwargs?.keys||"";return t?[`await ${t}.press(${JSON.stringify(a)}, { timeout: ${T} });`]:['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(a)} } },`,"});"]});l("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return A("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});l("scroll",e=>{let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]});l("scroll_down",m.get("scroll"));l("scroll_up",m.get("scroll"));l("scroll_element",m.get("scroll"));l("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});l("scroll_on_element",e=>A("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));l("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});l("open_tab",m.get("go_to_url"));l("go_back",()=>['await agent.execAction("go_back", page, {});']);l("reload_page",()=>['await agent.execAction("reload_page", page, {});']);l("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);l("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);l("verify",(e,t)=>{let a=e.action_data?.kwargs,r=typeof a?.code=="string",n=a?.statement||e.action_description;if(r&&n){let i=a.code.split(`
4
+ `),u=JSON.stringify(n);return["{ const _t = Date.now(); try {",...i.map(p=>` ${p}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${u}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${u}\`);`,` await agent.assert(page, ${u}, ${JSON.stringify(t||"")});`,"} }"]}return r?a.code.split(`
5
+ `):n?[`await agent.assert(page, ${JSON.stringify(n)}, ${JSON.stringify(t||"")});`]:["// Skipping verify: missing statement or code"]});l("ai_assert",m.get("verify"));l("assert",m.get("verify"));l("ai_action",(e,t)=>{let a=e.action_data?.kwargs?.statement;if(!a)return["// Skipping ai_action: missing statement"];let r=JSON.stringify(a),n=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${r}, '${t||""}', ${n});`]});l("ai_step",(e,t)=>{let a=e.action_data?.kwargs?.statement;return a?[`await agent.run(page, ${JSON.stringify(a)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]});l("ai_extract",(e,t)=>{let a=e.action_data?.kwargs?.element_description,r=e.action_data?.kwargs?.variable_name;if(!a||!r)return["// Skipping ai_extract: missing element_description or variable_name"];let n=JSON.stringify(a),s=JSON.stringify(r);return[`await agent.extract(page, ${n}, ${s}, '${t||""}');`]});l("ai_wait_until",(e,t)=>{let a=e.action_data?.kwargs?.condition,r=e.action_data?.kwargs?.timeout_seconds||60;return a?[`await agent.waitUntilCondition(page, ${JSON.stringify(a)}, ${r}, '${t||""}');`]:["// Skipping ai_wait_until: missing condition"]});l("save_variable",e=>{let t=e.action_data?.kwargs?.name||"",a=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(a)} } },`,"});"]});l("js_code",e=>{let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let a=["{"],r=t.split(`
6
+ `);for(let n of r)a.push(` ${n}`);return a.push("}"),a});l("function",(e,t,a)=>{let r=e.action_data?.kwargs||{},n=r.functionName;if(n&&n.includes("#")){let[i,u]=n.split("#");if(i&&u){let p=i.replace(/\.(ts|js|mjs)$/,""),o=`import { ${u} } from '${p}';`;a?.imports?.add(o);let c={...r,functionName:u},f=W(c);return f?[f.endsWith(";")?f:`${f};`]:["// Skipping function: invalid export pattern"]}}let s=W(r);return s?[s.endsWith(";")?s:`${s};`]:["// Skipping function: missing functionName"]});l("generate_2fa_code",e=>{let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]});l("upload_file",e=>{let t=e.action_data?.kwargs||{},a=[],r={};return t.paths?r.paths=t.paths:t.path&&(r.path=t.path),t.use_file_input&&(r.use_file_input=!0),a.push(`action_data: { kwargs: ${JSON.stringify(r)} }`),e.locator?a.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&a.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&a.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...a.map(n=>` ${n},`),"});"]});l("wait_for_download_complete",e=>['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]);l("switch_tab",e=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??0} } },`,"});"]);l("close_tab",e=>{let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]});l("set_date_for_native_date_picker",e=>{let t=e.action_data?.kwargs?.date??"",a=[];return a.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?a.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&a.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&a.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...a.map(r=>` ${r},`),"});"]});l("done",()=>["// Done - no action needed"]);l("js_action",e=>{let t=e.action_data?.kwargs?.code;return t?t.split(`
7
+ `):["// Skipping js_action: missing code"]});function W(e){let t=e.functionName;if(!t)return null;let a=Array.isArray(e.args)?e.args.map(String):[];if(a.length===0)return`await ${t}()`;let r=["page","testContext","request","agentServices"],n=["undefined","null","true","false"],s=a.map(i=>r.includes(i)||n.includes(i)||/^-?\d+(\.\d+)?$/.test(i)?i:i.startsWith("$")?`agent.agentServices.readVariable('${i.substring(1)}')`:`"${i}"`);return`await ${t}(${s.join(", ")})`}function w(e,t,a,r="main"){let n=[];for(let s=0;s<e.length;s++){let i=e[s],u=`${r}.${s}`,p=ne(i,t,u,a);p.length>0&&(n.push(...p),s<e.length-1&&n.push(""))}return n}function ne(e,t,a,r){let n=" ".repeat(t);switch(e.type){case"DRAFT":return re(e,t,a,r);case"ACTION":return se(e,t,a,r);case"STEP":return ie(e,t,a,r);case"IF_ELSE":return oe(e,t,a,r);case"WHILE_LOOP":return ce(e,t,a,r);default:return[`${n}// Unknown statement type: ${e.type}`]}}function re(e,t,a,r){let n=" ".repeat(t),s=e.description?.trim()||"";if(!s)return[`${n}// ${a}: Skipping - no description`];if(r.noAgent)return[`${n}// ${a}: ${d(s)}`,`${n}// DRAFT: ${d(s)} (requires agent - skipped in hook)`];let i=JSON.stringify(s);return[`${n}// ${a}: ${d(s)}`,`${n}// \u26A0 DRAFT: AI-resolved at runtime (~5-10s). Add a locator to make this <1s.`,`${n}page = agent.agentServices.validatePage(page);`,`${n}await agent.run(page, ${i}, '${a}');`]}function se(e,t,a,r){let n=" ".repeat(t),s=e.description,i=e.uid,p=r.actionEntityStore?.entries[e.uid]?.action_entity??e.action_entity;if(!p){if(!s)return[`${n}// ${a}: Skipping - no description`];if(r.noAgent)return[`${n}// ${a}: ${d(s)}`,`${n}// DRAFT: ${d(s)} (requires agent - skipped in hook)`];let _=JSON.stringify(s),x=!!e.use_pure_vision;return[`${n}// ${a}: ${d(s)}`,`${n}// \u26A0 DRAFT: AI-resolved at runtime (~5-10s). Add a locator to make this <1s.`,`${n}page = agent.agentServices.validatePage(page);`,`${n}await agent.execute(page, ${_}, '${a}', ${x});`]}let o=e.locator?{...p,locator:e.locator}:p;s&&s!==o.action_description&&(o={...o,action_description:s});let c=o.action_data?.action_name||"",f=o.action_description||"",h=ae(c);if(!h)return[`${n}// ${a}: Unknown action: ${c}`];let g={imports:r.imports},$=h(o,a,g);if(r.noAgent){if(Y(o))return[`${n}// ${a}: ${d(f)}`,`${n}// AI action: ${d(f)} (requires agent - skipped in hook)`];let _=le(o,c,n,a);return _||[`${n}// ${a}: ${d(f)}`,...$.map(x=>`${n}${x}`)]}if(Y(o))return[`${n}// ${a}: ${d(f)}`,`${n}page = agent.agentServices.validatePage(page);`,...$.map(_=>`${n}${_}`)];let v=JSON.stringify(f),S=$.map(_=>`${n} ${_}`),E=te(o),j=i?`'${i}'`:"undefined";return[`${n}// ${a}: ${d(f)}`,`${n}page = agent.agentServices.validatePage(page);`,`${n}await agent.step(page, async () => {`,...S,`${n}}, ${v}, '${a}', ${j}, ${E});`]}function ie(e,t,a,r){let n=" ".repeat(t),s=[];e.description&&e.description.trim()&&s.push(`${n}// Step: ${d(e.description)}`);let i=w(e.statements,t,r,a);return s.push(...i),s}function oe(e,t,a,r){let n=" ".repeat(t),s=[];if(s.push(`${n}// ${a}: Conditional check`),e.condition.type==="JS_CODE")s.push(`${n}if (${e.condition.expression}) {`);else{s.push(`${n}// AI Condition: ${d(e.condition.expression)}`);let u=JSON.stringify(e.condition.expression);s.push(`${n}if (await agent.evaluate(page, ${u}, "${a}")) {`)}let i=w(e.then,t+1,r,`${a}.then`);if(s.push(...i),e.else&&e.else.length>0){s.push(`${n}} else {`);let u=w(e.else,t+1,r,`${a}.else`);s.push(...u)}return s.push(`${n}}`),s}function ce(e,t,a,r){let n=" ".repeat(t),s=[];s.push(`${n}// ${a}: Loop`);let i=e.timeout_ms??F,u=i/1e3,p=e.timeout_ms?`While loop exceeded timeout of ${u}s`:`While loop exceeded default timeout of ${u}s`,o=`loop_${a.replace(/\./g,"_")}`;if(s.push(`${n}const ${o}_start = Date.now();`),s.push(`${n}const ${o}_timeout = ${i};`),s.push(`${n}const ${o}_check = () => {`),s.push(`${n} if (Date.now() - ${o}_start > ${o}_timeout) {`),s.push(`${n} throw new Error('${p}');`),s.push(`${n} }`),s.push(`${n} return true;`),s.push(`${n}};`),e.condition.type==="JS_CODE")s.push(`${n}while (${o}_check() && (${e.condition.expression})) {`);else{s.push(`${n}// AI Loop Condition: ${d(e.condition.expression)}`);let f=JSON.stringify(e.condition.expression);s.push(`${n}while (${o}_check() && await agent.evaluate(page, ${f}, "${a}")) {`)}let c=w(e.body,t+1,r,`${a}.body`);return s.push(...c),s.push(`${n}}`),s}function le(e,t,a,r){let n=e.action_description||"",s=e.action_data?.kwargs||{};switch(t){case"go_to_url":case"open_tab":{let i=s.url||"";return[`${a}// ${r}: ${d(n)}`,`${a}await page.goto(${JSON.stringify(i)}, { waitUntil: 'domcontentloaded' });`]}case"go_back":return[`${a}// ${r}: ${d(n)}`,`${a}await page.goBack();`];case"go_forward":return[`${a}// ${r}: ${d(n)}`,`${a}await page.goForward();`];case"input_text":{let i=s.text||"",u=O(e);return u?[`${a}// ${r}: ${d(n)}`,`${a}await ${u}.fill(${JSON.stringify(i)}, { timeout: ${T} });`]:null}case"select_dropdown_option":{let i=s.text||s.label||"",u=O(e);return u?[`${a}// ${r}: ${d(n)}`,`${a}await ${u}.selectOption({ label: ${JSON.stringify(i)} }, { timeout: ${T} });`]:null}default:return null}}function ue(e,t){let a=[],r=t?.version||"unknown";a.push(`// @generated by shiplightai v${r}`),a.push(...B()),a.push(""),t?.use&&Object.keys(t.use).length>0&&(a.push(`test.use(${JSON.stringify(t.use,null,2)});`),a.push(""));let n=new Set,s={imports:n};t?.beforeEach&&t.beforeEach.length>0&&(a.push(...U("beforeEach",t.beforeEach,s)),a.push(""));let i=t?.timeout||t?.skip!==void 0||t?.fail!==void 0||t?.only||t?.slow?{timeout:t.timeout,skip:t.skip,fail:t.fail,only:t.only,slow:t.slow}:void 0;if(t?.parameters&&t.parameters.length>0){let u=t?.testName||e.goal||"Generated test",p=P(t?.tags);for(let o of t.parameters){let c=V(e,o.values);a.push(...J(c,`${p}${k(u)} [${k(o.name)}]`,s,0,i)),a.push("")}}else{let u=t?.testName||e.goal||"Generated test",p=P(t?.tags);a.push(...J(e,`${p}${k(u)}`,s,0,i))}return t?.afterEach&&t.afterEach.length>0&&(a.push(""),a.push(...U("afterEach",t.afterEach,s))),D(a,n),a.join(`
8
+ `)}function pe(e,t){let a=[],r=t?.version||"unknown";a.push(`// @generated by shiplightai v${r}`),a.push(...B()),a.push(""),t?.use&&Object.keys(t.use).length>0&&(a.push(`test.use(${JSON.stringify(t.use,null,2)});`),a.push(""));let n=new Set,s={imports:n},i=t?.testName||"Test Suite",u=P(t?.tags),p=e.serial?"test.describe.serial":"test.describe";a.push(`${p}('${u}${k(i)}', () => {`),e.beforeAll&&e.beforeAll.length>0&&(a.push(...N("beforeAll",e.beforeAll,s,1)),a.push("")),e.beforeEach&&e.beforeEach.length>0&&(a.push(...N("beforeEach",e.beforeEach,s,1)),a.push(""));for(let o=0;o<e.tests.length;o++){let c=e.tests[o],f=c.timeout||c.skip!==void 0||c.fail!==void 0||c.only||c.slow?{timeout:c.timeout,skip:c.skip,fail:c.fail,only:c.only,slow:c.slow}:void 0;if(c.parameters&&c.parameters.length>0)for(let h of c.parameters){let g=V(c.testFlow,h.values);a.push(...J(g,`${k(c.name)} [${k(h.name)}]`,s,1,f)),a.push("")}else a.push(...J(c.testFlow,k(c.name),s,1,f)),(o<e.tests.length-1||e.afterEach||e.afterAll)&&a.push("")}return e.afterEach&&e.afterEach.length>0&&(a.push(...N("afterEach",e.afterEach,s,1)),a.push("")),e.afterAll&&e.afterAll.length>0&&a.push(...N("afterAll",e.afterAll,s,1)),a.push("});"),D(a,n),a.join(`
9
+ `)}function P(e){return e&&e.length>0?e.map(t=>`@${t}`).join(" ")+" ":""}function J(e,t,a,r=0,n){let s=" ".repeat(r),i=[],u=n?.only?"test.only":"test";i.push(`${s}${u}('${t}', async ({ page, agent }) => {`),n?.skip===!0?i.push(`${s} test.skip();`):typeof n?.skip=="string"&&i.push(`${s} test.skip(true, '${k(n.skip)}');`),n?.fail===!0?i.push(`${s} test.fail();`):typeof n?.fail=="string"&&i.push(`${s} test.fail(true, '${k(n.fail)}');`),n?.slow&&i.push(`${s} test.slow();`),n?.timeout&&i.push(`${s} test.setTimeout(${n.timeout});`);let p=e.teardown&&e.teardown.length>0,o=r+1;if(p){if(i.push(`${s} try {`),e.statements&&e.statements.length>0){i.push(`${s} // Test steps`);let f=w(e.statements,o+1,a);i.push(...f)}i.push(`${s} } finally {`),i.push(`${s} // Teardown`);let c=w(e.teardown,o+1,a,"teardown");i.push(...c),i.push(`${s} }`)}else if(e.statements&&e.statements.length>0){i.push(`${s} // Test steps`);let c=w(e.statements,o,a);i.push(...c)}return i.push(`${s}});`),i}function U(e,t,a){let r=[],n=q(t);return r.push(`test.${e}(async ({ page, agent }) => {`),r.push(...w(n,1,a,e)),r.push("});"),r}function N(e,t,a,r){let n=" ".repeat(r),s=[],i=q(t);if(e==="beforeAll"||e==="afterAll"){let p={...a,noAgent:!0};s.push(`${n}test.${e}(async ({ browser }, workerInfo) => {`),s.push(`${n} const page = await browser.newPage({ baseURL: workerInfo.project.use.baseURL });`),s.push(...w(i,r+1,p,e)),s.push(`${n} await page.close();`),s.push(`${n}});`)}else s.push(`${n}test.${e}(async ({ page, agent }) => {`),s.push(...w(i,r+1,a,e)),s.push(`${n}});`);return s}function q(e){let a=G({goal:"_hook",statements:e});return b(a).statements}function V(e,t){let a=L(e);for(let[r,n]of Object.entries(t))a=a.split(`<<${r}>>`).join(String(n));return b(a)}function B(){return["import { test, expect } from 'shiplightai/fixture';"]}function D(e,t){if(t.size>0){let a=0;for(let n=0;n<e.length;n++)e[n].startsWith("import ")&&(a=n+1);let r=Array.from(t);e.splice(a,0,...r)}}var M=5;function K(e,t){let a={expandingPaths:new Set([z(t)]),depth:0,referencedPaths:new Set},r={...e};Array.isArray(r.statements)&&(r.statements=y(r.statements,t,a)),Array.isArray(r.teardown)&&(r.teardown=y(r.teardown,t,a));for(let n of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(r[n])&&(r[n]=y(r[n],t,a));return{doc:r,referencedTemplatePaths:Array.from(a.referencedPaths)}}function y(e,t,a){let r=[];for(let n of e)if(he(n)){let s=$e(n,t,a);r.push(...s)}else r.push(_e(n,t,a));return r}function he(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function $e(e,t,a){if(a.depth>=M)throw new Error(`Template expansion exceeded maximum depth of ${M}. Check for deeply nested or circular template references.`);let r=z(de(t),e.template);if(a.expandingPaths.has(r))throw new Error(`Circular template reference detected: ${r} is already being expanded. Stack: ${Array.from(a.expandingPaths).join(" \u2192 ")} \u2192 ${r}`);a.referencedPaths.add(r);let n;try{n=ge(r,"utf-8")}catch(c){throw new Error(`Failed to read template file: ${r} (referenced from ${t}): ${c.message}`)}let s=H(n);if(!s||typeof s!="object")throw new Error(`Invalid template file: ${r} \u2014 expected a YAML object`);let i=s.params||[],u=e.params||{};for(let c of i)if(!(c in u))throw new Error(`Template ${e.template} requires param "${c}" but it was not provided. Required params: [${i.join(", ")}]`);let p=s.statements;if(!Array.isArray(p))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(u).length>0){let f=me(p);for(let[h,g]of Object.entries(u))f=f.split(`<<${h}>>`).join(String(g));p=H(f)}let o={expandingPaths:new Set([...a.expandingPaths,r]),depth:a.depth+1,referencedPaths:a.referencedPaths};return y(p,r,o)}function _e(e,t,a){if(typeof e!="object"||e===null)return e;let r={...e};return Array.isArray(r.statements)&&(r.statements=y(r.statements,t,a)),Array.isArray(r.THEN)&&(r.THEN=y(r.THEN,t,a)),Array.isArray(r.ELSE)&&(r.ELSE=y(r.ELSE,t,a)),Array.isArray(r.DO)&&(r.DO=y(r.DO,t,a)),r}function we(e,t){let a=fe(e),r=a?.name,n=a?.tags,s=a?.use;if(a&&(a.name!==void 0||a.tags!==void 0||a.use!==void 0)&&(delete a.name,delete a.tags,delete a.use),a?.suite){if(a.goal||a.statements)throw new Error('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return ye(a,r,n,s,t)}return ke(a,r,n,s,t)}function ke(e,t,a,r,n){let s=e?.beforeEach,i=e?.afterEach,u=R(e?.parameters),p=e?.timeout,o=e?.skip,c=e?.fail,f=e?.only,h=e?.slow;e&&(delete e.beforeEach,delete e.afterEach,delete e.parameters,delete e.timeout,delete e.skip,delete e.fail,delete e.only,delete e.slow),e&&!e.goal&&t&&(e.goal=t);let g=[];if(n&&e&&typeof e=="object"){let S=K(e,n);e=S.doc,g=S.referencedTemplatePaths}let $=I(e);return{testFlow:b($),name:t,tags:a,use:r,beforeEach:s,afterEach:i,parameters:u,timeout:p,skip:o,fail:c,only:f,slow:h,referencedTemplatePaths:g}}function ye(e,t,a,r,n){let s=e.suite;if(!Array.isArray(s.tests)||s.tests.length===0)throw new Error('Suite must have a non-empty "tests" array.');let i=s.serial,u=s.beforeAll,p=s.afterAll,o=s.beforeEach,c=s.afterEach,f=[],h=s.tests.map(g=>{if(!g.name)throw new Error('Each test in a suite must have a "name" field.');if(!Array.isArray(g.statements)||g.statements.length===0)throw new Error(`Suite test "${g.name}" must have a non-empty "statements" array.`);let $={goal:g.name,statements:g.statements};g.teardown&&($.teardown=g.teardown);let v=[],S=$;if(n&&typeof $=="object"){let x=K($,n);S=x.doc,v=x.referencedTemplatePaths,f.push(...v)}let E=I(S),j=b(E),_=R(g.parameters);return{testFlow:j,name:g.name,parameters:_,timeout:g.timeout,skip:g.skip,fail:g.fail,only:g.only,slow:g.slow}});return{suite:{serial:i,beforeAll:u,afterAll:p,beforeEach:o,afterEach:c,tests:h},name:t,tags:a,use:r,referencedTemplatePaths:f}}function R(e){if(!(!Array.isArray(e)||e.length===0))return e.map((t,a)=>{if(!t.name)throw new Error(`Parameter set at index ${a} must have a "name" field.`);if(!t.values||typeof t.values!="object")throw new Error(`Parameter set "${t.name}" must have a "values" object.`);return{name:t.name,values:t.values}})}function Ye(e,t,a){let r=/\btemplate:\s/.test(e),n=/^suite:/m.test(e),s=r||n?null:C(e);if(s&&!s.valid)return{valid:!1,errors:s.errors,warnings:[],stats:s.stats};let i,u,p=[];try{let o=we(e,t);p=o.referencedTemplatePaths;let c={version:a?.version};o.suite?i=pe(o.suite,{...c,testName:o.name,tags:o.tags,use:o.use}):i=ue(o.testFlow,{...c,testName:o.name,tags:o.tags,use:o.use,beforeEach:o.beforeEach,afterEach:o.afterEach,parameters:o.parameters,timeout:o.timeout,skip:o.skip,fail:o.fail,only:o.only,slow:o.slow});let f=i.split(`
10
+ `).filter(h=>!h.startsWith("import ")).join(`
11
+ `);new Function(f),u=t.replace(/\.test\.yaml$/,".yaml.spec.ts"),Ae(xe(u),{recursive:!0}),Se(u,i)}catch(o){let c=o.message.includes("Unexpected token")?" This usually means a YAML escaping issue \u2014 in double-quoted strings, use \\\\/ instead of \\/ for regex patterns, or use single quotes / block scalars.":" This may indicate a transpiler bug \u2014 please report it.";return{valid:!1,errors:[`Transpilation failed: ${o.message}.${c}`],warnings:[],stats:s?.stats??{total:0,withLocator:0,coverage:0},referencedTemplatePaths:p}}return{valid:!0,errors:[],warnings:s?.warnings??[],stats:s?.stats??{total:0,withLocator:0,coverage:0},specFile:u,referencedTemplatePaths:p}}export{we as a,Ye as b};
@@ -1,7 +1,11 @@
1
- "use strict";var _e=Object.create;var k=Object.defineProperty;var ke=Object.getOwnPropertyDescriptor;var Ee=Object.getOwnPropertyNames;var Ie=Object.getPrototypeOf,xe=Object.prototype.hasOwnProperty;var u=(e,t)=>()=>(e&&(t=e(e=0)),t);var E=(e,t)=>{for(var r in t)k(e,r,{get:t[r],enumerable:!0})},K=(e,t,r,i)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ee(t))!xe.call(e,o)&&o!==r&&k(e,o,{get:()=>t[o],enumerable:!(i=ke(t,o))||i.enumerable});return e};var y=(e,t,r)=>(r=e!=null?_e(Ie(e)):{},K(t||!e||!e.__esModule?k(r,"default",{value:e,enumerable:!0}):r,e)),Oe=e=>K(k({},"__esModule",{value:!0}),e);var I=u(()=>{"use strict"});var s,R,L,$,b,U,z,V,w,C,D=u(()=>{"use strict";s=require("zod"),R=s.z.enum(["JS_CODE","AI_MODE"]),L=s.z.object({type:R,expression:s.z.string()}),$=s.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),b=s.z.object({uid:s.z.string(),type:$}),U=s.z.object({action_data:s.z.object({action_name:s.z.string(),kwargs:s.z.record(s.z.any()).optional(),args:s.z.array(s.z.any()).optional()}),action_description:s.z.string().optional(),url:s.z.string().optional(),xpath:s.z.string().nullable().optional(),locator:s.z.string().nullable().optional(),css_selector:s.z.string().nullable().optional(),unique_selector:s.z.string().nullable().optional(),element_index:s.z.number().nullable().optional(),frame_path:s.z.array(s.z.any()).optional(),artifacts:s.z.record(s.z.any()).optional(),feedback:s.z.string().optional(),original_browser_use_action:s.z.any().optional()}).passthrough(),z=b.extend({type:s.z.literal("DRAFT"),description:s.z.string()}),V=b.extend({type:s.z.literal("ACTION"),description:s.z.string(),action_entity:U.optional(),locator:s.z.string().optional(),use_pure_vision:s.z.boolean().optional()}),w=s.z.lazy(()=>s.z.union([z,V,b.extend({type:s.z.literal("STEP"),description:s.z.string().optional().default(""),statements:s.z.array(w),reference_id:s.z.number().optional()}),b.extend({type:s.z.literal("IF_ELSE"),description:s.z.string().optional(),condition:L,then:s.z.array(w),else:s.z.array(w).optional()}),b.extend({type:s.z.literal("WHILE_LOOP"),description:s.z.string().optional(),condition:L,body:s.z.array(w),timeout_ms:s.z.number().optional()})])),C=s.z.object({version:s.z.string().optional(),goal:s.z.string(),url:s.z.string().optional(),final_feedback:s.z.string().optional(),completed:s.z.boolean().optional(),success:s.z.boolean().optional(),statements:s.z.array(w),teardown:s.z.array(w).optional(),last_modified_at:s.z.string().optional()})});function X(e,t){let r={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},goal:e.goal,url:e.url,statements:e.statements.map(M)};return e.final_feedback&&(r.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(r.teardown=e.teardown.map(M)),r}function W(e,t){return(0,P.stringify)(X(e,t),Le)}function M(e){switch(e.type){case"DRAFT":return Ce(e);case"ACTION":return De(e);case"STEP":return We(e);case"IF_ELSE":return Fe(e);case"WHILE_LOOP":return He(e)}}function Ce(e){return{desc:e.description}}function De(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,r=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let a=r?.statement;if(typeof a=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let c=r?.code;return typeof c=="string"?{VERIFY:a,js:c}:{VERIFY:a}}}if(t==="go_to_url"){let a=r?.url;if(typeof a=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let c={URL:a};return r?.new_tab===!0&&(c.new_tab=!0),typeof r?.timeout_seconds=="number"&&(c.timeout_seconds=r.timeout_seconds),c}}if(t==="js_action"){let a=r?.code;if(typeof a=="string"&&e.description)return{desc:e.description,js:a}}if(t==="js_code"){let a=r?.code;if(typeof a=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{CODE:a}}if(!e.action_entity)return{desc:e.description};let i=e.action_entity.action_data??e.action_entity.action;if(!i)return{desc:e.description};let o={desc:e.description,action:i.action_name},n=e.locator??e.action_entity.locator;n&&(o.locator=n);let l=e.action_entity.xpath;if(l&&(o.xpath=l),e.use_pure_vision&&(o.use_pure_vision=!0),i.kwargs&&Object.keys(i.kwargs).length>0)for(let[a,c]of Object.entries(i.kwargs))o[a]=c;return i.args&&i.args.length>0&&(o.args=i.args),o}function We(e){let t={STEP:e.description,statements:e.statements.map(M)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function Fe(e){let t={IF:Y(e.condition),THEN:e.then.map(M)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(M)),t}function He(e){let t={WHILE:Y(e.condition),DO:e.body.map(M)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function Y(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function F(e){try{let t=(0,P.parse)(e);if(!t||typeof t!="object")return{};let r={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(r.test_case_id=t.test_case_id),typeof t.name=="string"&&t.name.trim()&&(r.name=t.name.trim()),r}catch{return{}}}function A(e){if(e.length>j)throw new Error(`YAML input too large (${e.length} bytes, max ${j})`);let t=(0,P.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");let r={version:"1.3.0",goal:t.goal,url:t.url,statements:T(t.statements??[])};t.final_feedback&&(r.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(r.teardown=T(t.teardown));let i=C.safeParse(r);if(!i.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(i.error.errors)}`);return i.data}function T(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Ke)}function Ke(e){if(typeof e=="string")throw new Error(`Plain string statements are not supported. Use "desc: ${e}" instead.`);if(typeof e!="object"||e===null)throw new Error(`Invalid statement: expected object, got ${typeof e}`);let t=e;if("IF"in t)return Ge(t);if("WHILE"in t)return Ne(t);if("STEP"in t)return Be(t);if("VERIFY"in t){let r=t.VERIFY,i={statement:typeof r=="string"?r:String(r)};return typeof t.js=="string"&&(i.code=t.js),{uid:(0,p.v4)(),type:"ACTION",description:`Verify: ${r}`,action_entity:{action_description:`Verify: ${r}`,action_data:{action_name:"verify",kwargs:i}}}}if("URL"in t){let r=t.URL,i=t.new_tab===!0?!0:void 0,o=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,n={url:typeof r=="string"?r:String(r)};return i&&(n.new_tab=!0),o!==void 0&&(n.timeout_seconds=o),{uid:(0,p.v4)(),type:"ACTION",description:`Navigate to ${r}`,action_entity:{action_description:`Navigate to ${r}`,action_data:{action_name:"go_to_url",kwargs:n}}}}if("CODE"in t){let r=t.CODE;return{uid:(0,p.v4)(),type:"ACTION",description:"Code block",action_entity:{action_description:"Code block",action_data:{action_name:"js_code",kwargs:{code:typeof r=="string"?r:String(r)}}}}}if("js"in t&&"desc"in t&&!("VERIFY"in t)){let r=t.js,i=typeof t.desc=="string"?t.desc:"";return{uid:(0,p.v4)(),type:"ACTION",description:i,action_entity:{action_description:i,action_data:{action_name:"js_action",kwargs:{code:typeof r=="string"?r:String(r)}}}}}if("action"in t)return $e(t);if("desc"in t&&typeof t.desc=="string")return{uid:(0,p.v4)(),type:"DRAFT",description:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function J(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 Ge(e){let t=J(e.IF),r=e.THEN;if(!Array.isArray(r))throw new Error("IF_ELSE requires a THEN array");let i={uid:(0,p.v4)(),type:"IF_ELSE",condition:t,then:T(r)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(i.else=T(e.ELSE)),i}function Ne(e){let t=J(e.WHILE),r=e.DO;if(!Array.isArray(r))throw new Error("WHILE_LOOP requires a DO array");let i={uid:(0,p.v4)(),type:"WHILE_LOOP",condition:t,body:T(r)};return typeof e.timeout_ms=="number"&&(i.timeout_ms=e.timeout_ms),i}function Be(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let r={uid:(0,p.v4)(),type:"STEP",description:t,statements:T(e.statements)};return typeof e.reference_id=="number"&&(r.reference_id=e.reference_id),r}function $e(e){let t=typeof e.action=="string"?e.action:String(e.action),r=typeof e.desc=="string"?e.desc:"",i=typeof e.locator=="string"?e.locator:void 0,o=typeof e.xpath=="string"?e.xpath:void 0,n=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,l={};for(let[h,d]of Object.entries(e))Re.has(h)||(l[h]=d);let a={action_description:r,action_data:{action_name:t,kwargs:Object.keys(l).length>0?l:{}}};i&&(a.locator=i),o&&(a.xpath=o);let c={uid:(0,p.v4)(),type:"ACTION",description:r,action_entity:a};return n&&(c.use_pure_vision=!0),c}var P,p,Le,j,Re,x=u(()=>{"use strict";D();P=require("yaml"),p=require("uuid");Le={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};j=1024*1024;Re=new Set(["action","desc","locator","xpath","use_pure_vision"])});var q=u(()=>{"use strict";I();x()});var Z=u(()=>{"use strict";I()});var Q,ee=u(()=>{"use strict";x();Q=require("yaml")});var te=u(()=>{"use strict"});var O=u(()=>{"use strict"});var ie=u(()=>{"use strict";O()});var oe,je,re,ne,_,Xe,Ye,se=u(()=>{"use strict";oe=112,je=1080-oe,re={"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"}},ne={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"]},_=(e,t=!1)=>{let r=["chromium"];return t&&r.push("webkit"),ne[e].map(i=>re[i]).filter(i=>i.defaultBrowserType&&r.includes(i.defaultBrowserType))},Xe={desktop:{label:"Desktop",type:"desktop",devices:_("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:_("mobile")}},Ye={desktop:{label:"Desktop",type:"desktop",devices:_("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:_("mobile",!0)}}});var ae=u(()=>{"use strict"});var ce=u(()=>{"use strict"});var le=u(()=>{"use strict"});var ue=u(()=>{"use strict"});var he=u(()=>{"use strict"});var de=u(()=>{"use strict"});var pe=u(()=>{"use strict"});var fe=u(()=>{"use strict";O()});var ge=u(()=>{"use strict";q();Z();I();ee();x();te();D();ie();se();ae();ce();le();ue();he();de();pe();fe();O()});var ye={};E(ye,{createTestFlowRouter:()=>qe});function qe(e){let t=(0,me.Router)();return t.get("/api/test-flow",async(r,i)=>{try{let o=await f.readFile(e,"utf-8"),n=A(o),l=F(o),a=await f.stat(e);i.json({testFlow:n,metadata:l,filePath:e,fileName:we.basename(e),lastModified:a.mtimeMs})}catch(o){if(o.code==="ENOENT")return i.status(404).json({error:`File not found: ${e}`});console.error("[debugger] Error loading test flow:",o),i.status(500).json({error:o.message})}}),t.put("/api/test-flow",async(r,i)=>{try{let{testFlow:o,metadata:n}=r.body;if(!o)return i.status(400).json({error:"testFlow is required"});let l=W(o,n),a=e+".tmp";await f.writeFile(a,l,"utf-8"),await f.rename(a,e);let c=await f.stat(e);i.json({success:!0,lastModified:c.mtimeMs})}catch(o){console.error("[debugger] Error saving test flow:",o),i.status(500).json({error:o.message})}}),t}var me,f,we,Se=u(()=>{"use strict";me=require("express"),f=y(require("fs/promises"),1),we=y(require("path"),1);ge()});var Me={};E(Me,{createIntRunnerRouter:()=>Ze});function Ze(e){let t=(0,be.Router)();return t.post("/api/int-runner/create-session",async(r,i)=>{try{let o=r.body.startingUrl||r.body.testFlow?.url||r.body.urlOverride,n=await e.createSession({startingUrl:o});i.json({status:"success",sessionId:n.sessionId,searchParams:""})}catch(o){console.error("[debugger] create-session error:",o),i.status(500).json({status:"error",message:o.message})}}),t.post("/api/int-runner/login",async(r,i)=>{try{let{session:o}=r.body;if(!o?.sessionId)return i.status(400).json({status:"error",message:"Missing session"});let n=await e.executeLogin(o.sessionId);i.json(n)}catch(o){console.error("[debugger] login error:",o),i.status(500).json({status:"error",details:o.message})}}),t.post("/api/int-runner/liveview-url",async(r,i)=>{let{session:o}=r.body;if(!o?.sessionId)return i.status(400).json({status:"error",message:"Missing session"});i.json({liveviewUrl:"",browserWsUrl:""})}),t.post("/api/int-runner/end-debug",async(r,i)=>{let{session:o}=r.body;if(!o?.sessionId)return i.status(400).json({status:"error",message:"Missing session"});i.json({status:"success"})}),t.post("/api/int-runner/start-debug",async(r,i)=>{try{let{session:o}=r.body;if(!o?.sessionId)return i.status(400).json({status:"error",message:"Missing session"});let n=await e.startDebug(o.sessionId);i.json({status:"success",...n})}catch(o){console.error("[debugger] start-debug error:",o),i.status(500).json({status:"error",message:o.message})}}),t.post("/api/int-runner/execute-action",async(r,i)=>{try{let{session:o,actionEntity:n,stepId:l,withSelfHealing:a,stmtUid:c,executionHistory:h}=r.body;if(!o?.sessionId||!n)return i.status(400).json({status:"error",message:"Missing session or actionEntity"});let d=await e.executeAction(o.sessionId,n,l,{withSelfHealing:a,stmtUid:c,executionHistory:h});i.json(d)}catch(o){console.error("[debugger] execute-action error:",o),i.status(500).json({status:"error",details:o.message})}}),t.post("/api/int-runner/run-step",async(r,i)=>{let{session:o,statement:n,stepId:l,executionHistory:a}=r.body;if(!o?.sessionId||!n)return i.status(400).json({success:!1,message:"Session and statement required"});i.setHeader("Content-Type","text/event-stream"),i.setHeader("Cache-Control","no-cache"),i.setHeader("Connection","keep-alive"),i.flushHeaders();let c=h=>{i.write(`data: ${JSON.stringify(h)}
1
+ "use strict";var Ze=Object.create;var W=Object.defineProperty;var Qe=Object.getOwnPropertyDescriptor;var et=Object.getOwnPropertyNames;var tt=Object.getPrototypeOf,it=Object.prototype.hasOwnProperty;var f=(e,t)=>()=>(e&&(t=e(e=0)),t);var F=(e,t)=>{for(var i in t)W(e,i,{get:t[i],enumerable:!0})},Z=(e,t,i,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of et(t))!it.call(e,o)&&o!==i&&W(e,o,{get:()=>t[o],enumerable:!(r=Qe(t,o))||r.enumerable});return e};var v=(e,t,i)=>(i=e!=null?Ze(tt(e)):{},Z(t||!e||!e.__esModule?W(i,"default",{value:e,enumerable:!0}):i,e)),rt=e=>Z(W({},"__esModule",{value:!0}),e);var ie=f(()=>{"use strict"});var re=f(()=>{"use strict"});var oe=f(()=>{"use strict"});var H=f(()=>{"use strict"});var ne=f(()=>{"use strict";H()});var se,nt,ae,ce,L,st,at,le=f(()=>{"use strict";se=112,nt=1080-se,ae={"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"}},ce={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"]},L=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),ce[e].map(r=>ae[r]).filter(r=>r.defaultBrowserType&&i.includes(r.defaultBrowserType))},st={desktop:{label:"Desktop",type:"desktop",devices:L("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:L("mobile")}},at={desktop:{label:"Desktop",type:"desktop",devices:L("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:L("mobile",!0)}}});var ue=f(()=>{"use strict"});var c,he,U,de,P,pe,fe,ge,A,V,z=f(()=>{"use strict";c=require("zod"),he=c.z.enum(["JS_CODE","AI_MODE"]),U=c.z.object({type:he,expression:c.z.string()}),de=c.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),P=c.z.object({uid:c.z.string(),type:de}),pe=c.z.object({action_data:c.z.object({action_name:c.z.string(),kwargs:c.z.record(c.z.any()).optional(),args:c.z.array(c.z.any()).optional()}),action_description:c.z.string().optional(),url:c.z.string().optional(),xpath:c.z.string().nullable().optional(),locator:c.z.string().nullable().optional(),css_selector:c.z.string().nullable().optional(),unique_selector:c.z.string().nullable().optional(),element_index:c.z.number().nullable().optional(),frame_path:c.z.array(c.z.any()).optional(),artifacts:c.z.record(c.z.any()).optional(),feedback:c.z.string().optional(),original_browser_use_action:c.z.any().optional()}).passthrough(),fe=P.extend({type:c.z.literal("DRAFT"),description:c.z.string()}),ge=P.extend({type:c.z.literal("ACTION"),description:c.z.string(),action_entity:pe.optional(),locator:c.z.string().optional(),use_pure_vision:c.z.boolean().optional()}),A=c.z.lazy(()=>c.z.union([fe,ge,P.extend({type:c.z.literal("STEP"),description:c.z.string().optional().default(""),statements:c.z.array(A),reference_id:c.z.number().optional()}),P.extend({type:c.z.literal("IF_ELSE"),description:c.z.string().optional(),condition:U,then:c.z.array(A),else:c.z.array(A).optional()}),P.extend({type:c.z.literal("WHILE_LOOP"),description:c.z.string().optional(),condition:U,body:c.z.array(A),timeout_ms:c.z.number().optional()})])),V=c.z.object({version:c.z.string().optional(),goal:c.z.string(),url:c.z.string().optional(),final_feedback:c.z.string().optional(),completed:c.z.boolean().optional(),success:c.z.boolean().optional(),statements:c.z.array(A),teardown:c.z.array(A).optional(),last_modified_at:c.z.string().optional()})});function ye(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,statements:e.statements.map(E)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(E)),i}function K(e,t){return(0,$.stringify)(ye(e,t),ct)}function E(e){switch(e.type){case"DRAFT":return lt(e);case"ACTION":return ut(e);case"STEP":return ht(e);case"IF_ELSE":return dt(e);case"WHILE_LOOP":return pt(e)}}function lt(e){return{desc:e.description}}function ut(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 a=i?.statement;if(typeof a=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"?{VERIFY:a,js:l}:{VERIFY:a}}}if(t==="go_to_url"){let a=i?.url;if(typeof a=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:a};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 a=i?.code;if(typeof a=="string"&&e.description)return{desc:e.description,js:a}}if(t==="js_code"){let a=i?.code;if(typeof a=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{CODE:a}}if(!e.action_entity)return{desc:e.description};let r=e.action_entity.action_data??e.action_entity.action;if(!r)return{desc:e.description};let o={desc:e.description,action:r.action_name},n=e.locator??e.action_entity.locator;n&&(o.locator=n);let s=e.action_entity.xpath;if(s&&(o.xpath=s),e.use_pure_vision&&(o.use_pure_vision=!0),r.kwargs&&Object.keys(r.kwargs).length>0)for(let[a,l]of Object.entries(r.kwargs))o[a]=l;return r.args&&r.args.length>0&&(o.args=r.args),o}function ht(e){let t={STEP:e.description,statements:e.statements.map(E)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function dt(e){let t={IF:_e(e.condition),THEN:e.then.map(E)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(E)),t}function pt(e){let t={WHILE:_e(e.condition),DO:e.body.map(E)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function _e(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function J(e){try{let t=(0,$.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()),i}catch{return{}}}function S(e){if(e.length>me)throw new Error(`YAML input too large (${e.length} bytes, max ${me})`);let t=(0,$.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");let i={version:"1.3.0",goal:t.goal,url:t.url,statements:x(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=x(t.teardown));let r=V.safeParse(i);if(!r.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(r.error.errors)}`);return r.data}function x(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(ft)}function ft(e){if(typeof e=="string")throw new Error(`Plain string statements are not supported. Use "desc: ${e}" instead.`);if(typeof e!="object"||e===null)throw new Error(`Invalid statement: expected object, got ${typeof e}`);let t=e;if("IF"in t)return gt(t);if("WHILE"in t)return mt(t);if("STEP"in t)return wt(t);if("VERIFY"in t){let i=t.VERIFY,r={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(r.code=t.js),{uid:(0,_.v4)(),type:"ACTION",description:`Verify: ${i}`,action_entity:{action_description:`Verify: ${i}`,action_data:{action_name:"verify",kwargs:r}}}}if("URL"in t){let i=t.URL,r=t.new_tab===!0?!0:void 0,o=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,n={url:typeof i=="string"?i:String(i)};return r&&(n.new_tab=!0),o!==void 0&&(n.timeout_seconds=o),{uid:(0,_.v4)(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:n}}}}if("CODE"in t){let i=t.CODE;return{uid:(0,_.v4)(),type:"ACTION",description:"Code block",action_entity:{action_description:"Code block",action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&"desc"in t&&!("VERIFY"in t)){let i=t.js,r=typeof t.desc=="string"?t.desc:"";return{uid:(0,_.v4)(),type:"ACTION",description:r,action_entity:{action_description:r,action_data:{action_name:"js_action",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...r}=t;return we({...r,action:"function",functionName:i})}if("action"in t)return we(t);if("desc"in t&&typeof t.desc=="string")return{uid:(0,_.v4)(),type:"DRAFT",description:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Se(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 gt(e){let t=Se(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let r={uid:(0,_.v4)(),type:"IF_ELSE",condition:t,then:x(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(r.else=x(e.ELSE)),r}function mt(e){let t=Se(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let r={uid:(0,_.v4)(),type:"WHILE_LOOP",condition:t,body:x(i)};return typeof e.timeout_ms=="number"&&(r.timeout_ms=e.timeout_ms),r}function wt(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,_.v4)(),type:"STEP",description:t,statements:x(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}function we(e){let t=typeof e.action=="string"?e.action:String(e.action),i=typeof e.desc=="string"?e.desc:"",r=typeof e.locator=="string"?e.locator:void 0,o=typeof e.xpath=="string"?e.xpath:void 0,n=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,s={};for(let[d,p]of Object.entries(e))yt.has(d)||(s[d]=p);let a={action_description:i,action_data:{action_name:t,kwargs:Object.keys(s).length>0?s:{}}};r&&(a.locator=r),o&&(a.xpath=o);let l={uid:(0,_.v4)(),type:"ACTION",description:i,action_entity:a};return n&&(l.use_pure_vision=!0),l}var $,_,ct,me,yt,G=f(()=>{"use strict";z();$=require("yaml"),_=require("uuid");ct={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};me=1024*1024;yt=new Set(["action","desc","locator","xpath","use_pure_vision"])});var be,Te=f(()=>{"use strict";G();be=require("yaml")});var B=f(()=>{"use strict"});var Ae=f(()=>{"use strict";G();B()});var ke=f(()=>{"use strict";B()});var ve=f(()=>{"use strict"});var Me=f(()=>{"use strict"});var Pe=f(()=>{"use strict"});var Ee=f(()=>{"use strict"});var xe=f(()=>{"use strict";H()});var O=f(()=>{"use strict";ie();re();oe();ne();le();ue();Te();Ae();G();z();ke();B();ve();Me();Pe();Ee();xe();H()});function vt(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Mt(e){let t=e.xpath;return typeof t=="string"&&t.trim()?!t.startsWith("xpath=")&&!t.startsWith("/")&&!t.startsWith("//")?`xpath=//${t}`:t.startsWith("xpath=")?t:`xpath=${t}`:null}function Le(e){let t=vt(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let r=Mt(e);if(r){let o=JSON.stringify(r);return`${t}.locator(${o}).first()`}return null}function u(e,t){w.set(e,t)}function k(e,t,i=[]){let r=[...i];return t.locator?r.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&r.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&r.push(`frame_path: ${JSON.stringify(t.frame_path)}`),r.length===0?[`await agent.execAction("${e}", page, {});`]:[`await agent.execAction("${e}", page, {`,...r.map(o=>` ${o},`),"});"]}function $e(e){let t=e.functionName;if(!t)return null;let i=Array.isArray(e.args)?e.args.map(String):[];if(i.length===0)return`await ${t}()`;let r=["page","testContext","request","agentServices"],o=["undefined","null","true","false"],n=i.map(s=>r.includes(s)||o.includes(s)||/^-?\d+(\.\d+)?$/.test(s)?s:s.startsWith("$")?`agent.agentServices.readVariable('${s.substring(1)}')`:`"${s}"`);return`await ${t}(${n.join(", ")})`}function Ne(e,t){let i={expandingPaths:new Set([(0,D.resolve)(t)]),depth:0,referencedPaths:new Set},r={...e};Array.isArray(r.statements)&&(r.statements=T(r.statements,t,i)),Array.isArray(r.teardown)&&(r.teardown=T(r.teardown,t,i));for(let o of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(r[o])&&(r[o]=T(r[o],t,i));return{doc:r,referencedTemplatePaths:Array.from(i.referencedPaths)}}function T(e,t,i){let r=[];for(let o of e)if(Pt(o)){let n=Et(o,t,i);r.push(...n)}else r.push(xt(o,t,i));return r}function Pt(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function Et(e,t,i){if(i.depth>=Oe)throw new Error(`Template expansion exceeded maximum depth of ${Oe}. Check for deeply nested or circular template references.`);let r=(0,D.resolve)((0,D.dirname)(t),e.template);if(i.expandingPaths.has(r))throw new Error(`Circular template reference detected: ${r} is already being expanded. Stack: ${Array.from(i.expandingPaths).join(" \u2192 ")} \u2192 ${r}`);i.referencedPaths.add(r);let o;try{o=(0,Ce.readFileSync)(r,"utf-8")}catch(p){throw new Error(`Failed to read template file: ${r} (referenced from ${t}): ${p.message}`)}let n=(0,C.parse)(o);if(!n||typeof n!="object")throw new Error(`Invalid template file: ${r} \u2014 expected a YAML object`);let s=n.params||[],a=e.params||{};for(let p of s)if(!(p in a))throw new Error(`Template ${e.template} requires param "${p}" but it was not provided. Required params: [${s.join(", ")}]`);let l=n.statements;if(!Array.isArray(l))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(a).length>0){let g=(0,C.stringify)(l);for(let[y,h]of Object.entries(a))g=g.split(`<<${y}>>`).join(String(h));l=(0,C.parse)(g)}let d={expandingPaths:new Set([...i.expandingPaths,r]),depth:i.depth+1,referencedPaths:i.referencedPaths};return T(l,r,d)}function xt(e,t,i){if(typeof e!="object"||e===null)return e;let r={...e};return Array.isArray(r.statements)&&(r.statements=T(r.statements,t,i)),Array.isArray(r.THEN)&&(r.THEN=T(r.THEN,t,i)),Array.isArray(r.ELSE)&&(r.ELSE=T(r.ELSE,t,i)),Array.isArray(r.DO)&&(r.DO=T(r.DO,t,i)),r}function De(e,t){let i=(0,N.parse)(e),r=i?.name,o=i?.tags,n=i?.use;if(i&&(i.name!==void 0||i.tags!==void 0||i.use!==void 0)&&(delete i.name,delete i.tags,delete i.use),i?.suite){if(i.goal||i.statements)throw new Error('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return Ot(i,r,o,n,t)}return $t(i,r,o,n,t)}function $t(e,t,i,r,o){let n=e?.beforeEach,s=e?.afterEach,a=We(e?.parameters),l=e?.timeout,d=e?.skip,p=e?.fail,g=e?.only,y=e?.slow;e&&(delete e.beforeEach,delete e.afterEach,delete e.parameters,delete e.timeout,delete e.skip,delete e.fail,delete e.only,delete e.slow),e&&!e.goal&&t&&(e.goal=t);let h=[];if(o&&e&&typeof e=="object"){let I=Ne(e,o);e=I.doc,h=I.referencedTemplatePaths}let m=(0,N.stringify)(e);return{testFlow:S(m),name:t,tags:i,use:r,beforeEach:n,afterEach:s,parameters:a,timeout:l,skip:d,fail:p,only:g,slow:y,referencedTemplatePaths:h}}function Ot(e,t,i,r,o){let n=e.suite;if(!Array.isArray(n.tests)||n.tests.length===0)throw new Error('Suite must have a non-empty "tests" array.');let s=n.serial,a=n.beforeAll,l=n.afterAll,d=n.beforeEach,p=n.afterEach,g=[],y=n.tests.map(h=>{if(!h.name)throw new Error('Each test in a suite must have a "name" field.');if(!Array.isArray(h.statements)||h.statements.length===0)throw new Error(`Suite test "${h.name}" must have a non-empty "statements" array.`);let m={goal:h.name,statements:h.statements};h.teardown&&(m.teardown=h.teardown);let j=[],I=m;if(o&&typeof m=="object"){let q=Ne(m,o);I=q.doc,j=q.referencedTemplatePaths,g.push(...j)}let Ye=(0,N.stringify)(I),Xe=S(Ye),qe=We(h.parameters);return{testFlow:Xe,name:h.name,parameters:qe,timeout:h.timeout,skip:h.skip,fail:h.fail,only:h.only,slow:h.slow}});return{suite:{serial:s,beforeAll:a,afterAll:l,beforeEach:d,afterEach:p,tests:y},name:t,tags:i,use:r,referencedTemplatePaths:g}}function We(e){if(!(!Array.isArray(e)||e.length===0))return e.map((t,i)=>{if(!t.name)throw new Error(`Parameter set at index ${i} must have a "name" field.`);if(!t.values||typeof t.values!="object")throw new Error(`Parameter set "${t.name}" must have a "values" object.`);return{name:t.name,values:t.values}})}var kt,N,Ce,D,C,Ie,w,Oe,Fe=f(()=>{"use strict";O();kt=require("yaml");O();N=require("yaml");O();Ce=require("fs"),D=require("path"),C=require("yaml");O();Ie=1e4;w=new Map;u("click",e=>{let t=Le(e);return t?[`await ${t}.click({ timeout: ${Ie} });`]:['await agent.execAction("click", page, {});']});u("click_element",w.get("click"));u("click_element_by_index",w.get("click"));u("double_click",e=>k("double_click",e));u("double_click_on_element",w.get("double_click"));u("right_click",e=>k("right_click",e));u("right_click_on_element",w.get("right_click"));u("hover",e=>k("hover",e));u("hover_element_by_index",w.get("hover"));u("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return k("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});u("fill",w.get("input_text"));u("clear_input",e=>k("clear_input",e));u("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});u("send_keys",w.get("press"));u("send_keys_on_element",e=>{let t=Le(e),i=e.action_data?.kwargs?.keys||"";return t?[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${Ie} });`]:['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(i)} } },`,"});"]});u("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return k("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});u("scroll",e=>{let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]});u("scroll_down",w.get("scroll"));u("scroll_up",w.get("scroll"));u("scroll_element",w.get("scroll"));u("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});u("scroll_on_element",e=>k("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));u("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});u("open_tab",w.get("go_to_url"));u("go_back",()=>['await agent.execAction("go_back", page, {});']);u("reload_page",()=>['await agent.execAction("reload_page", page, {});']);u("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);u("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);u("verify",(e,t)=>{let i=e.action_data?.kwargs,r=typeof i?.code=="string",o=i?.statement||e.action_description;if(r&&o){let s=i.code.split(`
2
+ `),a=JSON.stringify(o);return["{ const _t = Date.now(); try {",...s.map(l=>` ${l}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${a}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${a}\`);`,` await agent.assert(page, ${a}, ${JSON.stringify(t||"")});`,"} }"]}return r?i.code.split(`
3
+ `):o?[`await agent.assert(page, ${JSON.stringify(o)}, ${JSON.stringify(t||"")});`]:["// Skipping verify: missing statement or code"]});u("ai_assert",w.get("verify"));u("assert",w.get("verify"));u("ai_action",(e,t)=>{let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let r=JSON.stringify(i),o=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${r}, '${t||""}', ${o});`]});u("ai_step",(e,t)=>{let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]});u("ai_extract",(e,t)=>{let i=e.action_data?.kwargs?.element_description,r=e.action_data?.kwargs?.variable_name;if(!i||!r)return["// Skipping ai_extract: missing element_description or variable_name"];let o=JSON.stringify(i),n=JSON.stringify(r);return[`await agent.extract(page, ${o}, ${n}, '${t||""}');`]});u("ai_wait_until",(e,t)=>{let i=e.action_data?.kwargs?.condition,r=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${r}, '${t||""}');`]:["// Skipping ai_wait_until: missing condition"]});u("save_variable",e=>{let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]});u("js_code",e=>{let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],r=t.split(`
4
+ `);for(let o of r)i.push(` ${o}`);return i.push("}"),i});u("function",(e,t,i)=>{let r=e.action_data?.kwargs||{},o=r.functionName;if(o&&o.includes("#")){let[s,a]=o.split("#");if(s&&a){let l=s.replace(/\.(ts|js|mjs)$/,""),d=`import { ${a} } from '${l}';`;i?.imports?.add(d);let p={...r,functionName:a},g=$e(p);return g?[g.endsWith(";")?g:`${g};`]:["// Skipping function: invalid export pattern"]}}let n=$e(r);return n?[n.endsWith(";")?n:`${n};`]:["// Skipping function: missing functionName"]});u("generate_2fa_code",e=>{let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]});u("upload_file",e=>{let t=e.action_data?.kwargs||{},i=[],r={};return t.paths?r.paths=t.paths:t.path&&(r.path=t.path),t.use_file_input&&(r.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(r)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(o=>` ${o},`),"});"]});u("wait_for_download_complete",e=>['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]);u("switch_tab",e=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??0} } },`,"});"]);u("close_tab",e=>{let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]});u("set_date_for_native_date_picker",e=>{let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(r=>` ${r},`),"});"]});u("done",()=>["// Done - no action needed"]);u("js_action",e=>{let t=e.action_data?.kwargs?.code;return t?t.split(`
5
+ `):["// Skipping js_action: missing code"]});Oe=5});var Ge={};F(Ge,{createTestFlowRouter:()=>It});function R(e){if(!e||e.length===0)return[];let t=(0,Ke.stringify)({goal:"_hook",statements:e});return S(t).statements}function It(e){let t=(0,He.Router)();return t.get("/api/test-flow",async(i,r)=>{try{let o=await b.readFile(e,"utf-8"),n=J(o),s=De(o,e),a=await b.stat(e);s.suite?r.json({isSuite:!0,suite:{beforeAll:R(s.suite.beforeAll),afterAll:R(s.suite.afterAll),beforeEach:R(s.suite.beforeEach),afterEach:R(s.suite.afterEach),tests:s.suite.tests.map(l=>({name:l.name,testFlow:l.testFlow,skip:l.skip,timeout:l.timeout,fail:l.fail,only:l.only,slow:l.slow}))},metadata:n,name:s.name,tags:s.tags,use:s.use,filePath:e,fileName:Y.basename(e),lastModified:a.mtimeMs}):r.json({testFlow:s.testFlow,metadata:n,filePath:e,fileName:Y.basename(e),lastModified:a.mtimeMs})}catch(o){if(o.code==="ENOENT")return r.status(404).json({error:`File not found: ${e}`});console.error("[debugger] Error loading test flow:",o),r.status(500).json({error:o.message})}}),t.put("/api/test-flow",async(i,r)=>{try{let{testFlow:o,metadata:n}=i.body;if(!o)return r.status(400).json({error:"testFlow is required"});let s=K(o,n),a=e+".tmp";await b.writeFile(a,s,"utf-8"),await b.rename(a,e);let l=await b.stat(e);r.json({success:!0,lastModified:l.mtimeMs})}catch(o){console.error("[debugger] Error saving test flow:",o),r.status(500).json({error:o.message})}}),t}var He,b,Y,Ke,Be=f(()=>{"use strict";He=require("express"),b=v(require("fs/promises"),1),Y=v(require("path"),1);O();Ke=require("yaml");Fe()});var je={};F(je,{createIntRunnerRouter:()=>Lt});function Lt(e){let t=(0,Re.Router)();return t.post("/api/int-runner/create-session",async(i,r)=>{try{let o=i.body.startingUrl||i.body.testFlow?.url||i.body.urlOverride,n=await e.createSession({startingUrl:o});r.json({status:"success",sessionId:n.sessionId,searchParams:""})}catch(o){console.error("[debugger] create-session error:",o),r.status(500).json({status:"error",message:o.message})}}),t.post("/api/int-runner/login",async(i,r)=>{try{let{session:o}=i.body;if(!o?.sessionId)return r.status(400).json({status:"error",message:"Missing session"});let n=await e.executeLogin(o.sessionId);r.json(n)}catch(o){console.error("[debugger] login error:",o),r.status(500).json({status:"error",details:o.message})}}),t.post("/api/int-runner/liveview-url",async(i,r)=>{let{session:o}=i.body;if(!o?.sessionId)return r.status(400).json({status:"error",message:"Missing session"});r.json({liveviewUrl:"",browserWsUrl:""})}),t.post("/api/int-runner/end-debug",async(i,r)=>{let{session:o}=i.body;if(!o?.sessionId)return r.status(400).json({status:"error",message:"Missing session"});r.json({status:"success"})}),t.post("/api/int-runner/start-debug",async(i,r)=>{try{let{session:o}=i.body;if(!o?.sessionId)return r.status(400).json({status:"error",message:"Missing session"});let n=await e.startDebug(o.sessionId);r.json({status:"success",...n})}catch(o){console.error("[debugger] start-debug error:",o),r.status(500).json({status:"error",message:o.message})}}),t.post("/api/int-runner/execute-action",async(i,r)=>{try{let{session:o,actionEntity:n,stepId:s,withSelfHealing:a,stmtUid:l,executionHistory:d}=i.body;if(!o?.sessionId||!n)return r.status(400).json({status:"error",message:"Missing session or actionEntity"});let p=await e.executeAction(o.sessionId,n,s,{withSelfHealing:a,stmtUid:l,executionHistory:d});r.json(p)}catch(o){console.error("[debugger] execute-action error:",o),r.status(500).json({status:"error",details:o.message})}}),t.post("/api/int-runner/run-step",async(i,r)=>{let{session:o,statement:n,stepId:s,executionHistory:a}=i.body;if(!o?.sessionId||!n)return r.status(400).json({success:!1,message:"Session and statement required"});r.setHeader("Content-Type","text/event-stream"),r.setHeader("Cache-Control","no-cache"),r.setHeader("Connection","keep-alive"),r.flushHeaders();let l=d=>{r.write(`data: ${JSON.stringify(d)}
2
6
 
3
- `)};try{await e.runStep(o.sessionId,n,l,c,a)}catch(h){c({type:"error",data:{message:h.message}})}finally{i.end()}}),t.post("/api/int-runner/execute-step",async(r,i)=>{let{session:o,statement:n,stepId:l,executionHistory:a,maxSteps:c}=r.body;if(!o?.sessionId||!n)return i.status(400).json({success:!1,message:"Session and statement required"});i.setHeader("Content-Type","text/event-stream"),i.setHeader("Cache-Control","no-cache"),i.setHeader("Connection","keep-alive"),i.flushHeaders();let h=d=>{i.write(`data: ${JSON.stringify(d)}
7
+ `)};try{await e.runStep(o.sessionId,n,s,l,a)}catch(d){l({type:"error",data:{message:d.message}})}finally{r.end()}}),t.post("/api/int-runner/execute-step",async(i,r)=>{let{session:o,statement:n,stepId:s,executionHistory:a,maxSteps:l}=i.body;if(!o?.sessionId||!n)return r.status(400).json({success:!1,message:"Session and statement required"});r.setHeader("Content-Type","text/event-stream"),r.setHeader("Cache-Control","no-cache"),r.setHeader("Connection","keep-alive"),r.flushHeaders();let d=p=>{r.write(`data: ${JSON.stringify(p)}
4
8
 
5
- `)};try{await e.runStep(o.sessionId,n,l,h,a)}catch(d){h({type:"error",data:{message:d.message}})}finally{i.end()}}),t.post("/api/int-runner/stop-run-step",async(r,i)=>{try{let{session:o}=r.body;if(!o?.sessionId)return i.status(400).json({status:"error",message:"Missing session"});let n=e.stopRunStep(o.sessionId);i.json({status:"success",aborted:n})}catch(o){console.error("[debugger] stop-run-step error:",o),i.status(500).json({status:"error",aborted:!1,details:o.message})}}),t.post("/api/int-runner/evaluate",async(r,i)=>{try{let{session:o,statement:n,stepId:l,executionHistory:a}=r.body;if(!o?.sessionId||!n)return i.status(400).json({status:"error",message:"Missing session or statement"});let c=await e.evaluate(o.sessionId,n,a);i.json(c)}catch(o){console.error("[debugger] evaluate error:",o),i.status(500).json({status:"error",conclusion:"unknown",explanation:o.message})}}),t.post("/api/int-runner/generate-action",async(r,i)=>{try{let{session:o,statement:n,stepId:l,executionHistory:a,usePureVision:c,includeDebugInfo:h}=r.body;if(!o?.sessionId||!n)return i.status(400).json({status:"error",message:"Missing session or statement"});let d=await e.generateAction(o.sessionId,n,l,{executionHistory:a,usePureVision:c,includeDebugInfo:h});i.json(d)}catch(o){console.error("[debugger] generate-action error:",o),i.status(500).json({status:"error",details:o.message})}}),t.post("/api/int-runner/screenshot",async(r,i)=>{try{let{session:o}=r.body;if(!o?.sessionId)return i.status(400).json({status:"error",message:"Missing session"});let n=await e.takeScreenshot(o.sessionId);i.json({status:"success",...n})}catch(o){console.error("[debugger] screenshot error:",o),i.status(500).json({status:"error",message:o.message})}}),t.post("/api/int-runner/terminate-session",async(r,i)=>{try{let{session:o}=r.body;if(!o?.sessionId)return i.status(400).json({status:"error",message:"Missing session"});await e.terminateSession(o.sessionId),i.json({status:"success",details:`Session ${o.sessionId} terminated`})}catch(o){console.error("[debugger] terminate-session error:",o),i.status(500).json({status:"error",details:o.message})}}),t.post("/api/int-runner/session-status",async(r,i)=>{let{session:o}=r.body;if(!o?.sessionId)return i.status(400).json({status:"timed_out"});i.json({status:"active",remainingSeconds:9999})}),t}var be,Te=u(()=>{"use strict";be=require("express")});var ve={};E(ve,{createCopilotRouter:()=>Qe});function Qe(e){let t=(0,Pe.Router)();return t.post("/api/int-runner/copilot/init",async(r,i)=>{try{let{session:o,initialTestFlow:n}=r.body;if(!o?.sessionId)return i.status(400).json({success:!1,message:"Missing session"});await e.initializeCopilot(o.sessionId,n),i.json({success:!0,status:"success"})}catch(o){console.error("[debugger] copilot/init error:",o),i.status(500).json({success:!1,message:o.message})}}),t.post("/api/int-runner/copilot/send",async(r,i)=>{let{session:o,message:n,testFlow:l}=r.body;if(!o?.sessionId||!n)return i.status(400).json({success:!1,message:"Session and message required"});i.setHeader("Content-Type","text/event-stream"),i.setHeader("Cache-Control","no-cache"),i.setHeader("Connection","keep-alive"),i.flushHeaders();let a=c=>{i.write(`data: ${JSON.stringify(c)}
9
+ `)};try{await e.runStep(o.sessionId,n,s,d,a)}catch(p){d({type:"error",data:{message:p.message}})}finally{r.end()}}),t.post("/api/int-runner/stop-run-step",async(i,r)=>{try{let{session:o}=i.body;if(!o?.sessionId)return r.status(400).json({status:"error",message:"Missing session"});let n=e.stopRunStep(o.sessionId);r.json({status:"success",aborted:n})}catch(o){console.error("[debugger] stop-run-step error:",o),r.status(500).json({status:"error",aborted:!1,details:o.message})}}),t.post("/api/int-runner/evaluate",async(i,r)=>{try{let{session:o,statement:n,stepId:s,executionHistory:a}=i.body;if(!o?.sessionId||!n)return r.status(400).json({status:"error",message:"Missing session or statement"});let l=await e.evaluate(o.sessionId,n,a);r.json(l)}catch(o){console.error("[debugger] evaluate error:",o),r.status(500).json({status:"error",conclusion:"unknown",explanation:o.message})}}),t.post("/api/int-runner/generate-action",async(i,r)=>{try{let{session:o,statement:n,stepId:s,executionHistory:a,usePureVision:l,includeDebugInfo:d}=i.body;if(!o?.sessionId||!n)return r.status(400).json({status:"error",message:"Missing session or statement"});let p=await e.generateAction(o.sessionId,n,s,{executionHistory:a,usePureVision:l,includeDebugInfo:d});r.json(p)}catch(o){console.error("[debugger] generate-action error:",o),r.status(500).json({status:"error",details:o.message})}}),t.post("/api/int-runner/screenshot",async(i,r)=>{try{let{session:o}=i.body;if(!o?.sessionId)return r.status(400).json({status:"error",message:"Missing session"});let n=await e.takeScreenshot(o.sessionId);r.json({status:"success",...n})}catch(o){console.error("[debugger] screenshot error:",o),r.status(500).json({status:"error",message:o.message})}}),t.post("/api/int-runner/terminate-session",async(i,r)=>{try{let{session:o}=i.body;if(!o?.sessionId)return r.status(400).json({status:"error",message:"Missing session"});await e.terminateSession(o.sessionId),r.json({status:"success",details:`Session ${o.sessionId} terminated`})}catch(o){console.error("[debugger] terminate-session error:",o),r.status(500).json({status:"error",details:o.message})}}),t.post("/api/int-runner/session-status",async(i,r)=>{let{session:o}=i.body;if(!o?.sessionId)return r.status(400).json({status:"timed_out"});r.json({status:"active",remainingSeconds:9999})}),t}var Re,Ue=f(()=>{"use strict";Re=require("express")});var ze={};F(ze,{createCopilotRouter:()=>Ct});function Ct(e){let t=(0,Ve.Router)();return t.post("/api/int-runner/copilot/init",async(i,r)=>{try{let{session:o,initialTestFlow:n}=i.body;if(!o?.sessionId)return r.status(400).json({success:!1,message:"Missing session"});await e.initializeCopilot(o.sessionId,n),r.json({success:!0,status:"success"})}catch(o){console.error("[debugger] copilot/init error:",o),r.status(500).json({success:!1,message:o.message})}}),t.post("/api/int-runner/copilot/send",async(i,r)=>{let{session:o,message:n,testFlow:s}=i.body;if(!o?.sessionId||!n)return r.status(400).json({success:!1,message:"Session and message required"});r.setHeader("Content-Type","text/event-stream"),r.setHeader("Cache-Control","no-cache"),r.setHeader("Connection","keep-alive"),r.flushHeaders();let a=l=>{r.write(`data: ${JSON.stringify(l)}
6
10
 
7
- `)};try{await e.sendCopilotMessage(o.sessionId,n,a,l)}catch(c){a({type:"copilot_message",data:{type:"error",message:c.message},sequenceNumber:0,timestamp:new Date().toISOString()})}finally{i.end()}}),t.post("/api/int-runner/copilot/abort",async(r,i)=>{try{let{session:o}=r.body;if(!o?.sessionId)return i.status(400).json({success:!1,message:"Missing session"});let n=e.abortCopilot(o.sessionId);i.json({success:!0,status:"success",aborted:n})}catch(o){console.error("[debugger] copilot/abort error:",o),i.status(500).json({success:!1,message:o.message})}}),t.post("/api/int-runner/copilot/status",async(r,i)=>{try{let{session:o}=r.body;if(!o?.sessionId)return i.status(400).json({status:"error",message:"Missing session"});let n=e.getCopilotTestFlow(o.sessionId);i.json({status:"success",copilotInitialized:!0,testFlow:n})}catch(o){i.status(500).json({status:"error",details:o.message})}}),t}var Pe,Ae=u(()=>{"use strict";Pe=require("express")});var tt={};E(tt,{PlaywrightSandboxService:()=>S,startPlaywrightDebugServer:()=>et});module.exports=Oe(tt);var H=y(require("express"),1);var G=y(require("path"),1),N=y(require("fs/promises"),1),B=y(require("os"),1),S=class{page;agent;sessionId="pw-"+Math.random().toString(36).slice(2,10);abortController=null;constructor(t,r){this.page=t,this.agent=r}async createSession(t){return{sessionId:this.sessionId}}async executeLogin(t){return{status:"success",details:"Handled by Playwright"}}async ensureBrowser(t){return{page:this.page,liveviewUrl:""}}async startDebug(t){return{sessionId:this.sessionId,liveviewUrl:"",browserWsUrl:""}}async executeAction(t,r,i,o){let n=r.action_data||r.action;if(!n)throw new Error("ActionEntity has no action_data");if(console.error(`[pw-sandbox] executeAction stepId=${JSON.stringify(i)} action_name=${JSON.stringify(n.action_name)} locator=${JSON.stringify(r.locator)} kwargs=${JSON.stringify(n.kwargs)}`),n.action_name==="js_code"&&i==="prelude"){if(this.page.url()==="about:blank"){let c=n.kwargs?.code?.match(/PLAYWRIGHT_STARTING_URL \|\| '([^']*)'/)?.[1];c&&await this.page.goto(c,{waitUntil:"domcontentloaded"})}return{status:"success"}}let l=r.action_description||n.action_name;return{status:"success",...await this.agent.step(this.page,async()=>{await this.agent.execAction(n.action_name,this.page,r)},l,i,o?.stmtUid,!!o?.withSelfHealing)}}async runStep(t,r,i,o,n){let l=[],a={},c=this.agent._actionHandler;this.abortController=new AbortController;try{let h=await this.agent.execute(this.page,r,i,!1);return{success:h?.success??!0,actions:l,details:h?.details}}finally{this.abortController=null}}stopRunStep(t){return this.abortController?(this.abortController.abort(),!0):!1}async evaluate(t,r,i){try{let o=await this.agent.evaluate(this.page,r);return{status:"success",conclusion:o?"true":"false",explanation:o?`Condition met: ${r}`:`Condition not met: ${r}`}}catch(o){return{status:"error",conclusion:"unknown",explanation:o.message}}}async generateAction(t,r,i,o){return this.agent.generate(this.page,r,i,o?.usePureVision)}async takeScreenshot(t){let r=await this.page.screenshot(),i=G.join(B.tmpdir(),`shiplight-screenshot-${Date.now()}.png`);return await N.writeFile(i,r),{screenshot:r.toString("base64"),screenshotPath:i}}async initializeCopilot(t,r){}async sendCopilotMessage(t,r,i,o){throw new Error("Copilot not supported in Playwright debug mode")}abortCopilot(t){return!1}getCopilotTestFlow(t){}async terminateSession(t){console.error("[debugger] Playwright session released")}async cleanupAll(){}};async function et(e){let{yamlFilePath:t,port:r,page:i,agent:o}=e,n=new S(i,o),l=(0,H.default)();l.use(H.default.json({limit:"10mb"})),l.use((v,g,m)=>{if(g.setHeader("Access-Control-Allow-Origin","*"),g.setHeader("Access-Control-Allow-Methods","GET, POST, PUT, DELETE, OPTIONS"),g.setHeader("Access-Control-Allow-Headers","Content-Type"),v.method==="OPTIONS")return g.sendStatus(204);m()});let{createTestFlowRouter:a}=await Promise.resolve().then(()=>(Se(),ye)),{createIntRunnerRouter:c}=await Promise.resolve().then(()=>(Te(),Me)),{createCopilotRouter:h}=await Promise.resolve().then(()=>(Ae(),ve));l.use(a(t)),l.use(c(n)),l.use(h(n));let d=await new Promise((v,g)=>{let m=l.listen(r,"localhost",()=>v(m));m.on("error",g)});return{url:`http://localhost:${r}`,close:async()=>{await n.cleanupAll(),await new Promise((v,g)=>{d.close(m=>m?g(m):v())})}}}0&&(module.exports={PlaywrightSandboxService,startPlaywrightDebugServer});
11
+ `)};try{await e.sendCopilotMessage(o.sessionId,n,a,s)}catch(l){a({type:"copilot_message",data:{type:"error",message:l.message},sequenceNumber:0,timestamp:new Date().toISOString()})}finally{r.end()}}),t.post("/api/int-runner/copilot/abort",async(i,r)=>{try{let{session:o}=i.body;if(!o?.sessionId)return r.status(400).json({success:!1,message:"Missing session"});let n=e.abortCopilot(o.sessionId);r.json({success:!0,status:"success",aborted:n})}catch(o){console.error("[debugger] copilot/abort error:",o),r.status(500).json({success:!1,message:o.message})}}),t.post("/api/int-runner/copilot/status",async(i,r)=>{try{let{session:o}=i.body;if(!o?.sessionId)return r.status(400).json({status:"error",message:"Missing session"});let n=e.getCopilotTestFlow(o.sessionId);r.json({status:"success",copilotInitialized:!0,testFlow:n})}catch(o){r.status(500).json({status:"error",details:o.message})}}),t}var Ve,Je=f(()=>{"use strict";Ve=require("express")});var Dt={};F(Dt,{PlaywrightSandboxService:()=>M,startPlaywrightDebugServer:()=>Nt});module.exports=rt(Dt);var X=v(require("express"),1);var Q=v(require("path"),1),ee=v(require("fs/promises"),1),te=v(require("os"),1),M=class{page;agent;sessionId="pw-"+Math.random().toString(36).slice(2,10);abortController=null;constructor(t,i){this.page=t,this.agent=i}async createSession(t){return{sessionId:this.sessionId}}async executeLogin(t){return{status:"success",details:"Handled by Playwright"}}async ensureBrowser(t){return{page:this.page,liveviewUrl:""}}async startDebug(t){return{sessionId:this.sessionId,liveviewUrl:"",browserWsUrl:""}}async executeAction(t,i,r,o){let n=i.action_data||i.action;if(!n)throw new Error("ActionEntity has no action_data");if(console.error(`[pw-sandbox] executeAction stepId=${JSON.stringify(r)} action_name=${JSON.stringify(n.action_name)} locator=${JSON.stringify(i.locator)} kwargs=${JSON.stringify(n.kwargs)}`),n.action_name==="js_code"&&r==="prelude"){if(this.page.url()==="about:blank"){let l=n.kwargs?.code?.match(/PLAYWRIGHT_STARTING_URL \|\| '([^']*)'/)?.[1];l&&await this.page.goto(l,{waitUntil:"domcontentloaded"})}return{status:"success"}}let s=i.action_description||n.action_name;return{status:"success",...await this.agent.step(this.page,async()=>{await this.agent.execAction(n.action_name,this.page,i)},s,r,o?.stmtUid,!!o?.withSelfHealing)}}async runStep(t,i,r,o,n){let s=[],a={},l=this.agent._actionHandler;this.abortController=new AbortController;try{let d=await this.agent.execute(this.page,i,r,!1);return{success:d?.success??!0,actions:s,details:d?.details}}finally{this.abortController=null}}stopRunStep(t){return this.abortController?(this.abortController.abort(),!0):!1}async evaluate(t,i,r){try{let o=await this.agent.evaluate(this.page,i);return{status:"success",conclusion:o?"true":"false",explanation:o?`Condition met: ${i}`:`Condition not met: ${i}`}}catch(o){return{status:"error",conclusion:"unknown",explanation:o.message}}}async generateAction(t,i,r,o){return this.agent.generate(this.page,i,r,o?.usePureVision)}async takeScreenshot(t){let i=await this.page.screenshot(),r=Q.join(te.tmpdir(),`shiplight-screenshot-${Date.now()}.png`);return await ee.writeFile(r,i),{screenshot:i.toString("base64"),screenshotPath:r}}async initializeCopilot(t,i){}async sendCopilotMessage(t,i,r,o){throw new Error("Copilot not supported in Playwright debug mode")}abortCopilot(t){return!1}getCopilotTestFlow(t){}async terminateSession(t){console.error("[debugger] Playwright session released")}async cleanupAll(){}};async function Nt(e){let{yamlFilePath:t,port:i,page:r,agent:o}=e,n=new M(r,o),s=(0,X.default)();s.use(X.default.json({limit:"10mb"})),s.use((y,h,m)=>{if(h.setHeader("Access-Control-Allow-Origin","*"),h.setHeader("Access-Control-Allow-Methods","GET, POST, PUT, DELETE, OPTIONS"),h.setHeader("Access-Control-Allow-Headers","Content-Type"),y.method==="OPTIONS")return h.sendStatus(204);m()});let{createTestFlowRouter:a}=await Promise.resolve().then(()=>(Be(),Ge)),{createIntRunnerRouter:l}=await Promise.resolve().then(()=>(Ue(),je)),{createCopilotRouter:d}=await Promise.resolve().then(()=>(Je(),ze));s.use(a(t)),s.use(l(n)),s.use(d(n));let p=await new Promise((y,h)=>{let m=s.listen(i,"localhost",()=>y(m));m.on("error",h)});return{url:`http://localhost:${i}`,close:async()=>{await n.cleanupAll(),await new Promise((y,h)=>{p.close(m=>m?h(m):y())})}}}0&&(module.exports={PlaywrightSandboxService,startPlaywrightDebugServer});