shiplightai 0.1.5 → 0.1.6

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.
@@ -1,14 +1,28 @@
1
- "use strict";var Le=Object.create;var N=Object.defineProperty;var Ie=Object.getOwnPropertyDescriptor;var De=Object.getOwnPropertyNames;var $e=Object.getPrototypeOf,Ce=Object.prototype.hasOwnProperty;var We=(e,t)=>{for(var i in t)N(e,i,{get:t[i],enumerable:!0})},Y=(e,t,i,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of De(t))!Ce.call(e,n)&&n!==i&&N(e,n,{get:()=>t[n],enumerable:!(r=Ie(t,n))||r.enumerable});return e};var b=(e,t,i)=>(i=e!=null?Le($e(e)):{},Y(t||!e||!e.__esModule?N(i,"default",{value:e,enumerable:!0}):i,e)),Ne=e=>Y(N({},"__esModule",{value:!0}),e);var mt={};We(mt,{authSetup:()=>Me,resolveLoginConfig:()=>B,shiplightConfig:()=>ve});module.exports=Ne(mt);var S=b(require("fs"),1),g=b(require("path"),1),Pe=b(require("dotenv"),1),Ae=require("glob");var w=require("fs"),_e=require("path"),ye=require("glob");var G=require("yaml");var q=112;var Ke=1080-q;var Z={"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"}};var Q={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"),Q[e].map(r=>Z[r]).filter(r=>r.defaultBrowserType&&i.includes(r.defaultBrowserType))};var Fe={desktop:{label:"Desktop",type:"desktop",devices:L("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:L("mobile")}},He={desktop:{label:"Desktop",type:"desktop",devices:L("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:L("mobile",!0)}};var a=require("zod"),ee=a.z.enum(["JS_CODE","AI_MODE"]),R=a.z.object({type:ee,expression:a.z.string()}),te=a.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),x=a.z.object({uid:a.z.string(),type:te}),ie=a.z.object({action_data:a.z.object({action_name:a.z.string(),kwargs:a.z.record(a.z.any()).optional(),args:a.z.array(a.z.any()).optional()}),action_description:a.z.string().optional(),url:a.z.string().optional(),xpath:a.z.string().nullable().optional(),locator:a.z.string().nullable().optional(),css_selector:a.z.string().nullable().optional(),unique_selector:a.z.string().nullable().optional(),element_index:a.z.number().nullable().optional(),frame_path:a.z.array(a.z.any()).optional(),artifacts:a.z.record(a.z.any()).optional(),feedback:a.z.string().optional(),original_browser_use_action:a.z.any().optional()}).passthrough(),re=x.extend({type:a.z.literal("DRAFT"),description:a.z.string()}),ne=x.extend({type:a.z.literal("ACTION"),description:a.z.string(),action_entity:ie.optional(),locator:a.z.string().optional(),use_pure_vision:a.z.boolean().optional()}),M=a.z.lazy(()=>a.z.union([re,ne,x.extend({type:a.z.literal("STEP"),description:a.z.string().optional().default(""),statements:a.z.array(M),reference_id:a.z.number().optional()}),x.extend({type:a.z.literal("IF_ELSE"),description:a.z.string().optional(),condition:R,then:a.z.array(M),else:a.z.array(M).optional()}),x.extend({type:a.z.literal("WHILE_LOOP"),description:a.z.string().optional(),condition:R,body:a.z.array(M),timeout_ms:a.z.number().optional()})])),U=a.z.object({version:a.z.string().optional(),goal:a.z.string(),url:a.z.string(),final_feedback:a.z.string().optional(),completed:a.z.boolean().optional(),success:a.z.boolean().optional(),statements:a.z.array(M),teardown:a.z.array(M).optional(),last_modified_at:a.z.string().optional()});var z=require("yaml"),y=require("uuid");var oe=1024*1024;function V(e){if(e.length>oe)throw new Error(`YAML input too large (${e.length} bytes, max ${oe})`);let t=(0,z.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");let i={version:"1.2.0",goal:t.goal,url:t.url,statements:E(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=E(t.teardown));let r=U.safeParse(i);if(!r.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(r.error.errors)}`);return r.data}function E(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Be)}function Be(e){if(typeof e=="string")return Re(e);if(typeof e!="object"||e===null)throw new Error(`Invalid statement: expected string or object, got ${typeof e}`);let t=e;if("IF"in t)return Ue(t);if("WHILE"in t)return ze(t);if("STEP"in t)return Ve(t);if("action_entity"in t)return Xe(t);if("description"in t&&typeof t.description=="string")return{uid:(0,y.v4)(),type:"DRAFT",description:t.description};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Re(e){let t=e.match(/^VERIFY:\s*(.+)$/i);return t?{uid:(0,y.v4)(),type:"ACTION",description:`Verify: ${t[1]}`,action_entity:{action_description:`Verify: ${t[1]}`,action_data:{action_name:"verify",kwargs:{statement:t[1]}}}}:{uid:(0,y.v4)(),type:"DRAFT",description:e}}function ae(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 Ue(e){let t=ae(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let r={uid:(0,y.v4)(),type:"IF_ELSE",condition:t,then:E(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(r.else=E(e.ELSE)),r}function ze(e){let t=ae(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let r={uid:(0,y.v4)(),type:"WHILE_LOOP",condition:t,body:E(i)};return typeof e.timeout_ms=="number"&&(r.timeout_ms=e.timeout_ms),r}function Ve(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,y.v4)(),type:"STEP",description:t,statements:E(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}function Xe(e){let t=typeof e.description=="string"?e.description:"",i=e.action_entity,r;i&&(r={action_description:t,...i});let n={uid:(0,y.v4)(),type:"ACTION",description:t};return r&&(n.action_entity=r),typeof e.locator=="string"&&(n.locator=e.locator),typeof e.use_pure_vision=="boolean"&&(n.use_pure_vision=e.use_pure_vision),n}var X=18e4;var ce=require("fs"),D=require("path"),I=require("yaml"),se=5;function le(e,t){let i={expandingPaths:new Set([(0,D.resolve)(t)]),depth:0,referencedPaths:new Set},r={...e};return Array.isArray(r.statements)&&(r.statements=k(r.statements,t,i)),Array.isArray(r.teardown)&&(r.teardown=k(r.teardown,t,i)),{doc:r,referencedTemplatePaths:Array.from(i.referencedPaths)}}function k(e,t,i){let r=[];for(let n of e)if(Ye(n)){let o=qe(n,t,i);r.push(...o)}else r.push(Ze(n,t,i));return r}function Ye(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function qe(e,t,i){if(i.depth>=se)throw new Error(`Template expansion exceeded maximum depth of ${se}. 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 n;try{n=(0,ce.readFileSync)(r,"utf-8")}catch(h){throw new Error(`Failed to read template file: ${r} (referenced from ${t}): ${h.message}`)}let o=(0,I.parse)(n);if(!o||typeof o!="object")throw new Error(`Invalid template file: ${r} \u2014 expected a YAML object`);let l=o.params||[],u=e.params||{};for(let h of l)if(!(h in u))throw new Error(`Template ${e.template} requires param "${h}" but it was not provided. Required params: [${l.join(", ")}]`);let p=o.statements;if(!Array.isArray(p))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(u).length>0){let d=(0,I.stringify)(p);for(let[_,v]of Object.entries(u))d=d.replaceAll(`{{${_}}}`,String(v));p=(0,I.parse)(d)}let s={expandingPaths:new Set([...i.expandingPaths,r]),depth:i.depth+1,referencedPaths:i.referencedPaths};return k(p,r,s)}function Ze(e,t,i){if(typeof e!="object"||e===null)return e;let r={...e};return Array.isArray(r.statements)&&(r.statements=k(r.statements,t,i)),Array.isArray(r.THEN)&&(r.THEN=k(r.THEN,t,i)),Array.isArray(r.ELSE)&&(r.ELSE=k(r.ELSE,t,i)),Array.isArray(r.DO)&&(r.DO=k(r.DO,t,i)),r}function ue(e,t){let i=(0,G.parse)(e),r=i?.name,n=i?.tags,o=i?.use;i&&(i.name!==void 0||i.tags!==void 0||i.use!==void 0)&&(delete i.name,delete i.tags,delete i.use);let l=[];if(t&&i&&typeof i=="object"){let s=le(i,t);i=s.doc,l=s.referencedTemplatePaths}let u=(0,G.stringify)(i);return{testFlow:V(u),name:r,tags:n,use:o,referencedTemplatePaths:l}}function K(e){return e.replace(/\\/g,"\\\\").replace(/'/g,"\\'").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/\t/g,"\\t")}function T(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function Qe(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function et(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 J(e){let t=Qe(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let r=et(e);if(r){let n=JSON.stringify(r);return`${t}.locator(${n}).first()`}return null}var tt=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],it=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"];function he(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:tt.includes(t)}function pe(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!it.includes(t)}var f=new Map;function c(e,t){f.set(e,t)}function ge(e){return f.get(e)}function P(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(n=>` ${n},`),"});"]}c("click",e=>{let t=J(e);return t?[`await ${t}.click({ timeout: ${5e3} });`]:['await agent.execAction("click", page, {});']});c("click_element",f.get("click"));c("click_element_by_index",f.get("click"));c("double_click",e=>P("double_click",e));c("double_click_on_element",f.get("double_click"));c("right_click",e=>P("right_click",e));c("right_click_on_element",f.get("right_click"));c("hover",e=>P("hover",e));c("hover_element_by_index",f.get("hover"));c("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return P("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});c("fill",f.get("input_text"));c("clear_input",e=>P("clear_input",e));c("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});c("send_keys",f.get("press"));c("send_keys_on_element",e=>{let t=J(e),i=e.action_data?.kwargs?.keys||"";return t?[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${5e3} });`]:['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(i)} } },`,"});"]});c("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return P("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});c("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)})');`]});c("scroll_down",f.get("scroll"));c("scroll_up",f.get("scroll"));c("scroll_element",f.get("scroll"));c("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});c("scroll_on_element",e=>P("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));c("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)} } },`,"});"]});c("open_tab",f.get("go_to_url"));c("go_back",()=>['await agent.execAction("go_back", page, {});']);c("reload_page",()=>['await agent.execAction("reload_page", page, {});']);c("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);c("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);c("verify",(e,t)=>{let i=e.action_data?.kwargs;if(i?.code)return i.code.split(`
2
- `);let r=i?.statement||e.action_description;return r?[`await agent.assert(page, ${JSON.stringify(r)}, '${t||""}');`]:["// Skipping verify: missing statement or code"]});c("ai_assert",f.get("verify"));c("assert",f.get("verify"));c("ai_action",(e,t)=>{let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let r=JSON.stringify(i),n=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${r}, '${t||""}', ${n});`]});c("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"]});c("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 n=JSON.stringify(i),o=JSON.stringify(r);return[`await agent.extract(page, ${n}, ${o}, '${t||""}');`]});c("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"]});c("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)} } },`,"});"]});c("js_code",e=>{let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],r=t.split(`
3
- `);for(let n of r)i.push(` ${n}`);return i.push("}"),i});c("function",(e,t,i)=>{let r=e.action_data?.kwargs||{},n=r.functionName;if(n&&n.includes("#")){let[l,u]=n.split("#");if(l&&u){let p=l.replace(/\.(ts|js|mjs)$/,""),s=`import { ${u} } from '${p}';`;i?.imports?.add(s);let h={...r,functionName:u},d=de(h);return d?[d.endsWith(";")?d:`${d};`]:["// Skipping function: invalid export pattern"]}}let o=de(r);return o?[o.endsWith(";")?o:`${o};`]:["// Skipping function: missing functionName"]});c("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)} } },`,"});"]});c("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(n=>` ${n},`),"});"]});c("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} } },`,"});"]);c("switch_tab",e=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??0} } },`,"});"]);c("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} } },`,"});"]});c("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},`),"});"]});c("done",()=>["// Done - no action needed"]);function de(e){let t=e.functionName;if(!t)return null;let i={},r=e.parameterNames||[],n=e.parameterValues||e.args||[];if(r.forEach((p,s)=>{s<n.length&&(i[p]=n[s])}),Object.keys(i).length===0)return`await ${t}()`;let o=["page","testContext","request","agentServices"],l=["undefined","null","true","false"],u=Object.entries(i).map(([p,s])=>{let h=String(s);return s==null?"undefined":o.includes(p)&&o.includes(h)||l.includes(h)||/^-?\d+(\.\d+)?$/.test(h)?h:h.startsWith("$")?`agent.agentServices.readVariable('${h.substring(1)}')`:`"${h}"`});return`await ${t}(${u.join(", ")})`}function m(e,t,i,r="main"){let n=[];for(let o=0;o<e.length;o++){let l=e[o],u=`${r}.${o}`,p=rt(l,t,u,i);p.length>0&&(n.push(...p),o<e.length-1&&n.push(""))}return n}function rt(e,t,i,r){let n=" ".repeat(t);switch(e.type){case"DRAFT":return nt(e,t,i);case"ACTION":return ot(e,t,i,r);case"STEP":return at(e,t,i,r);case"IF_ELSE":return st(e,t,i,r);case"WHILE_LOOP":return ct(e,t,i,r);default:return[`${n}// Unknown statement type: ${e.type}`]}}function nt(e,t,i){let r=" ".repeat(t),n=e.description?.trim()||"";if(!n)return[`${r}// ${i}: Skipping - no description`];let o=JSON.stringify(n);return[`${r}// ${i}: ${T(n)}`,`${r}page = agent.agentServices.validatePage(page);`,`${r}await agent.run(page, ${o}, '${i}');`]}function ot(e,t,i,r){let n=" ".repeat(t),o=e.description,l=e.uid,p=r.actionEntityStore?.entries[e.uid]?.action_entity??e.action_entity;if(!p){if(!o)return[`${n}// ${i}: Skipping - no description`];let O=JSON.stringify(o),Oe=!!e.use_pure_vision;return[`${n}// ${i}: ${T(o)}`,`${n}page = agent.agentServices.validatePage(page);`,`${n}await agent.execute(page, ${O}, '${i}', ${Oe});`]}let s=e.locator?{...p,locator:e.locator}:p;o&&o!==s.action_description&&(s={...s,action_description:o});let h=s.action_data?.action_name||"",d=s.action_description||"",_=ge(h);if(!_)return[`${n}// ${i}: Unknown action: ${h}`];let v={imports:r.imports},C=_(s,i,v);if(he(s))return[`${n}// ${i}: ${T(d)}`,`${n}page = agent.agentServices.validatePage(page);`,...C.map(O=>`${n}${O}`)];let j=JSON.stringify(d),W=C.map(O=>`${n} ${O}`),xe=pe(s),Ee=l?`'${l}'`:"undefined";return[`${n}// ${i}: ${T(d)}`,`${n}page = agent.agentServices.validatePage(page);`,`${n}await agent.step(page, async () => {`,...W,`${n}}, ${j}, '${i}', ${Ee}, ${xe});`]}function at(e,t,i,r){let n=" ".repeat(t),o=[];e.description&&e.description.trim()&&o.push(`${n}// Step: ${T(e.description)}`);let l=m(e.statements,t,r,i);return o.push(...l),o}function st(e,t,i,r){let n=" ".repeat(t),o=[];if(o.push(`${n}// ${i}: Conditional check`),e.condition.type==="JS_CODE")o.push(`${n}if (${e.condition.expression}) {`);else{o.push(`${n}// AI Condition: ${T(e.condition.expression)}`);let u=JSON.stringify(e.condition.expression);o.push(`${n}if (await agent.evaluate(page, ${u}, "${i}")) {`)}let l=m(e.then,t+1,r,`${i}.then`);if(o.push(...l),e.else&&e.else.length>0){o.push(`${n}} else {`);let u=m(e.else,t+1,r,`${i}.else`);o.push(...u)}return o.push(`${n}}`),o}function ct(e,t,i,r){let n=" ".repeat(t),o=[];o.push(`${n}// ${i}: Loop`);let l=e.timeout_ms??X,u=l/1e3,p=e.timeout_ms?`While loop exceeded timeout of ${u}s`:`While loop exceeded default timeout of ${u}s`,s=`loop_${i.replace(/\./g,"_")}`;if(o.push(`${n}const ${s}_start = Date.now();`),o.push(`${n}const ${s}_timeout = ${l};`),o.push(`${n}const ${s}_check = () => {`),o.push(`${n} if (Date.now() - ${s}_start > ${s}_timeout) {`),o.push(`${n} throw new Error('${p}');`),o.push(`${n} }`),o.push(`${n} return true;`),o.push(`${n}};`),e.condition.type==="JS_CODE")o.push(`${n}while (${s}_check() && (${e.condition.expression})) {`);else{o.push(`${n}// AI Loop Condition: ${T(e.condition.expression)}`);let d=JSON.stringify(e.condition.expression);o.push(`${n}while (${s}_check() && await agent.evaluate(page, ${d}, "${i}")) {`)}let h=m(e.body,t+1,r,`${i}.body`);return o.push(...h),o.push(`${n}}`),o}var me={name:"shiplightai",version:"0.1.5",type:"module",description:"Shiplight CLI for running and debugging .test.yaml files",main:"dist/index.js",types:"dist/index.d.ts",bin:{shiplight:"dist/cli.js"},exports:{".":{types:"./dist/index.d.ts",import:"./dist/index.js",require:"./dist/cjs/index.cjs",default:"./dist/index.js"},"./fixture":{types:"./dist/fixture.d.ts",import:"./dist/fixture.js",require:"./dist/cjs/fixture.cjs",default:"./dist/fixture.js"}},files:["dist","README.md"],publishConfig:{registry:"https://registry.npmjs.org",access:"public"},scripts:{build:"tsup","build:cli":"tsup",clean:"rm -rf dist",dev:"tsup --watch",test:"playwright test",typecheck:"tsc --noEmit"},dependencies:{"@babel/plugin-transform-typescript":"^7.27.0","@babel/preset-env":"^7.26.9","@babel/preset-typescript":"^7.27.0","@anthropic-ai/claude-agent-sdk":"^0.1.72","@modelcontextprotocol/sdk":"^0.5.0",axios:"^1.6.0",dotenv:"^16.0.3",express:"^4.21.0",glob:"^13.0.0",open:"^10.1.0",sharp:"^0.34.5",uuid:"^11.1.0",yaml:"^2.8.0",zod:"^3.22.0","zod-to-json-schema":"^3.24.6"},devDependencies:{"@playwright/test":"1.55.0","@shiplightai/sdk-pro":"workspace:*","@types/express":"^4.17.21","@types/node":"^24.0.0",copilot3:"workspace:*","mcp-tools":"workspace:*","sdk-core":"workspace:*","sdk-internal":"workspace:*","shiplight-types":"workspace:*",tsup:"^8.3.5",typescript:"5.5.4","web-session":"workspace:*"},peerDependencies:{"@playwright/test":"1.55.0","@shiplightai/sdk-pro":">=0.2.0"},engines:{node:">=22.0.0"},keywords:["playwright","yaml","testing","automation","ai","shiplight","mcp"],author:"Shiplight",license:"MIT"};var F=me.version;function we(e,t){let i=[];i.push(`// @generated by shiplightai v${F}`),i.push(...ut()),i.push(""),t?.use&&Object.keys(t.use).length>0&&(i.push(`test.use(${JSON.stringify(t.use,null,2)});`),i.push(""));let r=t?.testName||e.goal||"Generated test",n=t?.tags&&t.tags.length>0?t.tags.map(s=>`@${s}`).join(" ")+" ":"";i.push(`test('${n}${K(r)}', async ({ page, agent }) => {`);let o=t?.startingUrl||e.url;if(o){let s;try{s=new URL(o).pathname}catch{s=o}i.push(` await page.goto('${K(s)}', { waitUntil: 'domcontentloaded' });`),i.push("")}let l=new Set,u={imports:l};if(e.teardown&&e.teardown.length>0){if(i.push(" try {"),e.statements&&e.statements.length>0){i.push(" // Test steps");let h=m(e.statements,2,u);i.push(...h)}i.push(" } finally {"),i.push(" // Teardown");let s=m(e.teardown,2,u,"teardown");i.push(...s),i.push(" }")}else if(e.statements&&e.statements.length>0){i.push(" // Test steps");let s=m(e.statements,1,u);i.push(...s)}if(i.push("});"),l.size>0){let s=0;for(let d=0;d<i.length;d++)i[d].startsWith("import ")&&(s=d+1);let h=Array.from(l);i.splice(s,0,...h)}return i.join(`
4
- `)}function ut(){return["import { test, expect } from 'shiplightai/fixture';"]}function Se(e){try{return(0,w.statSync)(e).mtimeMs}catch{return 0}}var ht=`// @generated by shiplightai v${F}`;function pt(e,t){if(!(0,w.existsSync)(e)||(0,w.readFileSync)(e,"utf-8").split(`
5
- `,1)[0]!==ht)return!1;let r=Se(e);for(let n of t)if(Se(n)>r)return!1;return!0}function Te(e){let t=(0,ye.globSync)("**/*.test.yaml",{cwd:e.cwd,ignore:["**/node_modules/**"]}),i=[];for(let r of t){let n=(0,_e.resolve)(e.cwd,r),o=n.replace(/\.test\.yaml$/,".yaml.spec.ts"),l=(0,w.readFileSync)(n,"utf-8");try{let{testFlow:u,name:p,tags:s,use:h,referencedTemplatePaths:d}=ue(l,n);if(pt(o,[n,...d]))continue;let _=we(u,{testName:p,tags:s,use:h});(0,w.writeFileSync)(o,_)}catch(u){console.error(`[shiplight] Failed to transpile ${r}:`,u),i.push({file:r,error:u})}}if(i.length>0)throw new Error(`[shiplight] Transpilation failed for ${i.length} file(s):
1
+ "use strict";var Di=Object.create;var oe=Object.defineProperty;var $i=Object.getOwnPropertyDescriptor;var Ci=Object.getOwnPropertyNames;var Wi=Object.getPrototypeOf,Ni=Object.prototype.hasOwnProperty;var m=(e,t)=>()=>(e&&(t=e(e=0)),t);var Qe=(e,t)=>{for(var i in t)oe(e,i,{get:t[i],enumerable:!0})},et=(e,t,i,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of Ci(t))!Ni.call(e,n)&&n!==i&&oe(e,n,{get:()=>t[n],enumerable:!(r=$i(t,n))||r.enumerable});return e};var H=(e,t,i)=>(i=e!=null?Di(Wi(e)):{},et(t||!e||!e.__esModule?oe(i,"default",{value:e,enumerable:!0}):i,e)),Gi=e=>et(oe({},"__esModule",{value:!0}),e);var tt,it=m(()=>{"use strict";tt=class{version;goal;url;constructor(e,t){this.version=e,this.goal=t.goal,this.url=t.url}generatePrelude(){let e=`// version ${this.version}
2
+ `,t=this.goal,i=this.url;e+=`// Navigate to the specified URL
3
+ const targetUrl = process.env.PLAYWRIGHT_STARTING_URL || '${i}';
4
+ if (targetUrl !== null) {
5
+ await page.goto(targetUrl, { waitUntil: 'domcontentloaded' });
6
+ }
7
+
8
+ // wait for page to load and give it a chance to stabilize
9
+ await page.waitForLoadState('load', { timeout: 15000 });
10
+ await page.waitForTimeout(2000);
11
+
12
+ `,e+=` // Goal:
13
+ `;let r=t.trim().split(`
14
+ `);for(let n of r)e+=` // ${n}
15
+ `;return e}generatePostlude(){return""}}});function rt(e){if(!e)return"desktop";for(let t of Ki)if(t.test(e))return"mobile";return"desktop"}var Ki,nt=m(()=>{"use strict";Ki=[/iphone/i,/ipad/i,/android/i,/pixel/i,/galaxy/i,/mobile/i,/nexus/i,/blackberry/i,/kindle/i]});function ot(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,r=o=>{let a=o.startsWith("$")?o.slice(1):o,s=i[a]??i[`$${a}`];return s!=null?String(s):void 0},n=e;return n=n.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(o,a)=>{let s=r(a.trim());return s!==void 0?s:o}),n=n.replace(/<secret>\$?([\w-]+)<\/secret>/g,(o,a)=>{let s=r(a);return s!==void 0?s:o}),n=n.replace(/\$\{([^}]+)\}/g,(o,a)=>{let s=r(a.trim());return s!==void 0?s:o}),n=n.replace(/\$([a-zA-Z_]\w*)/g,(o,a)=>{let s=r(a);return s!==void 0?s:o}),n}var at=m(()=>{"use strict"});function st(e){return e?e.startsWith(b)?"android":e.startsWith(M)?"ios":"web":"web"}function ct(e){return e?e.startsWith(b)||e.startsWith(M):!1}function lt(e){return!!e&&e.startsWith(b)}function ut(e){return!!e&&e.startsWith(M)}function ht(e){return e.startsWith(b)?e.slice(b.length):e.startsWith(M)?e.slice(M.length):e}function pt(e){return`${b}${e}`}function dt(e){return`${M}${e}`}function ae(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function ft(e){return e?!ae(e):!1}function Te(e){return e?ae(e)?["web"]:["android","ios"]:["web","android","ios"]}function gt(e,t){if(!t)return!0;let i=Te(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var b,M,se=m(()=>{"use strict";b="android:",M="ios:"});function mt(e){return e.startsWith(M)?e:`${M}${e}`}function wt(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function St(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var _t=m(()=>{"use strict";se()});var be,ce,Me,ke,Pe,Ae,ve,xe,Ee,Oe,F,Le,q,Ie,De,J,yt,Z,Tt,bt,le,Mt,kt,Pt,At,vt=m(()=>{"use strict";be="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",ce=112,Me=1920,ke=1080,Pe=1920,Ae=1080-ce,ve=1280,xe=720,Ee=500,Oe=500,F="Desktop Chrome",Le=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Le||{}),q={"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"}},Ie=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Ie||{}),De={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"]},J=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),De[e].map(r=>q[r]).filter(r=>r.defaultBrowserType&&i.includes(r.defaultBrowserType))},yt=()=>Object.keys(q),Z=e=>q[e],Tt={desktop:{label:"Desktop",type:"desktop",devices:J("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:J("mobile")}},bt={desktop:{label:"Desktop",type:"desktop",devices:J("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:J("mobile",!0)}},le=(e,t=!1)=>{let i={userAgent:be,viewport:{width:Pe,height:Ae},isMobile:!1,hasTouch:!1};if(!e||e===F)return i;let r=Z(e);if(!r)return i;let{width:n,height:o}=r.viewport,a=Math.max(Ee/n,1),s=Math.max(Oe/o,1),l=Math.max(a,s),c={width:Math.round(n*l),height:Math.round(o*l)};return{userAgent:r.userAgent,viewport:t?c:r.viewport,isMobile:r.isMobile,hasTouch:r.hasTouch}},Mt=e=>{let t={width:Me,height:ke};if(!e||e===F)return t;let i=le(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+ce}:t},kt=e=>{let t={width:ve,height:xe};if(!e||e===F)return t;let i=le(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Pt=e=>!e||e===F?void 0:Z(e)?.channel,At=e=>!e||e===F?"chromium":Z(e)?.defaultBrowserType??"chromium"});var $e,Ce,xt=m(()=>{"use strict";$e=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))($e||{}),Ce=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Ce||{})});var h,We,ue,Ne,B,Ge,Ke,He,O,he,Fe=m(()=>{"use strict";h=require("zod"),We=h.z.enum(["JS_CODE","AI_MODE"]),ue=h.z.object({type:We,expression:h.z.string()}),Ne=h.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),B=h.z.object({uid:h.z.string(),type:Ne}),Ge=h.z.object({action_data:h.z.object({action_name:h.z.string(),kwargs:h.z.record(h.z.any()).optional(),args:h.z.array(h.z.any()).optional()}),action_description:h.z.string().optional(),url:h.z.string().optional(),xpath:h.z.string().nullable().optional(),locator:h.z.string().nullable().optional(),css_selector:h.z.string().nullable().optional(),unique_selector:h.z.string().nullable().optional(),element_index:h.z.number().nullable().optional(),frame_path:h.z.array(h.z.any()).optional(),artifacts:h.z.record(h.z.any()).optional(),feedback:h.z.string().optional(),original_browser_use_action:h.z.any().optional()}).passthrough(),Ke=B.extend({type:h.z.literal("DRAFT"),description:h.z.string()}),He=B.extend({type:h.z.literal("ACTION"),description:h.z.string(),action_entity:Ge.optional(),locator:h.z.string().optional(),use_pure_vision:h.z.boolean().optional()}),O=h.z.lazy(()=>h.z.union([Ke,He,B.extend({type:h.z.literal("STEP"),description:h.z.string().optional().default(""),statements:h.z.array(O),reference_id:h.z.number().optional()}),B.extend({type:h.z.literal("IF_ELSE"),description:h.z.string().optional(),condition:ue,then:h.z.array(O),else:h.z.array(O).optional()}),B.extend({type:h.z.literal("WHILE_LOOP"),description:h.z.string().optional(),condition:ue,body:h.z.array(O),timeout_ms:h.z.number().optional()})])),he=h.z.object({version:h.z.string().optional(),goal:h.z.string(),url:h.z.string(),final_feedback:h.z.string().optional(),completed:h.z.boolean().optional(),success:h.z.boolean().optional(),statements:h.z.array(O),teardown:h.z.array(O).optional(),last_modified_at:h.z.string().optional()})});function Ot(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},goal:e.goal,url:e.url,statements:e.statements.map(j)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(j)),(0,Q.stringify)(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"})}function j(e){switch(e.type){case"DRAFT":return Hi(e);case"ACTION":return Fi(e);case"STEP":return Ri(e);case"IF_ELSE":return Ui(e);case"WHILE_LOOP":return zi(e)}}function Hi(e){return e.description}function Fi(e){if((e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name)==="verify"){let o=(e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs)?.statement;if(typeof o=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return`VERIFY: ${o}`}if(!e.action_entity)return e.description;let i={description:e.description},r=Bi(e.action_entity);return r&&(i.action_entity=r),e.locator&&(i.locator=e.locator),e.use_pure_vision&&(i.use_pure_vision=!0),i}function Bi(e){let t={},i=!1,r=e.action_data??e.action;return r&&(t.action_data={action_name:r.action_name},r.kwargs&&Object.keys(r.kwargs).length>0&&(t.action_data.kwargs=r.kwargs),r.args&&r.args.length>0&&(t.action_data.args=r.args),i=!0),e.locator&&(t.locator=e.locator,i=!0),e.xpath&&(t.xpath=e.xpath,i=!0),i?t:void 0}function Ri(e){let t={STEP:e.description,statements:e.statements.map(j)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function Ui(e){let t={IF:Lt(e.condition),THEN:e.then.map(j)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(j)),t}function zi(e){let t={WHILE:Lt(e.condition),DO:e.body.map(j)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function Lt(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function It(e){try{let t=(0,Q.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),i}catch{return{}}}function pe(e){if(e.length>Et)throw new Error(`YAML input too large (${e.length} bytes, max ${Et})`);let t=(0,Q.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");let i={version:"1.2.0",goal:t.goal,url:t.url,statements:Y(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=Y(t.teardown));let r=he.safeParse(i);if(!r.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(r.error.errors)}`);return r.data}function Y(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Vi)}function Vi(e){if(typeof e=="string")return Xi(e);if(typeof e!="object"||e===null)throw new Error(`Invalid statement: expected string or object, got ${typeof e}`);let t=e;if("IF"in t)return Ji(t);if("WHILE"in t)return ji(t);if("STEP"in t)return Yi(t);if("action_entity"in t)return qi(t);if("description"in t&&typeof t.description=="string")return{uid:(0,L.v4)(),type:"DRAFT",description:t.description};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Xi(e){let t=e.match(/^VERIFY:\s*(.+)$/i);return t?{uid:(0,L.v4)(),type:"ACTION",description:`Verify: ${t[1]}`,action_entity:{action_description:`Verify: ${t[1]}`,action_data:{action_name:"verify",kwargs:{statement:t[1]}}}}:{uid:(0,L.v4)(),type:"DRAFT",description:e}}function Dt(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 Ji(e){let t=Dt(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let r={uid:(0,L.v4)(),type:"IF_ELSE",condition:t,then:Y(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(r.else=Y(e.ELSE)),r}function ji(e){let t=Dt(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let r={uid:(0,L.v4)(),type:"WHILE_LOOP",condition:t,body:Y(i)};return typeof e.timeout_ms=="number"&&(r.timeout_ms=e.timeout_ms),r}function Yi(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,L.v4)(),type:"STEP",description:t,statements:Y(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}function qi(e){let t=typeof e.description=="string"?e.description:"",i=e.action_entity,r;i&&(r={action_description:t,...i});let n={uid:(0,L.v4)(),type:"ACTION",description:t};return r&&(n.action_entity=r),typeof e.locator=="string"&&(n.locator=e.locator),typeof e.use_pure_vision=="boolean"&&(n.use_pure_vision=e.use_pure_vision),n}var Q,L,Et,$t=m(()=>{"use strict";Fe();Q=require("yaml"),L=require("uuid");Et=1024*1024});function Be(e){for(let t of e){if(t.type==="STEP"&&t.reference_id)return!0;let i=P(t);for(let r of i)if(Be(r.statements))return!0}return!1}function Gt(e){let t=new Set;function i(r){for(let n of r){n.type==="STEP"&&n.reference_id&&t.add(n.reference_id);let o=P(n);for(let a of o)i(a.statements)}}return i(e),Array.from(t)}function Ft(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return W(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&W(e.teardown,"teardown",t),t}function I(e,t,i){let r=e+".",n=t.filter(([u])=>u===e||u.startsWith(r));if(n.length===0)return[];let o=[],a=new Set;for(let[u]of n){let d=u===e?"":u.slice(r.length);if(!d)continue;let g=d.split(".")[0];a.has(g)||a.add(g)}let s=Array.from(a);s.sort((u,d)=>{let g=/^\d+$/.test(u)?parseInt(u,10):-1,_=/^\d+$/.test(d)?parseInt(d,10):-1;return g>=0&&_>=0?g-_:u==="then"&&d==="else"?-1:u==="else"&&d==="then"||u==="body"?1:d==="body"?-1:u.localeCompare(d)});function l(u){return i[u]}function c(u){let d=u.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"JS_CODE",expression:(d?d[2].trim():u)||"true"}}for(let u of s){let d=e?`${e}.${u}`:u,g=l(d),_=g?.description??"",V=d;if(u==="then"){let f=`${e}.then`,E=`${e}.else`,y=I(f,t,i),K=I(E,t,i),ne=l(e),Ii=ne?c(ne.description):{type:"JS_CODE",expression:"true"};o.push({uid:e,type:"IF_ELSE",condition:Ii,then:y,...K.length>0?{else:K}:{}});continue}if(u==="else")continue;if(u==="body"){let f=`${e}.body`,E=I(f,t,i),y=l(e),K=y?c(y.description):{type:"JS_CODE",expression:"true"};o.push({uid:e,type:"WHILE_LOOP",condition:K,body:E});continue}let w=`${e}.${u}`,re=t.some(([f])=>f.startsWith(w+".then.")||f===w+".then"),X=t.some(([f])=>f.startsWith(w+".else.")||f===w+".else"),ye=t.some(([f])=>f.startsWith(w+".body.")||f===w+".body"),G=t.filter(([f])=>{if(!f.startsWith(w+"."))return!1;let y=f.slice(w.length+1).split(".")[0];return/^\d+$/.test(y)&&y!=="then"&&y!=="else"&&y!=="body"});if(re||X){let f=w+".then",E=w+".else",y=I(f,t,i),K=I(E,t,i),ne=g?c(_):{type:"JS_CODE",expression:"true"};o.push({uid:d,type:"IF_ELSE",condition:ne,then:y,...K.length>0?{else:K}:{}})}else if(ye){let f=w+".body",E=I(f,t,i),y=g?c(_):{type:"JS_CODE",expression:"true"};o.push({uid:d,type:"WHILE_LOOP",condition:y,body:E})}else if(G.length>0){let f=I(w,t,i);o.push({uid:d,type:"STEP",description:_||"Group",statements:f})}else o.push({uid:d,type:"ACTION",description:_||"Action",action_entity:g?.action_entity})}return o}function Bt(e){let t=Object.entries(e),i=r=>{let n=r+".";return t.some(([a])=>a===r||a.startsWith(n))?I(r,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var P,T,D,$,C,Ct,Wt,Nt,Zi,Qi,Kt,Ht,W,Re=m(()=>{"use strict";P=e=>{let t=[];switch(e.type){case"STEP":e.statements&&t.push({key:"statements",statements:e.statements});break;case"IF_ELSE":e.then&&t.push({key:"then",statements:e.then}),e.else&&t.push({key:"else",statements:e.else});break;case"WHILE_LOOP":e.body&&t.push({key:"body",statements:e.body});break}return t},T=(e,t,i=void 0,r="root")=>{for(let n=0;n<e.length;n++){let o=e[n],a=o.uid;if(a===t)return{stableId:a,path:[n],statement:o,parent:i,containerKey:r,index:n};let s=P(o);for(let l of s){let c=T(l.statements,t,o,l.key);if(c)return{...c,path:[n,l.key,...c.path]}}}return null},D=(e,t,i)=>{let r=T(e,t);if(!r)return null;let{statement:n,parent:o,containerKey:a,index:s}=r,l=null;switch(n.type){case"DRAFT":case"ACTION":l=$(e,r)||C(e,r);break;case"STEP":if(n.statements&&n.statements.length>0)return n.statements[0];l=$(e,r)||C(e,r);break;case"IF_ELSE":if(i===!0&&n.then&&n.then.length>0)return n.then[0];if(i===!1&&n.else&&n.else.length>0)return n.else[0];l=$(e,r)||C(e,r);break;case"WHILE_LOOP":if(i===!0&&n.body&&n.body.length>0)return n.body[0];l=$(e,r)||C(e,r);break;default:l=$(e,r)||C(e,r);break}if(o&&o.type==="WHILE_LOOP"&&a==="body"){if(!l)return o;let c=T(e,l.uid);if(!c||c.parent!==o)return o}return l},$=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let r=P(t.parent).find(n=>n.key===t.containerKey);return r&&t.index+1<r.statements.length?r.statements[t.index+1]:null},C=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,r=T(e,i);return r?$(e,r)||C(e,r):null},Ct=e=>{let t=[],i=r=>{for(let n of r){t.push(n);let o=P(n);for(let a of o)i(a.statements)}};return i(e),t},Wt=e=>{switch(e.type){case"DRAFT":case"ACTION":return!0;case"STEP":return!0;case"IF_ELSE":case"WHILE_LOOP":return!0;default:return!1}},Nt=(e,t,i)=>{if(!T(e,t))return null;if(i===null){let s=[],l=t;for(;l!==null&&T(e,l);)if(s.push(l),l=D(e,l)?.uid||null,s.length>1e3)return null;return s}if(!T(e,i))return null;if(t===i)return[];let o=[],a=t;for(;a&&a!==i;){let s=T(e,a);if(!s)break;if(o.push(a),s.statement.type==="IF_ELSE"){let l=Zi(s.statement,i);l?a=D(e,a,l==="then")?.uid||null:a=D(e,a)?.uid||null}else s.statement.type==="WHILE_LOOP"?Qi(s.statement,i)?a=D(e,a,!0)?.uid||null:a=D(e,a,!1)?.uid||null:a=D(e,a)?.uid||null;if(o.length>1e3)return null}return a===i?o:null},Zi=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&T(i.then,t)?"then":i.else&&T(i.else,t)?"else":null},Qi=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&T(i.body,t))};Kt=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),Ht=e=>!["js_code","function","assert","ai_assert","verify","ai_extract","ai_wait_until","upload_file","login","extract_activation_code","extract_email_content","ai_step"].includes(e),W=(e,t,i)=>{e.forEach((r,n)=>{let o=`${t}.${n}`;r.type==="DRAFT"?i[o]={description:r.description||"Draft",action_entity:void 0}:r.type==="ACTION"?i[o]={description:r.description||"Action",action_entity:r.action_entity}:r.type==="STEP"&&r.statements?W(r.statements,o,i):r.type==="IF_ELSE"?(i[o]={description:"IF "+(r.condition?.expression||""),action_entity:void 0},r.then&&W(r.then,`${o}.then`,i),r.else&&W(r.else,`${o}.else`,i)):r.type==="WHILE_LOOP"&&(i[o]={description:"WHILE "+(r.condition?.expression||""),action_entity:void 0},r.body&&W(r.body,`${o}.body`,i))})}});function Rt(){return{version:"1.0",entries:{}}}function Ut(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function zt(e,t){let i=t?.entries[e.uid],r=i?.action_entity??e.action_entity;return e.locator&&r?{...r,locator:e.locator}:i?i.action_entity:e.action_entity?e.action_entity:null}function Vt(e,t,i,r){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:r},e}function Xt(e,t){let i=e??{version:"1.0",entries:{}};for(let[r,n]of t)i.entries[r]=n;return i}function Jt(e){return e?Object.keys(e.entries).length===0:!0}function jt(e){return e?Object.keys(e.entries).length:0}function Yt(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=Ue(e.statements,t),r=e.teardown?Ue(e.teardown,t):void 0;return{...e,statements:i,teardown:r}}function Ue(e,t){return e.map(i=>er(i,t))}function er(e,t){if(e.type==="ACTION"){let n=e,o=t.entries[n.uid];return o?{...n,action_entity:o.action_entity}:n}let i=P(e);if(i.length===0)return e;let r={};for(let n of i)r[n.key]=Ue(n.statements,t);return{...e,...r}}var qt=m(()=>{"use strict";Re()});var ze,Ve,de,Zt=m(()=>{"use strict";ze=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(ze||{}),Ve=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))(Ve||{}),de=18e4});var Qt,ti=m(()=>{"use strict";Qt=class ei{data={};sensitive=new Set;get(t){return this.data[t]}set(t,i,r=!1){this.data[t]=i,r?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,r]of Object.entries(t.getAll()))this.set(i,r,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new ei;if(t.data){let r=new Set(t.sensitiveKeys||[]);for(let[n,o]of Object.entries(t.data))i.set(n,o,r.has(n))}return i}}});function ii(e){return{copilot:e?.models?.copilot||Xe,webagent:e?.models?.webagent||Je}}function ri(e=process.env){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.ANTHROPIC_API_KEY)return je;if(e.GOOGLE_API_KEY)return Ye}var Xe,Je,je,Ye,ni=m(()=>{"use strict";Xe="claude-sonnet-4-5",Je="gemini-2.5-pro",je="claude-haiku-4-5",Ye="gemini-2.5-pro"});var qe,oi=m(()=>{"use strict";qe=(e=>(e.INITIALIZING="initializing",e.READY="ready",e.PROCESSING="processing",e.STOPPING="stopping",e.WAITING_USER="waiting_user",e.COMPLETED="completed",e.FAILED="failed",e))(qe||{})});function ai(e){let t=e.trim();if(!t||t.startsWith("List of devices"))return null;let i=t.split(/\s+/);if(i.length<2)return null;let r=i[0],n=i[1],o="usb";return r.startsWith("emulator-")?o="emulator":r.includes(":")&&(o="wifi"),{id:r,state:n,connectionType:o}}function si(e){return e.startsWith(b)?e:`${b}${e}`}function ci(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var li=m(()=>{"use strict";se()});var ui={};Qe(ui,{ADDRESS_BAR_HEIGHT:()=>ce,ANDROID_DEVICE_PREFIX:()=>b,ActionEntitySchema:()=>Ge,ActionSchema:()=>He,AgentStatus:()=>qe,BaseStatementSchema:()=>B,BrowserType:()=>Le,ConditionSchema:()=>ue,ConditionType:()=>Ve,ConditionTypeSchema:()=>We,DEFAULT_ANTHROPIC_MODEL:()=>je,DEFAULT_COPILOT_MODEL:()=>Xe,DEFAULT_DEVICE_NAME:()=>F,DEFAULT_GOOGLE_MODEL:()=>Ye,DEFAULT_WEBAGENT_MODEL:()=>Je,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>de,DEVICE_CATEGORIES:()=>De,DeviceType:()=>Ie,DraftSchema:()=>Ke,IOS_DEVICE_PREFIX:()=>M,LoginType:()=>$e,MIN_WINDOW_HEIGHT:()=>Oe,MIN_WINDOW_WIDTH:()=>Ee,NodeJSCodeCommon:()=>tt,PLAYWRIGHT_DEVICES:()=>q,RECORD_VIDEO_HEIGHT:()=>xe,RECORD_VIDEO_WIDTH:()=>ve,StatementSchema:()=>O,StatementType:()=>ze,StatementTypeSchema:()=>Ne,TestFlowSchema:()=>he,TwoFactorAuthType:()=>Ce,UI_DEVICE_CATEGORIES:()=>Tt,UI_DEVICE_CATEGORIES_ELECTRON:()=>bt,USER_AGENT:()=>be,VIEWPORT_HEIGHT:()=>Ae,VIEWPORT_WIDTH:()=>Pe,VariableStore:()=>Qt,WINDOW_HEIGHT:()=>ke,WINDOW_WIDTH:()=>Me,actionStepsMapToTestFlowSections:()=>Bt,allowPureVisionAction:()=>Ht,collectActionSteps:()=>W,createAndroidDeviceName:()=>pt,createEmptyStore:()=>Rt,createIOSDeviceName:()=>dt,createRunnerStoreEntry:()=>Ut,extractActionStepsFromTestFlow:()=>Ft,extractDeviceIdentifier:()=>ht,extractYamlMetadata:()=>It,findNextAfterContainer:()=>C,findNextSibling:()=>$,findNextStatement:()=>D,findPathBetweenStatements:()=>Nt,findStatementPathById:()=>T,getAllDeviceNames:()=>yt,getAllReferenceIds:()=>Gt,getAllStatementsInOrder:()=>Ct,getAndroidDeviceDisplayName:()=>ci,getBrowserWindowSize:()=>Mt,getCompatiblePlatforms:()=>Te,getDeviceBrowserType:()=>At,getDeviceByName:()=>Z,getDeviceChannel:()=>Pt,getDeviceOptions:()=>le,getDevicesByCategory:()=>J,getIOSDeviceDisplayName:()=>wt,getLoginConfigPlatform:()=>rt,getRecordVideoSize:()=>kt,getStatementContainers:()=>P,getStoreSize:()=>jt,getTestPlatformFromDeviceName:()=>st,hasReferenceIds:()=>Be,isAndroidDevice:()=>lt,isAppPackage:()=>ft,isDynamicAction:()=>Kt,isExecutableStatement:()=>Wt,isIOSDevice:()=>ut,isNativeDevice:()=>ct,isPhysicalDeviceUDID:()=>St,isPlatformCompatibleWithUrl:()=>gt,isStoreEmpty:()=>Jt,isWebUrl:()=>ae,mergeActionEntitiesIntoTestFlow:()=>Yt,mergeStoreUpdates:()=>Xt,parseAdbDeviceLine:()=>ai,replaceVariables:()=>ot,resolveActionEntity:()=>zt,resolveModelFromEnv:()=>ri,resolveModels:()=>ii,testFlowToYaml:()=>Ot,toAndroidDeviceName:()=>si,toIOSDeviceName:()=>mt,updateStoreEntry:()=>Vt,yamlToTestFlow:()=>pe});var fe=m(()=>{"use strict";it();nt();at();_t();vt();xt();$t();Fe();qt();Re();Zt();ti();ni();oi();li();se()});var Tr={};Qe(Tr,{authSetup:()=>vi,resolveLoginConfig:()=>_e,shiplightConfig:()=>Li});module.exports=Gi(Tr);var x=H(require("fs"),1),k=H(require("path"),1),Ei=H(require("dotenv"),1),Oi=require("glob");var v=require("fs"),Mi=require("path"),ki=require("glob");var ge=require("yaml");fe();var pi=require("fs"),te=require("path"),ee=require("yaml"),hi=5;function di(e,t){let i={expandingPaths:new Set([(0,te.resolve)(t)]),depth:0,referencedPaths:new Set},r={...e};return Array.isArray(r.statements)&&(r.statements=R(r.statements,t,i)),Array.isArray(r.teardown)&&(r.teardown=R(r.teardown,t,i)),{doc:r,referencedTemplatePaths:Array.from(i.referencedPaths)}}function R(e,t,i){let r=[];for(let n of e)if(tr(n)){let o=ir(n,t,i);r.push(...o)}else r.push(rr(n,t,i));return r}function tr(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function ir(e,t,i){if(i.depth>=hi)throw new Error(`Template expansion exceeded maximum depth of ${hi}. Check for deeply nested or circular template references.`);let r=(0,te.resolve)((0,te.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 n;try{n=(0,pi.readFileSync)(r,"utf-8")}catch(u){throw new Error(`Failed to read template file: ${r} (referenced from ${t}): ${u.message}`)}let o=(0,ee.parse)(n);if(!o||typeof o!="object")throw new Error(`Invalid template file: ${r} \u2014 expected a YAML object`);let a=o.params||[],s=e.params||{};for(let u of a)if(!(u in s))throw new Error(`Template ${e.template} requires param "${u}" but it was not provided. Required params: [${a.join(", ")}]`);let l=o.statements;if(!Array.isArray(l))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(s).length>0){let d=(0,ee.stringify)(l);for(let[g,_]of Object.entries(s))d=d.replaceAll(`{{${g}}}`,String(_));l=(0,ee.parse)(d)}let c={expandingPaths:new Set([...i.expandingPaths,r]),depth:i.depth+1,referencedPaths:i.referencedPaths};return R(l,r,c)}function rr(e,t,i){if(typeof e!="object"||e===null)return e;let r={...e};return Array.isArray(r.statements)&&(r.statements=R(r.statements,t,i)),Array.isArray(r.THEN)&&(r.THEN=R(r.THEN,t,i)),Array.isArray(r.ELSE)&&(r.ELSE=R(r.ELSE,t,i)),Array.isArray(r.DO)&&(r.DO=R(r.DO,t,i)),r}function fi(e,t){let i=(0,ge.parse)(e),r=i?.name,n=i?.tags,o=i?.use;i&&(i.name!==void 0||i.tags!==void 0||i.use!==void 0)&&(delete i.name,delete i.tags,delete i.use);let a=[];if(t&&i&&typeof i=="object"){let c=di(i,t);i=c.doc,a=c.referencedTemplatePaths}let s=(0,ge.stringify)(i);return{testFlow:pe(s),name:r,tags:n,use:o,referencedTemplatePaths:a}}fe();function me(e){return e.replace(/\\/g,"\\\\").replace(/'/g,"\\'").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/\t/g,"\\t")}function N(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function nr(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function or(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 Ze(e){let t=nr(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let r=or(e);if(r){let n=JSON.stringify(r);return`${t}.locator(${n}).first()`}return null}var ar=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],sr=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"];function gi(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:ar.includes(t)}function mi(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!sr.includes(t)}var S=new Map;function p(e,t){S.set(e,t)}function _i(e){return S.get(e)}function U(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(n=>` ${n},`),"});"]}p("click",e=>{let t=Ze(e);return t?[`await ${t}.click({ timeout: ${5e3} });`]:['await agent.execAction("click", page, {});']});p("click_element",S.get("click"));p("click_element_by_index",S.get("click"));p("double_click",e=>U("double_click",e));p("double_click_on_element",S.get("double_click"));p("right_click",e=>U("right_click",e));p("right_click_on_element",S.get("right_click"));p("hover",e=>U("hover",e));p("hover_element_by_index",S.get("hover"));p("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return U("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});p("fill",S.get("input_text"));p("clear_input",e=>U("clear_input",e));p("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});p("send_keys",S.get("press"));p("send_keys_on_element",e=>{let t=Ze(e),i=e.action_data?.kwargs?.keys||"";return t?[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${5e3} });`]:['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(i)} } },`,"});"]});p("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return U("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});p("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)})');`]});p("scroll_down",S.get("scroll"));p("scroll_up",S.get("scroll"));p("scroll_element",S.get("scroll"));p("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});p("scroll_on_element",e=>U("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));p("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)} } },`,"});"]});p("open_tab",S.get("go_to_url"));p("go_back",()=>['await agent.execAction("go_back", page, {});']);p("reload_page",()=>['await agent.execAction("reload_page", page, {});']);p("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);p("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);p("verify",(e,t)=>{let i=e.action_data?.kwargs;if(i?.code)return i.code.split(`
16
+ `);let r=i?.statement||e.action_description;return r?[`await agent.assert(page, ${JSON.stringify(r)}, '${t||""}');`]:["// Skipping verify: missing statement or code"]});p("ai_assert",S.get("verify"));p("assert",S.get("verify"));p("ai_action",(e,t)=>{let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let r=JSON.stringify(i),n=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${r}, '${t||""}', ${n});`]});p("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"]});p("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 n=JSON.stringify(i),o=JSON.stringify(r);return[`await agent.extract(page, ${n}, ${o}, '${t||""}');`]});p("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"]});p("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)} } },`,"});"]});p("js_code",e=>{let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],r=t.split(`
17
+ `);for(let n of r)i.push(` ${n}`);return i.push("}"),i});p("function",(e,t,i)=>{let r=e.action_data?.kwargs||{},n=r.functionName;if(n&&n.includes("#")){let[a,s]=n.split("#");if(a&&s){let l=a.replace(/\.(ts|js|mjs)$/,""),c=`import { ${s} } from '${l}';`;i?.imports?.add(c);let u={...r,functionName:s},d=wi(u);return d?[d.endsWith(";")?d:`${d};`]:["// Skipping function: invalid export pattern"]}}let o=wi(r);return o?[o.endsWith(";")?o:`${o};`]:["// Skipping function: missing functionName"]});p("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)} } },`,"});"]});p("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(n=>` ${n},`),"});"]});p("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} } },`,"});"]);p("switch_tab",e=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??0} } },`,"});"]);p("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} } },`,"});"]});p("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},`),"});"]});p("done",()=>["// Done - no action needed"]);function wi(e){let t=e.functionName;if(!t)return null;let i={},r=e.parameterNames||[],n=e.parameterValues||e.args||[];if(r.forEach((l,c)=>{c<n.length&&(i[l]=n[c])}),Object.keys(i).length===0)return`await ${t}()`;let o=["page","testContext","request","agentServices"],a=["undefined","null","true","false"],s=Object.entries(i).map(([l,c])=>{let u=String(c);return c==null?"undefined":o.includes(l)&&o.includes(u)||a.includes(u)||/^-?\d+(\.\d+)?$/.test(u)?u:u.startsWith("$")?`agent.agentServices.readVariable('${u.substring(1)}')`:`"${u}"`});return`await ${t}(${s.join(", ")})`}function A(e,t,i,r="main"){let n=[];for(let o=0;o<e.length;o++){let a=e[o],s=`${r}.${o}`,l=cr(a,t,s,i);l.length>0&&(n.push(...l),o<e.length-1&&n.push(""))}return n}function cr(e,t,i,r){let n=" ".repeat(t);switch(e.type){case"DRAFT":return lr(e,t,i);case"ACTION":return ur(e,t,i,r);case"STEP":return hr(e,t,i,r);case"IF_ELSE":return pr(e,t,i,r);case"WHILE_LOOP":return dr(e,t,i,r);default:return[`${n}// Unknown statement type: ${e.type}`]}}function lr(e,t,i){let r=" ".repeat(t),n=e.description?.trim()||"";if(!n)return[`${r}// ${i}: Skipping - no description`];let o=JSON.stringify(n);return[`${r}// ${i}: ${N(n)}`,`${r}page = agent.agentServices.validatePage(page);`,`${r}await agent.run(page, ${o}, '${i}');`]}function ur(e,t,i,r){let n=" ".repeat(t),o=e.description,a=e.uid,l=r.actionEntityStore?.entries[e.uid]?.action_entity??e.action_entity;if(!l){if(!o)return[`${n}// ${i}: Skipping - no description`];let G=JSON.stringify(o),f=!!e.use_pure_vision;return[`${n}// ${i}: ${N(o)}`,`${n}page = agent.agentServices.validatePage(page);`,`${n}await agent.execute(page, ${G}, '${i}', ${f});`]}let c=e.locator?{...l,locator:e.locator}:l;o&&o!==c.action_description&&(c={...c,action_description:o});let u=c.action_data?.action_name||"",d=c.action_description||"",g=_i(u);if(!g)return[`${n}// ${i}: Unknown action: ${u}`];let _={imports:r.imports},V=g(c,i,_);if(gi(c))return[`${n}// ${i}: ${N(d)}`,`${n}page = agent.agentServices.validatePage(page);`,...V.map(G=>`${n}${G}`)];let w=JSON.stringify(d),re=V.map(G=>`${n} ${G}`),X=mi(c),ye=a?`'${a}'`:"undefined";return[`${n}// ${i}: ${N(d)}`,`${n}page = agent.agentServices.validatePage(page);`,`${n}await agent.step(page, async () => {`,...re,`${n}}, ${w}, '${i}', ${ye}, ${X});`]}function hr(e,t,i,r){let n=" ".repeat(t),o=[];e.description&&e.description.trim()&&o.push(`${n}// Step: ${N(e.description)}`);let a=A(e.statements,t,r,i);return o.push(...a),o}function pr(e,t,i,r){let n=" ".repeat(t),o=[];if(o.push(`${n}// ${i}: Conditional check`),e.condition.type==="JS_CODE")o.push(`${n}if (${e.condition.expression}) {`);else{o.push(`${n}// AI Condition: ${N(e.condition.expression)}`);let s=JSON.stringify(e.condition.expression);o.push(`${n}if (await agent.evaluate(page, ${s}, "${i}")) {`)}let a=A(e.then,t+1,r,`${i}.then`);if(o.push(...a),e.else&&e.else.length>0){o.push(`${n}} else {`);let s=A(e.else,t+1,r,`${i}.else`);o.push(...s)}return o.push(`${n}}`),o}function dr(e,t,i,r){let n=" ".repeat(t),o=[];o.push(`${n}// ${i}: Loop`);let a=e.timeout_ms??de,s=a/1e3,l=e.timeout_ms?`While loop exceeded timeout of ${s}s`:`While loop exceeded default timeout of ${s}s`,c=`loop_${i.replace(/\./g,"_")}`;if(o.push(`${n}const ${c}_start = Date.now();`),o.push(`${n}const ${c}_timeout = ${a};`),o.push(`${n}const ${c}_check = () => {`),o.push(`${n} if (Date.now() - ${c}_start > ${c}_timeout) {`),o.push(`${n} throw new Error('${l}');`),o.push(`${n} }`),o.push(`${n} return true;`),o.push(`${n}};`),e.condition.type==="JS_CODE")o.push(`${n}while (${c}_check() && (${e.condition.expression})) {`);else{o.push(`${n}// AI Loop Condition: ${N(e.condition.expression)}`);let d=JSON.stringify(e.condition.expression);o.push(`${n}while (${c}_check() && await agent.evaluate(page, ${d}, "${i}")) {`)}let u=A(e.body,t+1,r,`${i}.body`);return o.push(...u),o.push(`${n}}`),o}var yi={name:"shiplightai",version:"0.1.6",type:"module",description:"Shiplight CLI for running and debugging .test.yaml files",main:"dist/index.js",types:"dist/index.d.ts",bin:{shiplight:"dist/cli.js"},exports:{".":{types:"./dist/index.d.ts",import:"./dist/index.js",require:"./dist/cjs/index.cjs",default:"./dist/index.js"},"./fixture":{types:"./dist/fixture.d.ts",import:"./dist/fixture.js",require:"./dist/cjs/fixture.cjs",default:"./dist/fixture.js"}},files:["dist","README.md"],publishConfig:{registry:"https://registry.npmjs.org",access:"public"},scripts:{build:"tsup","build:cli":"tsup",clean:"rm -rf dist",dev:"tsup --watch",test:"playwright test",typecheck:"tsc --noEmit"},dependencies:{"@babel/plugin-transform-typescript":"^7.27.0","@babel/preset-env":"^7.26.9","@babel/preset-typescript":"^7.27.0","@anthropic-ai/claude-agent-sdk":"^0.1.72","@modelcontextprotocol/sdk":"^0.5.0",axios:"^1.6.0",dotenv:"^16.0.3",express:"^4.21.0",glob:"^13.0.0",open:"^10.1.0",sharp:"^0.34.5",uuid:"^11.1.0",yaml:"^2.8.0",zod:"^3.22.0","zod-to-json-schema":"^3.24.6"},devDependencies:{"@playwright/test":"1.55.0","@shiplightai/sdk-pro":"workspace:*","@types/express":"^4.17.21","@types/node":"^24.0.0",copilot3:"workspace:*","mcp-tools":"workspace:*","sdk-core":"workspace:*","sdk-internal":"workspace:*","shiplight-types":"workspace:*",tsup:"^8.3.5",typescript:"5.5.4","web-session":"workspace:*"},peerDependencies:{"@playwright/test":"1.55.0","@shiplightai/sdk-pro":">=0.2.0"},engines:{node:">=22.0.0"},keywords:["playwright","yaml","testing","automation","ai","shiplight","mcp"],author:"Shiplight",license:"MIT"};var we=yi.version;function Ti(e,t){let i=[];i.push(`// @generated by shiplightai v${we}`),i.push(...gr()),i.push(""),t?.use&&Object.keys(t.use).length>0&&(i.push(`test.use(${JSON.stringify(t.use,null,2)});`),i.push(""));let r=t?.testName||e.goal||"Generated test",n=t?.tags&&t.tags.length>0?t.tags.map(c=>`@${c}`).join(" ")+" ":"";i.push(`test('${n}${me(r)}', async ({ page, agent }) => {`);let o=t?.startingUrl||e.url;if(o){let c;try{c=new URL(o).pathname}catch{c=o}i.push(` await page.goto('${me(c)}', { waitUntil: 'domcontentloaded' });`),i.push("")}let a=new Set,s={imports:a};if(e.teardown&&e.teardown.length>0){if(i.push(" try {"),e.statements&&e.statements.length>0){i.push(" // Test steps");let u=A(e.statements,2,s);i.push(...u)}i.push(" } finally {"),i.push(" // Teardown");let c=A(e.teardown,2,s,"teardown");i.push(...c),i.push(" }")}else if(e.statements&&e.statements.length>0){i.push(" // Test steps");let c=A(e.statements,1,s);i.push(...c)}if(i.push("});"),a.size>0){let c=0;for(let d=0;d<i.length;d++)i[d].startsWith("import ")&&(c=d+1);let u=Array.from(a);i.splice(c,0,...u)}return i.join(`
18
+ `)}function gr(){return["import { test, expect } from 'shiplightai/fixture';"]}function bi(e){try{return(0,v.statSync)(e).mtimeMs}catch{return 0}}var mr=`// @generated by shiplightai v${we}`;function wr(e,t){if(!(0,v.existsSync)(e)||(0,v.readFileSync)(e,"utf-8").split(`
19
+ `,1)[0]!==mr)return!1;let r=bi(e);for(let n of t)if(bi(n)>r)return!1;return!0}function Pi(e){let t=(0,ki.globSync)("**/*.test.yaml",{cwd:e.cwd,ignore:["**/node_modules/**"]}),i=[];for(let r of t){let n=(0,Mi.resolve)(e.cwd,r),o=n.replace(/\.test\.yaml$/,".yaml.spec.ts"),a=(0,v.readFileSync)(n,"utf-8");try{let{testFlow:s,name:l,tags:c,use:u,referencedTemplatePaths:d}=fi(a,n);if(wr(o,[n,...d]))continue;let g=Ti(s,{testName:l,tags:c,use:u});(0,v.writeFileSync)(o,g)}catch(s){console.error(`[shiplight] Failed to transpile ${r}:`,s),i.push({file:r,error:s})}}if(i.length>0)throw new Error(`[shiplight] Transpilation failed for ${i.length} file(s):
6
20
  `+i.map(r=>` - ${r.file}`).join(`
7
- `))}var $=b(require("path"),1),be=require("fs/promises");var H=b(require("fs"),1),A=b(require("path"),1);function B(e){let t=null,i=process.env.SHIPLIGHT_LOGIN_EMAIL,r=process.env.SHIPLIGHT_LOGIN_PASSWORD;return i&&r&&(t={username:i,password:r}),t||(t=dt(e)),t?(process.env.SHIPLIGHT_LOGIN_URL&&(t.loginUrl=process.env.SHIPLIGHT_LOGIN_URL),process.env.SHIPLIGHT_LOGIN_TOTP_SECRET&&(t.totpSecret=process.env.SHIPLIGHT_LOGIN_TOTP_SECRET),t):null}function dt(e){let t=A.resolve(e),i=A.resolve(process.cwd());for(;;){for(let n of["shiplight.config.json","login.config.json"]){let o=A.join(t,n);if(H.existsSync(o))try{let l=JSON.parse(H.readFileSync(o,"utf-8"));if(l.username&&l.password)return{username:l.username,password:l.password,loginUrl:l.url,totpSecret:l.totp_secret}}catch{}}if(t===i)break;let r=A.dirname(t);if(r===t)break;t=r}return null}async function Me(e,t){let i=$.resolve(t),r=B(i);if(!r)return;let{WebAgent:n,createAgentContext:o,configureSdk:l,VariableStore:u}=await import("@shiplightai/sdk-pro");l({env:{GOOGLE_API_KEY:process.env.GOOGLE_API_KEY??"",ANTHROPIC_API_KEY:process.env.ANTHROPIC_API_KEY??""}});let p=process.env.WEB_AGENT_MODEL||(process.env.ANTHROPIC_API_KEY?"claude-haiku-4-5":void 0)||(process.env.GOOGLE_API_KEY?"gemini-2.5-pro":void 0);if(!p)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, ANTHROPIC_API_KEY, or GOOGLE_API_KEY.");let s=new n(o({model:p,variableStore:new u})),{username:h,password:d,loginUrl:_,totpSecret:v}=r,C=_||e.url()||"about:blank";if(!(await s.loginPage(e,{site_url:C,num_verification_exprs:0,account:{type:"password",username:h,password:d,...v&&{two_factor_auth_config:{type:"totp",data:v}}}})).success)throw new Error("Login failed.");let W=$.join(i,".auth");await(0,be.mkdir)(W,{recursive:!0}),await e.context().storageState({path:$.join(W,"storage-state.json")})}function ke(){return`// @generated by shiplightai \u2014 do not edit
21
+ `))}var ie=H(require("path"),1),Ai=require("fs/promises");var Se=H(require("fs"),1),z=H(require("path"),1);function _e(e){let t=null,i=process.env.SHIPLIGHT_LOGIN_EMAIL,r=process.env.SHIPLIGHT_LOGIN_PASSWORD;return i&&r&&(t={username:i,password:r}),t||(t=Sr(e)),t?(process.env.SHIPLIGHT_LOGIN_URL&&(t.loginUrl=process.env.SHIPLIGHT_LOGIN_URL),process.env.SHIPLIGHT_LOGIN_TOTP_SECRET&&(t.totpSecret=process.env.SHIPLIGHT_LOGIN_TOTP_SECRET),t):null}function Sr(e){let t=z.resolve(e),i=z.resolve(process.cwd());for(;;){for(let n of["shiplight.config.json","login.config.json"]){let o=z.join(t,n);if(Se.existsSync(o))try{let a=JSON.parse(Se.readFileSync(o,"utf-8"));if(a.username&&a.password)return{username:a.username,password:a.password,loginUrl:a.url,totpSecret:a.totp_secret}}catch{}}if(t===i)break;let r=z.dirname(t);if(r===t)break;t=r}return null}async function vi(e,t){let i=ie.resolve(t),r=_e(i);if(!r)return;let{WebAgent:n,createAgentContext:o,configureSdk:a,VariableStore:s}=await import("@shiplightai/sdk-pro");a({env:{GOOGLE_API_KEY:process.env.GOOGLE_API_KEY??"",ANTHROPIC_API_KEY:process.env.ANTHROPIC_API_KEY??""}});let{resolveModelFromEnv:l}=await Promise.resolve().then(()=>(fe(),ui)),c=l();if(!c)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, ANTHROPIC_API_KEY, or GOOGLE_API_KEY.");let u=new n(o({model:c,variableStore:new s})),{username:d,password:g,loginUrl:_,totpSecret:V}=r,w=_||e.url()||"about:blank";if(!(await u.loginPage(e,{site_url:w,num_verification_exprs:0,account:{type:"password",username:d,password:g,...V&&{two_factor_auth_config:{type:"totp",data:V}}}})).success)throw new Error("Login failed.");let X=ie.join(i,".auth");await(0,Ai.mkdir)(X,{recursive:!0}),await e.context().storageState({path:ie.join(X,"storage-state.json")})}function xi(){return`// @generated by shiplightai \u2014 do not edit
8
22
  import { test as setup } from '@playwright/test';
9
23
 
10
24
  setup('authenticate', async ({ page }) => {
11
25
  const { authSetup } = await import('shiplightai');
12
26
  await authSetup(page, __dirname);
13
27
  });
14
- `}function ve(e={}){e.dotenv!==!1&&ft(e.scanDir||process.cwd());let t=e.scanDir||process.cwd();return Te({cwd:t}),gt(t),e.apiKey&&(process.env.__SHIPLIGHT_API_KEY=e.apiKey),{}}function ft(e){let t=[],i=g.resolve(e),r=g.resolve(process.cwd());for(;;){let n=g.join(i,".env");if(S.existsSync(n)&&t.push(n),i===r)break;let o=g.dirname(i);if(o===i)break;i=o}for(let n of t)Pe.default.config({path:n})}function gt(e){let t=(0,Ae.globSync)("**/shiplight.config.json",{cwd:e,ignore:["**/node_modules/**"]});for(let i of t){let r=g.resolve(e,i),n=g.dirname(r),o=g.join(n,"auth.setup.ts");try{let l=JSON.parse(S.readFileSync(r,"utf-8"));if(!l.username||!l.password)continue}catch{continue}try{let l=S.statSync(r).mtimeMs;if(S.statSync(o).mtimeMs>l)continue}catch{}S.writeFileSync(o,ke())}}0&&(module.exports={authSetup,resolveLoginConfig,shiplightConfig});
28
+ `}function Li(e={}){e.dotenv!==!1&&_r(e.scanDir||process.cwd());let t=e.scanDir||process.cwd();return Pi({cwd:t}),yr(t),e.apiKey&&(process.env.__SHIPLIGHT_API_KEY=e.apiKey),{}}function _r(e){let t=[],i=k.resolve(e),r=k.resolve(process.cwd());for(;;){let n=k.join(i,".env");if(x.existsSync(n)&&t.push(n),i===r)break;let o=k.dirname(i);if(o===i)break;i=o}for(let n of t)Ei.default.config({path:n})}function yr(e){let t=(0,Oi.globSync)("**/shiplight.config.json",{cwd:e,ignore:["**/node_modules/**"]});for(let i of t){let r=k.resolve(e,i),n=k.dirname(r),o=k.join(n,"auth.setup.ts"),a=!1;try{let s=JSON.parse(x.readFileSync(r,"utf-8"));a=!!(s.username&&s.password)}catch{}if(!a&&process.env.SHIPLIGHT_LOGIN_EMAIL&&process.env.SHIPLIGHT_LOGIN_PASSWORD&&(a=!0),!!a){try{let s=x.statSync(r).mtimeMs;if(x.statSync(o).mtimeMs>s)continue}catch{}x.writeFileSync(o,xi())}}}0&&(module.exports={authSetup,resolveLoginConfig,shiplightConfig});
package/dist/cli.js CHANGED
@@ -8812,7 +8812,7 @@ url: ${e}
8812
8812
  statements:
8813
8813
  - description: "TODO: Add your first step"
8814
8814
  `});var r8n={};Hs(r8n,{runTests:()=>Lxo});import{spawn as Mxo}from"child_process";import*as e8n from"fs";import*as t8n from"path";async function Lxo(e){(e.includes("--help")||e.includes("-h"))&&(console.log("Usage: shiplight run [playwright-args...]"),console.log(""),console.log("Delegates to `npx playwright test` with all arguments forwarded."),console.log("Auto-detects playwright.config.ts in the current directory."),console.log(""),console.log("Examples:"),console.log(" shiplight run # run all tests"),console.log(" shiplight run --headed # run tests with browser visible"),console.log(" shiplight run tests/login.test.ts # run a specific test"),console.log(" shiplight run --grep 'login' # filter tests by name"),process.exit(0));let t=process.cwd();["playwright.config.ts","playwright.config.js","playwright.config.mjs"].some(o=>e8n.existsSync(t8n.join(t,o)))||(console.warn("Warning: No playwright.config.ts found in current directory."),console.warn(`Make sure you're running from your project root.
8815
- `));let i=Mxo("npx",["playwright","test",...e],{stdio:"inherit",shell:!0,cwd:t}),s=await new Promise(o=>{i.on("close",a=>o(a??1))});process.exit(s)}var n8n=Q(()=>{"use strict"});var i8n=F(($Su,Qxo)=>{Qxo.exports={name:"shiplightai",version:"0.1.5",type:"module",description:"Shiplight CLI for running and debugging .test.yaml files",main:"dist/index.js",types:"dist/index.d.ts",bin:{shiplight:"dist/cli.js"},exports:{".":{types:"./dist/index.d.ts",import:"./dist/index.js",require:"./dist/cjs/index.cjs",default:"./dist/index.js"},"./fixture":{types:"./dist/fixture.d.ts",import:"./dist/fixture.js",require:"./dist/cjs/fixture.cjs",default:"./dist/fixture.js"}},files:["dist","README.md"],publishConfig:{registry:"https://registry.npmjs.org",access:"public"},scripts:{build:"tsup","build:cli":"tsup",clean:"rm -rf dist",dev:"tsup --watch",test:"playwright test",typecheck:"tsc --noEmit"},dependencies:{"@babel/plugin-transform-typescript":"^7.27.0","@babel/preset-env":"^7.26.9","@babel/preset-typescript":"^7.27.0","@anthropic-ai/claude-agent-sdk":"^0.1.72","@modelcontextprotocol/sdk":"^0.5.0",axios:"^1.6.0",dotenv:"^16.0.3",express:"^4.21.0",glob:"^13.0.0",open:"^10.1.0",sharp:"^0.34.5",uuid:"^11.1.0",yaml:"^2.8.0",zod:"^3.22.0","zod-to-json-schema":"^3.24.6"},devDependencies:{"@playwright/test":"1.55.0","@shiplightai/sdk-pro":"workspace:*","@types/express":"^4.17.21","@types/node":"^24.0.0",copilot3:"workspace:*","mcp-tools":"workspace:*","sdk-core":"workspace:*","sdk-internal":"workspace:*","shiplight-types":"workspace:*",tsup:"^8.3.5",typescript:"5.5.4","web-session":"workspace:*"},peerDependencies:{"@playwright/test":"1.55.0","@shiplightai/sdk-pro":">=0.2.0"},engines:{node:">=22.0.0"},keywords:["playwright","yaml","testing","automation","ai","shiplight","mcp"],author:"Shiplight",license:"MIT"}});import Uxo from"dotenv";Uxo.config();function s8n(){console.log(`
8815
+ `));let i=Mxo("npx",["playwright","test",...e],{stdio:"inherit",shell:!0,cwd:t}),s=await new Promise(o=>{i.on("close",a=>o(a??1))});process.exit(s)}var n8n=Q(()=>{"use strict"});var i8n=F(($Su,Qxo)=>{Qxo.exports={name:"shiplightai",version:"0.1.6",type:"module",description:"Shiplight CLI for running and debugging .test.yaml files",main:"dist/index.js",types:"dist/index.d.ts",bin:{shiplight:"dist/cli.js"},exports:{".":{types:"./dist/index.d.ts",import:"./dist/index.js",require:"./dist/cjs/index.cjs",default:"./dist/index.js"},"./fixture":{types:"./dist/fixture.d.ts",import:"./dist/fixture.js",require:"./dist/cjs/fixture.cjs",default:"./dist/fixture.js"}},files:["dist","README.md"],publishConfig:{registry:"https://registry.npmjs.org",access:"public"},scripts:{build:"tsup","build:cli":"tsup",clean:"rm -rf dist",dev:"tsup --watch",test:"playwright test",typecheck:"tsc --noEmit"},dependencies:{"@babel/plugin-transform-typescript":"^7.27.0","@babel/preset-env":"^7.26.9","@babel/preset-typescript":"^7.27.0","@anthropic-ai/claude-agent-sdk":"^0.1.72","@modelcontextprotocol/sdk":"^0.5.0",axios:"^1.6.0",dotenv:"^16.0.3",express:"^4.21.0",glob:"^13.0.0",open:"^10.1.0",sharp:"^0.34.5",uuid:"^11.1.0",yaml:"^2.8.0",zod:"^3.22.0","zod-to-json-schema":"^3.24.6"},devDependencies:{"@playwright/test":"1.55.0","@shiplightai/sdk-pro":"workspace:*","@types/express":"^4.17.21","@types/node":"^24.0.0",copilot3:"workspace:*","mcp-tools":"workspace:*","sdk-core":"workspace:*","sdk-internal":"workspace:*","shiplight-types":"workspace:*",tsup:"^8.3.5",typescript:"5.5.4","web-session":"workspace:*"},peerDependencies:{"@playwright/test":"1.55.0","@shiplightai/sdk-pro":">=0.2.0"},engines:{node:">=22.0.0"},keywords:["playwright","yaml","testing","automation","ai","shiplight","mcp"],author:"Shiplight",license:"MIT"}});import Uxo from"dotenv";Uxo.config();function s8n(){console.log(`
8816
8816
  Usage: shiplight <command> [options]
8817
8817
 
8818
8818
  Commands:
package/dist/index.js CHANGED
@@ -1,16 +1,16 @@
1
1
  import { createRequire as __createRequire } from "module";
2
2
  const require = __createRequire(import.meta.url);
3
- import{Da as I,da as C}from"./chunk-437WOFND.js";import*as _ from"fs";import*as f from"path";import Pt from"dotenv";import{globSync as Et}from"glob";import{readFileSync as q,writeFileSync as $t,statSync as St,existsSync as xt}from"fs";import{resolve as kt}from"path";import{globSync as At}from"glob";import{parse as at,stringify as ot}from"yaml";import{readFileSync as tt}from"fs";import{resolve as J,dirname as et}from"path";import{parse as j,stringify as nt}from"yaml";var R=5;function D(t,e){let n={expandingPaths:new Set([J(e)]),depth:0,referencedPaths:new Set},r={...t};return Array.isArray(r.statements)&&(r.statements=y(r.statements,e,n)),Array.isArray(r.teardown)&&(r.teardown=y(r.teardown,e,n)),{doc:r,referencedTemplatePaths:Array.from(n.referencedPaths)}}function y(t,e,n){let r=[];for(let s of t)if(rt(s)){let i=st(s,e,n);r.push(...i)}else r.push(it(s,e,n));return r}function rt(t){return typeof t=="object"&&t!==null&&typeof t.template=="string"}function st(t,e,n){if(n.depth>=R)throw new Error(`Template expansion exceeded maximum depth of ${R}. Check for deeply nested or circular template references.`);let r=J(et(e),t.template);if(n.expandingPaths.has(r))throw new Error(`Circular template reference detected: ${r} is already being expanded. Stack: ${Array.from(n.expandingPaths).join(" \u2192 ")} \u2192 ${r}`);n.referencedPaths.add(r);let s;try{s=tt(r,"utf-8")}catch(l){throw new Error(`Failed to read template file: ${r} (referenced from ${e}): ${l.message}`)}let i=j(s);if(!i||typeof i!="object")throw new Error(`Invalid template file: ${r} \u2014 expected a YAML object`);let c=i.params||[],p=t.params||{};for(let l of c)if(!(l in p))throw new Error(`Template ${t.template} requires param "${l}" but it was not provided. Required params: [${c.join(", ")}]`);let g=i.statements;if(!Array.isArray(g))throw new Error(`Template ${t.template} must have a "statements" array`);if(Object.keys(p).length>0){let u=nt(g);for(let[h,x]of Object.entries(p))u=u.replaceAll(`{{${h}}}`,String(x));g=j(u)}let a={expandingPaths:new Set([...n.expandingPaths,r]),depth:n.depth+1,referencedPaths:n.referencedPaths};return y(g,r,a)}function it(t,e,n){if(typeof t!="object"||t===null)return t;let r={...t};return Array.isArray(r.statements)&&(r.statements=y(r.statements,e,n)),Array.isArray(r.THEN)&&(r.THEN=y(r.THEN,e,n)),Array.isArray(r.ELSE)&&(r.ELSE=y(r.ELSE,e,n)),Array.isArray(r.DO)&&(r.DO=y(r.DO,e,n)),r}function H(t,e){let n=at(t),r=n?.name,s=n?.tags,i=n?.use;n&&(n.name!==void 0||n.tags!==void 0||n.use!==void 0)&&(delete n.name,delete n.tags,delete n.use);let c=[];if(e&&n&&typeof n=="object"){let a=D(n,e);n=a.doc,c=a.referencedTemplatePaths}let p=ot(n);return{testFlow:C(p),name:r,tags:s,use:i,referencedTemplatePaths:c}}function N(t){return t.replace(/\\/g,"\\\\").replace(/'/g,"\\'").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/\t/g,"\\t")}function w(t){return t.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function ct(t){let e=t.frame_path;return!e||e.length===0?"page":`page.frameLocator('${e[0]}')`}function pt(t){let e=t.xpath;return typeof e=="string"&&e.trim()?!e.startsWith("xpath=")&&!e.startsWith("/")&&!e.startsWith("//")?`xpath=//${e}`:e.startsWith("xpath=")?e:`xpath=${e}`:null}function P(t){let e=ct(t),n=t.locator;if(typeof n=="string"&&n.trim())return n=n.trim(),n.endsWith("first()")?`${e}.${n}`:`${e}.${n}.first()`;let r=pt(t);if(r){let s=JSON.stringify(r);return`${e}.locator(${s}).first()`}return null}var lt=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],gt=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"];function F(t){let e=t.action_data?.action_name;return!e||(e==="verify"||e==="ai_assert"||e==="assert")&&t.action_data?.kwargs?.code?!1:lt.includes(e)}function G(t){let e=t.action_data?.action_name;return!e||(e==="verify"||e==="ai_assert"||e==="assert")&&t.action_data?.kwargs?.code?!1:!gt.includes(e)}var d=new Map;function o(t,e){d.set(t,e)}function Y(t){return d.get(t)}function $(t,e,n=[]){let r=[...n];return e.locator?r.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&r.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&r.push(`frame_path: ${JSON.stringify(e.frame_path)}`),r.length===0?[`await agent.execAction("${t}", page, {});`]:[`await agent.execAction("${t}", page, {`,...r.map(s=>` ${s},`),"});"]}o("click",t=>{let e=P(t);return e?[`await ${e}.click({ timeout: ${5e3} });`]:['await agent.execAction("click", page, {});']});o("click_element",d.get("click"));o("click_element_by_index",d.get("click"));o("double_click",t=>$("double_click",t));o("double_click_on_element",d.get("double_click"));o("right_click",t=>$("right_click",t));o("right_click_on_element",d.get("right_click"));o("hover",t=>$("hover",t));o("hover_element_by_index",d.get("hover"));o("input_text",t=>{let e=t.action_data?.kwargs?.text??t.action_data?.kwargs?.value??"";return $("input_text",t,[`action_data: { kwargs: { text: ${JSON.stringify(e)} } }`])});o("fill",d.get("input_text"));o("clear_input",t=>$("clear_input",t));o("press",t=>{let e=t.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(e)});`]});o("send_keys",d.get("press"));o("send_keys_on_element",t=>{let e=P(t),n=t.action_data?.kwargs?.keys||"";return e?[`await ${e}.press(${JSON.stringify(n)}, { timeout: ${5e3} });`]:['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(n)} } },`,"});"]});o("select_dropdown_option",t=>{let e=t.action_data?.kwargs?.text||t.action_data?.kwargs?.option||"";return $("select_dropdown_option",t,[`action_data: { kwargs: { text: ${JSON.stringify(e)} } }`])});o("scroll",t=>{let e=t.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(t.action_data?.kwargs?.num_pages??1)*(e?1:-1)})');`]});o("scroll_down",d.get("scroll"));o("scroll_up",d.get("scroll"));o("scroll_element",d.get("scroll"));o("scroll_to_text",t=>{let e=t.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(e)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});o("scroll_on_element",t=>$("scroll_on_element",t,[`action_data: { kwargs: ${JSON.stringify(t.action_data?.kwargs||{})} }`]));o("go_to_url",t=>{let e=t.action_data?.kwargs?.url||"";return t.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(e)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(e)} } },`,"});"]});o("open_tab",d.get("go_to_url"));o("go_back",()=>['await agent.execAction("go_back", page, {});']);o("reload_page",()=>['await agent.execAction("reload_page", page, {});']);o("wait",t=>[`await page.waitForTimeout(${(t.action_data?.kwargs?.seconds||1)*1e3});`]);o("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);o("verify",(t,e)=>{let n=t.action_data?.kwargs;if(n?.code)return n.code.split(`
4
- `);let r=n?.statement||t.action_description;return r?[`await agent.assert(page, ${JSON.stringify(r)}, '${e||""}');`]:["// Skipping verify: missing statement or code"]});o("ai_assert",d.get("verify"));o("assert",d.get("verify"));o("ai_action",(t,e)=>{let n=t.action_data?.kwargs?.statement;if(!n)return["// Skipping ai_action: missing statement"];let r=JSON.stringify(n),s=t.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${r}, '${e||""}', ${s});`]});o("ai_step",(t,e)=>{let n=t.action_data?.kwargs?.statement;return n?[`await agent.run(page, ${JSON.stringify(n)}, '${e||""}');`]:["// Skipping ai_step: missing statement"]});o("ai_extract",(t,e)=>{let n=t.action_data?.kwargs?.element_description,r=t.action_data?.kwargs?.variable_name;if(!n||!r)return["// Skipping ai_extract: missing element_description or variable_name"];let s=JSON.stringify(n),i=JSON.stringify(r);return[`await agent.extract(page, ${s}, ${i}, '${e||""}');`]});o("ai_wait_until",(t,e)=>{let n=t.action_data?.kwargs?.condition,r=t.action_data?.kwargs?.timeout_seconds||60;return n?[`await agent.waitUntilCondition(page, ${JSON.stringify(n)}, ${r}, '${e||""}');`]:["// Skipping ai_wait_until: missing condition"]});o("save_variable",t=>{let e=t.action_data?.kwargs?.name||"",n=t.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(e)}, value: ${JSON.stringify(n)} } },`,"});"]});o("js_code",t=>{let e=t.action_data?.kwargs?.code;if(!e)return["// Skipping js_code: missing code"];let n=["{"],r=e.split(`
5
- `);for(let s of r)n.push(` ${s}`);return n.push("}"),n});o("function",(t,e,n)=>{let r=t.action_data?.kwargs||{},s=r.functionName;if(s&&s.includes("#")){let[c,p]=s.split("#");if(c&&p){let g=c.replace(/\.(ts|js|mjs)$/,""),a=`import { ${p} } from '${g}';`;n?.imports?.add(a);let l={...r,functionName:p},u=M(l);return u?[u.endsWith(";")?u:`${u};`]:["// Skipping function: invalid export pattern"]}}let i=M(r);return i?[i.endsWith(";")?i:`${i};`]:["// Skipping function: missing functionName"]});o("generate_2fa_code",t=>{let e=t.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(e)} } },`,"});"]});o("upload_file",t=>{let e=t.action_data?.kwargs||{},n=[],r={};return e.paths?r.paths=e.paths:e.path&&(r.path=e.path),e.use_file_input&&(r.use_file_input=!0),n.push(`action_data: { kwargs: ${JSON.stringify(r)} }`),t.locator?n.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&n.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&n.push(`frame_path: ${JSON.stringify(t.frame_path)}`),['await agent.execAction("upload_file", page, {',...n.map(s=>` ${s},`),"});"]});o("wait_for_download_complete",t=>['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${t.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]);o("switch_tab",t=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${t.action_data?.kwargs?.page_id??0} } },`,"});"]);o("close_tab",t=>{let e=t.action_data?.kwargs?.page_id;return e=e??t.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${e} } },`,"});"]});o("set_date_for_native_date_picker",t=>{let e=t.action_data?.kwargs?.date??"",n=[];return n.push(`action_data: { kwargs: { date: ${JSON.stringify(e)} } }`),t.locator?n.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&n.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&n.push(`frame_path: ${JSON.stringify(t.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...n.map(r=>` ${r},`),"});"]});o("done",()=>["// Done - no action needed"]);function M(t){let e=t.functionName;if(!e)return null;let n={},r=t.parameterNames||[],s=t.parameterValues||t.args||[];if(r.forEach((g,a)=>{a<s.length&&(n[g]=s[a])}),Object.keys(n).length===0)return`await ${e}()`;let i=["page","testContext","request","agentServices"],c=["undefined","null","true","false"],p=Object.entries(n).map(([g,a])=>{let l=String(a);return a==null?"undefined":i.includes(g)&&i.includes(l)||c.includes(l)||/^-?\d+(\.\d+)?$/.test(l)?l:l.startsWith("$")?`agent.agentServices.readVariable('${l.substring(1)}')`:`"${l}"`});return`await ${e}(${p.join(", ")})`}function m(t,e,n,r="main"){let s=[];for(let i=0;i<t.length;i++){let c=t[i],p=`${r}.${i}`,g=ut(c,e,p,n);g.length>0&&(s.push(...g),i<t.length-1&&s.push(""))}return s}function ut(t,e,n,r){let s=" ".repeat(e);switch(t.type){case"DRAFT":return dt(t,e,n);case"ACTION":return ft(t,e,n,r);case"STEP":return mt(t,e,n,r);case"IF_ELSE":return _t(t,e,n,r);case"WHILE_LOOP":return ht(t,e,n,r);default:return[`${s}// Unknown statement type: ${t.type}`]}}function dt(t,e,n){let r=" ".repeat(e),s=t.description?.trim()||"";if(!s)return[`${r}// ${n}: Skipping - no description`];let i=JSON.stringify(s);return[`${r}// ${n}: ${w(s)}`,`${r}page = agent.agentServices.validatePage(page);`,`${r}await agent.run(page, ${i}, '${n}');`]}function ft(t,e,n,r){let s=" ".repeat(e),i=t.description,c=t.uid,g=r.actionEntityStore?.entries[t.uid]?.action_entity??t.action_entity;if(!g){if(!i)return[`${s}// ${n}: Skipping - no description`];let k=JSON.stringify(i),Z=!!t.use_pure_vision;return[`${s}// ${n}: ${w(i)}`,`${s}page = agent.agentServices.validatePage(page);`,`${s}await agent.execute(page, ${k}, '${n}', ${Z});`]}let a=t.locator?{...g,locator:t.locator}:g;i&&i!==a.action_description&&(a={...a,action_description:i});let l=a.action_data?.action_name||"",u=a.action_description||"",h=Y(l);if(!h)return[`${s}// ${n}: Unknown action: ${l}`];let x={imports:r.imports},T=h(a,n,x);if(F(a))return[`${s}// ${n}: ${w(u)}`,`${s}page = agent.agentServices.validatePage(page);`,...T.map(k=>`${s}${k}`)];let L=JSON.stringify(u),O=T.map(k=>`${s} ${k}`),X=G(a),Q=c?`'${c}'`:"undefined";return[`${s}// ${n}: ${w(u)}`,`${s}page = agent.agentServices.validatePage(page);`,`${s}await agent.step(page, async () => {`,...O,`${s}}, ${L}, '${n}', ${Q}, ${X});`]}function mt(t,e,n,r){let s=" ".repeat(e),i=[];t.description&&t.description.trim()&&i.push(`${s}// Step: ${w(t.description)}`);let c=m(t.statements,e,r,n);return i.push(...c),i}function _t(t,e,n,r){let s=" ".repeat(e),i=[];if(i.push(`${s}// ${n}: Conditional check`),t.condition.type==="JS_CODE")i.push(`${s}if (${t.condition.expression}) {`);else{i.push(`${s}// AI Condition: ${w(t.condition.expression)}`);let p=JSON.stringify(t.condition.expression);i.push(`${s}if (await agent.evaluate(page, ${p}, "${n}")) {`)}let c=m(t.then,e+1,r,`${n}.then`);if(i.push(...c),t.else&&t.else.length>0){i.push(`${s}} else {`);let p=m(t.else,e+1,r,`${n}.else`);i.push(...p)}return i.push(`${s}}`),i}function ht(t,e,n,r){let s=" ".repeat(e),i=[];i.push(`${s}// ${n}: Loop`);let c=t.timeout_ms??I,p=c/1e3,g=t.timeout_ms?`While loop exceeded timeout of ${p}s`:`While loop exceeded default timeout of ${p}s`,a=`loop_${n.replace(/\./g,"_")}`;if(i.push(`${s}const ${a}_start = Date.now();`),i.push(`${s}const ${a}_timeout = ${c};`),i.push(`${s}const ${a}_check = () => {`),i.push(`${s} if (Date.now() - ${a}_start > ${a}_timeout) {`),i.push(`${s} throw new Error('${g}');`),i.push(`${s} }`),i.push(`${s} return true;`),i.push(`${s}};`),t.condition.type==="JS_CODE")i.push(`${s}while (${a}_check() && (${t.condition.expression})) {`);else{i.push(`${s}// AI Loop Condition: ${w(t.condition.expression)}`);let u=JSON.stringify(t.condition.expression);i.push(`${s}while (${a}_check() && await agent.evaluate(page, ${u}, "${n}")) {`)}let l=m(t.body,e+1,r,`${n}.body`);return i.push(...l),i.push(`${s}}`),i}var W={name:"shiplightai",version:"0.1.5",type:"module",description:"Shiplight CLI for running and debugging .test.yaml files",main:"dist/index.js",types:"dist/index.d.ts",bin:{shiplight:"dist/cli.js"},exports:{".":{types:"./dist/index.d.ts",import:"./dist/index.js",require:"./dist/cjs/index.cjs",default:"./dist/index.js"},"./fixture":{types:"./dist/fixture.d.ts",import:"./dist/fixture.js",require:"./dist/cjs/fixture.cjs",default:"./dist/fixture.js"}},files:["dist","README.md"],publishConfig:{registry:"https://registry.npmjs.org",access:"public"},scripts:{build:"tsup","build:cli":"tsup",clean:"rm -rf dist",dev:"tsup --watch",test:"playwright test",typecheck:"tsc --noEmit"},dependencies:{"@babel/plugin-transform-typescript":"^7.27.0","@babel/preset-env":"^7.26.9","@babel/preset-typescript":"^7.27.0","@anthropic-ai/claude-agent-sdk":"^0.1.72","@modelcontextprotocol/sdk":"^0.5.0",axios:"^1.6.0",dotenv:"^16.0.3",express:"^4.21.0",glob:"^13.0.0",open:"^10.1.0",sharp:"^0.34.5",uuid:"^11.1.0",yaml:"^2.8.0",zod:"^3.22.0","zod-to-json-schema":"^3.24.6"},devDependencies:{"@playwright/test":"1.55.0","@shiplightai/sdk-pro":"workspace:*","@types/express":"^4.17.21","@types/node":"^24.0.0",copilot3:"workspace:*","mcp-tools":"workspace:*","sdk-core":"workspace:*","sdk-internal":"workspace:*","shiplight-types":"workspace:*",tsup:"^8.3.5",typescript:"5.5.4","web-session":"workspace:*"},peerDependencies:{"@playwright/test":"1.55.0","@shiplightai/sdk-pro":">=0.2.0"},engines:{node:">=22.0.0"},keywords:["playwright","yaml","testing","automation","ai","shiplight","mcp"],author:"Shiplight",license:"MIT"};var v=W.version;function V(t,e){let n=[];n.push(`// @generated by shiplightai v${v}`),n.push(...yt()),n.push(""),e?.use&&Object.keys(e.use).length>0&&(n.push(`test.use(${JSON.stringify(e.use,null,2)});`),n.push(""));let r=e?.testName||t.goal||"Generated test",s=e?.tags&&e.tags.length>0?e.tags.map(a=>`@${a}`).join(" ")+" ":"";n.push(`test('${s}${N(r)}', async ({ page, agent }) => {`);let i=e?.startingUrl||t.url;if(i){let a;try{a=new URL(i).pathname}catch{a=i}n.push(` await page.goto('${N(a)}', { waitUntil: 'domcontentloaded' });`),n.push("")}let c=new Set,p={imports:c};if(t.teardown&&t.teardown.length>0){if(n.push(" try {"),t.statements&&t.statements.length>0){n.push(" // Test steps");let l=m(t.statements,2,p);n.push(...l)}n.push(" } finally {"),n.push(" // Teardown");let a=m(t.teardown,2,p,"teardown");n.push(...a),n.push(" }")}else if(t.statements&&t.statements.length>0){n.push(" // Test steps");let a=m(t.statements,1,p);n.push(...a)}if(n.push("});"),c.size>0){let a=0;for(let u=0;u<n.length;u++)n[u].startsWith("import ")&&(a=u+1);let l=Array.from(c);n.splice(a,0,...l)}return n.join(`
6
- `)}function yt(){return["import { test, expect } from 'shiplightai/fixture';"]}function K(t){try{return St(t).mtimeMs}catch{return 0}}var Tt=`// @generated by shiplightai v${v}`;function Ot(t,e){if(!xt(t)||q(t,"utf-8").split(`
7
- `,1)[0]!==Tt)return!1;let r=K(t);for(let s of e)if(K(s)>r)return!1;return!0}function z(t){let e=At("**/*.test.yaml",{cwd:t.cwd,ignore:["**/node_modules/**"]}),n=[];for(let r of e){let s=kt(t.cwd,r),i=s.replace(/\.test\.yaml$/,".yaml.spec.ts"),c=q(s,"utf-8");try{let{testFlow:p,name:g,tags:a,use:l,referencedTemplatePaths:u}=H(c,s);if(Ot(i,[s,...u]))continue;let h=V(p,{testName:g,tags:a,use:l});$t(i,h)}catch(p){console.error(`[shiplight] Failed to transpile ${r}:`,p),n.push({file:r,error:p})}}if(n.length>0)throw new Error(`[shiplight] Transpilation failed for ${n.length} file(s):
3
+ import{Da as j,da as C}from"./chunk-437WOFND.js";import*as _ from"fs";import*as d from"path";import Pt from"dotenv";import{globSync as Lt}from"glob";import{readFileSync as z,writeFileSync as $t,statSync as St,existsSync as xt}from"fs";import{resolve as kt}from"path";import{globSync as At}from"glob";import{parse as at,stringify as ot}from"yaml";import{readFileSync as tt}from"fs";import{resolve as D,dirname as et}from"path";import{parse as R,stringify as nt}from"yaml";var J=5;function H(t,e){let n={expandingPaths:new Set([D(e)]),depth:0,referencedPaths:new Set},r={...t};return Array.isArray(r.statements)&&(r.statements=y(r.statements,e,n)),Array.isArray(r.teardown)&&(r.teardown=y(r.teardown,e,n)),{doc:r,referencedTemplatePaths:Array.from(n.referencedPaths)}}function y(t,e,n){let r=[];for(let s of t)if(rt(s)){let i=st(s,e,n);r.push(...i)}else r.push(it(s,e,n));return r}function rt(t){return typeof t=="object"&&t!==null&&typeof t.template=="string"}function st(t,e,n){if(n.depth>=J)throw new Error(`Template expansion exceeded maximum depth of ${J}. Check for deeply nested or circular template references.`);let r=D(et(e),t.template);if(n.expandingPaths.has(r))throw new Error(`Circular template reference detected: ${r} is already being expanded. Stack: ${Array.from(n.expandingPaths).join(" \u2192 ")} \u2192 ${r}`);n.referencedPaths.add(r);let s;try{s=tt(r,"utf-8")}catch(l){throw new Error(`Failed to read template file: ${r} (referenced from ${e}): ${l.message}`)}let i=R(s);if(!i||typeof i!="object")throw new Error(`Invalid template file: ${r} \u2014 expected a YAML object`);let c=i.params||[],p=t.params||{};for(let l of c)if(!(l in p))throw new Error(`Template ${t.template} requires param "${l}" but it was not provided. Required params: [${c.join(", ")}]`);let g=i.statements;if(!Array.isArray(g))throw new Error(`Template ${t.template} must have a "statements" array`);if(Object.keys(p).length>0){let u=nt(g);for(let[h,x]of Object.entries(p))u=u.replaceAll(`{{${h}}}`,String(x));g=R(u)}let a={expandingPaths:new Set([...n.expandingPaths,r]),depth:n.depth+1,referencedPaths:n.referencedPaths};return y(g,r,a)}function it(t,e,n){if(typeof t!="object"||t===null)return t;let r={...t};return Array.isArray(r.statements)&&(r.statements=y(r.statements,e,n)),Array.isArray(r.THEN)&&(r.THEN=y(r.THEN,e,n)),Array.isArray(r.ELSE)&&(r.ELSE=y(r.ELSE,e,n)),Array.isArray(r.DO)&&(r.DO=y(r.DO,e,n)),r}function F(t,e){let n=at(t),r=n?.name,s=n?.tags,i=n?.use;n&&(n.name!==void 0||n.tags!==void 0||n.use!==void 0)&&(delete n.name,delete n.tags,delete n.use);let c=[];if(e&&n&&typeof n=="object"){let a=H(n,e);n=a.doc,c=a.referencedTemplatePaths}let p=ot(n);return{testFlow:C(p),name:r,tags:s,use:i,referencedTemplatePaths:c}}function v(t){return t.replace(/\\/g,"\\\\").replace(/'/g,"\\'").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/\t/g,"\\t")}function w(t){return t.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function ct(t){let e=t.frame_path;return!e||e.length===0?"page":`page.frameLocator('${e[0]}')`}function pt(t){let e=t.xpath;return typeof e=="string"&&e.trim()?!e.startsWith("xpath=")&&!e.startsWith("/")&&!e.startsWith("//")?`xpath=//${e}`:e.startsWith("xpath=")?e:`xpath=${e}`:null}function L(t){let e=ct(t),n=t.locator;if(typeof n=="string"&&n.trim())return n=n.trim(),n.endsWith("first()")?`${e}.${n}`:`${e}.${n}.first()`;let r=pt(t);if(r){let s=JSON.stringify(r);return`${e}.locator(${s}).first()`}return null}var lt=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],gt=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"];function G(t){let e=t.action_data?.action_name;return!e||(e==="verify"||e==="ai_assert"||e==="assert")&&t.action_data?.kwargs?.code?!1:lt.includes(e)}function M(t){let e=t.action_data?.action_name;return!e||(e==="verify"||e==="ai_assert"||e==="assert")&&t.action_data?.kwargs?.code?!1:!gt.includes(e)}var f=new Map;function o(t,e){f.set(t,e)}function Y(t){return f.get(t)}function $(t,e,n=[]){let r=[...n];return e.locator?r.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&r.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&r.push(`frame_path: ${JSON.stringify(e.frame_path)}`),r.length===0?[`await agent.execAction("${t}", page, {});`]:[`await agent.execAction("${t}", page, {`,...r.map(s=>` ${s},`),"});"]}o("click",t=>{let e=L(t);return e?[`await ${e}.click({ timeout: ${5e3} });`]:['await agent.execAction("click", page, {});']});o("click_element",f.get("click"));o("click_element_by_index",f.get("click"));o("double_click",t=>$("double_click",t));o("double_click_on_element",f.get("double_click"));o("right_click",t=>$("right_click",t));o("right_click_on_element",f.get("right_click"));o("hover",t=>$("hover",t));o("hover_element_by_index",f.get("hover"));o("input_text",t=>{let e=t.action_data?.kwargs?.text??t.action_data?.kwargs?.value??"";return $("input_text",t,[`action_data: { kwargs: { text: ${JSON.stringify(e)} } }`])});o("fill",f.get("input_text"));o("clear_input",t=>$("clear_input",t));o("press",t=>{let e=t.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(e)});`]});o("send_keys",f.get("press"));o("send_keys_on_element",t=>{let e=L(t),n=t.action_data?.kwargs?.keys||"";return e?[`await ${e}.press(${JSON.stringify(n)}, { timeout: ${5e3} });`]:['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(n)} } },`,"});"]});o("select_dropdown_option",t=>{let e=t.action_data?.kwargs?.text||t.action_data?.kwargs?.option||"";return $("select_dropdown_option",t,[`action_data: { kwargs: { text: ${JSON.stringify(e)} } }`])});o("scroll",t=>{let e=t.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(t.action_data?.kwargs?.num_pages??1)*(e?1:-1)})');`]});o("scroll_down",f.get("scroll"));o("scroll_up",f.get("scroll"));o("scroll_element",f.get("scroll"));o("scroll_to_text",t=>{let e=t.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(e)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});o("scroll_on_element",t=>$("scroll_on_element",t,[`action_data: { kwargs: ${JSON.stringify(t.action_data?.kwargs||{})} }`]));o("go_to_url",t=>{let e=t.action_data?.kwargs?.url||"";return t.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(e)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(e)} } },`,"});"]});o("open_tab",f.get("go_to_url"));o("go_back",()=>['await agent.execAction("go_back", page, {});']);o("reload_page",()=>['await agent.execAction("reload_page", page, {});']);o("wait",t=>[`await page.waitForTimeout(${(t.action_data?.kwargs?.seconds||1)*1e3});`]);o("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);o("verify",(t,e)=>{let n=t.action_data?.kwargs;if(n?.code)return n.code.split(`
4
+ `);let r=n?.statement||t.action_description;return r?[`await agent.assert(page, ${JSON.stringify(r)}, '${e||""}');`]:["// Skipping verify: missing statement or code"]});o("ai_assert",f.get("verify"));o("assert",f.get("verify"));o("ai_action",(t,e)=>{let n=t.action_data?.kwargs?.statement;if(!n)return["// Skipping ai_action: missing statement"];let r=JSON.stringify(n),s=t.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${r}, '${e||""}', ${s});`]});o("ai_step",(t,e)=>{let n=t.action_data?.kwargs?.statement;return n?[`await agent.run(page, ${JSON.stringify(n)}, '${e||""}');`]:["// Skipping ai_step: missing statement"]});o("ai_extract",(t,e)=>{let n=t.action_data?.kwargs?.element_description,r=t.action_data?.kwargs?.variable_name;if(!n||!r)return["// Skipping ai_extract: missing element_description or variable_name"];let s=JSON.stringify(n),i=JSON.stringify(r);return[`await agent.extract(page, ${s}, ${i}, '${e||""}');`]});o("ai_wait_until",(t,e)=>{let n=t.action_data?.kwargs?.condition,r=t.action_data?.kwargs?.timeout_seconds||60;return n?[`await agent.waitUntilCondition(page, ${JSON.stringify(n)}, ${r}, '${e||""}');`]:["// Skipping ai_wait_until: missing condition"]});o("save_variable",t=>{let e=t.action_data?.kwargs?.name||"",n=t.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(e)}, value: ${JSON.stringify(n)} } },`,"});"]});o("js_code",t=>{let e=t.action_data?.kwargs?.code;if(!e)return["// Skipping js_code: missing code"];let n=["{"],r=e.split(`
5
+ `);for(let s of r)n.push(` ${s}`);return n.push("}"),n});o("function",(t,e,n)=>{let r=t.action_data?.kwargs||{},s=r.functionName;if(s&&s.includes("#")){let[c,p]=s.split("#");if(c&&p){let g=c.replace(/\.(ts|js|mjs)$/,""),a=`import { ${p} } from '${g}';`;n?.imports?.add(a);let l={...r,functionName:p},u=U(l);return u?[u.endsWith(";")?u:`${u};`]:["// Skipping function: invalid export pattern"]}}let i=U(r);return i?[i.endsWith(";")?i:`${i};`]:["// Skipping function: missing functionName"]});o("generate_2fa_code",t=>{let e=t.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(e)} } },`,"});"]});o("upload_file",t=>{let e=t.action_data?.kwargs||{},n=[],r={};return e.paths?r.paths=e.paths:e.path&&(r.path=e.path),e.use_file_input&&(r.use_file_input=!0),n.push(`action_data: { kwargs: ${JSON.stringify(r)} }`),t.locator?n.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&n.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&n.push(`frame_path: ${JSON.stringify(t.frame_path)}`),['await agent.execAction("upload_file", page, {',...n.map(s=>` ${s},`),"});"]});o("wait_for_download_complete",t=>['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${t.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]);o("switch_tab",t=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${t.action_data?.kwargs?.page_id??0} } },`,"});"]);o("close_tab",t=>{let e=t.action_data?.kwargs?.page_id;return e=e??t.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${e} } },`,"});"]});o("set_date_for_native_date_picker",t=>{let e=t.action_data?.kwargs?.date??"",n=[];return n.push(`action_data: { kwargs: { date: ${JSON.stringify(e)} } }`),t.locator?n.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&n.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&n.push(`frame_path: ${JSON.stringify(t.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...n.map(r=>` ${r},`),"});"]});o("done",()=>["// Done - no action needed"]);function U(t){let e=t.functionName;if(!e)return null;let n={},r=t.parameterNames||[],s=t.parameterValues||t.args||[];if(r.forEach((g,a)=>{a<s.length&&(n[g]=s[a])}),Object.keys(n).length===0)return`await ${e}()`;let i=["page","testContext","request","agentServices"],c=["undefined","null","true","false"],p=Object.entries(n).map(([g,a])=>{let l=String(a);return a==null?"undefined":i.includes(g)&&i.includes(l)||c.includes(l)||/^-?\d+(\.\d+)?$/.test(l)?l:l.startsWith("$")?`agent.agentServices.readVariable('${l.substring(1)}')`:`"${l}"`});return`await ${e}(${p.join(", ")})`}function m(t,e,n,r="main"){let s=[];for(let i=0;i<t.length;i++){let c=t[i],p=`${r}.${i}`,g=ut(c,e,p,n);g.length>0&&(s.push(...g),i<t.length-1&&s.push(""))}return s}function ut(t,e,n,r){let s=" ".repeat(e);switch(t.type){case"DRAFT":return ft(t,e,n);case"ACTION":return dt(t,e,n,r);case"STEP":return mt(t,e,n,r);case"IF_ELSE":return _t(t,e,n,r);case"WHILE_LOOP":return ht(t,e,n,r);default:return[`${s}// Unknown statement type: ${t.type}`]}}function ft(t,e,n){let r=" ".repeat(e),s=t.description?.trim()||"";if(!s)return[`${r}// ${n}: Skipping - no description`];let i=JSON.stringify(s);return[`${r}// ${n}: ${w(s)}`,`${r}page = agent.agentServices.validatePage(page);`,`${r}await agent.run(page, ${i}, '${n}');`]}function dt(t,e,n,r){let s=" ".repeat(e),i=t.description,c=t.uid,g=r.actionEntityStore?.entries[t.uid]?.action_entity??t.action_entity;if(!g){if(!i)return[`${s}// ${n}: Skipping - no description`];let A=JSON.stringify(i),Z=!!t.use_pure_vision;return[`${s}// ${n}: ${w(i)}`,`${s}page = agent.agentServices.validatePage(page);`,`${s}await agent.execute(page, ${A}, '${n}', ${Z});`]}let a=t.locator?{...g,locator:t.locator}:g;i&&i!==a.action_description&&(a={...a,action_description:i});let l=a.action_data?.action_name||"",u=a.action_description||"",h=Y(l);if(!h)return[`${s}// ${n}: Unknown action: ${l}`];let x={imports:r.imports},k=h(a,n,x);if(G(a))return[`${s}// ${n}: ${w(u)}`,`${s}page = agent.agentServices.validatePage(page);`,...k.map(A=>`${s}${A}`)];let P=JSON.stringify(u),I=k.map(A=>`${s} ${A}`),O=M(a),Q=c?`'${c}'`:"undefined";return[`${s}// ${n}: ${w(u)}`,`${s}page = agent.agentServices.validatePage(page);`,`${s}await agent.step(page, async () => {`,...I,`${s}}, ${P}, '${n}', ${Q}, ${O});`]}function mt(t,e,n,r){let s=" ".repeat(e),i=[];t.description&&t.description.trim()&&i.push(`${s}// Step: ${w(t.description)}`);let c=m(t.statements,e,r,n);return i.push(...c),i}function _t(t,e,n,r){let s=" ".repeat(e),i=[];if(i.push(`${s}// ${n}: Conditional check`),t.condition.type==="JS_CODE")i.push(`${s}if (${t.condition.expression}) {`);else{i.push(`${s}// AI Condition: ${w(t.condition.expression)}`);let p=JSON.stringify(t.condition.expression);i.push(`${s}if (await agent.evaluate(page, ${p}, "${n}")) {`)}let c=m(t.then,e+1,r,`${n}.then`);if(i.push(...c),t.else&&t.else.length>0){i.push(`${s}} else {`);let p=m(t.else,e+1,r,`${n}.else`);i.push(...p)}return i.push(`${s}}`),i}function ht(t,e,n,r){let s=" ".repeat(e),i=[];i.push(`${s}// ${n}: Loop`);let c=t.timeout_ms??j,p=c/1e3,g=t.timeout_ms?`While loop exceeded timeout of ${p}s`:`While loop exceeded default timeout of ${p}s`,a=`loop_${n.replace(/\./g,"_")}`;if(i.push(`${s}const ${a}_start = Date.now();`),i.push(`${s}const ${a}_timeout = ${c};`),i.push(`${s}const ${a}_check = () => {`),i.push(`${s} if (Date.now() - ${a}_start > ${a}_timeout) {`),i.push(`${s} throw new Error('${g}');`),i.push(`${s} }`),i.push(`${s} return true;`),i.push(`${s}};`),t.condition.type==="JS_CODE")i.push(`${s}while (${a}_check() && (${t.condition.expression})) {`);else{i.push(`${s}// AI Loop Condition: ${w(t.condition.expression)}`);let u=JSON.stringify(t.condition.expression);i.push(`${s}while (${a}_check() && await agent.evaluate(page, ${u}, "${n}")) {`)}let l=m(t.body,e+1,r,`${n}.body`);return i.push(...l),i.push(`${s}}`),i}var V={name:"shiplightai",version:"0.1.6",type:"module",description:"Shiplight CLI for running and debugging .test.yaml files",main:"dist/index.js",types:"dist/index.d.ts",bin:{shiplight:"dist/cli.js"},exports:{".":{types:"./dist/index.d.ts",import:"./dist/index.js",require:"./dist/cjs/index.cjs",default:"./dist/index.js"},"./fixture":{types:"./dist/fixture.d.ts",import:"./dist/fixture.js",require:"./dist/cjs/fixture.cjs",default:"./dist/fixture.js"}},files:["dist","README.md"],publishConfig:{registry:"https://registry.npmjs.org",access:"public"},scripts:{build:"tsup","build:cli":"tsup",clean:"rm -rf dist",dev:"tsup --watch",test:"playwright test",typecheck:"tsc --noEmit"},dependencies:{"@babel/plugin-transform-typescript":"^7.27.0","@babel/preset-env":"^7.26.9","@babel/preset-typescript":"^7.27.0","@anthropic-ai/claude-agent-sdk":"^0.1.72","@modelcontextprotocol/sdk":"^0.5.0",axios:"^1.6.0",dotenv:"^16.0.3",express:"^4.21.0",glob:"^13.0.0",open:"^10.1.0",sharp:"^0.34.5",uuid:"^11.1.0",yaml:"^2.8.0",zod:"^3.22.0","zod-to-json-schema":"^3.24.6"},devDependencies:{"@playwright/test":"1.55.0","@shiplightai/sdk-pro":"workspace:*","@types/express":"^4.17.21","@types/node":"^24.0.0",copilot3:"workspace:*","mcp-tools":"workspace:*","sdk-core":"workspace:*","sdk-internal":"workspace:*","shiplight-types":"workspace:*",tsup:"^8.3.5",typescript:"5.5.4","web-session":"workspace:*"},peerDependencies:{"@playwright/test":"1.55.0","@shiplightai/sdk-pro":">=0.2.0"},engines:{node:">=22.0.0"},keywords:["playwright","yaml","testing","automation","ai","shiplight","mcp"],author:"Shiplight",license:"MIT"};var N=V.version;function K(t,e){let n=[];n.push(`// @generated by shiplightai v${N}`),n.push(...yt()),n.push(""),e?.use&&Object.keys(e.use).length>0&&(n.push(`test.use(${JSON.stringify(e.use,null,2)});`),n.push(""));let r=e?.testName||t.goal||"Generated test",s=e?.tags&&e.tags.length>0?e.tags.map(a=>`@${a}`).join(" ")+" ":"";n.push(`test('${s}${v(r)}', async ({ page, agent }) => {`);let i=e?.startingUrl||t.url;if(i){let a;try{a=new URL(i).pathname}catch{a=i}n.push(` await page.goto('${v(a)}', { waitUntil: 'domcontentloaded' });`),n.push("")}let c=new Set,p={imports:c};if(t.teardown&&t.teardown.length>0){if(n.push(" try {"),t.statements&&t.statements.length>0){n.push(" // Test steps");let l=m(t.statements,2,p);n.push(...l)}n.push(" } finally {"),n.push(" // Teardown");let a=m(t.teardown,2,p,"teardown");n.push(...a),n.push(" }")}else if(t.statements&&t.statements.length>0){n.push(" // Test steps");let a=m(t.statements,1,p);n.push(...a)}if(n.push("});"),c.size>0){let a=0;for(let u=0;u<n.length;u++)n[u].startsWith("import ")&&(a=u+1);let l=Array.from(c);n.splice(a,0,...l)}return n.join(`
6
+ `)}function yt(){return["import { test, expect } from 'shiplightai/fixture';"]}function q(t){try{return St(t).mtimeMs}catch{return 0}}var Tt=`// @generated by shiplightai v${N}`;function Ot(t,e){if(!xt(t)||z(t,"utf-8").split(`
7
+ `,1)[0]!==Tt)return!1;let r=q(t);for(let s of e)if(q(s)>r)return!1;return!0}function B(t){let e=At("**/*.test.yaml",{cwd:t.cwd,ignore:["**/node_modules/**"]}),n=[];for(let r of e){let s=kt(t.cwd,r),i=s.replace(/\.test\.yaml$/,".yaml.spec.ts"),c=z(s,"utf-8");try{let{testFlow:p,name:g,tags:a,use:l,referencedTemplatePaths:u}=F(c,s);if(Ot(i,[s,...u]))continue;let h=K(p,{testName:g,tags:a,use:l});$t(i,h)}catch(p){console.error(`[shiplight] Failed to transpile ${r}:`,p),n.push({file:r,error:p})}}if(n.length>0)throw new Error(`[shiplight] Transpilation failed for ${n.length} file(s):
8
8
  `+n.map(r=>` - ${r.file}`).join(`
9
- `))}import*as A from"path";import{mkdir as vt}from"fs/promises";import*as b from"fs";import*as S from"path";function E(t){let e=null,n=process.env.SHIPLIGHT_LOGIN_EMAIL,r=process.env.SHIPLIGHT_LOGIN_PASSWORD;return n&&r&&(e={username:n,password:r}),e||(e=Nt(t)),e?(process.env.SHIPLIGHT_LOGIN_URL&&(e.loginUrl=process.env.SHIPLIGHT_LOGIN_URL),process.env.SHIPLIGHT_LOGIN_TOTP_SECRET&&(e.totpSecret=process.env.SHIPLIGHT_LOGIN_TOTP_SECRET),e):null}function Nt(t){let e=S.resolve(t),n=S.resolve(process.cwd());for(;;){for(let s of["shiplight.config.json","login.config.json"]){let i=S.join(e,s);if(b.existsSync(i))try{let c=JSON.parse(b.readFileSync(i,"utf-8"));if(c.username&&c.password)return{username:c.username,password:c.password,loginUrl:c.url,totpSecret:c.totp_secret}}catch{}}if(e===n)break;let r=S.dirname(e);if(r===e)break;e=r}return null}async function bt(t,e){let n=A.resolve(e),r=E(n);if(!r)return;let{WebAgent:s,createAgentContext:i,configureSdk:c,VariableStore:p}=await import("@shiplightai/sdk-pro");c({env:{GOOGLE_API_KEY:process.env.GOOGLE_API_KEY??"",ANTHROPIC_API_KEY:process.env.ANTHROPIC_API_KEY??""}});let g=process.env.WEB_AGENT_MODEL||(process.env.ANTHROPIC_API_KEY?"claude-haiku-4-5":void 0)||(process.env.GOOGLE_API_KEY?"gemini-2.5-pro":void 0);if(!g)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, ANTHROPIC_API_KEY, or GOOGLE_API_KEY.");let a=new s(i({model:g,variableStore:new p})),{username:l,password:u,loginUrl:h,totpSecret:x}=r,T=h||t.url()||"about:blank";if(!(await a.loginPage(t,{site_url:T,num_verification_exprs:0,account:{type:"password",username:l,password:u,...x&&{two_factor_auth_config:{type:"totp",data:x}}}})).success)throw new Error("Login failed.");let O=A.join(n,".auth");await vt(O,{recursive:!0}),await t.context().storageState({path:A.join(O,"storage-state.json")})}function B(){return`// @generated by shiplightai \u2014 do not edit
9
+ `))}import*as T from"path";import{mkdir as Nt}from"fs/promises";import*as b from"fs";import*as S from"path";function E(t){let e=null,n=process.env.SHIPLIGHT_LOGIN_EMAIL,r=process.env.SHIPLIGHT_LOGIN_PASSWORD;return n&&r&&(e={username:n,password:r}),e||(e=vt(t)),e?(process.env.SHIPLIGHT_LOGIN_URL&&(e.loginUrl=process.env.SHIPLIGHT_LOGIN_URL),process.env.SHIPLIGHT_LOGIN_TOTP_SECRET&&(e.totpSecret=process.env.SHIPLIGHT_LOGIN_TOTP_SECRET),e):null}function vt(t){let e=S.resolve(t),n=S.resolve(process.cwd());for(;;){for(let s of["shiplight.config.json","login.config.json"]){let i=S.join(e,s);if(b.existsSync(i))try{let c=JSON.parse(b.readFileSync(i,"utf-8"));if(c.username&&c.password)return{username:c.username,password:c.password,loginUrl:c.url,totpSecret:c.totp_secret}}catch{}}if(e===n)break;let r=S.dirname(e);if(r===e)break;e=r}return null}async function bt(t,e){let n=T.resolve(e),r=E(n);if(!r)return;let{WebAgent:s,createAgentContext:i,configureSdk:c,VariableStore:p}=await import("@shiplightai/sdk-pro");c({env:{GOOGLE_API_KEY:process.env.GOOGLE_API_KEY??"",ANTHROPIC_API_KEY:process.env.ANTHROPIC_API_KEY??""}});let{resolveModelFromEnv:g}=await import("./dist-QV5DG3DA.js"),a=g();if(!a)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, ANTHROPIC_API_KEY, or GOOGLE_API_KEY.");let l=new s(i({model:a,variableStore:new p})),{username:u,password:h,loginUrl:x,totpSecret:k}=r,P=x||t.url()||"about:blank";if(!(await l.loginPage(t,{site_url:P,num_verification_exprs:0,account:{type:"password",username:u,password:h,...k&&{two_factor_auth_config:{type:"totp",data:k}}}})).success)throw new Error("Login failed.");let O=T.join(n,".auth");await Nt(O,{recursive:!0}),await t.context().storageState({path:T.join(O,"storage-state.json")})}function X(){return`// @generated by shiplightai \u2014 do not edit
10
10
  import { test as setup } from '@playwright/test';
11
11
 
12
12
  setup('authenticate', async ({ page }) => {
13
13
  const { authSetup } = await import('shiplightai');
14
14
  await authSetup(page, __dirname);
15
15
  });
16
- `}function Lt(t={}){t.dotenv!==!1&&Ct(t.scanDir||process.cwd());let e=t.scanDir||process.cwd();return z({cwd:e}),It(e),t.apiKey&&(process.env.__SHIPLIGHT_API_KEY=t.apiKey),{}}function Ct(t){let e=[],n=f.resolve(t),r=f.resolve(process.cwd());for(;;){let s=f.join(n,".env");if(_.existsSync(s)&&e.push(s),n===r)break;let i=f.dirname(n);if(i===n)break;n=i}for(let s of e)Pt.config({path:s})}function It(t){let e=Et("**/shiplight.config.json",{cwd:t,ignore:["**/node_modules/**"]});for(let n of e){let r=f.resolve(t,n),s=f.dirname(r),i=f.join(s,"auth.setup.ts");try{let c=JSON.parse(_.readFileSync(r,"utf-8"));if(!c.username||!c.password)continue}catch{continue}try{let c=_.statSync(r).mtimeMs;if(_.statSync(i).mtimeMs>c)continue}catch{}_.writeFileSync(i,B())}}export{bt as authSetup,E as resolveLoginConfig,Lt as shiplightConfig};
16
+ `}function Et(t={}){t.dotenv!==!1&&It(t.scanDir||process.cwd());let e=t.scanDir||process.cwd();return B({cwd:e}),Ct(e),t.apiKey&&(process.env.__SHIPLIGHT_API_KEY=t.apiKey),{}}function It(t){let e=[],n=d.resolve(t),r=d.resolve(process.cwd());for(;;){let s=d.join(n,".env");if(_.existsSync(s)&&e.push(s),n===r)break;let i=d.dirname(n);if(i===n)break;n=i}for(let s of e)Pt.config({path:s})}function Ct(t){let e=Lt("**/shiplight.config.json",{cwd:t,ignore:["**/node_modules/**"]});for(let n of e){let r=d.resolve(t,n),s=d.dirname(r),i=d.join(s,"auth.setup.ts"),c=!1;try{let p=JSON.parse(_.readFileSync(r,"utf-8"));c=!!(p.username&&p.password)}catch{}if(!c&&process.env.SHIPLIGHT_LOGIN_EMAIL&&process.env.SHIPLIGHT_LOGIN_PASSWORD&&(c=!0),!!c){try{let p=_.statSync(r).mtimeMs;if(_.statSync(i).mtimeMs>p)continue}catch{}_.writeFileSync(i,X())}}}export{bt as authSetup,E as resolveLoginConfig,Et as shiplightConfig};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "shiplightai",
3
- "version": "0.1.5",
3
+ "version": "0.1.6",
4
4
  "type": "module",
5
5
  "description": "Shiplight CLI for running and debugging .test.yaml files",
6
6
  "main": "dist/index.js",