momentic 2.0.1 → 2.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/bin/cli.js CHANGED
@@ -1,17 +1,17 @@
1
1
  #!/usr/bin/env node
2
2
 
3
- !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="a81c6a16-1a30-5cf3-be42-b81beeac317a")}catch(e){}}();
4
- var uT=Object.create;var wu=Object.defineProperty;var mT=Object.getOwnPropertyDescriptor;var hT=Object.getOwnPropertyNames;var gT=Object.getPrototypeOf,fT=Object.prototype.hasOwnProperty;var vu=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports);var ST=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of hT(e))!fT.call(n,o)&&o!==t&&wu(n,o,{get:()=>e[o],enumerable:!(r=mT(e,o))||r.enumerable});return n};var yT=(n,e,t)=>(t=n!=null?uT(gT(n)):{},ST(e||!n||!n.__esModule?wu(t,"default",{value:n,enumerable:!0}):t,n));var Ff=vu((Yq,Df)=>{"use strict";Df.exports=Nf;function Nf(n,e,t){n instanceof RegExp&&(n=Mf(n,t)),e instanceof RegExp&&(e=Mf(e,t));var r=_f(n,e,t);return r&&{start:r[0],end:r[1],pre:t.slice(0,r[0]),body:t.slice(r[0]+n.length,r[1]),post:t.slice(r[1]+e.length)}}function Mf(n,e){var t=e.match(n);return t?t[0]:null}Nf.range=_f;function _f(n,e,t){var r,o,i,a,s,l=t.indexOf(n),c=t.indexOf(e,l+1),d=l;if(l>=0&&c>0){if(n===e)return[l,c];for(r=[],i=t.length;d>=0&&!s;)d==l?(r.push(d),l=t.indexOf(n,d+1)):r.length==1?s=[r.pop(),c]:(o=r.pop(),o<i&&(i=o,a=c),c=t.indexOf(e,d+1)),d=l<c&&l>=0?l:c;r.length&&(s=[i,a])}return s}});var Wf=vu((Jq,Gf)=>{"use strict";var Uf=Ff();Gf.exports=sA;var Bf="\0SLASH"+Math.random()+"\0",zf="\0OPEN"+Math.random()+"\0",ud="\0CLOSE"+Math.random()+"\0",Hf="\0COMMA"+Math.random()+"\0",jf="\0PERIOD"+Math.random()+"\0";function pd(n){return parseInt(n,10)==n?parseInt(n,10):n.charCodeAt(0)}function iA(n){return n.split("\\\\").join(Bf).split("\\{").join(zf).split("\\}").join(ud).split("\\,").join(Hf).split("\\.").join(jf)}function aA(n){return n.split(Bf).join("\\").split(zf).join("{").split(ud).join("}").split(Hf).join(",").split(jf).join(".")}function $f(n){if(!n)return[""];var e=[],t=Uf("{","}",n);if(!t)return n.split(",");var r=t.pre,o=t.body,i=t.post,a=r.split(",");a[a.length-1]+="{"+o+"}";var s=$f(i);return i.length&&(a[a.length-1]+=s.shift(),a.push.apply(a,s)),e.push.apply(e,a),e}function sA(n){return n?(n.substr(0,2)==="{}"&&(n="\\{\\}"+n.substr(2)),ia(iA(n),!0).map(aA)):[]}function lA(n){return"{"+n+"}"}function cA(n){return/^-?0\d/.test(n)}function dA(n,e){return n<=e}function pA(n,e){return n>=e}function ia(n,e){var t=[],r=Uf("{","}",n);if(!r)return[n];var o=r.pre,i=r.post.length?ia(r.post,!1):[""];if(/\$$/.test(r.pre))for(var a=0;a<i.length;a++){var s=o+"{"+r.body+"}"+i[a];t.push(s)}else{var l=/^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(r.body),c=/^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(r.body),d=l||c,p=r.body.indexOf(",")>=0;if(!d&&!p)return r.post.match(/,.*\}/)?(n=r.pre+"{"+r.body+ud+r.post,ia(n)):[n];var m;if(d)m=r.body.split(/\.\./);else if(m=$f(r.body),m.length===1&&(m=ia(m[0],!1).map(lA),m.length===1))return i.map(function(H){return r.pre+m[0]+H});var u;if(d){var h=pd(m[0]),g=pd(m[1]),f=Math.max(m[0].length,m[1].length),S=m.length==3?Math.abs(pd(m[2])):1,b=dA,w=g<h;w&&(S*=-1,b=pA);var v=m.some(cA);u=[];for(var x=h;b(x,g);x+=S){var C;if(c)C=String.fromCharCode(x),C==="\\"&&(C="");else if(C=String(x),v){var A=f-C.length;if(A>0){var N=new Array(A+1).join("0");x<0?C="-"+N+C.slice(1):C=N+C}}u.push(C)}}else{u=[];for(var O=0;O<m.length;O++)u.push.apply(u,ia(m[O],!1))}for(var O=0;O<u.length;O++)for(var a=0;a<i.length;a++){var s=o+u[O]+i[a];(!e||d||s)&&t.push(s)}}return t}});var xi=(n,e)=>{},Zl=!1;try{let n=await import("@sentry/node");xi=n.captureException,n.init({dsn:"https://89e980855f7b9c6e56fc6c7e7143888b@o4506426201800704.ingest.us.sentry.io/4508343221354497",environment:"production",release:process.env.SENTRY_RELEASE_NAME}),Zl=!0}catch{}import{Command as TN,Option as rn}from"@commander-js/extra-typings";import{execSync as xN}from"child_process";import Uw from"body-parser";import iM from"cors";import aM from"dedent";import sM from"events";import Bw,{Router as lM}from"express";import{diff as nA}from"deep-object-diff";import cn from"fs";import $r from"path";import{diff as IR}from"deep-object-diff";import{z as Tu}from"zod";var NN=Tu.object({input:Tu.string()});import{z as Ve}from"zod";var FN=Ve.object({srcs:Ve.array(Ve.string()),urls:Ve.array(Ve.string()),desiredSrc:Ve.string().optional(),desiredUrl:Ve.string().optional()}),xu=Ve.object({srcRegex:Ve.string().optional(),urlRegex:Ve.string().optional()}),Eu=Ve.object({x:Ve.number(),y:Ve.number(),correlation:Ve.number()}),UN=Ve.object({searchImageBase64String:Ve.string(),pageImageBase64String:Ve.string(),id:Ve.string().uuid(),timeoutMs:Ve.number().max(1e4).min(0).optional()});import{z as k}from"zod";import{v4 as Re}from"uuid";import*as T from"zod";function ve(n){if(typeof n.ZodType.prototype.openapi<"u")return;n.ZodType.prototype.openapi=function(o){return new this.constructor({...this._def,openapi:o})};let e=n.ZodObject.prototype.extend;n.ZodObject.prototype.extend=function(...o){let i=e.apply(this,o);return i._def.extendMetadata={extends:this},delete i._def.openapi,i};let t=n.ZodObject.prototype.omit;n.ZodObject.prototype.omit=function(...o){let i=t.apply(this,o);return delete i._def.extendMetadata,delete i._def.openapi,i};let r=n.ZodObject.prototype.pick;n.ZodObject.prototype.pick=function(...o){let i=r.apply(this,o);return delete i._def.extendMetadata,delete i._def.openapi,i}}import{z as ge}from"zod";ve(ge);var Cu=ge.object({plan:ge.string().optional(),evidence:ge.string().optional(),thoughts:ge.string(),result:ge.boolean(),relevantElements:ge.array(ge.number()).optional()}),co=(o=>(o.CONTAINS="CONTAINS",o.STARTS_WITH="STARTS_WITH",o.EQUALS="EQUALS",o.EXISTS="EXISTS",o))(co||{});var bT=ge.object({type:ge.literal("ELEMENT_CONTENT"),negated:ge.boolean().optional(),operation:ge.nativeEnum(co),value:ge.string()}).openapi({ref:"ElementContentAssertion"}),wT=ge.object({type:ge.literal("ELEMENT_ATTRIBUTE"),negated:ge.boolean().optional(),operation:ge.nativeEnum(co),attr:ge.string(),value:ge.string()}).openapi({ref:"ElementAttributeValueAssertion"}),Ei=(o=>(o.EXISTS="EXISTS",o.VISIBLE="VISIBLE",o.ENABLED="ENABLED",o.EDITABLE="EDITABLE",o))(Ei||{}),vT=ge.object({type:ge.literal("ELEMENT_EXISTENCE"),negated:ge.boolean().optional(),condition:ge.nativeEnum(Ei).describe("Treated as the element exists AND is also ...")}).openapi({ref:"ElementExistenceAssertion"}),Ru=ge.discriminatedUnion("type",[bT,wT,vT]).openapi({ref:"ManualElementAssertion"});var TT=ge.object({type:ge.literal("CONTENT"),negated:ge.boolean().optional(),value:ge.string()}).openapi({ref:"PageContentAssertion"}),Au=ge.discriminatedUnion("type",[TT]).openapi({ref:"ManualPageAssertion"});import*as q from"zod";ve(q);var Jn=(s=>(s.AI="AI",s.AI_HEALED="AI_HEALED",s.CLICK_TO_FIND="CLICK_TO_FIND",s.XY_PERCENT="XY_PERCENT",s.RECORDING="RECORDING",s.USER_CSS_SELECTOR="USER_CSS_SELECTOR",s.HEURISTIC_HEALED="HEURISTIC_HEALED",s))(Jn||{}),xT=q.object({mPathSelectorTokens:q.string().array(),frameSrcRegex:q.string().optional(),frameUrlRegex:q.string().optional(),indices:q.number().array()}),vr=q.object({id:q.number().int(),dataMomenticId:q.number().int().optional(),selector:q.string().optional(),generatedSelectors:q.string().array().optional(),role:q.string().optional(),name:q.string().optional(),numChildren:q.number().optional(),content:q.string().optional(),pathFromRoot:q.string().optional(),serializedForm:q.string().optional(),nodeOnlySerializedForm:q.string().optional(),serializedHtml:q.string().optional().describe("pruned html including 1 neighbor and 1 layer of children. value for text inputs pruned."),nodeOnlySerializedHtml:q.string().optional().describe("outerHtml of the element without any children. value for text inputs pruned."),screenshotUrl:q.string().url().optional(),boundingBox:q.object({x:q.number().optional(),y:q.number().optional(),width:q.number(),height:q.number()}).describe("css pixel bounding box").optional(),frameCache:xT.optional(),inputDescription:q.string().optional().describe("the description that generated this cache"),targetSource:q.nativeEnum(Jn).optional(),targetUpdateTime:q.string().optional(),targetUpdateLoggerTags:q.record(q.string(),q.string()).optional()}).openapi({ref:"A11yTargetWithCache"});function Iu(n){return!!(n.name||n.role||n.content||n.serializedForm||n.serializedHtml||n.screenshotUrl)}var ET=q.object({type:q.literal("description"),elementDescriptor:q.string(),a11yData:vr.optional().describe("DEPRECATED: new a11y cache is stored in DB and resolved into the 'cache' field")}).openapi({ref:"DescriptionTarget"}),CT=q.object({x:q.number(),y:q.number()}),RT=q.object({type:q.literal("coordinates"),pixels:CT}).openapi({ref:"CoordinatesTarget"});function Xn(n){return n.type==="description"}function yn(n){return n.type==="coordinates"}var dt=q.discriminatedUnion("type",[ET,RT]).openapi({ref:"ElementTarget"});function Ql(n){if(!n)return!1;switch(n.type){case"description":return!!n.elementDescriptor}return!0}function pt(n){if(!n)return"";switch(n.type){case"description":return n.elementDescriptor;case"coordinates":return`x: ${n.pixels.x}, y: ${n.pixels.y}`}}import{z as ae}from"zod";var Na=ae.object({url:ae.string(),method:ae.union([ae.literal("GET"),ae.literal("POST"),ae.literal("PUT"),ae.literal("DELETE"),ae.literal("PATCH")]),headers:ae.record(ae.string(),ae.string()).optional(),params:ae.record(ae.string(),ae.string()).optional(),body:ae.string().optional(),timeout:ae.number().int().optional().describe("Max seconds to wait for the request to complete")}),Pu=ae.object({url:ae.string(),headers:ae.record(ae.string(),ae.string()).optional(),query:ae.string(),variables:ae.record(ae.string(),ae.string()).optional(),timeout:ae.number().int().optional().describe("Max seconds to wait for the request to complete")}),_a=ae.object({code:ae.string(),fragment:ae.boolean().optional(),environment:ae.union([ae.literal("NODE"),ae.literal("BROWSER")]).optional().describe("default NODE"),timeout:ae.number().int().max(60).optional().describe("Max seconds for the code to complete")});var Ue=(j=>(j.AI_EXTRACT="AI_EXTRACT",j.AI_ASSERTION="AI_ASSERTION",j.AUTH_LOAD="AUTH_LOAD",j.AUTH_SAVE="AUTH_SAVE",j.BLUR="BLUR",j.CAPTCHA="CAPTCHA",j.CLICK="CLICK",j.COOKIE="COOKIE",j.COPY="COPY",j.DIALOG="DIALOG",j.DRAG="DRAG",j.ELEMENT_CHECK="ELEMENT_CHECK",j.FILE_UPLOAD="FILE_UPLOAD",j.FOCUS="FOCUS",j.GO_BACK="GO_BACK",j.GO_FORWARD="GO_FORWARD",j.HOVER="HOVER",j.JAVASCRIPT="JAVASCRIPT",j.LOCAL_STORAGE="LOCAL_STORAGE",j.MOUSE_DRAG="MOUSE_DRAG",j.NAVIGATE="NAVIGATE",j.NEW_TAB="NEW_TAB",j.PAGE_CHECK="PAGE_CHECK",j.PASTE="PASTE",j.PRESS="PRESS",j.REFRESH="REFRESH",j.REQUEST="REQUEST",j.GRAPHQL_REQUEST="GRAPHQL_REQUEST",j.SCROLL_DOWN="SCROLL_DOWN",j.SCROLL_UP="SCROLL_UP",j.SCROLL_LEFT="SCROLL_LEFT",j.SCROLL_RIGHT="SCROLL_RIGHT",j.SELECT_OPTION="SELECT_OPTION",j.SWITCH_TAB="TAB",j.TYPE="TYPE",j.VISUAL_DIFF="VISUAL_DIFF",j.WAIT="WAIT",j.WAIT_FOR_URL="WAIT_FOR_URL",j.REGISTER_REQUEST_LISTENER="REGISTER_REQUEST_LISTENER",j.AWAIT_LISTENER="AWAIT_LISTENER",j.SUCCESS="SUCCESS",j))(Ue||{});ve(T);var J=T.object({thoughts:T.string().optional(),id:T.string().uuid().describe("unique identifier to this step, used for step cache")}),Ht=T.object({useSelector:T.boolean().optional(),force:T.boolean().optional(),disableCache:T.boolean().optional().describe("disable element caching for this step"),iframeUrl:T.string().optional().describe("url or url regex for the iframe")}).openapi({ref:"CommonTargetingOptions"}),bn=T.object({target:vr}).optional().openapi({ref:"SingleTargetCache"}),Da=T.object({loadTimeout:T.number().int().max(60).optional().describe("Max seconds for the page to load")}),AT=J.merge(Da).merge(T.object({type:T.literal("NAVIGATE"),url:T.string()})).openapi({ref:"NavigateCommand"}),Fa=Ht.merge(T.object({cache:bn})),po=J.merge(Fa.merge(T.object({target:dt.optional(),type:T.literal("SCROLL_UP"),deltaY:T.number().optional()}))).openapi({ref:"ScrollUpCommand"}),uo=J.merge(Fa.merge(T.object({target:dt.optional(),type:T.literal("SCROLL_DOWN"),deltaY:T.number().optional()}))).openapi({ref:"ScrollDownCommand"}),mo=J.merge(Fa.merge(T.object({target:dt.optional(),type:T.literal("SCROLL_LEFT"),deltaX:T.number().optional()}))).openapi({ref:"ScrollLeftCommand"}),ho=J.merge(Fa.merge(T.object({target:dt.optional(),type:T.literal("SCROLL_RIGHT"),deltaX:T.number().optional()}))).openapi({ref:"ScrollRightCommand"}),t_=T.discriminatedUnion("type",[po,uo,mo,ho]).openapi({ref:"AllScrollCommands"}),IT=J.merge(T.object({type:T.literal("DIALOG"),action:T.union([T.literal("ACCEPT"),T.literal("DISMISS")])})).openapi({ref:"DialogCommand"}),PT=J.merge(T.object({type:T.literal("WAIT"),delay:T.number()})).openapi({ref:"WaitCommand"}),LT=T.discriminatedUnion("type",[T.object({type:T.literal("SUBSTRING"),url:T.string()}),T.object({type:T.literal("GLOB"),glob:T.string()}),T.object({type:T.literal("REGEX"),regex:T.string()})]),OT=T.object({caseInsensitive:T.boolean().optional().describe("Whether to ignore case when matching the URL"),negated:T.boolean().optional().describe("Wait for the URL to NOT match the provided matcher instead."),timeout:T.number().int().optional().describe("Max seconds to wait for the URL to match")}),kT=J.extend({type:T.literal("WAIT_FOR_URL"),matcher:LT}).merge(OT).openapi({ref:"WaitUrlCommand"}),MT=J.merge(Da).merge(T.object({type:T.literal("REFRESH")})).openapi({ref:"RefreshCommand"}),NT=J.merge(T.object({type:T.literal("GO_BACK")})).openapi({ref:"GoBackCommand"}),_T=J.merge(T.object({type:T.literal("GO_FORWARD")})).openapi({ref:"GoForwardCommand"}),DT=J.extend({type:T.literal("AUTH_SAVE")}).openapi({ref:"AuthSaveCommand"}),FT=J.extend({type:T.literal("AUTH_LOAD"),storageState:T.string().describe("JSON string auth state. Leave blank or set to the empty string to clear all existing authentication.")}).openapi({ref:"AuthLoadCommand"}),tc=J.merge(Ht).extend({type:T.literal("CAPTCHA")}).openapi({ref:"CaptchaCommand"}),UT=J.extend({type:T.literal("COPY"),value:T.string()}).openapi({ref:"CopyCommand"}),BT=J.extend({type:T.literal("PASTE")}).openapi({ref:"PasteCommand"}),zT=J.merge(_a).extend({type:T.literal("JAVASCRIPT")}).openapi({ref:"JavaScriptCommand"}),Ri=J.merge(Ht).merge(T.object({type:T.literal("CLICK"),target:dt,doubleClick:T.boolean().optional(),rightClick:T.boolean().optional(),waitForDownload:T.boolean().optional().describe("Wait for the click to trigger a file download and for the file download to complete."),delayMs:T.number().optional(),downloadTimeoutMs:T.number().optional(),cache:bn,relativePosition:T.object({x:T.number(),y:T.number()}).optional()})).openapi({ref:"ClickCommand"}),Ai=J.merge(Ht).merge(T.object({type:T.literal("DRAG"),fromTarget:dt,toTarget:dt,steps:T.number().optional(),hoverSeconds:T.number().optional().describe("Seconds to hover the object before dropping"),cache:T.object({fromTarget:vr.optional(),toTarget:vr.optional()}).optional()})).openapi({ref:"DragCommand"}),Ii=J.merge(Ht).merge(T.object({type:T.literal("MOUSE_DRAG"),target:dt.optional(),deltaX:T.string().describe("pixels to move horizontally, can be template"),deltaY:T.string().describe("pixels to move vertically, can be template"),steps:T.number().optional(),cache:bn})).openapi({ref:"MouseDragCommand"}),Pi=J.merge(Ht).merge(T.object({type:T.literal("HOVER"),target:dt,cache:bn})).openapi({ref:"HoverCommand"}),Li=J.merge(Ht).merge(T.object({type:T.literal("FOCUS"),target:dt,cache:bn})).openapi({ref:"FocusCommand"}),Oi=J.merge(Ht).extend({type:T.literal("BLUR"),target:dt.optional(),cache:bn}).openapi({ref:"BlurCommand"}),HT=T.object({type:T.literal("URL"),url:T.string()}).describe("Accessible link to the file, either public http or local file://").openapi({ref:"UrlSource"}),jT=T.object({type:T.literal("USER_FILE"),name:T.string()}).describe("Accessible link to the file, references the google cloud file").openapi({ref:"UploadedFileSource"}),$T=J.extend({type:T.literal("FILE_UPLOAD"),fileSource:T.discriminatedUnion("type",[HT,jT]),filename:T.string().optional()}).openapi({ref:"FileUploadCommand"}),GT=T.discriminatedUnion("type",[T.object({type:T.literal("VALUE"),value:T.string()}),T.object({type:T.literal("LABEL"),label:T.string()}),T.object({type:T.literal("INDEX"),index:T.coerce.string()})]),ki=J.merge(Ht).extend({type:T.literal("SELECT_OPTION"),target:dt,cache:bn,choice:GT.describe("new field for selecting options, optional for backcompat")}).openapi({ref:"SelectOptionCommand"}),nc=T.union([T.literal("MULTIMODAL"),T.literal("VISION_ONLY")]),Lu=J.merge(T.object({type:T.literal("AI_ASSERTION"),assertion:T.string(),disableCache:T.boolean().optional(),iframeUrl:T.string().optional(),contextChoice:nc.optional(),timeout:T.number().int().optional().describe("Max seconds to wait for assertion to be true")})).openapi({ref:"AIAssertionCommand"}),wn=5,rc=600,Mi=J.merge(Ht).extend({type:T.literal("ELEMENT_CHECK"),target:dt,assertion:Ru,cache:bn,timeout:T.number().int().min(0).max(rc).optional().describe("max seconds to wait for the assertion to be true")}).openapi({ref:"ElementAssertionCommand"}),WT=J.extend({type:T.literal("PAGE_CHECK"),assertion:Au,iframeUrl:T.string().optional().describe("url or url regex for the iframe"),timeout:T.number().int().min(0).max(rc).optional().describe("max seconds to wait for the assertion to be true")}).openapi({ref:"PageAssertionCommand"}),VT=J.merge(T.object({type:T.literal("AI_EXTRACT"),goal:T.string(),schema:T.string().optional(),envKey:T.string().optional(),disableCache:T.boolean().optional(),iframeUrl:T.string().optional()})).openapi({ref:"AIExtractCommand"}),qT=T.object({clearContent:T.boolean().optional(),forceClearContent:T.boolean().optional(),delay:T.number().min(0).max(1e3).optional().describe("Delay between each press in milliseconds."),force:T.boolean().optional(),pressEnter:T.boolean().optional()}),Ou=25,Ni=J.merge(Ht).merge(qT).extend({type:T.literal("TYPE"),target:dt.optional(),value:T.string(),cache:bn}).openapi({ref:"TypeCommand"}),KT=J.merge(T.object({type:T.literal("PRESS"),value:T.string(),repeat:T.number().optional(),convertMeta:T.boolean().optional(),delayMs:T.number().optional()})).openapi({ref:"PressCommand"}),YT=T.object({type:T.literal("SUBSTRING"),substring:T.string()}),JT=T.object({type:T.literal("REGEX"),pattern:T.string()}),XT=T.object({type:T.literal("INDEX"),index:T.coerce.string()}),ZT=T.discriminatedUnion("type",[YT,JT,XT]),QT=J.merge(Da).merge(T.object({type:T.literal("TAB"),action:ZT})).openapi({ref:"TabCommand"}),ex=J.merge(Da).merge(T.object({type:T.literal("NEW_TAB"),url:T.string()})).openapi({ref:"NewTabCommand"}),tx=J.merge(T.object({type:T.literal("COOKIE"),value:T.string()})).openapi({ref:"CookieCommand"}),nx=J.merge(T.object({type:T.literal("LOCAL_STORAGE"),key:T.string(),value:T.string()})).openapi({ref:"LocalStorageCommand"}),rx=J.extend({type:T.literal("REQUEST")}).merge(Na).openapi({ref:"RequestCommand"}),ox=J.extend({type:T.literal("GRAPHQL_REQUEST")}).merge(Pu).openapi({ref:"GraphQLRequestCommand"}),ix=J.merge(T.object({type:T.literal("SUCCESS"),condition:Lu.optional()})).openapi({ref:"SuccessCommand"}),ax=J.merge(T.object({type:T.literal("FAILURE")})).openapi({ref:"FailureCommand"}),sx=T.object({data:T.string().describe("location at which to find a jpg"),width:T.number(),height:T.number()}),_i=J.merge(Ht).merge(T.object({type:T.literal("VISUAL_DIFF"),threshold:T.number().optional().describe("default 0.1"),target:dt.optional(),screenshot:sx.optional(),cache:bn})).openapi({ref:"VisualDiffCommand"}),lx=J.merge(T.object({type:T.literal("REGISTER_REQUEST_LISTENER"),pattern:T.string(),key:T.string()})).openapi({ref:"RegisterRequestListenerCommand"}),cx=J.merge(T.object({type:T.literal("AWAIT_LISTENER"),key:T.string(),timeout:T.number().optional().describe("timeout")})).openapi({ref:"WaitForListenerCommand"}),ku=T.discriminatedUnion("type",[Ri,Ni,KT,ki,AT,uo,po,Lu,Pi,PT,ix]),dx=T.discriminatedUnion("type",[VT,FT,DT,tc,tx,UT,IT,Ai,Mi,$T,NT,_T,zT,nx,Ii,ex,WT,BT,MT,rx,ox,mo,ho,QT,_i,Li,Oi,kT,lx,cx]),go=T.discriminatedUnion("type",[...ku.options,...dx.options]).openapi({ref:"Command"}),Ua=T.discriminatedUnion("type",[...ku.options,ax]);function Nn(n){let e;switch(n){case"PASTE":case"AUTH_SAVE":case"VISUAL_DIFF":case"SUCCESS":case"SCROLL_DOWN":case"SCROLL_UP":case"SCROLL_LEFT":case"SCROLL_RIGHT":case"CAPTCHA":case"GO_BACK":case"GO_FORWARD":case"REFRESH":e={id:Re(),type:n};break;case"AUTH_LOAD":{e={id:Re(),type:n,storageState:""};break}case"AI_EXTRACT":e={id:Re(),type:n,goal:""};break;case"DIALOG":e={id:Re(),type:n,action:"DISMISS"};break;case"DRAG":e={id:Re(),type:n,fromTarget:{type:"description",elementDescriptor:""},toTarget:{type:"description",elementDescriptor:""}};break;case"MOUSE_DRAG":e={id:Re(),type:n,deltaX:"0",deltaY:"0",steps:1};break;case"WAIT_FOR_URL":e={id:Re(),type:n,matcher:{type:"SUBSTRING",url:""}};break;case"WAIT":e={id:Re(),type:n,delay:1};break;case"BLUR":e={id:Re(),type:n};break;case"HOVER":case"FOCUS":case"CLICK":e={id:Re(),type:n,target:{type:"description",elementDescriptor:""}};break;case"COOKIE":case"PRESS":case"COPY":case"TYPE":e={id:Re(),type:n,value:"",clearContent:!0};break;case"SELECT_OPTION":e={id:Re(),type:n,target:{type:"description",elementDescriptor:""},choice:{type:"VALUE",value:""}};break;case"NAVIGATE":case"NEW_TAB":return{id:Re(),type:n,url:""};case"TAB":e={id:Re(),type:n,action:{type:"SUBSTRING",substring:""}};break;case"REQUEST":e={id:Re(),type:n,url:"",method:"GET"};break;case"GRAPHQL_REQUEST":e={id:Re(),type:n,url:"",query:""};break;case"LOCAL_STORAGE":e={id:Re(),type:n,key:"",value:""};break;case"JAVASCRIPT":e={id:Re(),type:n,code:""};break;case"AI_ASSERTION":e={id:Re(),type:n,assertion:""};break;case"FILE_UPLOAD":{e={id:Re(),type:n,fileSource:{type:"URL",url:""}};break}case"ELEMENT_CHECK":{e={id:Re(),type:n,target:{type:"description",elementDescriptor:""},assertion:{type:"ELEMENT_EXISTENCE",condition:"EXISTS"}};break}case"PAGE_CHECK":{e={id:Re(),type:n,assertion:{type:"CONTENT",value:""}};break}case"REGISTER_REQUEST_LISTENER":{e={id:Re(),type:n,pattern:"",key:""};break}case"AWAIT_LISTENER":{e={id:Re(),type:n,key:""};break}default:return(r=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}return e}function Mu(n){switch(n.type){case"BLUR":case"CLICK":case"DRAG":case"FOCUS":case"HOVER":case"MOUSE_DRAG":case"PRESS":case"SCROLL_DOWN":case"SCROLL_UP":case"SCROLL_LEFT":case"SCROLL_RIGHT":case"TYPE":return!0;case"AUTH_LOAD":case"AUTH_SAVE":case"AWAIT_LISTENER":case"SUCCESS":case"AI_ASSERTION":case"AI_EXTRACT":case"CAPTCHA":case"COOKIE":case"COPY":case"DIALOG":case"ELEMENT_CHECK":case"FILE_UPLOAD":case"GO_BACK":case"GO_FORWARD":case"GRAPHQL_REQUEST":case"JAVASCRIPT":case"LOCAL_STORAGE":case"NAVIGATE":case"NEW_TAB":case"PASTE":case"PAGE_CHECK":case"REGISTER_REQUEST_LISTENER":case"REFRESH":case"REQUEST":case"SELECT_OPTION":case"TAB":case"VISUAL_DIFF":case"WAIT":case"WAIT_FOR_URL":return!1;default:return(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}import{z as px}from"zod";var a_=px.discriminatedUnion("type",[Oi,tc,Ri,Ai,Li,Pi,Ii,po,uo,mo,ho,ki,Ni,_i,Mi]);function Nu(n){return["AI_ASSERTION","ELEMENT_CHECK","PAGE_CHECK"].includes(n)}import{z as ux}from"zod";var xt={type:!0,cache:!0},Tr=ux.discriminatedUnion("type",[Oi.pick(xt),Ri.pick(xt),Ai.pick(xt),Mi.pick(xt),Li.pick(xt),Pi.pick(xt),Ii.pick(xt),po.pick(xt),uo.pick(xt),mo.pick(xt),ho.pick(xt),ki.pick(xt),Ni.pick(xt),_i.pick(xt)]),oc=Object.values(Ue).filter(n=>Tr.options.some(e=>e.shape.type.safeParse(n).success));go.options.forEach(n=>{if("target"in n.shape&&!oc.includes(n.shape.type.value))throw new Error(`Command ${n.shape.type.value} has a target but no cache`)});import{z as ac}from"zod";import{z as ic}from"zod";import{z as fo}from"zod";var Et=fo.object({index:fo.number().optional().describe("global index within a test (in-order traversal)"),id:fo.string(),skipped:fo.boolean().optional(),envKey:fo.string().optional().describe("key in the environment to save the result of this step to"),aiSuggested:fo.boolean().optional()});ve(ic);var Ct=Et.extend({type:ic.literal("PRESET_ACTION"),command:go,skipped:ic.boolean().optional()}).openapi({ref:"PresetAction"});ve(ac);var xr=Et.extend({type:ac.literal("AI_ACTION"),text:ac.string(),steps:Ct.array().optional()}).openapi({ref:"AIAction"});import{z as le}from"zod";var mx=le.object({cacheKey:le.string(),cacheExpiryMs:le.number()}),sc=Et.extend({id:le.string().uuid().describe("ID of the module step itself. Used to 'namespace' step cache entries."),inputs:le.record(le.string()).optional(),cacheConfig:mx.optional()}),_n=sc.extend({type:le.literal("MODULE"),moduleId:le.string().uuid()}),hx=le.union([_n.pick({type:!0,moduleId:!0}),le.record(le.unknown())]),gx=le.object({type:le.literal("URL_REGEX"),regex:le.string()}),fx=le.object({type:le.literal("PAGE_CHECK"),substring:le.string()}),lc=le.object({cacheInvalidation:le.discriminatedUnion("type",[fx,gx]).optional()}),Rt=le.object({moduleId:le.string().uuid(),name:le.string(),description:le.string().nullish(),enabled:le.boolean().nullish(),parameters:le.string().array().nullish(),defaultParameters:le.record(le.string(),le.string()).nullish(),defaultCacheKey:le.string().nullish(),defaultCacheTtl:le.number().nullish(),defaultCacheAllInvocations:le.boolean().nullish(),autoAuth:le.boolean().nullish(),advanced:lc.nullish()});import{z as it}from"zod";import{z as cc}from"zod";ve(cc);var So=Et.extend({type:cc.literal("AI_ACTION_DYNAMIC"),text:cc.string()}).openapi({ref:"AIActionDynamic"});import{z as _u}from"zod";var dc=Et.extend({type:_u.literal("CONDITIONAL"),skipped:_u.boolean().optional()});import{z as Ba}from"zod";var Sx=Ba.object({type:Ba.literal("url"),url:Ba.string()}),Di=Et.extend({type:Ba.literal("IFRAME"),identifier:Sx});import{z as jt}from"zod";var pc=(r=>(r.ALWAYS="ALWAYS",r.ON_FAILURE="ON_FAILURE",r.ON_ACTION_FAILURE="ON_ACTION_FAILURE",r))(pc||{});var yx=jt.discriminatedUnion("type",[jt.object({type:jt.literal("NAVIGATE_URL"),url:jt.string().url()}),jt.object({type:jt.literal("GO_TO_SECTION_START")})]),bx=jt.object({trigger:jt.nativeEnum(pc).optional(),attempts:jt.number().int().optional(),restartBehavior:yx}),Fi=Et.extend({type:jt.literal("SECTION"),description:jt.string().describe("user provided goal of what the section should accomplish"),plan:jt.string().array().optional(),autohealingConfig:bx.optional()});var Du=Rt.merge(sc).extend({type:it.literal("RESOLVED_MODULE"),steps:it.lazy(()=>Ae.array())}),uc=Rt.extend({steps:it.lazy(()=>Ae.array())}),mc=Di.extend({steps:it.lazy(()=>Se.array())}),wx=Di.extend({steps:it.lazy(()=>Ae.array())}),hc=Fi.extend({steps:it.lazy(()=>Se.array())}),vx=Fi.extend({steps:it.lazy(()=>Ae.array())}),Er=dc.extend({blocks:it.object({assertion:it.lazy(()=>Ct),steps:it.lazy(()=>Se.array())}).array(),elseSteps:it.lazy(()=>Se.array().optional())}),Tx=dc.extend({blocks:it.object({assertion:it.lazy(()=>Ct),steps:it.lazy(()=>Ae.array())}).array(),elseSteps:it.lazy(()=>Ae.array().optional())}),Se=it.discriminatedUnion("type",[Ct,xr,So,_n,Er,mc,hc]),Ae=it.discriminatedUnion("type",[Ct,xr,So,Du,Tx,wx,vx]);import{z as $t}from"zod";var xx=$t.object({steps:Se.array(),beforeSteps:Se.array().nullish(),afterSteps:Se.array().nullish()}),yo=$t.object({steps:Ae.array(),beforeSteps:Ae.array().nullish(),afterSteps:Ae.array().nullish()}),Cr=$t.object({steps:$t.record($t.string(),$t.unknown()).array(),beforeSteps:$t.record($t.string(),$t.unknown()).array().nullish(),afterSteps:$t.record($t.string(),$t.unknown()).array().nullish()});var Fe="1.0.20";import{z as Zn}from"zod";var gc=Zn.object({key:Zn.string(),testId:Zn.string().optional(),moduleId:Zn.string().optional(),organizationId:Zn.string(),value:Tr}),Ex=gc.extend({uniqueKey:Zn.string()}),Fu=Zn.record(Zn.string(),Ex);var Uu=k.object({phrase:k.string()}),fc=k.object({thoughts:k.string().optional(),result:k.union([k.literal("NOT_FOUND"),k.string(),k.number(),k.array(k.unknown()),k.record(k.unknown(),k.unknown()),k.unknown()])}),iF=k.object({text:k.string()}),Bu=k.object({thoughts:k.string(),review:k.string().optional(),id:k.number().int()}),za=(m=>(m.NO_DESCRIPTION_PROVIDED="NO_DESCRIPTION_PROVIDED",m.FEW_WORDS="FEW_WORDS",m.STYLE_TAG="STYLE_TAG",m.TYPE_IN_DESCRIPTION="TYPE_IN_DESCRIPTION",m.HARDCODED_ATTRIBUTE="HARDCODED_ATTRIBUTE",m.NONE="NONE",m.AMBIGUOUS_DESCRIPTION="AMBIGUOUS_DESCRIPTION",m.AMBIGUOUS_ASSERTION="AMBIGUOUS_ASSERTION",m.PREFER_PAGE_CHECK="PREFER_PAGE_CHECK",m.PREFER_ASSERTION="PREFER_ASSERTION",m.HTML_ELEMENTS="HTML_ELEMENTS",m.MULTIPLE_ELEMENTS_DESCRIPTION="MULTIPLE_ELEMENTS_DESCRIPTION",m))(za||{});var zu=k.object({thoughts:k.string(),category:k.nativeEnum(za)}),Cx=k.discriminatedUnion("op",[k.object({op:k.literal("replace"),path:k.string(),value:k.string()}),k.object({op:k.literal("add"),path:k.string(),value:k.string()}),k.object({op:k.literal("remove"),path:k.string()})]),aF=k.object({thoughts:k.string(),patches:Cx.array()}),Hu=[k.literal("add"),k.literal("replace"),k.literal("remove")],Rx=k.object({op:k.union(Hu),path:k.string(),value:Ae.optional()}),ju=k.object({patches:Rx.array(),thoughts:k.string()});var Ax=k.object({thoughts:k.string(),op:k.union(Hu),value:k.union([k.null(),Ae])}),$u=k.object({reasoning:k.string(),scenario:k.string(),patch:Ax.or(k.null())}),sF=k.object({thoughts:k.string(),evaluation:k.number().min(1).max(10)}),lF=k.object({observations:k.string(),reasoning:k.string(),command:Ua});var Sc=k.object({summary:k.string(),reasoning:k.string(),evaluation:k.discriminatedUnion("type",[k.object({type:k.literal("DONE")}),k.object({type:k.literal("RIGHT_TRACK")}),k.object({type:k.literal("WRONG_TRACK"),feedback:k.string()}),k.object({type:k.literal("IMPOSSIBLE")})])});import{z as _}from"zod";import*as ee from"zod";var hF=ee.object({thoughts:ee.string().optional().describe("only provided if a description was provided"),target:vr.optional().describe("only provided if a description was provided"),pageState:ee.string().optional().describe("serialized a11y tree, only provided if a description was provided"),options:ee.object({label:ee.string(),value:ee.string()}).array().optional().describe("list of options, provided for <select> elements only"),screenshot:ee.object({data:ee.string(),height:ee.number().int(),width:ee.number().int()}).optional().describe("only provided if returnScreenshot is true")}),Gu=ee.union([ee.literal("ELEMENT_CHECK"),ee.literal("NEGATED_CHECK"),ee.literal("SELECT_OPTION"),ee.literal("TYPE")]);function Rr(n){if(!("useSelector"in n&&n.useSelector)){if(n.type==="SELECT_OPTION")return"SELECT_OPTION";if(n.type==="TYPE")return"TYPE";if(n.type==="ELEMENT_CHECK"&&n.assertion.type==="ELEMENT_EXISTENCE"&&n.assertion.negated)return"NEGATED_CHECK";if(n.type==="ELEMENT_CHECK")return"ELEMENT_CHECK"}}var Ui=(a=>(a.A11Y_ID="A11Y_ID",a.USER_SELECTOR="USER_SELECTOR",a.CSS_SELECTOR="CSS_SELECTOR",a.HTML_DISTANCE="HTML_DISTANCE",a.TEMPLATE_MATCHING="TEMPLATE_MATCHING",a.AUTO_FRAME="AUTO_FRAME",a))(Ui||{}),bo=ee.object({matched:ee.boolean(),reason:ee.string().optional().describe("Human understandable description"),logs:ee.string().array().optional().describe("Logs for debugging")}),Ix=bo.extend({type:ee.literal("A11Y_ID")}),Px=bo.extend({type:ee.literal("USER_SELECTOR")}),Lx=bo.extend({type:ee.literal("CSS_SELECTOR"),selectors:ee.string().array()}),Ox=bo.extend({type:ee.literal("HTML_DISTANCE"),distance:ee.number().optional(),closestElement:ee.string().optional(),savedElement:ee.string().optional()}),kx=bo.extend({type:ee.literal("TEMPLATE_MATCHING"),elementImageUrl:ee.string().url()}),Mx=bo.extend({type:ee.literal("AUTO_FRAME"),logs:ee.string().array().optional()}),Wu=ee.discriminatedUnion("type",[Ix,Px,Lx,Ox,kx,Mx]);import{z as $i}from"zod";import{z as tC}from"zod";import*as X from"zod";import{cloneDeep as zi}from"lodash-es";var Nx=n=>{let e=Vu(n,0);if(e===void 0||!Dx(n[e]))return;let t=Vu(n,e+1);if(t!==void 0)return Fx(n,e,t)},qu=Nx,Vu=(n,e)=>{for(let t=e;t<n.length;t+=1){let r=n[t];if(!_x(r))return t}},_x=n=>n===" "||n===" "||n===`
3
+ !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="cecd290f-b551-50e0-af2b-e744c94386d1")}catch(e){}}();
4
+ var uT=Object.create;var wu=Object.defineProperty;var mT=Object.getOwnPropertyDescriptor;var hT=Object.getOwnPropertyNames;var gT=Object.getPrototypeOf,fT=Object.prototype.hasOwnProperty;var vu=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports);var ST=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of hT(e))!fT.call(n,o)&&o!==t&&wu(n,o,{get:()=>e[o],enumerable:!(r=mT(e,o))||r.enumerable});return n};var yT=(n,e,t)=>(t=n!=null?uT(gT(n)):{},ST(e||!n||!n.__esModule?wu(t,"default",{value:n,enumerable:!0}):t,n));var Ff=vu((Yq,Df)=>{"use strict";Df.exports=Nf;function Nf(n,e,t){n instanceof RegExp&&(n=Mf(n,t)),e instanceof RegExp&&(e=Mf(e,t));var r=_f(n,e,t);return r&&{start:r[0],end:r[1],pre:t.slice(0,r[0]),body:t.slice(r[0]+n.length,r[1]),post:t.slice(r[1]+e.length)}}function Mf(n,e){var t=e.match(n);return t?t[0]:null}Nf.range=_f;function _f(n,e,t){var r,o,i,a,s,l=t.indexOf(n),c=t.indexOf(e,l+1),d=l;if(l>=0&&c>0){if(n===e)return[l,c];for(r=[],i=t.length;d>=0&&!s;)d==l?(r.push(d),l=t.indexOf(n,d+1)):r.length==1?s=[r.pop(),c]:(o=r.pop(),o<i&&(i=o,a=c),c=t.indexOf(e,d+1)),d=l<c&&l>=0?l:c;r.length&&(s=[i,a])}return s}});var Wf=vu((Jq,Gf)=>{"use strict";var Uf=Ff();Gf.exports=sA;var Bf="\0SLASH"+Math.random()+"\0",zf="\0OPEN"+Math.random()+"\0",ud="\0CLOSE"+Math.random()+"\0",Hf="\0COMMA"+Math.random()+"\0",jf="\0PERIOD"+Math.random()+"\0";function pd(n){return parseInt(n,10)==n?parseInt(n,10):n.charCodeAt(0)}function iA(n){return n.split("\\\\").join(Bf).split("\\{").join(zf).split("\\}").join(ud).split("\\,").join(Hf).split("\\.").join(jf)}function aA(n){return n.split(Bf).join("\\").split(zf).join("{").split(ud).join("}").split(Hf).join(",").split(jf).join(".")}function $f(n){if(!n)return[""];var e=[],t=Uf("{","}",n);if(!t)return n.split(",");var r=t.pre,o=t.body,i=t.post,a=r.split(",");a[a.length-1]+="{"+o+"}";var s=$f(i);return i.length&&(a[a.length-1]+=s.shift(),a.push.apply(a,s)),e.push.apply(e,a),e}function sA(n){return n?(n.substr(0,2)==="{}"&&(n="\\{\\}"+n.substr(2)),ia(iA(n),!0).map(aA)):[]}function lA(n){return"{"+n+"}"}function cA(n){return/^-?0\d/.test(n)}function dA(n,e){return n<=e}function pA(n,e){return n>=e}function ia(n,e){var t=[],r=Uf("{","}",n);if(!r)return[n];var o=r.pre,i=r.post.length?ia(r.post,!1):[""];if(/\$$/.test(r.pre))for(var a=0;a<i.length;a++){var s=o+"{"+r.body+"}"+i[a];t.push(s)}else{var l=/^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(r.body),c=/^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(r.body),d=l||c,p=r.body.indexOf(",")>=0;if(!d&&!p)return r.post.match(/,.*\}/)?(n=r.pre+"{"+r.body+ud+r.post,ia(n)):[n];var m;if(d)m=r.body.split(/\.\./);else if(m=$f(r.body),m.length===1&&(m=ia(m[0],!1).map(lA),m.length===1))return i.map(function(H){return r.pre+m[0]+H});var u;if(d){var h=pd(m[0]),g=pd(m[1]),f=Math.max(m[0].length,m[1].length),S=m.length==3?Math.abs(pd(m[2])):1,b=dA,w=g<h;w&&(S*=-1,b=pA);var v=m.some(cA);u=[];for(var x=h;b(x,g);x+=S){var C;if(c)C=String.fromCharCode(x),C==="\\"&&(C="");else if(C=String(x),v){var A=f-C.length;if(A>0){var N=new Array(A+1).join("0");x<0?C="-"+N+C.slice(1):C=N+C}}u.push(C)}}else{u=[];for(var O=0;O<m.length;O++)u.push.apply(u,ia(m[O],!1))}for(var O=0;O<u.length;O++)for(var a=0;a<i.length;a++){var s=o+u[O]+i[a];(!e||d||s)&&t.push(s)}}return t}});var xi=(n,e)=>{},Zl=!1;try{let n=await import("@sentry/node");xi=n.captureException,n.init({dsn:"https://89e980855f7b9c6e56fc6c7e7143888b@o4506426201800704.ingest.us.sentry.io/4508343221354497",environment:"production",release:process.env.SENTRY_RELEASE_NAME}),Zl=!0}catch{}import{Command as TN,Option as rn}from"@commander-js/extra-typings";import{execSync as xN}from"child_process";import Uw from"body-parser";import iM from"cors";import aM from"dedent";import sM from"events";import Bw,{Router as lM}from"express";import{diff as nA}from"deep-object-diff";import cn from"fs";import $r from"path";import{diff as IR}from"deep-object-diff";import{z as Tu}from"zod";var NN=Tu.object({input:Tu.string()});import{z as Ve}from"zod";var FN=Ve.object({srcs:Ve.array(Ve.string()),urls:Ve.array(Ve.string()),desiredSrc:Ve.string().optional(),desiredUrl:Ve.string().optional()}),xu=Ve.object({srcRegex:Ve.string().optional(),urlRegex:Ve.string().optional()}),Eu=Ve.object({x:Ve.number(),y:Ve.number(),correlation:Ve.number()}),UN=Ve.object({searchImageBase64String:Ve.string(),pageImageBase64String:Ve.string(),id:Ve.string().uuid(),timeoutMs:Ve.number().max(1e4).min(0).optional()});import{z as k}from"zod";import{v4 as Re}from"uuid";import*as T from"zod";function ve(n){if(typeof n.ZodType.prototype.openapi<"u")return;n.ZodType.prototype.openapi=function(o){return new this.constructor({...this._def,openapi:o})};let e=n.ZodObject.prototype.extend;n.ZodObject.prototype.extend=function(...o){let i=e.apply(this,o);return i._def.extendMetadata={extends:this},delete i._def.openapi,i};let t=n.ZodObject.prototype.omit;n.ZodObject.prototype.omit=function(...o){let i=t.apply(this,o);return delete i._def.extendMetadata,delete i._def.openapi,i};let r=n.ZodObject.prototype.pick;n.ZodObject.prototype.pick=function(...o){let i=r.apply(this,o);return delete i._def.extendMetadata,delete i._def.openapi,i}}import{z as ge}from"zod";ve(ge);var Cu=ge.object({plan:ge.string().optional(),evidence:ge.string().optional(),thoughts:ge.string(),result:ge.boolean(),relevantElements:ge.array(ge.number()).optional()}),lo=(o=>(o.CONTAINS="CONTAINS",o.STARTS_WITH="STARTS_WITH",o.EQUALS="EQUALS",o.EXISTS="EXISTS",o))(lo||{});var bT=ge.object({type:ge.literal("ELEMENT_CONTENT"),negated:ge.boolean().optional(),operation:ge.nativeEnum(lo),value:ge.string()}).openapi({ref:"ElementContentAssertion"}),wT=ge.object({type:ge.literal("ELEMENT_ATTRIBUTE"),negated:ge.boolean().optional(),operation:ge.nativeEnum(lo),attr:ge.string(),value:ge.string()}).openapi({ref:"ElementAttributeValueAssertion"}),Ei=(o=>(o.EXISTS="EXISTS",o.VISIBLE="VISIBLE",o.ENABLED="ENABLED",o.EDITABLE="EDITABLE",o))(Ei||{}),vT=ge.object({type:ge.literal("ELEMENT_EXISTENCE"),negated:ge.boolean().optional(),condition:ge.nativeEnum(Ei).describe("Treated as the element exists AND is also ...")}).openapi({ref:"ElementExistenceAssertion"}),Ru=ge.discriminatedUnion("type",[bT,wT,vT]).openapi({ref:"ManualElementAssertion"});var TT=ge.object({type:ge.literal("CONTENT"),negated:ge.boolean().optional(),value:ge.string()}).openapi({ref:"PageContentAssertion"}),Au=ge.discriminatedUnion("type",[TT]).openapi({ref:"ManualPageAssertion"});import*as V from"zod";ve(V);var Jn=(s=>(s.AI="AI",s.AI_HEALED="AI_HEALED",s.CLICK_TO_FIND="CLICK_TO_FIND",s.XY_PERCENT="XY_PERCENT",s.RECORDING="RECORDING",s.USER_CSS_SELECTOR="USER_CSS_SELECTOR",s.HEURISTIC_HEALED="HEURISTIC_HEALED",s))(Jn||{}),xT=V.object({mPathSelectorTokens:V.string().array(),frameSrcRegex:V.string().optional(),frameUrlRegex:V.string().optional(),indices:V.number().array()}),vr=V.object({id:V.number().int(),dataMomenticId:V.number().int().optional(),selector:V.string().optional(),generatedSelectors:V.string().array().optional(),role:V.string().optional(),name:V.string().optional(),numChildren:V.number().optional(),content:V.string().optional(),pathFromRoot:V.string().optional(),serializedForm:V.string().optional(),nodeOnlySerializedForm:V.string().optional(),serializedHtml:V.string().optional().describe("pruned html including 1 neighbor and 1 layer of children. value for text inputs pruned."),nodeOnlySerializedHtml:V.string().optional().describe("outerHtml of the element without any children. value for text inputs pruned."),screenshotUrl:V.string().url().optional(),boundingBox:V.object({x:V.number().optional(),y:V.number().optional(),width:V.number(),height:V.number()}).describe("css pixel bounding box").optional(),frameCache:xT.optional(),inputDescription:V.string().optional().describe("the description that generated this cache"),targetSource:V.nativeEnum(Jn).optional(),targetUpdateTime:V.string().optional(),targetUpdateLoggerTags:V.record(V.string(),V.string()).optional()}).openapi({ref:"A11yTargetWithCache"});function Iu(n){return!!(n.name||n.role||n.content||n.serializedForm||n.serializedHtml||n.screenshotUrl)}var ET=V.object({type:V.literal("description"),elementDescriptor:V.string(),a11yData:vr.optional().describe("DEPRECATED: new a11y cache is stored in DB and resolved into the 'cache' field")}).openapi({ref:"DescriptionTarget"}),CT=V.object({x:V.number(),y:V.number()}),RT=V.object({type:V.literal("coordinates"),pixels:CT}).openapi({ref:"CoordinatesTarget"});function Xn(n){return n.type==="description"}function yn(n){return n.type==="coordinates"}var dt=V.discriminatedUnion("type",[ET,RT]).openapi({ref:"ElementTarget"});function Ql(n){if(!n)return!1;switch(n.type){case"description":return!!n.elementDescriptor}return!0}function pt(n){if(!n)return"";switch(n.type){case"description":return n.elementDescriptor;case"coordinates":return`x: ${n.pixels.x}, y: ${n.pixels.y}`}}import{z as ae}from"zod";var Na=ae.object({url:ae.string(),method:ae.union([ae.literal("GET"),ae.literal("POST"),ae.literal("PUT"),ae.literal("DELETE"),ae.literal("PATCH")]),headers:ae.record(ae.string(),ae.string()).optional(),params:ae.record(ae.string(),ae.string()).optional(),body:ae.string().optional(),timeout:ae.number().int().optional().describe("Max seconds to wait for the request to complete")}),Pu=ae.object({url:ae.string(),headers:ae.record(ae.string(),ae.string()).optional(),query:ae.string(),variables:ae.record(ae.string(),ae.string()).optional(),timeout:ae.number().int().optional().describe("Max seconds to wait for the request to complete")}),_a=ae.object({code:ae.string(),fragment:ae.boolean().optional(),environment:ae.union([ae.literal("NODE"),ae.literal("BROWSER")]).optional().describe("default NODE"),timeout:ae.number().int().max(60).optional().describe("Max seconds for the code to complete")});var Ue=(j=>(j.AI_EXTRACT="AI_EXTRACT",j.AI_ASSERTION="AI_ASSERTION",j.AUTH_LOAD="AUTH_LOAD",j.AUTH_SAVE="AUTH_SAVE",j.BLUR="BLUR",j.CAPTCHA="CAPTCHA",j.CLICK="CLICK",j.COOKIE="COOKIE",j.COPY="COPY",j.DIALOG="DIALOG",j.DRAG="DRAG",j.ELEMENT_CHECK="ELEMENT_CHECK",j.FILE_UPLOAD="FILE_UPLOAD",j.FOCUS="FOCUS",j.GO_BACK="GO_BACK",j.GO_FORWARD="GO_FORWARD",j.HOVER="HOVER",j.JAVASCRIPT="JAVASCRIPT",j.LOCAL_STORAGE="LOCAL_STORAGE",j.MOUSE_DRAG="MOUSE_DRAG",j.NAVIGATE="NAVIGATE",j.NEW_TAB="NEW_TAB",j.PAGE_CHECK="PAGE_CHECK",j.PASTE="PASTE",j.PRESS="PRESS",j.REFRESH="REFRESH",j.REQUEST="REQUEST",j.GRAPHQL_REQUEST="GRAPHQL_REQUEST",j.SCROLL_DOWN="SCROLL_DOWN",j.SCROLL_UP="SCROLL_UP",j.SCROLL_LEFT="SCROLL_LEFT",j.SCROLL_RIGHT="SCROLL_RIGHT",j.SELECT_OPTION="SELECT_OPTION",j.SWITCH_TAB="TAB",j.TYPE="TYPE",j.VISUAL_DIFF="VISUAL_DIFF",j.WAIT="WAIT",j.WAIT_FOR_URL="WAIT_FOR_URL",j.REGISTER_REQUEST_LISTENER="REGISTER_REQUEST_LISTENER",j.AWAIT_LISTENER="AWAIT_LISTENER",j.SUCCESS="SUCCESS",j))(Ue||{});ve(T);var J=T.object({thoughts:T.string().optional(),id:T.string().uuid().describe("unique identifier to this step, used for step cache")}),Ht=T.object({useSelector:T.boolean().optional(),force:T.boolean().optional(),disableCache:T.boolean().optional().describe("disable element caching for this step"),iframeUrl:T.string().optional().describe("url or url regex for the iframe")}).openapi({ref:"CommonTargetingOptions"}),bn=T.object({target:vr}).optional().openapi({ref:"SingleTargetCache"}),Da=T.object({loadTimeout:T.number().int().max(60).optional().describe("Max seconds for the page to load")}),AT=J.merge(Da).merge(T.object({type:T.literal("NAVIGATE"),url:T.string()})).openapi({ref:"NavigateCommand"}),Fa=Ht.merge(T.object({cache:bn})),co=J.merge(Fa.merge(T.object({target:dt.optional(),type:T.literal("SCROLL_UP"),deltaY:T.number().optional()}))).openapi({ref:"ScrollUpCommand"}),po=J.merge(Fa.merge(T.object({target:dt.optional(),type:T.literal("SCROLL_DOWN"),deltaY:T.number().optional()}))).openapi({ref:"ScrollDownCommand"}),uo=J.merge(Fa.merge(T.object({target:dt.optional(),type:T.literal("SCROLL_LEFT"),deltaX:T.number().optional()}))).openapi({ref:"ScrollLeftCommand"}),mo=J.merge(Fa.merge(T.object({target:dt.optional(),type:T.literal("SCROLL_RIGHT"),deltaX:T.number().optional()}))).openapi({ref:"ScrollRightCommand"}),t_=T.discriminatedUnion("type",[co,po,uo,mo]).openapi({ref:"AllScrollCommands"}),IT=J.merge(T.object({type:T.literal("DIALOG"),action:T.union([T.literal("ACCEPT"),T.literal("DISMISS")])})).openapi({ref:"DialogCommand"}),PT=J.merge(T.object({type:T.literal("WAIT"),delay:T.number()})).openapi({ref:"WaitCommand"}),LT=T.discriminatedUnion("type",[T.object({type:T.literal("SUBSTRING"),url:T.string()}),T.object({type:T.literal("GLOB"),glob:T.string()}),T.object({type:T.literal("REGEX"),regex:T.string()})]),OT=T.object({caseInsensitive:T.boolean().optional().describe("Whether to ignore case when matching the URL"),negated:T.boolean().optional().describe("Wait for the URL to NOT match the provided matcher instead."),timeout:T.number().int().optional().describe("Max seconds to wait for the URL to match")}),kT=J.extend({type:T.literal("WAIT_FOR_URL"),matcher:LT}).merge(OT).openapi({ref:"WaitUrlCommand"}),MT=J.merge(Da).merge(T.object({type:T.literal("REFRESH")})).openapi({ref:"RefreshCommand"}),NT=J.merge(T.object({type:T.literal("GO_BACK")})).openapi({ref:"GoBackCommand"}),_T=J.merge(T.object({type:T.literal("GO_FORWARD")})).openapi({ref:"GoForwardCommand"}),DT=J.extend({type:T.literal("AUTH_SAVE")}).openapi({ref:"AuthSaveCommand"}),FT=J.extend({type:T.literal("AUTH_LOAD"),storageState:T.string().describe("JSON string auth state. Leave blank or set to the empty string to clear all existing authentication.")}).openapi({ref:"AuthLoadCommand"}),tc=J.merge(Ht).extend({type:T.literal("CAPTCHA")}).openapi({ref:"CaptchaCommand"}),UT=J.extend({type:T.literal("COPY"),value:T.string()}).openapi({ref:"CopyCommand"}),BT=J.extend({type:T.literal("PASTE")}).openapi({ref:"PasteCommand"}),zT=J.merge(_a).extend({type:T.literal("JAVASCRIPT")}).openapi({ref:"JavaScriptCommand"}),Ri=J.merge(Ht).merge(T.object({type:T.literal("CLICK"),target:dt,doubleClick:T.boolean().optional(),rightClick:T.boolean().optional(),waitForDownload:T.boolean().optional().describe("Wait for the click to trigger a file download and for the file download to complete."),delayMs:T.number().optional(),downloadTimeoutMs:T.number().optional(),cache:bn,relativePosition:T.object({x:T.number(),y:T.number()}).optional()})).openapi({ref:"ClickCommand"}),Ai=J.merge(Ht).merge(T.object({type:T.literal("DRAG"),fromTarget:dt,toTarget:dt,steps:T.number().optional(),hoverSeconds:T.number().optional().describe("Seconds to hover the object before dropping"),cache:T.object({fromTarget:vr.optional(),toTarget:vr.optional()}).optional()})).openapi({ref:"DragCommand"}),Ii=J.merge(Ht).merge(T.object({type:T.literal("MOUSE_DRAG"),target:dt.optional(),deltaX:T.string().describe("pixels to move horizontally, can be template"),deltaY:T.string().describe("pixels to move vertically, can be template"),steps:T.number().optional(),cache:bn})).openapi({ref:"MouseDragCommand"}),Pi=J.merge(Ht).merge(T.object({type:T.literal("HOVER"),target:dt,cache:bn})).openapi({ref:"HoverCommand"}),Li=J.merge(Ht).merge(T.object({type:T.literal("FOCUS"),target:dt,cache:bn})).openapi({ref:"FocusCommand"}),Oi=J.merge(Ht).extend({type:T.literal("BLUR"),target:dt.optional(),cache:bn}).openapi({ref:"BlurCommand"}),HT=T.object({type:T.literal("URL"),url:T.string()}).describe("Accessible link to the file, either public http or local file://").openapi({ref:"UrlSource"}),jT=T.object({type:T.literal("USER_FILE"),name:T.string()}).describe("Accessible link to the file, references the google cloud file").openapi({ref:"UploadedFileSource"}),$T=J.extend({type:T.literal("FILE_UPLOAD"),fileSource:T.discriminatedUnion("type",[HT,jT]),filename:T.string().optional()}).openapi({ref:"FileUploadCommand"}),GT=T.discriminatedUnion("type",[T.object({type:T.literal("VALUE"),value:T.string()}),T.object({type:T.literal("LABEL"),label:T.string()}),T.object({type:T.literal("INDEX"),index:T.coerce.string()})]),ki=J.merge(Ht).extend({type:T.literal("SELECT_OPTION"),target:dt,cache:bn,choice:GT.describe("new field for selecting options, optional for backcompat")}).openapi({ref:"SelectOptionCommand"}),nc=T.union([T.literal("MULTIMODAL"),T.literal("VISION_ONLY")]),Lu=J.merge(T.object({type:T.literal("AI_ASSERTION"),assertion:T.string(),disableCache:T.boolean().optional(),iframeUrl:T.string().optional(),contextChoice:nc.optional(),timeout:T.number().int().optional().describe("Max seconds to wait for assertion to be true")})).openapi({ref:"AIAssertionCommand"}),wn=5,rc=600,Mi=J.merge(Ht).extend({type:T.literal("ELEMENT_CHECK"),target:dt,assertion:Ru,cache:bn,timeout:T.number().int().min(0).max(rc).optional().describe("max seconds to wait for the assertion to be true")}).openapi({ref:"ElementAssertionCommand"}),WT=J.extend({type:T.literal("PAGE_CHECK"),assertion:Au,iframeUrl:T.string().optional().describe("url or url regex for the iframe"),timeout:T.number().int().min(0).max(rc).optional().describe("max seconds to wait for the assertion to be true")}).openapi({ref:"PageAssertionCommand"}),VT=J.merge(T.object({type:T.literal("AI_EXTRACT"),goal:T.string(),schema:T.string().optional(),envKey:T.string().optional(),disableCache:T.boolean().optional(),iframeUrl:T.string().optional()})).openapi({ref:"AIExtractCommand"}),qT=T.object({clearContent:T.boolean().optional(),forceClearContent:T.boolean().optional(),delay:T.number().min(0).max(1e3).optional().describe("Delay between each press in milliseconds."),force:T.boolean().optional(),pressEnter:T.boolean().optional()}),Ou=25,Ni=J.merge(Ht).merge(qT).extend({type:T.literal("TYPE"),target:dt.optional(),value:T.string(),cache:bn}).openapi({ref:"TypeCommand"}),KT=J.merge(T.object({type:T.literal("PRESS"),value:T.string(),repeat:T.number().optional(),convertMeta:T.boolean().optional(),delayMs:T.number().optional()})).openapi({ref:"PressCommand"}),YT=T.object({type:T.literal("SUBSTRING"),substring:T.string()}),JT=T.object({type:T.literal("REGEX"),pattern:T.string()}),XT=T.object({type:T.literal("INDEX"),index:T.coerce.string()}),ZT=T.discriminatedUnion("type",[YT,JT,XT]),QT=J.merge(Da).merge(T.object({type:T.literal("TAB"),action:ZT})).openapi({ref:"TabCommand"}),ex=J.merge(Da).merge(T.object({type:T.literal("NEW_TAB"),url:T.string()})).openapi({ref:"NewTabCommand"}),tx=J.merge(T.object({type:T.literal("COOKIE"),value:T.string()})).openapi({ref:"CookieCommand"}),nx=J.merge(T.object({type:T.literal("LOCAL_STORAGE"),key:T.string(),value:T.string()})).openapi({ref:"LocalStorageCommand"}),rx=J.extend({type:T.literal("REQUEST")}).merge(Na).openapi({ref:"RequestCommand"}),ox=J.extend({type:T.literal("GRAPHQL_REQUEST")}).merge(Pu).openapi({ref:"GraphQLRequestCommand"}),ix=J.merge(T.object({type:T.literal("SUCCESS"),condition:Lu.optional()})).openapi({ref:"SuccessCommand"}),ax=J.merge(T.object({type:T.literal("FAILURE")})).openapi({ref:"FailureCommand"}),sx=T.object({data:T.string().describe("location at which to find a jpg"),width:T.number(),height:T.number()}),_i=J.merge(Ht).merge(T.object({type:T.literal("VISUAL_DIFF"),threshold:T.number().optional().describe("default 0.1"),target:dt.optional(),screenshot:sx.optional(),cache:bn})).openapi({ref:"VisualDiffCommand"}),lx=J.merge(T.object({type:T.literal("REGISTER_REQUEST_LISTENER"),pattern:T.string(),key:T.string()})).openapi({ref:"RegisterRequestListenerCommand"}),cx=J.merge(T.object({type:T.literal("AWAIT_LISTENER"),key:T.string(),timeout:T.number().optional().describe("timeout")})).openapi({ref:"WaitForListenerCommand"}),ku=T.discriminatedUnion("type",[Ri,Ni,KT,ki,AT,po,co,Lu,Pi,PT,ix]),dx=T.discriminatedUnion("type",[VT,FT,DT,tc,tx,UT,IT,Ai,Mi,$T,NT,_T,zT,nx,Ii,ex,WT,BT,MT,rx,ox,uo,mo,QT,_i,Li,Oi,kT,lx,cx]),ho=T.discriminatedUnion("type",[...ku.options,...dx.options]).openapi({ref:"Command"}),Ua=T.discriminatedUnion("type",[...ku.options,ax]);function Nn(n){let e;switch(n){case"PASTE":case"AUTH_SAVE":case"VISUAL_DIFF":case"SUCCESS":case"SCROLL_DOWN":case"SCROLL_UP":case"SCROLL_LEFT":case"SCROLL_RIGHT":case"CAPTCHA":case"GO_BACK":case"GO_FORWARD":case"REFRESH":e={id:Re(),type:n};break;case"AUTH_LOAD":{e={id:Re(),type:n,storageState:""};break}case"AI_EXTRACT":e={id:Re(),type:n,goal:""};break;case"DIALOG":e={id:Re(),type:n,action:"DISMISS"};break;case"DRAG":e={id:Re(),type:n,fromTarget:{type:"description",elementDescriptor:""},toTarget:{type:"description",elementDescriptor:""}};break;case"MOUSE_DRAG":e={id:Re(),type:n,deltaX:"0",deltaY:"0",steps:1};break;case"WAIT_FOR_URL":e={id:Re(),type:n,matcher:{type:"SUBSTRING",url:""}};break;case"WAIT":e={id:Re(),type:n,delay:1};break;case"BLUR":e={id:Re(),type:n};break;case"HOVER":case"FOCUS":case"CLICK":e={id:Re(),type:n,target:{type:"description",elementDescriptor:""}};break;case"COOKIE":case"PRESS":case"COPY":case"TYPE":e={id:Re(),type:n,value:"",clearContent:!0};break;case"SELECT_OPTION":e={id:Re(),type:n,target:{type:"description",elementDescriptor:""},choice:{type:"VALUE",value:""}};break;case"NAVIGATE":case"NEW_TAB":return{id:Re(),type:n,url:""};case"TAB":e={id:Re(),type:n,action:{type:"SUBSTRING",substring:""}};break;case"REQUEST":e={id:Re(),type:n,url:"",method:"GET"};break;case"GRAPHQL_REQUEST":e={id:Re(),type:n,url:"",query:""};break;case"LOCAL_STORAGE":e={id:Re(),type:n,key:"",value:""};break;case"JAVASCRIPT":e={id:Re(),type:n,code:""};break;case"AI_ASSERTION":e={id:Re(),type:n,assertion:""};break;case"FILE_UPLOAD":{e={id:Re(),type:n,fileSource:{type:"URL",url:""}};break}case"ELEMENT_CHECK":{e={id:Re(),type:n,target:{type:"description",elementDescriptor:""},assertion:{type:"ELEMENT_EXISTENCE",condition:"EXISTS"}};break}case"PAGE_CHECK":{e={id:Re(),type:n,assertion:{type:"CONTENT",value:""}};break}case"REGISTER_REQUEST_LISTENER":{e={id:Re(),type:n,pattern:"",key:""};break}case"AWAIT_LISTENER":{e={id:Re(),type:n,key:""};break}default:return(r=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}return e}function Mu(n){switch(n.type){case"BLUR":case"CLICK":case"DRAG":case"FOCUS":case"HOVER":case"MOUSE_DRAG":case"PRESS":case"SCROLL_DOWN":case"SCROLL_UP":case"SCROLL_LEFT":case"SCROLL_RIGHT":case"TYPE":return!0;case"AUTH_LOAD":case"AUTH_SAVE":case"AWAIT_LISTENER":case"SUCCESS":case"AI_ASSERTION":case"AI_EXTRACT":case"CAPTCHA":case"COOKIE":case"COPY":case"DIALOG":case"ELEMENT_CHECK":case"FILE_UPLOAD":case"GO_BACK":case"GO_FORWARD":case"GRAPHQL_REQUEST":case"JAVASCRIPT":case"LOCAL_STORAGE":case"NAVIGATE":case"NEW_TAB":case"PASTE":case"PAGE_CHECK":case"REGISTER_REQUEST_LISTENER":case"REFRESH":case"REQUEST":case"SELECT_OPTION":case"TAB":case"VISUAL_DIFF":case"WAIT":case"WAIT_FOR_URL":return!1;default:return(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}import{z as px}from"zod";var a_=px.discriminatedUnion("type",[Oi,tc,Ri,Ai,Li,Pi,Ii,co,po,uo,mo,ki,Ni,_i,Mi]);function Nu(n){return["AI_ASSERTION","ELEMENT_CHECK","PAGE_CHECK"].includes(n)}import{z as ux}from"zod";var xt={type:!0,cache:!0},Tr=ux.discriminatedUnion("type",[Oi.pick(xt),Ri.pick(xt),Ai.pick(xt),Mi.pick(xt),Li.pick(xt),Pi.pick(xt),Ii.pick(xt),co.pick(xt),po.pick(xt),uo.pick(xt),mo.pick(xt),ki.pick(xt),Ni.pick(xt),_i.pick(xt)]),oc=Object.values(Ue).filter(n=>Tr.options.some(e=>e.shape.type.safeParse(n).success));ho.options.forEach(n=>{if("target"in n.shape&&!oc.includes(n.shape.type.value))throw new Error(`Command ${n.shape.type.value} has a target but no cache`)});import{z as ac}from"zod";import{z as ic}from"zod";import{z as go}from"zod";var Et=go.object({index:go.number().optional().describe("global index within a test (in-order traversal)"),id:go.string(),skipped:go.boolean().optional(),envKey:go.string().optional().describe("key in the environment to save the result of this step to"),aiSuggested:go.boolean().optional()});ve(ic);var Ct=Et.extend({type:ic.literal("PRESET_ACTION"),command:ho,skipped:ic.boolean().optional()}).openapi({ref:"PresetAction"});ve(ac);var xr=Et.extend({type:ac.literal("AI_ACTION"),text:ac.string(),steps:Ct.array().optional()}).openapi({ref:"AIAction"});import{z as le}from"zod";var mx=le.object({cacheKey:le.string(),cacheExpiryMs:le.number()}),sc=Et.extend({id:le.string().uuid().describe("ID of the module step itself. Used to 'namespace' step cache entries."),inputs:le.record(le.string()).optional(),cacheConfig:mx.optional()}),_n=sc.extend({type:le.literal("MODULE"),moduleId:le.string().uuid()}),hx=le.union([_n.pick({type:!0,moduleId:!0}),le.record(le.unknown())]),gx=le.object({type:le.literal("URL_REGEX"),regex:le.string()}),fx=le.object({type:le.literal("PAGE_CHECK"),substring:le.string()}),lc=le.object({cacheInvalidation:le.discriminatedUnion("type",[fx,gx]).optional()}),Rt=le.object({moduleId:le.string().uuid(),name:le.string(),description:le.string().nullish(),enabled:le.boolean().nullish(),parameters:le.string().array().nullish(),defaultParameters:le.record(le.string(),le.string()).nullish(),defaultCacheKey:le.string().nullish(),defaultCacheTtl:le.number().nullish(),defaultCacheAllInvocations:le.boolean().nullish(),autoAuth:le.boolean().nullish(),advanced:lc.nullish()});import{z as it}from"zod";import{z as cc}from"zod";ve(cc);var fo=Et.extend({type:cc.literal("AI_ACTION_DYNAMIC"),text:cc.string()}).openapi({ref:"AIActionDynamic"});import{z as _u}from"zod";var dc=Et.extend({type:_u.literal("CONDITIONAL"),skipped:_u.boolean().optional()});import{z as Ba}from"zod";var Sx=Ba.object({type:Ba.literal("url"),url:Ba.string()}),Di=Et.extend({type:Ba.literal("IFRAME"),identifier:Sx});import{z as jt}from"zod";var pc=(r=>(r.ALWAYS="ALWAYS",r.ON_FAILURE="ON_FAILURE",r.ON_ACTION_FAILURE="ON_ACTION_FAILURE",r))(pc||{});var yx=jt.discriminatedUnion("type",[jt.object({type:jt.literal("NAVIGATE_URL"),url:jt.string().url()}),jt.object({type:jt.literal("GO_TO_SECTION_START")})]),bx=jt.object({trigger:jt.nativeEnum(pc).optional(),attempts:jt.number().int().optional(),restartBehavior:yx}),Fi=Et.extend({type:jt.literal("SECTION"),description:jt.string().describe("user provided goal of what the section should accomplish"),plan:jt.string().array().optional(),autohealingConfig:bx.optional()});var Du=Rt.merge(sc).extend({type:it.literal("RESOLVED_MODULE"),steps:it.lazy(()=>Ae.array())}),uc=Rt.extend({steps:it.lazy(()=>Ae.array())}),mc=Di.extend({steps:it.lazy(()=>Se.array())}),wx=Di.extend({steps:it.lazy(()=>Ae.array())}),hc=Fi.extend({steps:it.lazy(()=>Se.array())}),vx=Fi.extend({steps:it.lazy(()=>Ae.array())}),Er=dc.extend({blocks:it.object({assertion:it.lazy(()=>Ct),steps:it.lazy(()=>Se.array())}).array(),elseSteps:it.lazy(()=>Se.array().optional())}),Tx=dc.extend({blocks:it.object({assertion:it.lazy(()=>Ct),steps:it.lazy(()=>Ae.array())}).array(),elseSteps:it.lazy(()=>Ae.array().optional())}),Se=it.discriminatedUnion("type",[Ct,xr,fo,_n,Er,mc,hc]),Ae=it.discriminatedUnion("type",[Ct,xr,fo,Du,Tx,wx,vx]);import{z as $t}from"zod";var xx=$t.object({steps:Se.array(),beforeSteps:Se.array().nullish(),afterSteps:Se.array().nullish()}),So=$t.object({steps:Ae.array(),beforeSteps:Ae.array().nullish(),afterSteps:Ae.array().nullish()}),Cr=$t.object({steps:$t.record($t.string(),$t.unknown()).array(),beforeSteps:$t.record($t.string(),$t.unknown()).array().nullish(),afterSteps:$t.record($t.string(),$t.unknown()).array().nullish()});var Fe="1.0.20";import{z as Zn}from"zod";var gc=Zn.object({key:Zn.string(),testId:Zn.string().optional(),moduleId:Zn.string().optional(),organizationId:Zn.string(),value:Tr}),Ex=gc.extend({uniqueKey:Zn.string()}),Fu=Zn.record(Zn.string(),Ex);var Uu=k.object({phrase:k.string()}),fc=k.object({thoughts:k.string().optional(),result:k.union([k.literal("NOT_FOUND"),k.string(),k.number(),k.array(k.unknown()),k.record(k.unknown(),k.unknown()),k.unknown()])}),iF=k.object({text:k.string()}),Bu=k.object({thoughts:k.string(),review:k.string().optional(),id:k.number().int()}),za=(m=>(m.NO_DESCRIPTION_PROVIDED="NO_DESCRIPTION_PROVIDED",m.FEW_WORDS="FEW_WORDS",m.STYLE_TAG="STYLE_TAG",m.TYPE_IN_DESCRIPTION="TYPE_IN_DESCRIPTION",m.HARDCODED_ATTRIBUTE="HARDCODED_ATTRIBUTE",m.NONE="NONE",m.AMBIGUOUS_DESCRIPTION="AMBIGUOUS_DESCRIPTION",m.AMBIGUOUS_ASSERTION="AMBIGUOUS_ASSERTION",m.PREFER_PAGE_CHECK="PREFER_PAGE_CHECK",m.PREFER_ASSERTION="PREFER_ASSERTION",m.HTML_ELEMENTS="HTML_ELEMENTS",m.MULTIPLE_ELEMENTS_DESCRIPTION="MULTIPLE_ELEMENTS_DESCRIPTION",m))(za||{});var zu=k.object({thoughts:k.string(),category:k.nativeEnum(za)}),Cx=k.discriminatedUnion("op",[k.object({op:k.literal("replace"),path:k.string(),value:k.string()}),k.object({op:k.literal("add"),path:k.string(),value:k.string()}),k.object({op:k.literal("remove"),path:k.string()})]),aF=k.object({thoughts:k.string(),patches:Cx.array()}),Hu=[k.literal("add"),k.literal("replace"),k.literal("remove")],Rx=k.object({op:k.union(Hu),path:k.string(),value:Ae.optional()}),ju=k.object({patches:Rx.array(),thoughts:k.string()});var Ax=k.object({thoughts:k.string(),op:k.union(Hu),value:k.union([k.null(),Ae])}),$u=k.object({reasoning:k.string(),scenario:k.string(),patch:Ax.or(k.null())}),sF=k.object({thoughts:k.string(),evaluation:k.number().min(1).max(10)}),lF=k.object({observations:k.string(),reasoning:k.string(),command:Ua});var Sc=k.object({summary:k.string(),reasoning:k.string(),evaluation:k.discriminatedUnion("type",[k.object({type:k.literal("DONE")}),k.object({type:k.literal("RIGHT_TRACK")}),k.object({type:k.literal("WRONG_TRACK"),feedback:k.string()}),k.object({type:k.literal("IMPOSSIBLE")})])});import{z as _}from"zod";import*as ee from"zod";var hF=ee.object({thoughts:ee.string().optional().describe("only provided if a description was provided"),target:vr.optional().describe("only provided if a description was provided"),pageState:ee.string().optional().describe("serialized a11y tree, only provided if a description was provided"),options:ee.object({label:ee.string(),value:ee.string()}).array().optional().describe("list of options, provided for <select> elements only"),screenshot:ee.object({data:ee.string(),height:ee.number().int(),width:ee.number().int()}).optional().describe("only provided if returnScreenshot is true")}),Gu=ee.union([ee.literal("ELEMENT_CHECK"),ee.literal("NEGATED_CHECK"),ee.literal("SELECT_OPTION"),ee.literal("TYPE")]);function Rr(n){if(!("useSelector"in n&&n.useSelector)){if(n.type==="SELECT_OPTION")return"SELECT_OPTION";if(n.type==="TYPE")return"TYPE";if(n.type==="ELEMENT_CHECK"&&n.assertion.type==="ELEMENT_EXISTENCE"&&n.assertion.negated)return"NEGATED_CHECK";if(n.type==="ELEMENT_CHECK")return"ELEMENT_CHECK"}}var Ui=(a=>(a.A11Y_ID="A11Y_ID",a.USER_SELECTOR="USER_SELECTOR",a.CSS_SELECTOR="CSS_SELECTOR",a.HTML_DISTANCE="HTML_DISTANCE",a.TEMPLATE_MATCHING="TEMPLATE_MATCHING",a.AUTO_FRAME="AUTO_FRAME",a))(Ui||{}),yo=ee.object({matched:ee.boolean(),reason:ee.string().optional().describe("Human understandable description"),logs:ee.string().array().optional().describe("Logs for debugging")}),Ix=yo.extend({type:ee.literal("A11Y_ID")}),Px=yo.extend({type:ee.literal("USER_SELECTOR")}),Lx=yo.extend({type:ee.literal("CSS_SELECTOR"),selectors:ee.string().array()}),Ox=yo.extend({type:ee.literal("HTML_DISTANCE"),distance:ee.number().optional(),closestElement:ee.string().optional(),savedElement:ee.string().optional()}),kx=yo.extend({type:ee.literal("TEMPLATE_MATCHING"),elementImageUrl:ee.string().url()}),Mx=yo.extend({type:ee.literal("AUTO_FRAME"),logs:ee.string().array().optional()}),Wu=ee.discriminatedUnion("type",[Ix,Px,Lx,Ox,kx,Mx]);import{z as $i}from"zod";import{z as tC}from"zod";import*as X from"zod";import{cloneDeep as zi}from"lodash-es";var Nx=n=>{let e=Vu(n,0);if(e===void 0||!Dx(n[e]))return;let t=Vu(n,e+1);if(t!==void 0)return Fx(n,e,t)},qu=Nx,Vu=(n,e)=>{for(let t=e;t<n.length;t+=1){let r=n[t];if(!_x(r))return t}},_x=n=>n===" "||n===" "||n===`
5
5
  `||n==="\r",Dx=n=>n==="{"||n==="[",Fx=(n,e,t)=>{let r;for(let o=t-1;o>e;o-=1){let i=n[o];if(i==="\r")return;if(i===`
6
- `)return Ux(r);if(r===void 0)r=i;else if(r[0]===i)r+=i;else return}},Ux=n=>n===void 0?0:n[0]===" "?n.length:n;var Ku=(n,e)=>{let t=yc(n,"toPrecision",e,e);return t===void 0?yc(n,"toExponential",e,e):t},yc=(n,e,t,r)=>{let i=n[e](r).replace(Bx,"$1").replace(zx,"$1");return i.length<=t?i:r===1?void 0:yc(n,e,t,r-1)},Bx=/(e)\+/iu,zx=/\.?0*($|e)/iu;var Ju=(n,e)=>{if(typeof n!="string")throw new TypeError(`Input must be a JSON string: ${n}`);Hx(e)},Hx=n=>{if(jx(n),n<0)throw new TypeError(`"maxSize" argument must be positive: ${n}`);if(n<Yu)throw new TypeError(`"maxSize" argument must be at least ${Yu}: ${n}`)},jx=n=>{if(n===void 0)throw new TypeError('"maxSize" argument must be defined');if(!Number.isInteger(n))throw new TypeError(`"maxSize" argument must be an integer: ${n}`)},Yu=7;var Ha=(n,e,t)=>{let r=Zu(e,t);return Xu(n,e,r)},Xu=(n,e,t)=>{if(t>=e)return t;let r=n[t];return r>=Xx&&r<=Zx?Xu(n,e,t+1):t},ja=(n,e,t)=>{if(t===void 0)return t;let r=Zu(e,t);return $x(n,r)},$x=(n,e)=>Gx(n,e)?e-3:Wx(n,e)?e-2:Vx(n,e)?e-1:e,Gx=(n,e)=>e>=3&&n[e-3]>=qx&&n[e-3]<=Kx,Wx=(n,e)=>e>=2&&n[e-2]>=Yx,Vx=(n,e)=>e>=1&&n[e-1]>=Jx,Zu=(n,e)=>e<0||Object.is(e,-0)?Math.max(n+e,0):e,qx=240,Kx=244,Yx=224,Jx=194,Xx=128,Zx=191;var Qu=(n,e,t)=>{let r=globalThis.Buffer.from(n),o=Ha(r,r.length,e),i=ja(r,r.length,t);return o===0&&i>=r.length?r.toString():r.toString("utf8",o,i)};var em=/[\uD800-\uDFFF]/gu,tm="\uFFFD";var $a=n=>Qx(n)?n.replace(em,tm):n,Qx=n=>{for(let e=0;e<n.length;e+=1){let t=n.codePointAt(e);if(t>=55296&&t<=57343)return!0}return!1};var vc=({input:n,targetByteCount:e,firstStartSurrogate:t,lastStartSurrogate:r,firstEndSurrogate:o,lastEndSurrogate:i,increment:a,canBacktrack:s,shift:l,charIndexInit:c})=>{let d=c,p=d,m=0;for(;m<e;d+=a){p=d;let h=n.charCodeAt(d);if(Number.isNaN(h))break;if(h<=127){m+=1;continue}if(h<=2047){m+=2;continue}if(m+=3,h<t||h>r)continue;let g=n.charCodeAt(d+a);Number.isNaN(g)||g<o||g>i||(m+=1,d+=a)}return(s&&m>e?p:d)+l};var Tc=(n,e,t)=>e<0||Object.is(e,-0)?iE(n,e,t):oE(n,e,t),oE=(n,e,t)=>vc({input:n,targetByteCount:e,firstStartSurrogate:55296,lastStartSurrogate:56319,firstEndSurrogate:56320,lastEndSurrogate:57343,increment:1,canBacktrack:t,shift:0,charIndexInit:0}),iE=(n,e,t)=>vc({input:n,targetByteCount:-e,firstStartSurrogate:56320,lastStartSurrogate:57343,firstEndSurrogate:55296,lastEndSurrogate:56319,increment:-1,canBacktrack:!t,shift:1,charIndexInit:n.length-1});var Ga=(n,e,t)=>{let r=Tc(n,e,!1),o=aE(n,t),i=r===0&&o===void 0?n:n.slice(r,o);return $a(i)},aE=(n,e)=>{if(e===void 0)return e;let t=Tc(n,e,!0);return t===n.length?void 0:t};var rm=(n,e,t)=>{let{textEncoder:r,textDecoder:o}=sE(),i=lE(n),{written:a}=r.encodeInto(n,i),s=Ha(i,a,e),l=ja(i,a,t),c=l===void 0?a:Math.min(l,a),d=i.subarray(s,c);return o.decode(d)},sE=()=>(xc===void 0&&(xc=new globalThis.TextEncoder,nm=new globalThis.TextDecoder("utf8",{fatal:!1})),{textEncoder:xc,textDecoder:nm}),xc,nm,lE=n=>{let e=n.length*3;return e>cE?new Uint8Array(e):((Wa===void 0||Wa.length<e)&&(Wa=new Uint8Array(e)),Wa)},cE=1e5,Wa;var om=(n,e)=>{if(e===void 0)return e;let t=Ec(n,e);return t>=n.length*im?void 0:t},Ec=(n,e)=>e<=n.length*-im?0:e,im=4;var am=(n,e,t)=>{if(typeof n!="string")throw new TypeError(`First argument must be a string: ${n}`);dE(e),pE(t)},dE=n=>{if(n===void 0)throw new TypeError("Second argument is required.");sm("Second",n)},pE=n=>{n!==void 0&&sm("Third",n)},sm=(n,e)=>{if(!Number.isInteger(e))throw new TypeError(`${n} argument must be an integer: ${e}`)};var lm=n=>{let e=!0,t=0;for(let r=0;r<Cc;r+=1){let o=uE(n,r);o<=127||(e&&(e=!1),o>2047&&(t+=1))}return{asciiOnly:e,longCharsPercentage:t/Cc}},uE=(n,e)=>{let t=Cc-1,r=1-(t-e)/t,o=Math.round(r*(n.length-1));return n.charCodeAt(o)},Cc=50;var mE=(n,e,t)=>{if(am(n,e,t),n==="")return n;let r=Ec(n,e),o=om(n,t);return o===void 0&&Object.is(r,0)?$a(n):hE(n,r,o)},cm=mE,hE=(n,e,t)=>{if(n.length<=gE)return Ga(n,e,t);let{asciiOnly:r,longCharsPercentage:o}=lm(n);return r?SE(n,e,t):o>=fE?Ga(n,e,t):dm(n,e,t)},gE=200,fE=.4,SE=(n,e,t)=>"Buffer"in globalThis&&"from"in globalThis.Buffer?Qu(n,e,t):dm(n,e,t),dm=(n,e,t)=>"TextEncoder"in globalThis?rm(n,e,t):Ga(n,e,t);var um=(n,e)=>{let t=JSON.stringify(n),r=wE(t),o=cm(r,0,e-pm.length-Bi.length*2),a=`${yE(o)}${pm}`;return vE(a)},yE=n=>n.replace(bE,""),bE=/(\\|\\u[0-9a-fA-F]{0,3})$/u,wE=n=>n.slice(Bi.length,-Bi.length),vE=n=>`${Bi}${n}${Bi}`,Bi='"',pm="...";var mm=n=>globalThis.Buffer.byteLength(n);var Rc=n=>{let e=n.length,t=e;for(let r=0;r<e;r+=1){let o=n.charCodeAt(r);if(o<=TE)continue;if(o<=xE){t+=1;continue}if(t+=2,o<EE||o>CE)continue;let i=n.charCodeAt(r+1);i<RE||i>AE||(r+=1)}return t},TE=127,xE=2047,EE=55296,CE=56319,RE=56320,AE=57343;var hm=()=>IE.bind(void 0,new TextEncoder),IE=(n,e)=>{let t=PE(e);return n.encodeInto(e,t).written},PE=n=>{let e=n.length*3;return e>LE?new Uint8Array(e):((Va===void 0||Va.length<e)&&(Va=new Uint8Array(e)),Va)},LE=1e5,Va;var kE=()=>"Buffer"in globalThis&&"byteLength"in globalThis.Buffer?mm:"TextEncoder"in globalThis?ME.bind(void 0,hm()):Rc,ME=(n,e)=>e.length<100?Rc(e):n(e),gm=kE();var fm=n=>{if(n===null)return NE;if(n===!0)return _E;if(n===!1)return DE;let e=typeof n;return e==="object"?FE:e==="number"?JSON.stringify(n).length:Ac(n)},NE=4,_E=4,DE=5,FE=2,Ac=n=>gm(JSON.stringify(n));var qa=({size:n,increment:e,maxSize:t,truncatedProps:r,path:o,value:i})=>{let a=n+e,s=a>t;return s?{size:n,stop:s,truncatedProps:[...r,{path:o,value:i}]}:{size:a,stop:s,truncatedProps:r}},ym=n=>fm(n),bm=(n,e,t)=>{let r=vm({empty:n,indent:e,depth:t,keySpaceSize:0}),o=Tm(n);return r+o},wm=({key:n,empty:e,indent:t,depth:r})=>{let o=vm({empty:e,indent:t,depth:r,keySpaceSize:1}),i=Ac(n),a=Tm(e);return o+i+UE+a},UE=1,vm=({empty:n,indent:e,depth:t,keySpaceSize:r})=>{if(e===void 0)return 0;let o=Sm+e*(t+1),i=n?Sm+e*t:0;return r+o+i},Sm=1,Tm=n=>n?0:BE,BE=1;var Ka=({parent:n,truncatedProps:e,path:t,increment:r,maxSize:o,key:i,empty:a,size:s,truncateValue:l,indent:c,depth:d})=>{let p=n[i],m=[...t,i],{size:u,stop:h,truncatedProps:g}=qa({size:s,increment:r,maxSize:o,truncatedProps:e,path:m,value:p});return h?{empty:a,size:u,truncatedProps:g}:zE({value:p,truncatedProps:e,path:m,maxSize:o,empty:a,size:s,newSize:u,truncateValue:l,indent:c,depth:d})},zE=({value:n,truncatedProps:e,path:t,maxSize:r,empty:o,size:i,newSize:a,truncateValue:s,indent:l,depth:c})=>{let{value:d,size:p,truncatedProps:m}=s({value:n,truncatedProps:e,path:t,size:a,maxSize:r,indent:l,depth:c+1});return d===void 0?{empty:o,size:i,truncatedProps:m}:{empty:!1,size:p,value:d,truncatedProps:m}};var xm=({array:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:i,indent:a,depth:s})=>{let l=[],c={empty:!0,size:r,truncatedProps:e};for(let d=0;d<n.length;d+=1){let p=bm(c.empty,a,s);c=Ka({parent:n,truncatedProps:c.truncatedProps,path:t,increment:p,maxSize:o,key:d,empty:c.empty,size:c.size,truncateValue:i,indent:a,depth:s}),c.value!==void 0&&l.push(c.value)}return{value:l,size:c.size,truncatedProps:c.truncatedProps}};var Em=({object:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:i,indent:a,depth:s})=>{let l={},c={empty:!0,size:r,truncatedProps:e};for(let d in n){let p=wm({key:d,empty:c.empty,indent:a,depth:s});c=Ka({parent:n,truncatedProps:c.truncatedProps,path:t,increment:p,maxSize:o,key:d,empty:c.empty,size:c.size,truncateValue:i,indent:a,depth:s}),c.value!==void 0&&(l[d]=c.value)}return{value:l,size:c.size,truncatedProps:c.truncatedProps}};var Ya=({value:n,truncatedProps:e,path:t,size:r,maxSize:o,indent:i,depth:a})=>{let s=ym(n),{size:l,stop:c,truncatedProps:d}=qa({size:r,increment:s,maxSize:o,truncatedProps:e,path:t,value:n});return c?{value:void 0,size:l,truncatedProps:d}:HE({value:n,truncatedProps:d,path:t,size:l,maxSize:o,indent:i,depth:a})},HE=({value:n,truncatedProps:e,path:t,size:r,maxSize:o,indent:i,depth:a})=>typeof n!="object"||n===null?{value:n,size:r,truncatedProps:e}:Array.isArray(n)?xm({array:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:Ya,indent:i,depth:a}):Em({object:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:Ya,indent:i,depth:a});var jE=(n,e)=>{Ju(n,e);let t=$E(n),r=GE(n),{value:o,truncatedProps:i}=Ya({value:r,truncatedProps:[],path:[],size:0,maxSize:e,indent:t,depth:0});return{jsonString:WE({newValue:o,value:r,maxSize:e,indent:t}),truncatedProps:i}},wo=jE,$E=n=>{let e=qu(n);return typeof e=="string"?e.length:e},GE=n=>{try{return JSON.parse(n)}catch(e){throw new TypeError(`Invalid JSON string: "${n}"
7
- ${e.message}`)}},WE=({newValue:n,value:e,maxSize:t,indent:r})=>n!==void 0?JSON.stringify(n,void 0,r):typeof e=="number"?Ku(e,t):um(e,t);import*as Ar from"zod";import{z as Ie}from"zod";var Cm=6e4,Ge="BASE_URL",Ja="CURRENT_URL",vo="ENV_NAME",T0={[Ge]:"https://www.google.com"},Rm=Ie.string().describe("Name of the fixture (must be available locally in the fixtures directory)."),Xa=Ie.object({name:Ie.string(),variables:Ie.record(Ie.string().describe("variable name"),Ie.string().describe("variable value"))}),To=Ie.object({pageLoadTimeoutMs:Ie.number().optional().refine(n=>n===void 0||n<=Cm&&n>=-1,{message:`Page load timeout must be between 0 and ${Cm/1e3} seconds`}).describe("global page load timeout default for all tests in ms, can still be overridden by individual tests"),localChromeExtensionPaths:Ie.string().array().optional(),extraHeaders:Ie.record(Ie.string(),Ie.string()).optional().describe("HTTP headers to be sent on every request"),userAgent:Ie.string().optional(),disableGpu:Ie.boolean().optional(),ignoreHrefForCaching:Ie.boolean().optional().describe("When running locally often times <a> hrefs will be different every time, resulting in cache busting. This will ignore href in <a> matching when there is text content."),autoFollowNewTabs:Ie.boolean().optional().describe("Deprecated: Auto-follow new tabs that are opened."),showZeroOpacityElements:Ie.boolean().optional().describe("Allow the AI to see and interact with elements that have zero opacity."),bustCacheOnBoundingBoxChange:Ie.boolean().optional().describe("Bust the cache if no elements are matched that have the same bounding box and location as the original element. This will improve accuracy on sites that use many same components, at the expense of stability and speed."),allowPartialAccessibilityTree:Ie.boolean().optional().describe("Allow fetching the partial accessibility tree if the full tree takes too long.")}),Am=Ie.object({name:Ie.string(),variables:Ie.record(Ie.string().describe("variable name"),Ie.unknown().describe("variable value")),browser:To.optional()});ve(Ar);var Hi=Ar.object({env:Ar.record(Ar.unknown())}).openapi({ref:"TestContextSnapshot"}),VE="\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022",qE=[Ge,vo],Im=[Ja,Ge,vo],At=class n{env={};varsFromMomenticEnvironment={};constructor(e){this.reset(e)}static dummyContext(e=void 0,t={}){return new n({baseUrl:"about:blank",currentUrl:"about:blank",envName:e,variablesFromEnvironment:t})}static fromSnapshot({snapshot:e,environmentVariables:t}){let r=e.env[Ge]??"about:blank",o=e.env[Ja]??"about:blank",i=e.env[vo],a={};for(let[l,c]of Object.entries(e.env))Im.includes(l)||(t??{})[l]===void 0&&(a[l]=c);return new n({baseUrl:r,currentUrl:o,dynamicVariables:a,envName:i,variablesFromEnvironment:t??{}})}setEnvVariables(e){let t=zi(e);this.env=Object.assign(this.env,t)}setInputs(e){e&&this.setEnvVariables(e)}setMomenticSystemVariable(e,t){this.varsFromMomenticEnvironment[e]=t}getVariable(e){return this.env[e]}setVariable(e,t){qE.includes(e)||(this.env[e]=t)}getEnvName(){return this.env[vo]}toObjectCopy(){let e={env:Object.assign({},this.env,this.varsFromMomenticEnvironment)};return zi(e)}toEditorDisplayCopy(){return this.toObjectCopy()}toRedactedDisplayCopy(){let e=this.toObjectCopy();e.env=Object.fromEntries(Object.entries(e.env).map(([r,o])=>Im.includes(r)||this.varsFromMomenticEnvironment[r]===void 0?[r,o]:[r,VE]));for(let[r,o]of Object.entries(e.env)){if(!o){e.env[r]=o;continue}let{jsonString:i}=wo(JSON.stringify(o),1e3);try{e.env[r]=JSON.parse(i)}catch{e.env[r]=void 0}}let{jsonString:t}=wo(JSON.stringify(e.env),5e3);try{e.env=JSON.parse(t)}catch{e.env={}}return e}setCurrentUrl(e){this.env[Ja]=e}reset(e){this.env={},this.varsFromMomenticEnvironment={},this.setEnvVariables(e.dynamicVariables??{}),this.setCurrentUrl(e.currentUrl),this.varsFromMomenticEnvironment=zi(e.variablesFromEnvironment),this.setMomenticSystemVariable(Ge,e.baseUrl),e.envName&&this.setMomenticSystemVariable(vo,e.envName)}getDynamicVariablesCopy(){return zi(this.env)}getVariablesFromEnvironmentCopy(){return zi(this.varsFromMomenticEnvironment)}};import{z as Ir}from"zod";ve(Ir);var pe=(c=>(c.AI_PROVIDER="AIProviderError",c.USER_INFRA="UserInfrastructureError",c.ACTION_FAILURE="ActionFailureError",c.ASSERTION_FAILURE="AssertionFailureError",c.CONFIG_ERROR="UserConfigurationError",c.WEB_AGENT_PLATFORM="InternalWebAgentError",c.UNKNOWN_PLATFORM="InternalPlatformError",c.JOB_TIMEOUT="JobTimeoutError",c.UNKNOWN="UnknownError",c))(pe||{});var Pm=["JobTimeoutError","UserConfigurationError","UserInfrastructureError"],Za={ActionFailureError:"Action failure",AssertionFailureError:"Assertion failure",UserInfrastructureError:"Infrastructure failure",UserConfigurationError:"Configuration error",AIProviderError:"AI provider error",InternalWebAgentError:"Momentic AI agent error",JobTimeoutError:"Job timeout",InternalPlatformError:"Unknown Momentic platform error",UnknownError:"Unknown error"},xo={ActionFailureError:"A browser action such as a click or type failed to execute because of the underlying page state is incorrect, suggesting a bug in the application itself.",AssertionFailureError:"An AI assertion or check failed for a legitimate reason, such as a missing element, a change in the page structure, or an unexpected state (e.g. loading state).",AIProviderError:"The AI provider failed to return a response or returned a malformed response.",UserInfrastructureError:"The user's web application exhibited an infrastructure failure, such as a page load timeout, a 5XX status code, maintenance page, or session crash.",UserConfigurationError:"The error message suggests a user-caused misconfiguration in the test, such as an undefined variable, a missing base URL, an empty test/module input parameter, or an invalid step option",JobTimeoutError:"The test took too long to complete, suggesting a problem with the test itself.",InternalWebAgentError:"The AI testing framework failed to find the correct element or evaluate the assertion correctly, even though the test steps and application state look valid. In other words, the AI agent failed to understand the page.",UnknownError:"An unknown error occurred. Please refer to the failure details in the run for more information or reach out to Momentic Support for assistance.",InternalPlatformError:"An unknown error occurred with the Momentic platform."},Ic=Ir.object({reason:Ir.nativeEnum(pe),summary:Ir.string()}).openapi({ref:"TestResultClassification"}),Qa=Ir.object({errorMessage:Ir.string(),errorStack:Ir.string().optional(),classification:Ic.optional()}).openapi({ref:"TestFailureDetails"});ve(X);var Te=(i=>(i.SUCCESS="SUCCESS",i.FAILED="FAILED",i.RUNNING="RUNNING",i.IDLE="IDLE",i.CANCELLED="CANCELLED",i))(Te||{}),Pc=(r=>(r.SUCCESS="SUCCESS",r.FAILED="FAILED",r.CANCELLED="CANCELLED",r))(Pc||{}),Lc=X.object({beforeUrl:X.string().optional(),afterUrl:X.string().optional(),message:X.string().optional(),beforeScreenshot:X.string().optional(),afterScreenshot:X.string().optional(),beforeSnapshot:X.string().optional(),afterSnapshot:X.string().optional(),startedAt:X.coerce.date(),finishedAt:X.coerce.date()}),KE=Lc.extend({viewport:X.object({height:X.number(),width:X.number()}),status:X.nativeEnum(Pc),message:X.string().optional(),elementInteracted:X.string().optional()}),Qn=Lc.extend({status:X.nativeEnum(Te),message:X.string().optional(),data:X.unknown().optional(),beforeTestContext:Hi.optional(),afterTestContext:Hi.optional(),failureReason:X.nativeEnum(pe).optional(),details:X.unknown().describe("Parse using StepExecutionLogSchema.array() to get type safety. We don't explicitly type it because it's non-critical information.")}).openapi({ref:"StepResultMetadata"}),es=Qn.merge(Ct).extend({results:KE.array(),proposedStep:Ct.optional()}),YE=Qn.merge(xr).extend({results:X.lazy(()=>es.array())}),JE=Qn.merge(So).extend({results:X.lazy(()=>es.array())}),XE=Qn.merge(_n).extend({moduleName:X.string().optional(),results:X.lazy(()=>It.array())}),ZE=Qn.merge(Er).extend({assertion:es.optional(),results:X.lazy(()=>It.array()).describe("results for the block actually executed")}),QE=Qn.merge(Di).extend({results:X.lazy(()=>It.array())}),eC=Qn.merge(Fi).extend({results:X.lazy(()=>It.array()),healingAttempts:X.lazy(()=>It.array().array()).optional()}),It=X.discriminatedUnion("type",[YE,JE,es,XE,ZE,QE,eC]),ts=Qn.pick({startedAt:!0,finishedAt:!0,status:!0,message:!0,data:!0}),ns=Lc.extend({index:X.number().optional(),description:X.string(),pageState:X.string().optional()});var Oc=tC.object({results:It.array().describe("main results"),beforeResults:It.array().optional(),afterResults:It.array().optional()}),rs=Oc.partial();import{z as $}from"zod";import{z as xe}from"zod";var nC=xe.object({type:xe.literal("FAILURE_RECOVERY"),thoughts:xe.string()}),rC=xe.object({type:xe.literal("DESCRIPTION_UPDATE"),thoughts:xe.string()}),os=xe.discriminatedUnion("type",[rC,nC]),is=(e=>(e.AUTO_HEALING="AUTO_HEALING",e))(is||{}),oC=xe.object({testId:xe.string(),name:xe.string(),orgId:xe.string(),runId:xe.string(),purpose:xe.nativeEnum(is).catch("AUTO_HEALING"),steps:Ae.array(),details:os.or(os.array()).optional()}),K0=oC.pick({name:!0,orgId:!0}),kc=xe.object({id:xe.string(),name:xe.string().nullish(),createdAt:xe.string().pipe(xe.coerce.date()).or(xe.date()),organizationId:xe.string(),schemaVersion:xe.string(),purpose:xe.nativeEnum(is).catch("AUTO_HEALING"),runId:xe.string().nullish(),details:os.or(os.array()).nullish(),applied:xe.boolean().nullish(),appliedAt:xe.coerce.date().nullish()}),Lm=kc.extend({steps:Ae.array()});import{isValidCron as iC}from"cron-validator";import{z as oe}from"zod";import{z as Mc}from"zod";var Dn=(r=>(r.CHROMIUM="Chromium",r.GOOGLE_CHROME="Google Chrome",r.CHROME_FOR_TESTING="Chrome for Testing",r))(Dn||{});var as=Mc.object({width:Mc.number().min(200).max(1e4),height:Mc.number().min(200).max(1e4)}),Om={"Desktop Large":{width:1920,height:1080},"Desktop Small":{width:1280,height:800},iPad:{width:768,height:1024},"Pixel 8":{width:448,height:998},"iPhone 15":{width:393,height:852}},X0=Object.keys(Om);var Gt=Om["Desktop Large"],Eo="en-US",Co="America/Los_Angeles";var km=["Africa/Abidjan","Africa/Accra","Africa/Algiers","Africa/Bissau","Africa/Cairo","Africa/Casablanca","Africa/Ceuta","Africa/El_Aaiun","Africa/Johannesburg","Africa/Juba","Africa/Khartoum","Africa/Lagos","Africa/Maputo","Africa/Monrovia","Africa/Nairobi","Africa/Ndjamena","Africa/Sao_Tome","Africa/Tripoli","Africa/Tunis","Africa/Windhoek","America/Adak","America/Anchorage","America/Argentina/Buenos_Aires","America/Argentina/Catamarca","America/Argentina/Cordoba","America/Argentina/Jujuy","America/Argentina/La_Rioja","America/Argentina/Mendoza","America/Argentina/Rio_Gallegos","America/Argentina/Salta","America/Argentina/San_Juan","America/Argentina/San_Luis","America/Argentina/Tucuman","America/Argentina/Ushuaia","America/Araguaina","America/Asuncion","America/Atikokan","America/Bahia","America/Bahia_Banderas","America/Barbados","America/Belem","America/Belize","America/Blanc-Sablon","America/Boa_Vista","America/Bogota","America/Boise","America/Cambridge_Bay","America/Campo_Grande","America/Cancun","America/Caracas","America/Cayenne","America/Chicago","America/Chihuahua","America/Costa_Rica","America/Creston","America/Cuiaba","America/Curacao","America/Danmarkshavn","America/Dawson","America/Dawson_Creek","America/Denver","America/Detroit","America/Dominica","America/Edmonton","America/Eirunepe","America/El_Salvador","America/Fort_Nelson","America/Fortaleza","America/Glace_Bay","America/Goose_Bay","America/Grand_Turk","America/Grenada","America/Guadeloupe","America/Guatemala","America/Guayaquil","America/Guyana","America/Halifax","America/Havana","America/Hermosillo","America/Indiana/Indianapolis","America/Indiana/Knox","America/Indiana/Marengo","America/Indiana/Petersburg","America/Indiana/Tell_City","America/Indiana/Vevay","America/Indiana/Vincennes","America/Indiana/Winamac","America/Inuvik","America/Iqaluit","America/Jamaica","America/Juneau","America/Kentucky/Louisville","America/Kentucky/Monticello","America/La_Paz","America/Lima","America/Los_Angeles","America/Maceio","America/Managua","America/Manaus","America/Marigot","America/Martinique","America/Matamoros","America/Mazatlan","America/Menominee","America/Merida","America/Metlakatla","America/Mexico_City","America/Miquelon","America/Moncton","America/Monterrey","America/Montevideo","America/Montserrat","America/Nassau","America/New_York","America/Nipigon","America/Nome","America/Noronha","America/North_Dakota/Beulah","America/North_Dakota/Center","America/North_Dakota/New_Salem","America/Ojinaga","America/Panama","America/Pangnirtung","America/Paramaribo","America/Phoenix","America/Port-au-Prince","America/Port_of_Spain","America/Porto_Velho","America/Puerto_Rico","America/Punta_Arenas","America/Rainy_River","America/Rankin_Inlet","America/Recife","America/Regina","America/Resolute","America/Rio_Branco","America/Santarem","America/Santiago","America/Santo_Domingo","America/Sao_Paulo","America/Scoresbysund","America/Sitka","America/St_Barthelemy","America/St_Johns","America/St_Kitts","America/St_Lucia","America/St_Thomas","America/St_Vincent","America/Swift_Current","America/Tegucigalpa","America/Thule","America/Thunder_Bay","America/Tijuana","America/Toronto","America/Tortola","America/Vancouver","America/Whitehorse","America/Winnipeg","America/Yakutat","America/Yellowknife","Antarctica/Casey","Antarctica/Davis","Antarctica/DumontDUrville","Antarctica/Macquarie","Antarctica/Mawson","Antarctica/Palmer","Antarctica/Rothera","Antarctica/Syowa","Antarctica/Troll","Antarctica/Vostok","Arctic/Longyearbyen","Asia/Aden","Asia/Almaty","Asia/Amman","Asia/Anadyr","Asia/Aqtau","Asia/Aqtobe","Asia/Ashgabat","Asia/Atyrau","Asia/Baghdad","Asia/Bahrain","Asia/Baku","Asia/Bangkok","Asia/Barnaul","Asia/Beirut","Asia/Bishkek","Asia/Brunei","Asia/Chita","Asia/Choibalsan","Asia/Colombo","Asia/Damascus","Asia/Dhaka","Asia/Dili","Asia/Dubai","Asia/Dushanbe","Asia/Famagusta","Asia/Gaza","Asia/Hebron","Asia/Ho_Chi_Minh","Asia/Hong_Kong","Asia/Hovd","Asia/Irkutsk","Asia/Jakarta","Asia/Jayapura","Asia/Jerusalem","Asia/Kabul","Asia/Kamchatka","Asia/Karachi","Asia/Kathmandu","Asia/Khandyga","Asia/Kolkata","Asia/Krasnoyarsk","Asia/Kuala_Lumpur","Asia/Kuching","Asia/Kuwait","Asia/Macau","Asia/Magadan","Asia/Makassar","Asia/Manila","Asia/Muscat","Asia/Nicosia","Asia/Novokuznetsk","Asia/Novosibirsk","Asia/Omsk","Asia/Oral","Asia/Phnom_Penh","Asia/Pontianak","Asia/Pyongyang","Asia/Qatar","Asia/Qostanay","Asia/Qyzylorda","Asia/Riyadh","Asia/Sakhalin","Asia/Samarkand","Asia/Seoul","Asia/Shanghai","Asia/Singapore","Asia/Srednekolymsk","Asia/Taipei","Asia/Tashkent","Asia/Tbilisi","Asia/Tehran","Asia/Thimphu","Asia/Tokyo","Asia/Tomsk","Asia/Ulaanbaatar","Asia/Urumqi","Asia/Ust-Nera","Asia/Vientiane","Asia/Vladivostok","Asia/Yakutsk","Asia/Yangon","Asia/Yekaterinburg","Asia/Yerevan","Atlantic/Azores","Atlantic/Bermuda","Atlantic/Canary","Atlantic/Cape_Verde","Atlantic/Faroe","Atlantic/Madeira","Atlantic/Reykjavik","Atlantic/South_Georgia","Atlantic/Stanley","Australia/Adelaide","Australia/Brisbane","Australia/Broken_Hill","Australia/Currie","Australia/Darwin","Australia/Eucla","Australia/Hobart","Australia/Lindeman","Australia/Lord_Howe","Australia/Melbourne","Australia/Perth","Australia/Sydney","Europe/Amsterdam","Europe/Andorra","Europe/Astrakhan","Europe/Athens","Europe/Belgrade","Europe/Berlin","Europe/Bratislava","Europe/Brussels","Europe/Bucharest","Europe/Budapest","Europe/Busingen","Europe/Chisinau","Europe/Copenhagen","Europe/Dublin","Europe/Gibraltar","Europe/Guernsey","Europe/Helsinki","Europe/Isle_of_Man","Europe/Istanbul","Europe/Jersey","Europe/Kaliningrad","Europe/Kiev","Europe/Kirov","Europe/Lisbon","Europe/Ljubljana","Europe/London","Europe/Luxembourg","Europe/Madrid","Europe/Malta","Europe/Mariehamn","Europe/Minsk","Europe/Monaco","Europe/Moscow","Europe/Oslo","Europe/Paris","Europe/Podgorica","Europe/Prague","Europe/Riga","Europe/Rome","Europe/Samara","Europe/San_Marino","Europe/Sarajevo","Europe/Saratov","Europe/Simferopol","Europe/Skopje","Europe/Sofia","Europe/Stockholm","Europe/Tallinn","Europe/Tirane","Europe/Ulyanovsk","Europe/Uzhgorod","Europe/Vaduz","Europe/Vatican","Europe/Vienna","Europe/Vilnius","Europe/Volgograd","Europe/Warsaw","Europe/Zagreb","Europe/Zaporozhye","Europe/Zurich","Indian/Antananarivo","Indian/Chagos","Indian/Christmas","Indian/Cocos","Indian/Comoro","Indian/Kerguelen","Indian/Mahe","Indian/Maldives","Indian/Mauritius","Indian/Mayotte","Indian/Reunion","Pacific/Apia","Pacific/Auckland","Pacific/Bougainville","Pacific/Chatham","Pacific/Chuuk","Pacific/Easter","Pacific/Efate","Pacific/Enderbury","Pacific/Fakaofo","Pacific/Fiji","Pacific/Funafuti","Pacific/Galapagos","Pacific/Gambier","Pacific/Guadalcanal","Pacific/Guam","Pacific/Honolulu","Pacific/Kiritimati","Pacific/Kosrae","Pacific/Kwajalein","Pacific/Majuro","Pacific/Marquesas","Pacific/Midway","Pacific/Nauru","Pacific/Niue","Pacific/Norfolk","Pacific/Noumea","Pacific/Pago_Pago","Pacific/Palau","Pacific/Pitcairn","Pacific/Pohnpei","Pacific/Port_Moresby","Pacific/Rarotonga","Pacific/Saipan","Pacific/Tahiti","Pacific/Tarawa","Pacific/Tongatapu","Pacific/Wake","Pacific/Wallis"];var Mm=1e4,Nm=2e3,ss=To.extend({browserType:oe.nativeEnum(Dn).optional(),slowMoMs:oe.number().optional().refine(n=>n===void 0||n<=Nm&&n>=-1,{message:`Slow motion must be between 0 and ${Nm} milliseconds`}),smartWaitingTimeoutMs:oe.number().optional().refine(n=>n===void 0||n<=Mm&&n>=-1,{message:`Smart waiting timeout must be between 0 and ${Mm/1e3} seconds`}),basicAuthorization:oe.object({username:oe.string().optional(),password:oe.string().optional()}).optional(),disableJavaScript:oe.boolean().optional(),disableGpu:oe.boolean().optional(),locale:oe.string().optional(),timezone:oe.enum(km).optional(),colorScheme:oe.enum(["light","dark"]).optional()}),_m=["extraHeaders","basicAuthorization","localChromeExtensionPaths"],aC=oe.object({disableAICaching:oe.boolean().optional(),failureRecovery:oe.boolean().optional().describe("undefined means inherit org settings")});var sC=oe.object({viewport:as.optional()}),Ro=sC.merge(aC).merge(ss),Ao=oe.object({cron:oe.string().refine(n=>iC(n),{message:"Invalid cron expression."}).default("0 0 */1 * *"),enabled:oe.boolean().default(!1),env:oe.string().optional(),timeZone:oe.string().default("America/Los_Angeles"),jobKey:oe.string().optional()}),Io=oe.object({onSuccess:oe.boolean().default(!1),failureMessage:oe.string().optional(),onFailure:oe.boolean().default(!0),successMessage:oe.string().optional()}),lC=oe.object({name:oe.string(),required:oe.boolean().optional(),defaultValue:oe.string().describe("this is not optional because we need a value when the editor is first loaded")}),ls=lC.array(),cC=oe.object({name:oe.string(),value:oe.string()}),Dm=cC.array(),cs=oe.object({name:oe.string(),default:oe.boolean().optional(),fixtures:Rm.array().optional()});ve($);var Wt={WEBHOOK:"WEBHOOK",CRON:"CRON",MANUAL:"MANUAL",CLI:"CLI"},ie=(s=>(s.PENDING="PENDING",s.RUNNING="RUNNING",s.PASSED="PASSED",s.FAILED="FAILED",s.CANCELLED="CANCELLED",s.RETRYING="RETRYING",s.WAITING_FOR_USER="WAITING_FOR_USER",s))(ie||{}),ds=(t=>(t.BEFORE_ALL="BEFORE_ALL",t.AFTER_ALL="AFTER_ALL",t))(ds||{});var We=$.string().pipe($.coerce.date()).or($.date()),ji=$.object({id:$.string(),runKey:$.string(),organizationId:$.string(),createdAt:We,createdBy:$.string(),flake:$.boolean().nullish(),scheduledAt:We.or($.null()),startedAt:We.or($.null()),updatedAt:We.nullish(),finishedAt:We.or($.null()),resolvedBaseUrl:$.string().nullish(),environmentName:$.string().nullish(),labels:$.array($.string()).optional(),cliVersion:$.string().nullish(),section:$.nativeEnum(ds).nullish(),status:$.nativeEnum(ie),trigger:$.nativeEnum(Wt),attempts:$.number(),runAttempts:$.array($.object({id:$.string(),status:$.nativeEnum(ie),startedAt:We.or($.null()),finishedAt:We.or($.null())})).optional(),videos:$.array($.string()).optional(),failureReason:$.nativeEnum(pe).nullish(),failureDetails:Qa.nullish(),testFragments:$.array(kc).nullish(),localTestId:$.string().nullish(),testId:$.string().nullish(),testName:$.string().nullish(),test:$.object({name:$.string(),id:$.string()}).nullish().default(null),suiteId:$.string().nullish()}).openapi({ref:"RunMetadata"}),dC={id:!0,status:!0,testName:!0,localTestId:!0,testId:!0,test:{select:{name:!0,id:!0}},finishedAt:!0,failureReason:!0,failureDetails:!0},ps=ji.pick({...dC,test:!0}),Fm=ji.omit({failureReason:!0,failureDetails:!0,test:!0}),Nc=ji.extend({stepsSnapshot:$.array($.record($.unknown())).nullish(),resolvedInputs:$.record($.string(),$.string()).nullish(),test:$.object({name:$.string(),id:$.string(),description:$.string().nullish(),baseUrl:$.string().nullish(),advanced:Ro.nullish()}).nullish()}).merge(Oc),Um=n=>n.includes("PASSED")&&n.includes("FAILED");var pC=$i.object({id:$i.string().uuid(),startedAt:We.or($i.null()),finishedAt:We.or($i.null()),status:$i.nativeEnum(ie)}).merge(rs),yU=pC.array();var Gi=(o=>(o.JUNIT="junit",o.ALLURE="allure",o.ALLURE_JSON="allure-json",o.PLAYWRIGHT_JSON="playwright-json",o))(Gi||{});import{z as qe}from"zod";var uC=qe.object({id:qe.string(),status:qe.nativeEnum(ie),trigger:qe.nativeEnum(Wt),createdAt:We,startedAt:We.nullish(),finishedAt:We.nullish(),gitCommitSha:qe.string().nullish(),gitCommitShaShort:qe.string().nullish(),gitCommitTimestamp:We.nullish(),gitBranchName:qe.string().nullish(),gitOriginUrl:qe.string().nullish(),gitCommitMessage:qe.string().nullish(),gitCommitAuthorName:qe.string().nullish(),githubRepository:qe.string().nullish(),gitlabProjectPath:qe.string().nullish(),pipelineId:qe.string().nullish(),cliVersion:qe.string().nullish(),suite:qe.object({id:qe.string(),name:qe.string()}).nullish(),runs:qe.object({status:qe.nativeEnum(ie)}).array()}).openapi({ref:"RunGroup"}),Bm=uC.pick({id:!0,createdAt:!0,startedAt:!0,finishedAt:!0,status:!0,trigger:!0,suite:!0}).extend({runs:ps.array()});import{z as Ze}from"zod";var mC=Ze.object({type:Ze.literal("TARGETING"),name:Ze.string().optional().describe("Target name to disambiguate for steps with multiple targets"),elementLocationDecisions:Wu.array(),pageState:Ze.string().optional(),targetSource:Ze.nativeEnum(Jn).optional(),targetUpdateTime:Ze.string().optional()}),hC=Ze.object({type:Ze.literal("AI_LOCATION"),matched:Ze.boolean(),pageState:Ze.string().optional(),ragUsed:Ze.boolean().optional(),thoughts:Ze.string().optional()}),gC=Ze.object({type:Ze.literal("ASSERTION"),relevantElementsSerialized:Ze.string().array().optional(),pageState:Ze.string().optional(),ragUsed:Ze.boolean().optional()}),zm=Ze.discriminatedUnion("type",[mC,hC,gC]);function us(){return{details:[]}}import{z as Be}from"zod";var fC=Be.object({id:Be.string(),name:Be.string()}),kU=fC.merge(Be.object({createdAt:We,createdBy:Be.string(),schedule:Ao,notification:Io,environment:Be.object({name:Be.string()}).nullish(),beforeTests:Be.object({id:Be.string()}).array().nullish(),afterTests:Be.object({id:Be.string()}).array().nullish()})),Hm=Be.object({id:Be.string().uuid(),orgId:Be.string(),createdAt:We,startedAt:We.or(Be.null()),finishedAt:We.or(Be.null()),status:Be.nativeEnum(ie),trigger:Be.nativeEnum(Wt),suite:Be.object({id:Be.string(),name:Be.string()}).nullish(),runs:ji.array()}),MU=Hm.pick({id:!0,createdAt:!0,startedAt:!0,finishedAt:!0,status:!0,trigger:!0,suite:!0}),jm=Hm.extend({runs:ps.array()});import{z as er}from"zod";import{cloneDeep as FU}from"lodash-es";import{z as ue}from"zod";var jU=ue.object({thoughts:ue.string(),subGoals:ue.object({instruction:ue.string()}).array()}),$U=ue.object({thoughts:ue.string(),newPlanMarkdown:ue.string()}),GU=ue.object({thoughts:ue.string(),correct:ue.boolean(),failedActionIndex:ue.number().optional()}),SC=ue.object({type:ue.literal("PLANNING"),beforePlan:ue.string(),goalDecision:ue.string(),thoughts:ue.string()}),yC=ue.object({type:ue.literal("RUNNING"),stepDisplayName:ue.string(),status:ue.nativeEnum(Te),results:It.array()}),bC=ue.object({type:ue.literal("REVISING"),beforePlan:ue.string(),afterPlan:ue.string(),errString:ue.string(),diffs:ue.string(),thoughts:ue.string()}),wC=ue.object({type:ue.literal("SYSTEM"),message:ue.string()}),vC=ue.discriminatedUnion("type",[SC,yC,bC,wC]),$m=vC.array();var YU=er.object({id:er.string(),scheduledAt:er.coerce.date().nullable(),startedAt:er.coerce.date().nullable(),finishedAt:er.coerce.date().nullable(),status:er.nativeEnum(ie),history:$m.nullable(),testPlan:er.object({name:er.string()})});var Vt=_.object({disableCache:_.boolean().optional(),loggerTags:_.record(_.string(),_.string()).optional(),langfuseSessionId:_.string().optional(),agentConfigVersion:_.string().optional()}),TC=_.object({screenshotBase64AfterCommand:_.string(),urlAfterCommand:_.string(),serializedCommand:_.string(),elementInteracted:_.string().optional(),thoughts:_.string().optional()}),Gm=_.object({goal:_.string(),browserState:_.string(),screenshot:_.string(),source:Gu.optional().catch(void 0)}),Wm=_.object({target:_.string().or(_.number()),browserState:_.string().optional(),screenshot:_.string().optional(),boundingBox:_.object({x:_.number(),y:_.number(),height:_.number(),width:_.number()}).optional()}),Vm=_.object({goal:_.string(),browserState:_.string(),screenshot:_.string().optional(),returnSchema:_.string().optional()}),qm=_.object({goal:_.string(),browserState:_.string(),screenshot:_.string(),url:_.string(),contextChoice:nc.optional()}),Km=_.object({command:go}),_c=_.object({goal:_.string(),browserState:_.string(),startingScreenshot:_.string().optional(),screenshot:_.string(),url:_.string(),history:TC.array(),actionHint:_.string().optional(),lastError:_.string().optional()}),Ym=_.object({results:ns.array(),errorMessage:_.string(),errorStack:_.string().optional()}),Jm=_.object({results:ns.array(),goal:_.string(),errorMessage:_.string()}),Xm=_.object({failedResults:ns.array(),nextStepsSerialized:_.string().array(),currentUrl:_.string(),currentPageState:_.string(),currentScreenshot:_.string()}),g1=_.object({description:_.string(),type:_.union([_.literal("locator"),_.literal("assertion"),_.literal("ai-action")]),excerpt:_.string()});import{z as Wi}from"zod";var y1=Wi.object({goal:Wi.string()}),Zm=Wi.object({keywords:Wi.array(Wi.string())});import{z as yt}from"zod";var Dc=yt.object({content:yt.string(),ids:yt.string().array(),tokenLength:yt.number()}),xC=yt.object({chunks:Dc.array()}),v1=yt.object({ids:yt.string().array(),score:yt.number(),tokenLength:yt.number()}),T1=xC.extend({description:yt.string().describe("Input to pass to RAG engine"),tokenLimit:yt.number()}),Qm=yt.object({ids:yt.number().array()}),eh=yt.object({indices:yt.number().array()});import{z as Fc}from"zod";var Uc=(t=>(t.LOCATOR="locator",t.ASSERTION="assertion",t))(Uc||{}),C1=Fc.nativeEnum(Uc),EC=Fc.enum(["v1","v2"]),R1=EC.or(Fc.string().describe("for people with special configurations"));var th=n=>!(!n.org_id||!n.user_id||!n.platform);import{z as Pr}from"zod";var nh=Pr.object({id:Pr.string().uuid(),skipped:Pr.boolean().optional(),envKey:Pr.string().optional().describe("key in the environment to save the result of this step to")}),Bc=nh.merge(Na).extend({type:Pr.literal("REQUEST")}),zc=nh.merge(_a).extend({type:Pr.literal("JAVASCRIPT")}),Hc=Pr.discriminatedUnion("type",[zc,Bc]);import{z as qt}from"zod";import{z as Lr}from"zod";var CC=/^[a-f0-9]{8}-[a-f0-9]{4}-[1-5][a-f0-9]{3}-[89ab][a-f0-9]{3}-[a-f0-9]{12}$/,Ne=n=>{let e=n.trim().toLowerCase().replace(/[^a-z0-9]/g,"-");for(;e.includes("--");)e=e.replaceAll("--","-");return e.startsWith("-")&&(e=e.slice(1)),e.endsWith("-")&&(e=e.slice(0,e.length-1)),e};var ms=Lr.string().min(1).max(255).superRefine((n,e)=>{try{Po(n)}catch(t){return e.addIssue({code:Lr.ZodIssueCode.custom,message:t.message,fatal:!0}),Lr.NEVER}});function Po(n){if(n=n.toLowerCase().trim(),n.length===0||n.length>255)throw new Error("Name must be between 1 and 255 characters long");if(/[<>:"/\\|?*]/.test(n))throw new Error('Name contains one of the following invalid characters: <>:"/\\|?*');if(n.endsWith("-")||n.startsWith("-"))throw new Error("Name cannot start or end with a dash.");if(n.includes("\0"))throw new Error("Name cannot contain null characters");if(/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i.test(n))throw new Error(`"${n}" is a reserved name on Windows and cannot be used as a filename.`);if(/^\.+$/.test(n)||/^\s|\s$/.test(n))throw new Error("Name cannot start or end with a space or dot.");if(n.endsWith(".yaml"))throw new Error('Name cannot end with ".yaml".');if(n==="none")throw new Error("Name cannot be 'none'.");if(n.match(CC))throw new Error("Name cannot be a UUID. Please choose a different name.")}var hs=Lr.preprocess(n=>n===null?"":n,Lr.union([Lr.string().url(),Lr.literal("")])).optional();var rh=qt.object({id:qt.string(),name:ms,description:qt.string().optional().nullish(),baseUrl:hs.nullish(),schemaVersion:qt.string(),advanced:qt.unknown().optional(),retries:qt.number(),envs:qt.array(cs).nullish(),parameters:ls.nullish()}),RC=qt.object({createdAt:qt.coerce.date(),updatedAt:qt.coerce.date(),schedule:Ao.nullish(),notification:Io.nullish(),createdBy:qt.string(),organizationId:qt.string()}),AC=rh.merge(RC),q1=AC.extend({steps:Hc.array()}),K1=rh.extend({steps:Hc.array()});import{z as Pt}from"zod";var oh=Pt.object({startedAt:Pt.coerce.date(),finishedAt:Pt.coerce.date(),status:Pt.nativeEnum(Te),message:Pt.string().optional(),data:Pt.unknown().optional()}),PC=oh.merge(zc).extend({type:Pt.literal("JAVASCRIPT")}),LC=oh.merge(Bc).extend({type:Pt.literal("REQUEST")}),OC=Pt.discriminatedUnion("type",[PC,LC]),ih=Pt.object({startedAt:Pt.coerce.date(),finishedAt:Pt.coerce.date().nullish(),status:Pt.nativeEnum(ie),results:OC.array(),failureReason:Pt.string().nullish(),failureDetails:Qa.nullish()});import{z as Lt}from"zod";var kC=Lt.object({id:Lt.string(),organizationId:Lt.string(),createdAt:Lt.coerce.date(),updatedAt:Lt.coerce.date(),createdBy:Lt.string(),scheduledAt:Lt.coerce.date().nullish(),startedAt:Lt.coerce.date().nullish(),finishedAt:Lt.coerce.date().nullish(),status:Lt.nativeEnum(ie),trigger:Lt.nativeEnum(Wt),results:ih.array().nullish(),apiTestName:Lt.string().nullish(),apiTestPath:Lt.string().nullish(),apiTestId:Lt.string().nullish()}),rB=kC.pick({status:!0,startedAt:!0,finishedAt:!0});var Vi=(t=>(t.TestRun="test-run",t.CreditsUsed="credits-used",t))(Vi||{}),ah=3;function MC(n){return n==="MODULE"||n==="IFRAME"||n==="CONDITIONAL"||n==="SECTION"||n==="RESOLVED_MODULE"}function qi(n){if(!MC(n))switch(n){case"PRESET_ACTION":return 0;case"AI_ACTION":return 3;case"AI_ACTION_DYNAMIC":return 5;default:(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}function Ki(n){switch(n.type){case"AI_EXTRACT":case"AI_ASSERTION":return ah;case"CAPTCHA":return 3;case"CLICK":case"TYPE":case"SELECT_OPTION":case"HOVER":case"ELEMENT_CHECK":case"FOCUS":case"BLUR":case"SCROLL_DOWN":case"SCROLL_LEFT":case"SCROLL_RIGHT":case"SCROLL_UP":return n.useSelector||!n.target||n.target.type!=="description"?0:1;case"DRAG":case"MOUSE_DRAG":return n.useSelector?0:1;case"VISUAL_DIFF":case"TAB":case"JAVASCRIPT":case"NAVIGATE":case"WAIT":case"SUCCESS":case"AUTH_LOAD":case"AUTH_SAVE":case"COOKIE":case"DIALOG":case"FILE_UPLOAD":case"GO_BACK":case"GO_FORWARD":case"LOCAL_STORAGE":case"NEW_TAB":case"PAGE_CHECK":case"PRESS":case"COPY":case"PASTE":case"REFRESH":case"REQUEST":case"GRAPHQL_REQUEST":case"WAIT_FOR_URL":case"REGISTER_REQUEST_LISTENER":case"AWAIT_LISTENER":return 0;default:(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}var Lo=class{async reportBillableEvent(e,t,r){}async reportCreditsUsed(e,t,r,o){}};function jc(n,e){return{...n,testId:e?.testId??"",testName:e?.testName??"",suiteId:e?.suiteId??"",suiteName:e?.suiteName??""}}import{parseString as NC,splitCookiesString as _C}from"set-cookie-parser";import{z as he}from"zod";var $c=he.object({name:he.string(),value:he.string(),url:he.string().optional(),domain:he.string().optional(),path:he.string().optional(),expires:he.number().default(Date.now()/1e3+60*60*24*365),httpOnly:he.boolean().optional(),secure:he.boolean().default(!0),sameSite:he.union([he.literal("Strict"),he.literal("Lax"),he.literal("None")]).default("None")});function gs(n,e){let t=[],r=_C(n);for(let o of r){let i=NC(o,{decodeValues:!1});if(!i.name)throw new Error("Name missing from cookie");if(!i.value)continue;let a;if(i.sameSite){let d=i.sameSite.trim().toLowerCase();if(d==="strict")a="Strict";else if(d==="lax")a="Lax";else if(d==="none")a="None";else throw new Error(`Invalid sameSite setting in cookie: ${d}`)}i.httpOnly===void 0&&(i.httpOnly=!1),!i.path&&i.domain&&(i.path="/"),!i.domain&&e&&(i.domain=e);let s=$c.parse({...i,expires:i.expires?i.expires.getTime()/1e3:void 0,sameSite:a});t.push(s);let l=[s.name,...Object.keys(s)].map(d=>d.toLowerCase()),c=o.match(/\b(\S+)=([^;]*)/g);if(c)for(let d of c){let[p,m]=d.split("=");if(!p||!m)throw new Error(`Invalid key-value pair in cookie: ${d}`);l.includes(p.toLowerCase())||t.push({...s,name:p,value:m})}}return t}var DC=he.object({origin:he.string(),localStorage:he.array(he.object({name:he.string(),value:he.string()}))}),FC=he.object({entries:he.record(he.string(),he.array(he.tuple([he.unknown(),he.unknown()]))),version:he.number().optional()}),fs=he.object({cookies:$c.array().optional(),origins:DC.array().optional(),idb:he.record(he.string(),FC).optional().describe("key is db name")});function Ss(n,e){let t=[];return n.cloneSync()?.serializeSync()?.cookies.forEach(r=>{let o=$c.safeParse({name:r.key,...r});if(!o.success)return;let i=o.data;!i.domain&&!i.url&&(i.domain=e),t.push(i)}),t}var CB=new Set(Object.values(Ue));var UC={AI_ACTION:"AI action",AI_ACTION_DYNAMIC:"AI action",RESOLVED_MODULE:"Module",AI_ASSERTION:"AI check",AI_EXTRACT:"AI extract",CLICK:"Click",TYPE:"Type",JAVASCRIPT:"JavaScript",SELECT_OPTION:"Select",PRESS:"Press",NAVIGATE:"Navigate",SCROLL_UP:"Scroll up",SCROLL_DOWN:"Scroll down",SCROLL_LEFT:"Scroll left",SCROLL_RIGHT:"Scroll right",HOVER:"Hover",BLUR:"Blur",FILE_UPLOAD:"File upload",FOCUS:"Focus",GO_BACK:"Go back",GO_FORWARD:"Go forward",WAIT:"Wait",REFRESH:"Refresh",TAB:"Switch tab",NEW_TAB:"New tab",COOKIE:"Cookie",LOCAL_STORAGE:"Local storage",REQUEST:"API request",GRAPHQL_REQUEST:"GraphQL request",CAPTCHA:"CAPTCHA",DRAG:"Drag & drop",VISUAL_DIFF:"Visual diff",DIALOG:"Dialog",MOUSE_DRAG:"Mouse drag",AUTH_LOAD:"Load auth state",AUTH_SAVE:"Save auth state",ELEMENT_CHECK:"Element check",PAGE_CHECK:"Page check",WAIT_FOR_URL:"Wait for URL",COPY:"Copy",PASTE:"Paste",REGISTER_REQUEST_LISTENER:"Register request listener",AWAIT_LISTENER:"Await listener",SUCCESS:"Done"},RB={AI_ACTION:["ai","action","agent"],AI_ACTION_DYNAMIC:["ai","action","dynamic","agent"],RESOLVED_MODULE:[],AI_ASSERTION:["ai","check","assert","make sure","ensure"],AI_EXTRACT:["ai","extract","data"],CLICK:["click","press"],TYPE:["type","input","write","press"],JAVASCRIPT:["js","javascript","code","execute"],SELECT_OPTION:["select","option","choose"],PRESS:["keyboard","type","key"],NAVIGATE:["go to","visit"],SCROLL_UP:[],SCROLL_DOWN:[],SCROLL_LEFT:[],SCROLL_RIGHT:[],HOVER:["scroll into view","go to"],BLUR:[],FILE_UPLOAD:[],FOCUS:[],GO_BACK:[],GO_FORWARD:[],WAIT:[],REFRESH:[],TAB:[],NEW_TAB:[],COOKIE:[],LOCAL_STORAGE:[],REQUEST:[],GRAPHQL_REQUEST:[],CAPTCHA:[],DRAG:[],VISUAL_DIFF:[],DIALOG:[],MOUSE_DRAG:[],AUTH_LOAD:[],AUTH_SAVE:[],ELEMENT_CHECK:[],PAGE_CHECK:[],WAIT_FOR_URL:[],COPY:[],PASTE:[],REGISTER_REQUEST_LISTENER:[],AWAIT_LISTENER:[],SUCCESS:[]},AB={AI_ACTION:"Ask AI achieve a specific goal. Caches the steps for reuse. Please use Dynamic AI action instead.",AI_ACTION_DYNAMIC:"Ask AI achieve a specific goal. Fully dynamic. Our most capable AI agent.",RESOLVED_MODULE:"A list of steps that can be reused in multiple tests.",AI_ASSERTION:"Ask AI whether something is true on the page, retrying until a configurable timeout.",CLICK:"Click on an element on the page based on a description.",DIALOG:"Specify how native browser dialogs should be handled.",AI_EXTRACT:"Ask AI to extract data from the page based on a description.",HOVER:"Hover over an element on the page based on a description.",FILE_UPLOAD:"Automatically upload a file when the next file chooser is activated.",FOCUS:"Focus an element on the page based on a description.",BLUR:"Remove focus from an element on the page based on a description.",SELECT_OPTION:"Select an option from an HTML Select <select> element based on a description.",TYPE:"Type the specified text into an element.",PRESS:"Press the specified keys using the keyboard. (e.g. Control+A)",NAVIGATE:"Navigate to the specified URL.",SCROLL_UP:"Scroll up by a specified height.",SCROLL_DOWN:"Scroll down by a specified height.",SCROLL_LEFT:"Scroll left by a specified width.",SCROLL_RIGHT:"Scroll right by a specified width.",GO_BACK:"Go back in browser history.",GO_FORWARD:"Go forward in browser history.",WAIT:"Wait for the specified number of seconds.",REFRESH:"Refresh the page. This will not clear cookies or session data.",TAB:"Switch to different tab in the browser.",NEW_TAB:"Create and switch to a new tab in the browser.",COOKIE:"Set a cookie that will persist throughout the browser session",LOCAL_STORAGE:"Set a local storage value that will persist throughout the browser session",CAPTCHA:"Solve CAPTCHAs on the page. This feature is only available on Momentic Cloud and may take up to 60 seconds. Disabling CAPTCHAs in non-production environments is strongly advised.",REQUEST:"Make an API request to a URL.",GRAPHQL_REQUEST:"Make a GraphQL request to a URL.",JAVASCRIPT:"Run JavaScript code.",DRAG:"Click and drag an element to another location.",VISUAL_DIFF:"Compare a screenshot of the page or a specific element to a baseline image.",MOUSE_DRAG:"Click and drag the mouse by a specified distance.",AUTH_LOAD:"Load or clear session state using a JSON snapshot including cookies, local storage, and IndexDB entries.",AUTH_SAVE:"Save auth state (cookies, local storage) into a JavaScript object format usable by 'Load auth state'.",ELEMENT_CHECK:"Assert on an element's state using pre-built conditions, including content, visibility, attribute value checks.",PAGE_CHECK:"Assert on the active page's state using pre-built conditions, including URL and content checks.",WAIT_FOR_URL:"Wait for the active page's URL to match a specific URL or glob pattern. If a new tab is opened, this command will wait for the new tab's URL to match instead.",COPY:"Copy the specified value to the browser clipboard.",PASTE:"Paste the clipboard contents.",REGISTER_REQUEST_LISTENER:"Register a listener for network requests.",AWAIT_LISTENER:"Wait for a listener to fire, and return the response data.",SUCCESS:"Indicate the entire AI action has succeeded, optionally based on a condition."};import{Faker as LB,en as OB}from"@faker-js/faker";import{z as G}from"zod";var sh=55555,_B=G.object({body:G.string(),to:G.string(),from:G.string()}),DB=G.object({from:G.string().optional(),to:G.string(),timeout:G.number().optional(),beforeDate:G.string().pipe(G.coerce.date()).or(G.date()).optional(),afterDate:G.string().pipe(G.coerce.date()).or(G.date()).optional()}),FB=G.object({to:G.string(),from:G.string(),subject:G.string(),body:G.string()}),UB=G.object({inbox:G.string(),afterDate:G.string().pipe(G.coerce.date()).or(G.date()).optional(),timeout:G.number().optional(),trimWhitespace:G.boolean().optional()}),BB=G.object({inbox:G.string(),limit:G.number().optional(),afterDate:G.string().pipe(G.coerce.date()).or(G.date()).optional(),trimWhitespace:G.boolean().optional()});var lh=G.object({result:G.unknown(),variableUpdates:G.record(G.string(),G.unknown()).optional(),persistentVariableUpdates:G.record(G.string(),G.unknown()).optional(),error:G.string().optional(),success:G.boolean()}),zB=G.object({id:G.string().optional(),orgId:G.string(),momenticLambdaAuthHash:G.string(),code:G.string(),fragment:G.boolean(),state:Hi,timeoutMs:G.number().optional()}),tr=15e3;import*as ut from"zod";ve(ut);var BC=ut.object({url:ut.string(),lineNumber:ut.number(),columnNumber:ut.number()}).openapi({ref:"CodeLocation"}),ys=ut.object({timestamp:ut.number(),text:ut.string(),type:ut.string(),tabIndex:ut.number(),args:ut.unknown().array().optional(),url:ut.string().optional(),location:BC.optional()}).openapi({ref:"ConsoleLog"}),ch=ys.array(),zC=ch.array();import*as Wc from"zod";import{z as I}from"zod";var HC=I.object({name:I.string(),version:I.string(),comment:I.string().optional()}),jC=I.object({name:I.string(),version:I.string(),comment:I.string().optional()}),$C=I.object({onContentLoad:I.number().optional(),onLoad:I.number().optional(),comment:I.string().optional()}),ph=I.object({startedDateTime:I.string(),id:I.string(),title:I.string().optional(),pageTimings:$C,comment:I.string().optional()}),GC=I.array(ph),WC=I.object({name:I.string(),value:I.string(),path:I.string().optional(),domain:I.string().optional(),expires:I.string().optional(),httpOnly:I.boolean().optional(),secure:I.boolean().optional(),comment:I.string().optional()}),uh=I.array(WC),VC=I.object({name:I.string(),value:I.string(),comment:I.string().optional()}),mh=I.array(VC),qC=I.object({name:I.string(),value:I.string(),comment:I.string().optional()}),KC=I.array(qC),YC=I.object({name:I.string(),value:I.string().optional(),fileName:I.string().optional(),contentType:I.string().optional(),comment:I.string().optional()}),JC=I.array(YC),XC=I.object({mimeType:I.string(),params:JC,text:I.string(),comment:I.string().optional()}),ZC=I.object({method:I.string(),url:I.string(),httpVersion:I.string().optional(),cookies:uh,headers:mh,queryString:KC,postData:XC.optional(),headersSize:I.number().optional(),bodySize:I.number().optional(),comment:I.string().optional()}),QC=I.object({size:I.number().optional(),compression:I.number().optional(),mimeType:I.string().optional(),text:I.string().optional(),encoding:I.string().optional(),comment:I.string().optional()}),eR=I.object({status:I.number(),statusText:I.string(),httpVersion:I.string().optional(),cookies:uh,headers:mh,content:QC,redirectURL:I.string().optional(),headersSize:I.number().optional(),bodySize:I.number().optional(),comment:I.string().optional()}),dh=I.object({expires:I.string().optional(),lastAccess:I.string(),eTag:I.string(),hitCount:I.number(),comment:I.string().optional()}),tR=I.object({beforeRequest:dh.optional(),afterRequest:dh.optional(),comment:I.string().optional()}),nR=I.object({blocked:I.number().optional(),dns:I.number().optional(),connect:I.number().optional(),send:I.number(),wait:I.number(),receive:I.number(),ssl:I.number().optional(),comment:I.string().optional()}),hh=I.object({pageref:I.string().optional(),startedDateTime:I.string(),time:I.number().optional(),request:ZC,response:eR.optional(),cache:tR.optional(),timings:nR,serverIPAddress:I.string().optional(),connection:I.string().optional(),comment:I.string().optional(),_resourceType:I.string().optional()}),rR=I.array(hh),oR=I.object({version:I.string().default("1.1"),creator:HC.optional(),browser:jC.optional(),pages:GC.optional(),entries:rR,comment:I.string().optional()}),iR=I.object({log:oR}),gh=I.record(I.string(),ph),fh=I.record(I.string(),hh);function Gc(n,e){return{log:{version:"1.2",creator:{name:"Momentic, Inc.",version:"1.0.0"},pages:Object.values(n).sort((t,r)=>new Date(t.startedDateTime).getTime()-new Date(r.startedDateTime).getTime()),entries:Object.values(e).sort((t,r)=>new Date(t.startedDateTime).getTime()-new Date(r.startedDateTime).getTime())}}}ve(Wc);var aR=Wc.object({logsPerPage:ys.array().array(),harPages:gh.optional(),harEntries:fh.optional()}).openapi({ref:"DebugData"});var Or=class{async getConsoleLogsForRunAttempt(e,t,r){}async getNetworkLogsForRunAttempt(e,t,r){}async getHtmlSnapshot(e,t){}async getA11yTreeSnapshot(e,t){}async getScreenshot(e,t){}async storeConsoleLogsForRunAttempt(e,t,r,o){}async storeNetworkLogsForRunAttempt(e,t,r,o){}async storeScreenshot(e,t,r){}async storeHtmlSnapshot(e,t,r){}};var bs=class extends Error{constructor(e,t,r,o={}){super(`The ${r} with id ${t} is invalid: ${e}`,o),this.name="InvalidEntityError"}};function Sh(n){for(let e of Object.values(pe))if(n.includes(e))return e}var R=class extends Error{reason;constructor(e,t,r){let o=!1;for(let i of Object.values(pe))if(t.startsWith(i)){o=!0,e=i;break}if(r?.errOptions?.cause)super(o?t:`${e}: ${t}`,r?.errOptions);else{let i=o?t:`${e}${t?`: ${t}`:""}`;super(i,r?.errOptions)}this.name="TestFailureError",this.stack=this.stack?.slice(this.name.length+2),this.reason=e,Object.defineProperty(this,"lastScreenshotBuffer",{value:r?.lastScreenshotBuffer,enumerable:!1})}getLastScreenshotBuffer(){return"lastScreenshotBuffer"in this?this.lastScreenshotBuffer:void 0}toString(){return this.message}toJSON(){return{message:this.message}}},nr=class extends Error{decisions;constructor(e,t,r={}){super(e,r),this.decisions=t,this.name="NoElementsFoundError"}toString(){return`${this.message}
6
+ `)return Ux(r);if(r===void 0)r=i;else if(r[0]===i)r+=i;else return}},Ux=n=>n===void 0?0:n[0]===" "?n.length:n;var Ku=(n,e)=>{let t=yc(n,"toPrecision",e,e);return t===void 0?yc(n,"toExponential",e,e):t},yc=(n,e,t,r)=>{let i=n[e](r).replace(Bx,"$1").replace(zx,"$1");return i.length<=t?i:r===1?void 0:yc(n,e,t,r-1)},Bx=/(e)\+/iu,zx=/\.?0*($|e)/iu;var Ju=(n,e)=>{if(typeof n!="string")throw new TypeError(`Input must be a JSON string: ${n}`);Hx(e)},Hx=n=>{if(jx(n),n<0)throw new TypeError(`"maxSize" argument must be positive: ${n}`);if(n<Yu)throw new TypeError(`"maxSize" argument must be at least ${Yu}: ${n}`)},jx=n=>{if(n===void 0)throw new TypeError('"maxSize" argument must be defined');if(!Number.isInteger(n))throw new TypeError(`"maxSize" argument must be an integer: ${n}`)},Yu=7;var Ha=(n,e,t)=>{let r=Zu(e,t);return Xu(n,e,r)},Xu=(n,e,t)=>{if(t>=e)return t;let r=n[t];return r>=Xx&&r<=Zx?Xu(n,e,t+1):t},ja=(n,e,t)=>{if(t===void 0)return t;let r=Zu(e,t);return $x(n,r)},$x=(n,e)=>Gx(n,e)?e-3:Wx(n,e)?e-2:Vx(n,e)?e-1:e,Gx=(n,e)=>e>=3&&n[e-3]>=qx&&n[e-3]<=Kx,Wx=(n,e)=>e>=2&&n[e-2]>=Yx,Vx=(n,e)=>e>=1&&n[e-1]>=Jx,Zu=(n,e)=>e<0||Object.is(e,-0)?Math.max(n+e,0):e,qx=240,Kx=244,Yx=224,Jx=194,Xx=128,Zx=191;var Qu=(n,e,t)=>{let r=globalThis.Buffer.from(n),o=Ha(r,r.length,e),i=ja(r,r.length,t);return o===0&&i>=r.length?r.toString():r.toString("utf8",o,i)};var em=/[\uD800-\uDFFF]/gu,tm="\uFFFD";var $a=n=>Qx(n)?n.replace(em,tm):n,Qx=n=>{for(let e=0;e<n.length;e+=1){let t=n.codePointAt(e);if(t>=55296&&t<=57343)return!0}return!1};var vc=({input:n,targetByteCount:e,firstStartSurrogate:t,lastStartSurrogate:r,firstEndSurrogate:o,lastEndSurrogate:i,increment:a,canBacktrack:s,shift:l,charIndexInit:c})=>{let d=c,p=d,m=0;for(;m<e;d+=a){p=d;let h=n.charCodeAt(d);if(Number.isNaN(h))break;if(h<=127){m+=1;continue}if(h<=2047){m+=2;continue}if(m+=3,h<t||h>r)continue;let g=n.charCodeAt(d+a);Number.isNaN(g)||g<o||g>i||(m+=1,d+=a)}return(s&&m>e?p:d)+l};var Tc=(n,e,t)=>e<0||Object.is(e,-0)?iE(n,e,t):oE(n,e,t),oE=(n,e,t)=>vc({input:n,targetByteCount:e,firstStartSurrogate:55296,lastStartSurrogate:56319,firstEndSurrogate:56320,lastEndSurrogate:57343,increment:1,canBacktrack:t,shift:0,charIndexInit:0}),iE=(n,e,t)=>vc({input:n,targetByteCount:-e,firstStartSurrogate:56320,lastStartSurrogate:57343,firstEndSurrogate:55296,lastEndSurrogate:56319,increment:-1,canBacktrack:!t,shift:1,charIndexInit:n.length-1});var Ga=(n,e,t)=>{let r=Tc(n,e,!1),o=aE(n,t),i=r===0&&o===void 0?n:n.slice(r,o);return $a(i)},aE=(n,e)=>{if(e===void 0)return e;let t=Tc(n,e,!0);return t===n.length?void 0:t};var rm=(n,e,t)=>{let{textEncoder:r,textDecoder:o}=sE(),i=lE(n),{written:a}=r.encodeInto(n,i),s=Ha(i,a,e),l=ja(i,a,t),c=l===void 0?a:Math.min(l,a),d=i.subarray(s,c);return o.decode(d)},sE=()=>(xc===void 0&&(xc=new globalThis.TextEncoder,nm=new globalThis.TextDecoder("utf8",{fatal:!1})),{textEncoder:xc,textDecoder:nm}),xc,nm,lE=n=>{let e=n.length*3;return e>cE?new Uint8Array(e):((Wa===void 0||Wa.length<e)&&(Wa=new Uint8Array(e)),Wa)},cE=1e5,Wa;var om=(n,e)=>{if(e===void 0)return e;let t=Ec(n,e);return t>=n.length*im?void 0:t},Ec=(n,e)=>e<=n.length*-im?0:e,im=4;var am=(n,e,t)=>{if(typeof n!="string")throw new TypeError(`First argument must be a string: ${n}`);dE(e),pE(t)},dE=n=>{if(n===void 0)throw new TypeError("Second argument is required.");sm("Second",n)},pE=n=>{n!==void 0&&sm("Third",n)},sm=(n,e)=>{if(!Number.isInteger(e))throw new TypeError(`${n} argument must be an integer: ${e}`)};var lm=n=>{let e=!0,t=0;for(let r=0;r<Cc;r+=1){let o=uE(n,r);o<=127||(e&&(e=!1),o>2047&&(t+=1))}return{asciiOnly:e,longCharsPercentage:t/Cc}},uE=(n,e)=>{let t=Cc-1,r=1-(t-e)/t,o=Math.round(r*(n.length-1));return n.charCodeAt(o)},Cc=50;var mE=(n,e,t)=>{if(am(n,e,t),n==="")return n;let r=Ec(n,e),o=om(n,t);return o===void 0&&Object.is(r,0)?$a(n):hE(n,r,o)},cm=mE,hE=(n,e,t)=>{if(n.length<=gE)return Ga(n,e,t);let{asciiOnly:r,longCharsPercentage:o}=lm(n);return r?SE(n,e,t):o>=fE?Ga(n,e,t):dm(n,e,t)},gE=200,fE=.4,SE=(n,e,t)=>"Buffer"in globalThis&&"from"in globalThis.Buffer?Qu(n,e,t):dm(n,e,t),dm=(n,e,t)=>"TextEncoder"in globalThis?rm(n,e,t):Ga(n,e,t);var um=(n,e)=>{let t=JSON.stringify(n),r=wE(t),o=cm(r,0,e-pm.length-Bi.length*2),a=`${yE(o)}${pm}`;return vE(a)},yE=n=>n.replace(bE,""),bE=/(\\|\\u[0-9a-fA-F]{0,3})$/u,wE=n=>n.slice(Bi.length,-Bi.length),vE=n=>`${Bi}${n}${Bi}`,Bi='"',pm="...";var mm=n=>globalThis.Buffer.byteLength(n);var Rc=n=>{let e=n.length,t=e;for(let r=0;r<e;r+=1){let o=n.charCodeAt(r);if(o<=TE)continue;if(o<=xE){t+=1;continue}if(t+=2,o<EE||o>CE)continue;let i=n.charCodeAt(r+1);i<RE||i>AE||(r+=1)}return t},TE=127,xE=2047,EE=55296,CE=56319,RE=56320,AE=57343;var hm=()=>IE.bind(void 0,new TextEncoder),IE=(n,e)=>{let t=PE(e);return n.encodeInto(e,t).written},PE=n=>{let e=n.length*3;return e>LE?new Uint8Array(e):((Va===void 0||Va.length<e)&&(Va=new Uint8Array(e)),Va)},LE=1e5,Va;var kE=()=>"Buffer"in globalThis&&"byteLength"in globalThis.Buffer?mm:"TextEncoder"in globalThis?ME.bind(void 0,hm()):Rc,ME=(n,e)=>e.length<100?Rc(e):n(e),gm=kE();var fm=n=>{if(n===null)return NE;if(n===!0)return _E;if(n===!1)return DE;let e=typeof n;return e==="object"?FE:e==="number"?JSON.stringify(n).length:Ac(n)},NE=4,_E=4,DE=5,FE=2,Ac=n=>gm(JSON.stringify(n));var qa=({size:n,increment:e,maxSize:t,truncatedProps:r,path:o,value:i})=>{let a=n+e,s=a>t;return s?{size:n,stop:s,truncatedProps:[...r,{path:o,value:i}]}:{size:a,stop:s,truncatedProps:r}},ym=n=>fm(n),bm=(n,e,t)=>{let r=vm({empty:n,indent:e,depth:t,keySpaceSize:0}),o=Tm(n);return r+o},wm=({key:n,empty:e,indent:t,depth:r})=>{let o=vm({empty:e,indent:t,depth:r,keySpaceSize:1}),i=Ac(n),a=Tm(e);return o+i+UE+a},UE=1,vm=({empty:n,indent:e,depth:t,keySpaceSize:r})=>{if(e===void 0)return 0;let o=Sm+e*(t+1),i=n?Sm+e*t:0;return r+o+i},Sm=1,Tm=n=>n?0:BE,BE=1;var Ka=({parent:n,truncatedProps:e,path:t,increment:r,maxSize:o,key:i,empty:a,size:s,truncateValue:l,indent:c,depth:d})=>{let p=n[i],m=[...t,i],{size:u,stop:h,truncatedProps:g}=qa({size:s,increment:r,maxSize:o,truncatedProps:e,path:m,value:p});return h?{empty:a,size:u,truncatedProps:g}:zE({value:p,truncatedProps:e,path:m,maxSize:o,empty:a,size:s,newSize:u,truncateValue:l,indent:c,depth:d})},zE=({value:n,truncatedProps:e,path:t,maxSize:r,empty:o,size:i,newSize:a,truncateValue:s,indent:l,depth:c})=>{let{value:d,size:p,truncatedProps:m}=s({value:n,truncatedProps:e,path:t,size:a,maxSize:r,indent:l,depth:c+1});return d===void 0?{empty:o,size:i,truncatedProps:m}:{empty:!1,size:p,value:d,truncatedProps:m}};var xm=({array:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:i,indent:a,depth:s})=>{let l=[],c={empty:!0,size:r,truncatedProps:e};for(let d=0;d<n.length;d+=1){let p=bm(c.empty,a,s);c=Ka({parent:n,truncatedProps:c.truncatedProps,path:t,increment:p,maxSize:o,key:d,empty:c.empty,size:c.size,truncateValue:i,indent:a,depth:s}),c.value!==void 0&&l.push(c.value)}return{value:l,size:c.size,truncatedProps:c.truncatedProps}};var Em=({object:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:i,indent:a,depth:s})=>{let l={},c={empty:!0,size:r,truncatedProps:e};for(let d in n){let p=wm({key:d,empty:c.empty,indent:a,depth:s});c=Ka({parent:n,truncatedProps:c.truncatedProps,path:t,increment:p,maxSize:o,key:d,empty:c.empty,size:c.size,truncateValue:i,indent:a,depth:s}),c.value!==void 0&&(l[d]=c.value)}return{value:l,size:c.size,truncatedProps:c.truncatedProps}};var Ya=({value:n,truncatedProps:e,path:t,size:r,maxSize:o,indent:i,depth:a})=>{let s=ym(n),{size:l,stop:c,truncatedProps:d}=qa({size:r,increment:s,maxSize:o,truncatedProps:e,path:t,value:n});return c?{value:void 0,size:l,truncatedProps:d}:HE({value:n,truncatedProps:d,path:t,size:l,maxSize:o,indent:i,depth:a})},HE=({value:n,truncatedProps:e,path:t,size:r,maxSize:o,indent:i,depth:a})=>typeof n!="object"||n===null?{value:n,size:r,truncatedProps:e}:Array.isArray(n)?xm({array:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:Ya,indent:i,depth:a}):Em({object:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:Ya,indent:i,depth:a});var jE=(n,e)=>{Ju(n,e);let t=$E(n),r=GE(n),{value:o,truncatedProps:i}=Ya({value:r,truncatedProps:[],path:[],size:0,maxSize:e,indent:t,depth:0});return{jsonString:WE({newValue:o,value:r,maxSize:e,indent:t}),truncatedProps:i}},bo=jE,$E=n=>{let e=qu(n);return typeof e=="string"?e.length:e},GE=n=>{try{return JSON.parse(n)}catch(e){throw new TypeError(`Invalid JSON string: "${n}"
7
+ ${e.message}`)}},WE=({newValue:n,value:e,maxSize:t,indent:r})=>n!==void 0?JSON.stringify(n,void 0,r):typeof e=="number"?Ku(e,t):um(e,t);import*as Ar from"zod";import{z as Ie}from"zod";var Cm=6e4,Ge="BASE_URL",Ja="CURRENT_URL",wo="ENV_NAME",T0={[Ge]:"https://www.google.com"},Rm=Ie.string().describe("Name of the fixture (must be available locally in the fixtures directory)."),Xa=Ie.object({name:Ie.string(),variables:Ie.record(Ie.string().describe("variable name"),Ie.string().describe("variable value"))}),vo=Ie.object({pageLoadTimeoutMs:Ie.number().optional().refine(n=>n===void 0||n<=Cm&&n>=-1,{message:`Page load timeout must be between 0 and ${Cm/1e3} seconds`}).describe("global page load timeout default for all tests in ms, can still be overridden by individual tests"),localChromeExtensionPaths:Ie.string().array().optional(),extraHeaders:Ie.record(Ie.string(),Ie.string()).optional().describe("HTTP headers to be sent on every request"),userAgent:Ie.string().optional(),disableGpu:Ie.boolean().optional(),ignoreHrefForCaching:Ie.boolean().optional().describe("When running locally often times <a> hrefs will be different every time, resulting in cache busting. This will ignore href in <a> matching when there is text content."),autoFollowNewTabs:Ie.boolean().optional().describe("Deprecated: Auto-follow new tabs that are opened."),showZeroOpacityElements:Ie.boolean().optional().describe("Allow the AI to see and interact with elements that have zero opacity."),bustCacheOnBoundingBoxChange:Ie.boolean().optional().describe("Bust the cache if no elements are matched that have the same bounding box and location as the original element. This will improve accuracy on sites that use many same components, at the expense of stability and speed."),allowPartialAccessibilityTree:Ie.boolean().optional().describe("Allow fetching the partial accessibility tree if the full tree takes too long.")}),Am=Ie.object({name:Ie.string(),variables:Ie.record(Ie.string().describe("variable name"),Ie.unknown().describe("variable value")),browser:vo.optional()});ve(Ar);var Hi=Ar.object({env:Ar.record(Ar.unknown())}).openapi({ref:"TestContextSnapshot"}),VE="\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022",qE=[Ge,wo],Im=[Ja,Ge,wo],At=class n{env={};varsFromMomenticEnvironment={};constructor(e){this.reset(e)}static dummyContext(e=void 0,t={}){return new n({baseUrl:"about:blank",currentUrl:"about:blank",envName:e,variablesFromEnvironment:t})}static fromSnapshot({snapshot:e,environmentVariables:t}){let r=e.env[Ge]??"about:blank",o=e.env[Ja]??"about:blank",i=e.env[wo],a={};for(let[l,c]of Object.entries(e.env))Im.includes(l)||(t??{})[l]===void 0&&(a[l]=c);return new n({baseUrl:r,currentUrl:o,dynamicVariables:a,envName:i,variablesFromEnvironment:t??{}})}setEnvVariables(e){let t=zi(e);this.env=Object.assign(this.env,t)}setInputs(e){e&&this.setEnvVariables(e)}setMomenticSystemVariable(e,t){this.varsFromMomenticEnvironment[e]=t}getVariable(e){return this.env[e]}setVariable(e,t){qE.includes(e)||(this.env[e]=t)}getEnvName(){return this.env[wo]}toObjectCopy(){let e={env:Object.assign({},this.env,this.varsFromMomenticEnvironment)};return zi(e)}toEditorDisplayCopy(){return this.toObjectCopy()}toRedactedDisplayCopy(){let e=this.toObjectCopy();e.env=Object.fromEntries(Object.entries(e.env).map(([r,o])=>Im.includes(r)||this.varsFromMomenticEnvironment[r]===void 0?[r,o]:[r,VE]));for(let[r,o]of Object.entries(e.env)){if(!o){e.env[r]=o;continue}let{jsonString:i}=bo(JSON.stringify(o),1e3);try{e.env[r]=JSON.parse(i)}catch{e.env[r]=void 0}}let{jsonString:t}=bo(JSON.stringify(e.env),5e3);try{e.env=JSON.parse(t)}catch{e.env={}}return e}setCurrentUrl(e){this.env[Ja]=e}reset(e){this.env={},this.varsFromMomenticEnvironment={},this.setEnvVariables(e.dynamicVariables??{}),this.setCurrentUrl(e.currentUrl),this.varsFromMomenticEnvironment=zi(e.variablesFromEnvironment),this.setMomenticSystemVariable(Ge,e.baseUrl),e.envName&&this.setMomenticSystemVariable(wo,e.envName)}getDynamicVariablesCopy(){return zi(this.env)}getVariablesFromEnvironmentCopy(){return zi(this.varsFromMomenticEnvironment)}};import{z as Ir}from"zod";ve(Ir);var pe=(c=>(c.AI_PROVIDER="AIProviderError",c.USER_INFRA="UserInfrastructureError",c.ACTION_FAILURE="ActionFailureError",c.ASSERTION_FAILURE="AssertionFailureError",c.CONFIG_ERROR="UserConfigurationError",c.WEB_AGENT_PLATFORM="InternalWebAgentError",c.UNKNOWN_PLATFORM="InternalPlatformError",c.JOB_TIMEOUT="JobTimeoutError",c.UNKNOWN="UnknownError",c))(pe||{});var Pm=["JobTimeoutError","UserConfigurationError","UserInfrastructureError"],Za={ActionFailureError:"Action failure",AssertionFailureError:"Assertion failure",UserInfrastructureError:"Infrastructure failure",UserConfigurationError:"Configuration error",AIProviderError:"AI provider error",InternalWebAgentError:"Momentic AI agent error",JobTimeoutError:"Job timeout",InternalPlatformError:"Unknown Momentic platform error",UnknownError:"Unknown error"},To={ActionFailureError:"A browser action such as a click or type failed to execute because of the underlying page state is incorrect, suggesting a bug in the application itself.",AssertionFailureError:"An AI assertion or check failed for a legitimate reason, such as a missing element, a change in the page structure, or an unexpected state (e.g. loading state).",AIProviderError:"The AI provider failed to return a response or returned a malformed response.",UserInfrastructureError:"The user's web application exhibited an infrastructure failure, such as a page load timeout, a 5XX status code, maintenance page, or session crash.",UserConfigurationError:"The error message suggests a user-caused misconfiguration in the test, such as an undefined variable, a missing base URL, an empty test/module input parameter, or an invalid step option",JobTimeoutError:"The test took too long to complete, suggesting a problem with the test itself.",InternalWebAgentError:"The AI testing framework failed to find the correct element or evaluate the assertion correctly, even though the test steps and application state look valid. In other words, the AI agent failed to understand the page.",UnknownError:"An unknown error occurred. Please refer to the failure details in the run for more information or reach out to Momentic Support for assistance.",InternalPlatformError:"An unknown error occurred with the Momentic platform."},Ic=Ir.object({reason:Ir.nativeEnum(pe),summary:Ir.string()}).openapi({ref:"TestResultClassification"}),Qa=Ir.object({errorMessage:Ir.string(),errorStack:Ir.string().optional(),classification:Ic.optional()}).openapi({ref:"TestFailureDetails"});ve(X);var Te=(i=>(i.SUCCESS="SUCCESS",i.FAILED="FAILED",i.RUNNING="RUNNING",i.IDLE="IDLE",i.CANCELLED="CANCELLED",i))(Te||{}),Pc=(r=>(r.SUCCESS="SUCCESS",r.FAILED="FAILED",r.CANCELLED="CANCELLED",r))(Pc||{}),Lc=X.object({beforeUrl:X.string().optional(),afterUrl:X.string().optional(),message:X.string().optional(),beforeScreenshot:X.string().optional(),afterScreenshot:X.string().optional(),beforeSnapshot:X.string().optional(),afterSnapshot:X.string().optional(),startedAt:X.coerce.date(),finishedAt:X.coerce.date()}),KE=Lc.extend({viewport:X.object({height:X.number(),width:X.number()}),status:X.nativeEnum(Pc),message:X.string().optional(),elementInteracted:X.string().optional()}),Qn=Lc.extend({status:X.nativeEnum(Te),message:X.string().optional(),data:X.unknown().optional(),beforeTestContext:Hi.optional(),afterTestContext:Hi.optional(),failureReason:X.nativeEnum(pe).optional(),details:X.unknown().describe("Parse using StepExecutionLogSchema.array() to get type safety. We don't explicitly type it because it's non-critical information.")}).openapi({ref:"StepResultMetadata"}),es=Qn.merge(Ct).extend({results:KE.array(),proposedStep:Ct.optional()}),YE=Qn.merge(xr).extend({results:X.lazy(()=>es.array())}),JE=Qn.merge(fo).extend({results:X.lazy(()=>es.array())}),XE=Qn.merge(_n).extend({moduleName:X.string().optional(),results:X.lazy(()=>It.array())}),ZE=Qn.merge(Er).extend({assertion:es.optional(),results:X.lazy(()=>It.array()).describe("results for the block actually executed")}),QE=Qn.merge(Di).extend({results:X.lazy(()=>It.array())}),eC=Qn.merge(Fi).extend({results:X.lazy(()=>It.array()),healingAttempts:X.lazy(()=>It.array().array()).optional()}),It=X.discriminatedUnion("type",[YE,JE,es,XE,ZE,QE,eC]),ts=Qn.pick({startedAt:!0,finishedAt:!0,status:!0,message:!0,data:!0}),ns=Lc.extend({index:X.number().optional(),description:X.string(),pageState:X.string().optional()});var Oc=tC.object({results:It.array().describe("main results"),beforeResults:It.array().optional(),afterResults:It.array().optional()}),rs=Oc.partial();import{z as $}from"zod";import{z as xe}from"zod";var nC=xe.object({type:xe.literal("FAILURE_RECOVERY"),thoughts:xe.string()}),rC=xe.object({type:xe.literal("DESCRIPTION_UPDATE"),thoughts:xe.string()}),os=xe.discriminatedUnion("type",[rC,nC]),is=(e=>(e.AUTO_HEALING="AUTO_HEALING",e))(is||{}),oC=xe.object({testId:xe.string(),name:xe.string(),orgId:xe.string(),runId:xe.string(),purpose:xe.nativeEnum(is).catch("AUTO_HEALING"),steps:Ae.array(),details:os.or(os.array()).optional()}),K0=oC.pick({name:!0,orgId:!0}),kc=xe.object({id:xe.string(),name:xe.string().nullish(),createdAt:xe.string().pipe(xe.coerce.date()).or(xe.date()),organizationId:xe.string(),schemaVersion:xe.string(),purpose:xe.nativeEnum(is).catch("AUTO_HEALING"),runId:xe.string().nullish(),details:os.or(os.array()).nullish(),applied:xe.boolean().nullish(),appliedAt:xe.coerce.date().nullish()}),Lm=kc.extend({steps:Ae.array()});import{isValidCron as iC}from"cron-validator";import{z as oe}from"zod";import{z as Mc}from"zod";var Dn=(r=>(r.CHROMIUM="Chromium",r.GOOGLE_CHROME="Google Chrome",r.CHROME_FOR_TESTING="Chrome for Testing",r))(Dn||{});var as=Mc.object({width:Mc.number().min(200).max(1e4),height:Mc.number().min(200).max(1e4)}),Om={"Desktop Large":{width:1920,height:1080},"Desktop Small":{width:1280,height:800},iPad:{width:768,height:1024},"Pixel 8":{width:448,height:998},"iPhone 15":{width:393,height:852}},X0=Object.keys(Om);var Gt=Om["Desktop Large"],xo="en-US",Eo="America/Los_Angeles";var km=["Africa/Abidjan","Africa/Accra","Africa/Algiers","Africa/Bissau","Africa/Cairo","Africa/Casablanca","Africa/Ceuta","Africa/El_Aaiun","Africa/Johannesburg","Africa/Juba","Africa/Khartoum","Africa/Lagos","Africa/Maputo","Africa/Monrovia","Africa/Nairobi","Africa/Ndjamena","Africa/Sao_Tome","Africa/Tripoli","Africa/Tunis","Africa/Windhoek","America/Adak","America/Anchorage","America/Argentina/Buenos_Aires","America/Argentina/Catamarca","America/Argentina/Cordoba","America/Argentina/Jujuy","America/Argentina/La_Rioja","America/Argentina/Mendoza","America/Argentina/Rio_Gallegos","America/Argentina/Salta","America/Argentina/San_Juan","America/Argentina/San_Luis","America/Argentina/Tucuman","America/Argentina/Ushuaia","America/Araguaina","America/Asuncion","America/Atikokan","America/Bahia","America/Bahia_Banderas","America/Barbados","America/Belem","America/Belize","America/Blanc-Sablon","America/Boa_Vista","America/Bogota","America/Boise","America/Cambridge_Bay","America/Campo_Grande","America/Cancun","America/Caracas","America/Cayenne","America/Chicago","America/Chihuahua","America/Costa_Rica","America/Creston","America/Cuiaba","America/Curacao","America/Danmarkshavn","America/Dawson","America/Dawson_Creek","America/Denver","America/Detroit","America/Dominica","America/Edmonton","America/Eirunepe","America/El_Salvador","America/Fort_Nelson","America/Fortaleza","America/Glace_Bay","America/Goose_Bay","America/Grand_Turk","America/Grenada","America/Guadeloupe","America/Guatemala","America/Guayaquil","America/Guyana","America/Halifax","America/Havana","America/Hermosillo","America/Indiana/Indianapolis","America/Indiana/Knox","America/Indiana/Marengo","America/Indiana/Petersburg","America/Indiana/Tell_City","America/Indiana/Vevay","America/Indiana/Vincennes","America/Indiana/Winamac","America/Inuvik","America/Iqaluit","America/Jamaica","America/Juneau","America/Kentucky/Louisville","America/Kentucky/Monticello","America/La_Paz","America/Lima","America/Los_Angeles","America/Maceio","America/Managua","America/Manaus","America/Marigot","America/Martinique","America/Matamoros","America/Mazatlan","America/Menominee","America/Merida","America/Metlakatla","America/Mexico_City","America/Miquelon","America/Moncton","America/Monterrey","America/Montevideo","America/Montserrat","America/Nassau","America/New_York","America/Nipigon","America/Nome","America/Noronha","America/North_Dakota/Beulah","America/North_Dakota/Center","America/North_Dakota/New_Salem","America/Ojinaga","America/Panama","America/Pangnirtung","America/Paramaribo","America/Phoenix","America/Port-au-Prince","America/Port_of_Spain","America/Porto_Velho","America/Puerto_Rico","America/Punta_Arenas","America/Rainy_River","America/Rankin_Inlet","America/Recife","America/Regina","America/Resolute","America/Rio_Branco","America/Santarem","America/Santiago","America/Santo_Domingo","America/Sao_Paulo","America/Scoresbysund","America/Sitka","America/St_Barthelemy","America/St_Johns","America/St_Kitts","America/St_Lucia","America/St_Thomas","America/St_Vincent","America/Swift_Current","America/Tegucigalpa","America/Thule","America/Thunder_Bay","America/Tijuana","America/Toronto","America/Tortola","America/Vancouver","America/Whitehorse","America/Winnipeg","America/Yakutat","America/Yellowknife","Antarctica/Casey","Antarctica/Davis","Antarctica/DumontDUrville","Antarctica/Macquarie","Antarctica/Mawson","Antarctica/Palmer","Antarctica/Rothera","Antarctica/Syowa","Antarctica/Troll","Antarctica/Vostok","Arctic/Longyearbyen","Asia/Aden","Asia/Almaty","Asia/Amman","Asia/Anadyr","Asia/Aqtau","Asia/Aqtobe","Asia/Ashgabat","Asia/Atyrau","Asia/Baghdad","Asia/Bahrain","Asia/Baku","Asia/Bangkok","Asia/Barnaul","Asia/Beirut","Asia/Bishkek","Asia/Brunei","Asia/Chita","Asia/Choibalsan","Asia/Colombo","Asia/Damascus","Asia/Dhaka","Asia/Dili","Asia/Dubai","Asia/Dushanbe","Asia/Famagusta","Asia/Gaza","Asia/Hebron","Asia/Ho_Chi_Minh","Asia/Hong_Kong","Asia/Hovd","Asia/Irkutsk","Asia/Jakarta","Asia/Jayapura","Asia/Jerusalem","Asia/Kabul","Asia/Kamchatka","Asia/Karachi","Asia/Kathmandu","Asia/Khandyga","Asia/Kolkata","Asia/Krasnoyarsk","Asia/Kuala_Lumpur","Asia/Kuching","Asia/Kuwait","Asia/Macau","Asia/Magadan","Asia/Makassar","Asia/Manila","Asia/Muscat","Asia/Nicosia","Asia/Novokuznetsk","Asia/Novosibirsk","Asia/Omsk","Asia/Oral","Asia/Phnom_Penh","Asia/Pontianak","Asia/Pyongyang","Asia/Qatar","Asia/Qostanay","Asia/Qyzylorda","Asia/Riyadh","Asia/Sakhalin","Asia/Samarkand","Asia/Seoul","Asia/Shanghai","Asia/Singapore","Asia/Srednekolymsk","Asia/Taipei","Asia/Tashkent","Asia/Tbilisi","Asia/Tehran","Asia/Thimphu","Asia/Tokyo","Asia/Tomsk","Asia/Ulaanbaatar","Asia/Urumqi","Asia/Ust-Nera","Asia/Vientiane","Asia/Vladivostok","Asia/Yakutsk","Asia/Yangon","Asia/Yekaterinburg","Asia/Yerevan","Atlantic/Azores","Atlantic/Bermuda","Atlantic/Canary","Atlantic/Cape_Verde","Atlantic/Faroe","Atlantic/Madeira","Atlantic/Reykjavik","Atlantic/South_Georgia","Atlantic/Stanley","Australia/Adelaide","Australia/Brisbane","Australia/Broken_Hill","Australia/Currie","Australia/Darwin","Australia/Eucla","Australia/Hobart","Australia/Lindeman","Australia/Lord_Howe","Australia/Melbourne","Australia/Perth","Australia/Sydney","Europe/Amsterdam","Europe/Andorra","Europe/Astrakhan","Europe/Athens","Europe/Belgrade","Europe/Berlin","Europe/Bratislava","Europe/Brussels","Europe/Bucharest","Europe/Budapest","Europe/Busingen","Europe/Chisinau","Europe/Copenhagen","Europe/Dublin","Europe/Gibraltar","Europe/Guernsey","Europe/Helsinki","Europe/Isle_of_Man","Europe/Istanbul","Europe/Jersey","Europe/Kaliningrad","Europe/Kiev","Europe/Kirov","Europe/Lisbon","Europe/Ljubljana","Europe/London","Europe/Luxembourg","Europe/Madrid","Europe/Malta","Europe/Mariehamn","Europe/Minsk","Europe/Monaco","Europe/Moscow","Europe/Oslo","Europe/Paris","Europe/Podgorica","Europe/Prague","Europe/Riga","Europe/Rome","Europe/Samara","Europe/San_Marino","Europe/Sarajevo","Europe/Saratov","Europe/Simferopol","Europe/Skopje","Europe/Sofia","Europe/Stockholm","Europe/Tallinn","Europe/Tirane","Europe/Ulyanovsk","Europe/Uzhgorod","Europe/Vaduz","Europe/Vatican","Europe/Vienna","Europe/Vilnius","Europe/Volgograd","Europe/Warsaw","Europe/Zagreb","Europe/Zaporozhye","Europe/Zurich","Indian/Antananarivo","Indian/Chagos","Indian/Christmas","Indian/Cocos","Indian/Comoro","Indian/Kerguelen","Indian/Mahe","Indian/Maldives","Indian/Mauritius","Indian/Mayotte","Indian/Reunion","Pacific/Apia","Pacific/Auckland","Pacific/Bougainville","Pacific/Chatham","Pacific/Chuuk","Pacific/Easter","Pacific/Efate","Pacific/Enderbury","Pacific/Fakaofo","Pacific/Fiji","Pacific/Funafuti","Pacific/Galapagos","Pacific/Gambier","Pacific/Guadalcanal","Pacific/Guam","Pacific/Honolulu","Pacific/Kiritimati","Pacific/Kosrae","Pacific/Kwajalein","Pacific/Majuro","Pacific/Marquesas","Pacific/Midway","Pacific/Nauru","Pacific/Niue","Pacific/Norfolk","Pacific/Noumea","Pacific/Pago_Pago","Pacific/Palau","Pacific/Pitcairn","Pacific/Pohnpei","Pacific/Port_Moresby","Pacific/Rarotonga","Pacific/Saipan","Pacific/Tahiti","Pacific/Tarawa","Pacific/Tongatapu","Pacific/Wake","Pacific/Wallis"];var Mm=1e4,Nm=2e3,ss=vo.extend({browserType:oe.nativeEnum(Dn).optional(),slowMoMs:oe.number().optional().refine(n=>n===void 0||n<=Nm&&n>=-1,{message:`Slow motion must be between 0 and ${Nm} milliseconds`}),smartWaitingTimeoutMs:oe.number().optional().refine(n=>n===void 0||n<=Mm&&n>=-1,{message:`Smart waiting timeout must be between 0 and ${Mm/1e3} seconds`}),basicAuthorization:oe.object({username:oe.string().optional(),password:oe.string().optional()}).optional(),disableJavaScript:oe.boolean().optional(),disableGpu:oe.boolean().optional(),locale:oe.string().optional(),timezone:oe.enum(km).optional(),colorScheme:oe.enum(["light","dark"]).optional()}),_m=["extraHeaders","basicAuthorization","localChromeExtensionPaths"],aC=oe.object({disableAICaching:oe.boolean().optional(),failureRecovery:oe.boolean().optional().describe("undefined means inherit org settings")});var sC=oe.object({viewport:as.optional()}),Co=sC.merge(aC).merge(ss),Ro=oe.object({cron:oe.string().refine(n=>iC(n),{message:"Invalid cron expression."}).default("0 0 */1 * *"),enabled:oe.boolean().default(!1),env:oe.string().optional(),timeZone:oe.string().default("America/Los_Angeles"),jobKey:oe.string().optional()}),Ao=oe.object({onSuccess:oe.boolean().default(!1),failureMessage:oe.string().optional(),onFailure:oe.boolean().default(!0),successMessage:oe.string().optional()}),lC=oe.object({name:oe.string(),required:oe.boolean().optional(),defaultValue:oe.string().describe("this is not optional because we need a value when the editor is first loaded")}),ls=lC.array(),cC=oe.object({name:oe.string(),value:oe.string()}),Dm=cC.array(),cs=oe.object({name:oe.string(),default:oe.boolean().optional(),fixtures:Rm.array().optional()});ve($);var Wt={WEBHOOK:"WEBHOOK",CRON:"CRON",MANUAL:"MANUAL",CLI:"CLI"},ie=(s=>(s.PENDING="PENDING",s.RUNNING="RUNNING",s.PASSED="PASSED",s.FAILED="FAILED",s.CANCELLED="CANCELLED",s.RETRYING="RETRYING",s.WAITING_FOR_USER="WAITING_FOR_USER",s))(ie||{}),ds=(t=>(t.BEFORE_ALL="BEFORE_ALL",t.AFTER_ALL="AFTER_ALL",t))(ds||{});var We=$.string().pipe($.coerce.date()).or($.date()),ji=$.object({id:$.string(),runKey:$.string(),organizationId:$.string(),createdAt:We,createdBy:$.string(),flake:$.boolean().nullish(),scheduledAt:We.or($.null()),startedAt:We.or($.null()),updatedAt:We.nullish(),finishedAt:We.or($.null()),resolvedBaseUrl:$.string().nullish(),environmentName:$.string().nullish(),labels:$.array($.string()).optional(),cliVersion:$.string().nullish(),section:$.nativeEnum(ds).nullish(),status:$.nativeEnum(ie),trigger:$.nativeEnum(Wt),attempts:$.number(),runAttempts:$.array($.object({id:$.string(),status:$.nativeEnum(ie),startedAt:We.or($.null()),finishedAt:We.or($.null())})).optional(),videos:$.array($.string()).optional(),failureReason:$.nativeEnum(pe).nullish(),failureDetails:Qa.nullish(),testFragments:$.array(kc).nullish(),localTestId:$.string().nullish(),testId:$.string().nullish(),testName:$.string().nullish(),test:$.object({name:$.string(),id:$.string()}).nullish().default(null),suiteId:$.string().nullish()}).openapi({ref:"RunMetadata"}),dC={id:!0,status:!0,testName:!0,localTestId:!0,testId:!0,test:{select:{name:!0,id:!0}},finishedAt:!0,failureReason:!0,failureDetails:!0},ps=ji.pick({...dC,test:!0}),Fm=ji.omit({failureReason:!0,failureDetails:!0,test:!0}),Nc=ji.extend({stepsSnapshot:$.array($.record($.unknown())).nullish(),resolvedInputs:$.record($.string(),$.string()).nullish(),test:$.object({name:$.string(),id:$.string(),description:$.string().nullish(),baseUrl:$.string().nullish(),advanced:Co.nullish()}).nullish()}).merge(Oc),Um=n=>n.includes("PASSED")&&n.includes("FAILED");var pC=$i.object({id:$i.string().uuid(),startedAt:We.or($i.null()),finishedAt:We.or($i.null()),status:$i.nativeEnum(ie)}).merge(rs),yU=pC.array();var Gi=(o=>(o.JUNIT="junit",o.ALLURE="allure",o.ALLURE_JSON="allure-json",o.PLAYWRIGHT_JSON="playwright-json",o))(Gi||{});import{z as qe}from"zod";var uC=qe.object({id:qe.string(),status:qe.nativeEnum(ie),trigger:qe.nativeEnum(Wt),createdAt:We,startedAt:We.nullish(),finishedAt:We.nullish(),gitCommitSha:qe.string().nullish(),gitCommitShaShort:qe.string().nullish(),gitCommitTimestamp:We.nullish(),gitBranchName:qe.string().nullish(),gitOriginUrl:qe.string().nullish(),gitCommitMessage:qe.string().nullish(),gitCommitAuthorName:qe.string().nullish(),githubRepository:qe.string().nullish(),gitlabProjectPath:qe.string().nullish(),pipelineId:qe.string().nullish(),cliVersion:qe.string().nullish(),suite:qe.object({id:qe.string(),name:qe.string()}).nullish(),runs:qe.object({status:qe.nativeEnum(ie)}).array()}).openapi({ref:"RunGroup"}),Bm=uC.pick({id:!0,createdAt:!0,startedAt:!0,finishedAt:!0,status:!0,trigger:!0,suite:!0}).extend({runs:ps.array()});import{z as Ze}from"zod";var mC=Ze.object({type:Ze.literal("TARGETING"),name:Ze.string().optional().describe("Target name to disambiguate for steps with multiple targets"),elementLocationDecisions:Wu.array(),pageState:Ze.string().optional(),targetSource:Ze.nativeEnum(Jn).optional(),targetUpdateTime:Ze.string().optional()}),hC=Ze.object({type:Ze.literal("AI_LOCATION"),matched:Ze.boolean(),pageState:Ze.string().optional(),ragUsed:Ze.boolean().optional(),thoughts:Ze.string().optional()}),gC=Ze.object({type:Ze.literal("ASSERTION"),relevantElementsSerialized:Ze.string().array().optional(),pageState:Ze.string().optional(),ragUsed:Ze.boolean().optional()}),zm=Ze.discriminatedUnion("type",[mC,hC,gC]);function us(){return{details:[]}}import{z as Be}from"zod";var fC=Be.object({id:Be.string(),name:Be.string()}),kU=fC.merge(Be.object({createdAt:We,createdBy:Be.string(),schedule:Ro,notification:Ao,environment:Be.object({name:Be.string()}).nullish(),beforeTests:Be.object({id:Be.string()}).array().nullish(),afterTests:Be.object({id:Be.string()}).array().nullish()})),Hm=Be.object({id:Be.string().uuid(),orgId:Be.string(),createdAt:We,startedAt:We.or(Be.null()),finishedAt:We.or(Be.null()),status:Be.nativeEnum(ie),trigger:Be.nativeEnum(Wt),suite:Be.object({id:Be.string(),name:Be.string()}).nullish(),runs:ji.array()}),MU=Hm.pick({id:!0,createdAt:!0,startedAt:!0,finishedAt:!0,status:!0,trigger:!0,suite:!0}),jm=Hm.extend({runs:ps.array()});import{z as er}from"zod";import{cloneDeep as FU}from"lodash-es";import{z as ue}from"zod";var jU=ue.object({thoughts:ue.string(),subGoals:ue.object({instruction:ue.string()}).array()}),$U=ue.object({thoughts:ue.string(),newPlanMarkdown:ue.string()}),GU=ue.object({thoughts:ue.string(),correct:ue.boolean(),failedActionIndex:ue.number().optional()}),SC=ue.object({type:ue.literal("PLANNING"),beforePlan:ue.string(),goalDecision:ue.string(),thoughts:ue.string()}),yC=ue.object({type:ue.literal("RUNNING"),stepDisplayName:ue.string(),status:ue.nativeEnum(Te),results:It.array()}),bC=ue.object({type:ue.literal("REVISING"),beforePlan:ue.string(),afterPlan:ue.string(),errString:ue.string(),diffs:ue.string(),thoughts:ue.string()}),wC=ue.object({type:ue.literal("SYSTEM"),message:ue.string()}),vC=ue.discriminatedUnion("type",[SC,yC,bC,wC]),$m=vC.array();var YU=er.object({id:er.string(),scheduledAt:er.coerce.date().nullable(),startedAt:er.coerce.date().nullable(),finishedAt:er.coerce.date().nullable(),status:er.nativeEnum(ie),history:$m.nullable(),testPlan:er.object({name:er.string()})});var Vt=_.object({disableCache:_.boolean().optional(),loggerTags:_.record(_.string(),_.string()).optional(),langfuseSessionId:_.string().optional(),agentConfigVersion:_.string().optional()}),TC=_.object({screenshotBase64AfterCommand:_.string(),urlAfterCommand:_.string(),serializedCommand:_.string(),elementInteracted:_.string().optional(),thoughts:_.string().optional()}),Gm=_.object({goal:_.string(),browserState:_.string(),screenshot:_.string(),source:Gu.optional().catch(void 0)}),Wm=_.object({target:_.string().or(_.number()),browserState:_.string().optional(),screenshot:_.string().optional(),boundingBox:_.object({x:_.number(),y:_.number(),height:_.number(),width:_.number()}).optional()}),Vm=_.object({goal:_.string(),browserState:_.string(),screenshot:_.string().optional(),returnSchema:_.string().optional()}),qm=_.object({goal:_.string(),browserState:_.string(),screenshot:_.string(),url:_.string(),contextChoice:nc.optional()}),Km=_.object({command:ho}),_c=_.object({goal:_.string(),browserState:_.string(),startingScreenshot:_.string().optional(),screenshot:_.string(),url:_.string(),history:TC.array(),actionHint:_.string().optional(),lastError:_.string().optional()}),Ym=_.object({results:ns.array(),errorMessage:_.string(),errorStack:_.string().optional()}),Jm=_.object({results:ns.array(),goal:_.string(),errorMessage:_.string()}),Xm=_.object({failedResults:ns.array(),nextStepsSerialized:_.string().array(),currentUrl:_.string(),currentPageState:_.string(),currentScreenshot:_.string()}),g1=_.object({description:_.string(),type:_.union([_.literal("locator"),_.literal("assertion"),_.literal("ai-action")]),excerpt:_.string()});import{z as Wi}from"zod";var y1=Wi.object({goal:Wi.string()}),Zm=Wi.object({keywords:Wi.array(Wi.string())});import{z as yt}from"zod";var Dc=yt.object({content:yt.string(),ids:yt.string().array(),tokenLength:yt.number()}),xC=yt.object({chunks:Dc.array()}),v1=yt.object({ids:yt.string().array(),score:yt.number(),tokenLength:yt.number()}),T1=xC.extend({description:yt.string().describe("Input to pass to RAG engine"),tokenLimit:yt.number()}),Qm=yt.object({ids:yt.number().array()}),eh=yt.object({indices:yt.number().array()});import{z as Fc}from"zod";var Uc=(t=>(t.LOCATOR="locator",t.ASSERTION="assertion",t))(Uc||{}),C1=Fc.nativeEnum(Uc),EC=Fc.enum(["v1","v2"]),R1=EC.or(Fc.string().describe("for people with special configurations"));var th=n=>!(!n.org_id||!n.user_id||!n.platform);import{z as Pr}from"zod";var nh=Pr.object({id:Pr.string().uuid(),skipped:Pr.boolean().optional(),envKey:Pr.string().optional().describe("key in the environment to save the result of this step to")}),Bc=nh.merge(Na).extend({type:Pr.literal("REQUEST")}),zc=nh.merge(_a).extend({type:Pr.literal("JAVASCRIPT")}),Hc=Pr.discriminatedUnion("type",[zc,Bc]);import{z as qt}from"zod";import{z as Lr}from"zod";var CC=/^[a-f0-9]{8}-[a-f0-9]{4}-[1-5][a-f0-9]{3}-[89ab][a-f0-9]{3}-[a-f0-9]{12}$/,Ne=n=>{let e=n.trim().toLowerCase().replace(/[^a-z0-9]/g,"-");for(;e.includes("--");)e=e.replaceAll("--","-");return e.startsWith("-")&&(e=e.slice(1)),e.endsWith("-")&&(e=e.slice(0,e.length-1)),e};var ms=Lr.string().min(1).max(255).superRefine((n,e)=>{try{Io(n)}catch(t){return e.addIssue({code:Lr.ZodIssueCode.custom,message:t.message,fatal:!0}),Lr.NEVER}});function Io(n){if(n=n.toLowerCase().trim(),n.length===0||n.length>255)throw new Error("Name must be between 1 and 255 characters long");if(/[<>:"/\\|?*]/.test(n))throw new Error('Name contains one of the following invalid characters: <>:"/\\|?*');if(n.endsWith("-")||n.startsWith("-"))throw new Error("Name cannot start or end with a dash.");if(n.includes("\0"))throw new Error("Name cannot contain null characters");if(/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i.test(n))throw new Error(`"${n}" is a reserved name on Windows and cannot be used as a filename.`);if(/^\.+$/.test(n)||/^\s|\s$/.test(n))throw new Error("Name cannot start or end with a space or dot.");if(n.endsWith(".yaml"))throw new Error('Name cannot end with ".yaml".');if(n==="none")throw new Error("Name cannot be 'none'.");if(n.match(CC))throw new Error("Name cannot be a UUID. Please choose a different name.")}var hs=Lr.preprocess(n=>n===null?"":n,Lr.union([Lr.string().url(),Lr.literal("")])).optional();var rh=qt.object({id:qt.string(),name:ms,description:qt.string().optional().nullish(),baseUrl:hs.nullish(),schemaVersion:qt.string(),advanced:qt.unknown().optional(),retries:qt.number(),envs:qt.array(cs).nullish(),parameters:ls.nullish()}),RC=qt.object({createdAt:qt.coerce.date(),updatedAt:qt.coerce.date(),schedule:Ro.nullish(),notification:Ao.nullish(),createdBy:qt.string(),organizationId:qt.string()}),AC=rh.merge(RC),q1=AC.extend({steps:Hc.array()}),K1=rh.extend({steps:Hc.array()});import{z as Pt}from"zod";var oh=Pt.object({startedAt:Pt.coerce.date(),finishedAt:Pt.coerce.date(),status:Pt.nativeEnum(Te),message:Pt.string().optional(),data:Pt.unknown().optional()}),PC=oh.merge(zc).extend({type:Pt.literal("JAVASCRIPT")}),LC=oh.merge(Bc).extend({type:Pt.literal("REQUEST")}),OC=Pt.discriminatedUnion("type",[PC,LC]),ih=Pt.object({startedAt:Pt.coerce.date(),finishedAt:Pt.coerce.date().nullish(),status:Pt.nativeEnum(ie),results:OC.array(),failureReason:Pt.string().nullish(),failureDetails:Qa.nullish()});import{z as Lt}from"zod";var kC=Lt.object({id:Lt.string(),organizationId:Lt.string(),createdAt:Lt.coerce.date(),updatedAt:Lt.coerce.date(),createdBy:Lt.string(),scheduledAt:Lt.coerce.date().nullish(),startedAt:Lt.coerce.date().nullish(),finishedAt:Lt.coerce.date().nullish(),status:Lt.nativeEnum(ie),trigger:Lt.nativeEnum(Wt),results:ih.array().nullish(),apiTestName:Lt.string().nullish(),apiTestPath:Lt.string().nullish(),apiTestId:Lt.string().nullish()}),rB=kC.pick({status:!0,startedAt:!0,finishedAt:!0});var Vi=(t=>(t.TestRun="test-run",t.CreditsUsed="credits-used",t))(Vi||{}),ah=3;function MC(n){return n==="MODULE"||n==="IFRAME"||n==="CONDITIONAL"||n==="SECTION"||n==="RESOLVED_MODULE"}function qi(n){if(!MC(n))switch(n){case"PRESET_ACTION":return 0;case"AI_ACTION":return 3;case"AI_ACTION_DYNAMIC":return 5;default:(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}function Ki(n){switch(n.type){case"AI_EXTRACT":case"AI_ASSERTION":return ah;case"CAPTCHA":return 3;case"CLICK":case"TYPE":case"SELECT_OPTION":case"HOVER":case"ELEMENT_CHECK":case"FOCUS":case"BLUR":case"SCROLL_DOWN":case"SCROLL_LEFT":case"SCROLL_RIGHT":case"SCROLL_UP":return n.useSelector||!n.target||n.target.type!=="description"?0:1;case"DRAG":case"MOUSE_DRAG":return n.useSelector?0:1;case"VISUAL_DIFF":case"TAB":case"JAVASCRIPT":case"NAVIGATE":case"WAIT":case"SUCCESS":case"AUTH_LOAD":case"AUTH_SAVE":case"COOKIE":case"DIALOG":case"FILE_UPLOAD":case"GO_BACK":case"GO_FORWARD":case"LOCAL_STORAGE":case"NEW_TAB":case"PAGE_CHECK":case"PRESS":case"COPY":case"PASTE":case"REFRESH":case"REQUEST":case"GRAPHQL_REQUEST":case"WAIT_FOR_URL":case"REGISTER_REQUEST_LISTENER":case"AWAIT_LISTENER":return 0;default:(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}var Po=class{async reportBillableEvent(e,t,r){}async reportCreditsUsed(e,t,r,o){}};function jc(n,e){return{...n,testId:e?.testId??"",testName:e?.testName??"",suiteId:e?.suiteId??"",suiteName:e?.suiteName??""}}import{parseString as NC,splitCookiesString as _C}from"set-cookie-parser";import{z as he}from"zod";var $c=he.object({name:he.string(),value:he.string(),url:he.string().optional(),domain:he.string().optional(),path:he.string().optional(),expires:he.number().default(Date.now()/1e3+60*60*24*365),httpOnly:he.boolean().optional(),secure:he.boolean().default(!0),sameSite:he.union([he.literal("Strict"),he.literal("Lax"),he.literal("None")]).default("None")});function gs(n,e){let t=[],r=_C(n);for(let o of r){let i=NC(o,{decodeValues:!1});if(!i.name)throw new Error("Name missing from cookie");if(!i.value)continue;let a;if(i.sameSite){let d=i.sameSite.trim().toLowerCase();if(d==="strict")a="Strict";else if(d==="lax")a="Lax";else if(d==="none")a="None";else throw new Error(`Invalid sameSite setting in cookie: ${d}`)}i.httpOnly===void 0&&(i.httpOnly=!1),!i.path&&i.domain&&(i.path="/"),!i.domain&&e&&(i.domain=e);let s=$c.parse({...i,expires:i.expires?i.expires.getTime()/1e3:void 0,sameSite:a});t.push(s);let l=[s.name,...Object.keys(s)].map(d=>d.toLowerCase()),c=o.match(/\b(\S+)=([^;]*)/g);if(c)for(let d of c){let[p,m]=d.split("=");if(!p||!m)throw new Error(`Invalid key-value pair in cookie: ${d}`);l.includes(p.toLowerCase())||t.push({...s,name:p,value:m})}}return t}var DC=he.object({origin:he.string(),localStorage:he.array(he.object({name:he.string(),value:he.string()}))}),FC=he.object({entries:he.record(he.string(),he.array(he.tuple([he.unknown(),he.unknown()]))),version:he.number().optional()}),fs=he.object({cookies:$c.array().optional(),origins:DC.array().optional(),idb:he.record(he.string(),FC).optional().describe("key is db name")});function Ss(n,e){let t=[];return n.cloneSync()?.serializeSync()?.cookies.forEach(r=>{let o=$c.safeParse({name:r.key,...r});if(!o.success)return;let i=o.data;!i.domain&&!i.url&&(i.domain=e),t.push(i)}),t}var CB=new Set(Object.values(Ue));var UC={AI_ACTION:"AI action",AI_ACTION_DYNAMIC:"AI action",RESOLVED_MODULE:"Module",AI_ASSERTION:"AI check",AI_EXTRACT:"AI extract",CLICK:"Click",TYPE:"Type",JAVASCRIPT:"JavaScript",SELECT_OPTION:"Select",PRESS:"Press",NAVIGATE:"Navigate",SCROLL_UP:"Scroll up",SCROLL_DOWN:"Scroll down",SCROLL_LEFT:"Scroll left",SCROLL_RIGHT:"Scroll right",HOVER:"Hover",BLUR:"Blur",FILE_UPLOAD:"File upload",FOCUS:"Focus",GO_BACK:"Go back",GO_FORWARD:"Go forward",WAIT:"Wait",REFRESH:"Refresh",TAB:"Switch tab",NEW_TAB:"New tab",COOKIE:"Cookie",LOCAL_STORAGE:"Local storage",REQUEST:"API request",GRAPHQL_REQUEST:"GraphQL request",CAPTCHA:"CAPTCHA",DRAG:"Drag & drop",VISUAL_DIFF:"Visual diff",DIALOG:"Dialog",MOUSE_DRAG:"Mouse drag",AUTH_LOAD:"Load auth state",AUTH_SAVE:"Save auth state",ELEMENT_CHECK:"Element check",PAGE_CHECK:"Page check",WAIT_FOR_URL:"Wait for URL",COPY:"Copy",PASTE:"Paste",REGISTER_REQUEST_LISTENER:"Register request listener",AWAIT_LISTENER:"Await listener",SUCCESS:"Done"},RB={AI_ACTION:["ai","action","agent"],AI_ACTION_DYNAMIC:["ai","action","dynamic","agent"],RESOLVED_MODULE:[],AI_ASSERTION:["ai","check","assert","make sure","ensure"],AI_EXTRACT:["ai","extract","data"],CLICK:["click","press"],TYPE:["type","input","write","press"],JAVASCRIPT:["js","javascript","code","execute"],SELECT_OPTION:["select","option","choose"],PRESS:["keyboard","type","key"],NAVIGATE:["go to","visit"],SCROLL_UP:[],SCROLL_DOWN:[],SCROLL_LEFT:[],SCROLL_RIGHT:[],HOVER:["scroll into view","go to"],BLUR:[],FILE_UPLOAD:[],FOCUS:[],GO_BACK:[],GO_FORWARD:[],WAIT:[],REFRESH:[],TAB:[],NEW_TAB:[],COOKIE:[],LOCAL_STORAGE:[],REQUEST:[],GRAPHQL_REQUEST:[],CAPTCHA:[],DRAG:[],VISUAL_DIFF:[],DIALOG:[],MOUSE_DRAG:[],AUTH_LOAD:[],AUTH_SAVE:[],ELEMENT_CHECK:[],PAGE_CHECK:[],WAIT_FOR_URL:[],COPY:[],PASTE:[],REGISTER_REQUEST_LISTENER:[],AWAIT_LISTENER:[],SUCCESS:[]},AB={AI_ACTION:"Ask AI achieve a specific goal. Caches the steps for reuse. Please use Dynamic AI action instead.",AI_ACTION_DYNAMIC:"Ask AI achieve a specific goal. Fully dynamic. Our most capable AI agent.",RESOLVED_MODULE:"A list of steps that can be reused in multiple tests.",AI_ASSERTION:"Ask AI whether something is true on the page, retrying until a configurable timeout.",CLICK:"Click on an element on the page based on a description.",DIALOG:"Specify how native browser dialogs should be handled.",AI_EXTRACT:"Ask AI to extract data from the page based on a description.",HOVER:"Hover over an element on the page based on a description.",FILE_UPLOAD:"Automatically upload a file when the next file chooser is activated.",FOCUS:"Focus an element on the page based on a description.",BLUR:"Remove focus from an element on the page based on a description.",SELECT_OPTION:"Select an option from an HTML Select <select> element based on a description.",TYPE:"Type the specified text into an element.",PRESS:"Press the specified keys using the keyboard. (e.g. Control+A)",NAVIGATE:"Navigate to the specified URL.",SCROLL_UP:"Scroll up by a specified height.",SCROLL_DOWN:"Scroll down by a specified height.",SCROLL_LEFT:"Scroll left by a specified width.",SCROLL_RIGHT:"Scroll right by a specified width.",GO_BACK:"Go back in browser history.",GO_FORWARD:"Go forward in browser history.",WAIT:"Wait for the specified number of seconds.",REFRESH:"Refresh the page. This will not clear cookies or session data.",TAB:"Switch to different tab in the browser.",NEW_TAB:"Create and switch to a new tab in the browser.",COOKIE:"Set a cookie that will persist throughout the browser session",LOCAL_STORAGE:"Set a local storage value that will persist throughout the browser session",CAPTCHA:"Solve CAPTCHAs on the page. This feature is only available on Momentic Cloud and may take up to 60 seconds. Disabling CAPTCHAs in non-production environments is strongly advised.",REQUEST:"Make an API request to a URL.",GRAPHQL_REQUEST:"Make a GraphQL request to a URL.",JAVASCRIPT:"Run JavaScript code.",DRAG:"Click and drag an element to another location.",VISUAL_DIFF:"Compare a screenshot of the page or a specific element to a baseline image.",MOUSE_DRAG:"Click and drag the mouse by a specified distance.",AUTH_LOAD:"Load or clear session state using a JSON snapshot including cookies, local storage, and IndexDB entries.",AUTH_SAVE:"Save auth state (cookies, local storage) into a JavaScript object format usable by 'Load auth state'.",ELEMENT_CHECK:"Assert on an element's state using pre-built conditions, including content, visibility, attribute value checks.",PAGE_CHECK:"Assert on the active page's state using pre-built conditions, including URL and content checks.",WAIT_FOR_URL:"Wait for the active page's URL to match a specific URL or glob pattern. If a new tab is opened, this command will wait for the new tab's URL to match instead.",COPY:"Copy the specified value to the browser clipboard.",PASTE:"Paste the clipboard contents.",REGISTER_REQUEST_LISTENER:"Register a listener for network requests.",AWAIT_LISTENER:"Wait for a listener to fire, and return the response data.",SUCCESS:"Indicate the entire AI action has succeeded, optionally based on a condition."};import{Faker as LB,en as OB}from"@faker-js/faker";import{z as G}from"zod";var sh=55555,_B=G.object({body:G.string(),to:G.string(),from:G.string()}),DB=G.object({from:G.string().optional(),to:G.string(),timeout:G.number().optional(),beforeDate:G.string().pipe(G.coerce.date()).or(G.date()).optional(),afterDate:G.string().pipe(G.coerce.date()).or(G.date()).optional()}),FB=G.object({to:G.string(),from:G.string(),subject:G.string(),body:G.string()}),UB=G.object({inbox:G.string(),afterDate:G.string().pipe(G.coerce.date()).or(G.date()).optional(),timeout:G.number().optional(),trimWhitespace:G.boolean().optional()}),BB=G.object({inbox:G.string(),limit:G.number().optional(),afterDate:G.string().pipe(G.coerce.date()).or(G.date()).optional(),trimWhitespace:G.boolean().optional()});var lh=G.object({result:G.unknown(),variableUpdates:G.record(G.string(),G.unknown()).optional(),persistentVariableUpdates:G.record(G.string(),G.unknown()).optional(),error:G.string().optional(),success:G.boolean()}),zB=G.object({id:G.string().optional(),orgId:G.string(),momenticLambdaAuthHash:G.string(),code:G.string(),fragment:G.boolean(),state:Hi,timeoutMs:G.number().optional()}),tr=15e3;import*as ut from"zod";ve(ut);var BC=ut.object({url:ut.string(),lineNumber:ut.number(),columnNumber:ut.number()}).openapi({ref:"CodeLocation"}),ys=ut.object({timestamp:ut.number(),text:ut.string(),type:ut.string(),tabIndex:ut.number(),args:ut.unknown().array().optional(),url:ut.string().optional(),location:BC.optional()}).openapi({ref:"ConsoleLog"}),ch=ys.array(),zC=ch.array();import*as Wc from"zod";import{z as I}from"zod";var HC=I.object({name:I.string(),version:I.string(),comment:I.string().optional()}),jC=I.object({name:I.string(),version:I.string(),comment:I.string().optional()}),$C=I.object({onContentLoad:I.number().optional(),onLoad:I.number().optional(),comment:I.string().optional()}),ph=I.object({startedDateTime:I.string(),id:I.string(),title:I.string().optional(),pageTimings:$C,comment:I.string().optional()}),GC=I.array(ph),WC=I.object({name:I.string(),value:I.string(),path:I.string().optional(),domain:I.string().optional(),expires:I.string().optional(),httpOnly:I.boolean().optional(),secure:I.boolean().optional(),comment:I.string().optional()}),uh=I.array(WC),VC=I.object({name:I.string(),value:I.string(),comment:I.string().optional()}),mh=I.array(VC),qC=I.object({name:I.string(),value:I.string(),comment:I.string().optional()}),KC=I.array(qC),YC=I.object({name:I.string(),value:I.string().optional(),fileName:I.string().optional(),contentType:I.string().optional(),comment:I.string().optional()}),JC=I.array(YC),XC=I.object({mimeType:I.string(),params:JC,text:I.string(),comment:I.string().optional()}),ZC=I.object({method:I.string(),url:I.string(),httpVersion:I.string().optional(),cookies:uh,headers:mh,queryString:KC,postData:XC.optional(),headersSize:I.number().optional(),bodySize:I.number().optional(),comment:I.string().optional()}),QC=I.object({size:I.number().optional(),compression:I.number().optional(),mimeType:I.string().optional(),text:I.string().optional(),encoding:I.string().optional(),comment:I.string().optional()}),eR=I.object({status:I.number(),statusText:I.string(),httpVersion:I.string().optional(),cookies:uh,headers:mh,content:QC,redirectURL:I.string().optional(),headersSize:I.number().optional(),bodySize:I.number().optional(),comment:I.string().optional()}),dh=I.object({expires:I.string().optional(),lastAccess:I.string(),eTag:I.string(),hitCount:I.number(),comment:I.string().optional()}),tR=I.object({beforeRequest:dh.optional(),afterRequest:dh.optional(),comment:I.string().optional()}),nR=I.object({blocked:I.number().optional(),dns:I.number().optional(),connect:I.number().optional(),send:I.number(),wait:I.number(),receive:I.number(),ssl:I.number().optional(),comment:I.string().optional()}),hh=I.object({pageref:I.string().optional(),startedDateTime:I.string(),time:I.number().optional(),request:ZC,response:eR.optional(),cache:tR.optional(),timings:nR,serverIPAddress:I.string().optional(),connection:I.string().optional(),comment:I.string().optional(),_resourceType:I.string().optional()}),rR=I.array(hh),oR=I.object({version:I.string().default("1.1"),creator:HC.optional(),browser:jC.optional(),pages:GC.optional(),entries:rR,comment:I.string().optional()}),iR=I.object({log:oR}),gh=I.record(I.string(),ph),fh=I.record(I.string(),hh);function Gc(n,e){return{log:{version:"1.2",creator:{name:"Momentic, Inc.",version:"1.0.0"},pages:Object.values(n).sort((t,r)=>new Date(t.startedDateTime).getTime()-new Date(r.startedDateTime).getTime()),entries:Object.values(e).sort((t,r)=>new Date(t.startedDateTime).getTime()-new Date(r.startedDateTime).getTime())}}}ve(Wc);var aR=Wc.object({logsPerPage:ys.array().array(),harPages:gh.optional(),harEntries:fh.optional()}).openapi({ref:"DebugData"});var Or=class{async getConsoleLogsForRunAttempt(e,t,r){}async getNetworkLogsForRunAttempt(e,t,r){}async getHtmlSnapshot(e,t){}async getA11yTreeSnapshot(e,t){}async getScreenshot(e,t){}async storeConsoleLogsForRunAttempt(e,t,r,o){}async storeNetworkLogsForRunAttempt(e,t,r,o){}async storeScreenshot(e,t,r){}async storeHtmlSnapshot(e,t,r){}};var bs=class extends Error{constructor(e,t,r,o={}){super(`The ${r} with id ${t} is invalid: ${e}`,o),this.name="InvalidEntityError"}};function Sh(n){for(let e of Object.values(pe))if(n.includes(e))return e}var R=class extends Error{reason;constructor(e,t,r){let o=!1;for(let i of Object.values(pe))if(t.startsWith(i)){o=!0,e=i;break}if(r?.errOptions?.cause)super(o?t:`${e}: ${t}`,r?.errOptions);else{let i=o?t:`${e}${t?`: ${t}`:""}`;super(i,r?.errOptions)}this.name="TestFailureError",this.stack=this.stack?.slice(this.name.length+2),this.reason=e,Object.defineProperty(this,"lastScreenshotBuffer",{value:r?.lastScreenshotBuffer,enumerable:!1})}getLastScreenshotBuffer(){return"lastScreenshotBuffer"in this?this.lastScreenshotBuffer:void 0}toString(){return this.message}toJSON(){return{message:this.message}}},nr=class extends Error{decisions;constructor(e,t,r={}){super(e,r),this.decisions=t,this.name="NoElementsFoundError"}toString(){return`${this.message}
8
8
  Decisions:
9
9
  ${this.decisions.map(e=>e.toString()).join(`
10
- `)}`}};function yh(n){return n instanceof Error?n.message.includes("Timeout")&&n.message.includes("exceeded")&&n.message.includes("waiting for locator"):!1}function Vc(n){return!(n instanceof Error)||n.message.includes("locator resolved to visible")?!1:!!(n.message.includes("Timeout")&&n.message.includes("exceeded")&&n.message.includes("body >")||n.message.includes("Element is not attached to the DOM"))}function Ji(n){return n instanceof Error?n.message.includes("Timeout")&&n.message.includes("exceeded")&&n.message.includes("waiting for locator")&&n.message.includes("data-momentic-id")&&!n.message.includes("locator resolved")&&!n.message.includes("waiting for element to be"):!1}var Yi=class extends Error{constructor(e,t={}){super(e,t),this.name="InsufficientCssDataError"}};import{cloneDeep as sR}from"lodash-es";import{z as vn}from"zod";var Dt=(p=>(p.AutoExpandIframes="auto_expand_iframes",p.DisableSecondaryCacheResolution="disable_secondary_cache_resolution",p.FakerConstantSeed="faker_constant_seed",p.ShowZeroOpacityElements="show_zero_opacity_elements",p.GlobalLocatorRedirect="global_locator_redirect",p.IconKnowledgeBase="icon_knowledge_base",p.MiniModelInitialAssertion="mini_model_initial_assertion",p.MiniModelInitialLocator="mini_model_initial_locator",p.ShowTestPlans="show_test_plans",p.RagV2="rag_v2",p.VisualActions="visual_actions",p))(Dt||{});var bh=vn.union([vn.string(),vn.number(),vn.boolean(),vn.null(),vn.record(vn.string(),vn.lazy(()=>bh)),vn.array(vn.lazy(()=>bh))]),Xi=class{flags;payloads;constructor(e,t){this.flags=e,this.payloads=t}isBooleanFlagEnabled(e){return process.env&&process.env[`MOMENTIC_FLAG_OVERRIDE_${e.toUpperCase()}`]==="true"?!0:process.env&&process.env[`MOMENTIC_FLAG_OVERRIDE_${e.toUpperCase()}`]==="false"?!1:this.flags[e]===!0}getAllFlags(){let e=sR(this.flags);return Object.entries(e).forEach(([t,r])=>{typeof r=="boolean"&&Object.values(Dt).includes(t)&&(e[t]=this.isBooleanFlagEnabled(t))}),e}getFlagPayload(e){let t=this.payloads[e];if(t!==void 0){if(typeof t=="string")try{return JSON.parse(t)}catch{return t}return t}}refresh(){throw new Error("Not implemented")}},Iz=new Xi({},{});var qc={".123":"application/vnd.lotus-1-2-3",".3dml":"text/vnd.in3d.3dml",".3g2":"video/3gpp2",".3gp":"video/3gpp",".a":"application/octet-stream",".aab":"application/x-authorware-bin",".aac":"audio/x-aac",".aam":"application/x-authorware-map",".aas":"application/x-authorware-seg",".abw":"application/x-abiword",".acc":"application/vnd.americandynamics.acc",".ace":"application/x-ace-compressed",".acu":"application/vnd.acucobol",".acutc":"application/vnd.acucorp",".adp":"audio/adpcm",".aep":"application/vnd.audiograph",".afm":"application/x-font-type1",".afp":"application/vnd.ibm.modcap",".ai":"application/postscript",".aif":"audio/x-aiff",".aifc":"audio/x-aiff",".aiff":"audio/x-aiff",".air":"application/vnd.adobe.air-application-installer-package+zip",".ami":"application/vnd.amiga.ami",".apk":"application/vnd.android.package-archive",".application":"application/x-ms-application",".apr":"application/vnd.lotus-approach",".asc":"application/pgp-signature",".asf":"video/x-ms-asf",".asm":"text/x-asm",".aso":"application/vnd.accpac.simply.aso",".asx":"video/x-ms-asf",".atc":"application/vnd.acucorp",".atom":"application/atom+xml",".atomcat":"application/atomcat+xml",".atomsvc":"application/atomsvc+xml",".atx":"application/vnd.antix.game-component",".au":"audio/basic",".avi":"video/x-msvideo",".aw":"application/applixware",".azf":"application/vnd.airzip.filesecure.azf",".azs":"application/vnd.airzip.filesecure.azs",".azw":"application/vnd.amazon.ebook",".bat":"application/x-msdownload",".bcpio":"application/x-bcpio",".bdf":"application/x-font-bdf",".bdm":"application/vnd.syncml.dm+wbxml",".bh2":"application/vnd.fujitsu.oasysprs",".bin":"application/octet-stream",".bmi":"application/vnd.bmi",".bmp":"image/bmp",".book":"application/vnd.framemaker",".box":"application/vnd.previewsystems.box",".boz":"application/x-bzip2",".bpk":"application/octet-stream",".btif":"image/prs.btif",".bz":"application/x-bzip",".bz2":"application/x-bzip2",".c":"text/x-c",".c4d":"application/vnd.clonk.c4group",".c4f":"application/vnd.clonk.c4group",".c4g":"application/vnd.clonk.c4group",".c4p":"application/vnd.clonk.c4group",".c4u":"application/vnd.clonk.c4group",".cab":"application/vnd.ms-cab-compressed",".car":"application/vnd.curl.car",".cat":"application/vnd.ms-pki.seccat",".cc":"text/x-c",".cct":"application/x-director",".ccxml":"application/ccxml+xml",".cdbcmsg":"application/vnd.contact.cmsg",".cdf":"application/x-netcdf",".cdkey":"application/vnd.mediastation.cdkey",".cdx":"chemical/x-cdx",".cdxml":"application/vnd.chemdraw+xml",".cdy":"application/vnd.cinderella",".cer":"application/pkix-cert",".cgm":"image/cgm",".chat":"application/x-chat",".chm":"application/vnd.ms-htmlhelp",".chrt":"application/vnd.kde.kchart",".cif":"chemical/x-cif",".cii":"application/vnd.anser-web-certificate-issue-initiation",".cil":"application/vnd.ms-artgalry",".cla":"application/vnd.claymore",".class":"application/java-vm",".clkk":"application/vnd.crick.clicker.keyboard",".clkp":"application/vnd.crick.clicker.palette",".clkt":"application/vnd.crick.clicker.template",".clkw":"application/vnd.crick.clicker.wordbank",".clkx":"application/vnd.crick.clicker",".clp":"application/x-msclip",".cmc":"application/vnd.cosmocaller",".cmdf":"chemical/x-cmdf",".cml":"chemical/x-cml",".cmp":"application/vnd.yellowriver-custom-menu",".cmx":"image/x-cmx",".cod":"application/vnd.rim.cod",".com":"application/x-msdownload",".conf":"text/plain",".cpio":"application/x-cpio",".cpp":"text/x-c",".cpt":"application/mac-compactpro",".crd":"application/x-mscardfile",".crl":"application/pkix-crl",".crt":"application/x-x509-ca-cert",".csh":"application/x-csh",".csml":"chemical/x-csml",".csp":"application/vnd.commonspace",".css":"text/css",".cst":"application/x-director",".csv":"text/csv",".cu":"application/cu-seeme",".curl":"text/vnd.curl",".cww":"application/prs.cww",".cxt":"application/x-director",".cxx":"text/x-c",".daf":"application/vnd.mobius.daf",".dataless":"application/vnd.fdsn.seed",".davmount":"application/davmount+xml",".dcr":"application/x-director",".dcurl":"text/vnd.curl.dcurl",".dd2":"application/vnd.oma.dd2+xml",".ddd":"application/vnd.fujixerox.ddd",".deb":"application/x-debian-package",".def":"text/plain",".deploy":"application/octet-stream",".der":"application/x-x509-ca-cert",".dfac":"application/vnd.dreamfactory",".dic":"text/x-c",".diff":"text/plain",".dir":"application/x-director",".dis":"application/vnd.mobius.dis",".dist":"application/octet-stream",".distz":"application/octet-stream",".djv":"image/vnd.djvu",".djvu":"image/vnd.djvu",".dll":"application/x-msdownload",".dmg":"application/octet-stream",".dms":"application/octet-stream",".dna":"application/vnd.dna",".doc":"application/msword",".docm":"application/vnd.ms-word.document.macroenabled.12",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".dot":"application/msword",".dotm":"application/vnd.ms-word.template.macroenabled.12",".dotx":"application/vnd.openxmlformats-officedocument.wordprocessingml.template",".dp":"application/vnd.osgi.dp",".dpg":"application/vnd.dpgraph",".dsc":"text/prs.lines.tag",".dtb":"application/x-dtbook+xml",".dtd":"application/xml-dtd",".dts":"audio/vnd.dts",".dtshd":"audio/vnd.dts.hd",".dump":"application/octet-stream",".dvi":"application/x-dvi",".dwf":"model/vnd.dwf",".dwg":"image/vnd.dwg",".dxf":"image/vnd.dxf",".dxp":"application/vnd.spotfire.dxp",".dxr":"application/x-director",".ecelp4800":"audio/vnd.nuera.ecelp4800",".ecelp7470":"audio/vnd.nuera.ecelp7470",".ecelp9600":"audio/vnd.nuera.ecelp9600",".ecma":"application/ecmascript",".edm":"application/vnd.novadigm.edm",".edx":"application/vnd.novadigm.edx",".efif":"application/vnd.picsel",".ei6":"application/vnd.pg.osasli",".elc":"application/octet-stream",".eml":"message/rfc822",".emma":"application/emma+xml",".eol":"audio/vnd.digital-winds",".eot":"application/vnd.ms-fontobject",".eps":"application/postscript",".epub":"application/epub+zip",".es3":"application/vnd.eszigno3+xml",".esf":"application/vnd.epson.esf",".et3":"application/vnd.eszigno3+xml",".etx":"text/x-setext",".exe":"application/x-msdownload",".ext":"application/vnd.novadigm.ext",".ez":"application/andrew-inset",".ez2":"application/vnd.ezpix-album",".ez3":"application/vnd.ezpix-package",".f":"text/x-fortran",".f4v":"video/x-f4v",".f77":"text/x-fortran",".f90":"text/x-fortran",".fbs":"image/vnd.fastbidsheet",".fdf":"application/vnd.fdf",".fe_launch":"application/vnd.denovo.fcselayout-link",".fg5":"application/vnd.fujitsu.oasysgp",".fgd":"application/x-director",".fh":"image/x-freehand",".fh4":"image/x-freehand",".fh5":"image/x-freehand",".fh7":"image/x-freehand",".fhc":"image/x-freehand",".fig":"application/x-xfig",".fli":"video/x-fli",".flo":"application/vnd.micrografx.flo",".flv":"video/x-flv",".flw":"application/vnd.kde.kivio",".flx":"text/vnd.fmi.flexstor",".fly":"text/vnd.fly",".fm":"application/vnd.framemaker",".fnc":"application/vnd.frogans.fnc",".for":"text/x-fortran",".fpx":"image/vnd.fpx",".frame":"application/vnd.framemaker",".fsc":"application/vnd.fsc.weblaunch",".fst":"image/vnd.fst",".ftc":"application/vnd.fluxtime.clip",".fti":"application/vnd.anser-web-funds-transfer-initiation",".fvt":"video/vnd.fvt",".fzs":"application/vnd.fuzzysheet",".g3":"image/g3fax",".gac":"application/vnd.groove-account",".gdl":"model/vnd.gdl",".geo":"application/vnd.dynageo",".gex":"application/vnd.geometry-explorer",".ggb":"application/vnd.geogebra.file",".ggt":"application/vnd.geogebra.tool",".ghf":"application/vnd.groove-help",".gif":"image/gif",".gim":"application/vnd.groove-identity-message",".gmx":"application/vnd.gmx",".gnumeric":"application/x-gnumeric",".gph":"application/vnd.flographit",".gqf":"application/vnd.grafeq",".gqs":"application/vnd.grafeq",".gram":"application/srgs",".gre":"application/vnd.geometry-explorer",".grv":"application/vnd.groove-injector",".grxml":"application/srgs+xml",".gsf":"application/x-font-ghostscript",".gtar":"application/x-gtar",".gtm":"application/vnd.groove-tool-message",".gtw":"model/vnd.gtw",".gv":"text/vnd.graphviz",".gz":"application/x-gzip",".h":"text/x-c",".h261":"video/h261",".h263":"video/h263",".h264":"video/h264",".hbci":"application/vnd.hbci",".hdf":"application/x-hdf",".hh":"text/x-c",".hlp":"application/winhlp",".hpgl":"application/vnd.hp-hpgl",".hpid":"application/vnd.hp-hpid",".hps":"application/vnd.hp-hps",".hqx":"application/mac-binhex40",".htke":"application/vnd.kenameaapp",".htm":"text/html",".html":"text/html",".hvd":"application/vnd.yamaha.hv-dic",".hvp":"application/vnd.yamaha.hv-voice",".hvs":"application/vnd.yamaha.hv-script",".icc":"application/vnd.iccprofile",".ice":"x-conference/x-cooltalk",".icm":"application/vnd.iccprofile",".ico":"image/x-icon",".ics":"text/calendar",".ief":"image/ief",".ifb":"text/calendar",".ifm":"application/vnd.shana.informed.formdata",".iges":"model/iges",".igl":"application/vnd.igloader",".igs":"model/iges",".igx":"application/vnd.micrografx.igx",".iif":"application/vnd.shana.informed.interchange",".imp":"application/vnd.accpac.simply.imp",".ims":"application/vnd.ms-ims",".in":"text/plain",".ipk":"application/vnd.shana.informed.package",".irm":"application/vnd.ibm.rights-management",".irp":"application/vnd.irepository.package+xml",".iso":"application/octet-stream",".itp":"application/vnd.shana.informed.formtemplate",".ivp":"application/vnd.immervision-ivp",".ivu":"application/vnd.immervision-ivu",".jad":"text/vnd.sun.j2me.app-descriptor",".jam":"application/vnd.jam",".jar":"application/java-archive",".java":"text/x-java-source",".jisp":"application/vnd.jisp",".jlt":"application/vnd.hp-jlyt",".jnlp":"application/x-java-jnlp-file",".joda":"application/vnd.joost.joda-archive",".jpe":"image/jpeg",".jpeg":"image/jpeg",".jpg":"image/jpeg",".jpgm":"video/jpm",".jpgv":"video/jpeg",".jpm":"video/jpm",".js":"application/javascript",".json":"application/json",".kar":"audio/midi",".karbon":"application/vnd.kde.karbon",".kfo":"application/vnd.kde.kformula",".kia":"application/vnd.kidspiration",".kil":"application/x-killustrator",".kml":"application/vnd.google-earth.kml+xml",".kmz":"application/vnd.google-earth.kmz",".kne":"application/vnd.kinar",".knp":"application/vnd.kinar",".kon":"application/vnd.kde.kontour",".kpr":"application/vnd.kde.kpresenter",".kpt":"application/vnd.kde.kpresenter",".ksh":"text/plain",".ksp":"application/vnd.kde.kspread",".ktr":"application/vnd.kahootz",".ktz":"application/vnd.kahootz",".kwd":"application/vnd.kde.kword",".kwt":"application/vnd.kde.kword",".latex":"application/x-latex",".lbd":"application/vnd.llamagraphics.life-balance.desktop",".lbe":"application/vnd.llamagraphics.life-balance.exchange+xml",".les":"application/vnd.hhe.lesson-player",".lha":"application/octet-stream",".link66":"application/vnd.route66.link66+xml",".list":"text/plain",".list3820":"application/vnd.ibm.modcap",".listafp":"application/vnd.ibm.modcap",".log":"text/plain",".lostxml":"application/lost+xml",".lrf":"application/octet-stream",".lrm":"application/vnd.ms-lrm",".ltf":"application/vnd.frogans.ltf",".lvp":"audio/vnd.lucent.voice",".lwp":"application/vnd.lotus-wordpro",".lzh":"application/octet-stream",".m13":"application/x-msmediaview",".m14":"application/x-msmediaview",".m1v":"video/mpeg",".m2a":"audio/mpeg",".m2v":"video/mpeg",".m3a":"audio/mpeg",".m3u":"audio/x-mpegurl",".m4u":"video/vnd.mpegurl",".m4v":"video/x-m4v",".ma":"application/mathematica",".mag":"application/vnd.ecowin.chart",".maker":"application/vnd.framemaker",".man":"text/troff",".mathml":"application/mathml+xml",".mb":"application/mathematica",".mbk":"application/vnd.mobius.mbk",".mbox":"application/mbox",".mc1":"application/vnd.medcalcdata",".mcd":"application/vnd.mcd",".mcurl":"text/vnd.curl.mcurl",".mdb":"application/x-msaccess",".mdi":"image/vnd.ms-modi",".me":"text/troff",".mesh":"model/mesh",".mfm":"application/vnd.mfmp",".mgz":"application/vnd.proteus.magazine",".mht":"message/rfc822",".mhtml":"message/rfc822",".mid":"audio/midi",".midi":"audio/midi",".mif":"application/vnd.mif",".mime":"message/rfc822",".mj2":"video/mj2",".mjp2":"video/mj2",".mkv":"video/x-matroska",".mlp":"application/vnd.dolby.mlp",".mmd":"application/vnd.chipnuts.karaoke-mmd",".mmf":"application/vnd.smaf",".mmr":"image/vnd.fujixerox.edmics-mmr",".mny":"application/x-msmoney",".mobi":"application/x-mobipocket-ebook",".mov":"video/quicktime",".movie":"video/x-sgi-movie",".mp2":"audio/mpeg",".mp2a":"audio/mpeg",".mp3":"audio/mpeg",".mp4":"video/mp4",".mp4a":"audio/mp4",".mp4s":"application/mp4",".mp4v":"video/mp4",".mpa":"video/mpeg",".mpc":"application/vnd.mophun.certificate",".mpe":"video/mpeg",".mpeg":"video/mpeg",".mpg":"video/mpeg",".mpg4":"video/mp4",".mpga":"audio/mpeg",".mpkg":"application/vnd.apple.installer+xml",".mpm":"application/vnd.blueice.multipass",".mpn":"application/vnd.mophun.application",".mpp":"application/vnd.ms-project",".mpt":"application/vnd.ms-project",".mpy":"application/vnd.ibm.minipay",".mqy":"application/vnd.mobius.mqy",".mrc":"application/marc",".ms":"text/troff",".mscml":"application/mediaservercontrol+xml",".mseed":"application/vnd.fdsn.mseed",".mseq":"application/vnd.mseq",".msf":"application/vnd.epson.msf",".msh":"model/mesh",".msi":"application/x-msdownload",".msl":"application/vnd.mobius.msl",".msty":"application/vnd.muvee.style",".mts":"model/vnd.mts",".mus":"application/vnd.musician",".musicxml":"application/vnd.recordare.musicxml+xml",".mvb":"application/x-msmediaview",".mwf":"application/vnd.mfer",".mxf":"application/mxf",".mxl":"application/vnd.recordare.musicxml",".mxml":"application/xv+xml",".mxs":"application/vnd.triscape.mxs",".mxu":"video/vnd.mpegurl",".n-gage":"application/vnd.nokia.n-gage.symbian.install",".nb":"application/mathematica",".nc":"application/x-netcdf",".ncx":"application/x-dtbncx+xml",".ngdat":"application/vnd.nokia.n-gage.data",".nlu":"application/vnd.neurolanguage.nlu",".nml":"application/vnd.enliven",".nnd":"application/vnd.noblenet-directory",".nns":"application/vnd.noblenet-sealer",".nnw":"application/vnd.noblenet-web",".npx":"image/vnd.net-fpx",".nsf":"application/vnd.lotus-notes",".nws":"message/rfc822",".o":"application/octet-stream",".oa2":"application/vnd.fujitsu.oasys2",".oa3":"application/vnd.fujitsu.oasys3",".oas":"application/vnd.fujitsu.oasys",".obd":"application/x-msbinder",".obj":"application/octet-stream",".oda":"application/oda",".odb":"application/vnd.oasis.opendocument.database",".odc":"application/vnd.oasis.opendocument.chart",".odf":"application/vnd.oasis.opendocument.formula",".odft":"application/vnd.oasis.opendocument.formula-template",".odg":"application/vnd.oasis.opendocument.graphics",".odi":"application/vnd.oasis.opendocument.image",".odp":"application/vnd.oasis.opendocument.presentation",".ods":"application/vnd.oasis.opendocument.spreadsheet",".odt":"application/vnd.oasis.opendocument.text",".oga":"audio/ogg",".ogg":"audio/ogg",".ogv":"video/ogg",".ogx":"application/ogg",".onepkg":"application/onenote",".onetmp":"application/onenote",".onetoc":"application/onenote",".onetoc2":"application/onenote",".opf":"application/oebps-package+xml",".oprc":"application/vnd.palm",".org":"application/vnd.lotus-organizer",".osf":"application/vnd.yamaha.openscoreformat",".osfpvg":"application/vnd.yamaha.openscoreformat.osfpvg+xml",".otc":"application/vnd.oasis.opendocument.chart-template",".otf":"application/x-font-otf",".otg":"application/vnd.oasis.opendocument.graphics-template",".oth":"application/vnd.oasis.opendocument.text-web",".oti":"application/vnd.oasis.opendocument.image-template",".otm":"application/vnd.oasis.opendocument.text-master",".otp":"application/vnd.oasis.opendocument.presentation-template",".ots":"application/vnd.oasis.opendocument.spreadsheet-template",".ott":"application/vnd.oasis.opendocument.text-template",".oxt":"application/vnd.openofficeorg.extension",".p":"text/x-pascal",".p10":"application/pkcs10",".p12":"application/x-pkcs12",".p7b":"application/x-pkcs7-certificates",".p7c":"application/pkcs7-mime",".p7m":"application/pkcs7-mime",".p7r":"application/x-pkcs7-certreqresp",".p7s":"application/pkcs7-signature",".pas":"text/x-pascal",".pbd":"application/vnd.powerbuilder6",".pbm":"image/x-portable-bitmap",".pcf":"application/x-font-pcf",".pcl":"application/vnd.hp-pcl",".pclxl":"application/vnd.hp-pclxl",".pct":"image/x-pict",".pcurl":"application/vnd.curl.pcurl",".pcx":"image/x-pcx",".pdb":"application/vnd.palm",".pdf":"application/pdf",".pfa":"application/x-font-type1",".pfb":"application/x-font-type1",".pfm":"application/x-font-type1",".pfr":"application/font-tdpfr",".pfx":"application/x-pkcs12",".pgm":"image/x-portable-graymap",".pgn":"application/x-chess-pgn",".pgp":"application/pgp-encrypted",".pic":"image/x-pict",".pkg":"application/octet-stream",".pki":"application/pkixcmp",".pkipath":"application/pkix-pkipath",".pl":"text/plain",".plb":"application/vnd.3gpp.pic-bw-large",".plc":"application/vnd.mobius.plc",".plf":"application/vnd.pocketlearn",".pls":"application/pls+xml",".pml":"application/vnd.ctc-posml",".png":"image/png",".pnm":"image/x-portable-anymap",".portpkg":"application/vnd.macports.portpkg",".pot":"application/vnd.ms-powerpoint",".potm":"application/vnd.ms-powerpoint.template.macroenabled.12",".potx":"application/vnd.openxmlformats-officedocument.presentationml.template",".ppa":"application/vnd.ms-powerpoint",".ppam":"application/vnd.ms-powerpoint.addin.macroenabled.12",".ppd":"application/vnd.cups-ppd",".ppm":"image/x-portable-pixmap",".pps":"application/vnd.ms-powerpoint",".ppsm":"application/vnd.ms-powerpoint.slideshow.macroenabled.12",".ppsx":"application/vnd.openxmlformats-officedocument.presentationml.slideshow",".ppt":"application/vnd.ms-powerpoint",".pptm":"application/vnd.ms-powerpoint.presentation.macroenabled.12",".pptx":"application/vnd.openxmlformats-officedocument.presentationml.presentation",".pqa":"application/vnd.palm",".prc":"application/x-mobipocket-ebook",".pre":"application/vnd.lotus-freelance",".prf":"application/pics-rules",".ps":"application/postscript",".psb":"application/vnd.3gpp.pic-bw-small",".psd":"image/vnd.adobe.photoshop",".psf":"application/x-font-linux-psf",".ptid":"application/vnd.pvi.ptid1",".pub":"application/x-mspublisher",".pvb":"application/vnd.3gpp.pic-bw-var",".pwn":"application/vnd.3m.post-it-notes",".pwz":"application/vnd.ms-powerpoint",".py":"text/x-python",".pya":"audio/vnd.ms-playready.media.pya",".pyc":"application/x-python-code",".pyo":"application/x-python-code",".pyv":"video/vnd.ms-playready.media.pyv",".qam":"application/vnd.epson.quickanime",".qbo":"application/vnd.intu.qbo",".qfx":"application/vnd.intu.qfx",".qps":"application/vnd.publishare-delta-tree",".qt":"video/quicktime",".qwd":"application/vnd.quark.quarkxpress",".qwt":"application/vnd.quark.quarkxpress",".qxb":"application/vnd.quark.quarkxpress",".qxd":"application/vnd.quark.quarkxpress",".qxl":"application/vnd.quark.quarkxpress",".qxt":"application/vnd.quark.quarkxpress",".ra":"audio/x-pn-realaudio",".ram":"audio/x-pn-realaudio",".rar":"application/x-rar-compressed",".ras":"image/x-cmu-raster",".rcprofile":"application/vnd.ipunplugged.rcprofile",".rdf":"application/rdf+xml",".rdz":"application/vnd.data-vision.rdz",".rep":"application/vnd.businessobjects",".res":"application/x-dtbresource+xml",".rgb":"image/x-rgb",".rif":"application/reginfo+xml",".rl":"application/resource-lists+xml",".rlc":"image/vnd.fujixerox.edmics-rlc",".rld":"application/resource-lists-diff+xml",".rm":"application/vnd.rn-realmedia",".rmi":"audio/midi",".rmp":"audio/x-pn-realaudio-plugin",".rms":"application/vnd.jcp.javame.midlet-rms",".rnc":"application/relax-ng-compact-syntax",".roff":"text/troff",".rpm":"application/x-rpm",".rpss":"application/vnd.nokia.radio-presets",".rpst":"application/vnd.nokia.radio-preset",".rq":"application/sparql-query",".rs":"application/rls-services+xml",".rsd":"application/rsd+xml",".rss":"application/rss+xml",".rtf":"application/rtf",".rtx":"text/richtext",".s":"text/x-asm",".saf":"application/vnd.yamaha.smaf-audio",".sbml":"application/sbml+xml",".sc":"application/vnd.ibm.secure-container",".scd":"application/x-msschedule",".scm":"application/vnd.lotus-screencam",".scq":"application/scvp-cv-request",".scs":"application/scvp-cv-response",".scurl":"text/vnd.curl.scurl",".sda":"application/vnd.stardivision.draw",".sdc":"application/vnd.stardivision.calc",".sdd":"application/vnd.stardivision.impress",".sdkd":"application/vnd.solent.sdkm+xml",".sdkm":"application/vnd.solent.sdkm+xml",".sdp":"application/sdp",".sdw":"application/vnd.stardivision.writer",".see":"application/vnd.seemail",".seed":"application/vnd.fdsn.seed",".sema":"application/vnd.sema",".semd":"application/vnd.semd",".semf":"application/vnd.semf",".ser":"application/java-serialized-object",".setpay":"application/set-payment-initiation",".setreg":"application/set-registration-initiation",".sfd-hdstx":"application/vnd.hydrostatix.sof-data",".sfs":"application/vnd.spotfire.sfs",".sgl":"application/vnd.stardivision.writer-global",".sgm":"text/sgml",".sgml":"text/sgml",".sh":"application/x-sh",".shar":"application/x-shar",".shf":"application/shf+xml",".si":"text/vnd.wap.si",".sic":"application/vnd.wap.sic",".sig":"application/pgp-signature",".silo":"model/mesh",".sis":"application/vnd.symbian.install",".sisx":"application/vnd.symbian.install",".sit":"application/x-stuffit",".sitx":"application/x-stuffitx",".skd":"application/vnd.koan",".skm":"application/vnd.koan",".skp":"application/vnd.koan",".skt":"application/vnd.koan",".sl":"text/vnd.wap.sl",".slc":"application/vnd.wap.slc",".sldm":"application/vnd.ms-powerpoint.slide.macroenabled.12",".sldx":"application/vnd.openxmlformats-officedocument.presentationml.slide",".slt":"application/vnd.epson.salt",".smf":"application/vnd.stardivision.math",".smi":"application/smil+xml",".smil":"application/smil+xml",".snd":"audio/basic",".snf":"application/x-font-snf",".so":"application/octet-stream",".spc":"application/x-pkcs7-certificates",".spf":"application/vnd.yamaha.smaf-phrase",".spl":"application/x-futuresplash",".spot":"text/vnd.in3d.spot",".spp":"application/scvp-vp-response",".spq":"application/scvp-vp-request",".spx":"audio/ogg",".src":"application/x-wais-source",".srx":"application/sparql-results+xml",".sse":"application/vnd.kodak-descriptor",".ssf":"application/vnd.epson.ssf",".ssml":"application/ssml+xml",".stc":"application/vnd.sun.xml.calc.template",".std":"application/vnd.sun.xml.draw.template",".stf":"application/vnd.wt.stf",".sti":"application/vnd.sun.xml.impress.template",".stk":"application/hyperstudio",".stl":"application/vnd.ms-pki.stl",".str":"application/vnd.pg.format",".stw":"application/vnd.sun.xml.writer.template",".sus":"application/vnd.sus-calendar",".susp":"application/vnd.sus-calendar",".sv4cpio":"application/x-sv4cpio",".sv4crc":"application/x-sv4crc",".svd":"application/vnd.svd",".svg":"image/svg+xml",".svgz":"image/svg+xml",".swa":"application/x-director",".swf":"application/x-shockwave-flash",".swi":"application/vnd.arastra.swi",".sxc":"application/vnd.sun.xml.calc",".sxd":"application/vnd.sun.xml.draw",".sxg":"application/vnd.sun.xml.writer.global",".sxi":"application/vnd.sun.xml.impress",".sxm":"application/vnd.sun.xml.math",".sxw":"application/vnd.sun.xml.writer",".t":"text/troff",".tao":"application/vnd.tao.intent-module-archive",".tar":"application/x-tar",".tcap":"application/vnd.3gpp2.tcap",".tcl":"application/x-tcl",".teacher":"application/vnd.smart.teacher",".tex":"application/x-tex",".texi":"application/x-texinfo",".texinfo":"application/x-texinfo",".text":"text/plain",".tfm":"application/x-tex-tfm",".tgz":"application/x-gzip",".tif":"image/tiff",".tiff":"image/tiff",".tmo":"application/vnd.tmobile-livetv",".torrent":"application/x-bittorrent",".tpl":"application/vnd.groove-tool-template",".tpt":"application/vnd.trid.tpt",".tr":"text/troff",".tra":"application/vnd.trueapp",".trm":"application/x-msterminal",".tsv":"text/tab-separated-values",".ttc":"application/x-font-ttf",".ttf":"application/x-font-ttf",".twd":"application/vnd.simtech-mindmapper",".twds":"application/vnd.simtech-mindmapper",".txd":"application/vnd.genomatix.tuxedo",".txf":"application/vnd.mobius.txf",".txt":"text/plain",".u32":"application/x-authorware-bin",".udeb":"application/x-debian-package",".ufd":"application/vnd.ufdl",".ufdl":"application/vnd.ufdl",".umj":"application/vnd.umajin",".unityweb":"application/vnd.unity",".uoml":"application/vnd.uoml+xml",".uri":"text/uri-list",".uris":"text/uri-list",".urls":"text/uri-list",".ustar":"application/x-ustar",".utz":"application/vnd.uiq.theme",".uu":"text/x-uuencode",".vcd":"application/x-cdlink",".vcf":"text/x-vcard",".vcg":"application/vnd.groove-vcard",".vcs":"text/x-vcalendar",".vcx":"application/vnd.vcx",".vis":"application/vnd.visionary",".viv":"video/vnd.vivo",".vor":"application/vnd.stardivision.writer",".vox":"application/x-authorware-bin",".vrml":"model/vrml",".vsd":"application/vnd.visio",".vsf":"application/vnd.vsf",".vss":"application/vnd.visio",".vst":"application/vnd.visio",".vsw":"application/vnd.visio",".vtu":"model/vnd.vtu",".vxml":"application/voicexml+xml",".w3d":"application/x-director",".webm":"video/webm",".wad":"application/x-doom",".wav":"audio/x-wav",".wax":"audio/x-ms-wax",".wbmp":"image/vnd.wap.wbmp",".wbs":"application/vnd.criticaltools.wbs+xml",".wbxml":"application/vnd.wap.wbxml",".wcm":"application/vnd.ms-works",".wdb":"application/vnd.ms-works",".wiz":"application/msword",".wks":"application/vnd.ms-works",".wm":"video/x-ms-wm",".wma":"audio/x-ms-wma",".wmd":"application/x-ms-wmd",".wmf":"application/x-msmetafile",".wml":"text/vnd.wap.wml",".wmlc":"application/vnd.wap.wmlc",".wmls":"text/vnd.wap.wmlscript",".wmlsc":"application/vnd.wap.wmlscriptc",".wmv":"video/x-ms-wmv",".wmx":"video/x-ms-wmx",".wmz":"application/x-ms-wmz",".wpd":"application/vnd.wordperfect",".wpl":"application/vnd.ms-wpl",".wps":"application/vnd.ms-works",".wqd":"application/vnd.wqd",".wri":"application/x-mswrite",".wrl":"model/vrml",".wsdl":"application/wsdl+xml",".wspolicy":"application/wspolicy+xml",".wtb":"application/vnd.webturbo",".wvx":"video/x-ms-wvx",".x32":"application/x-authorware-bin",".x3d":"application/vnd.hzn-3d-crossword",".xap":"application/x-silverlight-app",".xar":"application/vnd.xara",".xbap":"application/x-ms-xbap",".xbd":"application/vnd.fujixerox.docuworks.binder",".xbm":"image/x-xbitmap",".xdm":"application/vnd.syncml.dm+xml",".xdp":"application/vnd.adobe.xdp+xml",".xdw":"application/vnd.fujixerox.docuworks",".xenc":"application/xenc+xml",".xer":"application/patch-ops-error+xml",".xfdf":"application/vnd.adobe.xfdf",".xfdl":"application/vnd.xfdl",".xht":"application/xhtml+xml",".xhtml":"application/xhtml+xml",".xhvml":"application/xv+xml",".xif":"image/vnd.xiff",".xla":"application/vnd.ms-excel",".xlam":"application/vnd.ms-excel.addin.macroenabled.12",".xlb":"application/vnd.ms-excel",".xlc":"application/vnd.ms-excel",".xlm":"application/vnd.ms-excel",".xls":"application/vnd.ms-excel",".xlsb":"application/vnd.ms-excel.sheet.binary.macroenabled.12",".xlsm":"application/vnd.ms-excel.sheet.macroenabled.12",".xlsx":"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",".xlt":"application/vnd.ms-excel",".xltm":"application/vnd.ms-excel.template.macroenabled.12",".xltx":"application/vnd.openxmlformats-officedocument.spreadsheetml.template",".xlw":"application/vnd.ms-excel",".xml":"application/xml",".xo":"application/vnd.olpc-sugar",".xop":"application/xop+xml",".xpdl":"application/xml",".xpi":"application/x-xpinstall",".xpm":"image/x-xpixmap",".xpr":"application/vnd.is-xpr",".xps":"application/vnd.ms-xpsdocument",".xpw":"application/vnd.intercon.formnet",".xpx":"application/vnd.intercon.formnet",".xsl":"application/xml",".xslt":"application/xslt+xml",".xsm":"application/vnd.syncml+xml",".xspf":"application/xspf+xml",".xul":"application/vnd.mozilla.xul+xml",".xvm":"application/xv+xml",".xvml":"application/xv+xml",".xwd":"image/x-xwindowdump",".xyz":"chemical/x-xyz",".zaz":"application/vnd.zzazz.deck+xml",".zip":"application/zip",".zir":"application/vnd.zul",".zirz":"application/vnd.zul",".zmm":"application/vnd.handheld-entertainment+xml"},wh=[".sh",".exe",".app",".bat",".cmd",".msi",".apk",".jar",".py",".js",".cron",".php",".asp"],Lz=Object.keys(qc);import*as vh from"zod";var kz=vh.custom().refine(n=>n&&n.length>0).refine(n=>n&&n[0]instanceof File,{message:"Please upload a valid file."});import{z as rr}from"zod";var _z=rr.object({id:rr.string(),name:rr.string(),createdAt:rr.coerce.date(),createdBy:rr.string(),updatedAt:rr.coerce.date(),updatedBy:rr.string().nullable(),organizationId:rr.string()});import{z as W}from"zod";import{z as Ke}from"zod";var bt=Ke.object({id:Ke.string(),name:ms,baseUrl:hs,description:Ke.string().optional().nullish(),schemaVersion:Ke.string(),advanced:Ro,retries:Ke.number(),envs:Ke.array(cs).nullish(),parameters:ls.nullish(),disabled:Ke.boolean().optional(),labels:Ke.array(Ke.string()).optional().catch([])}),jz=bt.pick({name:!0,description:!0,baseUrl:!0,retries:!0,disabled:!0,advanced:!0,parameters:!0}),lR=Ke.object({labels:Ke.array(Ke.string()).optional(),outputs:Dm.nullish()}),Kt=bt.merge(lR),cR=Ke.object({createdAt:Ke.coerce.date(),updatedAt:Ke.coerce.date(),updatedBy:Ke.string().nullable(),schedule:Ao,notification:Io,createdBy:Ke.string(),organizationId:Ke.string(),folderId:Ke.string().nullable().optional()}),dR=bt.merge(cR),$z=dR.merge(yo),Zi=bt.merge(yo),Gz=bt.merge(Cr);var Th=W.object({platformSep:W.string(),fullPathSegments:W.string().array(),relativePath:W.string().describe("path relative to the root test directory, i.e. my-folder/my-test.yaml"),fileName:W.string().describe("base name of the file including the extension, e.g. my-module.module.yaml"),lastModified:W.coerce.date(),createdAt:W.coerce.date()}),Zz=W.array(Th.extend({id:W.string(),name:W.string(),description:W.string().optional(),labels:W.string().array().optional()})),Qz=W.array(Th.extend({id:W.string(),name:W.string(),description:W.string().optional(),content:uc})),eH=Zi.merge(Kt),xh=W.object({schemaVersion:W.string(),stepLists:yo}),Eh=Kt.partial().merge(bt.pick({id:!0})),Ch=W.object({name:W.string(),description:W.string().optional(),baseUrl:W.string().url().optional(),environment:W.string().optional(),browserType:W.nativeEnum(Dn).optional(),viewport:as.optional(),folderPath:W.string().optional()}),tH=Zi.merge(W.object({relativeFilePath:W.string().describe("relative to project root")})),Rh=W.object({name:W.string()}),nH=W.object({relativeFilePath:W.string()}),Ah=W.object({name:W.string(),description:W.string(),enabled:W.boolean(),steps:W.lazy(()=>Ae.array()),testFilePath:W.string().describe("relative to the project root"),folderPath:W.string().optional().describe("user selected folder path")}),Ih=W.object({description:W.string(),enabled:W.boolean()}).partial();var rH=W.array(Am),Ph=W.object({defaultEnv:W.string().optional().describe("name of the default env, or undefined to unset")}),Lh=W.object({configFilePath:W.string().describe("full path on disk")}),oH=W.string().array(),iH=W.object({message:W.string(),newRelativeTestPath:W.string().optional()});var ws=["node_modules","dist","bin",".git",".npm",".next","out",".yarn","__pycache__","build",".env",".venv","venv","env","wheels"],Oh=ws.map(n=>`**/${n}/**`);import Tn from"chalk";var pR=["app","version","env","namespace","host"];function ze(n){let e=n.bindings()??{},t={};for(let r of Object.keys(e)){let o=e[r];!pR.includes(r)&&typeof o=="string"&&(t[r]=o)}return t}var Kc=class n{minLogLevel;logBindings;constructor(e,t){this.minLogLevel=e,this.logBindings=t}logWithLevel(e,t,...r){if(e<this.minLogLevel)return;let o;Array.isArray(r[0])?(o=r[0],r=r.slice(1)):typeof r[0]=="object"&&!(r[0]instanceof Error)&&Object.entries(r[0]).length&&(o={...r[0],...this.logBindings},r=r.slice(1));let i=[];if(i.push(...r),console.log(t(...i)),o&&!Array.isArray(o)){let a=Object.entries(o);for(let[s,l]of a){let c=l;l instanceof Error?c=l.message:typeof l=="object"&&(c=JSON.stringify(l,void 0,2),c=c.split(`
10
+ `)}`}};function yh(n){return n instanceof Error?n.message.includes("Timeout")&&n.message.includes("exceeded")&&n.message.includes("waiting for locator"):!1}function Vc(n){return!(n instanceof Error)||n.message.includes("locator resolved to visible")?!1:!!(n.message.includes("Timeout")&&n.message.includes("exceeded")&&n.message.includes("body >")||n.message.includes("Element is not attached to the DOM"))}function Ji(n){return n instanceof Error?n.message.includes("Timeout")&&n.message.includes("exceeded")&&n.message.includes("waiting for locator")&&n.message.includes("data-momentic-id")&&!n.message.includes("locator resolved")&&!n.message.includes("waiting for element to be"):!1}var Yi=class extends Error{constructor(e,t={}){super(e,t),this.name="InsufficientCssDataError"}};import{cloneDeep as sR}from"lodash-es";import{z as vn}from"zod";var Dt=(p=>(p.AutoExpandIframes="auto_expand_iframes",p.DisableSecondaryCacheResolution="disable_secondary_cache_resolution",p.FakerConstantSeed="faker_constant_seed",p.ShowZeroOpacityElements="show_zero_opacity_elements",p.GlobalLocatorRedirect="global_locator_redirect",p.IconKnowledgeBase="icon_knowledge_base",p.MiniModelInitialAssertion="mini_model_initial_assertion",p.MiniModelInitialLocator="mini_model_initial_locator",p.ShowTestPlans="show_test_plans",p.RagV2="rag_v2",p.VisualActions="visual_actions",p))(Dt||{});var bh=vn.union([vn.string(),vn.number(),vn.boolean(),vn.null(),vn.record(vn.string(),vn.lazy(()=>bh)),vn.array(vn.lazy(()=>bh))]),Xi=class{flags;payloads;constructor(e,t){this.flags=e,this.payloads=t}isBooleanFlagEnabled(e){return process.env&&process.env[`MOMENTIC_FLAG_OVERRIDE_${e.toUpperCase()}`]==="true"?!0:process.env&&process.env[`MOMENTIC_FLAG_OVERRIDE_${e.toUpperCase()}`]==="false"?!1:this.flags[e]===!0}getAllFlags(){let e=sR(this.flags);return Object.entries(e).forEach(([t,r])=>{typeof r=="boolean"&&Object.values(Dt).includes(t)&&(e[t]=this.isBooleanFlagEnabled(t))}),e}getFlagPayload(e){let t=this.payloads[e];if(t!==void 0){if(typeof t=="string")try{return JSON.parse(t)}catch{return t}return t}}refresh(){throw new Error("Not implemented")}},Iz=new Xi({},{});var qc={".123":"application/vnd.lotus-1-2-3",".3dml":"text/vnd.in3d.3dml",".3g2":"video/3gpp2",".3gp":"video/3gpp",".a":"application/octet-stream",".aab":"application/x-authorware-bin",".aac":"audio/x-aac",".aam":"application/x-authorware-map",".aas":"application/x-authorware-seg",".abw":"application/x-abiword",".acc":"application/vnd.americandynamics.acc",".ace":"application/x-ace-compressed",".acu":"application/vnd.acucobol",".acutc":"application/vnd.acucorp",".adp":"audio/adpcm",".aep":"application/vnd.audiograph",".afm":"application/x-font-type1",".afp":"application/vnd.ibm.modcap",".ai":"application/postscript",".aif":"audio/x-aiff",".aifc":"audio/x-aiff",".aiff":"audio/x-aiff",".air":"application/vnd.adobe.air-application-installer-package+zip",".ami":"application/vnd.amiga.ami",".apk":"application/vnd.android.package-archive",".application":"application/x-ms-application",".apr":"application/vnd.lotus-approach",".asc":"application/pgp-signature",".asf":"video/x-ms-asf",".asm":"text/x-asm",".aso":"application/vnd.accpac.simply.aso",".asx":"video/x-ms-asf",".atc":"application/vnd.acucorp",".atom":"application/atom+xml",".atomcat":"application/atomcat+xml",".atomsvc":"application/atomsvc+xml",".atx":"application/vnd.antix.game-component",".au":"audio/basic",".avi":"video/x-msvideo",".aw":"application/applixware",".azf":"application/vnd.airzip.filesecure.azf",".azs":"application/vnd.airzip.filesecure.azs",".azw":"application/vnd.amazon.ebook",".bat":"application/x-msdownload",".bcpio":"application/x-bcpio",".bdf":"application/x-font-bdf",".bdm":"application/vnd.syncml.dm+wbxml",".bh2":"application/vnd.fujitsu.oasysprs",".bin":"application/octet-stream",".bmi":"application/vnd.bmi",".bmp":"image/bmp",".book":"application/vnd.framemaker",".box":"application/vnd.previewsystems.box",".boz":"application/x-bzip2",".bpk":"application/octet-stream",".btif":"image/prs.btif",".bz":"application/x-bzip",".bz2":"application/x-bzip2",".c":"text/x-c",".c4d":"application/vnd.clonk.c4group",".c4f":"application/vnd.clonk.c4group",".c4g":"application/vnd.clonk.c4group",".c4p":"application/vnd.clonk.c4group",".c4u":"application/vnd.clonk.c4group",".cab":"application/vnd.ms-cab-compressed",".car":"application/vnd.curl.car",".cat":"application/vnd.ms-pki.seccat",".cc":"text/x-c",".cct":"application/x-director",".ccxml":"application/ccxml+xml",".cdbcmsg":"application/vnd.contact.cmsg",".cdf":"application/x-netcdf",".cdkey":"application/vnd.mediastation.cdkey",".cdx":"chemical/x-cdx",".cdxml":"application/vnd.chemdraw+xml",".cdy":"application/vnd.cinderella",".cer":"application/pkix-cert",".cgm":"image/cgm",".chat":"application/x-chat",".chm":"application/vnd.ms-htmlhelp",".chrt":"application/vnd.kde.kchart",".cif":"chemical/x-cif",".cii":"application/vnd.anser-web-certificate-issue-initiation",".cil":"application/vnd.ms-artgalry",".cla":"application/vnd.claymore",".class":"application/java-vm",".clkk":"application/vnd.crick.clicker.keyboard",".clkp":"application/vnd.crick.clicker.palette",".clkt":"application/vnd.crick.clicker.template",".clkw":"application/vnd.crick.clicker.wordbank",".clkx":"application/vnd.crick.clicker",".clp":"application/x-msclip",".cmc":"application/vnd.cosmocaller",".cmdf":"chemical/x-cmdf",".cml":"chemical/x-cml",".cmp":"application/vnd.yellowriver-custom-menu",".cmx":"image/x-cmx",".cod":"application/vnd.rim.cod",".com":"application/x-msdownload",".conf":"text/plain",".cpio":"application/x-cpio",".cpp":"text/x-c",".cpt":"application/mac-compactpro",".crd":"application/x-mscardfile",".crl":"application/pkix-crl",".crt":"application/x-x509-ca-cert",".csh":"application/x-csh",".csml":"chemical/x-csml",".csp":"application/vnd.commonspace",".css":"text/css",".cst":"application/x-director",".csv":"text/csv",".cu":"application/cu-seeme",".curl":"text/vnd.curl",".cww":"application/prs.cww",".cxt":"application/x-director",".cxx":"text/x-c",".daf":"application/vnd.mobius.daf",".dataless":"application/vnd.fdsn.seed",".davmount":"application/davmount+xml",".dcr":"application/x-director",".dcurl":"text/vnd.curl.dcurl",".dd2":"application/vnd.oma.dd2+xml",".ddd":"application/vnd.fujixerox.ddd",".deb":"application/x-debian-package",".def":"text/plain",".deploy":"application/octet-stream",".der":"application/x-x509-ca-cert",".dfac":"application/vnd.dreamfactory",".dic":"text/x-c",".diff":"text/plain",".dir":"application/x-director",".dis":"application/vnd.mobius.dis",".dist":"application/octet-stream",".distz":"application/octet-stream",".djv":"image/vnd.djvu",".djvu":"image/vnd.djvu",".dll":"application/x-msdownload",".dmg":"application/octet-stream",".dms":"application/octet-stream",".dna":"application/vnd.dna",".doc":"application/msword",".docm":"application/vnd.ms-word.document.macroenabled.12",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".dot":"application/msword",".dotm":"application/vnd.ms-word.template.macroenabled.12",".dotx":"application/vnd.openxmlformats-officedocument.wordprocessingml.template",".dp":"application/vnd.osgi.dp",".dpg":"application/vnd.dpgraph",".dsc":"text/prs.lines.tag",".dtb":"application/x-dtbook+xml",".dtd":"application/xml-dtd",".dts":"audio/vnd.dts",".dtshd":"audio/vnd.dts.hd",".dump":"application/octet-stream",".dvi":"application/x-dvi",".dwf":"model/vnd.dwf",".dwg":"image/vnd.dwg",".dxf":"image/vnd.dxf",".dxp":"application/vnd.spotfire.dxp",".dxr":"application/x-director",".ecelp4800":"audio/vnd.nuera.ecelp4800",".ecelp7470":"audio/vnd.nuera.ecelp7470",".ecelp9600":"audio/vnd.nuera.ecelp9600",".ecma":"application/ecmascript",".edm":"application/vnd.novadigm.edm",".edx":"application/vnd.novadigm.edx",".efif":"application/vnd.picsel",".ei6":"application/vnd.pg.osasli",".elc":"application/octet-stream",".eml":"message/rfc822",".emma":"application/emma+xml",".eol":"audio/vnd.digital-winds",".eot":"application/vnd.ms-fontobject",".eps":"application/postscript",".epub":"application/epub+zip",".es3":"application/vnd.eszigno3+xml",".esf":"application/vnd.epson.esf",".et3":"application/vnd.eszigno3+xml",".etx":"text/x-setext",".exe":"application/x-msdownload",".ext":"application/vnd.novadigm.ext",".ez":"application/andrew-inset",".ez2":"application/vnd.ezpix-album",".ez3":"application/vnd.ezpix-package",".f":"text/x-fortran",".f4v":"video/x-f4v",".f77":"text/x-fortran",".f90":"text/x-fortran",".fbs":"image/vnd.fastbidsheet",".fdf":"application/vnd.fdf",".fe_launch":"application/vnd.denovo.fcselayout-link",".fg5":"application/vnd.fujitsu.oasysgp",".fgd":"application/x-director",".fh":"image/x-freehand",".fh4":"image/x-freehand",".fh5":"image/x-freehand",".fh7":"image/x-freehand",".fhc":"image/x-freehand",".fig":"application/x-xfig",".fli":"video/x-fli",".flo":"application/vnd.micrografx.flo",".flv":"video/x-flv",".flw":"application/vnd.kde.kivio",".flx":"text/vnd.fmi.flexstor",".fly":"text/vnd.fly",".fm":"application/vnd.framemaker",".fnc":"application/vnd.frogans.fnc",".for":"text/x-fortran",".fpx":"image/vnd.fpx",".frame":"application/vnd.framemaker",".fsc":"application/vnd.fsc.weblaunch",".fst":"image/vnd.fst",".ftc":"application/vnd.fluxtime.clip",".fti":"application/vnd.anser-web-funds-transfer-initiation",".fvt":"video/vnd.fvt",".fzs":"application/vnd.fuzzysheet",".g3":"image/g3fax",".gac":"application/vnd.groove-account",".gdl":"model/vnd.gdl",".geo":"application/vnd.dynageo",".gex":"application/vnd.geometry-explorer",".ggb":"application/vnd.geogebra.file",".ggt":"application/vnd.geogebra.tool",".ghf":"application/vnd.groove-help",".gif":"image/gif",".gim":"application/vnd.groove-identity-message",".gmx":"application/vnd.gmx",".gnumeric":"application/x-gnumeric",".gph":"application/vnd.flographit",".gqf":"application/vnd.grafeq",".gqs":"application/vnd.grafeq",".gram":"application/srgs",".gre":"application/vnd.geometry-explorer",".grv":"application/vnd.groove-injector",".grxml":"application/srgs+xml",".gsf":"application/x-font-ghostscript",".gtar":"application/x-gtar",".gtm":"application/vnd.groove-tool-message",".gtw":"model/vnd.gtw",".gv":"text/vnd.graphviz",".gz":"application/x-gzip",".h":"text/x-c",".h261":"video/h261",".h263":"video/h263",".h264":"video/h264",".hbci":"application/vnd.hbci",".hdf":"application/x-hdf",".hh":"text/x-c",".hlp":"application/winhlp",".hpgl":"application/vnd.hp-hpgl",".hpid":"application/vnd.hp-hpid",".hps":"application/vnd.hp-hps",".hqx":"application/mac-binhex40",".htke":"application/vnd.kenameaapp",".htm":"text/html",".html":"text/html",".hvd":"application/vnd.yamaha.hv-dic",".hvp":"application/vnd.yamaha.hv-voice",".hvs":"application/vnd.yamaha.hv-script",".icc":"application/vnd.iccprofile",".ice":"x-conference/x-cooltalk",".icm":"application/vnd.iccprofile",".ico":"image/x-icon",".ics":"text/calendar",".ief":"image/ief",".ifb":"text/calendar",".ifm":"application/vnd.shana.informed.formdata",".iges":"model/iges",".igl":"application/vnd.igloader",".igs":"model/iges",".igx":"application/vnd.micrografx.igx",".iif":"application/vnd.shana.informed.interchange",".imp":"application/vnd.accpac.simply.imp",".ims":"application/vnd.ms-ims",".in":"text/plain",".ipk":"application/vnd.shana.informed.package",".irm":"application/vnd.ibm.rights-management",".irp":"application/vnd.irepository.package+xml",".iso":"application/octet-stream",".itp":"application/vnd.shana.informed.formtemplate",".ivp":"application/vnd.immervision-ivp",".ivu":"application/vnd.immervision-ivu",".jad":"text/vnd.sun.j2me.app-descriptor",".jam":"application/vnd.jam",".jar":"application/java-archive",".java":"text/x-java-source",".jisp":"application/vnd.jisp",".jlt":"application/vnd.hp-jlyt",".jnlp":"application/x-java-jnlp-file",".joda":"application/vnd.joost.joda-archive",".jpe":"image/jpeg",".jpeg":"image/jpeg",".jpg":"image/jpeg",".jpgm":"video/jpm",".jpgv":"video/jpeg",".jpm":"video/jpm",".js":"application/javascript",".json":"application/json",".kar":"audio/midi",".karbon":"application/vnd.kde.karbon",".kfo":"application/vnd.kde.kformula",".kia":"application/vnd.kidspiration",".kil":"application/x-killustrator",".kml":"application/vnd.google-earth.kml+xml",".kmz":"application/vnd.google-earth.kmz",".kne":"application/vnd.kinar",".knp":"application/vnd.kinar",".kon":"application/vnd.kde.kontour",".kpr":"application/vnd.kde.kpresenter",".kpt":"application/vnd.kde.kpresenter",".ksh":"text/plain",".ksp":"application/vnd.kde.kspread",".ktr":"application/vnd.kahootz",".ktz":"application/vnd.kahootz",".kwd":"application/vnd.kde.kword",".kwt":"application/vnd.kde.kword",".latex":"application/x-latex",".lbd":"application/vnd.llamagraphics.life-balance.desktop",".lbe":"application/vnd.llamagraphics.life-balance.exchange+xml",".les":"application/vnd.hhe.lesson-player",".lha":"application/octet-stream",".link66":"application/vnd.route66.link66+xml",".list":"text/plain",".list3820":"application/vnd.ibm.modcap",".listafp":"application/vnd.ibm.modcap",".log":"text/plain",".lostxml":"application/lost+xml",".lrf":"application/octet-stream",".lrm":"application/vnd.ms-lrm",".ltf":"application/vnd.frogans.ltf",".lvp":"audio/vnd.lucent.voice",".lwp":"application/vnd.lotus-wordpro",".lzh":"application/octet-stream",".m13":"application/x-msmediaview",".m14":"application/x-msmediaview",".m1v":"video/mpeg",".m2a":"audio/mpeg",".m2v":"video/mpeg",".m3a":"audio/mpeg",".m3u":"audio/x-mpegurl",".m4u":"video/vnd.mpegurl",".m4v":"video/x-m4v",".ma":"application/mathematica",".mag":"application/vnd.ecowin.chart",".maker":"application/vnd.framemaker",".man":"text/troff",".mathml":"application/mathml+xml",".mb":"application/mathematica",".mbk":"application/vnd.mobius.mbk",".mbox":"application/mbox",".mc1":"application/vnd.medcalcdata",".mcd":"application/vnd.mcd",".mcurl":"text/vnd.curl.mcurl",".mdb":"application/x-msaccess",".mdi":"image/vnd.ms-modi",".me":"text/troff",".mesh":"model/mesh",".mfm":"application/vnd.mfmp",".mgz":"application/vnd.proteus.magazine",".mht":"message/rfc822",".mhtml":"message/rfc822",".mid":"audio/midi",".midi":"audio/midi",".mif":"application/vnd.mif",".mime":"message/rfc822",".mj2":"video/mj2",".mjp2":"video/mj2",".mkv":"video/x-matroska",".mlp":"application/vnd.dolby.mlp",".mmd":"application/vnd.chipnuts.karaoke-mmd",".mmf":"application/vnd.smaf",".mmr":"image/vnd.fujixerox.edmics-mmr",".mny":"application/x-msmoney",".mobi":"application/x-mobipocket-ebook",".mov":"video/quicktime",".movie":"video/x-sgi-movie",".mp2":"audio/mpeg",".mp2a":"audio/mpeg",".mp3":"audio/mpeg",".mp4":"video/mp4",".mp4a":"audio/mp4",".mp4s":"application/mp4",".mp4v":"video/mp4",".mpa":"video/mpeg",".mpc":"application/vnd.mophun.certificate",".mpe":"video/mpeg",".mpeg":"video/mpeg",".mpg":"video/mpeg",".mpg4":"video/mp4",".mpga":"audio/mpeg",".mpkg":"application/vnd.apple.installer+xml",".mpm":"application/vnd.blueice.multipass",".mpn":"application/vnd.mophun.application",".mpp":"application/vnd.ms-project",".mpt":"application/vnd.ms-project",".mpy":"application/vnd.ibm.minipay",".mqy":"application/vnd.mobius.mqy",".mrc":"application/marc",".ms":"text/troff",".mscml":"application/mediaservercontrol+xml",".mseed":"application/vnd.fdsn.mseed",".mseq":"application/vnd.mseq",".msf":"application/vnd.epson.msf",".msh":"model/mesh",".msi":"application/x-msdownload",".msl":"application/vnd.mobius.msl",".msty":"application/vnd.muvee.style",".mts":"model/vnd.mts",".mus":"application/vnd.musician",".musicxml":"application/vnd.recordare.musicxml+xml",".mvb":"application/x-msmediaview",".mwf":"application/vnd.mfer",".mxf":"application/mxf",".mxl":"application/vnd.recordare.musicxml",".mxml":"application/xv+xml",".mxs":"application/vnd.triscape.mxs",".mxu":"video/vnd.mpegurl",".n-gage":"application/vnd.nokia.n-gage.symbian.install",".nb":"application/mathematica",".nc":"application/x-netcdf",".ncx":"application/x-dtbncx+xml",".ngdat":"application/vnd.nokia.n-gage.data",".nlu":"application/vnd.neurolanguage.nlu",".nml":"application/vnd.enliven",".nnd":"application/vnd.noblenet-directory",".nns":"application/vnd.noblenet-sealer",".nnw":"application/vnd.noblenet-web",".npx":"image/vnd.net-fpx",".nsf":"application/vnd.lotus-notes",".nws":"message/rfc822",".o":"application/octet-stream",".oa2":"application/vnd.fujitsu.oasys2",".oa3":"application/vnd.fujitsu.oasys3",".oas":"application/vnd.fujitsu.oasys",".obd":"application/x-msbinder",".obj":"application/octet-stream",".oda":"application/oda",".odb":"application/vnd.oasis.opendocument.database",".odc":"application/vnd.oasis.opendocument.chart",".odf":"application/vnd.oasis.opendocument.formula",".odft":"application/vnd.oasis.opendocument.formula-template",".odg":"application/vnd.oasis.opendocument.graphics",".odi":"application/vnd.oasis.opendocument.image",".odp":"application/vnd.oasis.opendocument.presentation",".ods":"application/vnd.oasis.opendocument.spreadsheet",".odt":"application/vnd.oasis.opendocument.text",".oga":"audio/ogg",".ogg":"audio/ogg",".ogv":"video/ogg",".ogx":"application/ogg",".onepkg":"application/onenote",".onetmp":"application/onenote",".onetoc":"application/onenote",".onetoc2":"application/onenote",".opf":"application/oebps-package+xml",".oprc":"application/vnd.palm",".org":"application/vnd.lotus-organizer",".osf":"application/vnd.yamaha.openscoreformat",".osfpvg":"application/vnd.yamaha.openscoreformat.osfpvg+xml",".otc":"application/vnd.oasis.opendocument.chart-template",".otf":"application/x-font-otf",".otg":"application/vnd.oasis.opendocument.graphics-template",".oth":"application/vnd.oasis.opendocument.text-web",".oti":"application/vnd.oasis.opendocument.image-template",".otm":"application/vnd.oasis.opendocument.text-master",".otp":"application/vnd.oasis.opendocument.presentation-template",".ots":"application/vnd.oasis.opendocument.spreadsheet-template",".ott":"application/vnd.oasis.opendocument.text-template",".oxt":"application/vnd.openofficeorg.extension",".p":"text/x-pascal",".p10":"application/pkcs10",".p12":"application/x-pkcs12",".p7b":"application/x-pkcs7-certificates",".p7c":"application/pkcs7-mime",".p7m":"application/pkcs7-mime",".p7r":"application/x-pkcs7-certreqresp",".p7s":"application/pkcs7-signature",".pas":"text/x-pascal",".pbd":"application/vnd.powerbuilder6",".pbm":"image/x-portable-bitmap",".pcf":"application/x-font-pcf",".pcl":"application/vnd.hp-pcl",".pclxl":"application/vnd.hp-pclxl",".pct":"image/x-pict",".pcurl":"application/vnd.curl.pcurl",".pcx":"image/x-pcx",".pdb":"application/vnd.palm",".pdf":"application/pdf",".pfa":"application/x-font-type1",".pfb":"application/x-font-type1",".pfm":"application/x-font-type1",".pfr":"application/font-tdpfr",".pfx":"application/x-pkcs12",".pgm":"image/x-portable-graymap",".pgn":"application/x-chess-pgn",".pgp":"application/pgp-encrypted",".pic":"image/x-pict",".pkg":"application/octet-stream",".pki":"application/pkixcmp",".pkipath":"application/pkix-pkipath",".pl":"text/plain",".plb":"application/vnd.3gpp.pic-bw-large",".plc":"application/vnd.mobius.plc",".plf":"application/vnd.pocketlearn",".pls":"application/pls+xml",".pml":"application/vnd.ctc-posml",".png":"image/png",".pnm":"image/x-portable-anymap",".portpkg":"application/vnd.macports.portpkg",".pot":"application/vnd.ms-powerpoint",".potm":"application/vnd.ms-powerpoint.template.macroenabled.12",".potx":"application/vnd.openxmlformats-officedocument.presentationml.template",".ppa":"application/vnd.ms-powerpoint",".ppam":"application/vnd.ms-powerpoint.addin.macroenabled.12",".ppd":"application/vnd.cups-ppd",".ppm":"image/x-portable-pixmap",".pps":"application/vnd.ms-powerpoint",".ppsm":"application/vnd.ms-powerpoint.slideshow.macroenabled.12",".ppsx":"application/vnd.openxmlformats-officedocument.presentationml.slideshow",".ppt":"application/vnd.ms-powerpoint",".pptm":"application/vnd.ms-powerpoint.presentation.macroenabled.12",".pptx":"application/vnd.openxmlformats-officedocument.presentationml.presentation",".pqa":"application/vnd.palm",".prc":"application/x-mobipocket-ebook",".pre":"application/vnd.lotus-freelance",".prf":"application/pics-rules",".ps":"application/postscript",".psb":"application/vnd.3gpp.pic-bw-small",".psd":"image/vnd.adobe.photoshop",".psf":"application/x-font-linux-psf",".ptid":"application/vnd.pvi.ptid1",".pub":"application/x-mspublisher",".pvb":"application/vnd.3gpp.pic-bw-var",".pwn":"application/vnd.3m.post-it-notes",".pwz":"application/vnd.ms-powerpoint",".py":"text/x-python",".pya":"audio/vnd.ms-playready.media.pya",".pyc":"application/x-python-code",".pyo":"application/x-python-code",".pyv":"video/vnd.ms-playready.media.pyv",".qam":"application/vnd.epson.quickanime",".qbo":"application/vnd.intu.qbo",".qfx":"application/vnd.intu.qfx",".qps":"application/vnd.publishare-delta-tree",".qt":"video/quicktime",".qwd":"application/vnd.quark.quarkxpress",".qwt":"application/vnd.quark.quarkxpress",".qxb":"application/vnd.quark.quarkxpress",".qxd":"application/vnd.quark.quarkxpress",".qxl":"application/vnd.quark.quarkxpress",".qxt":"application/vnd.quark.quarkxpress",".ra":"audio/x-pn-realaudio",".ram":"audio/x-pn-realaudio",".rar":"application/x-rar-compressed",".ras":"image/x-cmu-raster",".rcprofile":"application/vnd.ipunplugged.rcprofile",".rdf":"application/rdf+xml",".rdz":"application/vnd.data-vision.rdz",".rep":"application/vnd.businessobjects",".res":"application/x-dtbresource+xml",".rgb":"image/x-rgb",".rif":"application/reginfo+xml",".rl":"application/resource-lists+xml",".rlc":"image/vnd.fujixerox.edmics-rlc",".rld":"application/resource-lists-diff+xml",".rm":"application/vnd.rn-realmedia",".rmi":"audio/midi",".rmp":"audio/x-pn-realaudio-plugin",".rms":"application/vnd.jcp.javame.midlet-rms",".rnc":"application/relax-ng-compact-syntax",".roff":"text/troff",".rpm":"application/x-rpm",".rpss":"application/vnd.nokia.radio-presets",".rpst":"application/vnd.nokia.radio-preset",".rq":"application/sparql-query",".rs":"application/rls-services+xml",".rsd":"application/rsd+xml",".rss":"application/rss+xml",".rtf":"application/rtf",".rtx":"text/richtext",".s":"text/x-asm",".saf":"application/vnd.yamaha.smaf-audio",".sbml":"application/sbml+xml",".sc":"application/vnd.ibm.secure-container",".scd":"application/x-msschedule",".scm":"application/vnd.lotus-screencam",".scq":"application/scvp-cv-request",".scs":"application/scvp-cv-response",".scurl":"text/vnd.curl.scurl",".sda":"application/vnd.stardivision.draw",".sdc":"application/vnd.stardivision.calc",".sdd":"application/vnd.stardivision.impress",".sdkd":"application/vnd.solent.sdkm+xml",".sdkm":"application/vnd.solent.sdkm+xml",".sdp":"application/sdp",".sdw":"application/vnd.stardivision.writer",".see":"application/vnd.seemail",".seed":"application/vnd.fdsn.seed",".sema":"application/vnd.sema",".semd":"application/vnd.semd",".semf":"application/vnd.semf",".ser":"application/java-serialized-object",".setpay":"application/set-payment-initiation",".setreg":"application/set-registration-initiation",".sfd-hdstx":"application/vnd.hydrostatix.sof-data",".sfs":"application/vnd.spotfire.sfs",".sgl":"application/vnd.stardivision.writer-global",".sgm":"text/sgml",".sgml":"text/sgml",".sh":"application/x-sh",".shar":"application/x-shar",".shf":"application/shf+xml",".si":"text/vnd.wap.si",".sic":"application/vnd.wap.sic",".sig":"application/pgp-signature",".silo":"model/mesh",".sis":"application/vnd.symbian.install",".sisx":"application/vnd.symbian.install",".sit":"application/x-stuffit",".sitx":"application/x-stuffitx",".skd":"application/vnd.koan",".skm":"application/vnd.koan",".skp":"application/vnd.koan",".skt":"application/vnd.koan",".sl":"text/vnd.wap.sl",".slc":"application/vnd.wap.slc",".sldm":"application/vnd.ms-powerpoint.slide.macroenabled.12",".sldx":"application/vnd.openxmlformats-officedocument.presentationml.slide",".slt":"application/vnd.epson.salt",".smf":"application/vnd.stardivision.math",".smi":"application/smil+xml",".smil":"application/smil+xml",".snd":"audio/basic",".snf":"application/x-font-snf",".so":"application/octet-stream",".spc":"application/x-pkcs7-certificates",".spf":"application/vnd.yamaha.smaf-phrase",".spl":"application/x-futuresplash",".spot":"text/vnd.in3d.spot",".spp":"application/scvp-vp-response",".spq":"application/scvp-vp-request",".spx":"audio/ogg",".src":"application/x-wais-source",".srx":"application/sparql-results+xml",".sse":"application/vnd.kodak-descriptor",".ssf":"application/vnd.epson.ssf",".ssml":"application/ssml+xml",".stc":"application/vnd.sun.xml.calc.template",".std":"application/vnd.sun.xml.draw.template",".stf":"application/vnd.wt.stf",".sti":"application/vnd.sun.xml.impress.template",".stk":"application/hyperstudio",".stl":"application/vnd.ms-pki.stl",".str":"application/vnd.pg.format",".stw":"application/vnd.sun.xml.writer.template",".sus":"application/vnd.sus-calendar",".susp":"application/vnd.sus-calendar",".sv4cpio":"application/x-sv4cpio",".sv4crc":"application/x-sv4crc",".svd":"application/vnd.svd",".svg":"image/svg+xml",".svgz":"image/svg+xml",".swa":"application/x-director",".swf":"application/x-shockwave-flash",".swi":"application/vnd.arastra.swi",".sxc":"application/vnd.sun.xml.calc",".sxd":"application/vnd.sun.xml.draw",".sxg":"application/vnd.sun.xml.writer.global",".sxi":"application/vnd.sun.xml.impress",".sxm":"application/vnd.sun.xml.math",".sxw":"application/vnd.sun.xml.writer",".t":"text/troff",".tao":"application/vnd.tao.intent-module-archive",".tar":"application/x-tar",".tcap":"application/vnd.3gpp2.tcap",".tcl":"application/x-tcl",".teacher":"application/vnd.smart.teacher",".tex":"application/x-tex",".texi":"application/x-texinfo",".texinfo":"application/x-texinfo",".text":"text/plain",".tfm":"application/x-tex-tfm",".tgz":"application/x-gzip",".tif":"image/tiff",".tiff":"image/tiff",".tmo":"application/vnd.tmobile-livetv",".torrent":"application/x-bittorrent",".tpl":"application/vnd.groove-tool-template",".tpt":"application/vnd.trid.tpt",".tr":"text/troff",".tra":"application/vnd.trueapp",".trm":"application/x-msterminal",".tsv":"text/tab-separated-values",".ttc":"application/x-font-ttf",".ttf":"application/x-font-ttf",".twd":"application/vnd.simtech-mindmapper",".twds":"application/vnd.simtech-mindmapper",".txd":"application/vnd.genomatix.tuxedo",".txf":"application/vnd.mobius.txf",".txt":"text/plain",".u32":"application/x-authorware-bin",".udeb":"application/x-debian-package",".ufd":"application/vnd.ufdl",".ufdl":"application/vnd.ufdl",".umj":"application/vnd.umajin",".unityweb":"application/vnd.unity",".uoml":"application/vnd.uoml+xml",".uri":"text/uri-list",".uris":"text/uri-list",".urls":"text/uri-list",".ustar":"application/x-ustar",".utz":"application/vnd.uiq.theme",".uu":"text/x-uuencode",".vcd":"application/x-cdlink",".vcf":"text/x-vcard",".vcg":"application/vnd.groove-vcard",".vcs":"text/x-vcalendar",".vcx":"application/vnd.vcx",".vis":"application/vnd.visionary",".viv":"video/vnd.vivo",".vor":"application/vnd.stardivision.writer",".vox":"application/x-authorware-bin",".vrml":"model/vrml",".vsd":"application/vnd.visio",".vsf":"application/vnd.vsf",".vss":"application/vnd.visio",".vst":"application/vnd.visio",".vsw":"application/vnd.visio",".vtu":"model/vnd.vtu",".vxml":"application/voicexml+xml",".w3d":"application/x-director",".webm":"video/webm",".wad":"application/x-doom",".wav":"audio/x-wav",".wax":"audio/x-ms-wax",".wbmp":"image/vnd.wap.wbmp",".wbs":"application/vnd.criticaltools.wbs+xml",".wbxml":"application/vnd.wap.wbxml",".wcm":"application/vnd.ms-works",".wdb":"application/vnd.ms-works",".wiz":"application/msword",".wks":"application/vnd.ms-works",".wm":"video/x-ms-wm",".wma":"audio/x-ms-wma",".wmd":"application/x-ms-wmd",".wmf":"application/x-msmetafile",".wml":"text/vnd.wap.wml",".wmlc":"application/vnd.wap.wmlc",".wmls":"text/vnd.wap.wmlscript",".wmlsc":"application/vnd.wap.wmlscriptc",".wmv":"video/x-ms-wmv",".wmx":"video/x-ms-wmx",".wmz":"application/x-ms-wmz",".wpd":"application/vnd.wordperfect",".wpl":"application/vnd.ms-wpl",".wps":"application/vnd.ms-works",".wqd":"application/vnd.wqd",".wri":"application/x-mswrite",".wrl":"model/vrml",".wsdl":"application/wsdl+xml",".wspolicy":"application/wspolicy+xml",".wtb":"application/vnd.webturbo",".wvx":"video/x-ms-wvx",".x32":"application/x-authorware-bin",".x3d":"application/vnd.hzn-3d-crossword",".xap":"application/x-silverlight-app",".xar":"application/vnd.xara",".xbap":"application/x-ms-xbap",".xbd":"application/vnd.fujixerox.docuworks.binder",".xbm":"image/x-xbitmap",".xdm":"application/vnd.syncml.dm+xml",".xdp":"application/vnd.adobe.xdp+xml",".xdw":"application/vnd.fujixerox.docuworks",".xenc":"application/xenc+xml",".xer":"application/patch-ops-error+xml",".xfdf":"application/vnd.adobe.xfdf",".xfdl":"application/vnd.xfdl",".xht":"application/xhtml+xml",".xhtml":"application/xhtml+xml",".xhvml":"application/xv+xml",".xif":"image/vnd.xiff",".xla":"application/vnd.ms-excel",".xlam":"application/vnd.ms-excel.addin.macroenabled.12",".xlb":"application/vnd.ms-excel",".xlc":"application/vnd.ms-excel",".xlm":"application/vnd.ms-excel",".xls":"application/vnd.ms-excel",".xlsb":"application/vnd.ms-excel.sheet.binary.macroenabled.12",".xlsm":"application/vnd.ms-excel.sheet.macroenabled.12",".xlsx":"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",".xlt":"application/vnd.ms-excel",".xltm":"application/vnd.ms-excel.template.macroenabled.12",".xltx":"application/vnd.openxmlformats-officedocument.spreadsheetml.template",".xlw":"application/vnd.ms-excel",".xml":"application/xml",".xo":"application/vnd.olpc-sugar",".xop":"application/xop+xml",".xpdl":"application/xml",".xpi":"application/x-xpinstall",".xpm":"image/x-xpixmap",".xpr":"application/vnd.is-xpr",".xps":"application/vnd.ms-xpsdocument",".xpw":"application/vnd.intercon.formnet",".xpx":"application/vnd.intercon.formnet",".xsl":"application/xml",".xslt":"application/xslt+xml",".xsm":"application/vnd.syncml+xml",".xspf":"application/xspf+xml",".xul":"application/vnd.mozilla.xul+xml",".xvm":"application/xv+xml",".xvml":"application/xv+xml",".xwd":"image/x-xwindowdump",".xyz":"chemical/x-xyz",".zaz":"application/vnd.zzazz.deck+xml",".zip":"application/zip",".zir":"application/vnd.zul",".zirz":"application/vnd.zul",".zmm":"application/vnd.handheld-entertainment+xml"},wh=[".sh",".exe",".app",".bat",".cmd",".msi",".apk",".jar",".py",".js",".cron",".php",".asp"],Lz=Object.keys(qc);import*as vh from"zod";var kz=vh.custom().refine(n=>n&&n.length>0).refine(n=>n&&n[0]instanceof File,{message:"Please upload a valid file."});import{z as rr}from"zod";var _z=rr.object({id:rr.string(),name:rr.string(),createdAt:rr.coerce.date(),createdBy:rr.string(),updatedAt:rr.coerce.date(),updatedBy:rr.string().nullable(),organizationId:rr.string()});import{z as W}from"zod";import{z as Ke}from"zod";var bt=Ke.object({id:Ke.string(),name:ms,baseUrl:hs,description:Ke.string().optional().nullish(),schemaVersion:Ke.string(),advanced:Co,retries:Ke.number(),envs:Ke.array(cs).nullish(),parameters:ls.nullish(),disabled:Ke.boolean().optional(),labels:Ke.array(Ke.string()).optional().catch([])}),jz=bt.pick({name:!0,description:!0,baseUrl:!0,retries:!0,disabled:!0,advanced:!0,parameters:!0}),lR=Ke.object({labels:Ke.array(Ke.string()).optional(),outputs:Dm.nullish()}),Kt=bt.merge(lR),cR=Ke.object({createdAt:Ke.coerce.date(),updatedAt:Ke.coerce.date(),updatedBy:Ke.string().nullable(),schedule:Ro,notification:Ao,createdBy:Ke.string(),organizationId:Ke.string(),folderId:Ke.string().nullable().optional()}),dR=bt.merge(cR),$z=dR.merge(So),Zi=bt.merge(So),Gz=bt.merge(Cr);var Th=W.object({platformSep:W.string(),fullPathSegments:W.string().array(),relativePath:W.string().describe("path relative to the root test directory, i.e. my-folder/my-test.yaml"),fileName:W.string().describe("base name of the file including the extension, e.g. my-module.module.yaml"),lastModified:W.coerce.date(),createdAt:W.coerce.date()}),Zz=W.array(Th.extend({id:W.string(),name:W.string(),description:W.string().optional(),labels:W.string().array().optional()})),Qz=W.array(Th.extend({id:W.string(),name:W.string(),description:W.string().optional(),content:uc})),eH=Zi.merge(Kt),xh=W.object({schemaVersion:W.string(),stepLists:So}),Eh=Kt.partial().merge(bt.pick({id:!0})),Ch=W.object({name:W.string(),description:W.string().optional(),baseUrl:W.string().url().optional(),environment:W.string().optional(),browserType:W.nativeEnum(Dn).optional(),viewport:as.optional(),folderPath:W.string().optional()}),tH=Zi.merge(W.object({relativeFilePath:W.string().describe("relative to project root")})),Rh=W.object({name:W.string()}),nH=W.object({relativeFilePath:W.string()}),Ah=W.object({name:W.string(),description:W.string(),enabled:W.boolean(),steps:W.lazy(()=>Ae.array()),testFilePath:W.string().describe("relative to the project root"),folderPath:W.string().optional().describe("user selected folder path")}),Ih=W.object({description:W.string(),enabled:W.boolean()}).partial();var rH=W.array(Am),Ph=W.object({defaultEnv:W.string().optional().describe("name of the default env, or undefined to unset")}),Lh=W.object({configFilePath:W.string().describe("full path on disk")}),oH=W.string().array(),iH=W.object({message:W.string(),newRelativeTestPath:W.string().optional()});var ws=["node_modules","dist","bin",".git",".npm",".next","out",".yarn","__pycache__","build",".env",".venv","venv","env","wheels"],Oh=ws.map(n=>`**/${n}/**`);import Tn from"chalk";var pR=["app","version","env","namespace","host"];function ze(n){let e=n.bindings()??{},t={};for(let r of Object.keys(e)){let o=e[r];!pR.includes(r)&&typeof o=="string"&&(t[r]=o)}return t}var Kc=class n{minLogLevel;logBindings;constructor(e,t){this.minLogLevel=e,this.logBindings=t}logWithLevel(e,t,...r){if(e<this.minLogLevel)return;let o;Array.isArray(r[0])?(o=r[0],r=r.slice(1)):typeof r[0]=="object"&&!(r[0]instanceof Error)&&Object.entries(r[0]).length&&(o={...r[0],...this.logBindings},r=r.slice(1));let i=[];if(i.push(...r),console.log(t(...i)),o&&!Array.isArray(o)){let a=Object.entries(o);for(let[s,l]of a){let c=l;l instanceof Error?c=l.message:typeof l=="object"&&(c=JSON.stringify(l,void 0,2),c=c.split(`
11
11
  `).map((d,p)=>p>0?` ${d}`:d).join(`
12
12
  `)),console.log(t(` ${s}:`,c))}}else if(o)for(let a of o){let s=a;typeof a=="object"&&(s=JSON.stringify(a,void 0,2),s=s.split(`
13
13
  `).map((l,c)=>c>0?` ${l}`:l).join(`
14
- `)),console.log(" ",t(s))}}setMinLevel(e){this.minLogLevel=e}log(...e){this.logWithLevel(1,Tn.reset,...e)}info(...e){this.logWithLevel(1,Tn.white,...e)}debug(...e){this.logWithLevel(0,Tn.dim,...e)}warn(...e){this.logWithLevel(2,Tn.yellow,...e)}error(...e){this.logWithLevel(3,Tn.red,...e)}success(...e){this.logWithLevel(4,Tn.green,...e)}dimmed(...e){this.logWithLevel(1,Tn.dim,...e)}underline(...e){this.logWithLevel(2,Tn.underline,...e)}bold(...e){this.logWithLevel(2,Tn.bold,...e)}grey(...e){this.logWithLevel(0,Tn.grey,...e)}child(e){return new n(this.minLogLevel,{...this.logBindings,...e})}flush(){}bindings(){return this.logBindings}},y=new Kc(1,{}),kr={info:()=>{},error:()=>{},debug:()=>{},warn:()=>{},child:()=>kr,flush:()=>{},bindings:()=>({})},vs={},Mr=({logger:n,logKey:e,maxCount:t,intervalMs:r},o,i,...a)=>{let s=vs[e];s?clearTimeout(s.timer):(s={count:0,totalCount:0},vs[e]=s),s.totalCount++,s.count<t&&(s.count++,n.debug(o,i,...a)),s.timer=setTimeout(()=>{let l=vs[e];l?.totalCount!==l?.count&&n.debug({logKey:e,totalCount:l?.totalCount,count:l?.count},`Debug logs were rate-limited for ${e}`),delete vs[e]},r)};import{z as Qe}from"zod";var kh=Qe.object({id:Qe.string(),createdAt:Qe.coerce.date(),createdBy:Qe.string(),organizationId:Qe.string(),name:Qe.string(),description:Qe.string().nullish(),enabled:Qe.boolean(),schemaVersion:Qe.string().describe("Schema version for steps"),parameters:Qe.string().array().nullish().describe("Parameter list"),defaultParameters:Qe.record(Qe.string(),Qe.string()).nullish(),defaultCacheKey:Qe.string().nullish(),defaultCacheTtl:Qe.number().nullish(),defaultCacheAllInvocations:Qe.boolean().nullish(),autoAuth:Qe.boolean().nullish(),advanced:lc.nullish()}),yH=kh.extend({steps:Qe.lazy(()=>Se.array())}),Mh=5*60*1e3,Yc=Rt.merge(kh.omit({id:!0,createdAt:!0,createdBy:!0,organizationId:!0,enabled:!0}));import{formatInTimeZone as vH}from"date-fns-tz";import{z as Pe}from"zod";var Jc=Pe.object({failureRecovery:Pe.boolean().optional(),aiAction:Pe.boolean().optional(),stepLintSuggestions:Pe.boolean().optional(),agentConfig:Pe.record(Pe.string(),Pe.string()).optional()}),Nh=Pe.object({fakerConstantSeed:Pe.boolean().optional()}),EH=Pe.object({ai:Jc.optional(),githubAppInstallationId:Pe.number().nullish(),githubReleaseAppInstallationId:Pe.number().nullish(),gitlabAppAccessToken:Pe.string().nullish().optional(),gitlabAppBaseUrl:Pe.string().nullish().optional(),qaseAccessToken:Pe.string().nullish().optional(),browser:Pe.object({autoFollowNewTabs:Pe.boolean().optional(),showZeroOpacityElements:Pe.boolean().optional()}).optional()}),CH=Pe.object({globalOverrides:Pe.record(Pe.string()).optional(),agentConfig:Pe.record(Pe.string(),Pe.string()).optional()});import*as E from"zod";var _h="x-momentic-cli-version",Dh="x-momentic-main-branch-name",Fh="x-momentic-branch-name",Uh="x-momentic-commit-timestamp",Bh="x-momentic-last-commit-on-main",zh="x-momentic-last-commit-on-main-timestamp",BH=E.object({error:E.boolean(),reason:E.string(),message:E.string()}),zH=Vt.merge(_c),Hh=Ua,HH=Vt.merge(_c);var jH=Vt.merge(qm).extend({useConsensus:E.boolean().optional(),attemptNumber:E.number().optional()}),Xc=Cu,$H=Vt.merge(Km),jh=zu,GH=Vt.merge(Gm),$h=Bu,WH=Vt.merge(Wm),Gh=Uu,VH=Vt.merge(Vm);var qH=E.object({testPaths:E.string().array().describe("can be either hyphenated, lowercase test names or UUIDs"),env:E.string().optional(),all:E.boolean().optional(),urlOverride:E.string().optional(),customHeaders:E.record(E.string(),E.string()).optional(),testInputMatrix:E.record(E.string(),E.string()).array().optional()}),Wh=E.object({queuedTests:E.unknown().array(),runIds:E.string().uuid().array(),runGroupId:E.string().optional()}),Vh=Zi,qh=E.string().array(),KH=E.union([E.object({paths:E.string().array().describe("run specific test paths (e.g. todo-test)"),all:E.boolean().describe("run all tests").optional()}),E.object({path:E.string().describe("deprecated; present for backcompat")})]),Kh=E.object({tests:E.record(E.string().describe("Test name"),E.string().describe("Test YAML")),modules:E.record(E.string().describe("Module name"),E.string().describe("Module YAML"))}),uR=E.object({test:E.string().describe("test YAML"),modules:E.record(E.string().describe("moduleId"),E.string().describe("module YAML"))}),YH=uR.array(),JH=E.object({testId:E.string(),schemaVersion:E.string()}).merge(Cr),XH=E.object({entries:E.array(gc),testId:E.string()}),ZH=E.object({testId:E.string(),uniqueKeys:E.string().array()}),QH=E.object({steps:E.array(E.record(E.unknown())),testId:E.string(),schemaVersion:E.string(),organizationId:E.string()}),Yh=Fu,Jh=E.object({trigger:E.nativeEnum(Wt),status:E.nativeEnum(ie),startedAt:E.coerce.date().optional(),gitCommitSha:E.string().optional(),gitCommitShaShort:E.string().optional(),gitCommitTimestamp:E.coerce.date().optional(),gitBranchName:E.string().optional(),gitOriginUrl:E.string().optional(),gitCommitMessage:E.string().optional(),gitCommitAuthorName:E.string().optional(),githubRepository:E.string().optional(),gitlabProjectPath:E.string().optional(),pipelineId:E.string().optional(),cliVersion:E.string().optional()}),Xh=E.object({id:E.string()}),Zh=E.object({status:E.nativeEnum(ie),updatedAt:E.coerce.date().optional(),finishedAt:E.coerce.date().optional()}),Qh=E.object({stepsSnapshot:E.array(E.record(E.unknown())).optional(),runGroupId:E.string().optional(),testId:E.string(),testName:E.string(),resolvedBaseUrl:E.string().optional(),environmentName:E.string().optional(),labels:E.array(E.string()).optional(),cliVersion:E.string().optional(),trigger:E.nativeEnum(Wt),schemaVersion:E.string().optional(),section:E.nativeEnum(ds).optional()}),eg=E.object({id:E.string()}),mR=Nc.pick({id:!0,status:!0,testName:!0,testId:!0,test:!0,failureReason:!0,failureDetails:!0}),tg=mR.array(),ng=Nc.pick({startedAt:!0,finishedAt:!0,updatedAt:!0,results:!0,beforeResults:!0,afterResults:!0,status:!0,failureDetails:!0,failureReason:!0,resolvedBaseUrl:!0,environmentName:!0,labels:!0,cliVersion:!0,resolvedInputs:!0,attempts:!0,flake:!0}).partial(),rg=E.object({id:E.string()}),og=E.object({status:E.nativeEnum(ie),finishedAt:E.coerce.date().optional(),schemaVersion:E.string().optional().default("1.0.19"),results:E.record(E.string(),E.unknown()).array().optional(),beforeResults:E.record(E.string(),E.unknown()).array().optional(),afterResults:E.record(E.string(),E.unknown()).array().optional()}),ej=E.object({screenshot:E.string()}),ig=E.object({key:E.string()}),ag=E.object({orgId:E.string(),userId:E.string()}),sg=E.array(Xa),lg=E.record(E.string(),E.union([E.string(),E.boolean()])),tj=E.object({paths:E.string().array(),env:E.string().optional(),urlOverride:E.string().optional(),customHeaders:E.record(E.string(),E.string()).optional()}),cg=E.object({suiteRunIds:E.string().array(),runGroupIds:E.string().array()}),nj=E.object({suiteRunIds:E.string().array()}),dg=jm.array(),rj=E.object({runGroupIds:E.string().array()}),Oo=E.object({uploadUrl:E.string()}),oj=Vt.merge(Ym),ij=Vt.merge(Xm),aj=Vt.merge(Jm),hR=E.object({testId:E.string().optional().default(""),testName:E.string().optional().default(""),suiteId:E.string().optional().default(""),suiteName:E.string().optional().default(""),creditsUsed:E.number().optional(),usedBy:E.string().optional()}),gR=E.object({transactionId:E.string(),timestamp:E.string(),event:E.nativeEnum(Vi),properties:hR}),sj=gR.array(),pg=Lm.omit({steps:!0}).extend({steps:E.array(E.record(E.string(),E.unknown())).describe("unparsed ResolvedStep[]")}),lj=E.object({limit:E.number().max(10).optional(),afterTime:E.number().optional()}),ug=Fm.array(),cj=E.object({applied:E.boolean().optional(),appliedAt:E.coerce.date().optional()}),dj=Vt.extend({chunks:Dc.array(),description:E.string().describe("Input to pass to AI"),type:E.union([E.literal("locator"),E.literal("assertion"),E.literal("ai-action")]),softTokenLimit:E.number(),hardTokenLimit:E.number()}),mg=Oo.extend({id:E.string()}),hg=E.object({runGroupId:E.string()});import{z as Le}from"zod";var gg=Le.object({orgId:Le.string(),cacheKeys:Le.string().array()}),mj=Le.object({keyParams:gg,clientMetadata:Le.string(),lockAcquisitionTimeoutMs:Le.number().optional()}),fg=Le.object({acquired:Le.boolean(),acquiredByMetadata:Le.string(),keyPrefix:Le.string()}),hj=Le.object({keyPrefix:Le.string(),result:Le.string(),ttlMs:Le.number()}),gj=Le.union([Le.object({keyPrefix:Le.string()}),gg]),fR=Le.object({remainingTtlMs:Le.number(),value:Le.string().nullish()}),fj=Le.object({results:Le.record(Le.string(),fR),activeLocks:Le.string().array()}),Sg=0,yg=5*60*1e3;import{z as sn}from"zod";var bg="test",wg="module",Ot=(t=>(t.TEST=`${bg}.yaml`,t.MODULE=`${wg}.yaml`,t))(Ot||{}),Ee=(t=>(t.TEST=`momentic/${bg}`,t.MODULE=`momentic/${wg}`,t))(Ee||{}),xj=bt.merge(Cr),Zc=Rt.extend({steps:sn.array(sn.record(sn.string(),sn.unknown())),schemaVersion:sn.string()}),Ej=Zc.extend({fileType:sn.literal(Ee.MODULE)}),Cj=sn.object({test:sn.string().describe("YAML for the test, including metadata and steps"),modules:sn.record(sn.string(),sn.string()).describe("Map of module name to YAML for the module")});import{z as at}from"zod";var SR=at.object({version:at.string(),json:at.record(at.unknown()),hash:at.string()}),vg=at.record(at.unknown()),Pj=at.object({newSvgs:at.array(SR),metadata:vg.optional()}),yR=at.object({version:at.string(),json:at.record(at.unknown()).nullish(),hash:at.string(),description:at.string().nullish(),metadata:vg.nullish()}),Tg=at.record(at.string().describe("icon hash"),yR);import{validator as Nj}from"@exodus/schemasafe";var xg=n=>{n.extraHeaders&&(n.extraHeaders=Object.fromEntries(Object.entries(n.extraHeaders).filter(([e,t])=>e.trim()&&t.trim())))};import{z as Vj}from"zod";import{z as Ye}from"zod";var Yj=Ye.object({repositoriesIndexed:Ye.boolean(),indexingInProgress:Ye.boolean(),indexesOutdated:Ye.boolean()}),Eg=(a=>(a.Queued="queued",a.InProgress="in_progress",a.Completed="completed",a.Waiting="waiting",a.Requested="requested",a.Pending="pending",a))(Eg||{}),Cg=(s=>(s.Success="success",s.Failure="failure",s.Neutral="neutral",s.Cancelled="cancelled",s.Skipped="skipped",s.TimedOut="timed_out",s.ActionRequired="action_required",s))(Cg||{}),Jj=Ye.object({name:Ye.string(),status:Ye.nativeEnum(Eg),conclusion:Ye.nativeEnum(Cg).nullable()}),Qc=Ye.object({sha:Ye.string(),message:Ye.string(),author:Ye.object({name:Ye.string().optional(),email:Ye.string().optional(),date:Ye.coerce.date().optional()}),committer:Ye.object({name:Ye.string().optional(),email:Ye.string().optional(),date:Ye.coerce.date().optional()})});import{z as _e}from"zod";var ed=_e.object({assertion:_e.string().describe("A human readable assertion that evaluates to either true or false depending on the state of the system.")}),bR=_e.object({instruction:_e.string().describe("Human readable instruction to execute the step. Instructions should only describe concrete actions that need to be taken. Any checks or assertions should be described in the preConditions, postConditions, or expectedResults."),expectedResults:ed.array().optional().describe("Human readable description of the expected results after the step is executed. Each expected result should contain a single assertion that evaluates to true or false.")}),Rg=bR.extend({subSteps:_e.lazy(()=>Rg.array().optional()).describe("More granular steps to be take to achieve the current step's higher level objective.")}),Ag=_e.object({name:_e.string().describe("Short name describing the test plan"),description:_e.string().nullish().transform(n=>n??void 0).describe("Longer form description of the high level goal of the test plan")}),Ig=Ag.extend({id:_e.string(),createdAt:_e.coerce.date(),updatedAt:_e.coerce.date(),updatedBy:_e.string(),createdBy:_e.string(),test:_e.object({id:_e.string(),name:_e.string()}).nullish().transform(n=>n??void 0)}),e$=Ig.extend({testGenRuns:_e.tuple([]).or(_e.tuple([_e.object({id:_e.string(),startedAt:_e.coerce.date(),status:_e.nativeEnum(ie)})]))}),Pg=_e.object({preConditions:ed.array().nullish().transform(n=>n??[]),postConditions:ed.array().nullish().transform(n=>n??[]),steps:Rg.array().nullish().transform(n=>n??[])}),t$=Ig.extend({plan:Pg.nullish().transform(n=>n??{preConditions:[],postConditions:[],steps:[]})}),wR=Ag.extend({plan:Pg.nullish().transform(n=>n??{preConditions:[],postConditions:[],steps:[]})}),n$=wR.array().nullish().transform(n=>n??[]);import{z as De}from"zod";var vR=De.object({step:Ae,status:De.nativeEnum(Te),startedAt:De.coerce.date(),finishedAt:De.coerce.date().optional(),healMetadata:De.object({healType:De.nativeEnum(Ui).or(De.literal("AI")),healedAt:De.coerce.date()}).optional(),beforeSnapshotId:De.string().uuid().optional(),afterSnapshotId:De.string().uuid().optional(),message:De.string().optional()}),p$=vR.extend({finishedAt:De.coerce.date().optional().transform(n=>n??new Date)}),TR=De.object({startedAt:De.coerce.date()}).merge(og).merge(rs),u$=TR.extend({finishedAt:De.coerce.date().optional().transform(n=>n??new Date)}),xR=ng.merge(Qh).extend({status:De.nativeEnum(ie),startedAt:De.coerce.date(),attempts:De.number()}),m$=xR.extend({finishedAt:De.coerce.date().optional().transform(n=>n??new Date)}),ER=Jh.merge(Zh).extend({startedAt:De.coerce.date(),cliVersion:De.string()}),td=ER.extend({updatedAt:De.coerce.date().optional().transform(n=>n??new Date),finishedAt:De.coerce.date().optional().transform(n=>n??new Date)});import CR from"semver";import{z as RR}from"zod";var S$=RR.string().refine(n=>CR.valid(n),{message:"must be a valid semver string"});var Ts=class{async resolveStepCacheEntries(){}async saveStepCacheEntries(){}};function nd(n){let e={parentChain:[]};return xs(n,e),e}function xs(n,e){let{onPresetAction:t,onSimpleStepContainer:r,onConditional:o,earlyStop:i}=n;for(let a of n.steps)switch(a.type){case"PRESET_ACTION":if(t(a,e)&&i)return!0;break;case"CONDITIONAL":if(o?.(a,e)&&i)return!0;e.parentChain.push(a);for(let l of a.blocks)if(t(l.assertion,e)&&i||xs({...n,steps:l.steps},e)&&i)return!0;if(xs({...n,steps:a.elseSteps??[]},e)&&i)return!0;e.parentChain.pop();break;case"RESOLVED_MODULE":case"IFRAME":case"SECTION":case"AI_ACTION":if(r?.(a,e)&&i)return!0;if(a.steps){if(e.parentChain.push(a),xs({...n,steps:a.steps},e)&&i)return!0;e.parentChain.pop()}break;case"AI_ACTION_DYNAMIC":{if(r?.(a,e)&&i)return!0;break}default:return(l=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(a)}}function Lg(n,e,t,r){let o=Array.from(e),i=Array.from(r);for(let s=0;s<o.length;s++){if(o[s]!==i[s])return!1;i.shift()}return!!AR([n],t,i).result}function AR(n,e,t=[]){let r,o=[],i=(a,s)=>{let l=JSON.stringify(s.parentChain.map(d=>d.id)),c=t.length===0?!0:JSON.stringify(t)===l;return a.id===e&&c?(r=a,o=s.parentChain,!0):!1};return nd({steps:n,earlyStop:!0,onPresetAction:i,onConditional:i,onSimpleStepContainer:i}),{result:r,parentChain:o}}function Og(n,e){e(n);for(let t in n){let r=n[t];r&&(Array.isArray(r)?Es(r,e):typeof r=="object"&&Og(r,e))}}function Es(n,e){for(let t of n)t&&(Array.isArray(t)?Es(t,e):typeof t=="object"&&Og(t,e))}import{cloneDeep as kg}from"lodash-es";import{v4 as rd}from"uuid";async function Yt(n){let e=new Map,t=new Set,r=kg(n.stepLists.steps),o=await Nr({...n,steps:r,moduleStepParents:[],moduleIdParents:[],moduleIdReplacements:e,seenModules:t}),i={stepsToSave:{steps:o.stepsToSave,beforeSteps:void 0,afterSteps:void 0},cachesToSave:o.cachesToSave,moduleUpdates:o.moduleUpdates};for(let a of["beforeSteps","afterSteps"]){let s=kg(n.stepLists[a]);if(!s)continue;let l=await Nr({...n,steps:s,moduleStepParents:[],moduleIdParents:[],moduleIdReplacements:e,seenModules:t});i.cachesToSave.push(...l.cachesToSave),i.moduleUpdates.push(...l.moduleUpdates),i.stepsToSave[a]=l.stepsToSave}return i}async function Nr({steps:n,...e}){let{seenModules:t,cacheCreationParams:r,moduleIdParents:o,moduleStepParents:i,moduleIdReplacements:a,shouldCreateNewModuleId:s,createNewCacheIds:l}=e,c={cachesToSave:[],stepsToSave:[],moduleUpdates:[]};for(let d of n)switch(delete d.index,delete d.aiSuggested,d.id=l?rd():d.id,d.type){case"PRESET_ACTION":{let m=d.command;m.id=l?rd():m.id,Ng(m),"cache"in m&&m.cache&&(r&&(c.cachesToSave=c.cachesToSave.concat(Mg({id:m.id,orgId:r.orgId,testId:r.testId,value:Tr.parse(m),moduleIdParents:o,moduleStepParents:i,skipIntermediateEntries:e.skipCacheIntermediateEntries}))),delete m.cache),m.thoughts&&delete m.thoughts,c.stepsToSave.push({...d,command:m});break}case"RESOLVED_MODULE":{let m=l?rd():d.id,u=d.moduleId;a.has(u)?u=a.get(u):s!==void 0&&(u=await s(d),a.set(d.moduleId,u));let{cachesToSave:h,stepsToSave:g,moduleUpdates:f}=await Nr({...e,steps:d.steps,cacheCreationParams:r?{...r}:void 0,createNewCacheIds:!1,moduleStepParents:[...i,m],moduleIdParents:[...o,u],skipCacheIntermediateEntries:l});c.moduleUpdates=c.moduleUpdates.concat(f),c.cachesToSave=c.cachesToSave.concat(h),t.has(u)||(t.add(u),c.moduleUpdates.push({...Rt.parse(d),steps:Se.array().parse(g),moduleId:u}));let S={type:"MODULE",moduleId:u,inputs:d.inputs,id:m,skipped:d.skipped,cacheConfig:d.cacheConfig,envKey:d.envKey};c.stepsToSave.push(S);break}case"AI_ACTION":{if(!d.steps){c.stepsToSave.push(d);break}let{stepsToSave:m,cachesToSave:u}=await Nr({...e,steps:d.steps});try{d.steps=Ct.array().parse(m)}catch(h){throw new Error(`Only preset actions are allowed in AI actions at the moment: ${h}`)}c.stepsToSave.push(d),c.cachesToSave=c.cachesToSave.concat(u);break}case"AI_ACTION_DYNAMIC":{c.stepsToSave.push(d);break}case"CONDITIONAL":{let m=[];for(let h of d.blocks){let{stepsToSave:g,cachesToSave:f,moduleUpdates:S}=await Nr({...e,steps:h.steps});m.push({...h,steps:g}),c.cachesToSave=c.cachesToSave.concat(f),c.moduleUpdates=c.moduleUpdates.concat(S)}let u={...d,elseSteps:void 0,blocks:m};if(d.elseSteps){let{stepsToSave:h,cachesToSave:g,moduleUpdates:f}=await Nr({...e,steps:d.elseSteps});u.elseSteps=h,c.cachesToSave=c.cachesToSave.concat(g),c.moduleUpdates=c.moduleUpdates.concat(f)}c.stepsToSave.push(u);break}case"IFRAME":case"SECTION":{let{stepsToSave:m,cachesToSave:u,moduleUpdates:h}=await Nr({...e,steps:d.steps}),g={...d,steps:m};c.moduleUpdates=c.moduleUpdates.concat(h),c.stepsToSave.push(g),c.cachesToSave=c.cachesToSave.concat(u);break}default:return(m=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(d)}return c}function ko({steps:n,topLevel:e=!0,...t}){let{stepCacheEntries:r,logger:o,keyPrefix:i}=t,a=[],s=[],l=[],c=0,d=(m,u)=>{try{let h=Tr.parse(u.value);if(h.type!==m.type){o.warn({parsedCacheEntry:h,command:m},"Not using step cache due to type mismatch"),s.push(u.key);return}m.cache=h.cache,a.push(u.key),l.push(u.uniqueKey)}catch(h){s.push(u.key),o.error({err:h,cacheEntry:u},"Not using step cache due to parsing error")}},p=(m,u)=>{let h=PR(m.id,u),g=h.find(f=>!!r[f]);g?d(m,r[g]):s.push(h[0])};for(let m of n)switch(m.type){case"RESOLVED_MODULE":{c+=m.steps.length;let{cacheKeysHit:h,cacheKeysMissed:g,uniqueKeysHit:f}=ko({...t,steps:m.steps,keyPrefix:i?`${i}:${m.id}`:m.id,topLevel:!1});a.push(...h),s.push(...g),l.push(...f);break}case"IFRAME":case"SECTION":case"AI_ACTION":{if(c+=m.steps?.length??0,!m.steps?.length)break;let{cacheKeysHit:h,cacheKeysMissed:g,uniqueKeysHit:f}=ko({...t,steps:m.steps,topLevel:!1});a.push(...h),s.push(...g),l.push(...f);break}case"AI_ACTION_DYNAMIC":continue;case"PRESET_ACTION":{if(!oc.includes(m.command.type)||(m.command.type==="TYPE"||m.command.type==="MOUSE_DRAG"||m.command.type==="VISUAL_DIFF"||m.command.type==="SCROLL_DOWN"||m.command.type==="SCROLL_UP"||m.command.type==="SCROLL_LEFT"||m.command.type==="SCROLL_RIGHT")&&!m.command.target||m.command.type==="ELEMENT_CHECK"&&m.command.assertion.type==="ELEMENT_EXISTENCE"&&m.command.assertion.negated||"cache"in m.command&&m.command.cache)continue;c++,p(m.command,i);break}case"CONDITIONAL":{for(let h of m.blocks){c++,p(h.assertion.command,i),c+=h.steps.length;let{cacheKeysHit:g,cacheKeysMissed:f,uniqueKeysHit:S}=ko({...t,steps:h.steps,topLevel:!1});a.push(...g),s.push(...f),l.push(...S)}if(m.elseSteps){c+=m.elseSteps.length;let{cacheKeysHit:h,cacheKeysMissed:g,uniqueKeysHit:f}=ko({...t,steps:m.elseSteps,topLevel:!1});a.push(...h),s.push(...g),l.push(...f)}break}default:return(h=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(m)}return e&&c&&s.length>0&&o.warn({totalSteps:c,cacheKeysMissed:s,cacheKeysHit:a,uniqueKeysHit:l,cacheEntries:r.length},"Step cache did not fully resolve"),{cacheKeysHit:a,cacheKeysMissed:s,uniqueKeysHit:l}}function _g(n,e){return e?`${e}:${n}`:n}function PR(n,e){let t=[],r=e?.split(":")??[];for(let o=r.length;o>=0;o--){let i=[...r.slice(o),n];t.push(i.join(":"))}return t.reverse(),t}function Mg(n){let{moduleStepParents:e=[],moduleIdParents:t=[]}=n;if(e.length!==t.length)throw new Error(`Invalid cache entry parent length: ${JSON.stringify(e)}
14
+ `)),console.log(" ",t(s))}}setMinLevel(e){this.minLogLevel=e}log(...e){this.logWithLevel(1,Tn.reset,...e)}info(...e){this.logWithLevel(1,Tn.white,...e)}debug(...e){this.logWithLevel(0,Tn.dim,...e)}warn(...e){this.logWithLevel(2,Tn.yellow,...e)}error(...e){this.logWithLevel(3,Tn.red,...e)}success(...e){this.logWithLevel(4,Tn.green,...e)}dimmed(...e){this.logWithLevel(1,Tn.dim,...e)}underline(...e){this.logWithLevel(2,Tn.underline,...e)}bold(...e){this.logWithLevel(2,Tn.bold,...e)}grey(...e){this.logWithLevel(0,Tn.grey,...e)}child(e){return new n(this.minLogLevel,{...this.logBindings,...e})}flush(){}bindings(){return this.logBindings}},y=new Kc(1,{}),kr={info:()=>{},error:()=>{},debug:()=>{},warn:()=>{},child:()=>kr,flush:()=>{},bindings:()=>({})},vs={},Mr=({logger:n,logKey:e,maxCount:t,intervalMs:r},o,i,...a)=>{let s=vs[e];s?clearTimeout(s.timer):(s={count:0,totalCount:0},vs[e]=s),s.totalCount++,s.count<t&&(s.count++,n.debug(o,i,...a)),s.timer=setTimeout(()=>{let l=vs[e];l?.totalCount!==l?.count&&n.debug({logKey:e,totalCount:l?.totalCount,count:l?.count},`Debug logs were rate-limited for ${e}`),delete vs[e]},r)};import{z as Qe}from"zod";var kh=Qe.object({id:Qe.string(),createdAt:Qe.coerce.date(),createdBy:Qe.string(),organizationId:Qe.string(),name:Qe.string(),description:Qe.string().nullish(),enabled:Qe.boolean(),schemaVersion:Qe.string().describe("Schema version for steps"),parameters:Qe.string().array().nullish().describe("Parameter list"),defaultParameters:Qe.record(Qe.string(),Qe.string()).nullish(),defaultCacheKey:Qe.string().nullish(),defaultCacheTtl:Qe.number().nullish(),defaultCacheAllInvocations:Qe.boolean().nullish(),autoAuth:Qe.boolean().nullish(),advanced:lc.nullish()}),yH=kh.extend({steps:Qe.lazy(()=>Se.array())}),Mh=5*60*1e3,Yc=Rt.merge(kh.omit({id:!0,createdAt:!0,createdBy:!0,organizationId:!0,enabled:!0}));import{formatInTimeZone as vH}from"date-fns-tz";import{z as Pe}from"zod";var Jc=Pe.object({failureRecovery:Pe.boolean().optional(),aiAction:Pe.boolean().optional(),stepLintSuggestions:Pe.boolean().optional(),agentConfig:Pe.record(Pe.string(),Pe.string()).optional()}),Nh=Pe.object({fakerConstantSeed:Pe.boolean().optional()}),EH=Pe.object({ai:Jc.optional(),githubAppInstallationId:Pe.number().nullish(),githubReleaseAppInstallationId:Pe.number().nullish(),gitlabAppAccessToken:Pe.string().nullish().optional(),gitlabAppBaseUrl:Pe.string().nullish().optional(),qaseAccessToken:Pe.string().nullish().optional(),browser:Pe.object({autoFollowNewTabs:Pe.boolean().optional(),showZeroOpacityElements:Pe.boolean().optional()}).optional()}),CH=Pe.object({globalOverrides:Pe.record(Pe.string()).optional(),agentConfig:Pe.record(Pe.string(),Pe.string()).optional()});import*as E from"zod";var _h="x-momentic-cli-version",Dh="x-momentic-main-branch-name",Fh="x-momentic-branch-name",Uh="x-momentic-commit-timestamp",Bh="x-momentic-last-commit-on-main",zh="x-momentic-last-commit-on-main-timestamp",BH=E.object({error:E.boolean(),reason:E.string(),message:E.string()}),zH=Vt.merge(_c),Hh=Ua,HH=Vt.merge(_c);var jH=Vt.merge(qm).extend({useConsensus:E.boolean().optional(),attemptNumber:E.number().optional()}),Xc=Cu,$H=Vt.merge(Km),jh=zu,GH=Vt.merge(Gm),$h=Bu,WH=Vt.merge(Wm),Gh=Uu,VH=Vt.merge(Vm);var qH=E.object({testPaths:E.string().array().describe("can be either hyphenated, lowercase test names or UUIDs"),env:E.string().optional(),all:E.boolean().optional(),urlOverride:E.string().optional(),customHeaders:E.record(E.string(),E.string()).optional(),testInputMatrix:E.record(E.string(),E.string()).array().optional()}),Wh=E.object({queuedTests:E.unknown().array(),runIds:E.string().uuid().array(),runGroupId:E.string().optional()}),Vh=Zi,qh=E.string().array(),KH=E.union([E.object({paths:E.string().array().describe("run specific test paths (e.g. todo-test)"),all:E.boolean().describe("run all tests").optional()}),E.object({path:E.string().describe("deprecated; present for backcompat")})]),Kh=E.object({tests:E.record(E.string().describe("Test name"),E.string().describe("Test YAML")),modules:E.record(E.string().describe("Module name"),E.string().describe("Module YAML"))}),uR=E.object({test:E.string().describe("test YAML"),modules:E.record(E.string().describe("moduleId"),E.string().describe("module YAML"))}),YH=uR.array(),JH=E.object({testId:E.string(),schemaVersion:E.string()}).merge(Cr),XH=E.object({entries:E.array(gc),testId:E.string()}),ZH=E.object({testId:E.string(),uniqueKeys:E.string().array()}),QH=E.object({steps:E.array(E.record(E.unknown())),testId:E.string(),schemaVersion:E.string(),organizationId:E.string()}),Yh=Fu,Jh=E.object({trigger:E.nativeEnum(Wt),status:E.nativeEnum(ie),startedAt:E.coerce.date().optional(),gitCommitSha:E.string().optional(),gitCommitShaShort:E.string().optional(),gitCommitTimestamp:E.coerce.date().optional(),gitBranchName:E.string().optional(),gitOriginUrl:E.string().optional(),gitCommitMessage:E.string().optional(),gitCommitAuthorName:E.string().optional(),githubRepository:E.string().optional(),gitlabProjectPath:E.string().optional(),pipelineId:E.string().optional(),cliVersion:E.string().optional()}),Xh=E.object({id:E.string()}),Zh=E.object({status:E.nativeEnum(ie),updatedAt:E.coerce.date().optional(),finishedAt:E.coerce.date().optional()}),Qh=E.object({stepsSnapshot:E.array(E.record(E.unknown())).optional(),runGroupId:E.string().optional(),testId:E.string(),testName:E.string(),resolvedBaseUrl:E.string().optional(),environmentName:E.string().optional(),labels:E.array(E.string()).optional(),cliVersion:E.string().optional(),trigger:E.nativeEnum(Wt),schemaVersion:E.string().optional(),section:E.nativeEnum(ds).optional()}),eg=E.object({id:E.string()}),mR=Nc.pick({id:!0,status:!0,testName:!0,testId:!0,test:!0,failureReason:!0,failureDetails:!0}),tg=mR.array(),ng=Nc.pick({startedAt:!0,finishedAt:!0,updatedAt:!0,results:!0,beforeResults:!0,afterResults:!0,status:!0,failureDetails:!0,failureReason:!0,resolvedBaseUrl:!0,environmentName:!0,labels:!0,cliVersion:!0,resolvedInputs:!0,attempts:!0,flake:!0}).partial(),rg=E.object({id:E.string()}),og=E.object({status:E.nativeEnum(ie),finishedAt:E.coerce.date().optional(),schemaVersion:E.string().optional().default("1.0.19"),results:E.record(E.string(),E.unknown()).array().optional(),beforeResults:E.record(E.string(),E.unknown()).array().optional(),afterResults:E.record(E.string(),E.unknown()).array().optional()}),ej=E.object({screenshot:E.string()}),ig=E.object({key:E.string()}),ag=E.object({orgId:E.string(),userId:E.string()}),sg=E.array(Xa),lg=E.record(E.string(),E.union([E.string(),E.boolean()])),tj=E.object({paths:E.string().array(),env:E.string().optional(),urlOverride:E.string().optional(),customHeaders:E.record(E.string(),E.string()).optional()}),cg=E.object({suiteRunIds:E.string().array(),runGroupIds:E.string().array()}),nj=E.object({suiteRunIds:E.string().array()}),dg=jm.array(),rj=E.object({runGroupIds:E.string().array()}),Lo=E.object({uploadUrl:E.string()}),oj=Vt.merge(Ym),ij=Vt.merge(Xm),aj=Vt.merge(Jm),hR=E.object({testId:E.string().optional().default(""),testName:E.string().optional().default(""),suiteId:E.string().optional().default(""),suiteName:E.string().optional().default(""),creditsUsed:E.number().optional(),usedBy:E.string().optional()}),gR=E.object({transactionId:E.string(),timestamp:E.string(),event:E.nativeEnum(Vi),properties:hR}),sj=gR.array(),pg=Lm.omit({steps:!0}).extend({steps:E.array(E.record(E.string(),E.unknown())).describe("unparsed ResolvedStep[]")}),lj=E.object({limit:E.number().max(10).optional(),afterTime:E.number().optional()}),ug=Fm.array(),cj=E.object({applied:E.boolean().optional(),appliedAt:E.coerce.date().optional()}),dj=Vt.extend({chunks:Dc.array(),description:E.string().describe("Input to pass to AI"),type:E.union([E.literal("locator"),E.literal("assertion"),E.literal("ai-action")]),softTokenLimit:E.number(),hardTokenLimit:E.number()}),mg=Lo.extend({id:E.string()}),hg=E.object({runGroupId:E.string()});import{z as Le}from"zod";var gg=Le.object({orgId:Le.string(),cacheKeys:Le.string().array()}),mj=Le.object({keyParams:gg,clientMetadata:Le.string(),lockAcquisitionTimeoutMs:Le.number().optional()}),fg=Le.object({acquired:Le.boolean(),acquiredByMetadata:Le.string(),keyPrefix:Le.string()}),hj=Le.object({keyPrefix:Le.string(),result:Le.string(),ttlMs:Le.number()}),gj=Le.union([Le.object({keyPrefix:Le.string()}),gg]),fR=Le.object({remainingTtlMs:Le.number(),value:Le.string().nullish()}),fj=Le.object({results:Le.record(Le.string(),fR),activeLocks:Le.string().array()}),Sg=0,yg=5*60*1e3;import{z as sn}from"zod";var bg="test",wg="module",Ot=(t=>(t.TEST=`${bg}.yaml`,t.MODULE=`${wg}.yaml`,t))(Ot||{}),Ee=(t=>(t.TEST=`momentic/${bg}`,t.MODULE=`momentic/${wg}`,t))(Ee||{}),xj=bt.merge(Cr),Zc=Rt.extend({steps:sn.array(sn.record(sn.string(),sn.unknown())),schemaVersion:sn.string()}),Ej=Zc.extend({fileType:sn.literal(Ee.MODULE)}),Cj=sn.object({test:sn.string().describe("YAML for the test, including metadata and steps"),modules:sn.record(sn.string(),sn.string()).describe("Map of module name to YAML for the module")});import{z as at}from"zod";var SR=at.object({version:at.string(),json:at.record(at.unknown()),hash:at.string()}),vg=at.record(at.unknown()),Pj=at.object({newSvgs:at.array(SR),metadata:vg.optional()}),yR=at.object({version:at.string(),json:at.record(at.unknown()).nullish(),hash:at.string(),description:at.string().nullish(),metadata:vg.nullish()}),Tg=at.record(at.string().describe("icon hash"),yR);import{validator as Nj}from"@exodus/schemasafe";var xg=n=>{n.extraHeaders&&(n.extraHeaders=Object.fromEntries(Object.entries(n.extraHeaders).filter(([e,t])=>e.trim()&&t.trim())))};import{z as Vj}from"zod";import{z as Ye}from"zod";var Yj=Ye.object({repositoriesIndexed:Ye.boolean(),indexingInProgress:Ye.boolean(),indexesOutdated:Ye.boolean()}),Eg=(a=>(a.Queued="queued",a.InProgress="in_progress",a.Completed="completed",a.Waiting="waiting",a.Requested="requested",a.Pending="pending",a))(Eg||{}),Cg=(s=>(s.Success="success",s.Failure="failure",s.Neutral="neutral",s.Cancelled="cancelled",s.Skipped="skipped",s.TimedOut="timed_out",s.ActionRequired="action_required",s))(Cg||{}),Jj=Ye.object({name:Ye.string(),status:Ye.nativeEnum(Eg),conclusion:Ye.nativeEnum(Cg).nullable()}),Qc=Ye.object({sha:Ye.string(),message:Ye.string(),author:Ye.object({name:Ye.string().optional(),email:Ye.string().optional(),date:Ye.coerce.date().optional()}),committer:Ye.object({name:Ye.string().optional(),email:Ye.string().optional(),date:Ye.coerce.date().optional()})});import{z as _e}from"zod";var ed=_e.object({assertion:_e.string().describe("A human readable assertion that evaluates to either true or false depending on the state of the system.")}),bR=_e.object({instruction:_e.string().describe("Human readable instruction to execute the step. Instructions should only describe concrete actions that need to be taken. Any checks or assertions should be described in the preConditions, postConditions, or expectedResults."),expectedResults:ed.array().optional().describe("Human readable description of the expected results after the step is executed. Each expected result should contain a single assertion that evaluates to true or false.")}),Rg=bR.extend({subSteps:_e.lazy(()=>Rg.array().optional()).describe("More granular steps to be take to achieve the current step's higher level objective.")}),Ag=_e.object({name:_e.string().describe("Short name describing the test plan"),description:_e.string().nullish().transform(n=>n??void 0).describe("Longer form description of the high level goal of the test plan")}),Ig=Ag.extend({id:_e.string(),createdAt:_e.coerce.date(),updatedAt:_e.coerce.date(),updatedBy:_e.string(),createdBy:_e.string(),test:_e.object({id:_e.string(),name:_e.string()}).nullish().transform(n=>n??void 0)}),e$=Ig.extend({testGenRuns:_e.tuple([]).or(_e.tuple([_e.object({id:_e.string(),startedAt:_e.coerce.date(),status:_e.nativeEnum(ie)})]))}),Pg=_e.object({preConditions:ed.array().nullish().transform(n=>n??[]),postConditions:ed.array().nullish().transform(n=>n??[]),steps:Rg.array().nullish().transform(n=>n??[])}),t$=Ig.extend({plan:Pg.nullish().transform(n=>n??{preConditions:[],postConditions:[],steps:[]})}),wR=Ag.extend({plan:Pg.nullish().transform(n=>n??{preConditions:[],postConditions:[],steps:[]})}),n$=wR.array().nullish().transform(n=>n??[]);import{z as De}from"zod";var vR=De.object({step:Ae,status:De.nativeEnum(Te),startedAt:De.coerce.date(),finishedAt:De.coerce.date().optional(),healMetadata:De.object({healType:De.nativeEnum(Ui).or(De.literal("AI")),healedAt:De.coerce.date()}).optional(),beforeSnapshotId:De.string().uuid().optional(),afterSnapshotId:De.string().uuid().optional(),message:De.string().optional()}),p$=vR.extend({finishedAt:De.coerce.date().optional().transform(n=>n??new Date)}),TR=De.object({startedAt:De.coerce.date()}).merge(og).merge(rs),u$=TR.extend({finishedAt:De.coerce.date().optional().transform(n=>n??new Date)}),xR=ng.merge(Qh).extend({status:De.nativeEnum(ie),startedAt:De.coerce.date(),attempts:De.number()}),m$=xR.extend({finishedAt:De.coerce.date().optional().transform(n=>n??new Date)}),ER=Jh.merge(Zh).extend({startedAt:De.coerce.date(),cliVersion:De.string()}),td=ER.extend({updatedAt:De.coerce.date().optional().transform(n=>n??new Date),finishedAt:De.coerce.date().optional().transform(n=>n??new Date)});import CR from"semver";import{z as RR}from"zod";var S$=RR.string().refine(n=>CR.valid(n),{message:"must be a valid semver string"});var Ts=class{async resolveStepCacheEntries(){}async saveStepCacheEntries(){}};function nd(n){let e={parentChain:[]};return xs(n,e),e}function xs(n,e){let{onPresetAction:t,onSimpleStepContainer:r,onConditional:o,earlyStop:i}=n;for(let a of n.steps)switch(a.type){case"PRESET_ACTION":if(t(a,e)&&i)return!0;break;case"CONDITIONAL":if(o?.(a,e)&&i)return!0;e.parentChain.push(a);for(let l of a.blocks)if(t(l.assertion,e)&&i||xs({...n,steps:l.steps},e)&&i)return!0;if(xs({...n,steps:a.elseSteps??[]},e)&&i)return!0;e.parentChain.pop();break;case"RESOLVED_MODULE":case"IFRAME":case"SECTION":case"AI_ACTION":if(r?.(a,e)&&i)return!0;if(a.steps){if(e.parentChain.push(a),xs({...n,steps:a.steps},e)&&i)return!0;e.parentChain.pop()}break;case"AI_ACTION_DYNAMIC":{if(r?.(a,e)&&i)return!0;break}default:return(l=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(a)}}function Lg(n,e,t,r){let o=Array.from(e),i=Array.from(r);for(let s=0;s<o.length;s++){if(o[s]!==i[s])return!1;i.shift()}return!!AR([n],t,i).result}function AR(n,e,t=[]){let r,o=[],i=(a,s)=>{let l=JSON.stringify(s.parentChain.map(d=>d.id)),c=t.length===0?!0:JSON.stringify(t)===l;return a.id===e&&c?(r=a,o=s.parentChain,!0):!1};return nd({steps:n,earlyStop:!0,onPresetAction:i,onConditional:i,onSimpleStepContainer:i}),{result:r,parentChain:o}}function Og(n,e){e(n);for(let t in n){let r=n[t];r&&(Array.isArray(r)?Es(r,e):typeof r=="object"&&Og(r,e))}}function Es(n,e){for(let t of n)t&&(Array.isArray(t)?Es(t,e):typeof t=="object"&&Og(t,e))}import{cloneDeep as kg}from"lodash-es";import{v4 as rd}from"uuid";async function Yt(n){let e=new Map,t=new Set,r=kg(n.stepLists.steps),o=await Nr({...n,steps:r,moduleStepParents:[],moduleIdParents:[],moduleIdReplacements:e,seenModules:t}),i={stepsToSave:{steps:o.stepsToSave,beforeSteps:void 0,afterSteps:void 0},cachesToSave:o.cachesToSave,moduleUpdates:o.moduleUpdates};for(let a of["beforeSteps","afterSteps"]){let s=kg(n.stepLists[a]);if(!s)continue;let l=await Nr({...n,steps:s,moduleStepParents:[],moduleIdParents:[],moduleIdReplacements:e,seenModules:t});i.cachesToSave.push(...l.cachesToSave),i.moduleUpdates.push(...l.moduleUpdates),i.stepsToSave[a]=l.stepsToSave}return i}async function Nr({steps:n,...e}){let{seenModules:t,cacheCreationParams:r,moduleIdParents:o,moduleStepParents:i,moduleIdReplacements:a,shouldCreateNewModuleId:s,createNewCacheIds:l}=e,c={cachesToSave:[],stepsToSave:[],moduleUpdates:[]};for(let d of n)switch(delete d.index,delete d.aiSuggested,d.id=l?rd():d.id,d.type){case"PRESET_ACTION":{let m=d.command;m.id=l?rd():m.id,Ng(m),"cache"in m&&m.cache&&(r&&(c.cachesToSave=c.cachesToSave.concat(Mg({id:m.id,orgId:r.orgId,testId:r.testId,value:Tr.parse(m),moduleIdParents:o,moduleStepParents:i,skipIntermediateEntries:e.skipCacheIntermediateEntries}))),delete m.cache),m.thoughts&&delete m.thoughts,c.stepsToSave.push({...d,command:m});break}case"RESOLVED_MODULE":{let m=l?rd():d.id,u=d.moduleId;a.has(u)?u=a.get(u):s!==void 0&&(u=await s(d),a.set(d.moduleId,u));let{cachesToSave:h,stepsToSave:g,moduleUpdates:f}=await Nr({...e,steps:d.steps,cacheCreationParams:r?{...r}:void 0,createNewCacheIds:!1,moduleStepParents:[...i,m],moduleIdParents:[...o,u],skipCacheIntermediateEntries:l});c.moduleUpdates=c.moduleUpdates.concat(f),c.cachesToSave=c.cachesToSave.concat(h),t.has(u)||(t.add(u),c.moduleUpdates.push({...Rt.parse(d),steps:Se.array().parse(g),moduleId:u}));let S={type:"MODULE",moduleId:u,inputs:d.inputs,id:m,skipped:d.skipped,cacheConfig:d.cacheConfig,envKey:d.envKey};c.stepsToSave.push(S);break}case"AI_ACTION":{if(!d.steps){c.stepsToSave.push(d);break}let{stepsToSave:m,cachesToSave:u}=await Nr({...e,steps:d.steps});try{d.steps=Ct.array().parse(m)}catch(h){throw new Error(`Only preset actions are allowed in AI actions at the moment: ${h}`)}c.stepsToSave.push(d),c.cachesToSave=c.cachesToSave.concat(u);break}case"AI_ACTION_DYNAMIC":{c.stepsToSave.push(d);break}case"CONDITIONAL":{let m=[];for(let h of d.blocks){let{stepsToSave:g,cachesToSave:f,moduleUpdates:S}=await Nr({...e,steps:h.steps});m.push({...h,steps:g}),c.cachesToSave=c.cachesToSave.concat(f),c.moduleUpdates=c.moduleUpdates.concat(S)}let u={...d,elseSteps:void 0,blocks:m};if(d.elseSteps){let{stepsToSave:h,cachesToSave:g,moduleUpdates:f}=await Nr({...e,steps:d.elseSteps});u.elseSteps=h,c.cachesToSave=c.cachesToSave.concat(g),c.moduleUpdates=c.moduleUpdates.concat(f)}c.stepsToSave.push(u);break}case"IFRAME":case"SECTION":{let{stepsToSave:m,cachesToSave:u,moduleUpdates:h}=await Nr({...e,steps:d.steps}),g={...d,steps:m};c.moduleUpdates=c.moduleUpdates.concat(h),c.stepsToSave.push(g),c.cachesToSave=c.cachesToSave.concat(u);break}default:return(m=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(d)}return c}function Oo({steps:n,topLevel:e=!0,...t}){let{stepCacheEntries:r,logger:o,keyPrefix:i}=t,a=[],s=[],l=[],c=0,d=(m,u)=>{try{let h=Tr.parse(u.value);if(h.type!==m.type){o.warn({parsedCacheEntry:h,command:m},"Not using step cache due to type mismatch"),s.push(u.key);return}m.cache=h.cache,a.push(u.key),l.push(u.uniqueKey)}catch(h){s.push(u.key),o.error({err:h,cacheEntry:u},"Not using step cache due to parsing error")}},p=(m,u)=>{let h=PR(m.id,u),g=h.find(f=>!!r[f]);g?d(m,r[g]):s.push(h[0])};for(let m of n)switch(m.type){case"RESOLVED_MODULE":{c+=m.steps.length;let{cacheKeysHit:h,cacheKeysMissed:g,uniqueKeysHit:f}=Oo({...t,steps:m.steps,keyPrefix:i?`${i}:${m.id}`:m.id,topLevel:!1});a.push(...h),s.push(...g),l.push(...f);break}case"IFRAME":case"SECTION":case"AI_ACTION":{if(c+=m.steps?.length??0,!m.steps?.length)break;let{cacheKeysHit:h,cacheKeysMissed:g,uniqueKeysHit:f}=Oo({...t,steps:m.steps,topLevel:!1});a.push(...h),s.push(...g),l.push(...f);break}case"AI_ACTION_DYNAMIC":continue;case"PRESET_ACTION":{if(!oc.includes(m.command.type)||(m.command.type==="TYPE"||m.command.type==="MOUSE_DRAG"||m.command.type==="VISUAL_DIFF"||m.command.type==="SCROLL_DOWN"||m.command.type==="SCROLL_UP"||m.command.type==="SCROLL_LEFT"||m.command.type==="SCROLL_RIGHT")&&!m.command.target||m.command.type==="ELEMENT_CHECK"&&m.command.assertion.type==="ELEMENT_EXISTENCE"&&m.command.assertion.negated||"cache"in m.command&&m.command.cache)continue;c++,p(m.command,i);break}case"CONDITIONAL":{for(let h of m.blocks){c++,p(h.assertion.command,i),c+=h.steps.length;let{cacheKeysHit:g,cacheKeysMissed:f,uniqueKeysHit:S}=Oo({...t,steps:h.steps,topLevel:!1});a.push(...g),s.push(...f),l.push(...S)}if(m.elseSteps){c+=m.elseSteps.length;let{cacheKeysHit:h,cacheKeysMissed:g,uniqueKeysHit:f}=Oo({...t,steps:m.elseSteps,topLevel:!1});a.push(...h),s.push(...g),l.push(...f)}break}default:return(h=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(m)}return e&&c&&s.length>0&&o.warn({totalSteps:c,cacheKeysMissed:s,cacheKeysHit:a,uniqueKeysHit:l,cacheEntries:r.length},"Step cache did not fully resolve"),{cacheKeysHit:a,cacheKeysMissed:s,uniqueKeysHit:l}}function _g(n,e){return e?`${e}:${n}`:n}function PR(n,e){let t=[],r=e?.split(":")??[];for(let o=r.length;o>=0;o--){let i=[...r.slice(o),n];t.push(i.join(":"))}return t.reverse(),t}function Mg(n){let{moduleStepParents:e=[],moduleIdParents:t=[]}=n;if(e.length!==t.length)throw new Error(`Invalid cache entry parent length: ${JSON.stringify(e)}
15
15
  ${JSON.stringify(t)}`);let r=[];if(!n.skipIntermediateEntries)for(let o=e.length;o>0;o--){let i=t[o-1],a=e.slice(o,e.length).join(":");r.push({key:_g(n.id,a),moduleId:i,organizationId:n.orgId,value:n.value})}return r.push({key:_g(n.id,e.join(":")),organizationId:n.orgId,value:n.value,testId:n.testId}),r}function Ng(n){switch(n.type){case"DRAG":{if(n.fromTarget.type==="coordinates"||n.toTarget.type==="coordinates"||!n.fromTarget?.a11yData||!n.toTarget?.a11yData)return;n.cache={fromTarget:n.fromTarget.a11yData,toTarget:n.toTarget.a11yData},delete n.fromTarget.a11yData,delete n.toTarget.a11yData;return}case"MOUSE_DRAG":case"HOVER":case"SCROLL_UP":case"SCROLL_DOWN":case"SCROLL_LEFT":case"SCROLL_RIGHT":case"SELECT_OPTION":case"TYPE":case"VISUAL_DIFF":case"CLICK":case"FOCUS":case"ELEMENT_CHECK":case"BLUR":{if(n.target?.type==="coordinates"||!n.target?.a11yData)return;n.cache={target:n.target.a11yData},delete n.target.a11yData;return}default:return}}function Dg(n){let e=new Set;return Es(n,t=>{if("type"in t&&t.type==="RESOLVED_MODULE"&&"moduleId"in t){let r=t.moduleId;typeof r=="string"&&!e.has(r)&&e.add(r)}}),e}function Fg(n,e,t){e.length&&(n.type==="DRAG"?e.length!==2||!e.every(r=>r.cache)?t.warn({newTargets:e,cmd:n},"New targets for step are incorrect"):n.fromTarget.type==="description"&&n.toTarget.type==="description"&&(n.cache={fromTarget:e[0].cache,toTarget:e[1].cache}):e.length!==1||!e[0]?.cache?t.warn({newTargets:e,cmd:n},"New targets for step are incorrect"):"target"in n&&n.target&&n.target.type==="description"&&(n.cache={target:e[0].cache}))}async function Cs({logger:n,cacheStorage:e,orgId:t,testId:r,originalSteps:o,updatedSteps:i}){let a=IR(o,i);if(Object.keys(a).length>0){n.info({changes:a},"Updating steps caches post-run success");try{let{cachesToSave:s}=await Yt({stepLists:i,cacheCreationParams:{testId:r,orgId:t}});await e.saveStepCacheEntries(s,r,n)}catch(s){n.error({err:s},"Failed to save step caches after successful execution. This is not critical, but can impact future performance.")}}}function He(n,e,t=!1){return n.length<e?n:n.slice(0,e-3)+(t?"...TRUNCATED...":"[...]")}var or={EQUALS:"equals",CONTAINS:"contains",STARTS_WITH:"starts with",EXISTS:"exists"},ir={EQUALS:"does not equal",CONTAINS:"does not contain",STARTS_WITH:"does not start with",EXISTS:"does not exist"},od={EXISTS:"exists",VISIBLE:"is visible",ENABLED:"is enabled",EDITABLE:"is editable"},id={EXISTS:"does not exists",VISIBLE:"is not visible",ENABLED:"is disabled",EDITABLE:"is not editable"};function LR(n){switch(n.type){case"ELEMENT_CONTENT":return`${n.negated?ir[n.operation]:or[n.operation]} '${n.value}'`;case"ELEMENT_ATTRIBUTE":{let t=n.negated?ir[n.operation]:or[n.operation];return n.operation==="EXISTS"?`attribute '${n.attr}' ${t}`:`attribute '${n.attr}' ${t} '${n.value}'`}case"ELEMENT_EXISTENCE":return n.negated?id[n.condition]:od[n.condition];default:return(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}var yW={CONTENT:"The page"};function OR(n){switch(n.type){case"VALUE":return`the option with value ${n.value}`;case"LABEL":return`the option with label ${n.label}`;case"INDEX":return`the option at index ${n.index}`;default:return(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}function ad(n){switch(n.type){case"SUBSTRING":return`match substring '${n.url}'`;case"REGEX":return`match regex '${n.regex}'`;case"GLOB":return`match glob '${n.glob}'`;default:return(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}function kR(n){switch(n.type){case"CONTENT":return`${n.negated?ir.CONTAINS:or.CONTAINS} '${n.value}'`;default:return(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n.type)}}function _r(n){switch(n.type){case"SUCCESS":return n.condition?.assertion?`Check success condition: ${n.condition.assertion}`:"All commands completed";case"AI_EXTRACT":return`Extract data from page: ${n.goal}`;case"NAVIGATE":return`Go to URL: ${He(n.url,30)}`;case"DIALOG":return`Automatically ${n.action.toLowerCase()} the next dialog`;case"CAPTCHA":return"Solve captchas on the page";case"GO_BACK":return"Go back to the previous page";case"GO_FORWARD":return"Go forward to the next page";case"SCROLL_DOWN":return`Scroll down ${n.deltaY?`${n.deltaY}px`:"1 page height"}${n.target?` in the container of: ${pt(n.target)}`:""}`;case"SCROLL_UP":return`Scroll up ${n.deltaY?`${n.deltaY}px`:"1 page height"}${n.target?` in the container of: ${pt(n.target)}`:""}`;case"SCROLL_LEFT":return`Scroll left ${n.deltaX?`${n.deltaX}px`:"1 page width"}${n.target?` in the container of: ${pt(n.target)}`:""}`;case"SCROLL_RIGHT":return`Scroll right ${n.deltaX?`${n.deltaX}px`:"1 page width"}${n.target?` in the container of: ${pt(n.target)}`:""}`;case"WAIT":return`Wait for ${n.delay} seconds`;case"REFRESH":return"Refresh the page";case"CLICK":{if(n.target?.type==="coordinates")return`Click at coordinates: ${pt(n.target)}`;let t="";return n.target?.elementDescriptor.length?t=` on element: '${n.target.elementDescriptor}'`:n.cache?.target.nodeOnlySerializedHtml&&(t=` on element: '${n.cache?.target.nodeOnlySerializedHtml}'`),`Click${t}`}case"FOCUS":return`Focus ${pt(n.target)}`;case"BLUR":return`Focus ${pt(n.target)}`;case"DRAG":return`Drag ${pt(n.fromTarget)} onto ${pt(n.toTarget)}`;case"MOUSE_DRAG":return n.target?.type==="description"&&n.target.elementDescriptor?`Click and drag ${pt(n.target)} by ${n.deltaX}px horizontally, ${n.deltaY}px vertically`:`Click and drag mouse by ${n.deltaX}px horizontally, ${n.deltaY}px vertically`;case"TYPE":{let t="";return n.target?.type==="coordinates"?t=` in element at coordinates: ${pt(n.target)}`:n.target?.elementDescriptor.length?t=` in element: '${n.target.elementDescriptor}'`:n.cache?.target.nodeOnlySerializedHtml&&(t=` in element: '${n.cache?.target.nodeOnlySerializedHtml}'`),`Type '${n.value}'${t||""}`}case"HOVER":{let t="";return n.target.type==="coordinates"?t=` over coordinates: ${pt(n.target)}`:n.target.elementDescriptor.length>0?t=` over element: '${n.target.elementDescriptor}'`:n.cache?.target.nodeOnlySerializedHtml&&(t=` over element: '${n.cache?.target.nodeOnlySerializedHtml}'`),`Hover${t}`}case"PRESS":return`Press ${n.value}`;case"SELECT_OPTION":{let t="",r=OR(n.choice);return n.target.type==="coordinates"?t=` from element at coordinates: ${pt(n.target)}`:n.target.elementDescriptor.length>0?t=` from: '${n.target.elementDescriptor}'`:n.cache?.target.nodeOnlySerializedHtml&&(t=` from: '${n.cache?.target.nodeOnlySerializedHtml}'`),`Select option '${r}'${t}`}case"TAB":switch(n.action.type){case"SUBSTRING":return`Switch to tab with substring: ${n.action.substring}`;case"REGEX":return`Switch to tab matching regex: ${n.action.pattern}`;case"INDEX":return`Switch to tab at index: ${n.action.index}`;default:return(r=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n.action)}return"Switch to unknown tab";case"NEW_TAB":return`Open new tab to: ${n.url}`;case"REQUEST":return`Send ${n.method} request to ${n.url}`;case"GRAPHQL_REQUEST":return`Send GraphQL request to ${n.url}`;case"COOKIE":return`Set cookie: ${n.value}`;case"LOCAL_STORAGE":return`Set local storage: ${n.key}: ${n.value}`;case"JAVASCRIPT":return`Run JavaScript: ${He(n.code,30)}`;case"AI_ASSERTION":return`Assertion: '${n.assertion}'`;case"VISUAL_DIFF":return`Visual diff against baseline ${n.target?`for element: ${pt(n.target)}`:"for entire page"}`;case"FILE_UPLOAD":return n.fileSource.type==="URL"?`Upload file: ${n.fileSource.url}`:`Upload file: ${n.fileSource.name}`;case"AUTH_LOAD":return"Load auth state";case"AUTH_SAVE":return"Save auth state";case"ELEMENT_CHECK":return`Check the element ${pt(n.target)} ${LR(n.assertion)}`;case"PAGE_CHECK":return`Check the page ${kR(n.assertion)}`;case"WAIT_FOR_URL":return`Wait for page URL to ${ad(n.matcher)}`;case"COPY":return"Copy to clipboard";case"PASTE":return"Paste clipboard contents";case"REGISTER_REQUEST_LISTENER":return n.pattern?`Register a listener for network requests that match ${n.pattern}`:"Register a listener for network requests";case"AWAIT_LISTENER":return n.key?`Wait for the listener ${n.key} to resolve`:"Wait for a listener to resolve";default:return(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}function Ug(n){let e=[];for(let t of n){t.sort((a,s)=>a.timestamp-s.timestamp);let r=[],o,i=1;for(let a of t)o&&o.text===a.text&&o.type===a.type&&JSON.stringify(o.args??null)===JSON.stringify(a.args??null)?i++:(o&&(i>1?o.args&&o.args.length?o.args.push(`(repeated ${i} times)`):o.text+=` (repeated ${i} times)`:r.push(o)),o=a,i=1);o&&r.push(o),e.push(r)}return e}import{cloneDeep as MR}from"lodash-es";import{cloneDeep as TW,unset as xW}from"lodash-es";function ln(n){switch(n.type){case"AI_ACTION":return`AI action: ${He(n.text,100)}`;case"AI_ACTION_DYNAMIC":return`AI action: ${He(n.text,100)}`;case"PRESET_ACTION":return _r(n.command);case"MODULE":return`Module: ${n.id}`;case"RESOLVED_MODULE":return`Module: ${n.name}`;case"CONDITIONAL":return"Conditional step";case"IFRAME":return"Frame step";case"SECTION":return`Section${n.description?`with goal: ${He(n.description,100)}`:""}`;default:return(t=>{throw new Error("You missed a case in the switch above")})(n)}}var Bg=1e3,zg=3e6,NR="[FAILED]";async function Hg(n,e,t,r){if(t)if(t.startsWith("http")){let i=await(await fetch(t)).arrayBuffer();return`data:image/jpeg;base64,${Buffer.from(i).toString("base64")}`}else return t.startsWith("data:")?t:`data:image/jpeg;base64,${t}`;else if(r){let o=await e.getScreenshot(n,r);if(o)return`data:image/jpeg;base64,${Buffer.from(o).toString("base64")}`}}async function Rs(n,e,t,{numScreenshots:r=1,addIndices:o=!0,includeBeforeScreenshots:i=!1,includeDomState:a=!1,recursive:s=!0}){let l=[],c;for(let d=0;d<t.length;d++){let p=t[d],m=s?Dr(p):ln(p),u={description:`Step ${d}: ${m}`,startedAt:p.startedAt,finishedAt:p.finishedAt,beforeUrl:p.beforeUrl,afterUrl:p.afterUrl,message:p.message!=="Successfully executed preset action."?p.message:void 0,index:o?d:void 0};if(p.status==="FAILED"){u.description=`${NR} ${u.description}`,o&&(c=d);try{let h=zm.array().parse(p.details);for(let g of h)"pageState"in g&&a&&(u.pageState=g.pageState)}catch{}}r>0&&d>=t.length-r&&(u.afterScreenshot=await Hg(n,e,p.afterScreenshot,p.afterSnapshot),i&&(u.beforeScreenshot=await Hg(n,e,p.beforeScreenshot,p.beforeSnapshot))),l.push(u)}return{results:l,failureIndex:c}}function Dr(n){let e=ln(n);switch(n.type){case"AI_ACTION":case"AI_ACTION_DYNAMIC":e+=`
16
16
  `;for(let t=0;t<n.results.length;t++)e+=Je(`Sub-step ${t} in AI action:
17
17
  `,2),e+=`${Je(Dr(n.results[t]),2)}
@@ -38,23 +38,23 @@ ${JSON.stringify(t)}`);let r=[];if(!n.skipIntermediateEntries)for(let o=e.length
38
38
  `,e+=Je(`${"=".repeat(10)}
39
39
  `,2);return e}default:return(r=>{throw new Error("You missed a case in the switch above")})(n)}}function Je(n,e){return n.split(`
40
40
  `).map(t=>" ".repeat(e)+t).join(`
41
- `)}function Gg(n,e){try{if(!n)return n;if(typeof n=="string")return He(n,3e4);if(typeof n=="object"){let{jsonString:t}=wo(JSON.stringify(n,(r,o)=>e?.includes(r)||typeof o=="string"&&o.length>3e4?"REDACTED":o),2e4);return JSON.parse(t)}return n}catch{return n}}function sd(n,e){for(let t=0;t<n.length;t++){let r=n[t];try{if(r.data){let{jsonString:o}=wo(JSON.stringify(r.data),1e3);r.data=JSON.parse(o)}}catch(o){e.error({err:o},"Failed to serialize individual result output data"),r.data=`Result output data could not be serialized: ${o}`}switch(r.details&&(r.details=void 0),r.type){case"PRESET_ACTION":jg(r);break;case"CONDITIONAL":r.assertion&&jg(r.assertion),sd(r.results,e);break;case"AI_ACTION_DYNAMIC":case"AI_ACTION":case"IFRAME":case"MODULE":case"SECTION":{sd(r.results,e);break}default:return(i=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(r)}}}function jg(n){let e=n.command;"cache"in e&&e.cache&&(e.cache=void 0)}function $g(n,e){let t=JSON.stringify(n),r=t.replaceAll("\\u0000","");if(t.length!==r.length){let o=t.indexOf("\\u0000");e.warn({input:t.slice(Math.max(0,o-500),Math.min(t.length,o+500))},"Database content violation: stripped unicode character from input")}return r}function As(n,e){let t=MR(n);if(sd(t,e),t.length>Bg)return e.error("Database content violation: results too long, truncating before insertion"),t.slice(0,Bg);let r=$g(t,e);if(r.length>zg)for(e.error({serializedLength:r.length,resultsArrayLength:t.length},"Database content violation: results too large, truncating before insertion");r.length>zg;)t.pop(),r=$g(t,e);try{return It.array().parse(JSON.parse(r))}catch(o){throw e.error({serialized:r,err:o},"Could not parse serialized results into JSON structure after processing"),o}}import{cloneDeep as jW}from"lodash-es";var _R=/^(?!.*\S+\s+\S+).*$/,DR=/^[a-zA-Z0-9\s.,;:'"!?()\- \u00C0-\u00FF]+$/,FR=/style="([^"]*)/g,UR=/data-[\w-]+/g,BR=n=>{switch(n.type){case"AI_ASSERTION":return{type:n.type,assertion:n.assertion};case"DRAG":if(n.fromTarget.type==="description")return{type:n.type,description:n.fromTarget.elementDescriptor};break;case"CLICK":case"BLUR":case"TYPE":case"SELECT_OPTION":case"ELEMENT_CHECK":case"FOCUS":case"HOVER":case"MOUSE_DRAG":case"VISUAL_DIFF":case"SCROLL_DOWN":case"SCROLL_UP":case"SCROLL_LEFT":case"SCROLL_RIGHT":if(n.target?.type==="description")return{type:n.type,description:n.target.elementDescriptor};break}return{type:"NONE",description:"NONE"}};function Wg(n){let e=BR(n),t=e.type==="AI_ASSERTION"?e.assertion:e.description;return!t||t==="NONE"?{thoughts:"NONE",category:"NO_DESCRIPTION_PROVIDED"}:_R.test(t)&&DR.test(t)?{thoughts:"The target description is too short. Please provide more details.",category:"FEW_WORDS"}:FR.test(t)?{thoughts:"Style tags are not recommended in the command description as they change frequently. Please remove them and describe the target in a different way.",category:"STYLE_TAG"}:UR.test(t)?{thoughts:"Hardcoded data attributes are not recommended in the command description as they change frequently.",category:"HARDCODED_ATTRIBUTE"}:new RegExp(`\\b${e.type}\\b`,"gi").test(t)?{thoughts:`The element description you provided starts with the command type (${e.type}). This can confuse our AI agents since the element itself is unrelated to the desired action.`,category:"TYPE_IN_DESCRIPTION"}:{thoughts:"NONE",category:"NONE"}}function Vg(n,e){if(!(!n.envs||!n.envs.length)){for(let t of n.envs){let r=t;e in t&&(r[e]&&(t.default=!0),delete r.defaultOnCloud,delete r.defaultOnLocal)}n.envs.some(t=>t.default)||(n.envs[0].default=!0)}}import{cloneDeep as bf}from"lodash-es";import GR from"diff-lines";import Ps,{gte as WR}from"semver";var qg={name:"Migrate to ai step v2",fromVersion:"1.0.4",toVersion:"1.0.5",recursiveKeys:new Set(["results","commands"]),stopOnFailure:!0,execute:async n=>(n=n.filter(e=>!(e.status!==void 0&&e.type==="AI_ACTION")),n=n.map(e=>(e.status===void 0||e.type==="PRESET_ACTION"&&(e.results=e.commands??e.results??[]),e)),n)};var Kg={name:"Make sure ai step v2 has done command",fromVersion:"1.0.5",toVersion:"1.0.6",recursiveKeys:new Set(["results","commands"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if(e.type!=="AI_ACTION"||e.status!==void 0||!e.commands||!e.commands.length)return e;let t=e.commands,r=t[t.length-1];return r&&r.type!=="SUCCESS"&&t.push({type:"SUCCESS"}),e})};var zR=["target","fromTarget","toTarget"];function Yg(n){for(let e of zR){if(n[e]===void 0)continue;let t=n[e];t.elementDescriptor!==void 0?t.type="description":n[e]={type:"description",elementDescriptor:""}}}var Jg={name:"Migrate element target to discriminated union",fromVersion:"1.0.6",toVersion:"1.0.7",recursiveKeys:new Set(["results","steps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{switch(e.type){case"PRESET_ACTION":return Yg(e.command),e;case"AI_ACTION":{let t=e.commands;for(let r of t??[])Yg(r);return e}default:return e}})};import{v4 as HR}from"uuid";var Xg={name:"Ensure module steps have ids",fromVersion:"1.0.7",toVersion:"1.0.8",recursiveKeys:new Set(["results","steps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{switch(e.type){case"MODULE":return e.id||(e.id=HR()),e;default:return e}})};import{v4 as Zg}from"uuid";var Qg={name:"Ensure module steps have ids",fromVersion:"1.0.8",toVersion:"1.0.9",recursiveKeys:new Set(["results","steps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{switch(e.type){case"PRESET_ACTION":{if(!e.command)return e;let t=e.command;return t.id=t.id??Zg(),e}case"AI_ACTION":return e.commands&&(e.steps=e.commands.map(t=>({type:"PRESET_ACTION",command:{...t,id:t.id??Zg()}})),delete e.commands),e;default:return e}})};var ef={name:"Migrate ai waits to checks",fromVersion:"1.0.9",toVersion:"1.0.10",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{switch(e.type){case"PRESET_ACTION":{if(!e.command)return e;let t=e.command;return typeof t.type!="string"||t.type!=="AI_WAIT"||(t.type="AI_ASSERTION",t.timeout||(t.timeout=10)),e}default:return e}})};import{v4 as jR}from"uuid";var tf={name:"Add ids to all steps",fromVersion:"1.0.10",toVersion:"1.0.11",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>("id"in e&&typeof e.id=="string"||(e.id=jR()),e))};import{v4 as nf}from"uuid";var rf={name:"Add ids to all steps",fromVersion:"1.0.11",toVersion:"1.0.12",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if("id"in e&&typeof e.id=="string")return e;if("condition"in e&&typeof e.condition=="object"&&e.condition){let t=e.condition;t.id||(t.id=nf())}return e.id=nf(),e})};var of={name:"Move env key to steps",fromVersion:"1.0.12",toVersion:"1.0.13",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;return!t||typeof t.envKey!="string"||(e.envKey=t.envKey,delete t.envKey),e})};import{v4 as $R}from"uuid";var af={name:"Redo last two migrations",fromVersion:"1.0.13",toVersion:"1.0.14",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if((!("id"in e)||typeof e.id!="string")&&(e.id=$R()),e.type!=="PRESET_ACTION")return e;let t=e.command;return!t||typeof t.envKey!="string"||(e.envKey=t.envKey,delete t.envKey),e})};var sf={name:"Migrate select choice",fromVersion:"1.0.14",toVersion:"1.0.15",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;return!t||t.type!=="SELECT_OPTION"||e.option===void 0||(e.choice={type:"VALUE",value:t.option},e.option=void 0),e})};var lf={name:"Migrate select choice",fromVersion:"1.0.15",toVersion:"1.0.16",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;return t&&cf(t),e})};function cf(n){n&&Object.keys(n).forEach(e=>{if(typeof n[e]=="object"&&n[e]){cf(n[e]);return}if(typeof n[e]!="string")return;let t=n[e];e==="code"?n[e]=t.replace(/inputs\./g,"env."):t.includes("{{")&&t.includes("}}")&&(n[e]=t.replace(/inputs\./g,"env."))})}var df={name:"Migrate switch tab choice",fromVersion:"1.0.16",toVersion:"1.0.17",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;return!t||t.type!=="TAB"||t.url===void 0||(t.action={type:"SUBSTRING",substring:t.url},t.url=void 0),e})};var pf={name:"Remove press keys sequentially",fromVersion:"1.0.17",toVersion:"1.0.18",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!1,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;return!t||t.type!=="TYPE"?e:t.pressKeysSequentially===void 0?(t.delay=0,e):(t.pressKeysSequentially&&(t.pressKeysSequentially=void 0,t.delay=50),e)})};var uf={name:"Migrate wait for URL to matcher",fromVersion:"1.0.18",toVersion:"1.0.19",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!1,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;return!t||t.type!=="WAIT_FOR_URL"||t.url===void 0||(t.matcher={type:"GLOB",glob:t.url},t.url=void 0),e})};var mf={name:"Migrate select choice round 2",fromVersion:"1.0.19",toVersion:"1.0.20",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;if(!t)return e;if(t.type==="SELECT_OPTION"){if(t.option===void 0)return e;t.choice={type:"VALUE",value:t.option},t.option=void 0}else if(t.type==="TAB"){if(t.url===void 0)return e;t.action={type:"SUBSTRING",substring:t.url},t.url=void 0}else if(t.type==="WAIT_FOR_URL"){if(t.url===void 0)return e;t.matcher={type:"GLOB",glob:t.url},t.url=void 0}else t.type==="AI_WAIT"&&(t.type="AI_ASSERTION",t.timeout||(t.timeout=10));return e})};var hf={name:"Migrate AI assertions to preset actions",fromVersion:"1.0.0",toVersion:"1.0.1",recursiveKeys:new Set,execute:async n=>n.map(e=>{if(e.type!=="AI_ASSERTION")return e;let r={type:"PRESET_ACTION",command:{type:"AI_ASSERTION",assertion:e.text,useVision:!1,disableCache:!0}},o={...e,...r};return delete o.text,o}),stopOnFailure:!0};var Is=new Set(["CLICK","TYPE","SELECT_OPTION"]),gf={name:"Migrate element descriptor to live in a target object",fromVersion:"1.0.3",toVersion:"1.0.4",recursiveKeys:new Set,execute:async n=>n.map(e=>{let t=e.command,r=t?.type,o=t?.elementDescriptor;return(o!==void 0||Is.has(r))&&(t.target={elementDescriptor:o??""}),e.commands&&Array.isArray(e.commands)&&e.commands.forEach(a=>{let s=a?.elementDescriptor,l=a?.type;(s!==void 0||Is.has(l))&&(a.target={elementDescriptor:s??""})}),e.results&&Array.isArray(e.results)&&e.results.forEach(a=>{let s=a.command,l=s?.elementDescriptor,c=s?.type;(l!==void 0||Is.has(c))&&(s.target={elementDescriptor:l??""}),a.commands&&Array.isArray(a.commands)&&a.commands.forEach(p=>{let m=p?.elementDescriptor,u=p?.type;(m!==void 0||Is.has(u))&&(p.target={elementDescriptor:m??""})})}),e}),stopOnFailure:!0};var ff={name:"Migrate FAILURE status to FAILED",fromVersion:"1.0.1",toVersion:"1.0.2",recursiveKeys:new Set,execute:async n=>n.map(e=>{let t=e;return t.status==="FAILURE"&&(t.status="FAILED"),typeof t.commands=="object"&&Array.isArray(t.commands)&&t.commands.forEach(r=>{if(r&&typeof r=="object"){let o=r;o?.status==="FAILURE"&&(o.status="FAILED")}}),t}),stopOnFailure:!0};var Sf={name:"Migrate preset step types to use the same",fromVersion:"1.0.2",toVersion:"1.0.3",recursiveKeys:new Set,execute:async n=>n.map(e=>{let t=e.command,r=t?.type;return r?.startsWith("PRESET_")&&(t.type=r.slice(7)),e.commands&&Array.isArray(e.commands)&&e.commands.forEach(i=>{let a=i.type;a?.startsWith("PRESET_")&&(i.type=a.slice(7))}),e.results&&Array.isArray(e.results)&&e.results.forEach(i=>{let a=i.command,s=a?.type;s?.startsWith("PRESET_")&&(a.type=s.slice(7)),i.commands&&Array.isArray(i.commands)&&i.commands.forEach(c=>{let d=c.type;d?.startsWith("PRESET_")&&(c.type=d.slice(7))})}),e}),stopOnFailure:!0};var Fr=[hf,ff,Sf,gf,qg,Kg,Jg,Xg,Qg,ef,tf,rf,of,af,sf,lf,df,pf,uf,mf];if(Fe!==Fr[Fr.length-1].toVersion)throw new Error("Please bump LATEST_SCHEMA_VERSION in types package after adding a migration");Fr.forEach((n,e)=>{if(!Ps.valid(n.toVersion)||!Ps.valid(n.fromVersion))throw new Error(`Migration '${n.name}' has invalid version`);if(!Ps.gt(n.toVersion,n.fromVersion))throw new Error(`Migration '${n.name}' has toVersion <= fromVersion`);if(e===0)return;if(Fr[e-1].toVersion!==n.fromVersion)throw new Error(`Migration '${n.name}' at index ${e} is not contiguous with previous migration`)});function VR(n){return n.every(e=>e&&typeof e=="object"&&!Array.isArray(e))}var Qi=async({metadata:n,steps:e,logger:t,toVersion:r})=>{let o=e,{schemaVersion:i,id:a}=n,s=Fr.findIndex(d=>Ps.gt(d.toVersion,i));if(s===-1)return{steps:o,newVersion:i};let l=i;for(let d=s;d<Fr.length;d++){if(r&&WR(l,r)){t.debug("Stopping migration early because toVersion was reached");break}let p=Fr[d],m={id:a,migration:p.name,toVersion:p.toVersion};try{o=await yf(o,p),l=p.toVersion}catch(u){throw t.error({err:u,...m},"Migration failed"),new Error(`Step migration ${p.name} failed: ${u}`)}}let c=GR(JSON.stringify(e,void 0,2),JSON.stringify(o,void 0,2),{n_surrounding:1});return c.trim()&&t.debug({diffs:c,id:a},"Migration diffs"),{newVersion:l,steps:o}};async function yf(n,e){let t=await e.execute(n);for(let r of t)for(let o of Object.keys(r)){if(!e.recursiveKeys.has(o))continue;let i=r[o];!i||!Array.isArray(i)||VR(i)&&(r[o]=await yf(i,e))}return t}async function wf({rawSteps:n,metadata:e,logger:t,callbacks:r}){Vg(e,"defaultOnCloud");let o={},{resolvedSteps:i,newSchemaVersion:a}=await Ls({rawSteps:n.steps,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o}),s={...e,steps:i,schemaVersion:a};for(let l of["beforeSteps","afterSteps"]){let c=n[l];if(!c)continue;let{resolvedSteps:d}=await Ls({rawSteps:c,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o});s[l]=d}return{resolvedTest:s,moduleIds:Array.from(Object.keys(o))}}async function Ur(n,e,t){let{newVersion:r,steps:o}=await Qi({metadata:n,steps:e,logger:t});try{return{steps:Se.array().parse(o),newVersion:r}}catch(i){throw t.error({type:"zod",err:i,newVersion:r,id:n.id,steps:o},"Failed to parse test steps while migrating test"),new bs(`Failed to parse test steps while migrating test: ${i}`,n.id,"entity",{cause:i})}}async function Ls({rawSteps:n,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o={}}){let{newVersion:i,steps:a}=await Ur(e,n,t),s=[];for(let l of a)s.push(await ea({step:l,callbacks:r,logger:t,resolvedModuleCache:o}));return{resolvedSteps:s,newSchemaVersion:i}}async function ea({step:n,callbacks:e,logger:t,resolvedModuleCache:r}){switch(n.type){case"AI_ACTION":return n;case"AI_ACTION_DYNAMIC":return n;case"PRESET_ACTION":return n;case"MODULE":{let l=n.moduleId,c=r[l];if(c)return{...bf(c),...n,type:"RESOLVED_MODULE"};let d=await e.onFetchModule({id:l,logger:t});if(!d)throw new Error(`Could not find module with id ${l}`);let{newVersion:p,steps:m}=await Qi({metadata:{id:l,schemaVersion:d.schemaVersion},steps:d.steps,logger:t}),u;try{u=Se.array().parse(m)}catch(f){throw t.error({type:"zod",err:f,steps:m,newVersion:p,id:l},"Module failed to parse"),f}let h;try{h=await Promise.all(u.map(f=>ea({step:f,callbacks:e,logger:t,resolvedModuleCache:r})))}catch(f){throw t.error({err:f,...n},`Failed to recursively resolve module '${d.name}': ${f}`),f}let g={...d,steps:h};return r[l]=bf(g),{...g,...n,type:"RESOLVED_MODULE"}}case"CONDITIONAL":let o=[];for(let l of n.blocks){let c=[];for(let d of l.steps)c.push(await ea({step:d,callbacks:e,logger:t,resolvedModuleCache:r}));o.push({...l,steps:c})}let i;if(n.elseSteps){i=[];for(let l of n.elseSteps)i.push(await ea({step:l,callbacks:e,logger:t,resolvedModuleCache:r}))}return{...n,blocks:o,elseSteps:i};case"SECTION":case"IFRAME":let a=[];for(let l of n.steps)a.push(await ea({step:l,callbacks:e,logger:t,resolvedModuleCache:r}));return{...n,steps:a};default:return(l=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}function qR(n){return typeof n=="object"&&n!==null}function Fn(n){if(Array.isArray(n))return n.map(Fn);if(qR(n)){let e={};return Object.entries(n).forEach(([t,r])=>{r!==void 0&&(e[t]=Fn(r))}),e}return n}import{cloneDeep as KR}from"lodash-es";import{stringify as vf}from"yaml";async function Tf({test:n,processedModuleNames:e=new Set,createNewCacheIds:t=!1}){let r={id:n.id,name:n.name,description:n.description,baseUrl:n.baseUrl,schemaVersion:n.schemaVersion,advanced:n.advanced,retries:n.retries,envs:n.envs,disabled:n.disabled,labels:n.labels},o={},i=await YR({originalStepLists:{steps:n.steps,beforeSteps:n.beforeSteps,afterSteps:n.afterSteps},modules:o,processedModuleNames:e,createNewCacheIds:t}),a={fileType:Ee.TEST,...r,beforeSteps:i.beforeSteps&&i.beforeSteps.length>0?i.beforeSteps:void 0,steps:i.steps,afterSteps:i.afterSteps&&i.afterSteps.length>0?i.afterSteps:void 0};return{test:vf(a),modules:o}}async function YR({originalStepLists:n,modules:e,processedModuleNames:t,createNewCacheIds:r}){let o=KR(n);Object.values(o).forEach(s=>{JR(s??[])});let{stepsToSave:i,moduleUpdates:a}=await Yt({stepLists:o,createNewCacheIds:r});for(let s of a)t.has(s.name)||(e[s.name]=XR(s),t.add(s.name));return i}function JR(n){nd({steps:n,onPresetAction:e=>{e.aiSuggested=void 0,e.index=void 0,e.command.thoughts=void 0},onConditional:e=>{e.aiSuggested=void 0,e.index=void 0},onSimpleStepContainer:e=>{e.aiSuggested=void 0,e.index=void 0}})}function XR(n){let e=Rt.parse(n),t={fileType:Ee.MODULE,...e,schemaVersion:Fe,steps:n.steps};return vf(t)}async function te(n,e){return new Promise((t,r)=>{if(e?.aborted){r(e.reason);return}e?.addEventListener("abort",i);let o=setTimeout(()=>{e?.removeEventListener("abort",i),t()},n);function i(){clearTimeout(o),e?.removeEventListener("abort",i),r(e?.reason)}})}async function ta({promiseGenerator:n,signal:e,codePath:t,logger:r}){let i=Date.now(),a=setInterval(()=>{if(e?.aborted){clearInterval(a);return}r?.warn({codePath:t,startTime:i,elapsedMilliseconds:Date.now()-i},`Asynchronous operation is taking a long time (${t})`)},5e3);return new Promise((s,l)=>{function c(){clearInterval(a),e?.removeEventListener("abort",c),l(e?.reason)}if(e?.aborted){l(e?.reason),clearInterval(a);return}e?.addEventListener("abort",c),(async()=>{try{s(await n())}catch(d){l(d)}finally{clearInterval(a),e?.removeEventListener("abort",c)}})()})}async function Br({promiseGenerator:n,timeoutMs:e,codePath:t,logger:r,signal:o}){let i=!1,a=new AbortController,s=()=>{a.abort()},l=setTimeout(()=>{i||a.abort()},e);o?.addEventListener("abort",s);try{return await ta({promiseGenerator:n,signal:a.signal,codePath:t,logger:r})}finally{i=!0,o?.removeEventListener("abort",s),clearTimeout(l)}}function Os(n){let e=[];for(let t of n)switch(t.type){case"PRESET_ACTION":case"AI_ACTION":case"AI_ACTION_DYNAMIC":e.push(t);break;case"RESOLVED_MODULE":{let r={...t,type:"MODULE"};e.push(_n.parse(r));break}case"IFRAME":case"SECTION":{let r={...t,steps:Os(t.steps)};e.push(Se.parse(r));break}case"CONDITIONAL":{let r={...t,blocks:t.blocks.map(o=>({assertion:o.assertion,steps:Os(o.steps)})),elseSteps:t.elseSteps?Os(t.elseSteps):void 0};e.push(Er.parse(r));break}default:return(o=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(t)}return e}function ks(n){return Os([n])[0]}import ZR from"picomatch";var xf=(n,e,t)=>{t?.caseInsensitive&&(n=n.toLowerCase());let r;switch(e.type){case"SUBSTRING":{let o=t?.caseInsensitive?e.url.toLowerCase():e.url;r=n.includes(o);break}case"GLOB":{let o=t?.caseInsensitive?e.glob.toLowerCase():e.glob;r=n===e.glob||ZR(o)(n);break}case"REGEX":{r=new RegExp(e.regex).test(n);break}}return t?.negated?!r:r},Ms=(n,e)=>{try{let{hostname:t,pathname:r}=new URL(n),{hostname:o,pathname:i}=new URL(e);return t!==o||r!==i}catch{return!1}},Mo=n=>{try{return new URL(n),!0}catch{return!1}},Ef=n=>!n.toLowerCase().startsWith("http"),No=(n,e)=>{try{return new URL(n,e),!0}catch{return!1}};function zr(n,e){try{return!!new URL(n).origin.trim()}catch(t){return e?.error({url:n,err:t},"Invalid URL in check"),!1}}import _o from"yaml";import{z as If}from"zod";import{execSync as QR}from"child_process";function Hr(n,e){let t=e.hooks?.postSave;if(!t)return;let r;t.includes("$1")?r=t.replaceAll("$1",n):r=`${t} ${n}`,y.debug({postSaveCommand:r},"Executing post-save hook command");try{QR(r,{encoding:"utf-8"})}catch(o){y.warn({err:o,postSaveCommand:r},"Failed to execute post-save hook command, continuing...")}}import{diff as Cf}from"deep-object-diff";import ar from"fs";import{cloneDeep as eA}from"lodash-es";import ld from"path";import{v4 as tA}from"uuid";import na from"yaml";function jr({content:n,schemaVersion:e,momenticFiles:t,project:r,forceSaveOnNoDiffs:o}){let i=t.modules[n.moduleId]?.fullFilePath;if(!i||!ar.existsSync(i))throw new Error(`Tried to update module ${n.moduleId} that could not be found on disk`);let a=ar.readFileSync(i,"utf-8"),s=na.parse(a),l;if(n.name&&n.name!==s.name){let u=`${Ne(n.name)}.${Ot.MODULE}`;if(l=ld.join(ld.dirname(i),u),ar.existsSync(l))throw new Error(`Test with name '${n.name}' already exists at path '${l}'`)}let c={...n,schemaVersion:e},d=Fn({fileType:Ee.MODULE,...Yc.parse(c),steps:Se.array().parse(n.steps)}),p=Cf(d,s);if(p&&Object.keys(p).length===0&&!o){y.debug(`Skipping save for module ${n.moduleId} since there are no changes`);return}let m=na.stringify(d);ar.writeFileSync(i,m,"utf-8"),l&&ar.renameSync(i,l),Hr(l||i,r.config)}function Rf({moduleId:n,content:e,momenticFiles:t,project:r,logger:o}){let i=t.modules[n]?.fullFilePath;if(!i)throw new Error(`Tried to update module ${n} that could not be found on disk`);let a=Un(i,o),s={...a,...e},l=Fn({fileType:Ee.MODULE,...Yc.parse(s),steps:a.steps}),c=Cf(l,a);if(c&&Object.keys(c).length===0){y.debug(`Skipping save for module ${n} since there are no changes`);return}let d=na.stringify(l);ar.writeFileSync(i,d,"utf-8"),Hr(i,r.config)}async function Af({name:n,description:e,enabled:t,steps:r,folder:o,project:i}){let a=Ne(n),s=ld.join(o,`${a}.module.yaml`),l=tA(),{stepsToSave:c}=await Yt({stepLists:{steps:r}}),d={fileType:Ee.MODULE,schemaVersion:Fe,moduleId:l,name:n,description:e,enabled:t,steps:c.steps},p=na.stringify(d);return ar.writeFileSync(s,p,"utf-8"),Hr(s,i.config),{moduleId:l,name:n,description:e,enabled:t,steps:r}}function Un(n,e){let t=ar.readFileSync(n,"utf-8"),r=na.parse(t);try{return Zc.parse(r)}catch(o){throw e.error({err:o,moduleFilePath:n,moduleContents:t},`${n} does not parse as a valid Momentic module`),o}}async function cd(n,e,t,r){let o=Un(n.fullFilePath,t),{resolvedSteps:i}=await Ls({rawSteps:o.steps,migrationMetadata:{id:o.moduleId,schemaVersion:o.schemaVersion},resolvedModuleCache:r,logger:t,callbacks:{onFetchModule:async({id:s})=>{let l=e.modules[s]?.fullFilePath;if(l)return Un(l,t)}}}),a={...o,steps:i};return r&&(r[n.id]=eA(a)),a}async function Ns(n,e){let t={};return await Promise.all(Object.values(n.modules).map(async r=>{await cd(r,n,e,t)})),Array.from(Object.values(t))}async function Pf({test:n,name:e,folder:t}){let r=await Tf({test:n});if(Object.keys(r.modules).length)throw new Error("A brand new test should not contain any modules in it");let i=`${Ne(e)}.${Ot.TEST}`,a=$r.join(t,i);return cn.writeFileSync(a,r.test,"utf-8"),a}function dd(n,e,t){let r=$r.join(t.rootDir,n);if(!cn.existsSync(r))throw new Error(`Test not found at path '${n}' in project '${t.rootDir}'`);let o=cn.readFileSync(r,"utf-8"),i=_o.parse(o),a,s;if(e.name&&e.name!==i.name){let m=`${Ne(e.name)}.${Ot.TEST}`;if(a=$r.join($r.dirname(n),m),s=$r.join(t.rootDir,a),cn.existsSync(s))throw new Error(`Test with name '${e.name}' already exists at path '${s}'`)}let l={...i,...e},c=Kt.parse(l),d={fileType:Ee.TEST,...Kt.parse(c),beforeSteps:i.beforeSteps??void 0,steps:i.steps,afterSteps:i.afterSteps??void 0},p=_o.stringify(d);return cn.writeFileSync(r,p,"utf-8"),s&&cn.renameSync(r,s),Hr(r,t.config),{newRelativeTestPath:a}}function Bn({relativeTestPath:n,steps:e,schemaVersion:t,project:r,forceSaveOnNoDiffs:o}){let i=$r.join(r.rootDir,n);if(!cn.existsSync(i))throw new Error(`Test not found at path '${n}' in project '${r.rootDir}'`);let a=cn.readFileSync(i,"utf-8"),s=_o.parse(a),l=Kt.parse({...s,schemaVersion:t}),c=Fn({fileType:Ee.TEST,...l,beforeSteps:Se.array().or(If.undefined()).parse(e.beforeSteps),steps:Se.array().parse(e.steps),afterSteps:Se.array().or(If.undefined()).parse(e.afterSteps)}),d=nA(c,s);if(d&&Object.keys(d).length===0&&!o){y.debug(`Skipping save for test ${l.name} since there are no changes`);return}let p=_o.stringify(c);cn.writeFileSync(i,p,"utf-8"),y.debug(`Saving test ${l.name} to ${i}`),Hr(i,r.config)}function _s(n,e){let t=$r.join(e.rootDir,n);if(!t)throw new Error(`Could not find test with path ${n} in Momentic project (${e.rootDir})`);let r;try{r=cn.readFileSync(t,"utf8"),r=r.replace(/\r\n|\r/g,`
42
- `)}catch(i){throw new Error(`Could not read test file ${t}: ${i}`)}let o;try{o=_o.parse(r)}catch(i){throw new Error(`Could not parse test file ${t} as YAML: ${i}`)}return bt.parse(o)}function Gr(n,e,t){let r=t.project.rootDir,o;try{o=cn.readFileSync(n,"utf-8")}catch(a){throw e.error({err:a,projectRoot:r},a.message),new Error(a.message)}let i=_o.parse(o);if(!i.steps||!Array.isArray(i.steps))throw new Error(`Test ${n} is missing steps`);return i}async function ra(n,e,t){let r=Gr(n,e,t),o;try{o=Kt.parse(r)}catch(a){throw new Error(`Test ${n} is missing metadata or has invalid metadata: ${a}`)}let{resolvedTest:i}=await wf({rawSteps:{steps:r.steps,beforeSteps:r.beforeSteps,afterSteps:r.afterSteps},metadata:o,logger:e,callbacks:{onFetchModule:async({id:a,logger:s})=>{let l=t.modules[a]?.fullFilePath;if(l)return Un(l,s)}}});return i}import rA from"@dotenvx/dotenvx";import oA from"fs";import Lf from"path";function kf(n,e){return(n.config.environments??[]).map(t=>oa(t.name,n,e))}function Of(n){return n.includes("${")?n.replace(/\$\{([^}]+)\}/g,(e,t)=>{let[r,o]=t.split(/:-|-/,2),i=process.env[r];return t.includes(":-")?i&&i!==""?i:o||"":t.includes("-")?i!==void 0?i:o||"":i||""}):n}function oa(n,e,t){let r=(e.config.environments??[]).find(a=>a.name===n);if(!r)throw new Error(`Environment ${n} not found in local project configuration file`);let o={[Ge]:Of(r.baseUrl)};if(r.envVariables){let a={};for(let[s,l]of Object.entries(r.envVariables))if(typeof l=="string"){let c=Of(l);c&&(a[s]=c)}else{let c=l.fromFile,d;try{d=oA.readFileSync(Lf.resolve(e.rootDir,c),"utf-8")}catch(p){throw new Error(`Failed to read environment variable '${s}' from file '${c}': ${p}`)}if(l.json)try{a[s]=JSON.parse(d)}catch(p){throw new Error(`Failed to parse environment variable '${s}' from file '${c}' as JSON: ${p}`)}else a[s]=d}Object.keys(a).length>0&&y.debug(a,"Set environment variables with interpolation from project configuration"),Object.assign(o,a)}if(r.envFile){let a={},s=rA.config({path:Lf.resolve(e.rootDir,r.envFile),processEnv:a,logLevel:"error",quiet:!0});if(s.error)throw new Error(`Failed to load .env file: ${s.error.message}`);t.debug(a,"Set environment variables from .env file"),Object.assign(o,a)}return r.inheritFromShell&&(t.debug(process.env,"Inheriting environment variables from shell"),Object.assign(o,process.env)),{name:n,variables:o,browser:r.browser}}import{existsSync as _I,readFileSync as DI,readdirSync as FI,writeFileSync as UI}from"fs";var Qf=yT(Wf(),1);var aa=n=>{if(typeof n!="string")throw new TypeError("invalid pattern");if(n.length>65536)throw new TypeError("pattern is too long")};var uA={"[:alnum:]":["\\p{L}\\p{Nl}\\p{Nd}",!0],"[:alpha:]":["\\p{L}\\p{Nl}",!0],"[:ascii:]":["\\x00-\\x7f",!1],"[:blank:]":["\\p{Zs}\\t",!0],"[:cntrl:]":["\\p{Cc}",!0],"[:digit:]":["\\p{Nd}",!0],"[:graph:]":["\\p{Z}\\p{C}",!0,!0],"[:lower:]":["\\p{Ll}",!0],"[:print:]":["\\p{C}",!0],"[:punct:]":["\\p{P}",!0],"[:space:]":["\\p{Z}\\t\\r\\n\\v\\f",!0],"[:upper:]":["\\p{Lu}",!0],"[:word:]":["\\p{L}\\p{Nl}\\p{Nd}\\p{Pc}",!0],"[:xdigit:]":["A-Fa-f0-9",!1]},sa=n=>n.replace(/[[\]\\-]/g,"\\$&"),mA=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),Vf=n=>n.join(""),qf=(n,e)=>{let t=e;if(n.charAt(t)!=="[")throw new Error("not in a brace expression");let r=[],o=[],i=t+1,a=!1,s=!1,l=!1,c=!1,d=t,p="";e:for(;i<n.length;){let g=n.charAt(i);if((g==="!"||g==="^")&&i===t+1){c=!0,i++;continue}if(g==="]"&&a&&!l){d=i+1;break}if(a=!0,g==="\\"&&!l){l=!0,i++;continue}if(g==="["&&!l){for(let[f,[S,b,w]]of Object.entries(uA))if(n.startsWith(f,i)){if(p)return["$.",!1,n.length-t,!0];i+=f.length,w?o.push(S):r.push(S),s=s||b;continue e}}if(l=!1,p){g>p?r.push(sa(p)+"-"+sa(g)):g===p&&r.push(sa(g)),p="",i++;continue}if(n.startsWith("-]",i+1)){r.push(sa(g+"-")),i+=2;continue}if(n.startsWith("-",i+1)){p=g,i+=2;continue}r.push(sa(g)),i++}if(d<i)return["",!1,0,!1];if(!r.length&&!o.length)return["$.",!1,n.length-t,!0];if(o.length===0&&r.length===1&&/^\\?.$/.test(r[0])&&!c){let g=r[0].length===2?r[0].slice(-1):r[0];return[mA(g),!1,d-t,!1]}let m="["+(c?"^":"")+Vf(r)+"]",u="["+(c?"":"^")+Vf(o)+"]";return[r.length&&o.length?"("+m+"|"+u+")":r.length?m:u,s,d-t,!0]};var dn=(n,{windowsPathsNoEscape:e=!1}={})=>e?n.replace(/\[([^\/\\])\]/g,"$1"):n.replace(/((?!\\).|^)\[([^\/\\])\]/g,"$1$2").replace(/\\([^\/])/g,"$1");var hA=new Set(["!","?","+","*","@"]),Kf=n=>hA.has(n),gA="(?!(?:^|/)\\.\\.?(?:$|/))",Ds="(?!\\.)",fA=new Set(["[","."]),SA=new Set(["..","."]),yA=new Set("().*{}+?[]^$\\!"),bA=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),md="[^/]",Yf=md+"*?",Jf=md+"+?",Do=class n{type;#e;#t;#i=!1;#r=[];#a;#w;#c;#p=!1;#s;#l;#o=!1;constructor(e,t,r={}){this.type=e,e&&(this.#t=!0),this.#a=t,this.#e=this.#a?this.#a.#e:this,this.#s=this.#e===this?r:this.#e.#s,this.#c=this.#e===this?[]:this.#e.#c,e==="!"&&!this.#e.#p&&this.#c.push(this),this.#w=this.#a?this.#a.#r.length:0}get hasMagic(){if(this.#t!==void 0)return this.#t;for(let e of this.#r)if(typeof e!="string"&&(e.type||e.hasMagic))return this.#t=!0;return this.#t}toString(){return this.#l!==void 0?this.#l:this.type?this.#l=this.type+"("+this.#r.map(e=>String(e)).join("|")+")":this.#l=this.#r.map(e=>String(e)).join("")}#f(){if(this!==this.#e)throw new Error("should only call on root");if(this.#p)return this;this.toString(),this.#p=!0;let e;for(;e=this.#c.pop();){if(e.type!=="!")continue;let t=e,r=t.#a;for(;r;){for(let o=t.#w+1;!r.type&&o<r.#r.length;o++)for(let i of e.#r){if(typeof i=="string")throw new Error("string part in extglob AST??");i.copyIn(r.#r[o])}t=r,r=t.#a}}return this}push(...e){for(let t of e)if(t!==""){if(typeof t!="string"&&!(t instanceof n&&t.#a===this))throw new Error("invalid part: "+t);this.#r.push(t)}}toJSON(){let e=this.type===null?this.#r.slice().map(t=>typeof t=="string"?t:t.toJSON()):[this.type,...this.#r.map(t=>t.toJSON())];return this.isStart()&&!this.type&&e.unshift([]),this.isEnd()&&(this===this.#e||this.#e.#p&&this.#a?.type==="!")&&e.push({}),e}isStart(){if(this.#e===this)return!0;if(!this.#a?.isStart())return!1;if(this.#w===0)return!0;let e=this.#a;for(let t=0;t<this.#w;t++){let r=e.#r[t];if(!(r instanceof n&&r.type==="!"))return!1}return!0}isEnd(){if(this.#e===this||this.#a?.type==="!")return!0;if(!this.#a?.isEnd())return!1;if(!this.type)return this.#a?.isEnd();let e=this.#a?this.#a.#r.length:0;return this.#w===e-1}copyIn(e){typeof e=="string"?this.push(e):this.push(e.clone(this))}clone(e){let t=new n(this.type,e);for(let r of this.#r)t.copyIn(r);return t}static#S(e,t,r,o){let i=!1,a=!1,s=-1,l=!1;if(t.type===null){let u=r,h="";for(;u<e.length;){let g=e.charAt(u++);if(i||g==="\\"){i=!i,h+=g;continue}if(a){u===s+1?(g==="^"||g==="!")&&(l=!0):g==="]"&&!(u===s+2&&l)&&(a=!1),h+=g;continue}else if(g==="["){a=!0,s=u,l=!1,h+=g;continue}if(!o.noext&&Kf(g)&&e.charAt(u)==="("){t.push(h),h="";let f=new n(g,t);u=n.#S(e,f,u,o),t.push(f);continue}h+=g}return t.push(h),u}let c=r+1,d=new n(null,t),p=[],m="";for(;c<e.length;){let u=e.charAt(c++);if(i||u==="\\"){i=!i,m+=u;continue}if(a){c===s+1?(u==="^"||u==="!")&&(l=!0):u==="]"&&!(c===s+2&&l)&&(a=!1),m+=u;continue}else if(u==="["){a=!0,s=c,l=!1,m+=u;continue}if(Kf(u)&&e.charAt(c)==="("){d.push(m),m="";let h=new n(u,d);d.push(h),c=n.#S(e,h,c,o);continue}if(u==="|"){d.push(m),m="",p.push(d),d=new n(null,t);continue}if(u===")")return m===""&&t.#r.length===0&&(t.#o=!0),d.push(m),m="",t.push(...p,d),c;m+=u}return t.type=null,t.#t=void 0,t.#r=[e.substring(r-1)],c}static fromGlob(e,t={}){let r=new n(null,void 0,t);return n.#S(e,r,0,t),r}toMMPattern(){if(this!==this.#e)return this.#e.toMMPattern();let e=this.toString(),[t,r,o,i]=this.toRegExpSource();if(!(o||this.#t||this.#s.nocase&&!this.#s.nocaseMagicOnly&&e.toUpperCase()!==e.toLowerCase()))return r;let s=(this.#s.nocase?"i":"")+(i?"u":"");return Object.assign(new RegExp(`^${t}$`,s),{_src:t,_glob:e})}get options(){return this.#s}toRegExpSource(e){let t=e??!!this.#s.dot;if(this.#e===this&&this.#f(),!this.type){let l=this.isStart()&&this.isEnd(),c=this.#r.map(u=>{let[h,g,f,S]=typeof u=="string"?n.#u(u,this.#t,l):u.toRegExpSource(e);return this.#t=this.#t||f,this.#i=this.#i||S,h}).join(""),d="";if(this.isStart()&&typeof this.#r[0]=="string"&&!(this.#r.length===1&&SA.has(this.#r[0]))){let h=fA,g=t&&h.has(c.charAt(0))||c.startsWith("\\.")&&h.has(c.charAt(2))||c.startsWith("\\.\\.")&&h.has(c.charAt(4)),f=!t&&!e&&h.has(c.charAt(0));d=g?gA:f?Ds:""}let p="";return this.isEnd()&&this.#e.#p&&this.#a?.type==="!"&&(p="(?:$|\\/)"),[d+c+p,dn(c),this.#t=!!this.#t,this.#i]}let r=this.type==="*"||this.type==="+",o=this.type==="!"?"(?:(?!(?:":"(?:",i=this.#m(t);if(this.isStart()&&this.isEnd()&&!i&&this.type!=="!"){let l=this.toString();return this.#r=[l],this.type=null,this.#t=void 0,[l,dn(this.toString()),!1,!1]}let a=!r||e||t||!Ds?"":this.#m(!0);a===i&&(a=""),a&&(i=`(?:${i})(?:${a})*?`);let s="";if(this.type==="!"&&this.#o)s=(this.isStart()&&!t?Ds:"")+Jf;else{let l=this.type==="!"?"))"+(this.isStart()&&!t&&!e?Ds:"")+Yf+")":this.type==="@"?")":this.type==="?"?")?":this.type==="+"&&a?")":this.type==="*"&&a?")?":`)${this.type}`;s=o+i+l}return[s,dn(i),this.#t=!!this.#t,this.#i]}#m(e){return this.#r.map(t=>{if(typeof t=="string")throw new Error("string type in extglob ast??");let[r,o,i,a]=t.toRegExpSource(e);return this.#i=this.#i||a,r}).filter(t=>!(this.isStart()&&this.isEnd())||!!t).join("|")}static#u(e,t,r=!1){let o=!1,i="",a=!1;for(let s=0;s<e.length;s++){let l=e.charAt(s);if(o){o=!1,i+=(yA.has(l)?"\\":"")+l;continue}if(l==="\\"){s===e.length-1?i+="\\\\":o=!0;continue}if(l==="["){let[c,d,p,m]=qf(e,s);if(p){i+=c,a=a||d,s+=p-1,t=t||m;continue}}if(l==="*"){r&&e==="*"?i+=Jf:i+=Yf,t=!0;continue}if(l==="?"){i+=md,t=!0;continue}i+=bA(l)}return[i,dn(e),!!t,a]}};var Fo=(n,{windowsPathsNoEscape:e=!1}={})=>e?n.replace(/[?*()[\]]/g,"[$&]"):n.replace(/[?*()[\]\\]/g,"\\$&");var wt=(n,e,t={})=>(aa(e),!t.nocomment&&e.charAt(0)==="#"?!1:new Ft(e,t).match(n)),wA=/^\*+([^+@!?\*\[\(]*)$/,vA=n=>e=>!e.startsWith(".")&&e.endsWith(n),TA=n=>e=>e.endsWith(n),xA=n=>(n=n.toLowerCase(),e=>!e.startsWith(".")&&e.toLowerCase().endsWith(n)),EA=n=>(n=n.toLowerCase(),e=>e.toLowerCase().endsWith(n)),CA=/^\*+\.\*+$/,RA=n=>!n.startsWith(".")&&n.includes("."),AA=n=>n!=="."&&n!==".."&&n.includes("."),IA=/^\.\*+$/,PA=n=>n!=="."&&n!==".."&&n.startsWith("."),LA=/^\*+$/,OA=n=>n.length!==0&&!n.startsWith("."),kA=n=>n.length!==0&&n!=="."&&n!=="..",MA=/^\?+([^+@!?\*\[\(]*)?$/,NA=([n,e=""])=>{let t=eS([n]);return e?(e=e.toLowerCase(),r=>t(r)&&r.toLowerCase().endsWith(e)):t},_A=([n,e=""])=>{let t=tS([n]);return e?(e=e.toLowerCase(),r=>t(r)&&r.toLowerCase().endsWith(e)):t},DA=([n,e=""])=>{let t=tS([n]);return e?r=>t(r)&&r.endsWith(e):t},FA=([n,e=""])=>{let t=eS([n]);return e?r=>t(r)&&r.endsWith(e):t},eS=([n])=>{let e=n.length;return t=>t.length===e&&!t.startsWith(".")},tS=([n])=>{let e=n.length;return t=>t.length===e&&t!=="."&&t!==".."},nS=typeof process=="object"&&process?typeof process.env=="object"&&process.env&&process.env.__MINIMATCH_TESTING_PLATFORM__||process.platform:"posix",Xf={win32:{sep:"\\"},posix:{sep:"/"}},UA=nS==="win32"?Xf.win32.sep:Xf.posix.sep;wt.sep=UA;var st=Symbol("globstar **");wt.GLOBSTAR=st;var BA="[^/]",zA=BA+"*?",HA="(?:(?!(?:\\/|^)(?:\\.{1,2})($|\\/)).)*?",jA="(?:(?!(?:\\/|^)\\.).)*?",$A=(n,e={})=>t=>wt(t,n,e);wt.filter=$A;var Jt=(n,e={})=>Object.assign({},n,e),GA=n=>{if(!n||typeof n!="object"||!Object.keys(n).length)return wt;let e=wt;return Object.assign((r,o,i={})=>e(r,o,Jt(n,i)),{Minimatch:class extends e.Minimatch{constructor(o,i={}){super(o,Jt(n,i))}static defaults(o){return e.defaults(Jt(n,o)).Minimatch}},AST:class extends e.AST{constructor(o,i,a={}){super(o,i,Jt(n,a))}static fromGlob(o,i={}){return e.AST.fromGlob(o,Jt(n,i))}},unescape:(r,o={})=>e.unescape(r,Jt(n,o)),escape:(r,o={})=>e.escape(r,Jt(n,o)),filter:(r,o={})=>e.filter(r,Jt(n,o)),defaults:r=>e.defaults(Jt(n,r)),makeRe:(r,o={})=>e.makeRe(r,Jt(n,o)),braceExpand:(r,o={})=>e.braceExpand(r,Jt(n,o)),match:(r,o,i={})=>e.match(r,o,Jt(n,i)),sep:e.sep,GLOBSTAR:st})};wt.defaults=GA;var rS=(n,e={})=>(aa(n),e.nobrace||!/\{(?:(?!\{).)*\}/.test(n)?[n]:(0,Qf.default)(n));wt.braceExpand=rS;var WA=(n,e={})=>new Ft(n,e).makeRe();wt.makeRe=WA;var VA=(n,e,t={})=>{let r=new Ft(e,t);return n=n.filter(o=>r.match(o)),r.options.nonull&&!n.length&&n.push(e),n};wt.match=VA;var Zf=/[?*]|[+@!]\(.*?\)|\[|\]/,qA=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),Ft=class{options;set;pattern;windowsPathsNoEscape;nonegate;negate;comment;empty;preserveMultipleSlashes;partial;globSet;globParts;nocase;isWindows;platform;windowsNoMagicRoot;regexp;constructor(e,t={}){aa(e),t=t||{},this.options=t,this.pattern=e,this.platform=t.platform||nS,this.isWindows=this.platform==="win32",this.windowsPathsNoEscape=!!t.windowsPathsNoEscape||t.allowWindowsEscape===!1,this.windowsPathsNoEscape&&(this.pattern=this.pattern.replace(/\\/g,"/")),this.preserveMultipleSlashes=!!t.preserveMultipleSlashes,this.regexp=null,this.negate=!1,this.nonegate=!!t.nonegate,this.comment=!1,this.empty=!1,this.partial=!!t.partial,this.nocase=!!this.options.nocase,this.windowsNoMagicRoot=t.windowsNoMagicRoot!==void 0?t.windowsNoMagicRoot:!!(this.isWindows&&this.nocase),this.globSet=[],this.globParts=[],this.set=[],this.make()}hasMagic(){if(this.options.magicalBraces&&this.set.length>1)return!0;for(let e of this.set)for(let t of e)if(typeof t!="string")return!0;return!1}debug(...e){}make(){let e=this.pattern,t=this.options;if(!t.nocomment&&e.charAt(0)==="#"){this.comment=!0;return}if(!e){this.empty=!0;return}this.parseNegate(),this.globSet=[...new Set(this.braceExpand())],t.debug&&(this.debug=(...i)=>console.error(...i)),this.debug(this.pattern,this.globSet);let r=this.globSet.map(i=>this.slashSplit(i));this.globParts=this.preprocess(r),this.debug(this.pattern,this.globParts);let o=this.globParts.map((i,a,s)=>{if(this.isWindows&&this.windowsNoMagicRoot){let l=i[0]===""&&i[1]===""&&(i[2]==="?"||!Zf.test(i[2]))&&!Zf.test(i[3]),c=/^[a-z]:/i.test(i[0]);if(l)return[...i.slice(0,4),...i.slice(4).map(d=>this.parse(d))];if(c)return[i[0],...i.slice(1).map(d=>this.parse(d))]}return i.map(l=>this.parse(l))});if(this.debug(this.pattern,o),this.set=o.filter(i=>i.indexOf(!1)===-1),this.isWindows)for(let i=0;i<this.set.length;i++){let a=this.set[i];a[0]===""&&a[1]===""&&this.globParts[i][2]==="?"&&typeof a[3]=="string"&&/^[a-z]:$/i.test(a[3])&&(a[2]="?")}this.debug(this.pattern,this.set)}preprocess(e){if(this.options.noglobstar)for(let r=0;r<e.length;r++)for(let o=0;o<e[r].length;o++)e[r][o]==="**"&&(e[r][o]="*");let{optimizationLevel:t=1}=this.options;return t>=2?(e=this.firstPhasePreProcess(e),e=this.secondPhasePreProcess(e)):t>=1?e=this.levelOneOptimize(e):e=this.adjascentGlobstarOptimize(e),e}adjascentGlobstarOptimize(e){return e.map(t=>{let r=-1;for(;(r=t.indexOf("**",r+1))!==-1;){let o=r;for(;t[o+1]==="**";)o++;o!==r&&t.splice(r,o-r)}return t})}levelOneOptimize(e){return e.map(t=>(t=t.reduce((r,o)=>{let i=r[r.length-1];return o==="**"&&i==="**"?r:o===".."&&i&&i!==".."&&i!=="."&&i!=="**"?(r.pop(),r):(r.push(o),r)},[]),t.length===0?[""]:t))}levelTwoFileOptimize(e){Array.isArray(e)||(e=this.slashSplit(e));let t=!1;do{if(t=!1,!this.preserveMultipleSlashes){for(let o=1;o<e.length-1;o++){let i=e[o];o===1&&i===""&&e[0]===""||(i==="."||i==="")&&(t=!0,e.splice(o,1),o--)}e[0]==="."&&e.length===2&&(e[1]==="."||e[1]==="")&&(t=!0,e.pop())}let r=0;for(;(r=e.indexOf("..",r+1))!==-1;){let o=e[r-1];o&&o!=="."&&o!==".."&&o!=="**"&&(t=!0,e.splice(r-1,2),r-=2)}}while(t);return e.length===0?[""]:e}firstPhasePreProcess(e){let t=!1;do{t=!1;for(let r of e){let o=-1;for(;(o=r.indexOf("**",o+1))!==-1;){let a=o;for(;r[a+1]==="**";)a++;a>o&&r.splice(o+1,a-o);let s=r[o+1],l=r[o+2],c=r[o+3];if(s!==".."||!l||l==="."||l===".."||!c||c==="."||c==="..")continue;t=!0,r.splice(o,1);let d=r.slice(0);d[o]="**",e.push(d),o--}if(!this.preserveMultipleSlashes){for(let a=1;a<r.length-1;a++){let s=r[a];a===1&&s===""&&r[0]===""||(s==="."||s==="")&&(t=!0,r.splice(a,1),a--)}r[0]==="."&&r.length===2&&(r[1]==="."||r[1]==="")&&(t=!0,r.pop())}let i=0;for(;(i=r.indexOf("..",i+1))!==-1;){let a=r[i-1];if(a&&a!=="."&&a!==".."&&a!=="**"){t=!0;let l=i===1&&r[i+1]==="**"?["."]:[];r.splice(i-1,2,...l),r.length===0&&r.push(""),i-=2}}}}while(t);return e}secondPhasePreProcess(e){for(let t=0;t<e.length-1;t++)for(let r=t+1;r<e.length;r++){let o=this.partsMatch(e[t],e[r],!this.preserveMultipleSlashes);if(o){e[t]=[],e[r]=o;break}}return e.filter(t=>t.length)}partsMatch(e,t,r=!1){let o=0,i=0,a=[],s="";for(;o<e.length&&i<t.length;)if(e[o]===t[i])a.push(s==="b"?t[i]:e[o]),o++,i++;else if(r&&e[o]==="**"&&t[i]===e[o+1])a.push(e[o]),o++;else if(r&&t[i]==="**"&&e[o]===t[i+1])a.push(t[i]),i++;else if(e[o]==="*"&&t[i]&&(this.options.dot||!t[i].startsWith("."))&&t[i]!=="**"){if(s==="b")return!1;s="a",a.push(e[o]),o++,i++}else if(t[i]==="*"&&e[o]&&(this.options.dot||!e[o].startsWith("."))&&e[o]!=="**"){if(s==="a")return!1;s="b",a.push(t[i]),o++,i++}else return!1;return e.length===t.length&&a}parseNegate(){if(this.nonegate)return;let e=this.pattern,t=!1,r=0;for(let o=0;o<e.length&&e.charAt(o)==="!";o++)t=!t,r++;r&&(this.pattern=e.slice(r)),this.negate=t}matchOne(e,t,r=!1){let o=this.options;if(this.isWindows){let g=typeof e[0]=="string"&&/^[a-z]:$/i.test(e[0]),f=!g&&e[0]===""&&e[1]===""&&e[2]==="?"&&/^[a-z]:$/i.test(e[3]),S=typeof t[0]=="string"&&/^[a-z]:$/i.test(t[0]),b=!S&&t[0]===""&&t[1]===""&&t[2]==="?"&&typeof t[3]=="string"&&/^[a-z]:$/i.test(t[3]),w=f?3:g?0:void 0,v=b?3:S?0:void 0;if(typeof w=="number"&&typeof v=="number"){let[x,C]=[e[w],t[v]];x.toLowerCase()===C.toLowerCase()&&(t[v]=x,v>w?t=t.slice(v):w>v&&(e=e.slice(w)))}}let{optimizationLevel:i=1}=this.options;i>=2&&(e=this.levelTwoFileOptimize(e)),this.debug("matchOne",this,{file:e,pattern:t}),this.debug("matchOne",e.length,t.length);for(var a=0,s=0,l=e.length,c=t.length;a<l&&s<c;a++,s++){this.debug("matchOne loop");var d=t[s],p=e[a];if(this.debug(t,d,p),d===!1)return!1;if(d===st){this.debug("GLOBSTAR",[t,d,p]);var m=a,u=s+1;if(u===c){for(this.debug("** at the end");a<l;a++)if(e[a]==="."||e[a]===".."||!o.dot&&e[a].charAt(0)===".")return!1;return!0}for(;m<l;){var h=e[m];if(this.debug(`
41
+ `)}function Gg(n,e){try{if(!n)return n;if(typeof n=="string")return He(n,3e4);if(typeof n=="object"){let{jsonString:t}=bo(JSON.stringify(n,(r,o)=>e?.includes(r)||typeof o=="string"&&o.length>3e4?"REDACTED":o),2e4);return JSON.parse(t)}return n}catch{return n}}function sd(n,e){for(let t=0;t<n.length;t++){let r=n[t];try{if(r.data){let{jsonString:o}=bo(JSON.stringify(r.data),1e3);r.data=JSON.parse(o)}}catch(o){e.error({err:o},"Failed to serialize individual result output data"),r.data=`Result output data could not be serialized: ${o}`}switch(r.details&&(r.details=void 0),r.type){case"PRESET_ACTION":jg(r);break;case"CONDITIONAL":r.assertion&&jg(r.assertion),sd(r.results,e);break;case"AI_ACTION_DYNAMIC":case"AI_ACTION":case"IFRAME":case"MODULE":case"SECTION":{sd(r.results,e);break}default:return(i=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(r)}}}function jg(n){let e=n.command;"cache"in e&&e.cache&&(e.cache=void 0)}function $g(n,e){let t=JSON.stringify(n),r=t.replaceAll("\\u0000","");if(t.length!==r.length){let o=t.indexOf("\\u0000");e.warn({input:t.slice(Math.max(0,o-500),Math.min(t.length,o+500))},"Database content violation: stripped unicode character from input")}return r}function As(n,e){let t=MR(n);if(sd(t,e),t.length>Bg)return e.error("Database content violation: results too long, truncating before insertion"),t.slice(0,Bg);let r=$g(t,e);if(r.length>zg)for(e.error({serializedLength:r.length,resultsArrayLength:t.length},"Database content violation: results too large, truncating before insertion");r.length>zg;)t.pop(),r=$g(t,e);try{return It.array().parse(JSON.parse(r))}catch(o){throw e.error({serialized:r,err:o},"Could not parse serialized results into JSON structure after processing"),o}}import{cloneDeep as jW}from"lodash-es";var _R=/^(?!.*\S+\s+\S+).*$/,DR=/^[a-zA-Z0-9\s.,;:'"!?()\- \u00C0-\u00FF]+$/,FR=/style="([^"]*)/g,UR=/data-[\w-]+/g,BR=n=>{switch(n.type){case"AI_ASSERTION":return{type:n.type,assertion:n.assertion};case"DRAG":if(n.fromTarget.type==="description")return{type:n.type,description:n.fromTarget.elementDescriptor};break;case"CLICK":case"BLUR":case"TYPE":case"SELECT_OPTION":case"ELEMENT_CHECK":case"FOCUS":case"HOVER":case"MOUSE_DRAG":case"VISUAL_DIFF":case"SCROLL_DOWN":case"SCROLL_UP":case"SCROLL_LEFT":case"SCROLL_RIGHT":if(n.target?.type==="description")return{type:n.type,description:n.target.elementDescriptor};break}return{type:"NONE",description:"NONE"}};function Wg(n){let e=BR(n),t=e.type==="AI_ASSERTION"?e.assertion:e.description;return!t||t==="NONE"?{thoughts:"NONE",category:"NO_DESCRIPTION_PROVIDED"}:_R.test(t)&&DR.test(t)?{thoughts:"The target description is too short. Please provide more details.",category:"FEW_WORDS"}:FR.test(t)?{thoughts:"Style tags are not recommended in the command description as they change frequently. Please remove them and describe the target in a different way.",category:"STYLE_TAG"}:UR.test(t)?{thoughts:"Hardcoded data attributes are not recommended in the command description as they change frequently.",category:"HARDCODED_ATTRIBUTE"}:new RegExp(`\\b${e.type}\\b`,"gi").test(t)?{thoughts:`The element description you provided starts with the command type (${e.type}). This can confuse our AI agents since the element itself is unrelated to the desired action.`,category:"TYPE_IN_DESCRIPTION"}:{thoughts:"NONE",category:"NONE"}}function Vg(n,e){if(!(!n.envs||!n.envs.length)){for(let t of n.envs){let r=t;e in t&&(r[e]&&(t.default=!0),delete r.defaultOnCloud,delete r.defaultOnLocal)}n.envs.some(t=>t.default)||(n.envs[0].default=!0)}}import{cloneDeep as bf}from"lodash-es";import GR from"diff-lines";import Ps,{gte as WR}from"semver";var qg={name:"Migrate to ai step v2",fromVersion:"1.0.4",toVersion:"1.0.5",recursiveKeys:new Set(["results","commands"]),stopOnFailure:!0,execute:async n=>(n=n.filter(e=>!(e.status!==void 0&&e.type==="AI_ACTION")),n=n.map(e=>(e.status===void 0||e.type==="PRESET_ACTION"&&(e.results=e.commands??e.results??[]),e)),n)};var Kg={name:"Make sure ai step v2 has done command",fromVersion:"1.0.5",toVersion:"1.0.6",recursiveKeys:new Set(["results","commands"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if(e.type!=="AI_ACTION"||e.status!==void 0||!e.commands||!e.commands.length)return e;let t=e.commands,r=t[t.length-1];return r&&r.type!=="SUCCESS"&&t.push({type:"SUCCESS"}),e})};var zR=["target","fromTarget","toTarget"];function Yg(n){for(let e of zR){if(n[e]===void 0)continue;let t=n[e];t.elementDescriptor!==void 0?t.type="description":n[e]={type:"description",elementDescriptor:""}}}var Jg={name:"Migrate element target to discriminated union",fromVersion:"1.0.6",toVersion:"1.0.7",recursiveKeys:new Set(["results","steps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{switch(e.type){case"PRESET_ACTION":return Yg(e.command),e;case"AI_ACTION":{let t=e.commands;for(let r of t??[])Yg(r);return e}default:return e}})};import{v4 as HR}from"uuid";var Xg={name:"Ensure module steps have ids",fromVersion:"1.0.7",toVersion:"1.0.8",recursiveKeys:new Set(["results","steps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{switch(e.type){case"MODULE":return e.id||(e.id=HR()),e;default:return e}})};import{v4 as Zg}from"uuid";var Qg={name:"Ensure module steps have ids",fromVersion:"1.0.8",toVersion:"1.0.9",recursiveKeys:new Set(["results","steps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{switch(e.type){case"PRESET_ACTION":{if(!e.command)return e;let t=e.command;return t.id=t.id??Zg(),e}case"AI_ACTION":return e.commands&&(e.steps=e.commands.map(t=>({type:"PRESET_ACTION",command:{...t,id:t.id??Zg()}})),delete e.commands),e;default:return e}})};var ef={name:"Migrate ai waits to checks",fromVersion:"1.0.9",toVersion:"1.0.10",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{switch(e.type){case"PRESET_ACTION":{if(!e.command)return e;let t=e.command;return typeof t.type!="string"||t.type!=="AI_WAIT"||(t.type="AI_ASSERTION",t.timeout||(t.timeout=10)),e}default:return e}})};import{v4 as jR}from"uuid";var tf={name:"Add ids to all steps",fromVersion:"1.0.10",toVersion:"1.0.11",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>("id"in e&&typeof e.id=="string"||(e.id=jR()),e))};import{v4 as nf}from"uuid";var rf={name:"Add ids to all steps",fromVersion:"1.0.11",toVersion:"1.0.12",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if("id"in e&&typeof e.id=="string")return e;if("condition"in e&&typeof e.condition=="object"&&e.condition){let t=e.condition;t.id||(t.id=nf())}return e.id=nf(),e})};var of={name:"Move env key to steps",fromVersion:"1.0.12",toVersion:"1.0.13",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;return!t||typeof t.envKey!="string"||(e.envKey=t.envKey,delete t.envKey),e})};import{v4 as $R}from"uuid";var af={name:"Redo last two migrations",fromVersion:"1.0.13",toVersion:"1.0.14",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if((!("id"in e)||typeof e.id!="string")&&(e.id=$R()),e.type!=="PRESET_ACTION")return e;let t=e.command;return!t||typeof t.envKey!="string"||(e.envKey=t.envKey,delete t.envKey),e})};var sf={name:"Migrate select choice",fromVersion:"1.0.14",toVersion:"1.0.15",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;return!t||t.type!=="SELECT_OPTION"||e.option===void 0||(e.choice={type:"VALUE",value:t.option},e.option=void 0),e})};var lf={name:"Migrate select choice",fromVersion:"1.0.15",toVersion:"1.0.16",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;return t&&cf(t),e})};function cf(n){n&&Object.keys(n).forEach(e=>{if(typeof n[e]=="object"&&n[e]){cf(n[e]);return}if(typeof n[e]!="string")return;let t=n[e];e==="code"?n[e]=t.replace(/inputs\./g,"env."):t.includes("{{")&&t.includes("}}")&&(n[e]=t.replace(/inputs\./g,"env."))})}var df={name:"Migrate switch tab choice",fromVersion:"1.0.16",toVersion:"1.0.17",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;return!t||t.type!=="TAB"||t.url===void 0||(t.action={type:"SUBSTRING",substring:t.url},t.url=void 0),e})};var pf={name:"Remove press keys sequentially",fromVersion:"1.0.17",toVersion:"1.0.18",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!1,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;return!t||t.type!=="TYPE"?e:t.pressKeysSequentially===void 0?(t.delay=0,e):(t.pressKeysSequentially&&(t.pressKeysSequentially=void 0,t.delay=50),e)})};var uf={name:"Migrate wait for URL to matcher",fromVersion:"1.0.18",toVersion:"1.0.19",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!1,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;return!t||t.type!=="WAIT_FOR_URL"||t.url===void 0||(t.matcher={type:"GLOB",glob:t.url},t.url=void 0),e})};var mf={name:"Migrate select choice round 2",fromVersion:"1.0.19",toVersion:"1.0.20",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if(e.type!=="PRESET_ACTION")return e;let t=e.command;if(!t)return e;if(t.type==="SELECT_OPTION"){if(t.option===void 0)return e;t.choice={type:"VALUE",value:t.option},t.option=void 0}else if(t.type==="TAB"){if(t.url===void 0)return e;t.action={type:"SUBSTRING",substring:t.url},t.url=void 0}else if(t.type==="WAIT_FOR_URL"){if(t.url===void 0)return e;t.matcher={type:"GLOB",glob:t.url},t.url=void 0}else t.type==="AI_WAIT"&&(t.type="AI_ASSERTION",t.timeout||(t.timeout=10));return e})};var hf={name:"Migrate AI assertions to preset actions",fromVersion:"1.0.0",toVersion:"1.0.1",recursiveKeys:new Set,execute:async n=>n.map(e=>{if(e.type!=="AI_ASSERTION")return e;let r={type:"PRESET_ACTION",command:{type:"AI_ASSERTION",assertion:e.text,useVision:!1,disableCache:!0}},o={...e,...r};return delete o.text,o}),stopOnFailure:!0};var Is=new Set(["CLICK","TYPE","SELECT_OPTION"]),gf={name:"Migrate element descriptor to live in a target object",fromVersion:"1.0.3",toVersion:"1.0.4",recursiveKeys:new Set,execute:async n=>n.map(e=>{let t=e.command,r=t?.type,o=t?.elementDescriptor;return(o!==void 0||Is.has(r))&&(t.target={elementDescriptor:o??""}),e.commands&&Array.isArray(e.commands)&&e.commands.forEach(a=>{let s=a?.elementDescriptor,l=a?.type;(s!==void 0||Is.has(l))&&(a.target={elementDescriptor:s??""})}),e.results&&Array.isArray(e.results)&&e.results.forEach(a=>{let s=a.command,l=s?.elementDescriptor,c=s?.type;(l!==void 0||Is.has(c))&&(s.target={elementDescriptor:l??""}),a.commands&&Array.isArray(a.commands)&&a.commands.forEach(p=>{let m=p?.elementDescriptor,u=p?.type;(m!==void 0||Is.has(u))&&(p.target={elementDescriptor:m??""})})}),e}),stopOnFailure:!0};var ff={name:"Migrate FAILURE status to FAILED",fromVersion:"1.0.1",toVersion:"1.0.2",recursiveKeys:new Set,execute:async n=>n.map(e=>{let t=e;return t.status==="FAILURE"&&(t.status="FAILED"),typeof t.commands=="object"&&Array.isArray(t.commands)&&t.commands.forEach(r=>{if(r&&typeof r=="object"){let o=r;o?.status==="FAILURE"&&(o.status="FAILED")}}),t}),stopOnFailure:!0};var Sf={name:"Migrate preset step types to use the same",fromVersion:"1.0.2",toVersion:"1.0.3",recursiveKeys:new Set,execute:async n=>n.map(e=>{let t=e.command,r=t?.type;return r?.startsWith("PRESET_")&&(t.type=r.slice(7)),e.commands&&Array.isArray(e.commands)&&e.commands.forEach(i=>{let a=i.type;a?.startsWith("PRESET_")&&(i.type=a.slice(7))}),e.results&&Array.isArray(e.results)&&e.results.forEach(i=>{let a=i.command,s=a?.type;s?.startsWith("PRESET_")&&(a.type=s.slice(7)),i.commands&&Array.isArray(i.commands)&&i.commands.forEach(c=>{let d=c.type;d?.startsWith("PRESET_")&&(c.type=d.slice(7))})}),e}),stopOnFailure:!0};var Fr=[hf,ff,Sf,gf,qg,Kg,Jg,Xg,Qg,ef,tf,rf,of,af,sf,lf,df,pf,uf,mf];if(Fe!==Fr[Fr.length-1].toVersion)throw new Error("Please bump LATEST_SCHEMA_VERSION in types package after adding a migration");Fr.forEach((n,e)=>{if(!Ps.valid(n.toVersion)||!Ps.valid(n.fromVersion))throw new Error(`Migration '${n.name}' has invalid version`);if(!Ps.gt(n.toVersion,n.fromVersion))throw new Error(`Migration '${n.name}' has toVersion <= fromVersion`);if(e===0)return;if(Fr[e-1].toVersion!==n.fromVersion)throw new Error(`Migration '${n.name}' at index ${e} is not contiguous with previous migration`)});function VR(n){return n.every(e=>e&&typeof e=="object"&&!Array.isArray(e))}var Qi=async({metadata:n,steps:e,logger:t,toVersion:r})=>{let o=e,{schemaVersion:i,id:a}=n,s=Fr.findIndex(d=>Ps.gt(d.toVersion,i));if(s===-1)return{steps:o,newVersion:i};let l=i;for(let d=s;d<Fr.length;d++){if(r&&WR(l,r)){t.debug("Stopping migration early because toVersion was reached");break}let p=Fr[d],m={id:a,migration:p.name,toVersion:p.toVersion};try{o=await yf(o,p),l=p.toVersion}catch(u){throw t.error({err:u,...m},"Migration failed"),new Error(`Step migration ${p.name} failed: ${u}`)}}let c=GR(JSON.stringify(e,void 0,2),JSON.stringify(o,void 0,2),{n_surrounding:1});return c.trim()&&t.debug({diffs:c,id:a},"Migration diffs"),{newVersion:l,steps:o}};async function yf(n,e){let t=await e.execute(n);for(let r of t)for(let o of Object.keys(r)){if(!e.recursiveKeys.has(o))continue;let i=r[o];!i||!Array.isArray(i)||VR(i)&&(r[o]=await yf(i,e))}return t}async function wf({rawSteps:n,metadata:e,logger:t,callbacks:r}){Vg(e,"defaultOnCloud");let o={},{resolvedSteps:i,newSchemaVersion:a}=await Ls({rawSteps:n.steps,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o}),s={...e,steps:i,schemaVersion:a};for(let l of["beforeSteps","afterSteps"]){let c=n[l];if(!c)continue;let{resolvedSteps:d}=await Ls({rawSteps:c,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o});s[l]=d}return{resolvedTest:s,moduleIds:Array.from(Object.keys(o))}}async function Ur(n,e,t){let{newVersion:r,steps:o}=await Qi({metadata:n,steps:e,logger:t});try{return{steps:Se.array().parse(o),newVersion:r}}catch(i){throw t.error({type:"zod",err:i,newVersion:r,id:n.id,steps:o},"Failed to parse test steps while migrating test"),new bs(`Failed to parse test steps while migrating test: ${i}`,n.id,"entity",{cause:i})}}async function Ls({rawSteps:n,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o={}}){let{newVersion:i,steps:a}=await Ur(e,n,t),s=[];for(let l of a)s.push(await ea({step:l,callbacks:r,logger:t,resolvedModuleCache:o}));return{resolvedSteps:s,newSchemaVersion:i}}async function ea({step:n,callbacks:e,logger:t,resolvedModuleCache:r}){switch(n.type){case"AI_ACTION":return n;case"AI_ACTION_DYNAMIC":return n;case"PRESET_ACTION":return n;case"MODULE":{let l=n.moduleId,c=r[l];if(c)return{...bf(c),...n,type:"RESOLVED_MODULE"};let d=await e.onFetchModule({id:l,logger:t});if(!d)throw new Error(`Could not find module with id ${l}`);let{newVersion:p,steps:m}=await Qi({metadata:{id:l,schemaVersion:d.schemaVersion},steps:d.steps,logger:t}),u;try{u=Se.array().parse(m)}catch(f){throw t.error({type:"zod",err:f,steps:m,newVersion:p,id:l},"Module failed to parse"),f}let h;try{h=await Promise.all(u.map(f=>ea({step:f,callbacks:e,logger:t,resolvedModuleCache:r})))}catch(f){throw t.error({err:f,...n},`Failed to recursively resolve module '${d.name}': ${f}`),f}let g={...d,steps:h};return r[l]=bf(g),{...g,...n,type:"RESOLVED_MODULE"}}case"CONDITIONAL":let o=[];for(let l of n.blocks){let c=[];for(let d of l.steps)c.push(await ea({step:d,callbacks:e,logger:t,resolvedModuleCache:r}));o.push({...l,steps:c})}let i;if(n.elseSteps){i=[];for(let l of n.elseSteps)i.push(await ea({step:l,callbacks:e,logger:t,resolvedModuleCache:r}))}return{...n,blocks:o,elseSteps:i};case"SECTION":case"IFRAME":let a=[];for(let l of n.steps)a.push(await ea({step:l,callbacks:e,logger:t,resolvedModuleCache:r}));return{...n,steps:a};default:return(l=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}function qR(n){return typeof n=="object"&&n!==null}function Fn(n){if(Array.isArray(n))return n.map(Fn);if(qR(n)){let e={};return Object.entries(n).forEach(([t,r])=>{r!==void 0&&(e[t]=Fn(r))}),e}return n}import{cloneDeep as KR}from"lodash-es";import{stringify as vf}from"yaml";async function Tf({test:n,processedModuleNames:e=new Set,createNewCacheIds:t=!1}){let r={id:n.id,name:n.name,description:n.description,baseUrl:n.baseUrl,schemaVersion:n.schemaVersion,advanced:n.advanced,retries:n.retries,envs:n.envs,disabled:n.disabled,labels:n.labels},o={},i=await YR({originalStepLists:{steps:n.steps,beforeSteps:n.beforeSteps,afterSteps:n.afterSteps},modules:o,processedModuleNames:e,createNewCacheIds:t}),a={fileType:Ee.TEST,...r,beforeSteps:i.beforeSteps&&i.beforeSteps.length>0?i.beforeSteps:void 0,steps:i.steps,afterSteps:i.afterSteps&&i.afterSteps.length>0?i.afterSteps:void 0};return{test:vf(a),modules:o}}async function YR({originalStepLists:n,modules:e,processedModuleNames:t,createNewCacheIds:r}){let o=KR(n);Object.values(o).forEach(s=>{JR(s??[])});let{stepsToSave:i,moduleUpdates:a}=await Yt({stepLists:o,createNewCacheIds:r});for(let s of a)t.has(s.name)||(e[s.name]=XR(s),t.add(s.name));return i}function JR(n){nd({steps:n,onPresetAction:e=>{e.aiSuggested=void 0,e.index=void 0,e.command.thoughts=void 0},onConditional:e=>{e.aiSuggested=void 0,e.index=void 0},onSimpleStepContainer:e=>{e.aiSuggested=void 0,e.index=void 0}})}function XR(n){let e=Rt.parse(n),t={fileType:Ee.MODULE,...e,schemaVersion:Fe,steps:n.steps};return vf(t)}async function te(n,e){return new Promise((t,r)=>{if(e?.aborted){r(e.reason);return}e?.addEventListener("abort",i);let o=setTimeout(()=>{e?.removeEventListener("abort",i),t()},n);function i(){clearTimeout(o),e?.removeEventListener("abort",i),r(e?.reason)}})}async function ta({promiseGenerator:n,signal:e,codePath:t,logger:r}){let i=Date.now(),a=setInterval(()=>{if(e?.aborted){clearInterval(a);return}r?.warn({codePath:t,startTime:i,elapsedMilliseconds:Date.now()-i},`Asynchronous operation is taking a long time (${t})`)},5e3);return new Promise((s,l)=>{function c(){clearInterval(a),e?.removeEventListener("abort",c),l(e?.reason)}if(e?.aborted){l(e?.reason),clearInterval(a);return}e?.addEventListener("abort",c),(async()=>{try{s(await n())}catch(d){l(d)}finally{clearInterval(a),e?.removeEventListener("abort",c)}})()})}async function Br({promiseGenerator:n,timeoutMs:e,codePath:t,logger:r,signal:o}){let i=!1,a=new AbortController,s=()=>{a.abort()},l=setTimeout(()=>{i||a.abort()},e);o?.addEventListener("abort",s);try{return await ta({promiseGenerator:n,signal:a.signal,codePath:t,logger:r})}finally{i=!0,o?.removeEventListener("abort",s),clearTimeout(l)}}function Os(n){let e=[];for(let t of n)switch(t.type){case"PRESET_ACTION":case"AI_ACTION":case"AI_ACTION_DYNAMIC":e.push(t);break;case"RESOLVED_MODULE":{let r={...t,type:"MODULE"};e.push(_n.parse(r));break}case"IFRAME":case"SECTION":{let r={...t,steps:Os(t.steps)};e.push(Se.parse(r));break}case"CONDITIONAL":{let r={...t,blocks:t.blocks.map(o=>({assertion:o.assertion,steps:Os(o.steps)})),elseSteps:t.elseSteps?Os(t.elseSteps):void 0};e.push(Er.parse(r));break}default:return(o=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(t)}return e}function ks(n){return Os([n])[0]}import ZR from"picomatch";var xf=(n,e,t)=>{t?.caseInsensitive&&(n=n.toLowerCase());let r;switch(e.type){case"SUBSTRING":{let o=t?.caseInsensitive?e.url.toLowerCase():e.url;r=n.includes(o);break}case"GLOB":{let o=t?.caseInsensitive?e.glob.toLowerCase():e.glob;r=n===e.glob||ZR(o)(n);break}case"REGEX":{r=new RegExp(e.regex).test(n);break}}return t?.negated?!r:r},Ms=(n,e)=>{try{let{hostname:t,pathname:r}=new URL(n),{hostname:o,pathname:i}=new URL(e);return t!==o||r!==i}catch{return!1}},ko=n=>{try{return new URL(n),!0}catch{return!1}},Ef=n=>!n.toLowerCase().startsWith("http"),Mo=(n,e)=>{try{return new URL(n,e),!0}catch{return!1}};function zr(n,e){try{return!!new URL(n).origin.trim()}catch(t){return e?.error({url:n,err:t},"Invalid URL in check"),!1}}import No from"yaml";import{z as If}from"zod";import{execSync as QR}from"child_process";function Hr(n,e){let t=e.hooks?.postSave;if(!t)return;let r;t.includes("$1")?r=t.replaceAll("$1",n):r=`${t} ${n}`,y.debug({postSaveCommand:r},"Executing post-save hook command");try{QR(r,{encoding:"utf-8"})}catch(o){y.warn({err:o,postSaveCommand:r},"Failed to execute post-save hook command, continuing...")}}import{diff as Cf}from"deep-object-diff";import ar from"fs";import{cloneDeep as eA}from"lodash-es";import ld from"path";import{v4 as tA}from"uuid";import na from"yaml";function jr({content:n,schemaVersion:e,momenticFiles:t,project:r,forceSaveOnNoDiffs:o}){let i=t.modules[n.moduleId]?.fullFilePath;if(!i||!ar.existsSync(i))throw new Error(`Tried to update module ${n.moduleId} that could not be found on disk`);let a=ar.readFileSync(i,"utf-8"),s=na.parse(a),l;if(n.name&&n.name!==s.name){let u=`${Ne(n.name)}.${Ot.MODULE}`;if(l=ld.join(ld.dirname(i),u),ar.existsSync(l))throw new Error(`Test with name '${n.name}' already exists at path '${l}'`)}let c={...n,schemaVersion:e},d=Fn({fileType:Ee.MODULE,...Yc.parse(c),steps:Se.array().parse(n.steps)}),p=Cf(d,s);if(p&&Object.keys(p).length===0&&!o){y.debug(`Skipping save for module ${n.moduleId} since there are no changes`);return}let m=na.stringify(d);ar.writeFileSync(i,m,"utf-8"),l&&ar.renameSync(i,l),Hr(l||i,r.config)}function Rf({moduleId:n,content:e,momenticFiles:t,project:r,logger:o}){let i=t.modules[n]?.fullFilePath;if(!i)throw new Error(`Tried to update module ${n} that could not be found on disk`);let a=Un(i,o),s={...a,...e},l=Fn({fileType:Ee.MODULE,...Yc.parse(s),steps:a.steps}),c=Cf(l,a);if(c&&Object.keys(c).length===0){y.debug(`Skipping save for module ${n} since there are no changes`);return}let d=na.stringify(l);ar.writeFileSync(i,d,"utf-8"),Hr(i,r.config)}async function Af({name:n,description:e,enabled:t,steps:r,folder:o,project:i}){let a=Ne(n),s=ld.join(o,`${a}.module.yaml`),l=tA(),{stepsToSave:c}=await Yt({stepLists:{steps:r}}),d={fileType:Ee.MODULE,schemaVersion:Fe,moduleId:l,name:n,description:e,enabled:t,steps:c.steps},p=na.stringify(d);return ar.writeFileSync(s,p,"utf-8"),Hr(s,i.config),{moduleId:l,name:n,description:e,enabled:t,steps:r}}function Un(n,e){let t=ar.readFileSync(n,"utf-8"),r=na.parse(t);try{return Zc.parse(r)}catch(o){throw e.error({err:o,moduleFilePath:n,moduleContents:t},`${n} does not parse as a valid Momentic module`),o}}async function cd(n,e,t,r){let o=Un(n.fullFilePath,t),{resolvedSteps:i}=await Ls({rawSteps:o.steps,migrationMetadata:{id:o.moduleId,schemaVersion:o.schemaVersion},resolvedModuleCache:r,logger:t,callbacks:{onFetchModule:async({id:s})=>{let l=e.modules[s]?.fullFilePath;if(l)return Un(l,t)}}}),a={...o,steps:i};return r&&(r[n.id]=eA(a)),a}async function Ns(n,e){let t={};return await Promise.all(Object.values(n.modules).map(async r=>{await cd(r,n,e,t)})),Array.from(Object.values(t))}async function Pf({test:n,name:e,folder:t}){let r=await Tf({test:n});if(Object.keys(r.modules).length)throw new Error("A brand new test should not contain any modules in it");let i=`${Ne(e)}.${Ot.TEST}`,a=$r.join(t,i);return cn.writeFileSync(a,r.test,"utf-8"),a}function dd(n,e,t){let r=$r.join(t.rootDir,n);if(!cn.existsSync(r))throw new Error(`Test not found at path '${n}' in project '${t.rootDir}'`);let o=cn.readFileSync(r,"utf-8"),i=No.parse(o),a,s;if(e.name&&e.name!==i.name){let m=`${Ne(e.name)}.${Ot.TEST}`;if(a=$r.join($r.dirname(n),m),s=$r.join(t.rootDir,a),cn.existsSync(s))throw new Error(`Test with name '${e.name}' already exists at path '${s}'`)}let l={...i,...e},c=Kt.parse(l),d={fileType:Ee.TEST,...Kt.parse(c),beforeSteps:i.beforeSteps??void 0,steps:i.steps,afterSteps:i.afterSteps??void 0},p=No.stringify(d);return cn.writeFileSync(r,p,"utf-8"),s&&cn.renameSync(r,s),Hr(r,t.config),{newRelativeTestPath:a}}function Bn({relativeTestPath:n,steps:e,schemaVersion:t,project:r,forceSaveOnNoDiffs:o}){let i=$r.join(r.rootDir,n);if(!cn.existsSync(i))throw new Error(`Test not found at path '${n}' in project '${r.rootDir}'`);let a=cn.readFileSync(i,"utf-8"),s=No.parse(a),l=Kt.parse({...s,schemaVersion:t}),c=Fn({fileType:Ee.TEST,...l,beforeSteps:Se.array().or(If.undefined()).parse(e.beforeSteps),steps:Se.array().parse(e.steps),afterSteps:Se.array().or(If.undefined()).parse(e.afterSteps)}),d=nA(c,s);if(d&&Object.keys(d).length===0&&!o){y.debug(`Skipping save for test ${l.name} since there are no changes`);return}let p=No.stringify(c);cn.writeFileSync(i,p,"utf-8"),y.debug(`Saving test ${l.name} to ${i}`),Hr(i,r.config)}function _s(n,e){let t=$r.join(e.rootDir,n);if(!t)throw new Error(`Could not find test with path ${n} in Momentic project (${e.rootDir})`);let r;try{r=cn.readFileSync(t,"utf8"),r=r.replace(/\r\n|\r/g,`
42
+ `)}catch(i){throw new Error(`Could not read test file ${t}: ${i}`)}let o;try{o=No.parse(r)}catch(i){throw new Error(`Could not parse test file ${t} as YAML: ${i}`)}return bt.parse(o)}function Gr(n,e,t){let r=t.project.rootDir,o;try{o=cn.readFileSync(n,"utf-8")}catch(a){throw e.error({err:a,projectRoot:r},a.message),new Error(a.message)}let i=No.parse(o);if(!i.steps||!Array.isArray(i.steps))throw new Error(`Test ${n} is missing steps`);return i}async function ra(n,e,t){let r=Gr(n,e,t),o;try{o=Kt.parse(r)}catch(a){throw new Error(`Test ${n} is missing metadata or has invalid metadata: ${a}`)}let{resolvedTest:i}=await wf({rawSteps:{steps:r.steps,beforeSteps:r.beforeSteps,afterSteps:r.afterSteps},metadata:o,logger:e,callbacks:{onFetchModule:async({id:a,logger:s})=>{let l=t.modules[a]?.fullFilePath;if(l)return Un(l,s)}}});return i}import rA from"@dotenvx/dotenvx";import oA from"fs";import Lf from"path";function kf(n,e){return(n.config.environments??[]).map(t=>oa(t.name,n,e))}function Of(n){return n.includes("${")?n.replace(/\$\{([^}]+)\}/g,(e,t)=>{let[r,o]=t.split(/:-|-/,2),i=process.env[r];return t.includes(":-")?i&&i!==""?i:o||"":t.includes("-")?i!==void 0?i:o||"":i||""}):n}function oa(n,e,t){let r=(e.config.environments??[]).find(a=>a.name===n);if(!r)throw new Error(`Environment ${n} not found in local project configuration file`);let o={[Ge]:Of(r.baseUrl)};if(r.envVariables){let a={};for(let[s,l]of Object.entries(r.envVariables))if(typeof l=="string"){let c=Of(l);c&&(a[s]=c)}else{let c=l.fromFile,d;try{d=oA.readFileSync(Lf.resolve(e.rootDir,c),"utf-8")}catch(p){throw new Error(`Failed to read environment variable '${s}' from file '${c}': ${p}`)}if(l.json)try{a[s]=JSON.parse(d)}catch(p){throw new Error(`Failed to parse environment variable '${s}' from file '${c}' as JSON: ${p}`)}else a[s]=d}Object.keys(a).length>0&&y.debug(a,"Set environment variables with interpolation from project configuration"),Object.assign(o,a)}if(r.envFile){let a={},s=rA.config({path:Lf.resolve(e.rootDir,r.envFile),processEnv:a,logLevel:"error",quiet:!0});if(s.error)throw new Error(`Failed to load .env file: ${s.error.message}`);t.debug(a,"Set environment variables from .env file"),Object.assign(o,a)}return r.inheritFromShell&&(t.debug(process.env,"Inheriting environment variables from shell"),Object.assign(o,process.env)),{name:n,variables:o,browser:r.browser}}import{existsSync as _I,readFileSync as DI,readdirSync as FI,writeFileSync as UI}from"fs";var Qf=yT(Wf(),1);var aa=n=>{if(typeof n!="string")throw new TypeError("invalid pattern");if(n.length>65536)throw new TypeError("pattern is too long")};var uA={"[:alnum:]":["\\p{L}\\p{Nl}\\p{Nd}",!0],"[:alpha:]":["\\p{L}\\p{Nl}",!0],"[:ascii:]":["\\x00-\\x7f",!1],"[:blank:]":["\\p{Zs}\\t",!0],"[:cntrl:]":["\\p{Cc}",!0],"[:digit:]":["\\p{Nd}",!0],"[:graph:]":["\\p{Z}\\p{C}",!0,!0],"[:lower:]":["\\p{Ll}",!0],"[:print:]":["\\p{C}",!0],"[:punct:]":["\\p{P}",!0],"[:space:]":["\\p{Z}\\t\\r\\n\\v\\f",!0],"[:upper:]":["\\p{Lu}",!0],"[:word:]":["\\p{L}\\p{Nl}\\p{Nd}\\p{Pc}",!0],"[:xdigit:]":["A-Fa-f0-9",!1]},sa=n=>n.replace(/[[\]\\-]/g,"\\$&"),mA=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),Vf=n=>n.join(""),qf=(n,e)=>{let t=e;if(n.charAt(t)!=="[")throw new Error("not in a brace expression");let r=[],o=[],i=t+1,a=!1,s=!1,l=!1,c=!1,d=t,p="";e:for(;i<n.length;){let g=n.charAt(i);if((g==="!"||g==="^")&&i===t+1){c=!0,i++;continue}if(g==="]"&&a&&!l){d=i+1;break}if(a=!0,g==="\\"&&!l){l=!0,i++;continue}if(g==="["&&!l){for(let[f,[S,b,w]]of Object.entries(uA))if(n.startsWith(f,i)){if(p)return["$.",!1,n.length-t,!0];i+=f.length,w?o.push(S):r.push(S),s=s||b;continue e}}if(l=!1,p){g>p?r.push(sa(p)+"-"+sa(g)):g===p&&r.push(sa(g)),p="",i++;continue}if(n.startsWith("-]",i+1)){r.push(sa(g+"-")),i+=2;continue}if(n.startsWith("-",i+1)){p=g,i+=2;continue}r.push(sa(g)),i++}if(d<i)return["",!1,0,!1];if(!r.length&&!o.length)return["$.",!1,n.length-t,!0];if(o.length===0&&r.length===1&&/^\\?.$/.test(r[0])&&!c){let g=r[0].length===2?r[0].slice(-1):r[0];return[mA(g),!1,d-t,!1]}let m="["+(c?"^":"")+Vf(r)+"]",u="["+(c?"":"^")+Vf(o)+"]";return[r.length&&o.length?"("+m+"|"+u+")":r.length?m:u,s,d-t,!0]};var dn=(n,{windowsPathsNoEscape:e=!1}={})=>e?n.replace(/\[([^\/\\])\]/g,"$1"):n.replace(/((?!\\).|^)\[([^\/\\])\]/g,"$1$2").replace(/\\([^\/])/g,"$1");var hA=new Set(["!","?","+","*","@"]),Kf=n=>hA.has(n),gA="(?!(?:^|/)\\.\\.?(?:$|/))",Ds="(?!\\.)",fA=new Set(["[","."]),SA=new Set(["..","."]),yA=new Set("().*{}+?[]^$\\!"),bA=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),md="[^/]",Yf=md+"*?",Jf=md+"+?",_o=class n{type;#e;#t;#i=!1;#r=[];#a;#w;#c;#p=!1;#s;#l;#o=!1;constructor(e,t,r={}){this.type=e,e&&(this.#t=!0),this.#a=t,this.#e=this.#a?this.#a.#e:this,this.#s=this.#e===this?r:this.#e.#s,this.#c=this.#e===this?[]:this.#e.#c,e==="!"&&!this.#e.#p&&this.#c.push(this),this.#w=this.#a?this.#a.#r.length:0}get hasMagic(){if(this.#t!==void 0)return this.#t;for(let e of this.#r)if(typeof e!="string"&&(e.type||e.hasMagic))return this.#t=!0;return this.#t}toString(){return this.#l!==void 0?this.#l:this.type?this.#l=this.type+"("+this.#r.map(e=>String(e)).join("|")+")":this.#l=this.#r.map(e=>String(e)).join("")}#f(){if(this!==this.#e)throw new Error("should only call on root");if(this.#p)return this;this.toString(),this.#p=!0;let e;for(;e=this.#c.pop();){if(e.type!=="!")continue;let t=e,r=t.#a;for(;r;){for(let o=t.#w+1;!r.type&&o<r.#r.length;o++)for(let i of e.#r){if(typeof i=="string")throw new Error("string part in extglob AST??");i.copyIn(r.#r[o])}t=r,r=t.#a}}return this}push(...e){for(let t of e)if(t!==""){if(typeof t!="string"&&!(t instanceof n&&t.#a===this))throw new Error("invalid part: "+t);this.#r.push(t)}}toJSON(){let e=this.type===null?this.#r.slice().map(t=>typeof t=="string"?t:t.toJSON()):[this.type,...this.#r.map(t=>t.toJSON())];return this.isStart()&&!this.type&&e.unshift([]),this.isEnd()&&(this===this.#e||this.#e.#p&&this.#a?.type==="!")&&e.push({}),e}isStart(){if(this.#e===this)return!0;if(!this.#a?.isStart())return!1;if(this.#w===0)return!0;let e=this.#a;for(let t=0;t<this.#w;t++){let r=e.#r[t];if(!(r instanceof n&&r.type==="!"))return!1}return!0}isEnd(){if(this.#e===this||this.#a?.type==="!")return!0;if(!this.#a?.isEnd())return!1;if(!this.type)return this.#a?.isEnd();let e=this.#a?this.#a.#r.length:0;return this.#w===e-1}copyIn(e){typeof e=="string"?this.push(e):this.push(e.clone(this))}clone(e){let t=new n(this.type,e);for(let r of this.#r)t.copyIn(r);return t}static#S(e,t,r,o){let i=!1,a=!1,s=-1,l=!1;if(t.type===null){let u=r,h="";for(;u<e.length;){let g=e.charAt(u++);if(i||g==="\\"){i=!i,h+=g;continue}if(a){u===s+1?(g==="^"||g==="!")&&(l=!0):g==="]"&&!(u===s+2&&l)&&(a=!1),h+=g;continue}else if(g==="["){a=!0,s=u,l=!1,h+=g;continue}if(!o.noext&&Kf(g)&&e.charAt(u)==="("){t.push(h),h="";let f=new n(g,t);u=n.#S(e,f,u,o),t.push(f);continue}h+=g}return t.push(h),u}let c=r+1,d=new n(null,t),p=[],m="";for(;c<e.length;){let u=e.charAt(c++);if(i||u==="\\"){i=!i,m+=u;continue}if(a){c===s+1?(u==="^"||u==="!")&&(l=!0):u==="]"&&!(c===s+2&&l)&&(a=!1),m+=u;continue}else if(u==="["){a=!0,s=c,l=!1,m+=u;continue}if(Kf(u)&&e.charAt(c)==="("){d.push(m),m="";let h=new n(u,d);d.push(h),c=n.#S(e,h,c,o);continue}if(u==="|"){d.push(m),m="",p.push(d),d=new n(null,t);continue}if(u===")")return m===""&&t.#r.length===0&&(t.#o=!0),d.push(m),m="",t.push(...p,d),c;m+=u}return t.type=null,t.#t=void 0,t.#r=[e.substring(r-1)],c}static fromGlob(e,t={}){let r=new n(null,void 0,t);return n.#S(e,r,0,t),r}toMMPattern(){if(this!==this.#e)return this.#e.toMMPattern();let e=this.toString(),[t,r,o,i]=this.toRegExpSource();if(!(o||this.#t||this.#s.nocase&&!this.#s.nocaseMagicOnly&&e.toUpperCase()!==e.toLowerCase()))return r;let s=(this.#s.nocase?"i":"")+(i?"u":"");return Object.assign(new RegExp(`^${t}$`,s),{_src:t,_glob:e})}get options(){return this.#s}toRegExpSource(e){let t=e??!!this.#s.dot;if(this.#e===this&&this.#f(),!this.type){let l=this.isStart()&&this.isEnd(),c=this.#r.map(u=>{let[h,g,f,S]=typeof u=="string"?n.#u(u,this.#t,l):u.toRegExpSource(e);return this.#t=this.#t||f,this.#i=this.#i||S,h}).join(""),d="";if(this.isStart()&&typeof this.#r[0]=="string"&&!(this.#r.length===1&&SA.has(this.#r[0]))){let h=fA,g=t&&h.has(c.charAt(0))||c.startsWith("\\.")&&h.has(c.charAt(2))||c.startsWith("\\.\\.")&&h.has(c.charAt(4)),f=!t&&!e&&h.has(c.charAt(0));d=g?gA:f?Ds:""}let p="";return this.isEnd()&&this.#e.#p&&this.#a?.type==="!"&&(p="(?:$|\\/)"),[d+c+p,dn(c),this.#t=!!this.#t,this.#i]}let r=this.type==="*"||this.type==="+",o=this.type==="!"?"(?:(?!(?:":"(?:",i=this.#m(t);if(this.isStart()&&this.isEnd()&&!i&&this.type!=="!"){let l=this.toString();return this.#r=[l],this.type=null,this.#t=void 0,[l,dn(this.toString()),!1,!1]}let a=!r||e||t||!Ds?"":this.#m(!0);a===i&&(a=""),a&&(i=`(?:${i})(?:${a})*?`);let s="";if(this.type==="!"&&this.#o)s=(this.isStart()&&!t?Ds:"")+Jf;else{let l=this.type==="!"?"))"+(this.isStart()&&!t&&!e?Ds:"")+Yf+")":this.type==="@"?")":this.type==="?"?")?":this.type==="+"&&a?")":this.type==="*"&&a?")?":`)${this.type}`;s=o+i+l}return[s,dn(i),this.#t=!!this.#t,this.#i]}#m(e){return this.#r.map(t=>{if(typeof t=="string")throw new Error("string type in extglob ast??");let[r,o,i,a]=t.toRegExpSource(e);return this.#i=this.#i||a,r}).filter(t=>!(this.isStart()&&this.isEnd())||!!t).join("|")}static#u(e,t,r=!1){let o=!1,i="",a=!1;for(let s=0;s<e.length;s++){let l=e.charAt(s);if(o){o=!1,i+=(yA.has(l)?"\\":"")+l;continue}if(l==="\\"){s===e.length-1?i+="\\\\":o=!0;continue}if(l==="["){let[c,d,p,m]=qf(e,s);if(p){i+=c,a=a||d,s+=p-1,t=t||m;continue}}if(l==="*"){r&&e==="*"?i+=Jf:i+=Yf,t=!0;continue}if(l==="?"){i+=md,t=!0;continue}i+=bA(l)}return[i,dn(e),!!t,a]}};var Do=(n,{windowsPathsNoEscape:e=!1}={})=>e?n.replace(/[?*()[\]]/g,"[$&]"):n.replace(/[?*()[\]\\]/g,"\\$&");var wt=(n,e,t={})=>(aa(e),!t.nocomment&&e.charAt(0)==="#"?!1:new Ft(e,t).match(n)),wA=/^\*+([^+@!?\*\[\(]*)$/,vA=n=>e=>!e.startsWith(".")&&e.endsWith(n),TA=n=>e=>e.endsWith(n),xA=n=>(n=n.toLowerCase(),e=>!e.startsWith(".")&&e.toLowerCase().endsWith(n)),EA=n=>(n=n.toLowerCase(),e=>e.toLowerCase().endsWith(n)),CA=/^\*+\.\*+$/,RA=n=>!n.startsWith(".")&&n.includes("."),AA=n=>n!=="."&&n!==".."&&n.includes("."),IA=/^\.\*+$/,PA=n=>n!=="."&&n!==".."&&n.startsWith("."),LA=/^\*+$/,OA=n=>n.length!==0&&!n.startsWith("."),kA=n=>n.length!==0&&n!=="."&&n!=="..",MA=/^\?+([^+@!?\*\[\(]*)?$/,NA=([n,e=""])=>{let t=eS([n]);return e?(e=e.toLowerCase(),r=>t(r)&&r.toLowerCase().endsWith(e)):t},_A=([n,e=""])=>{let t=tS([n]);return e?(e=e.toLowerCase(),r=>t(r)&&r.toLowerCase().endsWith(e)):t},DA=([n,e=""])=>{let t=tS([n]);return e?r=>t(r)&&r.endsWith(e):t},FA=([n,e=""])=>{let t=eS([n]);return e?r=>t(r)&&r.endsWith(e):t},eS=([n])=>{let e=n.length;return t=>t.length===e&&!t.startsWith(".")},tS=([n])=>{let e=n.length;return t=>t.length===e&&t!=="."&&t!==".."},nS=typeof process=="object"&&process?typeof process.env=="object"&&process.env&&process.env.__MINIMATCH_TESTING_PLATFORM__||process.platform:"posix",Xf={win32:{sep:"\\"},posix:{sep:"/"}},UA=nS==="win32"?Xf.win32.sep:Xf.posix.sep;wt.sep=UA;var st=Symbol("globstar **");wt.GLOBSTAR=st;var BA="[^/]",zA=BA+"*?",HA="(?:(?!(?:\\/|^)(?:\\.{1,2})($|\\/)).)*?",jA="(?:(?!(?:\\/|^)\\.).)*?",$A=(n,e={})=>t=>wt(t,n,e);wt.filter=$A;var Jt=(n,e={})=>Object.assign({},n,e),GA=n=>{if(!n||typeof n!="object"||!Object.keys(n).length)return wt;let e=wt;return Object.assign((r,o,i={})=>e(r,o,Jt(n,i)),{Minimatch:class extends e.Minimatch{constructor(o,i={}){super(o,Jt(n,i))}static defaults(o){return e.defaults(Jt(n,o)).Minimatch}},AST:class extends e.AST{constructor(o,i,a={}){super(o,i,Jt(n,a))}static fromGlob(o,i={}){return e.AST.fromGlob(o,Jt(n,i))}},unescape:(r,o={})=>e.unescape(r,Jt(n,o)),escape:(r,o={})=>e.escape(r,Jt(n,o)),filter:(r,o={})=>e.filter(r,Jt(n,o)),defaults:r=>e.defaults(Jt(n,r)),makeRe:(r,o={})=>e.makeRe(r,Jt(n,o)),braceExpand:(r,o={})=>e.braceExpand(r,Jt(n,o)),match:(r,o,i={})=>e.match(r,o,Jt(n,i)),sep:e.sep,GLOBSTAR:st})};wt.defaults=GA;var rS=(n,e={})=>(aa(n),e.nobrace||!/\{(?:(?!\{).)*\}/.test(n)?[n]:(0,Qf.default)(n));wt.braceExpand=rS;var WA=(n,e={})=>new Ft(n,e).makeRe();wt.makeRe=WA;var VA=(n,e,t={})=>{let r=new Ft(e,t);return n=n.filter(o=>r.match(o)),r.options.nonull&&!n.length&&n.push(e),n};wt.match=VA;var Zf=/[?*]|[+@!]\(.*?\)|\[|\]/,qA=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),Ft=class{options;set;pattern;windowsPathsNoEscape;nonegate;negate;comment;empty;preserveMultipleSlashes;partial;globSet;globParts;nocase;isWindows;platform;windowsNoMagicRoot;regexp;constructor(e,t={}){aa(e),t=t||{},this.options=t,this.pattern=e,this.platform=t.platform||nS,this.isWindows=this.platform==="win32",this.windowsPathsNoEscape=!!t.windowsPathsNoEscape||t.allowWindowsEscape===!1,this.windowsPathsNoEscape&&(this.pattern=this.pattern.replace(/\\/g,"/")),this.preserveMultipleSlashes=!!t.preserveMultipleSlashes,this.regexp=null,this.negate=!1,this.nonegate=!!t.nonegate,this.comment=!1,this.empty=!1,this.partial=!!t.partial,this.nocase=!!this.options.nocase,this.windowsNoMagicRoot=t.windowsNoMagicRoot!==void 0?t.windowsNoMagicRoot:!!(this.isWindows&&this.nocase),this.globSet=[],this.globParts=[],this.set=[],this.make()}hasMagic(){if(this.options.magicalBraces&&this.set.length>1)return!0;for(let e of this.set)for(let t of e)if(typeof t!="string")return!0;return!1}debug(...e){}make(){let e=this.pattern,t=this.options;if(!t.nocomment&&e.charAt(0)==="#"){this.comment=!0;return}if(!e){this.empty=!0;return}this.parseNegate(),this.globSet=[...new Set(this.braceExpand())],t.debug&&(this.debug=(...i)=>console.error(...i)),this.debug(this.pattern,this.globSet);let r=this.globSet.map(i=>this.slashSplit(i));this.globParts=this.preprocess(r),this.debug(this.pattern,this.globParts);let o=this.globParts.map((i,a,s)=>{if(this.isWindows&&this.windowsNoMagicRoot){let l=i[0]===""&&i[1]===""&&(i[2]==="?"||!Zf.test(i[2]))&&!Zf.test(i[3]),c=/^[a-z]:/i.test(i[0]);if(l)return[...i.slice(0,4),...i.slice(4).map(d=>this.parse(d))];if(c)return[i[0],...i.slice(1).map(d=>this.parse(d))]}return i.map(l=>this.parse(l))});if(this.debug(this.pattern,o),this.set=o.filter(i=>i.indexOf(!1)===-1),this.isWindows)for(let i=0;i<this.set.length;i++){let a=this.set[i];a[0]===""&&a[1]===""&&this.globParts[i][2]==="?"&&typeof a[3]=="string"&&/^[a-z]:$/i.test(a[3])&&(a[2]="?")}this.debug(this.pattern,this.set)}preprocess(e){if(this.options.noglobstar)for(let r=0;r<e.length;r++)for(let o=0;o<e[r].length;o++)e[r][o]==="**"&&(e[r][o]="*");let{optimizationLevel:t=1}=this.options;return t>=2?(e=this.firstPhasePreProcess(e),e=this.secondPhasePreProcess(e)):t>=1?e=this.levelOneOptimize(e):e=this.adjascentGlobstarOptimize(e),e}adjascentGlobstarOptimize(e){return e.map(t=>{let r=-1;for(;(r=t.indexOf("**",r+1))!==-1;){let o=r;for(;t[o+1]==="**";)o++;o!==r&&t.splice(r,o-r)}return t})}levelOneOptimize(e){return e.map(t=>(t=t.reduce((r,o)=>{let i=r[r.length-1];return o==="**"&&i==="**"?r:o===".."&&i&&i!==".."&&i!=="."&&i!=="**"?(r.pop(),r):(r.push(o),r)},[]),t.length===0?[""]:t))}levelTwoFileOptimize(e){Array.isArray(e)||(e=this.slashSplit(e));let t=!1;do{if(t=!1,!this.preserveMultipleSlashes){for(let o=1;o<e.length-1;o++){let i=e[o];o===1&&i===""&&e[0]===""||(i==="."||i==="")&&(t=!0,e.splice(o,1),o--)}e[0]==="."&&e.length===2&&(e[1]==="."||e[1]==="")&&(t=!0,e.pop())}let r=0;for(;(r=e.indexOf("..",r+1))!==-1;){let o=e[r-1];o&&o!=="."&&o!==".."&&o!=="**"&&(t=!0,e.splice(r-1,2),r-=2)}}while(t);return e.length===0?[""]:e}firstPhasePreProcess(e){let t=!1;do{t=!1;for(let r of e){let o=-1;for(;(o=r.indexOf("**",o+1))!==-1;){let a=o;for(;r[a+1]==="**";)a++;a>o&&r.splice(o+1,a-o);let s=r[o+1],l=r[o+2],c=r[o+3];if(s!==".."||!l||l==="."||l===".."||!c||c==="."||c==="..")continue;t=!0,r.splice(o,1);let d=r.slice(0);d[o]="**",e.push(d),o--}if(!this.preserveMultipleSlashes){for(let a=1;a<r.length-1;a++){let s=r[a];a===1&&s===""&&r[0]===""||(s==="."||s==="")&&(t=!0,r.splice(a,1),a--)}r[0]==="."&&r.length===2&&(r[1]==="."||r[1]==="")&&(t=!0,r.pop())}let i=0;for(;(i=r.indexOf("..",i+1))!==-1;){let a=r[i-1];if(a&&a!=="."&&a!==".."&&a!=="**"){t=!0;let l=i===1&&r[i+1]==="**"?["."]:[];r.splice(i-1,2,...l),r.length===0&&r.push(""),i-=2}}}}while(t);return e}secondPhasePreProcess(e){for(let t=0;t<e.length-1;t++)for(let r=t+1;r<e.length;r++){let o=this.partsMatch(e[t],e[r],!this.preserveMultipleSlashes);if(o){e[t]=[],e[r]=o;break}}return e.filter(t=>t.length)}partsMatch(e,t,r=!1){let o=0,i=0,a=[],s="";for(;o<e.length&&i<t.length;)if(e[o]===t[i])a.push(s==="b"?t[i]:e[o]),o++,i++;else if(r&&e[o]==="**"&&t[i]===e[o+1])a.push(e[o]),o++;else if(r&&t[i]==="**"&&e[o]===t[i+1])a.push(t[i]),i++;else if(e[o]==="*"&&t[i]&&(this.options.dot||!t[i].startsWith("."))&&t[i]!=="**"){if(s==="b")return!1;s="a",a.push(e[o]),o++,i++}else if(t[i]==="*"&&e[o]&&(this.options.dot||!e[o].startsWith("."))&&e[o]!=="**"){if(s==="a")return!1;s="b",a.push(t[i]),o++,i++}else return!1;return e.length===t.length&&a}parseNegate(){if(this.nonegate)return;let e=this.pattern,t=!1,r=0;for(let o=0;o<e.length&&e.charAt(o)==="!";o++)t=!t,r++;r&&(this.pattern=e.slice(r)),this.negate=t}matchOne(e,t,r=!1){let o=this.options;if(this.isWindows){let g=typeof e[0]=="string"&&/^[a-z]:$/i.test(e[0]),f=!g&&e[0]===""&&e[1]===""&&e[2]==="?"&&/^[a-z]:$/i.test(e[3]),S=typeof t[0]=="string"&&/^[a-z]:$/i.test(t[0]),b=!S&&t[0]===""&&t[1]===""&&t[2]==="?"&&typeof t[3]=="string"&&/^[a-z]:$/i.test(t[3]),w=f?3:g?0:void 0,v=b?3:S?0:void 0;if(typeof w=="number"&&typeof v=="number"){let[x,C]=[e[w],t[v]];x.toLowerCase()===C.toLowerCase()&&(t[v]=x,v>w?t=t.slice(v):w>v&&(e=e.slice(w)))}}let{optimizationLevel:i=1}=this.options;i>=2&&(e=this.levelTwoFileOptimize(e)),this.debug("matchOne",this,{file:e,pattern:t}),this.debug("matchOne",e.length,t.length);for(var a=0,s=0,l=e.length,c=t.length;a<l&&s<c;a++,s++){this.debug("matchOne loop");var d=t[s],p=e[a];if(this.debug(t,d,p),d===!1)return!1;if(d===st){this.debug("GLOBSTAR",[t,d,p]);var m=a,u=s+1;if(u===c){for(this.debug("** at the end");a<l;a++)if(e[a]==="."||e[a]===".."||!o.dot&&e[a].charAt(0)===".")return!1;return!0}for(;m<l;){var h=e[m];if(this.debug(`
43
43
  globstar while`,e,m,t,u,h),this.matchOne(e.slice(m),t.slice(u),r))return this.debug("globstar found match!",m,l,h),!0;if(h==="."||h===".."||!o.dot&&h.charAt(0)==="."){this.debug("dot detected!",e,m,t,u);break}this.debug("globstar swallow a segment, and continue"),m++}return!!(r&&(this.debug(`
44
- >>> no match, partial?`,e,m,t,u),m===l))}let g;if(typeof d=="string"?(g=p===d,this.debug("string match",d,p,g)):(g=d.test(p),this.debug("pattern match",d,p,g)),!g)return!1}if(a===l&&s===c)return!0;if(a===l)return r;if(s===c)return a===l-1&&e[a]==="";throw new Error("wtf?")}braceExpand(){return rS(this.pattern,this.options)}parse(e){aa(e);let t=this.options;if(e==="**")return st;if(e==="")return"";let r,o=null;(r=e.match(LA))?o=t.dot?kA:OA:(r=e.match(wA))?o=(t.nocase?t.dot?EA:xA:t.dot?TA:vA)(r[1]):(r=e.match(MA))?o=(t.nocase?t.dot?_A:NA:t.dot?DA:FA)(r):(r=e.match(CA))?o=t.dot?AA:RA:(r=e.match(IA))&&(o=PA);let i=Do.fromGlob(e,this.options).toMMPattern();return o&&typeof i=="object"&&Reflect.defineProperty(i,"test",{value:o}),i}makeRe(){if(this.regexp||this.regexp===!1)return this.regexp;let e=this.set;if(!e.length)return this.regexp=!1,this.regexp;let t=this.options,r=t.noglobstar?zA:t.dot?HA:jA,o=new Set(t.nocase?["i"]:[]),i=e.map(l=>{let c=l.map(d=>{if(d instanceof RegExp)for(let p of d.flags.split(""))o.add(p);return typeof d=="string"?qA(d):d===st?st:d._src});return c.forEach((d,p)=>{let m=c[p+1],u=c[p-1];d!==st||u===st||(u===void 0?m!==void 0&&m!==st?c[p+1]="(?:\\/|"+r+"\\/)?"+m:c[p]=r:m===void 0?c[p-1]=u+"(?:\\/|"+r+")?":m!==st&&(c[p-1]=u+"(?:\\/|\\/"+r+"\\/)"+m,c[p+1]=st))}),c.filter(d=>d!==st).join("/")}).join("|"),[a,s]=e.length>1?["(?:",")"]:["",""];i="^"+a+i+s+"$",this.negate&&(i="^(?!"+i+").+$");try{this.regexp=new RegExp(i,[...o].join(""))}catch{this.regexp=!1}return this.regexp}slashSplit(e){return this.preserveMultipleSlashes?e.split("/"):this.isWindows&&/^\/\/[^\/]+/.test(e)?["",...e.split(/\/+/)]:e.split(/\/+/)}match(e,t=this.partial){if(this.debug("match",e,this.pattern),this.comment)return!1;if(this.empty)return e==="";if(e==="/"&&t)return!0;let r=this.options;this.isWindows&&(e=e.split("\\").join("/"));let o=this.slashSplit(e);this.debug(this.pattern,"split",o);let i=this.set;this.debug(this.pattern,"set",i);let a=o[o.length-1];if(!a)for(let s=o.length-2;!a&&s>=0;s--)a=o[s];for(let s=0;s<i.length;s++){let l=i[s],c=o;if(r.matchBase&&l.length===1&&(c=[a]),this.matchOne(c,l,t))return r.flipNegate?!0:!this.negate}return r.flipNegate?!1:this.negate}static defaults(e){return wt.defaults(e).Minimatch}};wt.AST=Do;wt.Minimatch=Ft;wt.escape=Fo;wt.unescape=dn;import{fileURLToPath as CI}from"node:url";var Uo=typeof performance=="object"&&performance&&typeof performance.now=="function"?performance:Date,iS=new Set,hd=typeof process=="object"&&process?process:{},aS=(n,e,t,r)=>{typeof hd.emitWarning=="function"?hd.emitWarning(n,e,t,r):console.error(`[${t}] ${e}: ${n}`)},Fs=globalThis.AbortController,oS=globalThis.AbortSignal;if(typeof Fs>"u"){oS=class{onabort;_onabort=[];reason;aborted=!1;addEventListener(r,o){this._onabort.push(o)}},Fs=class{constructor(){e()}signal=new oS;abort(r){if(!this.signal.aborted){this.signal.reason=r,this.signal.aborted=!0;for(let o of this.signal._onabort)o(r);this.signal.onabort?.(r)}}};let n=hd.env?.LRU_CACHE_IGNORE_AC_WARNING!=="1",e=()=>{n&&(n=!1,aS("AbortController is not defined. If using lru-cache in node 14, load an AbortController polyfill from the `node-abort-controller` package. A minimal polyfill is provided for use by LRUCache.fetch(), but it should not be relied upon in other contexts (eg, passing it to other APIs that use AbortController/AbortSignal might have undesirable effects). You may disable this with LRU_CACHE_IGNORE_AC_WARNING=1 in the env.","NO_ABORT_CONTROLLER","ENOTSUP",e))}}var KA=n=>!iS.has(n),fK=Symbol("type"),sr=n=>n&&n===Math.floor(n)&&n>0&&isFinite(n),sS=n=>sr(n)?n<=Math.pow(2,8)?Uint8Array:n<=Math.pow(2,16)?Uint16Array:n<=Math.pow(2,32)?Uint32Array:n<=Number.MAX_SAFE_INTEGER?Bo:null:null,Bo=class extends Array{constructor(e){super(e),this.fill(0)}},gd=class n{heap;length;static#e=!1;static create(e){let t=sS(e);if(!t)return[];n.#e=!0;let r=new n(e,t);return n.#e=!1,r}constructor(e,t){if(!n.#e)throw new TypeError("instantiate Stack using Stack.create(n)");this.heap=new t(e),this.length=0}push(e){this.heap[this.length++]=e}pop(){return this.heap[--this.length]}},la=class n{#e;#t;#i;#r;#a;#w;ttl;ttlResolution;ttlAutopurge;updateAgeOnGet;updateAgeOnHas;allowStale;noDisposeOnSet;noUpdateTTL;maxEntrySize;sizeCalculation;noDeleteOnFetchRejection;noDeleteOnStaleGet;allowStaleOnFetchAbort;allowStaleOnFetchRejection;ignoreFetchAbort;#c;#p;#s;#l;#o;#f;#S;#m;#u;#x;#g;#E;#C;#b;#v;#T;#h;static unsafeExposeInternals(e){return{starts:e.#C,ttls:e.#b,sizes:e.#E,keyMap:e.#s,keyList:e.#l,valList:e.#o,next:e.#f,prev:e.#S,get head(){return e.#m},get tail(){return e.#u},free:e.#x,isBackgroundFetch:t=>e.#d(t),backgroundFetch:(t,r,o,i)=>e.#U(t,r,o,i),moveToTail:t=>e.#z(t),indexes:t=>e.#A(t),rindexes:t=>e.#I(t),isStale:t=>e.#y(t)}}get max(){return this.#e}get maxSize(){return this.#t}get calculatedSize(){return this.#p}get size(){return this.#c}get fetchMethod(){return this.#a}get memoMethod(){return this.#w}get dispose(){return this.#i}get disposeAfter(){return this.#r}constructor(e){let{max:t=0,ttl:r,ttlResolution:o=1,ttlAutopurge:i,updateAgeOnGet:a,updateAgeOnHas:s,allowStale:l,dispose:c,disposeAfter:d,noDisposeOnSet:p,noUpdateTTL:m,maxSize:u=0,maxEntrySize:h=0,sizeCalculation:g,fetchMethod:f,memoMethod:S,noDeleteOnFetchRejection:b,noDeleteOnStaleGet:w,allowStaleOnFetchRejection:v,allowStaleOnFetchAbort:x,ignoreFetchAbort:C}=e;if(t!==0&&!sr(t))throw new TypeError("max option must be a nonnegative integer");let A=t?sS(t):Array;if(!A)throw new Error("invalid max value: "+t);if(this.#e=t,this.#t=u,this.maxEntrySize=h||this.#t,this.sizeCalculation=g,this.sizeCalculation){if(!this.#t&&!this.maxEntrySize)throw new TypeError("cannot set sizeCalculation without setting maxSize or maxEntrySize");if(typeof this.sizeCalculation!="function")throw new TypeError("sizeCalculation set to non-function")}if(S!==void 0&&typeof S!="function")throw new TypeError("memoMethod must be a function if defined");if(this.#w=S,f!==void 0&&typeof f!="function")throw new TypeError("fetchMethod must be a function if specified");if(this.#a=f,this.#T=!!f,this.#s=new Map,this.#l=new Array(t).fill(void 0),this.#o=new Array(t).fill(void 0),this.#f=new A(t),this.#S=new A(t),this.#m=0,this.#u=0,this.#x=gd.create(t),this.#c=0,this.#p=0,typeof c=="function"&&(this.#i=c),typeof d=="function"?(this.#r=d,this.#g=[]):(this.#r=void 0,this.#g=void 0),this.#v=!!this.#i,this.#h=!!this.#r,this.noDisposeOnSet=!!p,this.noUpdateTTL=!!m,this.noDeleteOnFetchRejection=!!b,this.allowStaleOnFetchRejection=!!v,this.allowStaleOnFetchAbort=!!x,this.ignoreFetchAbort=!!C,this.maxEntrySize!==0){if(this.#t!==0&&!sr(this.#t))throw new TypeError("maxSize must be a positive integer if specified");if(!sr(this.maxEntrySize))throw new TypeError("maxEntrySize must be a positive integer if specified");this.#L()}if(this.allowStale=!!l,this.noDeleteOnStaleGet=!!w,this.updateAgeOnGet=!!a,this.updateAgeOnHas=!!s,this.ttlResolution=sr(o)||o===0?o:1,this.ttlAutopurge=!!i,this.ttl=r||0,this.ttl){if(!sr(this.ttl))throw new TypeError("ttl must be a positive integer if specified");this.#P()}if(this.#e===0&&this.ttl===0&&this.#t===0)throw new TypeError("At least one of max, maxSize, or ttl is required");if(!this.ttlAutopurge&&!this.#e&&!this.#t){let N="LRU_CACHE_UNBOUNDED";KA(N)&&(iS.add(N),aS("TTL caching without ttlAutopurge, max, or maxSize can result in unbounded memory consumption.","UnboundedCacheWarning",N,n))}}getRemainingTTL(e){return this.#s.has(e)?1/0:0}#P(){let e=new Bo(this.#e),t=new Bo(this.#e);this.#b=e,this.#C=t,this.#k=(i,a,s=Uo.now())=>{if(t[i]=a!==0?s:0,e[i]=a,a!==0&&this.ttlAutopurge){let l=setTimeout(()=>{this.#y(i)&&this.#O(this.#l[i],"expire")},a+1);l.unref&&l.unref()}},this.#R=i=>{t[i]=e[i]!==0?Uo.now():0},this.#n=(i,a)=>{if(e[a]){let s=e[a],l=t[a];if(!s||!l)return;i.ttl=s,i.start=l,i.now=r||o();let c=i.now-l;i.remainingTTL=s-c}};let r=0,o=()=>{let i=Uo.now();if(this.ttlResolution>0){r=i;let a=setTimeout(()=>r=0,this.ttlResolution);a.unref&&a.unref()}return i};this.getRemainingTTL=i=>{let a=this.#s.get(i);if(a===void 0)return 0;let s=e[a],l=t[a];if(!s||!l)return 1/0;let c=(r||o())-l;return s-c},this.#y=i=>{let a=t[i],s=e[i];return!!s&&!!a&&(r||o())-a>s}}#R=()=>{};#n=()=>{};#k=()=>{};#y=()=>!1;#L(){let e=new Bo(this.#e);this.#p=0,this.#E=e,this.#M=t=>{this.#p-=e[t],e[t]=0},this.#_=(t,r,o,i)=>{if(this.#d(r))return 0;if(!sr(o))if(i){if(typeof i!="function")throw new TypeError("sizeCalculation must be a function");if(o=i(r,t),!sr(o))throw new TypeError("sizeCalculation return invalid (expect positive integer)")}else throw new TypeError("invalid size value (must be positive integer). When maxSize or maxEntrySize is used, sizeCalculation or size must be set.");return o},this.#N=(t,r,o)=>{if(e[t]=r,this.#t){let i=this.#t-e[t];for(;this.#p>i;)this.#F(!0)}this.#p+=e[t],o&&(o.entrySize=r,o.totalCalculatedSize=this.#p)}}#M=e=>{};#N=(e,t,r)=>{};#_=(e,t,r,o)=>{if(r||o)throw new TypeError("cannot set size without setting maxSize or maxEntrySize on cache");return 0};*#A({allowStale:e=this.allowStale}={}){if(this.#c)for(let t=this.#u;!(!this.#D(t)||((e||!this.#y(t))&&(yield t),t===this.#m));)t=this.#S[t]}*#I({allowStale:e=this.allowStale}={}){if(this.#c)for(let t=this.#m;!(!this.#D(t)||((e||!this.#y(t))&&(yield t),t===this.#u));)t=this.#f[t]}#D(e){return e!==void 0&&this.#s.get(this.#l[e])===e}*entries(){for(let e of this.#A())this.#o[e]!==void 0&&this.#l[e]!==void 0&&!this.#d(this.#o[e])&&(yield[this.#l[e],this.#o[e]])}*rentries(){for(let e of this.#I())this.#o[e]!==void 0&&this.#l[e]!==void 0&&!this.#d(this.#o[e])&&(yield[this.#l[e],this.#o[e]])}*keys(){for(let e of this.#A()){let t=this.#l[e];t!==void 0&&!this.#d(this.#o[e])&&(yield t)}}*rkeys(){for(let e of this.#I()){let t=this.#l[e];t!==void 0&&!this.#d(this.#o[e])&&(yield t)}}*values(){for(let e of this.#A())this.#o[e]!==void 0&&!this.#d(this.#o[e])&&(yield this.#o[e])}*rvalues(){for(let e of this.#I())this.#o[e]!==void 0&&!this.#d(this.#o[e])&&(yield this.#o[e])}[Symbol.iterator](){return this.entries()}[Symbol.toStringTag]="LRUCache";find(e,t={}){for(let r of this.#A()){let o=this.#o[r],i=this.#d(o)?o.__staleWhileFetching:o;if(i!==void 0&&e(i,this.#l[r],this))return this.get(this.#l[r],t)}}forEach(e,t=this){for(let r of this.#A()){let o=this.#o[r],i=this.#d(o)?o.__staleWhileFetching:o;i!==void 0&&e.call(t,i,this.#l[r],this)}}rforEach(e,t=this){for(let r of this.#I()){let o=this.#o[r],i=this.#d(o)?o.__staleWhileFetching:o;i!==void 0&&e.call(t,i,this.#l[r],this)}}purgeStale(){let e=!1;for(let t of this.#I({allowStale:!0}))this.#y(t)&&(this.#O(this.#l[t],"expire"),e=!0);return e}info(e){let t=this.#s.get(e);if(t===void 0)return;let r=this.#o[t],o=this.#d(r)?r.__staleWhileFetching:r;if(o===void 0)return;let i={value:o};if(this.#b&&this.#C){let a=this.#b[t],s=this.#C[t];if(a&&s){let l=a-(Uo.now()-s);i.ttl=l,i.start=Date.now()}}return this.#E&&(i.size=this.#E[t]),i}dump(){let e=[];for(let t of this.#A({allowStale:!0})){let r=this.#l[t],o=this.#o[t],i=this.#d(o)?o.__staleWhileFetching:o;if(i===void 0||r===void 0)continue;let a={value:i};if(this.#b&&this.#C){a.ttl=this.#b[t];let s=Uo.now()-this.#C[t];a.start=Math.floor(Date.now()-s)}this.#E&&(a.size=this.#E[t]),e.unshift([r,a])}return e}load(e){this.clear();for(let[t,r]of e){if(r.start){let o=Date.now()-r.start;r.start=Uo.now()-o}this.set(t,r.value,r)}}set(e,t,r={}){if(t===void 0)return this.delete(e),this;let{ttl:o=this.ttl,start:i,noDisposeOnSet:a=this.noDisposeOnSet,sizeCalculation:s=this.sizeCalculation,status:l}=r,{noUpdateTTL:c=this.noUpdateTTL}=r,d=this.#_(e,t,r.size||0,s);if(this.maxEntrySize&&d>this.maxEntrySize)return l&&(l.set="miss",l.maxEntrySizeExceeded=!0),this.#O(e,"set"),this;let p=this.#c===0?void 0:this.#s.get(e);if(p===void 0)p=this.#c===0?this.#u:this.#x.length!==0?this.#x.pop():this.#c===this.#e?this.#F(!1):this.#c,this.#l[p]=e,this.#o[p]=t,this.#s.set(e,p),this.#f[this.#u]=p,this.#S[p]=this.#u,this.#u=p,this.#c++,this.#N(p,d,l),l&&(l.set="add"),c=!1;else{this.#z(p);let m=this.#o[p];if(t!==m){if(this.#T&&this.#d(m)){m.__abortController.abort(new Error("replaced"));let{__staleWhileFetching:u}=m;u!==void 0&&!a&&(this.#v&&this.#i?.(u,e,"set"),this.#h&&this.#g?.push([u,e,"set"]))}else a||(this.#v&&this.#i?.(m,e,"set"),this.#h&&this.#g?.push([m,e,"set"]));if(this.#M(p),this.#N(p,d,l),this.#o[p]=t,l){l.set="replace";let u=m&&this.#d(m)?m.__staleWhileFetching:m;u!==void 0&&(l.oldValue=u)}}else l&&(l.set="update")}if(o!==0&&!this.#b&&this.#P(),this.#b&&(c||this.#k(p,o,i),l&&this.#n(l,p)),!a&&this.#h&&this.#g){let m=this.#g,u;for(;u=m?.shift();)this.#r?.(...u)}return this}pop(){try{for(;this.#c;){let e=this.#o[this.#m];if(this.#F(!0),this.#d(e)){if(e.__staleWhileFetching)return e.__staleWhileFetching}else if(e!==void 0)return e}}finally{if(this.#h&&this.#g){let e=this.#g,t;for(;t=e?.shift();)this.#r?.(...t)}}}#F(e){let t=this.#m,r=this.#l[t],o=this.#o[t];return this.#T&&this.#d(o)?o.__abortController.abort(new Error("evicted")):(this.#v||this.#h)&&(this.#v&&this.#i?.(o,r,"evict"),this.#h&&this.#g?.push([o,r,"evict"])),this.#M(t),e&&(this.#l[t]=void 0,this.#o[t]=void 0,this.#x.push(t)),this.#c===1?(this.#m=this.#u=0,this.#x.length=0):this.#m=this.#f[t],this.#s.delete(r),this.#c--,t}has(e,t={}){let{updateAgeOnHas:r=this.updateAgeOnHas,status:o}=t,i=this.#s.get(e);if(i!==void 0){let a=this.#o[i];if(this.#d(a)&&a.__staleWhileFetching===void 0)return!1;if(this.#y(i))o&&(o.has="stale",this.#n(o,i));else return r&&this.#R(i),o&&(o.has="hit",this.#n(o,i)),!0}else o&&(o.has="miss");return!1}peek(e,t={}){let{allowStale:r=this.allowStale}=t,o=this.#s.get(e);if(o===void 0||!r&&this.#y(o))return;let i=this.#o[o];return this.#d(i)?i.__staleWhileFetching:i}#U(e,t,r,o){let i=t===void 0?void 0:this.#o[t];if(this.#d(i))return i;let a=new Fs,{signal:s}=r;s?.addEventListener("abort",()=>a.abort(s.reason),{signal:a.signal});let l={signal:a.signal,options:r,context:o},c=(g,f=!1)=>{let{aborted:S}=a.signal,b=r.ignoreFetchAbort&&g!==void 0;if(r.status&&(S&&!f?(r.status.fetchAborted=!0,r.status.fetchError=a.signal.reason,b&&(r.status.fetchAbortIgnored=!0)):r.status.fetchResolved=!0),S&&!b&&!f)return p(a.signal.reason);let w=u;return this.#o[t]===u&&(g===void 0?w.__staleWhileFetching?this.#o[t]=w.__staleWhileFetching:this.#O(e,"fetch"):(r.status&&(r.status.fetchUpdated=!0),this.set(e,g,l.options))),g},d=g=>(r.status&&(r.status.fetchRejected=!0,r.status.fetchError=g),p(g)),p=g=>{let{aborted:f}=a.signal,S=f&&r.allowStaleOnFetchAbort,b=S||r.allowStaleOnFetchRejection,w=b||r.noDeleteOnFetchRejection,v=u;if(this.#o[t]===u&&(!w||v.__staleWhileFetching===void 0?this.#O(e,"fetch"):S||(this.#o[t]=v.__staleWhileFetching)),b)return r.status&&v.__staleWhileFetching!==void 0&&(r.status.returnedStale=!0),v.__staleWhileFetching;if(v.__returned===v)throw g},m=(g,f)=>{let S=this.#a?.(e,i,l);S&&S instanceof Promise&&S.then(b=>g(b===void 0?void 0:b),f),a.signal.addEventListener("abort",()=>{(!r.ignoreFetchAbort||r.allowStaleOnFetchAbort)&&(g(void 0),r.allowStaleOnFetchAbort&&(g=b=>c(b,!0)))})};r.status&&(r.status.fetchDispatched=!0);let u=new Promise(m).then(c,d),h=Object.assign(u,{__abortController:a,__staleWhileFetching:i,__returned:void 0});return t===void 0?(this.set(e,h,{...l.options,status:void 0}),t=this.#s.get(e)):this.#o[t]=h,h}#d(e){if(!this.#T)return!1;let t=e;return!!t&&t instanceof Promise&&t.hasOwnProperty("__staleWhileFetching")&&t.__abortController instanceof Fs}async fetch(e,t={}){let{allowStale:r=this.allowStale,updateAgeOnGet:o=this.updateAgeOnGet,noDeleteOnStaleGet:i=this.noDeleteOnStaleGet,ttl:a=this.ttl,noDisposeOnSet:s=this.noDisposeOnSet,size:l=0,sizeCalculation:c=this.sizeCalculation,noUpdateTTL:d=this.noUpdateTTL,noDeleteOnFetchRejection:p=this.noDeleteOnFetchRejection,allowStaleOnFetchRejection:m=this.allowStaleOnFetchRejection,ignoreFetchAbort:u=this.ignoreFetchAbort,allowStaleOnFetchAbort:h=this.allowStaleOnFetchAbort,context:g,forceRefresh:f=!1,status:S,signal:b}=t;if(!this.#T)return S&&(S.fetch="get"),this.get(e,{allowStale:r,updateAgeOnGet:o,noDeleteOnStaleGet:i,status:S});let w={allowStale:r,updateAgeOnGet:o,noDeleteOnStaleGet:i,ttl:a,noDisposeOnSet:s,size:l,sizeCalculation:c,noUpdateTTL:d,noDeleteOnFetchRejection:p,allowStaleOnFetchRejection:m,allowStaleOnFetchAbort:h,ignoreFetchAbort:u,status:S,signal:b},v=this.#s.get(e);if(v===void 0){S&&(S.fetch="miss");let x=this.#U(e,v,w,g);return x.__returned=x}else{let x=this.#o[v];if(this.#d(x)){let H=r&&x.__staleWhileFetching!==void 0;return S&&(S.fetch="inflight",H&&(S.returnedStale=!0)),H?x.__staleWhileFetching:x.__returned=x}let C=this.#y(v);if(!f&&!C)return S&&(S.fetch="hit"),this.#z(v),o&&this.#R(v),S&&this.#n(S,v),x;let A=this.#U(e,v,w,g),O=A.__staleWhileFetching!==void 0&&r;return S&&(S.fetch=C?"stale":"refresh",O&&C&&(S.returnedStale=!0)),O?A.__staleWhileFetching:A.__returned=A}}async forceFetch(e,t={}){let r=await this.fetch(e,t);if(r===void 0)throw new Error("fetch() returned undefined");return r}memo(e,t={}){let r=this.#w;if(!r)throw new Error("no memoMethod provided to constructor");let{context:o,forceRefresh:i,...a}=t,s=this.get(e,a);if(!i&&s!==void 0)return s;let l=r(e,s,{options:a,context:o});return this.set(e,l,a),l}get(e,t={}){let{allowStale:r=this.allowStale,updateAgeOnGet:o=this.updateAgeOnGet,noDeleteOnStaleGet:i=this.noDeleteOnStaleGet,status:a}=t,s=this.#s.get(e);if(s!==void 0){let l=this.#o[s],c=this.#d(l);return a&&this.#n(a,s),this.#y(s)?(a&&(a.get="stale"),c?(a&&r&&l.__staleWhileFetching!==void 0&&(a.returnedStale=!0),r?l.__staleWhileFetching:void 0):(i||this.#O(e,"expire"),a&&r&&(a.returnedStale=!0),r?l:void 0)):(a&&(a.get="hit"),c?l.__staleWhileFetching:(this.#z(s),o&&this.#R(s),l))}else a&&(a.get="miss")}#B(e,t){this.#S[t]=e,this.#f[e]=t}#z(e){e!==this.#u&&(e===this.#m?this.#m=this.#f[e]:this.#B(this.#S[e],this.#f[e]),this.#B(this.#u,e),this.#u=e)}delete(e){return this.#O(e,"delete")}#O(e,t){let r=!1;if(this.#c!==0){let o=this.#s.get(e);if(o!==void 0)if(r=!0,this.#c===1)this.#H(t);else{this.#M(o);let i=this.#o[o];if(this.#d(i)?i.__abortController.abort(new Error("deleted")):(this.#v||this.#h)&&(this.#v&&this.#i?.(i,e,t),this.#h&&this.#g?.push([i,e,t])),this.#s.delete(e),this.#l[o]=void 0,this.#o[o]=void 0,o===this.#u)this.#u=this.#S[o];else if(o===this.#m)this.#m=this.#f[o];else{let a=this.#S[o];this.#f[a]=this.#f[o];let s=this.#f[o];this.#S[s]=this.#S[o]}this.#c--,this.#x.push(o)}}if(this.#h&&this.#g?.length){let o=this.#g,i;for(;i=o?.shift();)this.#r?.(...i)}return r}clear(){return this.#H("delete")}#H(e){for(let t of this.#I({allowStale:!0})){let r=this.#o[t];if(this.#d(r))r.__abortController.abort(new Error("deleted"));else{let o=this.#l[t];this.#v&&this.#i?.(r,o,e),this.#h&&this.#g?.push([r,o,e])}}if(this.#s.clear(),this.#o.fill(void 0),this.#l.fill(void 0),this.#b&&this.#C&&(this.#b.fill(0),this.#C.fill(0)),this.#E&&this.#E.fill(0),this.#m=0,this.#u=0,this.#x.length=0,this.#p=0,this.#c=0,this.#h&&this.#g){let t=this.#g,r;for(;r=t?.shift();)this.#r?.(...r)}}};import{posix as iI,win32 as Cd}from"node:path";import{fileURLToPath as aI}from"node:url";import{lstatSync as sI,readdir as lI,readdirSync as cI,readlinkSync as dI,realpathSync as pI}from"fs";import*as uI from"node:fs";import{lstat as hI,readdir as gI,readlink as fI,realpath as SI}from"node:fs/promises";import{EventEmitter as Td}from"node:events";import uS from"node:stream";import{StringDecoder as YA}from"node:string_decoder";var lS=typeof process=="object"&&process?process:{stdout:null,stderr:null},JA=n=>!!n&&typeof n=="object"&&(n instanceof cr||n instanceof uS||XA(n)||ZA(n)),XA=n=>!!n&&typeof n=="object"&&n instanceof Td&&typeof n.pipe=="function"&&n.pipe!==uS.Writable.prototype.pipe,ZA=n=>!!n&&typeof n=="object"&&n instanceof Td&&typeof n.write=="function"&&typeof n.end=="function",zn=Symbol("EOF"),Hn=Symbol("maybeEmitEnd"),lr=Symbol("emittedEnd"),Us=Symbol("emittingEnd"),ca=Symbol("emittedError"),Bs=Symbol("closed"),cS=Symbol("read"),zs=Symbol("flush"),dS=Symbol("flushChunk"),pn=Symbol("encoding"),zo=Symbol("decoder"),et=Symbol("flowing"),da=Symbol("paused"),Ho=Symbol("resume"),tt=Symbol("buffer"),vt=Symbol("pipes"),nt=Symbol("bufferLength"),fd=Symbol("bufferPush"),Hs=Symbol("bufferShift"),mt=Symbol("objectMode"),je=Symbol("destroyed"),Sd=Symbol("error"),yd=Symbol("emitData"),pS=Symbol("emitEnd"),bd=Symbol("emitEnd2"),xn=Symbol("async"),wd=Symbol("abort"),js=Symbol("aborted"),pa=Symbol("signal"),Wr=Symbol("dataListeners"),Ut=Symbol("discarded"),ua=n=>Promise.resolve().then(n),QA=n=>n(),eI=n=>n==="end"||n==="finish"||n==="prefinish",tI=n=>n instanceof ArrayBuffer||!!n&&typeof n=="object"&&n.constructor&&n.constructor.name==="ArrayBuffer"&&n.byteLength>=0,nI=n=>!Buffer.isBuffer(n)&&ArrayBuffer.isView(n),$s=class{src;dest;opts;ondrain;constructor(e,t,r){this.src=e,this.dest=t,this.opts=r,this.ondrain=()=>e[Ho](),this.dest.on("drain",this.ondrain)}unpipe(){this.dest.removeListener("drain",this.ondrain)}proxyErrors(e){}end(){this.unpipe(),this.opts.end&&this.dest.end()}},vd=class extends $s{unpipe(){this.src.removeListener("error",this.proxyErrors),super.unpipe()}constructor(e,t,r){super(e,t,r),this.proxyErrors=o=>t.emit("error",o),e.on("error",this.proxyErrors)}},rI=n=>!!n.objectMode,oI=n=>!n.objectMode&&!!n.encoding&&n.encoding!=="buffer",cr=class extends Td{[et]=!1;[da]=!1;[vt]=[];[tt]=[];[mt];[pn];[xn];[zo];[zn]=!1;[lr]=!1;[Us]=!1;[Bs]=!1;[ca]=null;[nt]=0;[je]=!1;[pa];[js]=!1;[Wr]=0;[Ut]=!1;writable=!0;readable=!0;constructor(...e){let t=e[0]||{};if(super(),t.objectMode&&typeof t.encoding=="string")throw new TypeError("Encoding and objectMode may not be used together");rI(t)?(this[mt]=!0,this[pn]=null):oI(t)?(this[pn]=t.encoding,this[mt]=!1):(this[mt]=!1,this[pn]=null),this[xn]=!!t.async,this[zo]=this[pn]?new YA(this[pn]):null,t&&t.debugExposeBuffer===!0&&Object.defineProperty(this,"buffer",{get:()=>this[tt]}),t&&t.debugExposePipes===!0&&Object.defineProperty(this,"pipes",{get:()=>this[vt]});let{signal:r}=t;r&&(this[pa]=r,r.aborted?this[wd]():r.addEventListener("abort",()=>this[wd]()))}get bufferLength(){return this[nt]}get encoding(){return this[pn]}set encoding(e){throw new Error("Encoding must be set at instantiation time")}setEncoding(e){throw new Error("Encoding must be set at instantiation time")}get objectMode(){return this[mt]}set objectMode(e){throw new Error("objectMode must be set at instantiation time")}get async(){return this[xn]}set async(e){this[xn]=this[xn]||!!e}[wd](){this[js]=!0,this.emit("abort",this[pa]?.reason),this.destroy(this[pa]?.reason)}get aborted(){return this[js]}set aborted(e){}write(e,t,r){if(this[js])return!1;if(this[zn])throw new Error("write after end");if(this[je])return this.emit("error",Object.assign(new Error("Cannot call write after a stream was destroyed"),{code:"ERR_STREAM_DESTROYED"})),!0;typeof t=="function"&&(r=t,t="utf8"),t||(t="utf8");let o=this[xn]?ua:QA;if(!this[mt]&&!Buffer.isBuffer(e)){if(nI(e))e=Buffer.from(e.buffer,e.byteOffset,e.byteLength);else if(tI(e))e=Buffer.from(e);else if(typeof e!="string")throw new Error("Non-contiguous data written to non-objectMode stream")}return this[mt]?(this[et]&&this[nt]!==0&&this[zs](!0),this[et]?this.emit("data",e):this[fd](e),this[nt]!==0&&this.emit("readable"),r&&o(r),this[et]):e.length?(typeof e=="string"&&!(t===this[pn]&&!this[zo]?.lastNeed)&&(e=Buffer.from(e,t)),Buffer.isBuffer(e)&&this[pn]&&(e=this[zo].write(e)),this[et]&&this[nt]!==0&&this[zs](!0),this[et]?this.emit("data",e):this[fd](e),this[nt]!==0&&this.emit("readable"),r&&o(r),this[et]):(this[nt]!==0&&this.emit("readable"),r&&o(r),this[et])}read(e){if(this[je])return null;if(this[Ut]=!1,this[nt]===0||e===0||e&&e>this[nt])return this[Hn](),null;this[mt]&&(e=null),this[tt].length>1&&!this[mt]&&(this[tt]=[this[pn]?this[tt].join(""):Buffer.concat(this[tt],this[nt])]);let t=this[cS](e||null,this[tt][0]);return this[Hn](),t}[cS](e,t){if(this[mt])this[Hs]();else{let r=t;e===r.length||e===null?this[Hs]():typeof r=="string"?(this[tt][0]=r.slice(e),t=r.slice(0,e),this[nt]-=e):(this[tt][0]=r.subarray(e),t=r.subarray(0,e),this[nt]-=e)}return this.emit("data",t),!this[tt].length&&!this[zn]&&this.emit("drain"),t}end(e,t,r){return typeof e=="function"&&(r=e,e=void 0),typeof t=="function"&&(r=t,t="utf8"),e!==void 0&&this.write(e,t),r&&this.once("end",r),this[zn]=!0,this.writable=!1,(this[et]||!this[da])&&this[Hn](),this}[Ho](){this[je]||(!this[Wr]&&!this[vt].length&&(this[Ut]=!0),this[da]=!1,this[et]=!0,this.emit("resume"),this[tt].length?this[zs]():this[zn]?this[Hn]():this.emit("drain"))}resume(){return this[Ho]()}pause(){this[et]=!1,this[da]=!0,this[Ut]=!1}get destroyed(){return this[je]}get flowing(){return this[et]}get paused(){return this[da]}[fd](e){this[mt]?this[nt]+=1:this[nt]+=e.length,this[tt].push(e)}[Hs](){return this[mt]?this[nt]-=1:this[nt]-=this[tt][0].length,this[tt].shift()}[zs](e=!1){do;while(this[dS](this[Hs]())&&this[tt].length);!e&&!this[tt].length&&!this[zn]&&this.emit("drain")}[dS](e){return this.emit("data",e),this[et]}pipe(e,t){if(this[je])return e;this[Ut]=!1;let r=this[lr];return t=t||{},e===lS.stdout||e===lS.stderr?t.end=!1:t.end=t.end!==!1,t.proxyErrors=!!t.proxyErrors,r?t.end&&e.end():(this[vt].push(t.proxyErrors?new vd(this,e,t):new $s(this,e,t)),this[xn]?ua(()=>this[Ho]()):this[Ho]()),e}unpipe(e){let t=this[vt].find(r=>r.dest===e);t&&(this[vt].length===1?(this[et]&&this[Wr]===0&&(this[et]=!1),this[vt]=[]):this[vt].splice(this[vt].indexOf(t),1),t.unpipe())}addListener(e,t){return this.on(e,t)}on(e,t){let r=super.on(e,t);if(e==="data")this[Ut]=!1,this[Wr]++,!this[vt].length&&!this[et]&&this[Ho]();else if(e==="readable"&&this[nt]!==0)super.emit("readable");else if(eI(e)&&this[lr])super.emit(e),this.removeAllListeners(e);else if(e==="error"&&this[ca]){let o=t;this[xn]?ua(()=>o.call(this,this[ca])):o.call(this,this[ca])}return r}removeListener(e,t){return this.off(e,t)}off(e,t){let r=super.off(e,t);return e==="data"&&(this[Wr]=this.listeners("data").length,this[Wr]===0&&!this[Ut]&&!this[vt].length&&(this[et]=!1)),r}removeAllListeners(e){let t=super.removeAllListeners(e);return(e==="data"||e===void 0)&&(this[Wr]=0,!this[Ut]&&!this[vt].length&&(this[et]=!1)),t}get emittedEnd(){return this[lr]}[Hn](){!this[Us]&&!this[lr]&&!this[je]&&this[tt].length===0&&this[zn]&&(this[Us]=!0,this.emit("end"),this.emit("prefinish"),this.emit("finish"),this[Bs]&&this.emit("close"),this[Us]=!1)}emit(e,...t){let r=t[0];if(e!=="error"&&e!=="close"&&e!==je&&this[je])return!1;if(e==="data")return!this[mt]&&!r?!1:this[xn]?(ua(()=>this[yd](r)),!0):this[yd](r);if(e==="end")return this[pS]();if(e==="close"){if(this[Bs]=!0,!this[lr]&&!this[je])return!1;let i=super.emit("close");return this.removeAllListeners("close"),i}else if(e==="error"){this[ca]=r,super.emit(Sd,r);let i=!this[pa]||this.listeners("error").length?super.emit("error",r):!1;return this[Hn](),i}else if(e==="resume"){let i=super.emit("resume");return this[Hn](),i}else if(e==="finish"||e==="prefinish"){let i=super.emit(e);return this.removeAllListeners(e),i}let o=super.emit(e,...t);return this[Hn](),o}[yd](e){for(let r of this[vt])r.dest.write(e)===!1&&this.pause();let t=this[Ut]?!1:super.emit("data",e);return this[Hn](),t}[pS](){return this[lr]?!1:(this[lr]=!0,this.readable=!1,this[xn]?(ua(()=>this[bd]()),!0):this[bd]())}[bd](){if(this[zo]){let t=this[zo].end();if(t){for(let r of this[vt])r.dest.write(t);this[Ut]||super.emit("data",t)}}for(let t of this[vt])t.end();let e=super.emit("end");return this.removeAllListeners("end"),e}async collect(){let e=Object.assign([],{dataLength:0});this[mt]||(e.dataLength=0);let t=this.promise();return this.on("data",r=>{e.push(r),this[mt]||(e.dataLength+=r.length)}),await t,e}async concat(){if(this[mt])throw new Error("cannot concat in objectMode");let e=await this.collect();return this[pn]?e.join(""):Buffer.concat(e,e.dataLength)}async promise(){return new Promise((e,t)=>{this.on(je,()=>t(new Error("stream destroyed"))),this.on("error",r=>t(r)),this.on("end",()=>e())})}[Symbol.asyncIterator](){this[Ut]=!1;let e=!1,t=async()=>(this.pause(),e=!0,{value:void 0,done:!0});return{next:()=>{if(e)return t();let o=this.read();if(o!==null)return Promise.resolve({done:!1,value:o});if(this[zn])return t();let i,a,s=p=>{this.off("data",l),this.off("end",c),this.off(je,d),t(),a(p)},l=p=>{this.off("error",s),this.off("end",c),this.off(je,d),this.pause(),i({value:p,done:!!this[zn]})},c=()=>{this.off("error",s),this.off("data",l),this.off(je,d),t(),i({done:!0,value:void 0})},d=()=>s(new Error("stream destroyed"));return new Promise((p,m)=>{a=m,i=p,this.once(je,d),this.once("error",s),this.once("end",c),this.once("data",l)})},throw:t,return:t,[Symbol.asyncIterator](){return this}}}[Symbol.iterator](){this[Ut]=!1;let e=!1,t=()=>(this.pause(),this.off(Sd,t),this.off(je,t),this.off("end",t),e=!0,{done:!0,value:void 0}),r=()=>{if(e)return t();let o=this.read();return o===null?t():{done:!1,value:o}};return this.once("end",t),this.once(Sd,t),this.once(je,t),{next:r,throw:t,return:t,[Symbol.iterator](){return this}}}destroy(e){if(this[je])return e?this.emit("error",e):this.emit(je),this;this[je]=!0,this[Ut]=!0,this[tt].length=0,this[nt]=0;let t=this;return typeof t.close=="function"&&!this[Bs]&&t.close(),e?this.emit("error",e):this.emit(je),this}static get isStream(){return JA}};var mI=pI.native,ha={lstatSync:sI,readdir:lI,readdirSync:cI,readlinkSync:dI,realpathSync:mI,promises:{lstat:hI,readdir:gI,readlink:fI,realpath:SI}},SS=n=>!n||n===ha||n===uI?ha:{...ha,...n,promises:{...ha.promises,...n.promises||{}}},yS=/^\\\\\?\\([a-z]:)\\?$/i,yI=n=>n.replace(/\//g,"\\").replace(yS,"$1\\"),bI=/[\\\/]/,Zt=0,bS=1,wS=2,En=4,vS=6,TS=8,Vr=10,xS=12,Xt=15,ma=~Xt,xd=16,mS=32,ga=64,un=128,Gs=256,Vs=512,hS=ga|un|Vs,wI=1023,Ed=n=>n.isFile()?TS:n.isDirectory()?En:n.isSymbolicLink()?Vr:n.isCharacterDevice()?wS:n.isBlockDevice()?vS:n.isSocket()?xS:n.isFIFO()?bS:Zt,gS=new Map,fa=n=>{let e=gS.get(n);if(e)return e;let t=n.normalize("NFKD");return gS.set(n,t),t},fS=new Map,Ws=n=>{let e=fS.get(n);if(e)return e;let t=fa(n.toLowerCase());return fS.set(n,t),t},qs=class extends la{constructor(){super({max:256})}},Rd=class extends la{constructor(e=16*1024){super({maxSize:e,sizeCalculation:t=>t.length+1})}},ES=Symbol("PathScurry setAsCwd"),ht=class{name;root;roots;parent;nocase;isCWD=!1;#e;#t;get dev(){return this.#t}#i;get mode(){return this.#i}#r;get nlink(){return this.#r}#a;get uid(){return this.#a}#w;get gid(){return this.#w}#c;get rdev(){return this.#c}#p;get blksize(){return this.#p}#s;get ino(){return this.#s}#l;get size(){return this.#l}#o;get blocks(){return this.#o}#f;get atimeMs(){return this.#f}#S;get mtimeMs(){return this.#S}#m;get ctimeMs(){return this.#m}#u;get birthtimeMs(){return this.#u}#x;get atime(){return this.#x}#g;get mtime(){return this.#g}#E;get ctime(){return this.#E}#C;get birthtime(){return this.#C}#b;#v;#T;#h;#P;#R;#n;#k;#y;#L;get parentPath(){return(this.parent||this).fullpath()}get path(){return this.parentPath}constructor(e,t=Zt,r,o,i,a,s){this.name=e,this.#b=i?Ws(e):fa(e),this.#n=t&wI,this.nocase=i,this.roots=o,this.root=r||this,this.#k=a,this.#T=s.fullpath,this.#P=s.relative,this.#R=s.relativePosix,this.parent=s.parent,this.parent?this.#e=this.parent.#e:this.#e=SS(s.fs)}depth(){return this.#v!==void 0?this.#v:this.parent?this.#v=this.parent.depth()+1:this.#v=0}childrenCache(){return this.#k}resolve(e){if(!e)return this;let t=this.getRootString(e),o=e.substring(t.length).split(this.splitSep);return t?this.getRoot(t).#M(o):this.#M(o)}#M(e){let t=this;for(let r of e)t=t.child(r);return t}children(){let e=this.#k.get(this);if(e)return e;let t=Object.assign([],{provisional:0});return this.#k.set(this,t),this.#n&=~xd,t}child(e,t){if(e===""||e===".")return this;if(e==="..")return this.parent||this;let r=this.children(),o=this.nocase?Ws(e):fa(e);for(let l of r)if(l.#b===o)return l;let i=this.parent?this.sep:"",a=this.#T?this.#T+i+e:void 0,s=this.newChild(e,Zt,{...t,parent:this,fullpath:a});return this.canReaddir()||(s.#n|=un),r.push(s),s}relative(){if(this.isCWD)return"";if(this.#P!==void 0)return this.#P;let e=this.name,t=this.parent;if(!t)return this.#P=this.name;let r=t.relative();return r+(!r||!t.parent?"":this.sep)+e}relativePosix(){if(this.sep==="/")return this.relative();if(this.isCWD)return"";if(this.#R!==void 0)return this.#R;let e=this.name,t=this.parent;if(!t)return this.#R=this.fullpathPosix();let r=t.relativePosix();return r+(!r||!t.parent?"":"/")+e}fullpath(){if(this.#T!==void 0)return this.#T;let e=this.name,t=this.parent;if(!t)return this.#T=this.name;let o=t.fullpath()+(t.parent?this.sep:"")+e;return this.#T=o}fullpathPosix(){if(this.#h!==void 0)return this.#h;if(this.sep==="/")return this.#h=this.fullpath();if(!this.parent){let o=this.fullpath().replace(/\\/g,"/");return/^[a-z]:\//i.test(o)?this.#h=`//?/${o}`:this.#h=o}let e=this.parent,t=e.fullpathPosix(),r=t+(!t||!e.parent?"":"/")+this.name;return this.#h=r}isUnknown(){return(this.#n&Xt)===Zt}isType(e){return this[`is${e}`]()}getType(){return this.isUnknown()?"Unknown":this.isDirectory()?"Directory":this.isFile()?"File":this.isSymbolicLink()?"SymbolicLink":this.isFIFO()?"FIFO":this.isCharacterDevice()?"CharacterDevice":this.isBlockDevice()?"BlockDevice":this.isSocket()?"Socket":"Unknown"}isFile(){return(this.#n&Xt)===TS}isDirectory(){return(this.#n&Xt)===En}isCharacterDevice(){return(this.#n&Xt)===wS}isBlockDevice(){return(this.#n&Xt)===vS}isFIFO(){return(this.#n&Xt)===bS}isSocket(){return(this.#n&Xt)===xS}isSymbolicLink(){return(this.#n&Vr)===Vr}lstatCached(){return this.#n&mS?this:void 0}readlinkCached(){return this.#y}realpathCached(){return this.#L}readdirCached(){let e=this.children();return e.slice(0,e.provisional)}canReadlink(){if(this.#y)return!0;if(!this.parent)return!1;let e=this.#n&Xt;return!(e!==Zt&&e!==Vr||this.#n&Gs||this.#n&un)}calledReaddir(){return!!(this.#n&xd)}isENOENT(){return!!(this.#n&un)}isNamed(e){return this.nocase?this.#b===Ws(e):this.#b===fa(e)}async readlink(){let e=this.#y;if(e)return e;if(this.canReadlink()&&this.parent)try{let t=await this.#e.promises.readlink(this.fullpath()),r=(await this.parent.realpath())?.resolve(t);if(r)return this.#y=r}catch(t){this.#d(t.code);return}}readlinkSync(){let e=this.#y;if(e)return e;if(this.canReadlink()&&this.parent)try{let t=this.#e.readlinkSync(this.fullpath()),r=this.parent.realpathSync()?.resolve(t);if(r)return this.#y=r}catch(t){this.#d(t.code);return}}#N(e){this.#n|=xd;for(let t=e.provisional;t<e.length;t++){let r=e[t];r&&r.#_()}}#_(){this.#n&un||(this.#n=(this.#n|un)&ma,this.#A())}#A(){let e=this.children();e.provisional=0;for(let t of e)t.#_()}#I(){this.#n|=Vs,this.#D()}#D(){if(this.#n&ga)return;let e=this.#n;(e&Xt)===En&&(e&=ma),this.#n=e|ga,this.#A()}#F(e=""){e==="ENOTDIR"||e==="EPERM"?this.#D():e==="ENOENT"?this.#_():this.children().provisional=0}#U(e=""){e==="ENOTDIR"?this.parent.#D():e==="ENOENT"&&this.#_()}#d(e=""){let t=this.#n;t|=Gs,e==="ENOENT"&&(t|=un),(e==="EINVAL"||e==="UNKNOWN")&&(t&=ma),this.#n=t,e==="ENOTDIR"&&this.parent&&this.parent.#D()}#B(e,t){return this.#O(e,t)||this.#z(e,t)}#z(e,t){let r=Ed(e),o=this.newChild(e.name,r,{parent:this}),i=o.#n&Xt;return i!==En&&i!==Vr&&i!==Zt&&(o.#n|=ga),t.unshift(o),t.provisional++,o}#O(e,t){for(let r=t.provisional;r<t.length;r++){let o=t[r];if((this.nocase?Ws(e.name):fa(e.name))===o.#b)return this.#H(e,o,r,t)}}#H(e,t,r,o){let i=t.name;return t.#n=t.#n&ma|Ed(e),i!==e.name&&(t.name=e.name),r!==o.provisional&&(r===o.length-1?o.pop():o.splice(r,1),o.unshift(t)),o.provisional++,t}async lstat(){if(!(this.#n&un))try{return this.#W(await this.#e.promises.lstat(this.fullpath())),this}catch(e){this.#U(e.code)}}lstatSync(){if(!(this.#n&un))try{return this.#W(this.#e.lstatSync(this.fullpath())),this}catch(e){this.#U(e.code)}}#W(e){let{atime:t,atimeMs:r,birthtime:o,birthtimeMs:i,blksize:a,blocks:s,ctime:l,ctimeMs:c,dev:d,gid:p,ino:m,mode:u,mtime:h,mtimeMs:g,nlink:f,rdev:S,size:b,uid:w}=e;this.#x=t,this.#f=r,this.#C=o,this.#u=i,this.#p=a,this.#o=s,this.#E=l,this.#m=c,this.#t=d,this.#w=p,this.#s=m,this.#i=u,this.#g=h,this.#S=g,this.#r=f,this.#c=S,this.#l=b,this.#a=w;let v=Ed(e);this.#n=this.#n&ma|v|mS,v!==Zt&&v!==En&&v!==Vr&&(this.#n|=ga)}#$=[];#G=!1;#V(e){this.#G=!1;let t=this.#$.slice();this.#$.length=0,t.forEach(r=>r(null,e))}readdirCB(e,t=!1){if(!this.canReaddir()){t?e(null,[]):queueMicrotask(()=>e(null,[]));return}let r=this.children();if(this.calledReaddir()){let i=r.slice(0,r.provisional);t?e(null,i):queueMicrotask(()=>e(null,i));return}if(this.#$.push(e),this.#G)return;this.#G=!0;let o=this.fullpath();this.#e.readdir(o,{withFileTypes:!0},(i,a)=>{if(i)this.#F(i.code),r.provisional=0;else{for(let s of a)this.#B(s,r);this.#N(r)}this.#V(r.slice(0,r.provisional))})}#j;async readdir(){if(!this.canReaddir())return[];let e=this.children();if(this.calledReaddir())return e.slice(0,e.provisional);let t=this.fullpath();if(this.#j)await this.#j;else{let r=()=>{};this.#j=new Promise(o=>r=o);try{for(let o of await this.#e.promises.readdir(t,{withFileTypes:!0}))this.#B(o,e);this.#N(e)}catch(o){this.#F(o.code),e.provisional=0}this.#j=void 0,r()}return e.slice(0,e.provisional)}readdirSync(){if(!this.canReaddir())return[];let e=this.children();if(this.calledReaddir())return e.slice(0,e.provisional);let t=this.fullpath();try{for(let r of this.#e.readdirSync(t,{withFileTypes:!0}))this.#B(r,e);this.#N(e)}catch(r){this.#F(r.code),e.provisional=0}return e.slice(0,e.provisional)}canReaddir(){if(this.#n&hS)return!1;let e=Xt&this.#n;return e===Zt||e===En||e===Vr}shouldWalk(e,t){return(this.#n&En)===En&&!(this.#n&hS)&&!e.has(this)&&(!t||t(this))}async realpath(){if(this.#L)return this.#L;if(!((Vs|Gs|un)&this.#n))try{let e=await this.#e.promises.realpath(this.fullpath());return this.#L=this.resolve(e)}catch{this.#I()}}realpathSync(){if(this.#L)return this.#L;if(!((Vs|Gs|un)&this.#n))try{let e=this.#e.realpathSync(this.fullpath());return this.#L=this.resolve(e)}catch{this.#I()}}[ES](e){if(e===this)return;e.isCWD=!1,this.isCWD=!0;let t=new Set([]),r=[],o=this;for(;o&&o.parent;)t.add(o),o.#P=r.join(this.sep),o.#R=r.join("/"),o=o.parent,r.push("..");for(o=e;o&&o.parent&&!t.has(o);)o.#P=void 0,o.#R=void 0,o=o.parent}},Ks=class n extends ht{sep="\\";splitSep=bI;constructor(e,t=Zt,r,o,i,a,s){super(e,t,r,o,i,a,s)}newChild(e,t=Zt,r={}){return new n(e,t,this.root,this.roots,this.nocase,this.childrenCache(),r)}getRootString(e){return Cd.parse(e).root}getRoot(e){if(e=yI(e.toUpperCase()),e===this.root.name)return this.root;for(let[t,r]of Object.entries(this.roots))if(this.sameRoot(e,t))return this.roots[e]=r;return this.roots[e]=new jo(e,this).root}sameRoot(e,t=this.root.name){return e=e.toUpperCase().replace(/\//g,"\\").replace(yS,"$1\\"),e===t}},Ys=class n extends ht{splitSep="/";sep="/";constructor(e,t=Zt,r,o,i,a,s){super(e,t,r,o,i,a,s)}getRootString(e){return e.startsWith("/")?"/":""}getRoot(e){return this.root}newChild(e,t=Zt,r={}){return new n(e,t,this.root,this.roots,this.nocase,this.childrenCache(),r)}},Js=class{root;rootPath;roots;cwd;#e;#t;#i;nocase;#r;constructor(e=process.cwd(),t,r,{nocase:o,childrenCacheSize:i=16*1024,fs:a=ha}={}){this.#r=SS(a),(e instanceof URL||e.startsWith("file://"))&&(e=aI(e));let s=t.resolve(e);this.roots=Object.create(null),this.rootPath=this.parseRootPath(s),this.#e=new qs,this.#t=new qs,this.#i=new Rd(i);let l=s.substring(this.rootPath.length).split(r);if(l.length===1&&!l[0]&&l.pop(),o===void 0)throw new TypeError("must provide nocase setting to PathScurryBase ctor");this.nocase=o,this.root=this.newRoot(this.#r),this.roots[this.rootPath]=this.root;let c=this.root,d=l.length-1,p=t.sep,m=this.rootPath,u=!1;for(let h of l){let g=d--;c=c.child(h,{relative:new Array(g).fill("..").join(p),relativePosix:new Array(g).fill("..").join("/"),fullpath:m+=(u?"":p)+h}),u=!0}this.cwd=c}depth(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.depth()}childrenCache(){return this.#i}resolve(...e){let t="";for(let i=e.length-1;i>=0;i--){let a=e[i];if(!(!a||a===".")&&(t=t?`${a}/${t}`:a,this.isAbsolute(a)))break}let r=this.#e.get(t);if(r!==void 0)return r;let o=this.cwd.resolve(t).fullpath();return this.#e.set(t,o),o}resolvePosix(...e){let t="";for(let i=e.length-1;i>=0;i--){let a=e[i];if(!(!a||a===".")&&(t=t?`${a}/${t}`:a,this.isAbsolute(a)))break}let r=this.#t.get(t);if(r!==void 0)return r;let o=this.cwd.resolve(t).fullpathPosix();return this.#t.set(t,o),o}relative(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.relative()}relativePosix(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.relativePosix()}basename(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.name}dirname(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),(e.parent||e).fullpath()}async readdir(e=this.cwd,t={withFileTypes:!0}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r}=t;if(e.canReaddir()){let o=await e.readdir();return r?o:o.map(i=>i.name)}else return[]}readdirSync(e=this.cwd,t={withFileTypes:!0}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r=!0}=t;return e.canReaddir()?r?e.readdirSync():e.readdirSync().map(o=>o.name):[]}async lstat(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.lstat()}lstatSync(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.lstatSync()}async readlink(e=this.cwd,{withFileTypes:t}={withFileTypes:!1}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e.withFileTypes,e=this.cwd);let r=await e.readlink();return t?r:r?.fullpath()}readlinkSync(e=this.cwd,{withFileTypes:t}={withFileTypes:!1}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e.withFileTypes,e=this.cwd);let r=e.readlinkSync();return t?r:r?.fullpath()}async realpath(e=this.cwd,{withFileTypes:t}={withFileTypes:!1}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e.withFileTypes,e=this.cwd);let r=await e.realpath();return t?r:r?.fullpath()}realpathSync(e=this.cwd,{withFileTypes:t}={withFileTypes:!1}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e.withFileTypes,e=this.cwd);let r=e.realpathSync();return t?r:r?.fullpath()}async walk(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t,s=[];(!i||i(e))&&s.push(r?e:e.fullpath());let l=new Set,c=(p,m)=>{l.add(p),p.readdirCB((u,h)=>{if(u)return m(u);let g=h.length;if(!g)return m();let f=()=>{--g===0&&m()};for(let S of h)(!i||i(S))&&s.push(r?S:S.fullpath()),o&&S.isSymbolicLink()?S.realpath().then(b=>b?.isUnknown()?b.lstat():b).then(b=>b?.shouldWalk(l,a)?c(b,f):f()):S.shouldWalk(l,a)?c(S,f):f()},!0)},d=e;return new Promise((p,m)=>{c(d,u=>{if(u)return m(u);p(s)})})}walkSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t,s=[];(!i||i(e))&&s.push(r?e:e.fullpath());let l=new Set([e]);for(let c of l){let d=c.readdirSync();for(let p of d){(!i||i(p))&&s.push(r?p:p.fullpath());let m=p;if(p.isSymbolicLink()){if(!(o&&(m=p.realpathSync())))continue;m.isUnknown()&&m.lstatSync()}m.shouldWalk(l,a)&&l.add(m)}}return s}[Symbol.asyncIterator](){return this.iterate()}iterate(e=this.cwd,t={}){return typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd),this.stream(e,t)[Symbol.asyncIterator]()}[Symbol.iterator](){return this.iterateSync()}*iterateSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t;(!i||i(e))&&(yield r?e:e.fullpath());let s=new Set([e]);for(let l of s){let c=l.readdirSync();for(let d of c){(!i||i(d))&&(yield r?d:d.fullpath());let p=d;if(d.isSymbolicLink()){if(!(o&&(p=d.realpathSync())))continue;p.isUnknown()&&p.lstatSync()}p.shouldWalk(s,a)&&s.add(p)}}}stream(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t,s=new cr({objectMode:!0});(!i||i(e))&&s.write(r?e:e.fullpath());let l=new Set,c=[e],d=0,p=()=>{let m=!1;for(;!m;){let u=c.shift();if(!u){d===0&&s.end();return}d++,l.add(u);let h=(f,S,b=!1)=>{if(f)return s.emit("error",f);if(o&&!b){let w=[];for(let v of S)v.isSymbolicLink()&&w.push(v.realpath().then(x=>x?.isUnknown()?x.lstat():x));if(w.length){Promise.all(w).then(()=>h(null,S,!0));return}}for(let w of S)w&&(!i||i(w))&&(s.write(r?w:w.fullpath())||(m=!0));d--;for(let w of S){let v=w.realpathCached()||w;v.shouldWalk(l,a)&&c.push(v)}m&&!s.flowing?s.once("drain",p):g||p()},g=!0;u.readdirCB(h,!0),g=!1}};return p(),s}streamSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t,s=new cr({objectMode:!0}),l=new Set;(!i||i(e))&&s.write(r?e:e.fullpath());let c=[e],d=0,p=()=>{let m=!1;for(;!m;){let u=c.shift();if(!u){d===0&&s.end();return}d++,l.add(u);let h=u.readdirSync();for(let g of h)(!i||i(g))&&(s.write(r?g:g.fullpath())||(m=!0));d--;for(let g of h){let f=g;if(g.isSymbolicLink()){if(!(o&&(f=g.realpathSync())))continue;f.isUnknown()&&f.lstatSync()}f.shouldWalk(l,a)&&c.push(f)}}m&&!s.flowing&&s.once("drain",p)};return p(),s}chdir(e=this.cwd){let t=this.cwd;this.cwd=typeof e=="string"?this.cwd.resolve(e):e,this.cwd[ES](t)}},jo=class extends Js{sep="\\";constructor(e=process.cwd(),t={}){let{nocase:r=!0}=t;super(e,Cd,"\\",{...t,nocase:r}),this.nocase=r;for(let o=this.cwd;o;o=o.parent)o.nocase=this.nocase}parseRootPath(e){return Cd.parse(e).root.toUpperCase()}newRoot(e){return new Ks(this.rootPath,En,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")||e.startsWith("\\")||/^[a-z]:(\/|\\)/i.test(e)}},$o=class extends Js{sep="/";constructor(e=process.cwd(),t={}){let{nocase:r=!1}=t;super(e,iI,"/",{...t,nocase:r}),this.nocase=r}parseRootPath(e){return"/"}newRoot(e){return new Ys(this.rootPath,En,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")}},Sa=class extends $o{constructor(e=process.cwd(),t={}){let{nocase:r=!0}=t;super(e,{...t,nocase:r})}},IK=process.platform==="win32"?Ks:Ys,CS=process.platform==="win32"?jo:process.platform==="darwin"?Sa:$o;var vI=n=>n.length>=1,TI=n=>n.length>=1,Go=class n{#e;#t;#i;length;#r;#a;#w;#c;#p;#s;#l=!0;constructor(e,t,r,o){if(!vI(e))throw new TypeError("empty pattern list");if(!TI(t))throw new TypeError("empty glob list");if(t.length!==e.length)throw new TypeError("mismatched pattern list and glob list lengths");if(this.length=e.length,r<0||r>=this.length)throw new TypeError("index out of range");if(this.#e=e,this.#t=t,this.#i=r,this.#r=o,this.#i===0){if(this.isUNC()){let[i,a,s,l,...c]=this.#e,[d,p,m,u,...h]=this.#t;c[0]===""&&(c.shift(),h.shift());let g=[i,a,s,l,""].join("/"),f=[d,p,m,u,""].join("/");this.#e=[g,...c],this.#t=[f,...h],this.length=this.#e.length}else if(this.isDrive()||this.isAbsolute()){let[i,...a]=this.#e,[s,...l]=this.#t;a[0]===""&&(a.shift(),l.shift());let c=i+"/",d=s+"/";this.#e=[c,...a],this.#t=[d,...l],this.length=this.#e.length}}}pattern(){return this.#e[this.#i]}isString(){return typeof this.#e[this.#i]=="string"}isGlobstar(){return this.#e[this.#i]===st}isRegExp(){return this.#e[this.#i]instanceof RegExp}globString(){return this.#w=this.#w||(this.#i===0?this.isAbsolute()?this.#t[0]+this.#t.slice(1).join("/"):this.#t.join("/"):this.#t.slice(this.#i).join("/"))}hasMore(){return this.length>this.#i+1}rest(){return this.#a!==void 0?this.#a:this.hasMore()?(this.#a=new n(this.#e,this.#t,this.#i+1,this.#r),this.#a.#s=this.#s,this.#a.#p=this.#p,this.#a.#c=this.#c,this.#a):this.#a=null}isUNC(){let e=this.#e;return this.#p!==void 0?this.#p:this.#p=this.#r==="win32"&&this.#i===0&&e[0]===""&&e[1]===""&&typeof e[2]=="string"&&!!e[2]&&typeof e[3]=="string"&&!!e[3]}isDrive(){let e=this.#e;return this.#c!==void 0?this.#c:this.#c=this.#r==="win32"&&this.#i===0&&this.length>1&&typeof e[0]=="string"&&/^[a-z]:$/i.test(e[0])}isAbsolute(){let e=this.#e;return this.#s!==void 0?this.#s:this.#s=e[0]===""&&e.length>1||this.isDrive()||this.isUNC()}root(){let e=this.#e[0];return typeof e=="string"&&this.isAbsolute()&&this.#i===0?e:""}checkFollowGlobstar(){return!(this.#i===0||!this.isGlobstar()||!this.#l)}markFollowGlobstar(){return this.#i===0||!this.isGlobstar()||!this.#l?!1:(this.#l=!1,!0)}};var xI=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",Wo=class{relative;relativeChildren;absolute;absoluteChildren;platform;mmopts;constructor(e,{nobrace:t,nocase:r,noext:o,noglobstar:i,platform:a=xI}){this.relative=[],this.absolute=[],this.relativeChildren=[],this.absoluteChildren=[],this.platform=a,this.mmopts={dot:!0,nobrace:t,nocase:r,noext:o,noglobstar:i,optimizationLevel:2,platform:a,nocomment:!0,nonegate:!0};for(let s of e)this.add(s)}add(e){let t=new Ft(e,this.mmopts);for(let r=0;r<t.set.length;r++){let o=t.set[r],i=t.globParts[r];if(!o||!i)throw new Error("invalid pattern object");for(;o[0]==="."&&i[0]===".";)o.shift(),i.shift();let a=new Go(o,i,0,this.platform),s=new Ft(a.globString(),this.mmopts),l=i[i.length-1]==="**",c=a.isAbsolute();c?this.absolute.push(s):this.relative.push(s),l&&(c?this.absoluteChildren.push(s):this.relativeChildren.push(s))}}ignored(e){let t=e.fullpath(),r=`${t}/`,o=e.relative()||".",i=`${o}/`;for(let a of this.relative)if(a.match(o)||a.match(i))return!0;for(let a of this.absolute)if(a.match(t)||a.match(r))return!0;return!1}childrenIgnored(e){let t=e.fullpath()+"/",r=(e.relative()||".")+"/";for(let o of this.relativeChildren)if(o.match(r))return!0;for(let o of this.absoluteChildren)if(o.match(t))return!0;return!1}};var Ad=class n{store;constructor(e=new Map){this.store=e}copy(){return new n(new Map(this.store))}hasWalked(e,t){return this.store.get(e.fullpath())?.has(t.globString())}storeWalked(e,t){let r=e.fullpath(),o=this.store.get(r);o?o.add(t.globString()):this.store.set(r,new Set([t.globString()]))}},Id=class{store=new Map;add(e,t,r){let o=(t?2:0)|(r?1:0),i=this.store.get(e);this.store.set(e,i===void 0?o:o&i)}entries(){return[...this.store.entries()].map(([e,t])=>[e,!!(t&2),!!(t&1)])}},Pd=class{store=new Map;add(e,t){if(!e.canReaddir())return;let r=this.store.get(e);r?r.find(o=>o.globString()===t.globString())||r.push(t):this.store.set(e,[t])}get(e){let t=this.store.get(e);if(!t)throw new Error("attempting to walk unknown path");return t}entries(){return this.keys().map(e=>[e,this.store.get(e)])}keys(){return[...this.store.keys()].filter(e=>e.canReaddir())}},ya=class n{hasWalkedCache;matches=new Id;subwalks=new Pd;patterns;follow;dot;opts;constructor(e,t){this.opts=e,this.follow=!!e.follow,this.dot=!!e.dot,this.hasWalkedCache=t?t.copy():new Ad}processPatterns(e,t){this.patterns=t;let r=t.map(o=>[e,o]);for(let[o,i]of r){this.hasWalkedCache.storeWalked(o,i);let a=i.root(),s=i.isAbsolute()&&this.opts.absolute!==!1;if(a){o=o.resolve(a==="/"&&this.opts.root!==void 0?this.opts.root:a);let p=i.rest();if(p)i=p;else{this.matches.add(o,!0,!1);continue}}if(o.isENOENT())continue;let l,c,d=!1;for(;typeof(l=i.pattern())=="string"&&(c=i.rest());)o=o.resolve(l),i=c,d=!0;if(l=i.pattern(),c=i.rest(),d){if(this.hasWalkedCache.hasWalked(o,i))continue;this.hasWalkedCache.storeWalked(o,i)}if(typeof l=="string"){let p=l===".."||l===""||l===".";this.matches.add(o.resolve(l),s,p);continue}else if(l===st){(!o.isSymbolicLink()||this.follow||i.checkFollowGlobstar())&&this.subwalks.add(o,i);let p=c?.pattern(),m=c?.rest();if(!c||(p===""||p===".")&&!m)this.matches.add(o,s,p===""||p===".");else if(p===".."){let u=o.parent||o;m?this.hasWalkedCache.hasWalked(u,m)||this.subwalks.add(u,m):this.matches.add(u,s,!0)}}else l instanceof RegExp&&this.subwalks.add(o,i)}return this}subwalkTargets(){return this.subwalks.keys()}child(){return new n(this.opts,this.hasWalkedCache)}filterEntries(e,t){let r=this.subwalks.get(e),o=this.child();for(let i of t)for(let a of r){let s=a.isAbsolute(),l=a.pattern(),c=a.rest();l===st?o.testGlobstar(i,a,c,s):l instanceof RegExp?o.testRegExp(i,l,c,s):o.testString(i,l,c,s)}return o}testGlobstar(e,t,r,o){if((this.dot||!e.name.startsWith("."))&&(t.hasMore()||this.matches.add(e,o,!1),e.canReaddir()&&(this.follow||!e.isSymbolicLink()?this.subwalks.add(e,t):e.isSymbolicLink()&&(r&&t.checkFollowGlobstar()?this.subwalks.add(e,r):t.markFollowGlobstar()&&this.subwalks.add(e,t)))),r){let i=r.pattern();if(typeof i=="string"&&i!==".."&&i!==""&&i!==".")this.testString(e,i,r.rest(),o);else if(i===".."){let a=e.parent||e;this.subwalks.add(a,r)}else i instanceof RegExp&&this.testRegExp(e,i,r.rest(),o)}}testRegExp(e,t,r,o){t.test(e.name)&&(r?this.subwalks.add(e,r):this.matches.add(e,o,!1))}testString(e,t,r,o){e.isNamed(t)&&(r?this.subwalks.add(e,r):this.matches.add(e,o,!1))}};var EI=(n,e)=>typeof n=="string"?new Wo([n],e):Array.isArray(n)?new Wo(n,e):n,Xs=class{path;patterns;opts;seen=new Set;paused=!1;aborted=!1;#e=[];#t;#i;signal;maxDepth;includeChildMatches;constructor(e,t,r){if(this.patterns=e,this.path=t,this.opts=r,this.#i=!r.posix&&r.platform==="win32"?"\\":"/",this.includeChildMatches=r.includeChildMatches!==!1,(r.ignore||!this.includeChildMatches)&&(this.#t=EI(r.ignore??[],r),!this.includeChildMatches&&typeof this.#t.add!="function")){let o="cannot ignore child matches, ignore lacks add() method.";throw new Error(o)}this.maxDepth=r.maxDepth||1/0,r.signal&&(this.signal=r.signal,this.signal.addEventListener("abort",()=>{this.#e.length=0}))}#r(e){return this.seen.has(e)||!!this.#t?.ignored?.(e)}#a(e){return!!this.#t?.childrenIgnored?.(e)}pause(){this.paused=!0}resume(){if(this.signal?.aborted)return;this.paused=!1;let e;for(;!this.paused&&(e=this.#e.shift());)e()}onResume(e){this.signal?.aborted||(this.paused?this.#e.push(e):e())}async matchCheck(e,t){if(t&&this.opts.nodir)return;let r;if(this.opts.realpath){if(r=e.realpathCached()||await e.realpath(),!r)return;e=r}let i=e.isUnknown()||this.opts.stat?await e.lstat():e;if(this.opts.follow&&this.opts.nodir&&i?.isSymbolicLink()){let a=await i.realpath();a&&(a.isUnknown()||this.opts.stat)&&await a.lstat()}return this.matchCheckTest(i,t)}matchCheckTest(e,t){return e&&(this.maxDepth===1/0||e.depth()<=this.maxDepth)&&(!t||e.canReaddir())&&(!this.opts.nodir||!e.isDirectory())&&(!this.opts.nodir||!this.opts.follow||!e.isSymbolicLink()||!e.realpathCached()?.isDirectory())&&!this.#r(e)?e:void 0}matchCheckSync(e,t){if(t&&this.opts.nodir)return;let r;if(this.opts.realpath){if(r=e.realpathCached()||e.realpathSync(),!r)return;e=r}let i=e.isUnknown()||this.opts.stat?e.lstatSync():e;if(this.opts.follow&&this.opts.nodir&&i?.isSymbolicLink()){let a=i.realpathSync();a&&(a?.isUnknown()||this.opts.stat)&&a.lstatSync()}return this.matchCheckTest(i,t)}matchFinish(e,t){if(this.#r(e))return;if(!this.includeChildMatches&&this.#t?.add){let i=`${e.relativePosix()}/**`;this.#t.add(i)}let r=this.opts.absolute===void 0?t:this.opts.absolute;this.seen.add(e);let o=this.opts.mark&&e.isDirectory()?this.#i:"";if(this.opts.withFileTypes)this.matchEmit(e);else if(r){let i=this.opts.posix?e.fullpathPosix():e.fullpath();this.matchEmit(i+o)}else{let i=this.opts.posix?e.relativePosix():e.relative(),a=this.opts.dotRelative&&!i.startsWith(".."+this.#i)?"."+this.#i:"";this.matchEmit(i?a+i+o:"."+o)}}async match(e,t,r){let o=await this.matchCheck(e,r);o&&this.matchFinish(o,t)}matchSync(e,t,r){let o=this.matchCheckSync(e,r);o&&this.matchFinish(o,t)}walkCB(e,t,r){this.signal?.aborted&&r(),this.walkCB2(e,t,new ya(this.opts),r)}walkCB2(e,t,r,o){if(this.#a(e))return o();if(this.signal?.aborted&&o(),this.paused){this.onResume(()=>this.walkCB2(e,t,r,o));return}r.processPatterns(e,t);let i=1,a=()=>{--i===0&&o()};for(let[s,l,c]of r.matches.entries())this.#r(s)||(i++,this.match(s,l,c).then(()=>a()));for(let s of r.subwalkTargets()){if(this.maxDepth!==1/0&&s.depth()>=this.maxDepth)continue;i++;let l=s.readdirCached();s.calledReaddir()?this.walkCB3(s,l,r,a):s.readdirCB((c,d)=>this.walkCB3(s,d,r,a),!0)}a()}walkCB3(e,t,r,o){r=r.filterEntries(e,t);let i=1,a=()=>{--i===0&&o()};for(let[s,l,c]of r.matches.entries())this.#r(s)||(i++,this.match(s,l,c).then(()=>a()));for(let[s,l]of r.subwalks.entries())i++,this.walkCB2(s,l,r.child(),a);a()}walkCBSync(e,t,r){this.signal?.aborted&&r(),this.walkCB2Sync(e,t,new ya(this.opts),r)}walkCB2Sync(e,t,r,o){if(this.#a(e))return o();if(this.signal?.aborted&&o(),this.paused){this.onResume(()=>this.walkCB2Sync(e,t,r,o));return}r.processPatterns(e,t);let i=1,a=()=>{--i===0&&o()};for(let[s,l,c]of r.matches.entries())this.#r(s)||this.matchSync(s,l,c);for(let s of r.subwalkTargets()){if(this.maxDepth!==1/0&&s.depth()>=this.maxDepth)continue;i++;let l=s.readdirSync();this.walkCB3Sync(s,l,r,a)}a()}walkCB3Sync(e,t,r,o){r=r.filterEntries(e,t);let i=1,a=()=>{--i===0&&o()};for(let[s,l,c]of r.matches.entries())this.#r(s)||this.matchSync(s,l,c);for(let[s,l]of r.subwalks.entries())i++,this.walkCB2Sync(s,l,r.child(),a);a()}},ba=class extends Xs{matches=new Set;constructor(e,t,r){super(e,t,r)}matchEmit(e){this.matches.add(e)}async walk(){if(this.signal?.aborted)throw this.signal.reason;return this.path.isUnknown()&&await this.path.lstat(),await new Promise((e,t)=>{this.walkCB(this.path,this.patterns,()=>{this.signal?.aborted?t(this.signal.reason):e(this.matches)})}),this.matches}walkSync(){if(this.signal?.aborted)throw this.signal.reason;return this.path.isUnknown()&&this.path.lstatSync(),this.walkCBSync(this.path,this.patterns,()=>{if(this.signal?.aborted)throw this.signal.reason}),this.matches}},wa=class extends Xs{results;constructor(e,t,r){super(e,t,r),this.results=new cr({signal:this.signal,objectMode:!0}),this.results.on("drain",()=>this.resume()),this.results.on("resume",()=>this.resume())}matchEmit(e){this.results.write(e),this.results.flowing||this.pause()}stream(){let e=this.path;return e.isUnknown()?e.lstat().then(()=>{this.walkCB(e,this.patterns,()=>this.results.end())}):this.walkCB(e,this.patterns,()=>this.results.end()),this.results}streamSync(){return this.path.isUnknown()&&this.path.lstatSync(),this.walkCBSync(this.path,this.patterns,()=>this.results.end()),this.results}};var RI=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",mn=class{absolute;cwd;root;dot;dotRelative;follow;ignore;magicalBraces;mark;matchBase;maxDepth;nobrace;nocase;nodir;noext;noglobstar;pattern;platform;realpath;scurry;stat;signal;windowsPathsNoEscape;withFileTypes;includeChildMatches;opts;patterns;constructor(e,t){if(!t)throw new TypeError("glob options required");if(this.withFileTypes=!!t.withFileTypes,this.signal=t.signal,this.follow=!!t.follow,this.dot=!!t.dot,this.dotRelative=!!t.dotRelative,this.nodir=!!t.nodir,this.mark=!!t.mark,t.cwd?(t.cwd instanceof URL||t.cwd.startsWith("file://"))&&(t.cwd=CI(t.cwd)):this.cwd="",this.cwd=t.cwd||"",this.root=t.root,this.magicalBraces=!!t.magicalBraces,this.nobrace=!!t.nobrace,this.noext=!!t.noext,this.realpath=!!t.realpath,this.absolute=t.absolute,this.includeChildMatches=t.includeChildMatches!==!1,this.noglobstar=!!t.noglobstar,this.matchBase=!!t.matchBase,this.maxDepth=typeof t.maxDepth=="number"?t.maxDepth:1/0,this.stat=!!t.stat,this.ignore=t.ignore,this.withFileTypes&&this.absolute!==void 0)throw new Error("cannot set absolute and withFileTypes:true");if(typeof e=="string"&&(e=[e]),this.windowsPathsNoEscape=!!t.windowsPathsNoEscape||t.allowWindowsEscape===!1,this.windowsPathsNoEscape&&(e=e.map(l=>l.replace(/\\/g,"/"))),this.matchBase){if(t.noglobstar)throw new TypeError("base matching requires globstar");e=e.map(l=>l.includes("/")?l:`./**/${l}`)}if(this.pattern=e,this.platform=t.platform||RI,this.opts={...t,platform:this.platform},t.scurry){if(this.scurry=t.scurry,t.nocase!==void 0&&t.nocase!==t.scurry.nocase)throw new Error("nocase option contradicts provided scurry option")}else{let l=t.platform==="win32"?jo:t.platform==="darwin"?Sa:t.platform?$o:CS;this.scurry=new l(this.cwd,{nocase:t.nocase,fs:t.fs})}this.nocase=this.scurry.nocase;let r=this.platform==="darwin"||this.platform==="win32",o={...t,dot:this.dot,matchBase:this.matchBase,nobrace:this.nobrace,nocase:this.nocase,nocaseMagicOnly:r,nocomment:!0,noext:this.noext,nonegate:!0,optimizationLevel:2,platform:this.platform,windowsPathsNoEscape:this.windowsPathsNoEscape,debug:!!this.opts.debug},i=this.pattern.map(l=>new Ft(l,o)),[a,s]=i.reduce((l,c)=>(l[0].push(...c.set),l[1].push(...c.globParts),l),[[],[]]);this.patterns=a.map((l,c)=>{let d=s[c];if(!d)throw new Error("invalid pattern object");return new Go(l,d,0,this.platform)})}async walk(){return[...await new ba(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).walk()]}walkSync(){return[...new ba(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).walkSync()]}stream(){return new wa(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).stream()}streamSync(){return new wa(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).streamSync()}iterateSync(){return this.streamSync()[Symbol.iterator]()}[Symbol.iterator](){return this.iterateSync()}iterate(){return this.stream()[Symbol.asyncIterator]()}[Symbol.asyncIterator](){return this.iterate()}};var Ld=(n,e={})=>{Array.isArray(n)||(n=[n]);for(let t of n)if(new Ft(t,e).hasMagic())return!0;return!1};function Zs(n,e={}){return new mn(n,e).streamSync()}function IS(n,e={}){return new mn(n,e).stream()}function Vo(n,e={}){return new mn(n,e).walkSync()}async function RS(n,e={}){return new mn(n,e).walk()}function Qs(n,e={}){return new mn(n,e).iterateSync()}function PS(n,e={}){return new mn(n,e).iterate()}var AI=Zs,II=Object.assign(IS,{sync:Zs}),PI=Qs,LI=Object.assign(PS,{sync:Qs}),OI=Object.assign(Vo,{stream:Zs,iterate:Qs}),AS=Object.assign(RS,{glob:RS,globSync:Vo,sync:OI,globStream:IS,stream:II,globStreamSync:Zs,streamSync:AI,globIterate:PS,iterate:LI,globIterateSync:Qs,iterateSync:PI,Glob:mn,hasMagic:Ld,escape:Fo,unescape:dn});AS.glob=AS;import qr,{dirname as MS}from"path";import{cwd as _d}from"process";import NS from"yaml";import{z as ce}from"zod";import LS from"fs";import el from"path";import kI from"yaml";import{z as Od}from"zod";var OS=!1,kd=[`**/*.${Ot.TEST}`,`**/*.${Ot.MODULE}`],Md=Od.string().refine(n=>/^[a-zA-Z0-9-]+$/.test(n)),Nd=50,MI=Od.object({fileType:Od.nativeEnum(Ee)});function Oe(n,e){let t={project:n,tests:{},modules:{}},r=n.config.include??kd,o=Array.from(n.config.exclude??[]).concat(Oh),i=Vo(r,{absolute:!1,cwd:n.rootDir,ignore:o,dotRelative:!1,maxDepth:Nd,nodir:!0});for(let a of i)NI(n.rootDir,a,t,e);return OS=!0,t}function NI(n,e,t,r){let o=el.join(n,e),i;try{i=LS.readFileSync(o,"utf-8")}catch(p){r.warn(`Could not read possible Momentic file at ${o}, skipping: ${p}`);return}let a;try{if(a=kI.parse(i),typeof a!="object"||a===null)throw new Error("The YAML document should parse as a map with key-value pairs")}catch(p){r.warn(`Could not parse possible Momentic file at ${o}, skipping: ${p}`);return}let s=MI.safeParse(a);if(s.error){r.warn(`Possible Momentic file at ${o} does not have a 'fileType', skipping: ${s.error}`);return}let l=s.data.fileType,c;try{c=LS.statSync(o)}catch(p){r.warn(`Skipping path '${o}' because it could not be stat, skipping: ${p}`);return}let d={relativePath:e,fullFilePath:o,platformSep:el.sep,fullPathSegments:o.split(el.sep),fileName:el.basename(o),lastModified:c.mtime,createdAt:c.birthtime};switch(l){case Ee.TEST:try{let p=Kt.parse(a);if(t.tests[p.id]){let m=t.tests[p.id].fullFilePath;y.error(`Two tests with the same ID (${p.id}) were found in the same project. Please ensure that all test IDs are unique and avoid copying tests manually. Momentic will ignore the first test when resolving tests.
44
+ >>> no match, partial?`,e,m,t,u),m===l))}let g;if(typeof d=="string"?(g=p===d,this.debug("string match",d,p,g)):(g=d.test(p),this.debug("pattern match",d,p,g)),!g)return!1}if(a===l&&s===c)return!0;if(a===l)return r;if(s===c)return a===l-1&&e[a]==="";throw new Error("wtf?")}braceExpand(){return rS(this.pattern,this.options)}parse(e){aa(e);let t=this.options;if(e==="**")return st;if(e==="")return"";let r,o=null;(r=e.match(LA))?o=t.dot?kA:OA:(r=e.match(wA))?o=(t.nocase?t.dot?EA:xA:t.dot?TA:vA)(r[1]):(r=e.match(MA))?o=(t.nocase?t.dot?_A:NA:t.dot?DA:FA)(r):(r=e.match(CA))?o=t.dot?AA:RA:(r=e.match(IA))&&(o=PA);let i=_o.fromGlob(e,this.options).toMMPattern();return o&&typeof i=="object"&&Reflect.defineProperty(i,"test",{value:o}),i}makeRe(){if(this.regexp||this.regexp===!1)return this.regexp;let e=this.set;if(!e.length)return this.regexp=!1,this.regexp;let t=this.options,r=t.noglobstar?zA:t.dot?HA:jA,o=new Set(t.nocase?["i"]:[]),i=e.map(l=>{let c=l.map(d=>{if(d instanceof RegExp)for(let p of d.flags.split(""))o.add(p);return typeof d=="string"?qA(d):d===st?st:d._src});return c.forEach((d,p)=>{let m=c[p+1],u=c[p-1];d!==st||u===st||(u===void 0?m!==void 0&&m!==st?c[p+1]="(?:\\/|"+r+"\\/)?"+m:c[p]=r:m===void 0?c[p-1]=u+"(?:\\/|"+r+")?":m!==st&&(c[p-1]=u+"(?:\\/|\\/"+r+"\\/)"+m,c[p+1]=st))}),c.filter(d=>d!==st).join("/")}).join("|"),[a,s]=e.length>1?["(?:",")"]:["",""];i="^"+a+i+s+"$",this.negate&&(i="^(?!"+i+").+$");try{this.regexp=new RegExp(i,[...o].join(""))}catch{this.regexp=!1}return this.regexp}slashSplit(e){return this.preserveMultipleSlashes?e.split("/"):this.isWindows&&/^\/\/[^\/]+/.test(e)?["",...e.split(/\/+/)]:e.split(/\/+/)}match(e,t=this.partial){if(this.debug("match",e,this.pattern),this.comment)return!1;if(this.empty)return e==="";if(e==="/"&&t)return!0;let r=this.options;this.isWindows&&(e=e.split("\\").join("/"));let o=this.slashSplit(e);this.debug(this.pattern,"split",o);let i=this.set;this.debug(this.pattern,"set",i);let a=o[o.length-1];if(!a)for(let s=o.length-2;!a&&s>=0;s--)a=o[s];for(let s=0;s<i.length;s++){let l=i[s],c=o;if(r.matchBase&&l.length===1&&(c=[a]),this.matchOne(c,l,t))return r.flipNegate?!0:!this.negate}return r.flipNegate?!1:this.negate}static defaults(e){return wt.defaults(e).Minimatch}};wt.AST=_o;wt.Minimatch=Ft;wt.escape=Do;wt.unescape=dn;import{fileURLToPath as CI}from"node:url";var Fo=typeof performance=="object"&&performance&&typeof performance.now=="function"?performance:Date,iS=new Set,hd=typeof process=="object"&&process?process:{},aS=(n,e,t,r)=>{typeof hd.emitWarning=="function"?hd.emitWarning(n,e,t,r):console.error(`[${t}] ${e}: ${n}`)},Fs=globalThis.AbortController,oS=globalThis.AbortSignal;if(typeof Fs>"u"){oS=class{onabort;_onabort=[];reason;aborted=!1;addEventListener(r,o){this._onabort.push(o)}},Fs=class{constructor(){e()}signal=new oS;abort(r){if(!this.signal.aborted){this.signal.reason=r,this.signal.aborted=!0;for(let o of this.signal._onabort)o(r);this.signal.onabort?.(r)}}};let n=hd.env?.LRU_CACHE_IGNORE_AC_WARNING!=="1",e=()=>{n&&(n=!1,aS("AbortController is not defined. If using lru-cache in node 14, load an AbortController polyfill from the `node-abort-controller` package. A minimal polyfill is provided for use by LRUCache.fetch(), but it should not be relied upon in other contexts (eg, passing it to other APIs that use AbortController/AbortSignal might have undesirable effects). You may disable this with LRU_CACHE_IGNORE_AC_WARNING=1 in the env.","NO_ABORT_CONTROLLER","ENOTSUP",e))}}var KA=n=>!iS.has(n),fK=Symbol("type"),sr=n=>n&&n===Math.floor(n)&&n>0&&isFinite(n),sS=n=>sr(n)?n<=Math.pow(2,8)?Uint8Array:n<=Math.pow(2,16)?Uint16Array:n<=Math.pow(2,32)?Uint32Array:n<=Number.MAX_SAFE_INTEGER?Uo:null:null,Uo=class extends Array{constructor(e){super(e),this.fill(0)}},gd=class n{heap;length;static#e=!1;static create(e){let t=sS(e);if(!t)return[];n.#e=!0;let r=new n(e,t);return n.#e=!1,r}constructor(e,t){if(!n.#e)throw new TypeError("instantiate Stack using Stack.create(n)");this.heap=new t(e),this.length=0}push(e){this.heap[this.length++]=e}pop(){return this.heap[--this.length]}},la=class n{#e;#t;#i;#r;#a;#w;ttl;ttlResolution;ttlAutopurge;updateAgeOnGet;updateAgeOnHas;allowStale;noDisposeOnSet;noUpdateTTL;maxEntrySize;sizeCalculation;noDeleteOnFetchRejection;noDeleteOnStaleGet;allowStaleOnFetchAbort;allowStaleOnFetchRejection;ignoreFetchAbort;#c;#p;#s;#l;#o;#f;#S;#m;#u;#x;#g;#E;#C;#b;#v;#T;#h;static unsafeExposeInternals(e){return{starts:e.#C,ttls:e.#b,sizes:e.#E,keyMap:e.#s,keyList:e.#l,valList:e.#o,next:e.#f,prev:e.#S,get head(){return e.#m},get tail(){return e.#u},free:e.#x,isBackgroundFetch:t=>e.#d(t),backgroundFetch:(t,r,o,i)=>e.#U(t,r,o,i),moveToTail:t=>e.#z(t),indexes:t=>e.#A(t),rindexes:t=>e.#I(t),isStale:t=>e.#y(t)}}get max(){return this.#e}get maxSize(){return this.#t}get calculatedSize(){return this.#p}get size(){return this.#c}get fetchMethod(){return this.#a}get memoMethod(){return this.#w}get dispose(){return this.#i}get disposeAfter(){return this.#r}constructor(e){let{max:t=0,ttl:r,ttlResolution:o=1,ttlAutopurge:i,updateAgeOnGet:a,updateAgeOnHas:s,allowStale:l,dispose:c,disposeAfter:d,noDisposeOnSet:p,noUpdateTTL:m,maxSize:u=0,maxEntrySize:h=0,sizeCalculation:g,fetchMethod:f,memoMethod:S,noDeleteOnFetchRejection:b,noDeleteOnStaleGet:w,allowStaleOnFetchRejection:v,allowStaleOnFetchAbort:x,ignoreFetchAbort:C}=e;if(t!==0&&!sr(t))throw new TypeError("max option must be a nonnegative integer");let A=t?sS(t):Array;if(!A)throw new Error("invalid max value: "+t);if(this.#e=t,this.#t=u,this.maxEntrySize=h||this.#t,this.sizeCalculation=g,this.sizeCalculation){if(!this.#t&&!this.maxEntrySize)throw new TypeError("cannot set sizeCalculation without setting maxSize or maxEntrySize");if(typeof this.sizeCalculation!="function")throw new TypeError("sizeCalculation set to non-function")}if(S!==void 0&&typeof S!="function")throw new TypeError("memoMethod must be a function if defined");if(this.#w=S,f!==void 0&&typeof f!="function")throw new TypeError("fetchMethod must be a function if specified");if(this.#a=f,this.#T=!!f,this.#s=new Map,this.#l=new Array(t).fill(void 0),this.#o=new Array(t).fill(void 0),this.#f=new A(t),this.#S=new A(t),this.#m=0,this.#u=0,this.#x=gd.create(t),this.#c=0,this.#p=0,typeof c=="function"&&(this.#i=c),typeof d=="function"?(this.#r=d,this.#g=[]):(this.#r=void 0,this.#g=void 0),this.#v=!!this.#i,this.#h=!!this.#r,this.noDisposeOnSet=!!p,this.noUpdateTTL=!!m,this.noDeleteOnFetchRejection=!!b,this.allowStaleOnFetchRejection=!!v,this.allowStaleOnFetchAbort=!!x,this.ignoreFetchAbort=!!C,this.maxEntrySize!==0){if(this.#t!==0&&!sr(this.#t))throw new TypeError("maxSize must be a positive integer if specified");if(!sr(this.maxEntrySize))throw new TypeError("maxEntrySize must be a positive integer if specified");this.#L()}if(this.allowStale=!!l,this.noDeleteOnStaleGet=!!w,this.updateAgeOnGet=!!a,this.updateAgeOnHas=!!s,this.ttlResolution=sr(o)||o===0?o:1,this.ttlAutopurge=!!i,this.ttl=r||0,this.ttl){if(!sr(this.ttl))throw new TypeError("ttl must be a positive integer if specified");this.#P()}if(this.#e===0&&this.ttl===0&&this.#t===0)throw new TypeError("At least one of max, maxSize, or ttl is required");if(!this.ttlAutopurge&&!this.#e&&!this.#t){let N="LRU_CACHE_UNBOUNDED";KA(N)&&(iS.add(N),aS("TTL caching without ttlAutopurge, max, or maxSize can result in unbounded memory consumption.","UnboundedCacheWarning",N,n))}}getRemainingTTL(e){return this.#s.has(e)?1/0:0}#P(){let e=new Uo(this.#e),t=new Uo(this.#e);this.#b=e,this.#C=t,this.#k=(i,a,s=Fo.now())=>{if(t[i]=a!==0?s:0,e[i]=a,a!==0&&this.ttlAutopurge){let l=setTimeout(()=>{this.#y(i)&&this.#O(this.#l[i],"expire")},a+1);l.unref&&l.unref()}},this.#R=i=>{t[i]=e[i]!==0?Fo.now():0},this.#n=(i,a)=>{if(e[a]){let s=e[a],l=t[a];if(!s||!l)return;i.ttl=s,i.start=l,i.now=r||o();let c=i.now-l;i.remainingTTL=s-c}};let r=0,o=()=>{let i=Fo.now();if(this.ttlResolution>0){r=i;let a=setTimeout(()=>r=0,this.ttlResolution);a.unref&&a.unref()}return i};this.getRemainingTTL=i=>{let a=this.#s.get(i);if(a===void 0)return 0;let s=e[a],l=t[a];if(!s||!l)return 1/0;let c=(r||o())-l;return s-c},this.#y=i=>{let a=t[i],s=e[i];return!!s&&!!a&&(r||o())-a>s}}#R=()=>{};#n=()=>{};#k=()=>{};#y=()=>!1;#L(){let e=new Uo(this.#e);this.#p=0,this.#E=e,this.#M=t=>{this.#p-=e[t],e[t]=0},this.#_=(t,r,o,i)=>{if(this.#d(r))return 0;if(!sr(o))if(i){if(typeof i!="function")throw new TypeError("sizeCalculation must be a function");if(o=i(r,t),!sr(o))throw new TypeError("sizeCalculation return invalid (expect positive integer)")}else throw new TypeError("invalid size value (must be positive integer). When maxSize or maxEntrySize is used, sizeCalculation or size must be set.");return o},this.#N=(t,r,o)=>{if(e[t]=r,this.#t){let i=this.#t-e[t];for(;this.#p>i;)this.#F(!0)}this.#p+=e[t],o&&(o.entrySize=r,o.totalCalculatedSize=this.#p)}}#M=e=>{};#N=(e,t,r)=>{};#_=(e,t,r,o)=>{if(r||o)throw new TypeError("cannot set size without setting maxSize or maxEntrySize on cache");return 0};*#A({allowStale:e=this.allowStale}={}){if(this.#c)for(let t=this.#u;!(!this.#D(t)||((e||!this.#y(t))&&(yield t),t===this.#m));)t=this.#S[t]}*#I({allowStale:e=this.allowStale}={}){if(this.#c)for(let t=this.#m;!(!this.#D(t)||((e||!this.#y(t))&&(yield t),t===this.#u));)t=this.#f[t]}#D(e){return e!==void 0&&this.#s.get(this.#l[e])===e}*entries(){for(let e of this.#A())this.#o[e]!==void 0&&this.#l[e]!==void 0&&!this.#d(this.#o[e])&&(yield[this.#l[e],this.#o[e]])}*rentries(){for(let e of this.#I())this.#o[e]!==void 0&&this.#l[e]!==void 0&&!this.#d(this.#o[e])&&(yield[this.#l[e],this.#o[e]])}*keys(){for(let e of this.#A()){let t=this.#l[e];t!==void 0&&!this.#d(this.#o[e])&&(yield t)}}*rkeys(){for(let e of this.#I()){let t=this.#l[e];t!==void 0&&!this.#d(this.#o[e])&&(yield t)}}*values(){for(let e of this.#A())this.#o[e]!==void 0&&!this.#d(this.#o[e])&&(yield this.#o[e])}*rvalues(){for(let e of this.#I())this.#o[e]!==void 0&&!this.#d(this.#o[e])&&(yield this.#o[e])}[Symbol.iterator](){return this.entries()}[Symbol.toStringTag]="LRUCache";find(e,t={}){for(let r of this.#A()){let o=this.#o[r],i=this.#d(o)?o.__staleWhileFetching:o;if(i!==void 0&&e(i,this.#l[r],this))return this.get(this.#l[r],t)}}forEach(e,t=this){for(let r of this.#A()){let o=this.#o[r],i=this.#d(o)?o.__staleWhileFetching:o;i!==void 0&&e.call(t,i,this.#l[r],this)}}rforEach(e,t=this){for(let r of this.#I()){let o=this.#o[r],i=this.#d(o)?o.__staleWhileFetching:o;i!==void 0&&e.call(t,i,this.#l[r],this)}}purgeStale(){let e=!1;for(let t of this.#I({allowStale:!0}))this.#y(t)&&(this.#O(this.#l[t],"expire"),e=!0);return e}info(e){let t=this.#s.get(e);if(t===void 0)return;let r=this.#o[t],o=this.#d(r)?r.__staleWhileFetching:r;if(o===void 0)return;let i={value:o};if(this.#b&&this.#C){let a=this.#b[t],s=this.#C[t];if(a&&s){let l=a-(Fo.now()-s);i.ttl=l,i.start=Date.now()}}return this.#E&&(i.size=this.#E[t]),i}dump(){let e=[];for(let t of this.#A({allowStale:!0})){let r=this.#l[t],o=this.#o[t],i=this.#d(o)?o.__staleWhileFetching:o;if(i===void 0||r===void 0)continue;let a={value:i};if(this.#b&&this.#C){a.ttl=this.#b[t];let s=Fo.now()-this.#C[t];a.start=Math.floor(Date.now()-s)}this.#E&&(a.size=this.#E[t]),e.unshift([r,a])}return e}load(e){this.clear();for(let[t,r]of e){if(r.start){let o=Date.now()-r.start;r.start=Fo.now()-o}this.set(t,r.value,r)}}set(e,t,r={}){if(t===void 0)return this.delete(e),this;let{ttl:o=this.ttl,start:i,noDisposeOnSet:a=this.noDisposeOnSet,sizeCalculation:s=this.sizeCalculation,status:l}=r,{noUpdateTTL:c=this.noUpdateTTL}=r,d=this.#_(e,t,r.size||0,s);if(this.maxEntrySize&&d>this.maxEntrySize)return l&&(l.set="miss",l.maxEntrySizeExceeded=!0),this.#O(e,"set"),this;let p=this.#c===0?void 0:this.#s.get(e);if(p===void 0)p=this.#c===0?this.#u:this.#x.length!==0?this.#x.pop():this.#c===this.#e?this.#F(!1):this.#c,this.#l[p]=e,this.#o[p]=t,this.#s.set(e,p),this.#f[this.#u]=p,this.#S[p]=this.#u,this.#u=p,this.#c++,this.#N(p,d,l),l&&(l.set="add"),c=!1;else{this.#z(p);let m=this.#o[p];if(t!==m){if(this.#T&&this.#d(m)){m.__abortController.abort(new Error("replaced"));let{__staleWhileFetching:u}=m;u!==void 0&&!a&&(this.#v&&this.#i?.(u,e,"set"),this.#h&&this.#g?.push([u,e,"set"]))}else a||(this.#v&&this.#i?.(m,e,"set"),this.#h&&this.#g?.push([m,e,"set"]));if(this.#M(p),this.#N(p,d,l),this.#o[p]=t,l){l.set="replace";let u=m&&this.#d(m)?m.__staleWhileFetching:m;u!==void 0&&(l.oldValue=u)}}else l&&(l.set="update")}if(o!==0&&!this.#b&&this.#P(),this.#b&&(c||this.#k(p,o,i),l&&this.#n(l,p)),!a&&this.#h&&this.#g){let m=this.#g,u;for(;u=m?.shift();)this.#r?.(...u)}return this}pop(){try{for(;this.#c;){let e=this.#o[this.#m];if(this.#F(!0),this.#d(e)){if(e.__staleWhileFetching)return e.__staleWhileFetching}else if(e!==void 0)return e}}finally{if(this.#h&&this.#g){let e=this.#g,t;for(;t=e?.shift();)this.#r?.(...t)}}}#F(e){let t=this.#m,r=this.#l[t],o=this.#o[t];return this.#T&&this.#d(o)?o.__abortController.abort(new Error("evicted")):(this.#v||this.#h)&&(this.#v&&this.#i?.(o,r,"evict"),this.#h&&this.#g?.push([o,r,"evict"])),this.#M(t),e&&(this.#l[t]=void 0,this.#o[t]=void 0,this.#x.push(t)),this.#c===1?(this.#m=this.#u=0,this.#x.length=0):this.#m=this.#f[t],this.#s.delete(r),this.#c--,t}has(e,t={}){let{updateAgeOnHas:r=this.updateAgeOnHas,status:o}=t,i=this.#s.get(e);if(i!==void 0){let a=this.#o[i];if(this.#d(a)&&a.__staleWhileFetching===void 0)return!1;if(this.#y(i))o&&(o.has="stale",this.#n(o,i));else return r&&this.#R(i),o&&(o.has="hit",this.#n(o,i)),!0}else o&&(o.has="miss");return!1}peek(e,t={}){let{allowStale:r=this.allowStale}=t,o=this.#s.get(e);if(o===void 0||!r&&this.#y(o))return;let i=this.#o[o];return this.#d(i)?i.__staleWhileFetching:i}#U(e,t,r,o){let i=t===void 0?void 0:this.#o[t];if(this.#d(i))return i;let a=new Fs,{signal:s}=r;s?.addEventListener("abort",()=>a.abort(s.reason),{signal:a.signal});let l={signal:a.signal,options:r,context:o},c=(g,f=!1)=>{let{aborted:S}=a.signal,b=r.ignoreFetchAbort&&g!==void 0;if(r.status&&(S&&!f?(r.status.fetchAborted=!0,r.status.fetchError=a.signal.reason,b&&(r.status.fetchAbortIgnored=!0)):r.status.fetchResolved=!0),S&&!b&&!f)return p(a.signal.reason);let w=u;return this.#o[t]===u&&(g===void 0?w.__staleWhileFetching?this.#o[t]=w.__staleWhileFetching:this.#O(e,"fetch"):(r.status&&(r.status.fetchUpdated=!0),this.set(e,g,l.options))),g},d=g=>(r.status&&(r.status.fetchRejected=!0,r.status.fetchError=g),p(g)),p=g=>{let{aborted:f}=a.signal,S=f&&r.allowStaleOnFetchAbort,b=S||r.allowStaleOnFetchRejection,w=b||r.noDeleteOnFetchRejection,v=u;if(this.#o[t]===u&&(!w||v.__staleWhileFetching===void 0?this.#O(e,"fetch"):S||(this.#o[t]=v.__staleWhileFetching)),b)return r.status&&v.__staleWhileFetching!==void 0&&(r.status.returnedStale=!0),v.__staleWhileFetching;if(v.__returned===v)throw g},m=(g,f)=>{let S=this.#a?.(e,i,l);S&&S instanceof Promise&&S.then(b=>g(b===void 0?void 0:b),f),a.signal.addEventListener("abort",()=>{(!r.ignoreFetchAbort||r.allowStaleOnFetchAbort)&&(g(void 0),r.allowStaleOnFetchAbort&&(g=b=>c(b,!0)))})};r.status&&(r.status.fetchDispatched=!0);let u=new Promise(m).then(c,d),h=Object.assign(u,{__abortController:a,__staleWhileFetching:i,__returned:void 0});return t===void 0?(this.set(e,h,{...l.options,status:void 0}),t=this.#s.get(e)):this.#o[t]=h,h}#d(e){if(!this.#T)return!1;let t=e;return!!t&&t instanceof Promise&&t.hasOwnProperty("__staleWhileFetching")&&t.__abortController instanceof Fs}async fetch(e,t={}){let{allowStale:r=this.allowStale,updateAgeOnGet:o=this.updateAgeOnGet,noDeleteOnStaleGet:i=this.noDeleteOnStaleGet,ttl:a=this.ttl,noDisposeOnSet:s=this.noDisposeOnSet,size:l=0,sizeCalculation:c=this.sizeCalculation,noUpdateTTL:d=this.noUpdateTTL,noDeleteOnFetchRejection:p=this.noDeleteOnFetchRejection,allowStaleOnFetchRejection:m=this.allowStaleOnFetchRejection,ignoreFetchAbort:u=this.ignoreFetchAbort,allowStaleOnFetchAbort:h=this.allowStaleOnFetchAbort,context:g,forceRefresh:f=!1,status:S,signal:b}=t;if(!this.#T)return S&&(S.fetch="get"),this.get(e,{allowStale:r,updateAgeOnGet:o,noDeleteOnStaleGet:i,status:S});let w={allowStale:r,updateAgeOnGet:o,noDeleteOnStaleGet:i,ttl:a,noDisposeOnSet:s,size:l,sizeCalculation:c,noUpdateTTL:d,noDeleteOnFetchRejection:p,allowStaleOnFetchRejection:m,allowStaleOnFetchAbort:h,ignoreFetchAbort:u,status:S,signal:b},v=this.#s.get(e);if(v===void 0){S&&(S.fetch="miss");let x=this.#U(e,v,w,g);return x.__returned=x}else{let x=this.#o[v];if(this.#d(x)){let H=r&&x.__staleWhileFetching!==void 0;return S&&(S.fetch="inflight",H&&(S.returnedStale=!0)),H?x.__staleWhileFetching:x.__returned=x}let C=this.#y(v);if(!f&&!C)return S&&(S.fetch="hit"),this.#z(v),o&&this.#R(v),S&&this.#n(S,v),x;let A=this.#U(e,v,w,g),O=A.__staleWhileFetching!==void 0&&r;return S&&(S.fetch=C?"stale":"refresh",O&&C&&(S.returnedStale=!0)),O?A.__staleWhileFetching:A.__returned=A}}async forceFetch(e,t={}){let r=await this.fetch(e,t);if(r===void 0)throw new Error("fetch() returned undefined");return r}memo(e,t={}){let r=this.#w;if(!r)throw new Error("no memoMethod provided to constructor");let{context:o,forceRefresh:i,...a}=t,s=this.get(e,a);if(!i&&s!==void 0)return s;let l=r(e,s,{options:a,context:o});return this.set(e,l,a),l}get(e,t={}){let{allowStale:r=this.allowStale,updateAgeOnGet:o=this.updateAgeOnGet,noDeleteOnStaleGet:i=this.noDeleteOnStaleGet,status:a}=t,s=this.#s.get(e);if(s!==void 0){let l=this.#o[s],c=this.#d(l);return a&&this.#n(a,s),this.#y(s)?(a&&(a.get="stale"),c?(a&&r&&l.__staleWhileFetching!==void 0&&(a.returnedStale=!0),r?l.__staleWhileFetching:void 0):(i||this.#O(e,"expire"),a&&r&&(a.returnedStale=!0),r?l:void 0)):(a&&(a.get="hit"),c?l.__staleWhileFetching:(this.#z(s),o&&this.#R(s),l))}else a&&(a.get="miss")}#B(e,t){this.#S[t]=e,this.#f[e]=t}#z(e){e!==this.#u&&(e===this.#m?this.#m=this.#f[e]:this.#B(this.#S[e],this.#f[e]),this.#B(this.#u,e),this.#u=e)}delete(e){return this.#O(e,"delete")}#O(e,t){let r=!1;if(this.#c!==0){let o=this.#s.get(e);if(o!==void 0)if(r=!0,this.#c===1)this.#H(t);else{this.#M(o);let i=this.#o[o];if(this.#d(i)?i.__abortController.abort(new Error("deleted")):(this.#v||this.#h)&&(this.#v&&this.#i?.(i,e,t),this.#h&&this.#g?.push([i,e,t])),this.#s.delete(e),this.#l[o]=void 0,this.#o[o]=void 0,o===this.#u)this.#u=this.#S[o];else if(o===this.#m)this.#m=this.#f[o];else{let a=this.#S[o];this.#f[a]=this.#f[o];let s=this.#f[o];this.#S[s]=this.#S[o]}this.#c--,this.#x.push(o)}}if(this.#h&&this.#g?.length){let o=this.#g,i;for(;i=o?.shift();)this.#r?.(...i)}return r}clear(){return this.#H("delete")}#H(e){for(let t of this.#I({allowStale:!0})){let r=this.#o[t];if(this.#d(r))r.__abortController.abort(new Error("deleted"));else{let o=this.#l[t];this.#v&&this.#i?.(r,o,e),this.#h&&this.#g?.push([r,o,e])}}if(this.#s.clear(),this.#o.fill(void 0),this.#l.fill(void 0),this.#b&&this.#C&&(this.#b.fill(0),this.#C.fill(0)),this.#E&&this.#E.fill(0),this.#m=0,this.#u=0,this.#x.length=0,this.#p=0,this.#c=0,this.#h&&this.#g){let t=this.#g,r;for(;r=t?.shift();)this.#r?.(...r)}}};import{posix as iI,win32 as Cd}from"node:path";import{fileURLToPath as aI}from"node:url";import{lstatSync as sI,readdir as lI,readdirSync as cI,readlinkSync as dI,realpathSync as pI}from"fs";import*as uI from"node:fs";import{lstat as hI,readdir as gI,readlink as fI,realpath as SI}from"node:fs/promises";import{EventEmitter as Td}from"node:events";import uS from"node:stream";import{StringDecoder as YA}from"node:string_decoder";var lS=typeof process=="object"&&process?process:{stdout:null,stderr:null},JA=n=>!!n&&typeof n=="object"&&(n instanceof cr||n instanceof uS||XA(n)||ZA(n)),XA=n=>!!n&&typeof n=="object"&&n instanceof Td&&typeof n.pipe=="function"&&n.pipe!==uS.Writable.prototype.pipe,ZA=n=>!!n&&typeof n=="object"&&n instanceof Td&&typeof n.write=="function"&&typeof n.end=="function",zn=Symbol("EOF"),Hn=Symbol("maybeEmitEnd"),lr=Symbol("emittedEnd"),Us=Symbol("emittingEnd"),ca=Symbol("emittedError"),Bs=Symbol("closed"),cS=Symbol("read"),zs=Symbol("flush"),dS=Symbol("flushChunk"),pn=Symbol("encoding"),Bo=Symbol("decoder"),et=Symbol("flowing"),da=Symbol("paused"),zo=Symbol("resume"),tt=Symbol("buffer"),vt=Symbol("pipes"),nt=Symbol("bufferLength"),fd=Symbol("bufferPush"),Hs=Symbol("bufferShift"),mt=Symbol("objectMode"),je=Symbol("destroyed"),Sd=Symbol("error"),yd=Symbol("emitData"),pS=Symbol("emitEnd"),bd=Symbol("emitEnd2"),xn=Symbol("async"),wd=Symbol("abort"),js=Symbol("aborted"),pa=Symbol("signal"),Wr=Symbol("dataListeners"),Ut=Symbol("discarded"),ua=n=>Promise.resolve().then(n),QA=n=>n(),eI=n=>n==="end"||n==="finish"||n==="prefinish",tI=n=>n instanceof ArrayBuffer||!!n&&typeof n=="object"&&n.constructor&&n.constructor.name==="ArrayBuffer"&&n.byteLength>=0,nI=n=>!Buffer.isBuffer(n)&&ArrayBuffer.isView(n),$s=class{src;dest;opts;ondrain;constructor(e,t,r){this.src=e,this.dest=t,this.opts=r,this.ondrain=()=>e[zo](),this.dest.on("drain",this.ondrain)}unpipe(){this.dest.removeListener("drain",this.ondrain)}proxyErrors(e){}end(){this.unpipe(),this.opts.end&&this.dest.end()}},vd=class extends $s{unpipe(){this.src.removeListener("error",this.proxyErrors),super.unpipe()}constructor(e,t,r){super(e,t,r),this.proxyErrors=o=>t.emit("error",o),e.on("error",this.proxyErrors)}},rI=n=>!!n.objectMode,oI=n=>!n.objectMode&&!!n.encoding&&n.encoding!=="buffer",cr=class extends Td{[et]=!1;[da]=!1;[vt]=[];[tt]=[];[mt];[pn];[xn];[Bo];[zn]=!1;[lr]=!1;[Us]=!1;[Bs]=!1;[ca]=null;[nt]=0;[je]=!1;[pa];[js]=!1;[Wr]=0;[Ut]=!1;writable=!0;readable=!0;constructor(...e){let t=e[0]||{};if(super(),t.objectMode&&typeof t.encoding=="string")throw new TypeError("Encoding and objectMode may not be used together");rI(t)?(this[mt]=!0,this[pn]=null):oI(t)?(this[pn]=t.encoding,this[mt]=!1):(this[mt]=!1,this[pn]=null),this[xn]=!!t.async,this[Bo]=this[pn]?new YA(this[pn]):null,t&&t.debugExposeBuffer===!0&&Object.defineProperty(this,"buffer",{get:()=>this[tt]}),t&&t.debugExposePipes===!0&&Object.defineProperty(this,"pipes",{get:()=>this[vt]});let{signal:r}=t;r&&(this[pa]=r,r.aborted?this[wd]():r.addEventListener("abort",()=>this[wd]()))}get bufferLength(){return this[nt]}get encoding(){return this[pn]}set encoding(e){throw new Error("Encoding must be set at instantiation time")}setEncoding(e){throw new Error("Encoding must be set at instantiation time")}get objectMode(){return this[mt]}set objectMode(e){throw new Error("objectMode must be set at instantiation time")}get async(){return this[xn]}set async(e){this[xn]=this[xn]||!!e}[wd](){this[js]=!0,this.emit("abort",this[pa]?.reason),this.destroy(this[pa]?.reason)}get aborted(){return this[js]}set aborted(e){}write(e,t,r){if(this[js])return!1;if(this[zn])throw new Error("write after end");if(this[je])return this.emit("error",Object.assign(new Error("Cannot call write after a stream was destroyed"),{code:"ERR_STREAM_DESTROYED"})),!0;typeof t=="function"&&(r=t,t="utf8"),t||(t="utf8");let o=this[xn]?ua:QA;if(!this[mt]&&!Buffer.isBuffer(e)){if(nI(e))e=Buffer.from(e.buffer,e.byteOffset,e.byteLength);else if(tI(e))e=Buffer.from(e);else if(typeof e!="string")throw new Error("Non-contiguous data written to non-objectMode stream")}return this[mt]?(this[et]&&this[nt]!==0&&this[zs](!0),this[et]?this.emit("data",e):this[fd](e),this[nt]!==0&&this.emit("readable"),r&&o(r),this[et]):e.length?(typeof e=="string"&&!(t===this[pn]&&!this[Bo]?.lastNeed)&&(e=Buffer.from(e,t)),Buffer.isBuffer(e)&&this[pn]&&(e=this[Bo].write(e)),this[et]&&this[nt]!==0&&this[zs](!0),this[et]?this.emit("data",e):this[fd](e),this[nt]!==0&&this.emit("readable"),r&&o(r),this[et]):(this[nt]!==0&&this.emit("readable"),r&&o(r),this[et])}read(e){if(this[je])return null;if(this[Ut]=!1,this[nt]===0||e===0||e&&e>this[nt])return this[Hn](),null;this[mt]&&(e=null),this[tt].length>1&&!this[mt]&&(this[tt]=[this[pn]?this[tt].join(""):Buffer.concat(this[tt],this[nt])]);let t=this[cS](e||null,this[tt][0]);return this[Hn](),t}[cS](e,t){if(this[mt])this[Hs]();else{let r=t;e===r.length||e===null?this[Hs]():typeof r=="string"?(this[tt][0]=r.slice(e),t=r.slice(0,e),this[nt]-=e):(this[tt][0]=r.subarray(e),t=r.subarray(0,e),this[nt]-=e)}return this.emit("data",t),!this[tt].length&&!this[zn]&&this.emit("drain"),t}end(e,t,r){return typeof e=="function"&&(r=e,e=void 0),typeof t=="function"&&(r=t,t="utf8"),e!==void 0&&this.write(e,t),r&&this.once("end",r),this[zn]=!0,this.writable=!1,(this[et]||!this[da])&&this[Hn](),this}[zo](){this[je]||(!this[Wr]&&!this[vt].length&&(this[Ut]=!0),this[da]=!1,this[et]=!0,this.emit("resume"),this[tt].length?this[zs]():this[zn]?this[Hn]():this.emit("drain"))}resume(){return this[zo]()}pause(){this[et]=!1,this[da]=!0,this[Ut]=!1}get destroyed(){return this[je]}get flowing(){return this[et]}get paused(){return this[da]}[fd](e){this[mt]?this[nt]+=1:this[nt]+=e.length,this[tt].push(e)}[Hs](){return this[mt]?this[nt]-=1:this[nt]-=this[tt][0].length,this[tt].shift()}[zs](e=!1){do;while(this[dS](this[Hs]())&&this[tt].length);!e&&!this[tt].length&&!this[zn]&&this.emit("drain")}[dS](e){return this.emit("data",e),this[et]}pipe(e,t){if(this[je])return e;this[Ut]=!1;let r=this[lr];return t=t||{},e===lS.stdout||e===lS.stderr?t.end=!1:t.end=t.end!==!1,t.proxyErrors=!!t.proxyErrors,r?t.end&&e.end():(this[vt].push(t.proxyErrors?new vd(this,e,t):new $s(this,e,t)),this[xn]?ua(()=>this[zo]()):this[zo]()),e}unpipe(e){let t=this[vt].find(r=>r.dest===e);t&&(this[vt].length===1?(this[et]&&this[Wr]===0&&(this[et]=!1),this[vt]=[]):this[vt].splice(this[vt].indexOf(t),1),t.unpipe())}addListener(e,t){return this.on(e,t)}on(e,t){let r=super.on(e,t);if(e==="data")this[Ut]=!1,this[Wr]++,!this[vt].length&&!this[et]&&this[zo]();else if(e==="readable"&&this[nt]!==0)super.emit("readable");else if(eI(e)&&this[lr])super.emit(e),this.removeAllListeners(e);else if(e==="error"&&this[ca]){let o=t;this[xn]?ua(()=>o.call(this,this[ca])):o.call(this,this[ca])}return r}removeListener(e,t){return this.off(e,t)}off(e,t){let r=super.off(e,t);return e==="data"&&(this[Wr]=this.listeners("data").length,this[Wr]===0&&!this[Ut]&&!this[vt].length&&(this[et]=!1)),r}removeAllListeners(e){let t=super.removeAllListeners(e);return(e==="data"||e===void 0)&&(this[Wr]=0,!this[Ut]&&!this[vt].length&&(this[et]=!1)),t}get emittedEnd(){return this[lr]}[Hn](){!this[Us]&&!this[lr]&&!this[je]&&this[tt].length===0&&this[zn]&&(this[Us]=!0,this.emit("end"),this.emit("prefinish"),this.emit("finish"),this[Bs]&&this.emit("close"),this[Us]=!1)}emit(e,...t){let r=t[0];if(e!=="error"&&e!=="close"&&e!==je&&this[je])return!1;if(e==="data")return!this[mt]&&!r?!1:this[xn]?(ua(()=>this[yd](r)),!0):this[yd](r);if(e==="end")return this[pS]();if(e==="close"){if(this[Bs]=!0,!this[lr]&&!this[je])return!1;let i=super.emit("close");return this.removeAllListeners("close"),i}else if(e==="error"){this[ca]=r,super.emit(Sd,r);let i=!this[pa]||this.listeners("error").length?super.emit("error",r):!1;return this[Hn](),i}else if(e==="resume"){let i=super.emit("resume");return this[Hn](),i}else if(e==="finish"||e==="prefinish"){let i=super.emit(e);return this.removeAllListeners(e),i}let o=super.emit(e,...t);return this[Hn](),o}[yd](e){for(let r of this[vt])r.dest.write(e)===!1&&this.pause();let t=this[Ut]?!1:super.emit("data",e);return this[Hn](),t}[pS](){return this[lr]?!1:(this[lr]=!0,this.readable=!1,this[xn]?(ua(()=>this[bd]()),!0):this[bd]())}[bd](){if(this[Bo]){let t=this[Bo].end();if(t){for(let r of this[vt])r.dest.write(t);this[Ut]||super.emit("data",t)}}for(let t of this[vt])t.end();let e=super.emit("end");return this.removeAllListeners("end"),e}async collect(){let e=Object.assign([],{dataLength:0});this[mt]||(e.dataLength=0);let t=this.promise();return this.on("data",r=>{e.push(r),this[mt]||(e.dataLength+=r.length)}),await t,e}async concat(){if(this[mt])throw new Error("cannot concat in objectMode");let e=await this.collect();return this[pn]?e.join(""):Buffer.concat(e,e.dataLength)}async promise(){return new Promise((e,t)=>{this.on(je,()=>t(new Error("stream destroyed"))),this.on("error",r=>t(r)),this.on("end",()=>e())})}[Symbol.asyncIterator](){this[Ut]=!1;let e=!1,t=async()=>(this.pause(),e=!0,{value:void 0,done:!0});return{next:()=>{if(e)return t();let o=this.read();if(o!==null)return Promise.resolve({done:!1,value:o});if(this[zn])return t();let i,a,s=p=>{this.off("data",l),this.off("end",c),this.off(je,d),t(),a(p)},l=p=>{this.off("error",s),this.off("end",c),this.off(je,d),this.pause(),i({value:p,done:!!this[zn]})},c=()=>{this.off("error",s),this.off("data",l),this.off(je,d),t(),i({done:!0,value:void 0})},d=()=>s(new Error("stream destroyed"));return new Promise((p,m)=>{a=m,i=p,this.once(je,d),this.once("error",s),this.once("end",c),this.once("data",l)})},throw:t,return:t,[Symbol.asyncIterator](){return this}}}[Symbol.iterator](){this[Ut]=!1;let e=!1,t=()=>(this.pause(),this.off(Sd,t),this.off(je,t),this.off("end",t),e=!0,{done:!0,value:void 0}),r=()=>{if(e)return t();let o=this.read();return o===null?t():{done:!1,value:o}};return this.once("end",t),this.once(Sd,t),this.once(je,t),{next:r,throw:t,return:t,[Symbol.iterator](){return this}}}destroy(e){if(this[je])return e?this.emit("error",e):this.emit(je),this;this[je]=!0,this[Ut]=!0,this[tt].length=0,this[nt]=0;let t=this;return typeof t.close=="function"&&!this[Bs]&&t.close(),e?this.emit("error",e):this.emit(je),this}static get isStream(){return JA}};var mI=pI.native,ha={lstatSync:sI,readdir:lI,readdirSync:cI,readlinkSync:dI,realpathSync:mI,promises:{lstat:hI,readdir:gI,readlink:fI,realpath:SI}},SS=n=>!n||n===ha||n===uI?ha:{...ha,...n,promises:{...ha.promises,...n.promises||{}}},yS=/^\\\\\?\\([a-z]:)\\?$/i,yI=n=>n.replace(/\//g,"\\").replace(yS,"$1\\"),bI=/[\\\/]/,Zt=0,bS=1,wS=2,En=4,vS=6,TS=8,Vr=10,xS=12,Xt=15,ma=~Xt,xd=16,mS=32,ga=64,un=128,Gs=256,Vs=512,hS=ga|un|Vs,wI=1023,Ed=n=>n.isFile()?TS:n.isDirectory()?En:n.isSymbolicLink()?Vr:n.isCharacterDevice()?wS:n.isBlockDevice()?vS:n.isSocket()?xS:n.isFIFO()?bS:Zt,gS=new Map,fa=n=>{let e=gS.get(n);if(e)return e;let t=n.normalize("NFKD");return gS.set(n,t),t},fS=new Map,Ws=n=>{let e=fS.get(n);if(e)return e;let t=fa(n.toLowerCase());return fS.set(n,t),t},qs=class extends la{constructor(){super({max:256})}},Rd=class extends la{constructor(e=16*1024){super({maxSize:e,sizeCalculation:t=>t.length+1})}},ES=Symbol("PathScurry setAsCwd"),ht=class{name;root;roots;parent;nocase;isCWD=!1;#e;#t;get dev(){return this.#t}#i;get mode(){return this.#i}#r;get nlink(){return this.#r}#a;get uid(){return this.#a}#w;get gid(){return this.#w}#c;get rdev(){return this.#c}#p;get blksize(){return this.#p}#s;get ino(){return this.#s}#l;get size(){return this.#l}#o;get blocks(){return this.#o}#f;get atimeMs(){return this.#f}#S;get mtimeMs(){return this.#S}#m;get ctimeMs(){return this.#m}#u;get birthtimeMs(){return this.#u}#x;get atime(){return this.#x}#g;get mtime(){return this.#g}#E;get ctime(){return this.#E}#C;get birthtime(){return this.#C}#b;#v;#T;#h;#P;#R;#n;#k;#y;#L;get parentPath(){return(this.parent||this).fullpath()}get path(){return this.parentPath}constructor(e,t=Zt,r,o,i,a,s){this.name=e,this.#b=i?Ws(e):fa(e),this.#n=t&wI,this.nocase=i,this.roots=o,this.root=r||this,this.#k=a,this.#T=s.fullpath,this.#P=s.relative,this.#R=s.relativePosix,this.parent=s.parent,this.parent?this.#e=this.parent.#e:this.#e=SS(s.fs)}depth(){return this.#v!==void 0?this.#v:this.parent?this.#v=this.parent.depth()+1:this.#v=0}childrenCache(){return this.#k}resolve(e){if(!e)return this;let t=this.getRootString(e),o=e.substring(t.length).split(this.splitSep);return t?this.getRoot(t).#M(o):this.#M(o)}#M(e){let t=this;for(let r of e)t=t.child(r);return t}children(){let e=this.#k.get(this);if(e)return e;let t=Object.assign([],{provisional:0});return this.#k.set(this,t),this.#n&=~xd,t}child(e,t){if(e===""||e===".")return this;if(e==="..")return this.parent||this;let r=this.children(),o=this.nocase?Ws(e):fa(e);for(let l of r)if(l.#b===o)return l;let i=this.parent?this.sep:"",a=this.#T?this.#T+i+e:void 0,s=this.newChild(e,Zt,{...t,parent:this,fullpath:a});return this.canReaddir()||(s.#n|=un),r.push(s),s}relative(){if(this.isCWD)return"";if(this.#P!==void 0)return this.#P;let e=this.name,t=this.parent;if(!t)return this.#P=this.name;let r=t.relative();return r+(!r||!t.parent?"":this.sep)+e}relativePosix(){if(this.sep==="/")return this.relative();if(this.isCWD)return"";if(this.#R!==void 0)return this.#R;let e=this.name,t=this.parent;if(!t)return this.#R=this.fullpathPosix();let r=t.relativePosix();return r+(!r||!t.parent?"":"/")+e}fullpath(){if(this.#T!==void 0)return this.#T;let e=this.name,t=this.parent;if(!t)return this.#T=this.name;let o=t.fullpath()+(t.parent?this.sep:"")+e;return this.#T=o}fullpathPosix(){if(this.#h!==void 0)return this.#h;if(this.sep==="/")return this.#h=this.fullpath();if(!this.parent){let o=this.fullpath().replace(/\\/g,"/");return/^[a-z]:\//i.test(o)?this.#h=`//?/${o}`:this.#h=o}let e=this.parent,t=e.fullpathPosix(),r=t+(!t||!e.parent?"":"/")+this.name;return this.#h=r}isUnknown(){return(this.#n&Xt)===Zt}isType(e){return this[`is${e}`]()}getType(){return this.isUnknown()?"Unknown":this.isDirectory()?"Directory":this.isFile()?"File":this.isSymbolicLink()?"SymbolicLink":this.isFIFO()?"FIFO":this.isCharacterDevice()?"CharacterDevice":this.isBlockDevice()?"BlockDevice":this.isSocket()?"Socket":"Unknown"}isFile(){return(this.#n&Xt)===TS}isDirectory(){return(this.#n&Xt)===En}isCharacterDevice(){return(this.#n&Xt)===wS}isBlockDevice(){return(this.#n&Xt)===vS}isFIFO(){return(this.#n&Xt)===bS}isSocket(){return(this.#n&Xt)===xS}isSymbolicLink(){return(this.#n&Vr)===Vr}lstatCached(){return this.#n&mS?this:void 0}readlinkCached(){return this.#y}realpathCached(){return this.#L}readdirCached(){let e=this.children();return e.slice(0,e.provisional)}canReadlink(){if(this.#y)return!0;if(!this.parent)return!1;let e=this.#n&Xt;return!(e!==Zt&&e!==Vr||this.#n&Gs||this.#n&un)}calledReaddir(){return!!(this.#n&xd)}isENOENT(){return!!(this.#n&un)}isNamed(e){return this.nocase?this.#b===Ws(e):this.#b===fa(e)}async readlink(){let e=this.#y;if(e)return e;if(this.canReadlink()&&this.parent)try{let t=await this.#e.promises.readlink(this.fullpath()),r=(await this.parent.realpath())?.resolve(t);if(r)return this.#y=r}catch(t){this.#d(t.code);return}}readlinkSync(){let e=this.#y;if(e)return e;if(this.canReadlink()&&this.parent)try{let t=this.#e.readlinkSync(this.fullpath()),r=this.parent.realpathSync()?.resolve(t);if(r)return this.#y=r}catch(t){this.#d(t.code);return}}#N(e){this.#n|=xd;for(let t=e.provisional;t<e.length;t++){let r=e[t];r&&r.#_()}}#_(){this.#n&un||(this.#n=(this.#n|un)&ma,this.#A())}#A(){let e=this.children();e.provisional=0;for(let t of e)t.#_()}#I(){this.#n|=Vs,this.#D()}#D(){if(this.#n&ga)return;let e=this.#n;(e&Xt)===En&&(e&=ma),this.#n=e|ga,this.#A()}#F(e=""){e==="ENOTDIR"||e==="EPERM"?this.#D():e==="ENOENT"?this.#_():this.children().provisional=0}#U(e=""){e==="ENOTDIR"?this.parent.#D():e==="ENOENT"&&this.#_()}#d(e=""){let t=this.#n;t|=Gs,e==="ENOENT"&&(t|=un),(e==="EINVAL"||e==="UNKNOWN")&&(t&=ma),this.#n=t,e==="ENOTDIR"&&this.parent&&this.parent.#D()}#B(e,t){return this.#O(e,t)||this.#z(e,t)}#z(e,t){let r=Ed(e),o=this.newChild(e.name,r,{parent:this}),i=o.#n&Xt;return i!==En&&i!==Vr&&i!==Zt&&(o.#n|=ga),t.unshift(o),t.provisional++,o}#O(e,t){for(let r=t.provisional;r<t.length;r++){let o=t[r];if((this.nocase?Ws(e.name):fa(e.name))===o.#b)return this.#H(e,o,r,t)}}#H(e,t,r,o){let i=t.name;return t.#n=t.#n&ma|Ed(e),i!==e.name&&(t.name=e.name),r!==o.provisional&&(r===o.length-1?o.pop():o.splice(r,1),o.unshift(t)),o.provisional++,t}async lstat(){if(!(this.#n&un))try{return this.#W(await this.#e.promises.lstat(this.fullpath())),this}catch(e){this.#U(e.code)}}lstatSync(){if(!(this.#n&un))try{return this.#W(this.#e.lstatSync(this.fullpath())),this}catch(e){this.#U(e.code)}}#W(e){let{atime:t,atimeMs:r,birthtime:o,birthtimeMs:i,blksize:a,blocks:s,ctime:l,ctimeMs:c,dev:d,gid:p,ino:m,mode:u,mtime:h,mtimeMs:g,nlink:f,rdev:S,size:b,uid:w}=e;this.#x=t,this.#f=r,this.#C=o,this.#u=i,this.#p=a,this.#o=s,this.#E=l,this.#m=c,this.#t=d,this.#w=p,this.#s=m,this.#i=u,this.#g=h,this.#S=g,this.#r=f,this.#c=S,this.#l=b,this.#a=w;let v=Ed(e);this.#n=this.#n&ma|v|mS,v!==Zt&&v!==En&&v!==Vr&&(this.#n|=ga)}#$=[];#G=!1;#V(e){this.#G=!1;let t=this.#$.slice();this.#$.length=0,t.forEach(r=>r(null,e))}readdirCB(e,t=!1){if(!this.canReaddir()){t?e(null,[]):queueMicrotask(()=>e(null,[]));return}let r=this.children();if(this.calledReaddir()){let i=r.slice(0,r.provisional);t?e(null,i):queueMicrotask(()=>e(null,i));return}if(this.#$.push(e),this.#G)return;this.#G=!0;let o=this.fullpath();this.#e.readdir(o,{withFileTypes:!0},(i,a)=>{if(i)this.#F(i.code),r.provisional=0;else{for(let s of a)this.#B(s,r);this.#N(r)}this.#V(r.slice(0,r.provisional))})}#j;async readdir(){if(!this.canReaddir())return[];let e=this.children();if(this.calledReaddir())return e.slice(0,e.provisional);let t=this.fullpath();if(this.#j)await this.#j;else{let r=()=>{};this.#j=new Promise(o=>r=o);try{for(let o of await this.#e.promises.readdir(t,{withFileTypes:!0}))this.#B(o,e);this.#N(e)}catch(o){this.#F(o.code),e.provisional=0}this.#j=void 0,r()}return e.slice(0,e.provisional)}readdirSync(){if(!this.canReaddir())return[];let e=this.children();if(this.calledReaddir())return e.slice(0,e.provisional);let t=this.fullpath();try{for(let r of this.#e.readdirSync(t,{withFileTypes:!0}))this.#B(r,e);this.#N(e)}catch(r){this.#F(r.code),e.provisional=0}return e.slice(0,e.provisional)}canReaddir(){if(this.#n&hS)return!1;let e=Xt&this.#n;return e===Zt||e===En||e===Vr}shouldWalk(e,t){return(this.#n&En)===En&&!(this.#n&hS)&&!e.has(this)&&(!t||t(this))}async realpath(){if(this.#L)return this.#L;if(!((Vs|Gs|un)&this.#n))try{let e=await this.#e.promises.realpath(this.fullpath());return this.#L=this.resolve(e)}catch{this.#I()}}realpathSync(){if(this.#L)return this.#L;if(!((Vs|Gs|un)&this.#n))try{let e=this.#e.realpathSync(this.fullpath());return this.#L=this.resolve(e)}catch{this.#I()}}[ES](e){if(e===this)return;e.isCWD=!1,this.isCWD=!0;let t=new Set([]),r=[],o=this;for(;o&&o.parent;)t.add(o),o.#P=r.join(this.sep),o.#R=r.join("/"),o=o.parent,r.push("..");for(o=e;o&&o.parent&&!t.has(o);)o.#P=void 0,o.#R=void 0,o=o.parent}},Ks=class n extends ht{sep="\\";splitSep=bI;constructor(e,t=Zt,r,o,i,a,s){super(e,t,r,o,i,a,s)}newChild(e,t=Zt,r={}){return new n(e,t,this.root,this.roots,this.nocase,this.childrenCache(),r)}getRootString(e){return Cd.parse(e).root}getRoot(e){if(e=yI(e.toUpperCase()),e===this.root.name)return this.root;for(let[t,r]of Object.entries(this.roots))if(this.sameRoot(e,t))return this.roots[e]=r;return this.roots[e]=new Ho(e,this).root}sameRoot(e,t=this.root.name){return e=e.toUpperCase().replace(/\//g,"\\").replace(yS,"$1\\"),e===t}},Ys=class n extends ht{splitSep="/";sep="/";constructor(e,t=Zt,r,o,i,a,s){super(e,t,r,o,i,a,s)}getRootString(e){return e.startsWith("/")?"/":""}getRoot(e){return this.root}newChild(e,t=Zt,r={}){return new n(e,t,this.root,this.roots,this.nocase,this.childrenCache(),r)}},Js=class{root;rootPath;roots;cwd;#e;#t;#i;nocase;#r;constructor(e=process.cwd(),t,r,{nocase:o,childrenCacheSize:i=16*1024,fs:a=ha}={}){this.#r=SS(a),(e instanceof URL||e.startsWith("file://"))&&(e=aI(e));let s=t.resolve(e);this.roots=Object.create(null),this.rootPath=this.parseRootPath(s),this.#e=new qs,this.#t=new qs,this.#i=new Rd(i);let l=s.substring(this.rootPath.length).split(r);if(l.length===1&&!l[0]&&l.pop(),o===void 0)throw new TypeError("must provide nocase setting to PathScurryBase ctor");this.nocase=o,this.root=this.newRoot(this.#r),this.roots[this.rootPath]=this.root;let c=this.root,d=l.length-1,p=t.sep,m=this.rootPath,u=!1;for(let h of l){let g=d--;c=c.child(h,{relative:new Array(g).fill("..").join(p),relativePosix:new Array(g).fill("..").join("/"),fullpath:m+=(u?"":p)+h}),u=!0}this.cwd=c}depth(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.depth()}childrenCache(){return this.#i}resolve(...e){let t="";for(let i=e.length-1;i>=0;i--){let a=e[i];if(!(!a||a===".")&&(t=t?`${a}/${t}`:a,this.isAbsolute(a)))break}let r=this.#e.get(t);if(r!==void 0)return r;let o=this.cwd.resolve(t).fullpath();return this.#e.set(t,o),o}resolvePosix(...e){let t="";for(let i=e.length-1;i>=0;i--){let a=e[i];if(!(!a||a===".")&&(t=t?`${a}/${t}`:a,this.isAbsolute(a)))break}let r=this.#t.get(t);if(r!==void 0)return r;let o=this.cwd.resolve(t).fullpathPosix();return this.#t.set(t,o),o}relative(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.relative()}relativePosix(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.relativePosix()}basename(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.name}dirname(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),(e.parent||e).fullpath()}async readdir(e=this.cwd,t={withFileTypes:!0}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r}=t;if(e.canReaddir()){let o=await e.readdir();return r?o:o.map(i=>i.name)}else return[]}readdirSync(e=this.cwd,t={withFileTypes:!0}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r=!0}=t;return e.canReaddir()?r?e.readdirSync():e.readdirSync().map(o=>o.name):[]}async lstat(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.lstat()}lstatSync(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.lstatSync()}async readlink(e=this.cwd,{withFileTypes:t}={withFileTypes:!1}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e.withFileTypes,e=this.cwd);let r=await e.readlink();return t?r:r?.fullpath()}readlinkSync(e=this.cwd,{withFileTypes:t}={withFileTypes:!1}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e.withFileTypes,e=this.cwd);let r=e.readlinkSync();return t?r:r?.fullpath()}async realpath(e=this.cwd,{withFileTypes:t}={withFileTypes:!1}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e.withFileTypes,e=this.cwd);let r=await e.realpath();return t?r:r?.fullpath()}realpathSync(e=this.cwd,{withFileTypes:t}={withFileTypes:!1}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e.withFileTypes,e=this.cwd);let r=e.realpathSync();return t?r:r?.fullpath()}async walk(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t,s=[];(!i||i(e))&&s.push(r?e:e.fullpath());let l=new Set,c=(p,m)=>{l.add(p),p.readdirCB((u,h)=>{if(u)return m(u);let g=h.length;if(!g)return m();let f=()=>{--g===0&&m()};for(let S of h)(!i||i(S))&&s.push(r?S:S.fullpath()),o&&S.isSymbolicLink()?S.realpath().then(b=>b?.isUnknown()?b.lstat():b).then(b=>b?.shouldWalk(l,a)?c(b,f):f()):S.shouldWalk(l,a)?c(S,f):f()},!0)},d=e;return new Promise((p,m)=>{c(d,u=>{if(u)return m(u);p(s)})})}walkSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t,s=[];(!i||i(e))&&s.push(r?e:e.fullpath());let l=new Set([e]);for(let c of l){let d=c.readdirSync();for(let p of d){(!i||i(p))&&s.push(r?p:p.fullpath());let m=p;if(p.isSymbolicLink()){if(!(o&&(m=p.realpathSync())))continue;m.isUnknown()&&m.lstatSync()}m.shouldWalk(l,a)&&l.add(m)}}return s}[Symbol.asyncIterator](){return this.iterate()}iterate(e=this.cwd,t={}){return typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd),this.stream(e,t)[Symbol.asyncIterator]()}[Symbol.iterator](){return this.iterateSync()}*iterateSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t;(!i||i(e))&&(yield r?e:e.fullpath());let s=new Set([e]);for(let l of s){let c=l.readdirSync();for(let d of c){(!i||i(d))&&(yield r?d:d.fullpath());let p=d;if(d.isSymbolicLink()){if(!(o&&(p=d.realpathSync())))continue;p.isUnknown()&&p.lstatSync()}p.shouldWalk(s,a)&&s.add(p)}}}stream(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t,s=new cr({objectMode:!0});(!i||i(e))&&s.write(r?e:e.fullpath());let l=new Set,c=[e],d=0,p=()=>{let m=!1;for(;!m;){let u=c.shift();if(!u){d===0&&s.end();return}d++,l.add(u);let h=(f,S,b=!1)=>{if(f)return s.emit("error",f);if(o&&!b){let w=[];for(let v of S)v.isSymbolicLink()&&w.push(v.realpath().then(x=>x?.isUnknown()?x.lstat():x));if(w.length){Promise.all(w).then(()=>h(null,S,!0));return}}for(let w of S)w&&(!i||i(w))&&(s.write(r?w:w.fullpath())||(m=!0));d--;for(let w of S){let v=w.realpathCached()||w;v.shouldWalk(l,a)&&c.push(v)}m&&!s.flowing?s.once("drain",p):g||p()},g=!0;u.readdirCB(h,!0),g=!1}};return p(),s}streamSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof ht||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t,s=new cr({objectMode:!0}),l=new Set;(!i||i(e))&&s.write(r?e:e.fullpath());let c=[e],d=0,p=()=>{let m=!1;for(;!m;){let u=c.shift();if(!u){d===0&&s.end();return}d++,l.add(u);let h=u.readdirSync();for(let g of h)(!i||i(g))&&(s.write(r?g:g.fullpath())||(m=!0));d--;for(let g of h){let f=g;if(g.isSymbolicLink()){if(!(o&&(f=g.realpathSync())))continue;f.isUnknown()&&f.lstatSync()}f.shouldWalk(l,a)&&c.push(f)}}m&&!s.flowing&&s.once("drain",p)};return p(),s}chdir(e=this.cwd){let t=this.cwd;this.cwd=typeof e=="string"?this.cwd.resolve(e):e,this.cwd[ES](t)}},Ho=class extends Js{sep="\\";constructor(e=process.cwd(),t={}){let{nocase:r=!0}=t;super(e,Cd,"\\",{...t,nocase:r}),this.nocase=r;for(let o=this.cwd;o;o=o.parent)o.nocase=this.nocase}parseRootPath(e){return Cd.parse(e).root.toUpperCase()}newRoot(e){return new Ks(this.rootPath,En,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")||e.startsWith("\\")||/^[a-z]:(\/|\\)/i.test(e)}},jo=class extends Js{sep="/";constructor(e=process.cwd(),t={}){let{nocase:r=!1}=t;super(e,iI,"/",{...t,nocase:r}),this.nocase=r}parseRootPath(e){return"/"}newRoot(e){return new Ys(this.rootPath,En,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")}},Sa=class extends jo{constructor(e=process.cwd(),t={}){let{nocase:r=!0}=t;super(e,{...t,nocase:r})}},IK=process.platform==="win32"?Ks:Ys,CS=process.platform==="win32"?Ho:process.platform==="darwin"?Sa:jo;var vI=n=>n.length>=1,TI=n=>n.length>=1,$o=class n{#e;#t;#i;length;#r;#a;#w;#c;#p;#s;#l=!0;constructor(e,t,r,o){if(!vI(e))throw new TypeError("empty pattern list");if(!TI(t))throw new TypeError("empty glob list");if(t.length!==e.length)throw new TypeError("mismatched pattern list and glob list lengths");if(this.length=e.length,r<0||r>=this.length)throw new TypeError("index out of range");if(this.#e=e,this.#t=t,this.#i=r,this.#r=o,this.#i===0){if(this.isUNC()){let[i,a,s,l,...c]=this.#e,[d,p,m,u,...h]=this.#t;c[0]===""&&(c.shift(),h.shift());let g=[i,a,s,l,""].join("/"),f=[d,p,m,u,""].join("/");this.#e=[g,...c],this.#t=[f,...h],this.length=this.#e.length}else if(this.isDrive()||this.isAbsolute()){let[i,...a]=this.#e,[s,...l]=this.#t;a[0]===""&&(a.shift(),l.shift());let c=i+"/",d=s+"/";this.#e=[c,...a],this.#t=[d,...l],this.length=this.#e.length}}}pattern(){return this.#e[this.#i]}isString(){return typeof this.#e[this.#i]=="string"}isGlobstar(){return this.#e[this.#i]===st}isRegExp(){return this.#e[this.#i]instanceof RegExp}globString(){return this.#w=this.#w||(this.#i===0?this.isAbsolute()?this.#t[0]+this.#t.slice(1).join("/"):this.#t.join("/"):this.#t.slice(this.#i).join("/"))}hasMore(){return this.length>this.#i+1}rest(){return this.#a!==void 0?this.#a:this.hasMore()?(this.#a=new n(this.#e,this.#t,this.#i+1,this.#r),this.#a.#s=this.#s,this.#a.#p=this.#p,this.#a.#c=this.#c,this.#a):this.#a=null}isUNC(){let e=this.#e;return this.#p!==void 0?this.#p:this.#p=this.#r==="win32"&&this.#i===0&&e[0]===""&&e[1]===""&&typeof e[2]=="string"&&!!e[2]&&typeof e[3]=="string"&&!!e[3]}isDrive(){let e=this.#e;return this.#c!==void 0?this.#c:this.#c=this.#r==="win32"&&this.#i===0&&this.length>1&&typeof e[0]=="string"&&/^[a-z]:$/i.test(e[0])}isAbsolute(){let e=this.#e;return this.#s!==void 0?this.#s:this.#s=e[0]===""&&e.length>1||this.isDrive()||this.isUNC()}root(){let e=this.#e[0];return typeof e=="string"&&this.isAbsolute()&&this.#i===0?e:""}checkFollowGlobstar(){return!(this.#i===0||!this.isGlobstar()||!this.#l)}markFollowGlobstar(){return this.#i===0||!this.isGlobstar()||!this.#l?!1:(this.#l=!1,!0)}};var xI=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",Go=class{relative;relativeChildren;absolute;absoluteChildren;platform;mmopts;constructor(e,{nobrace:t,nocase:r,noext:o,noglobstar:i,platform:a=xI}){this.relative=[],this.absolute=[],this.relativeChildren=[],this.absoluteChildren=[],this.platform=a,this.mmopts={dot:!0,nobrace:t,nocase:r,noext:o,noglobstar:i,optimizationLevel:2,platform:a,nocomment:!0,nonegate:!0};for(let s of e)this.add(s)}add(e){let t=new Ft(e,this.mmopts);for(let r=0;r<t.set.length;r++){let o=t.set[r],i=t.globParts[r];if(!o||!i)throw new Error("invalid pattern object");for(;o[0]==="."&&i[0]===".";)o.shift(),i.shift();let a=new $o(o,i,0,this.platform),s=new Ft(a.globString(),this.mmopts),l=i[i.length-1]==="**",c=a.isAbsolute();c?this.absolute.push(s):this.relative.push(s),l&&(c?this.absoluteChildren.push(s):this.relativeChildren.push(s))}}ignored(e){let t=e.fullpath(),r=`${t}/`,o=e.relative()||".",i=`${o}/`;for(let a of this.relative)if(a.match(o)||a.match(i))return!0;for(let a of this.absolute)if(a.match(t)||a.match(r))return!0;return!1}childrenIgnored(e){let t=e.fullpath()+"/",r=(e.relative()||".")+"/";for(let o of this.relativeChildren)if(o.match(r))return!0;for(let o of this.absoluteChildren)if(o.match(t))return!0;return!1}};var Ad=class n{store;constructor(e=new Map){this.store=e}copy(){return new n(new Map(this.store))}hasWalked(e,t){return this.store.get(e.fullpath())?.has(t.globString())}storeWalked(e,t){let r=e.fullpath(),o=this.store.get(r);o?o.add(t.globString()):this.store.set(r,new Set([t.globString()]))}},Id=class{store=new Map;add(e,t,r){let o=(t?2:0)|(r?1:0),i=this.store.get(e);this.store.set(e,i===void 0?o:o&i)}entries(){return[...this.store.entries()].map(([e,t])=>[e,!!(t&2),!!(t&1)])}},Pd=class{store=new Map;add(e,t){if(!e.canReaddir())return;let r=this.store.get(e);r?r.find(o=>o.globString()===t.globString())||r.push(t):this.store.set(e,[t])}get(e){let t=this.store.get(e);if(!t)throw new Error("attempting to walk unknown path");return t}entries(){return this.keys().map(e=>[e,this.store.get(e)])}keys(){return[...this.store.keys()].filter(e=>e.canReaddir())}},ya=class n{hasWalkedCache;matches=new Id;subwalks=new Pd;patterns;follow;dot;opts;constructor(e,t){this.opts=e,this.follow=!!e.follow,this.dot=!!e.dot,this.hasWalkedCache=t?t.copy():new Ad}processPatterns(e,t){this.patterns=t;let r=t.map(o=>[e,o]);for(let[o,i]of r){this.hasWalkedCache.storeWalked(o,i);let a=i.root(),s=i.isAbsolute()&&this.opts.absolute!==!1;if(a){o=o.resolve(a==="/"&&this.opts.root!==void 0?this.opts.root:a);let p=i.rest();if(p)i=p;else{this.matches.add(o,!0,!1);continue}}if(o.isENOENT())continue;let l,c,d=!1;for(;typeof(l=i.pattern())=="string"&&(c=i.rest());)o=o.resolve(l),i=c,d=!0;if(l=i.pattern(),c=i.rest(),d){if(this.hasWalkedCache.hasWalked(o,i))continue;this.hasWalkedCache.storeWalked(o,i)}if(typeof l=="string"){let p=l===".."||l===""||l===".";this.matches.add(o.resolve(l),s,p);continue}else if(l===st){(!o.isSymbolicLink()||this.follow||i.checkFollowGlobstar())&&this.subwalks.add(o,i);let p=c?.pattern(),m=c?.rest();if(!c||(p===""||p===".")&&!m)this.matches.add(o,s,p===""||p===".");else if(p===".."){let u=o.parent||o;m?this.hasWalkedCache.hasWalked(u,m)||this.subwalks.add(u,m):this.matches.add(u,s,!0)}}else l instanceof RegExp&&this.subwalks.add(o,i)}return this}subwalkTargets(){return this.subwalks.keys()}child(){return new n(this.opts,this.hasWalkedCache)}filterEntries(e,t){let r=this.subwalks.get(e),o=this.child();for(let i of t)for(let a of r){let s=a.isAbsolute(),l=a.pattern(),c=a.rest();l===st?o.testGlobstar(i,a,c,s):l instanceof RegExp?o.testRegExp(i,l,c,s):o.testString(i,l,c,s)}return o}testGlobstar(e,t,r,o){if((this.dot||!e.name.startsWith("."))&&(t.hasMore()||this.matches.add(e,o,!1),e.canReaddir()&&(this.follow||!e.isSymbolicLink()?this.subwalks.add(e,t):e.isSymbolicLink()&&(r&&t.checkFollowGlobstar()?this.subwalks.add(e,r):t.markFollowGlobstar()&&this.subwalks.add(e,t)))),r){let i=r.pattern();if(typeof i=="string"&&i!==".."&&i!==""&&i!==".")this.testString(e,i,r.rest(),o);else if(i===".."){let a=e.parent||e;this.subwalks.add(a,r)}else i instanceof RegExp&&this.testRegExp(e,i,r.rest(),o)}}testRegExp(e,t,r,o){t.test(e.name)&&(r?this.subwalks.add(e,r):this.matches.add(e,o,!1))}testString(e,t,r,o){e.isNamed(t)&&(r?this.subwalks.add(e,r):this.matches.add(e,o,!1))}};var EI=(n,e)=>typeof n=="string"?new Go([n],e):Array.isArray(n)?new Go(n,e):n,Xs=class{path;patterns;opts;seen=new Set;paused=!1;aborted=!1;#e=[];#t;#i;signal;maxDepth;includeChildMatches;constructor(e,t,r){if(this.patterns=e,this.path=t,this.opts=r,this.#i=!r.posix&&r.platform==="win32"?"\\":"/",this.includeChildMatches=r.includeChildMatches!==!1,(r.ignore||!this.includeChildMatches)&&(this.#t=EI(r.ignore??[],r),!this.includeChildMatches&&typeof this.#t.add!="function")){let o="cannot ignore child matches, ignore lacks add() method.";throw new Error(o)}this.maxDepth=r.maxDepth||1/0,r.signal&&(this.signal=r.signal,this.signal.addEventListener("abort",()=>{this.#e.length=0}))}#r(e){return this.seen.has(e)||!!this.#t?.ignored?.(e)}#a(e){return!!this.#t?.childrenIgnored?.(e)}pause(){this.paused=!0}resume(){if(this.signal?.aborted)return;this.paused=!1;let e;for(;!this.paused&&(e=this.#e.shift());)e()}onResume(e){this.signal?.aborted||(this.paused?this.#e.push(e):e())}async matchCheck(e,t){if(t&&this.opts.nodir)return;let r;if(this.opts.realpath){if(r=e.realpathCached()||await e.realpath(),!r)return;e=r}let i=e.isUnknown()||this.opts.stat?await e.lstat():e;if(this.opts.follow&&this.opts.nodir&&i?.isSymbolicLink()){let a=await i.realpath();a&&(a.isUnknown()||this.opts.stat)&&await a.lstat()}return this.matchCheckTest(i,t)}matchCheckTest(e,t){return e&&(this.maxDepth===1/0||e.depth()<=this.maxDepth)&&(!t||e.canReaddir())&&(!this.opts.nodir||!e.isDirectory())&&(!this.opts.nodir||!this.opts.follow||!e.isSymbolicLink()||!e.realpathCached()?.isDirectory())&&!this.#r(e)?e:void 0}matchCheckSync(e,t){if(t&&this.opts.nodir)return;let r;if(this.opts.realpath){if(r=e.realpathCached()||e.realpathSync(),!r)return;e=r}let i=e.isUnknown()||this.opts.stat?e.lstatSync():e;if(this.opts.follow&&this.opts.nodir&&i?.isSymbolicLink()){let a=i.realpathSync();a&&(a?.isUnknown()||this.opts.stat)&&a.lstatSync()}return this.matchCheckTest(i,t)}matchFinish(e,t){if(this.#r(e))return;if(!this.includeChildMatches&&this.#t?.add){let i=`${e.relativePosix()}/**`;this.#t.add(i)}let r=this.opts.absolute===void 0?t:this.opts.absolute;this.seen.add(e);let o=this.opts.mark&&e.isDirectory()?this.#i:"";if(this.opts.withFileTypes)this.matchEmit(e);else if(r){let i=this.opts.posix?e.fullpathPosix():e.fullpath();this.matchEmit(i+o)}else{let i=this.opts.posix?e.relativePosix():e.relative(),a=this.opts.dotRelative&&!i.startsWith(".."+this.#i)?"."+this.#i:"";this.matchEmit(i?a+i+o:"."+o)}}async match(e,t,r){let o=await this.matchCheck(e,r);o&&this.matchFinish(o,t)}matchSync(e,t,r){let o=this.matchCheckSync(e,r);o&&this.matchFinish(o,t)}walkCB(e,t,r){this.signal?.aborted&&r(),this.walkCB2(e,t,new ya(this.opts),r)}walkCB2(e,t,r,o){if(this.#a(e))return o();if(this.signal?.aborted&&o(),this.paused){this.onResume(()=>this.walkCB2(e,t,r,o));return}r.processPatterns(e,t);let i=1,a=()=>{--i===0&&o()};for(let[s,l,c]of r.matches.entries())this.#r(s)||(i++,this.match(s,l,c).then(()=>a()));for(let s of r.subwalkTargets()){if(this.maxDepth!==1/0&&s.depth()>=this.maxDepth)continue;i++;let l=s.readdirCached();s.calledReaddir()?this.walkCB3(s,l,r,a):s.readdirCB((c,d)=>this.walkCB3(s,d,r,a),!0)}a()}walkCB3(e,t,r,o){r=r.filterEntries(e,t);let i=1,a=()=>{--i===0&&o()};for(let[s,l,c]of r.matches.entries())this.#r(s)||(i++,this.match(s,l,c).then(()=>a()));for(let[s,l]of r.subwalks.entries())i++,this.walkCB2(s,l,r.child(),a);a()}walkCBSync(e,t,r){this.signal?.aborted&&r(),this.walkCB2Sync(e,t,new ya(this.opts),r)}walkCB2Sync(e,t,r,o){if(this.#a(e))return o();if(this.signal?.aborted&&o(),this.paused){this.onResume(()=>this.walkCB2Sync(e,t,r,o));return}r.processPatterns(e,t);let i=1,a=()=>{--i===0&&o()};for(let[s,l,c]of r.matches.entries())this.#r(s)||this.matchSync(s,l,c);for(let s of r.subwalkTargets()){if(this.maxDepth!==1/0&&s.depth()>=this.maxDepth)continue;i++;let l=s.readdirSync();this.walkCB3Sync(s,l,r,a)}a()}walkCB3Sync(e,t,r,o){r=r.filterEntries(e,t);let i=1,a=()=>{--i===0&&o()};for(let[s,l,c]of r.matches.entries())this.#r(s)||this.matchSync(s,l,c);for(let[s,l]of r.subwalks.entries())i++,this.walkCB2Sync(s,l,r.child(),a);a()}},ba=class extends Xs{matches=new Set;constructor(e,t,r){super(e,t,r)}matchEmit(e){this.matches.add(e)}async walk(){if(this.signal?.aborted)throw this.signal.reason;return this.path.isUnknown()&&await this.path.lstat(),await new Promise((e,t)=>{this.walkCB(this.path,this.patterns,()=>{this.signal?.aborted?t(this.signal.reason):e(this.matches)})}),this.matches}walkSync(){if(this.signal?.aborted)throw this.signal.reason;return this.path.isUnknown()&&this.path.lstatSync(),this.walkCBSync(this.path,this.patterns,()=>{if(this.signal?.aborted)throw this.signal.reason}),this.matches}},wa=class extends Xs{results;constructor(e,t,r){super(e,t,r),this.results=new cr({signal:this.signal,objectMode:!0}),this.results.on("drain",()=>this.resume()),this.results.on("resume",()=>this.resume())}matchEmit(e){this.results.write(e),this.results.flowing||this.pause()}stream(){let e=this.path;return e.isUnknown()?e.lstat().then(()=>{this.walkCB(e,this.patterns,()=>this.results.end())}):this.walkCB(e,this.patterns,()=>this.results.end()),this.results}streamSync(){return this.path.isUnknown()&&this.path.lstatSync(),this.walkCBSync(this.path,this.patterns,()=>this.results.end()),this.results}};var RI=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",mn=class{absolute;cwd;root;dot;dotRelative;follow;ignore;magicalBraces;mark;matchBase;maxDepth;nobrace;nocase;nodir;noext;noglobstar;pattern;platform;realpath;scurry;stat;signal;windowsPathsNoEscape;withFileTypes;includeChildMatches;opts;patterns;constructor(e,t){if(!t)throw new TypeError("glob options required");if(this.withFileTypes=!!t.withFileTypes,this.signal=t.signal,this.follow=!!t.follow,this.dot=!!t.dot,this.dotRelative=!!t.dotRelative,this.nodir=!!t.nodir,this.mark=!!t.mark,t.cwd?(t.cwd instanceof URL||t.cwd.startsWith("file://"))&&(t.cwd=CI(t.cwd)):this.cwd="",this.cwd=t.cwd||"",this.root=t.root,this.magicalBraces=!!t.magicalBraces,this.nobrace=!!t.nobrace,this.noext=!!t.noext,this.realpath=!!t.realpath,this.absolute=t.absolute,this.includeChildMatches=t.includeChildMatches!==!1,this.noglobstar=!!t.noglobstar,this.matchBase=!!t.matchBase,this.maxDepth=typeof t.maxDepth=="number"?t.maxDepth:1/0,this.stat=!!t.stat,this.ignore=t.ignore,this.withFileTypes&&this.absolute!==void 0)throw new Error("cannot set absolute and withFileTypes:true");if(typeof e=="string"&&(e=[e]),this.windowsPathsNoEscape=!!t.windowsPathsNoEscape||t.allowWindowsEscape===!1,this.windowsPathsNoEscape&&(e=e.map(l=>l.replace(/\\/g,"/"))),this.matchBase){if(t.noglobstar)throw new TypeError("base matching requires globstar");e=e.map(l=>l.includes("/")?l:`./**/${l}`)}if(this.pattern=e,this.platform=t.platform||RI,this.opts={...t,platform:this.platform},t.scurry){if(this.scurry=t.scurry,t.nocase!==void 0&&t.nocase!==t.scurry.nocase)throw new Error("nocase option contradicts provided scurry option")}else{let l=t.platform==="win32"?Ho:t.platform==="darwin"?Sa:t.platform?jo:CS;this.scurry=new l(this.cwd,{nocase:t.nocase,fs:t.fs})}this.nocase=this.scurry.nocase;let r=this.platform==="darwin"||this.platform==="win32",o={...t,dot:this.dot,matchBase:this.matchBase,nobrace:this.nobrace,nocase:this.nocase,nocaseMagicOnly:r,nocomment:!0,noext:this.noext,nonegate:!0,optimizationLevel:2,platform:this.platform,windowsPathsNoEscape:this.windowsPathsNoEscape,debug:!!this.opts.debug},i=this.pattern.map(l=>new Ft(l,o)),[a,s]=i.reduce((l,c)=>(l[0].push(...c.set),l[1].push(...c.globParts),l),[[],[]]);this.patterns=a.map((l,c)=>{let d=s[c];if(!d)throw new Error("invalid pattern object");return new $o(l,d,0,this.platform)})}async walk(){return[...await new ba(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).walk()]}walkSync(){return[...new ba(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).walkSync()]}stream(){return new wa(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).stream()}streamSync(){return new wa(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).streamSync()}iterateSync(){return this.streamSync()[Symbol.iterator]()}[Symbol.iterator](){return this.iterateSync()}iterate(){return this.stream()[Symbol.asyncIterator]()}[Symbol.asyncIterator](){return this.iterate()}};var Ld=(n,e={})=>{Array.isArray(n)||(n=[n]);for(let t of n)if(new Ft(t,e).hasMagic())return!0;return!1};function Zs(n,e={}){return new mn(n,e).streamSync()}function IS(n,e={}){return new mn(n,e).stream()}function Wo(n,e={}){return new mn(n,e).walkSync()}async function RS(n,e={}){return new mn(n,e).walk()}function Qs(n,e={}){return new mn(n,e).iterateSync()}function PS(n,e={}){return new mn(n,e).iterate()}var AI=Zs,II=Object.assign(IS,{sync:Zs}),PI=Qs,LI=Object.assign(PS,{sync:Qs}),OI=Object.assign(Wo,{stream:Zs,iterate:Qs}),AS=Object.assign(RS,{glob:RS,globSync:Wo,sync:OI,globStream:IS,stream:II,globStreamSync:Zs,streamSync:AI,globIterate:PS,iterate:LI,globIterateSync:Qs,iterateSync:PI,Glob:mn,hasMagic:Ld,escape:Do,unescape:dn});AS.glob=AS;import qr,{dirname as MS}from"path";import{cwd as _d}from"process";import NS from"yaml";import{z as ce}from"zod";import LS from"fs";import el from"path";import kI from"yaml";import{z as Od}from"zod";var OS=!1,kd=[`**/*.${Ot.TEST}`,`**/*.${Ot.MODULE}`],Md=Od.string().refine(n=>/^[a-zA-Z0-9-]+$/.test(n)),Nd=50,MI=Od.object({fileType:Od.nativeEnum(Ee)});function Oe(n,e){let t={project:n,tests:{},modules:{}},r=n.config.include??kd,o=Array.from(n.config.exclude??[]).concat(Oh),i=Wo(r,{absolute:!1,cwd:n.rootDir,ignore:o,dotRelative:!1,maxDepth:Nd,nodir:!0});for(let a of i)NI(n.rootDir,a,t,e);return OS=!0,t}function NI(n,e,t,r){let o=el.join(n,e),i;try{i=LS.readFileSync(o,"utf-8")}catch(p){r.warn(`Could not read possible Momentic file at ${o}, skipping: ${p}`);return}let a;try{if(a=kI.parse(i),typeof a!="object"||a===null)throw new Error("The YAML document should parse as a map with key-value pairs")}catch(p){r.warn(`Could not parse possible Momentic file at ${o}, skipping: ${p}`);return}let s=MI.safeParse(a);if(s.error){r.warn(`Possible Momentic file at ${o} does not have a 'fileType', skipping: ${s.error}`);return}let l=s.data.fileType,c;try{c=LS.statSync(o)}catch(p){r.warn(`Skipping path '${o}' because it could not be stat, skipping: ${p}`);return}let d={relativePath:e,fullFilePath:o,platformSep:el.sep,fullPathSegments:o.split(el.sep),fileName:el.basename(o),lastModified:c.mtime,createdAt:c.birthtime};switch(l){case Ee.TEST:try{let p=Kt.parse(a);if(t.tests[p.id]){let m=t.tests[p.id].fullFilePath;y.error(`Two tests with the same ID (${p.id}) were found in the same project. Please ensure that all test IDs are unique and avoid copying tests manually. Momentic will ignore the first test when resolving tests.
45
45
 
46
46
  First test path: ${m}
47
47
 
48
- Second test path: ${o}`)}t.tests[p.id]={type:Ee.TEST,name:p.name,id:p.id,description:p.description??void 0,labels:p.labels,...d};return}catch(p){r.warn(`Skipping file '${o}' because it is missing Momentic test metadata: ${p}`);return}case Ee.MODULE:try{let p=Rt.parse(a);t.modules[p.moduleId]={type:Ee.MODULE,name:p.name,id:p.moduleId,description:p.description??void 0,...d};let m=d.fileName.replace(".module.yaml","");!OS&&Ne(p.name)!==m&&r.warn(`The module with ID ${p.moduleId} has a name (${p.name}) that does not match its file name (${m}). We recommend renaming the module or the file to be consistent to avoid confusion and issues with module resolution.`);return}catch(p){r.warn(`Skipping file '${o}' because it is missing Momentic module metadata: ${p}`);return}default:r.warn(`Unsupported file type ${l}, skipping...`);return}}var qo="momentic.config.yaml",kS="momentic.workspace.yaml",BI=ce.object({projects:ce.string().array().describe("list of glob patterns to find project (momentic.config.yaml) files")}),zI=ce.union([ce.string(),ce.object({fromFile:ce.string(),json:ce.boolean().optional()})]),HI=ce.object({name:Md,baseUrl:ce.string(),envFile:ce.string().optional().describe("path to a file on disk to read environment variables from. can be relative to project root or absolute."),envVariables:ce.record(ce.string(),zI).optional(),inheritFromShell:ce.boolean().optional().describe("inherit all environment variables from the shell - might be noisy"),browser:To.optional()}),jI=ce.object({postSave:ce.string().optional()}),$I=ce.object({name:Md,include:ce.string().array().optional().describe("list of glob patterns that match momentic files (optional)"),exclude:ce.string().array().optional().describe("opposite of include, takes precedence over include"),goldenFileDir:ce.string().optional(),reporterDir:ce.string().optional(),outputDir:ce.string().optional(),retries:ce.number().optional().describe("number of retries per test"),parallel:ce.number().optional().describe("degree of parallelism"),environments:ce.array(HI).optional(),gitMainBranch:ce.string().optional(),gitProtectedBranches:ce.string().array().optional(),ai:Jc.extend({aiPageFiltering:ce.boolean().optional().describe("rag v2 flag")}).optional(),browser:To.extend({autoExpandIframes:ce.boolean().optional(),disableSecondaryCacheResolution:ce.boolean().optional(),showZeroOpacityElements:ce.boolean().optional(),globalLocatorRedirect:ce.boolean().optional(),visualActions:ce.boolean().optional()}).optional(),advanced:Nh.optional(),hooks:jI.optional()});function _S(n,e){let t;try{t=DI(n,"utf-8")}catch(o){y.warn(`Could not read possible Momentic ${e} file at ${n}: ${o}`);return}let r;try{if(r=NS.parse(t),typeof r!="object"||r===null)throw new Error(`The ${e} file should parse as a map with key-value pairs, but is type ${typeof r} instead`)}catch(o){y.warn(`Possible Momentic ${e} file at ${n} does not parse as valid YAML: ${o}`);return}return r}function Dd(n){let e=_S(n,"project configuration");if(e!==void 0)try{return $I.parse(e)}catch(t){y.warn(`Possible Momentic project configuration file at ${n} does not adhere to the required schema: ${t}`);return}}function GI(n){let e=_S(n,"workspace configuration");if(e!==void 0)try{return BI.parse(e)}catch(t){y.warn(`Possible Momentic workspace configuration file at ${n} does not adhere to the required schema: ${t}`);return}}function WI(){let n=[],e=_d(),t=qr.parse(e).root,r=15,o=0;for(;o<r;){o++;let i=qr.basename(e);if(ws.includes(i))return y.warn(`Stopping search for Momentic projects since the current directory name (${i}) is likely a system artifact folder.`),n;for(let a of FI(e))if(a.endsWith(qo)){let s=qr.join(e,a),l=Dd(s);l&&n.push({configFilePath:s,config:l,rootDir:MS(s)})}if(n.length)return n;if(e=qr.dirname(e),e===t)break}return n}function Qt(n={}){let{configFilePath:e,nameFilter:t}=n,r=Fd(e);if(t&&(r=r.filter(o=>o.config.name===t)),r.length>1)throw new Error(`Multiple valid projects were found in the same directory. Please use the '-c / --config' flag to disambiguate:
49
- ${r.map(o=>o.configFilePath)}`);if(r.length===0)throw new Error("No valid Momentic project file available.");return y.debug(`Found valid project configuration at ${r[0].configFilePath}`),r[0]}function VI(n){let e=GI(n);if(!e||!e.projects||!e.projects.length)return;let t=e.projects.map(i=>(i.endsWith("/")||(i+="/"),`${i}*${qo}`)),r=Vo(t,{absolute:!1,cwd:_d(),dotRelative:!1,maxDepth:Nd,nodir:!0}),o=[];for(let i of r){let a=qr.join(_d(),i),s=Dd(a);s&&o.push({configFilePath:a,config:s,rootDir:MS(a)})}return o}function Fd(n){if(n){n=qr.resolve(n);let t=Dd(n);return t||(console.error(`No valid Momentic project file found at ${n}.`),process.exit(1)),[{config:t,configFilePath:n,rootDir:qr.dirname(n)}]}if(_I(kS)){let t=VI(kS);if(t)return t}return WI()}function Ko(n,e){let t=NS.stringify(n);UI(e,t)}import Yo from"fs";import Ud from"path";import{z as Bd}from"zod";var DS="golden/visual-diff",FS="reports",US="test-results";var qI=Bd.object({width:Bd.number(),height:Bd.number()}),Jo=class{defaultGoldenScreenshotDir;regenerateGoldenFiles;constructor(e,t){let r=Ud.join(e.rootDir,e.config.goldenFileDir??DS);this.defaultGoldenScreenshotDir=r,this.regenerateGoldenFiles=t}async prepareGoldenScreenshotForComparison(e,t,r){if(t.screenshot?.data?.startsWith("https://")){let a=await fetch(t.screenshot.data);return{buffer:Buffer.from(await a.arrayBuffer()),width:t.screenshot.width,height:t.screenshot.height}}let o=t.screenshot?.data;o||(o=Ud.join(this.defaultGoldenScreenshotDir,`${t.id}.jpg`));let i=`${o}.metadata.json`;if(this.regenerateGoldenFiles)return Yo.mkdirSync(Ud.dirname(o),{recursive:!0}),Yo.writeFileSync(o,r.buffer),Yo.writeFileSync(i,JSON.stringify({width:r.width,height:r.height})),{buffer:Buffer.from(r.buffer),width:r.width,height:r.height};if(Yo.existsSync(o)){let a=Yo.readFileSync(o),s=qI.parse(JSON.parse(Yo.readFileSync(i,"utf-8")));return{buffer:a,width:s.width,height:s.height}}else throw new R("UserConfigurationError",`Cannot execute visual diff without a saved baseline screenshot at ${o}`)}};var Xo=class{flags;constructor(e){this.flags={auto_expand_iframes:e.browser?.autoExpandIframes??!1,rag_v2:e.ai?.aiPageFiltering??!1,faker_constant_seed:e.advanced?.fakerConstantSeed??!1,disable_secondary_cache_resolution:e.browser?.disableSecondaryCacheResolution??!1,show_zero_opacity_elements:e.browser?.showZeroOpacityElements??!1,global_locator_redirect:e.browser?.globalLocatorRedirect??!1,visual_actions:e.browser?.visualActions??!1,mini_model_initial_assertion:!1,mini_model_initial_locator:!1,show_test_plans:!1,icon_knowledge_base:!1}}isBooleanFlagEnabled(e){return this.flags[e]}getAllFlags(){return{...this.flags}}getFlagPayload(e){}async refresh(){}};import KI from"simple-git";var ye=KI();function tl(n){if(n.startsWith("git@")){let e=n.split(":");if(e.length===2){let t=e[1].replace(".git","").split("/");if(t.length===2){let r=t[0],o=t[1];return`${r}/${o}`}}}else if(n.startsWith("http")||n.startsWith("https")){let t=new URL(n).pathname.split("/").filter(Boolean);if(t.length>=2){let r=t[0],o=t[1].replace(".git","");return`${r}/${o}`}}}async function be(n,e){try{return(await e).trim()}catch(t){n.error({err:t},"Failed to run git command");return}}function YI(){if(process.env.GITHUB_ACTION)return"GithubActions";if(process.env.GITLAB_CI)return"GitlabCI";if(process.env.CIRCLECI)return"CircleCI";if(process.env.BUILDKITE)return"Buildkite";if(process.env["System.CollectionUri"]?.includes("azure"))return"AzureDevOps"}async function JI(n){let[e,t,r,o]=await Promise.all([be(n,ye.show(["--no-patch","--format=%ci"])),be(n,ye.listRemote(["--get-url","origin"])),be(n,ye.show(["-s","--pretty=%B"])),be(n,ye.show(["-s","--pretty=%an"]))]);return{gitCommitSha:process.env.GITHUB_SHA,gitCommitShaShort:process.env.GITHUB_SHA?.slice(0,6),gitCommitTimestamp:e?new Date(e):void 0,gitBranchName:process.env.GITHUB_HEAD_REF||process.env.GITHUB_REF_NAME,gitOriginUrl:t,gitCommitMessage:r,gitCommitAuthorName:o,githubRepository:process.env.GITHUB_REPOSITORY,pipelineId:`${process.env.GITHUB_RUN_ID}:${process.env.GITHUB_RUN_ATTEMPT}`}}async function XI(n){let[e,t,r]=await Promise.all([be(n,ye.listRemote(["--get-url","origin"])),be(n,ye.show(["-s","--pretty=%B"])),be(n,ye.show(["-s","--pretty=%an"]))]);return{gitCommitSha:process.env.CI_COMMIT_SHA,gitCommitShaShort:process.env.CI_COMMIT_SHORT_SHA,gitCommitTimestamp:process.env.CI_COMMIT_TIMESTAMP?new Date(process.env.CI_COMMIT_TIMESTAMP):void 0,gitBranchName:process.env.CI_COMMIT_BRANCH||process.env.CI_COMMIT_REF_NAME,gitOriginUrl:e,gitCommitMessage:t,gitCommitAuthorName:r,gitlabProjectPath:process.env.CI_SERVER_HOST,pipelineId:`${process.env.CI_PIPELINE_ID}:${process.env.CI_JOB_ID}`}}async function ZI(n){let[e,t,r,o]=await Promise.all([be(n,ye.show(["--no-patch","--format=%ci"])),be(n,ye.listRemote(["--get-url","origin"])),be(n,ye.show(["-s","--pretty=%B"])),be(n,ye.show(["-s","--pretty=%an"]))]),i=t?.includes("github.com"),a=t?.includes("gitlab.com"),s=t?tl(t):void 0;return{gitCommitSha:process.env.CIRCLE_SHA1,gitCommitShaShort:process.env.CIRCLE_SHA1?.slice(0,6),gitCommitTimestamp:e?new Date(e):void 0,gitBranchName:process.env.CIRCLE_BRANCH,gitOriginUrl:process.env.CIRCLE_REPOSITORY_URL,gitCommitMessage:r,gitCommitAuthorName:o,githubRepository:i?s:void 0,gitlabProjectPath:a?s:void 0,pipelineId:`${process.env.CIRCLE_WORKFLOW_ID}:${process.env.CIRCLE_WORKFLOW_JOB_ID}`}}async function QI(n){let[e,t,r]=await Promise.all([be(n,ye.show(["--no-patch","--format=%ci"])),be(n,ye.show(["-s","--pretty=%B"])),be(n,ye.show(["-s","--pretty=%an"]))]),o=process.env.BUILDKITE_REPO,i=o?.includes("github.com"),a=o?.includes("gitlab.com"),s=o?tl(o):void 0;return{gitCommitSha:process.env.BUILDKITE_COMMIT,gitCommitShaShort:process.env.BUILDKITE_COMMIT?.slice(0,6),gitCommitTimestamp:e?new Date(e):void 0,gitBranchName:process.env.BUILDKITE_BRANCH,gitOriginUrl:o,gitCommitMessage:t,gitCommitAuthorName:r,githubRepository:i?s:void 0,gitlabProjectPath:a?s:void 0,pipelineId:`${process.env.BUILDKITE_PIPELINE_ID}:${process.env.BUILDKITE_BUILD_ID}:${process.env.BUILDKITE_JOB_ID}`}}async function eP(n){let[e,t,r]=await Promise.all([be(n,ye.show(["--no-patch","--format=%ci"])),be(n,ye.show(["-s","--pretty=%B"])),be(n,ye.show(["-s","--pretty=%an"]))]),o=process.env["Build.Repository.Uri"],i=o?.includes("github.com"),a=o?.includes("gitlab.com"),s=o?tl(o):void 0;return{gitCommitSha:process.env["Build.SourceVersion"],gitCommitShaShort:process.env["Build.SourceVersion"]?.slice(0,6),gitCommitTimestamp:e?new Date(e):void 0,gitBranchName:process.env["Build.SourceBranchName"],gitOriginUrl:o,gitCommitMessage:t,gitCommitAuthorName:r,githubRepository:i?s:void 0,gitlabProjectPath:a?s:void 0,pipelineId:`${process.env["System.JobId"]}:${process.env["System.JobAttempt"]}`}}async function tP(n,e){let[t,r,o,i,a,s,l,c]=await Promise.all([be(n,ye.revparse(["HEAD"])),be(n,ye.revparse(["--short","HEAD"])),be(n,ye.revparse(["--abbrev-ref","HEAD"])),be(n,ye.listRemote(["--get-url","origin"])),be(n,ye.show(["--no-patch","--format=%ci"])),be(n,ye.show(["-s","--pretty=%B"])),be(n,ye.show(["-s","--pretty=%an"])),e?be(n,ye.raw(["merge-base","--fork-point",e])):Promise.resolve(void 0)]),d=c?await be(n,ye.show(["--no-patch","--format=%ci",c])):void 0,p=i?.includes("github.com"),m=i?.includes("gitlab.com"),u=i?tl(i):void 0;return{gitCommitSha:t,gitCommitShaShort:r,gitBranchName:o,gitOriginUrl:i,gitCommitTimestamp:a?new Date(a):void 0,gitCommitMessage:s,gitCommitAuthorName:l,lastCommitOnMainSha:c,lastCommitOnMainTimestamp:d?new Date(d):void 0,githubRepository:p?u:void 0,gitlabProjectPath:m?u:void 0,pipelineId:void 0}}async function nP(n){let e=n.config.gitProtectedBranches??[];return n.config.gitMainBranch&&e.push(n.config.gitMainBranch),{gitMainBranch:n.config.gitMainBranch,gitProtectedBranches:e}}async function rP(n,e){let t=YI();if(!t)return tP(n,e);switch(t){case"GithubActions":return JI(n);case"GitlabCI":return XI(n);case"CircleCI":return ZI(n);case"Buildkite":return QI(n);case"AzureDevOps":return eP(n)}}async function oP(n,e,t){if(t.lastCommitOnMainSha&&t.lastCommitOnMainTimestamp)return{};if(t.gitlabProjectPath){if(!t.gitMainBranch||!t.gitCommitSha)return{};try{let r=await e.getMergeBaseCommitFromGitlab(t.gitlabProjectPath,t.gitMainBranch,t.gitCommitSha);return{lastCommitOnMainSha:r.sha,lastCommitOnMainTimestamp:r.committer.date}}catch(r){return n.warn({err:r},"Failed to get remote metadata from Gitlab"),{}}}if(t.githubRepository){if(!t.gitMainBranch||!t.gitCommitSha)return{};try{let[r,o]=t.githubRepository.split("/"),i=await e.getMergeBaseCommitFromGithub(r,o,t.gitMainBranch,t.gitCommitSha);return{lastCommitOnMainSha:i.sha,lastCommitOnMainTimestamp:i.committer.date}}catch(r){return n.warn({err:r},"Failed to get remote metadata from Github"),{}}}return{}}async function Zo(n,e,t){let r=await nP(t),o=await rP(n,r.gitMainBranch),i={...r,...o},a=await oP(n,e,i);return{...r,...o,...a}}import cM from"http";import{z as Hd}from"zod";var M="v1",va="2.0.1";var iP=9e4,aP=15e3,hn=class extends Error{status;rawError;constructor(e,t,r,o={}){super(r,o),this.status=e,this.rawError=t}};async function sP(n){return n.text().then(e=>{try{return JSON.parse(e).error}catch{return e}})}var zd=class{baseUrl;logger;constructor(e){this.baseUrl=e.baseUrl,this.logger=e.logger}getHeaders(){let e={"Content-Type":"application/json"};return va&&(e[_h]=va),e}async sendRequest(e,t,r=3,o=iP){let i=r,a,s={path:e,baseUrl:this.baseUrl,method:t.method};for(;r>0;)try{return r--,await this.sendSingleRequestHelper(e,t,o)}catch(l){if(a=l,l instanceof hn&&l.status>=400&&l.status<500||r===0)throw l;let c=1500,d=i-r,p=Math.min(c*Math.pow(2,d-1),aP);await new Promise(m=>setTimeout(m,p))}throw this.logger.warn({...s,err:a},"Got fatal error response from Momentic server"),a}async sendSingleRequestHelper(e,t,r){let o={path:e,baseUrl:this.baseUrl,method:t.method},i=new AbortController,a=setTimeout(()=>i.abort(),r),s=()=>i.abort();t.signal&&t.signal.addEventListener("abort",s);let l={...this.getHeaders(),...t.extraHeaders};try{let c=await fetch(`${this.baseUrl}${e}`,{method:t.method,body:t.body?JSON.stringify(t.body):void 0,headers:l,signal:i.signal});if(!c.ok){let p=await sP(c);throw new hn(c.status,p,`Request to ${e} failed with status ${c.status}: ${p}`)}let d;if(c.status===204)d={};else{let p=await c.text();try{d=JSON.parse(p)}catch{d=p}}return this.logger&&!t.noLog&&d&&this.logger.debug({result:d,status:c.status,...o},"Got response from Momentic server"),d}finally{clearTimeout(a),t.signal&&t.signal.removeEventListener("abort",s)}}},kt=class extends zd{apiKey;constructor(e){super(e),this.apiKey=e.apiKey}getHeaders(){return{...super.getHeaders(),Authorization:`Bearer ${this.apiKey}`}}};var lt=class extends kt{constructor(e){super(e)}getAppUrl(){return this.baseUrl.replace(/\/\/api/,"//app")}async getAuthInfo(){let e=await this.sendRequest(`/${M}/auth/check`,{method:"GET",noLog:!0},10,5e3),{orgId:t,userId:r}=ag.parse(e);return{orgId:t,userId:r}}async bulkGetRunStatus(e){let t=await this.sendRequest(`/${M}/runs/status`,{method:"POST",body:e,noLog:!0},3,1e4);return tg.parse(t)}async createRunGroup(e){let t=await this.sendRequest(`/${M}/run-groups`,{method:"POST",body:e,noLog:!0},10,5e3);return Xh.parse(t)}async updateRunGroup(e,t){await this.sendRequest(`/${M}/run-groups/${e}`,{method:"PATCH",body:t,noLog:!0},5,5e3)}async createRun(e){let t=await this.sendRequest(`/${M}/runs`,{method:"POST",body:e,noLog:!0},10,5e3);return eg.parse(t)}async updateRun(e,t){await this.sendRequest(`/${M}/runs/${e}`,{method:"PATCH",body:t,noLog:!0},3,5e3)}async createRunAttempt(e){let t=await this.sendRequest(`/${M}/runs/${e}/attempts`,{method:"POST",noLog:!0},10,5e3);return rg.parse(t)}async updateRunAttempt(e,t,r){await this.sendRequest(`/${M}/runs/${e}/attempts/${t}`,{method:"PATCH",body:r,noLog:!0},3,5e3)}async getTest(e){let t=await this.sendRequest(`/${M}/tests/${e}`,{method:"GET"},3,5e3);return Vh.parse(t)}async getAllTestIds(){let e=await this.sendRequest(`/${M}/tests`,{method:"GET"},3,5e3);return qh.parse(e)}async getTestYAMLExport(e){let t=await this.sendRequest(`/${M}/tests/export`,{method:"POST",body:e},3,5e3);return Kh.parse(t)}async updateTestWithYAML(e){await this.sendRequest(`/${M}/tests/update`,{method:"POST",body:e},3,5e3)}async updateStepCaches(e,t){await this.sendRequest(`/${M}/cache`,{method:"PATCH",body:e,extraHeaders:t},3,1e4)}async getStepCacheForTest(e,t){let r=await this.sendRequest(`/${M}/cache`,{method:"POST",body:e,extraHeaders:t},10,1e4);return Yh.parse(r)}async queueTests(e){let t=await this.sendRequest(`/${M}/tests/queue`,{method:"POST",body:e},3,1e4);return Wh.parse(t)}async uploadScreenshot(e){let t=await this.sendRequest(`/${M}/screenshots`,{method:"POST",body:e,noLog:!0},3,5e3);return ig.parse(t)}async getAllEnvironments(){let e=await this.sendRequest(`/${M}/environments`,{method:"GET"},3,5e3);return sg.parse(e)}async getEnvironment(e){let t=await this.sendRequest(`/${M}/environments/${e}`,{method:"GET"},3,5e3);return Xa.parse(t)}async getAllFeatureFlags(){let e=await this.sendRequest(`/${M}/auth/flags`,{method:"GET",noLog:!0},10,1e4);return lg.parse(e)}async acquireCacheLock(e,t){let r=await this.sendRequest(`/${M}/result-cache/lock`,{method:"POST",body:e,signal:t},3,3e4);return fg.parse(r)}async releaseCacheLock(e){await this.sendRequest(`/${M}/result-cache/lock`,{method:"DELETE",body:{key:e}},3,5e3)}async deleteCacheResult(e){await this.sendRequest(`/${M}/result-cache/entry`,{method:"DELETE",body:e},3,5e3)}async setCacheResult(e){await this.sendRequest(`/${M}/result-cache/entry`,{method:"PATCH",body:e},3,5e3)}async getCacheResult(e){try{return await this.sendRequest(`/${M}/result-cache/entry`,{method:"POST",body:e},3,5e3)}catch(t){if(t instanceof Error&&t.message.includes("404"))return null;throw t}}async queueSuiteRuns(e){let t=await this.sendRequest(`/${M}/suites/queue`,{method:"POST",body:e},3,5e3);return cg.parse(t)}async bulkGetSuiteStatus(e){let t={suiteRunIds:e},r=await this.sendRequest(`/${M}/suites/status`,{method:"POST",body:t,noLog:!0},3,5e3);return dg.parse(r)}async bulkGetRunGroupStatus(e){let t={runGroupIds:e},r=await this.sendRequest(`/${M}/run-groups/status`,{method:"POST",body:t,noLog:!0},3,5e3);return Bm.array().parse(r)}async updateCacheLastUsedDate(e,t,r,o){try{await this.sendRequest(`/${M}/cache/last-used-at`,{method:"PATCH",body:{uniqueKeys:t,testId:e},noLog:!0,extraHeaders:o},3,5e3)}catch(i){r.error({err:i},"Failed to update cache last used date")}}async uploadProposedSteps(e,t){try{await this.sendRequest(`/${M}/test-fragments/`,{method:"POST",body:e},3,1e4)}catch(r){t.error({err:r},"Failed to upload proposed steps")}}async uploadSnapshotScreenshot(e,t,r){try{await this.sendRequest(`/${M}/snapshots/${t}/screenshot`,{method:"POST",body:r,noLog:!0},3,1e4)}catch(o){e.error({err:o},"Failed to upload screenshot")}}async generateConsoleLogsForRunAttemptUploadUrl(e,t,r){let o=await this.sendRequest(`/${M}/runs/${t}/attempts/${r}/console-logs`,{method:"POST",noLog:!0},3,5e3);return Oo.parse(o)}async generateNetworkLogsForRunAttemptUploadUrl(e,t,r){let o=await this.sendRequest(`/${M}/runs/${t}/attempts/${r}/network-logs`,{method:"POST",noLog:!0},3,1e4);return Oo.parse(o)}async generateHtmlSnapshotUploadUrl(e,t){let r=await this.sendRequest(`/${M}/snapshots/${t}/html`,{method:"POST",noLog:!0},3,1e4);return Oo.parse(r)}async generateA11yTreeSnapshotUploadUrl(e,t){let r=await this.sendRequest(`/${M}/snapshots/${t}/a11y`,{method:"POST",noLog:!0},3,1e4);return Oo.parse(r)}async reportBillableEvents(e,t){try{await this.sendRequest(`/${M}/billing/events`,{method:"POST",body:t,noLog:!0},10,5e3)}catch(r){e.error({err:r},"Failed to report billable event")}}async fetchTestFragment(e){let t=await this.sendRequest(`/${M}/test-fragments/${e}`,{method:"GET",noLog:!0});return pg.parse(t)}async patchTestFragment(e,t){await this.sendRequest(`/${M}/test-fragments/${e}`,{method:"PATCH",body:t},3,5e3)}async getPastTestResults(e,t){let r=await this.sendRequest(`/${M}/results/tests/${e}`,{method:"POST",body:t},3,1e4);return ug.parse(r)}async generateTestResultsUploadUrl(){let e=await this.sendRequest(`/${M}/results/uploads`,{method:"POST",noLog:!0},3,1e4);return mg.parse(e)}async startProcessingResultsUpload(e){let t=await this.sendRequest(`/${M}/results/uploads/${e}/process`,{method:"POST",noLog:!0},3,1e4);return hg.parse(t)}async fetchIconKnowledgeBase(e,t){try{let r=await this.sendRequest(`/${M}/knowledge-base/icons`,{method:"GET",noLog:!0},3,5e3);return Tg.parse(r)}catch(r){return t.error({err:r},"Failed to fetch icon knowledge base"),null}}async saveNewIcons(e,t){try{await this.sendRequest(`/${M}/knowledge-base/icons`,{method:"POST",body:e,noLog:!0},3,5e3)}catch(r){t.error({err:r},"Failed to save new icons to icon knowledge base")}}async getMergeBaseCommitFromGithub(e,t,r,o){let i=new URLSearchParams;i.set("base",r),i.set("head",o);let a=await this.sendRequest(`/${M}/git/github/${e}/${t}/merge-base-commit?${i.toString()}`,{method:"GET",noLog:!0},3,1e4);return Qc.parse(a)}async getMergeBaseCommitFromGitlab(e,t,r){let o=new URLSearchParams;o.set("base",t),o.set("head",r);let i=await this.sendRequest(`/${M}/git/gitlab/${e}/merge-base-commit?${o.toString()}`,{method:"GET",noLog:!0},3,5e3);return Qc.parse(i)}async getAgentConfig(){let e=await this.sendRequest(`/${M}/web-agent/agent-config`,{method:"GET",noLog:!0},3,5e3);return Hd.record(Hd.string(),Hd.string()).parse(e)}};import{randomUUID as BS}from"crypto";var nl=class{apiClient;constructor(e){this.apiClient=e}async reportBillableEvent(e,t,r){try{return await this.apiClient.reportBillableEvents(e,[{event:t,timestamp:new Date().toISOString(),transactionId:r?.eventId??BS(),properties:jc({},r)}])}catch(o){e.error({err:o},"Failed to report billable event")}}async reportCreditsUsed(e,t,r,o){if(r)try{return await this.apiClient.reportBillableEvents(e,[{event:"credits-used",timestamp:new Date().toISOString(),transactionId:o?.eventId??BS(),properties:jc({creditsUsed:r,usedBy:t},o)}])}catch(i){e.error({err:i},"Failed to report credits used")}}};function Qo(n,e,t){return fetch(n,{method:"PUT",body:t,headers:{"Content-Type":e}})}var rl=class{constructor(e){this.client=e}async storeConsoleLogsForRunAttempt(e,t,r,o){try{let i=JSON.stringify(o),{uploadUrl:a}=await this.client.generateConsoleLogsForRunAttemptUploadUrl(e,t,r),s=await Qo(a,"application/json",i);if(!s.ok)throw new Error(`Failed to upload network logs: ${s.statusText}`)}catch(i){e.error({err:i},"Failed to upload console logs")}}async storeNetworkLogsForRunAttempt(e,t,r,o){let i=JSON.stringify(o);try{let{uploadUrl:a}=await this.client.generateNetworkLogsForRunAttemptUploadUrl(e,t,r),s=await Qo(a,"application/json",i);if(!s.ok)throw new Error(`Failed to upload network logs: ${s.statusText}`)}catch(a){e.error({err:a},"Failed to upload network logs")}}async storeHtmlSnapshot(e,t,r){try{let{uploadUrl:o}=await this.client.generateHtmlSnapshotUploadUrl(e,t),i=await Qo(o,"text/html",r);if(!i.ok)throw new Error(`Failed to upload network logs: ${i.statusText}`)}catch(o){e.error({err:o},"Failed to upload html snapshot")}}async storeScreenshot(e,t,r){try{await this.client.uploadSnapshotScreenshot(e,t,{screenshot:r.toString("base64")})}catch(o){e.error({err:o},"Failed to upload screenshot")}}async storeA11yTreeSnapshot(e,t,r){return Promise.resolve()}async getConsoleLogsForRunAttempt(e,t,r){}async getNetworkLogsForRunAttempt(e,t,r){}async getHtmlSnapshot(e,t){}async getA11yTreeSnapshot(e,t){}async getScreenshot(e,t){}};var ei=class{constructor(e,t){this.client=e;this.orgId=t}async acquireCacheLock(e,t){return this.client.acquireCacheLock(e,t)}async uploadScreenshot(e){return(await this.client.uploadScreenshot({screenshot:e.toString("base64")})).key}async releaseCacheLock(e){return this.client.releaseCacheLock(e)}async deleteCacheResult(e){return this.client.deleteCacheResult(e)}async setCacheResult(e){return this.client.setCacheResult(e)}async getCacheResult(e){return this.client.getCacheResult(e)}fetchIconKnowledgeBase(e,t){return this.client.fetchIconKnowledgeBase(e,t)}saveNewIcons(e,t,r){return this.client.saveNewIcons(t,r)}};import{Faker as lP,en as cP}from"@faker-js/faker";var ti="v1",dr=class{httpClient;fakerInstance;type="API_CLIENT";sms={send:this.sendSms.bind(this),fetchLatest:this.fetchLatestSms.bind(this)};email={send:this.sendEmail.bind(this),fetchLatest:this.fetchLatestEmail.bind(this),fetchAll:this.fetchAllEmails.bind(this)};ai={generate:this.sendAiGenerate.bind(this)};constructor(e){this.httpClient=e.httpClient,e.fakerSeed&&(this.fakerInstance=new lP({locale:cP}),this.fakerInstance.seed(e.fakerSeed))}async sendAiGenerate(e){let t=typeof e=="string"?{input:e}:e;return this.httpClient.sendRequest(`/${ti}/tools/ai/generate`,{method:"POST",body:t}).catch(r=>{throw r instanceof hn?new Error(r.rawError):new Error(`Failed to send AI generation: ${r.message}`)})}async sendSms(e){return this.httpClient.sendRequest(`/${ti}/tools/sms/send`,{method:"POST",body:e}).then(()=>{}).catch(t=>{throw t instanceof hn?new Error(t.rawError):new Error(`Failed to send sms: ${t.message}`)})}async fetchLatestSms(e){return this.httpClient.sendRequest(`/${ti}/tools/sms/fetchLatest`,{method:"POST",body:e}).catch(t=>{throw t instanceof hn?new Error(t.rawError):t})}async sendEmail(e){return this.httpClient.sendRequest(`/${ti}/tools/email/send`,{method:"POST",body:e}).then(()=>{}).catch(t=>{throw t instanceof hn?new Error(t.rawError):new Error(`Failed to send email: ${t.message}`)})}async fetchAllEmails(e){return this.httpClient.sendRequest(`/${ti}/tools/email/fetchAll`,{method:"POST",body:e}).catch(t=>{throw t instanceof hn?new Error(t.rawError):new Error(`Failed to fetch all emails: ${t.message}`)})}async fetchLatestEmail(e){return this.httpClient.sendRequest(`/${ti}/tools/email/fetchLatest`,{method:"POST",body:e}).catch(t=>{throw t instanceof hn?new Error(t.rawError):new Error(`Failed to fetch latest emails: ${t.message}`)})}};import{z as dP}from"zod";var ni=class extends kt{agentConfig;constructor(e,t){super(t),this.agentConfig=e}async rankChunksWithAi(e,t){let r={...e,loggerTags:t.loggerTags},o=await this.sendRequest(`/${M}/web-agent/recommend-chunks-ai`,{method:"POST",body:r,signal:t.abortSignal});return eh.parse(o)}async rankChunksWithRag(e,t){let r=await this.sendRequest(`/${M}/web-agent/recommend-chunks`,{method:"POST",body:{cliVersion:va,...e},signal:t.abortSignal});return Qm.parse(r)}async getScreenshotFromS3(e){let t=await this.sendRequest(`/${M}/s3/visual-diff-screenshot`,{method:"POST",body:{url:e}});return dP.string().parse(t)}async getElementLocation(e,t){let r={...e,disableCache:t.disableCache,loggerTags:t.loggerTags,agentConfigVersion:this.agentConfig?.locator},o=await this.sendRequest(`/${M}/web-agent/locate-element`,{method:"POST",body:r,signal:t.abortSignal});return $h.parse(o)}async getAssertionResult(e,t){let r={...e,disableCache:!!t.disableCache,useConsensus:!!t.useConsensus,attemptNumber:t.attemptNumber,loggerTags:t.loggerTags,agentConfigVersion:this.agentConfig?.locator},o=await this.sendRequest(`/${M}/web-agent/assertion`,{method:"POST",body:r,signal:t.abortSignal});return Xc.parse(o)}async getLintStepResult(e,t){let r={...e,disableCache:!!t.disableCache,loggerTags:t.loggerTags},o=await this.sendRequest(`/${M}/web-agent/lint/step`,{method:"POST",body:r,signal:t.abortSignal});return jh.parse(o)}async getVisualAssertionResult(e,t){let r={...e,disableCache:!!t.disableCache,useConsensus:!!t.useConsensus,loggerTags:t.loggerTags},o=await this.sendRequest(`/${M}/web-agent/visual-assertion`,{method:"POST",body:r,signal:t.abortSignal});return Xc.parse(o)}async getAiActionCommand(e,t){let r=await this.sendRequest(`/${M}/web-agent/next-command-dynamic`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Hh.parse(r)}async getMultiturnAiActionCommand(e,t){return await this.sendRequest(`/${M}/web-agent/ai-action/next-command`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal})}async getMultiturnAiActionEvaluation(e,t){let r=await this.sendRequest(`/${M}/web-agent/ai-action/evaluate`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Sc.parse(r)}async getReverseMappedDescription(e,t){let r=await this.sendRequest(`/${M}/web-agent/reverse-mapped-description`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Gh.parse(r)}async getTextExtraction(e,t){let r={...e,disableCache:t.disableCache,loggerTags:t.loggerTags},o=await this.sendRequest(`/${M}/web-agent/text-extraction`,{method:"POST",body:r,signal:t.abortSignal});return fc.parse(o)}async getTestResultClassification(e,t){let r=await this.sendRequest(`/${M}/web-agent/result-classification`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return Ic.parse(r)}async getExtractedKeywords(e,t){let r=await this.sendRequest(`/${M}/web-agent/extract-keywords`,{method:"POST",body:{goal:e,disableCache:t.disableCache,context:e},signal:t.abortSignal});return Zm.parse(r)}async getAutohealingProposal(e,t){let r=await this.sendRequest(`/${M}/web-agent/autoheal-section`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return ju.parse(r)}async getFailureRecoveryProposal(e,t){let r=await this.sendRequest(`/${M}/web-agent/failure-recovery`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return $u.parse(r)}async getIframeRegex(e,t){let r=await this.sendRequest(`/${M}/web-agent/iframe-regex`,{method:"POST",body:e,signal:t.abortSignal});return xu.parse(r)}};var ri=class extends kt{generator;constructor(e,t){super(e),this.generator=t}async runTemplateMatching(e,t={}){let r=await this.sendRequest(`/${M}/web-agent/template-matching`,{method:"POST",body:e,signal:t?.signal});return Eu.parse(r)}async constructIframeRegex(e,t={}){return this.generator.getIframeRegex(e,{abortSignal:t.signal})}};var ol=class{constructor(e){this.client=e}async uploadResultsArchive(e){let{uploadUrl:t,id:r}=await this.client.generateTestResultsUploadUrl(),o=await Qo(t,"application/zip",e);if(!o.ok)throw new Error(`Failed to upload test results: ${await o.text()}`);let{runGroupId:i}=await this.client.startProcessingResultsUpload(r);return i}};function oi({client:n,gitMetadata:e,alwaysSaveCache:t,noCache:r}){return r?new Ts:new jd(n,e,t)}var jd=class{constructor(e,{gitMainBranch:t,gitBranchName:r,gitProtectedBranches:o,gitCommitTimestamp:i,lastCommitOnMainSha:a,lastCommitOnMainTimestamp:s},l){this.client=e;this.cacheHeaders={},t&&(this.cacheHeaders[Dh]=t),r&&(this.cacheHeaders[Fh]=r),i&&(this.cacheHeaders[Uh]=i.toISOString()),a&&(this.cacheHeaders[Bh]=a),s&&(this.cacheHeaders[zh]=s.toISOString()),l?this.writeCaches=!0:r?this.writeCaches=!o.includes(r):this.writeCaches=!0}cacheHeaders;writeCaches;async saveStepCacheEntries(e,t,r){if(!this.writeCaches){r.debug("Skipping cache storage because branch is protected");return}try{await this.client.updateStepCaches({entries:e,testId:t},this.cacheHeaders)}catch(o){r.error({err:o},"Failed to save step cache entries")}}async resolveStepCacheEntries(e){let t=await this.client.getStepCacheForTest({testId:e.testId,organizationId:e.organizationId,steps:e.steps,schemaVersion:e.schemaVersion},this.cacheHeaders);if(!this.writeCaches){e.logger.debug("Skipping cache last used at update because branch is protected");return}let{uniqueKeysHit:r}=ko({steps:e.steps,stepCacheEntries:t,logger:e.logger});this.client.updateCacheLastUsedDate(e.testId,r,e.logger,this.cacheHeaders)}};import{Server as Bk}from"socket.io";import{cloneDeep as pP}from"lodash-es";var uP={showOverlay:!1},$d=class{sessions=new Map;sessionCountByIp=new Map;getCurrentConnectionsByIp(e){return this.sessionCountByIp.get(e)??0}getCurrentSessionsByIp(){return Object.fromEntries(this.sessionCountByIp)}reserveCapacityByIp(e){e&&this.sessionCountByIp.set(e,(this.sessionCountByIp.get(e)??0)+1)}releaseCapacityByIp(e){e&&this.sessionCountByIp.set(e,Math.max(this.getCurrentConnectionsByIp(e)-1,0))}registerSession({controller:e,context:t,cleanup:r,clientIp:o,sessionId:i,browserbaseSessionId:a}){return this.sessions.set(i,{controller:e,context:t,cleanup:r,clientIp:o,browserbaseSessionId:a,browserBehavior:pP(uP)}),i}removeSession(e,t){(async()=>{let o=this.sessions.get(e);if(!o)return;this.releaseCapacityByIp(o.clientIp);let{controller:i}=o;try{i.setClosed(),await i.browser.cleanup()}catch(a){t.error({err:a},"Error cleaning up browser in global state manager")}try{await o.cleanup?.()}catch(a){t.error({err:a},"Error running cleanup function in global state manager")}this.sessions.delete(e)})()}getSession(e){return this.sessions.get(e)}},Q=new $d;function zS(n,e,t){let r=Date.now(),o=Date.now(),i,a,s,l,c=!1,d=async(h,g)=>{if(!h.closed&&!h.isInPageLoad)try{let f=s;s=void 0;let S=h.url(),b=g.toEditorDisplayCopy();JSON.stringify(b)===JSON.stringify(i)&&S===l&&r>o||(n.emit("browserState",{logsPerPage:f?.logsPerPage,harPages:f?.harPages,harEntries:f?.harEntries,viewport:h.getViewport(),url:S,iframeSrcUrls:a??[],context:b,isInPageLoad:h.isInPageLoad}),r=Date.now()),l=S,i=b}catch(f){if(!n.connected)return;let S=f instanceof Error?f.message:`${f}`;if(S.includes("Frame was detached")||S.includes("Not attached to an active page")||S.includes("browser has been closed")||S.includes("UserInfrastructureError"))return;t.error({err:f,sessionId:e},"Error grabbing browser state")}},p=setInterval(()=>{let h=Q.getSession(e),g=h?.controller?.browser;if(!g||g.closed){t.debug("Clearing browser state socket cron due to the browser being closed"),clearInterval(p);return}d(g,h.context)},1e3),m=(h,g)=>!!(JSON.stringify(h)!==JSON.stringify(a)||g.logsPerPage.some(f=>f.length>0)||g.harPages&&Object.keys(g.harPages).length>0||g.harEntries&&Object.keys(g.harEntries).length>0),u=setInterval(async()=>{let g=Q.getSession(e)?.controller?.browser;if(!g||g.closed){clearInterval(u);return}else if(c)return;c=!0;try{let f=await g.getAllFrameUrls(),S=g.retrieveAndClearDebugData();m(f,S)&&(a=f,s=S,o=Date.now())}catch(f){t.warn({err:f},"Failed to fetch extended details")}finally{c=!1}},2500);return{timers:[p,u]}}var pr={};var mP=n=>()=>{let{sessionId:e}=n.metadata;pr[e]?.abort?.abort()},HS={event:"cancelApiTest",createHandler:mP};import{CookieJar as OP}from"tough-cookie";import{randomUUID as vP}from"crypto";import{faker as hP}from"@faker-js/faker";import gP from"assert";import fP from"axios";import SP from"moment";import*as yP from"otpauth";import bP from"pg";var ii=class extends Error{constructor(e){super(e),this.name="TimeoutError"}};var jS=n=>{let e=n.reason===void 0?new DOMException("This operation was aborted.","AbortError"):n.reason;return e instanceof Error?e:new DOMException(e,"AbortError")};async function D(n,e){let{milliseconds:t,fallback:r,message:o,customTimers:i={setTimeout,clearTimeout}}=e,a,s;return new Promise((l,c)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(e.signal){let{signal:p}=e;p.aborted&&c(jS(p)),s=()=>{c(jS(p))},p.addEventListener("abort",s)}if(t===Number.POSITIVE_INFINITY){n.then(l,c);return}let d=new ii;a=i.setTimeout.call(void 0,()=>{if(r){try{l(r())}catch(p){c(p)}return}"cancel"in n&&typeof n.cancel=="function"&&n.cancel(),o instanceof Error?c(o):(d.message=o??`Promise timed out after ${t} milliseconds`,c(d))},t),(async()=>{try{l(await n)}catch(p){c(p)}})()}).catch(l=>{throw l}).finally(()=>{a!==void 0&&i.clearTimeout.call(void 0,a),s!==void 0&&e.signal&&e.signal.removeEventListener("abort",s)})}async function $S(n){let e;try{e=new URL(n.url).hostname}catch{}let t=[];return n.headers.getSetCookie()?.forEach(r=>{let o=gs(r,e);t.push(...o)}),t}var wP=Object.getPrototypeOf(async function(){}).constructor;async function GS(n,e,t){let r=e.code;e.options.fragment&&(r=`return ${e.code}`);let{env:o}=e.bindings,i=e.tools,a={},s=(f,S)=>{o[f]=S,a[f]=S},l={},c=(f,S)=>{o[f]=S,l[f]=S},d;r.includes("Octokit")&&(d=(await import("@octokit/rest")).Octokit);let p;r.includes("createAppAuth")&&(p=(await import("@octokit/auth-app")).createAppAuth);let m=async()=>await Promise.resolve(new wP("axios","moment","faker","assert","pg","Octokit","createAppAuth","OTPAuth","extractCookiesFromResponse","env","setVariable","setPersistentVariable","sendSms","waitForLatestSms","email","sms","ai",r)(fP,SP,i.fakerInstance??hP,gP,bP,d,p,yP,$S,o,s,c,S=>i.sms.send(S),S=>i.sms.fetchLatest(S),i.email,i.sms,i.ai)),u=!0,h,g;try{h=await D(m(),{milliseconds:e.options.timeoutMs,message:`Timeout of ${e.options.timeoutMs}ms exceeded for code execution`,signal:e.signal})}catch(f){t.error({err:f,env:o,evalCode:r},`[${n}] Error executing code: ${f}`),u=!1,f instanceof ii?g=`Timeout of ${e.options.timeoutMs}ms exceeded for code execution`:g=f instanceof Error?f.message:`${f}`}return{result:h,variableUpdates:a,persistentVariableUpdates:l,success:u,error:g}}async function WS({code:n,fragment:e,context:t,localTools:r,logger:o,signal:i,timeoutMs:a=tr}){let s=vP(),l=await GS(s,{code:n,options:{fragment:e,timeoutMs:a},bindings:t.toObjectCopy(),tools:r,signal:i},o);return y.debug(`[${s}] Got execution result: ${JSON.stringify(l)}`),l}import{createHmac as TP,randomUUID as xP}from"crypto";import EP from"fetch-retry";var CP=EP(global.fetch,{retries:3,retryOn:function(n,e,t){return!!(e!==null||t&&t.status>=500)},retryDelay:function(n){return Math.pow(2,n)*500}}),VS=process.env.GCP_JS_EVAL_FUNCTION_ENDPOINT,qS=process.env.MOMENTIC_LAMBDA_AUTH_SECRET;async function KS({orgId:n,code:e,fragment:t,context:r,timeoutMs:o=tr,retries:i=2,signal:a,logger:s}){if(!VS)throw new Error("GCP_JS_EVAL_FUNCTION_ENDPOINT environment variable not set");let l,c,d=0;if(!qS)throw new Error("Missing lambda auth secret.");let p=TP("sha256",qS).update(n).digest("hex");for(;d<=i;){d++,a?.throwIfAborted();let u={id:xP(),orgId:n,momenticLambdaAuthHash:p,code:e,fragment:t,state:r.toObjectCopy(),timeoutMs:o};try{if(l=await D(CP(VS,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(u)}),{milliseconds:o,message:`Timeout of ${o}ms exceeded for code execution`,signal:a}),!l)throw new Error("Got empty response from code evaluation server");if(!l.ok)throw new Error(`Code evaluation server returned error code ${l.status}`);c=void 0;break}catch(h){c=h}}if(c)throw s.error({err:c},"Failed to evaluate code remotely"),c;if(!l)throw new Error(`An unexpected code evaluation error occurred${c?`: ${c}`:""}`);let m;try{m=lh.parse(await l.json())}catch(u){throw new Error(`Code evaluation server returned invalid response: ${u}`)}if(m.error)throw new Error(`Code evaluation error: ${m.error}`);return m}async function jn(n){let e;if(process.env.GCP_JS_EVAL_FUNCTION_ENDPOINT)e=await KS(n);else if(n.localTools)e=await WS({...n,localTools:n.localTools});else throw new Error("No code evaluation environment available");if(e.error){let t=`Failed to evaluate code:
48
+ Second test path: ${o}`)}t.tests[p.id]={type:Ee.TEST,name:p.name,id:p.id,description:p.description??void 0,labels:p.labels,...d};return}catch(p){r.warn(`Skipping file '${o}' because it is missing Momentic test metadata: ${p}`);return}case Ee.MODULE:try{let p=Rt.parse(a);t.modules[p.moduleId]={type:Ee.MODULE,name:p.name,id:p.moduleId,description:p.description??void 0,...d};let m=d.fileName.replace(".module.yaml","");!OS&&Ne(p.name)!==m&&r.warn(`The module with ID ${p.moduleId} has a name (${p.name}) that does not match its file name (${m}). We recommend renaming the module or the file to be consistent to avoid confusion and issues with module resolution.`);return}catch(p){r.warn(`Skipping file '${o}' because it is missing Momentic module metadata: ${p}`);return}default:r.warn(`Unsupported file type ${l}, skipping...`);return}}var Vo="momentic.config.yaml",kS="momentic.workspace.yaml",BI=ce.object({projects:ce.string().array().describe("list of glob patterns to find project (momentic.config.yaml) files")}),zI=ce.union([ce.string(),ce.object({fromFile:ce.string(),json:ce.boolean().optional()})]),HI=ce.object({name:Md,baseUrl:ce.string(),envFile:ce.string().optional().describe("path to a file on disk to read environment variables from. can be relative to project root or absolute."),envVariables:ce.record(ce.string(),zI).optional(),inheritFromShell:ce.boolean().optional().describe("inherit all environment variables from the shell - might be noisy"),browser:vo.optional()}),jI=ce.object({postSave:ce.string().optional()}),$I=ce.object({name:Md,include:ce.string().array().optional().describe("list of glob patterns that match momentic files (optional)"),exclude:ce.string().array().optional().describe("opposite of include, takes precedence over include"),goldenFileDir:ce.string().optional(),reporterDir:ce.string().optional(),outputDir:ce.string().optional(),retries:ce.number().optional().describe("number of retries per test"),parallel:ce.number().optional().describe("degree of parallelism"),environments:ce.array(HI).optional(),gitMainBranch:ce.string().optional(),gitProtectedBranches:ce.string().array().optional(),ai:Jc.extend({aiPageFiltering:ce.boolean().optional().describe("rag v2 flag")}).optional(),browser:vo.extend({autoExpandIframes:ce.boolean().optional(),disableSecondaryCacheResolution:ce.boolean().optional(),showZeroOpacityElements:ce.boolean().optional(),globalLocatorRedirect:ce.boolean().optional(),visualActions:ce.boolean().optional()}).optional(),advanced:Nh.optional(),hooks:jI.optional()});function _S(n,e){let t;try{t=DI(n,"utf-8")}catch(o){y.warn(`Could not read possible Momentic ${e} file at ${n}: ${o}`);return}let r;try{if(r=NS.parse(t),typeof r!="object"||r===null)throw new Error(`The ${e} file should parse as a map with key-value pairs, but is type ${typeof r} instead`)}catch(o){y.warn(`Possible Momentic ${e} file at ${n} does not parse as valid YAML: ${o}`);return}return r}function Dd(n){let e=_S(n,"project configuration");if(e!==void 0)try{return $I.parse(e)}catch(t){y.warn(`Possible Momentic project configuration file at ${n} does not adhere to the required schema: ${t}`);return}}function GI(n){let e=_S(n,"workspace configuration");if(e!==void 0)try{return BI.parse(e)}catch(t){y.warn(`Possible Momentic workspace configuration file at ${n} does not adhere to the required schema: ${t}`);return}}function WI(){let n=[],e=_d(),t=qr.parse(e).root,r=15,o=0;for(;o<r;){o++;let i=qr.basename(e);if(ws.includes(i))return y.warn(`Stopping search for Momentic projects since the current directory name (${i}) is likely a system artifact folder.`),n;for(let a of FI(e))if(a.endsWith(Vo)){let s=qr.join(e,a),l=Dd(s);l&&n.push({configFilePath:s,config:l,rootDir:MS(s)})}if(n.length)return n;if(e=qr.dirname(e),e===t)break}return n}function Qt(n={}){let{configFilePath:e,nameFilter:t}=n,r=Fd(e);if(t&&(r=r.filter(o=>o.config.name===t)),r.length>1)throw new Error(`Multiple valid projects were found in the same directory. Please use the '-c / --config' flag to disambiguate:
49
+ ${r.map(o=>o.configFilePath)}`);if(r.length===0)throw new Error("No valid Momentic project file available.");return y.debug(`Found valid project configuration at ${r[0].configFilePath}`),r[0]}function VI(n){let e=GI(n);if(!e||!e.projects||!e.projects.length)return;let t=e.projects.map(i=>(i.endsWith("/")||(i+="/"),`${i}*${Vo}`)),r=Wo(t,{absolute:!1,cwd:_d(),dotRelative:!1,maxDepth:Nd,nodir:!0}),o=[];for(let i of r){let a=qr.join(_d(),i),s=Dd(a);s&&o.push({configFilePath:a,config:s,rootDir:MS(a)})}return o}function Fd(n){if(n){n=qr.resolve(n);let t=Dd(n);return t||(console.error(`No valid Momentic project file found at ${n}.`),process.exit(1)),[{config:t,configFilePath:n,rootDir:qr.dirname(n)}]}if(_I(kS)){let t=VI(kS);if(t)return t}return WI()}function qo(n,e){let t=NS.stringify(n);UI(e,t)}import Ko from"fs";import Ud from"path";import{z as Bd}from"zod";var DS="golden/visual-diff",FS="reports",US="test-results";var qI=Bd.object({width:Bd.number(),height:Bd.number()}),Yo=class{defaultGoldenScreenshotDir;regenerateGoldenFiles;constructor(e,t){let r=Ud.join(e.rootDir,e.config.goldenFileDir??DS);this.defaultGoldenScreenshotDir=r,this.regenerateGoldenFiles=t}async prepareGoldenScreenshotForComparison(e,t,r){if(t.screenshot?.data?.startsWith("https://")){let a=await fetch(t.screenshot.data);return{buffer:Buffer.from(await a.arrayBuffer()),width:t.screenshot.width,height:t.screenshot.height}}let o=t.screenshot?.data;o||(o=Ud.join(this.defaultGoldenScreenshotDir,`${t.id}.jpg`));let i=`${o}.metadata.json`;if(this.regenerateGoldenFiles)return Ko.mkdirSync(Ud.dirname(o),{recursive:!0}),Ko.writeFileSync(o,r.buffer),Ko.writeFileSync(i,JSON.stringify({width:r.width,height:r.height})),{buffer:Buffer.from(r.buffer),width:r.width,height:r.height};if(Ko.existsSync(o)){let a=Ko.readFileSync(o),s=qI.parse(JSON.parse(Ko.readFileSync(i,"utf-8")));return{buffer:a,width:s.width,height:s.height}}else throw new R("UserConfigurationError",`Cannot execute visual diff without a saved baseline screenshot at ${o}`)}};var Jo=class{flags;constructor(e){this.flags={auto_expand_iframes:e.browser?.autoExpandIframes??!1,rag_v2:e.ai?.aiPageFiltering??!1,faker_constant_seed:e.advanced?.fakerConstantSeed??!1,disable_secondary_cache_resolution:e.browser?.disableSecondaryCacheResolution??!1,show_zero_opacity_elements:e.browser?.showZeroOpacityElements??!1,global_locator_redirect:e.browser?.globalLocatorRedirect??!1,visual_actions:e.browser?.visualActions??!1,mini_model_initial_assertion:!1,mini_model_initial_locator:!1,show_test_plans:!1,icon_knowledge_base:!1}}isBooleanFlagEnabled(e){return this.flags[e]}getAllFlags(){return{...this.flags}}getFlagPayload(e){}async refresh(){}};import KI from"simple-git";var ye=KI();function tl(n){if(n.startsWith("git@")){let e=n.split(":");if(e.length===2){let t=e[1].replace(".git","").split("/");if(t.length===2){let r=t[0],o=t[1];return`${r}/${o}`}}}else if(n.startsWith("http")||n.startsWith("https")){let t=new URL(n).pathname.split("/").filter(Boolean);if(t.length>=2){let r=t[0],o=t[1].replace(".git","");return`${r}/${o}`}}}async function be(n,e){try{return(await e).trim()}catch(t){n.error({err:t},"Failed to run git command");return}}function YI(){if(process.env.GITHUB_ACTION)return"GithubActions";if(process.env.GITLAB_CI)return"GitlabCI";if(process.env.CIRCLECI)return"CircleCI";if(process.env.BUILDKITE)return"Buildkite";if(process.env["System.CollectionUri"]?.includes("azure"))return"AzureDevOps"}async function JI(n){let[e,t,r,o]=await Promise.all([be(n,ye.show(["--no-patch","--format=%ci"])),be(n,ye.listRemote(["--get-url","origin"])),be(n,ye.show(["-s","--pretty=%B"])),be(n,ye.show(["-s","--pretty=%an"]))]);return{gitCommitSha:process.env.GITHUB_SHA,gitCommitShaShort:process.env.GITHUB_SHA?.slice(0,6),gitCommitTimestamp:e?new Date(e):void 0,gitBranchName:process.env.GITHUB_HEAD_REF||process.env.GITHUB_REF_NAME,gitOriginUrl:t,gitCommitMessage:r,gitCommitAuthorName:o,githubRepository:process.env.GITHUB_REPOSITORY,pipelineId:`${process.env.GITHUB_RUN_ID}:${process.env.GITHUB_RUN_ATTEMPT}`}}async function XI(n){let[e,t,r]=await Promise.all([be(n,ye.listRemote(["--get-url","origin"])),be(n,ye.show(["-s","--pretty=%B"])),be(n,ye.show(["-s","--pretty=%an"]))]);return{gitCommitSha:process.env.CI_COMMIT_SHA,gitCommitShaShort:process.env.CI_COMMIT_SHORT_SHA,gitCommitTimestamp:process.env.CI_COMMIT_TIMESTAMP?new Date(process.env.CI_COMMIT_TIMESTAMP):void 0,gitBranchName:process.env.CI_COMMIT_BRANCH||process.env.CI_COMMIT_REF_NAME,gitOriginUrl:e,gitCommitMessage:t,gitCommitAuthorName:r,gitlabProjectPath:process.env.CI_SERVER_HOST,pipelineId:`${process.env.CI_PIPELINE_ID}:${process.env.CI_JOB_ID}`}}async function ZI(n){let[e,t,r,o]=await Promise.all([be(n,ye.show(["--no-patch","--format=%ci"])),be(n,ye.listRemote(["--get-url","origin"])),be(n,ye.show(["-s","--pretty=%B"])),be(n,ye.show(["-s","--pretty=%an"]))]),i=t?.includes("github.com"),a=t?.includes("gitlab.com"),s=t?tl(t):void 0;return{gitCommitSha:process.env.CIRCLE_SHA1,gitCommitShaShort:process.env.CIRCLE_SHA1?.slice(0,6),gitCommitTimestamp:e?new Date(e):void 0,gitBranchName:process.env.CIRCLE_BRANCH,gitOriginUrl:process.env.CIRCLE_REPOSITORY_URL,gitCommitMessage:r,gitCommitAuthorName:o,githubRepository:i?s:void 0,gitlabProjectPath:a?s:void 0,pipelineId:`${process.env.CIRCLE_WORKFLOW_ID}:${process.env.CIRCLE_WORKFLOW_JOB_ID}`}}async function QI(n){let[e,t,r]=await Promise.all([be(n,ye.show(["--no-patch","--format=%ci"])),be(n,ye.show(["-s","--pretty=%B"])),be(n,ye.show(["-s","--pretty=%an"]))]),o=process.env.BUILDKITE_REPO,i=o?.includes("github.com"),a=o?.includes("gitlab.com"),s=o?tl(o):void 0;return{gitCommitSha:process.env.BUILDKITE_COMMIT,gitCommitShaShort:process.env.BUILDKITE_COMMIT?.slice(0,6),gitCommitTimestamp:e?new Date(e):void 0,gitBranchName:process.env.BUILDKITE_BRANCH,gitOriginUrl:o,gitCommitMessage:t,gitCommitAuthorName:r,githubRepository:i?s:void 0,gitlabProjectPath:a?s:void 0,pipelineId:`${process.env.BUILDKITE_PIPELINE_ID}:${process.env.BUILDKITE_BUILD_ID}:${process.env.BUILDKITE_JOB_ID}`}}async function eP(n){let[e,t,r]=await Promise.all([be(n,ye.show(["--no-patch","--format=%ci"])),be(n,ye.show(["-s","--pretty=%B"])),be(n,ye.show(["-s","--pretty=%an"]))]),o=process.env["Build.Repository.Uri"],i=o?.includes("github.com"),a=o?.includes("gitlab.com"),s=o?tl(o):void 0;return{gitCommitSha:process.env["Build.SourceVersion"],gitCommitShaShort:process.env["Build.SourceVersion"]?.slice(0,6),gitCommitTimestamp:e?new Date(e):void 0,gitBranchName:process.env["Build.SourceBranchName"],gitOriginUrl:o,gitCommitMessage:t,gitCommitAuthorName:r,githubRepository:i?s:void 0,gitlabProjectPath:a?s:void 0,pipelineId:`${process.env["System.JobId"]}:${process.env["System.JobAttempt"]}`}}async function tP(n,e){let[t,r,o,i,a,s,l,c]=await Promise.all([be(n,ye.revparse(["HEAD"])),be(n,ye.revparse(["--short","HEAD"])),be(n,ye.revparse(["--abbrev-ref","HEAD"])),be(n,ye.listRemote(["--get-url","origin"])),be(n,ye.show(["--no-patch","--format=%ci"])),be(n,ye.show(["-s","--pretty=%B"])),be(n,ye.show(["-s","--pretty=%an"])),e?be(n,ye.raw(["merge-base","--fork-point",e])):Promise.resolve(void 0)]),d=c?await be(n,ye.show(["--no-patch","--format=%ci",c])):void 0,p=i?.includes("github.com"),m=i?.includes("gitlab.com"),u=i?tl(i):void 0;return{gitCommitSha:t,gitCommitShaShort:r,gitBranchName:o,gitOriginUrl:i,gitCommitTimestamp:a?new Date(a):void 0,gitCommitMessage:s,gitCommitAuthorName:l,lastCommitOnMainSha:c,lastCommitOnMainTimestamp:d?new Date(d):void 0,githubRepository:p?u:void 0,gitlabProjectPath:m?u:void 0,pipelineId:void 0}}async function nP(n){let e=n.config.gitProtectedBranches??[];return n.config.gitMainBranch&&e.push(n.config.gitMainBranch),{gitMainBranch:n.config.gitMainBranch,gitProtectedBranches:e}}async function rP(n,e){let t=YI();if(!t)return tP(n,e);switch(t){case"GithubActions":return JI(n);case"GitlabCI":return XI(n);case"CircleCI":return ZI(n);case"Buildkite":return QI(n);case"AzureDevOps":return eP(n)}}async function oP(n,e,t){if(t.lastCommitOnMainSha&&t.lastCommitOnMainTimestamp)return{};if(t.gitlabProjectPath){if(!t.gitMainBranch||!t.gitCommitSha)return{};try{let r=await e.getMergeBaseCommitFromGitlab(t.gitlabProjectPath,t.gitMainBranch,t.gitCommitSha);return{lastCommitOnMainSha:r.sha,lastCommitOnMainTimestamp:r.committer.date}}catch(r){return n.warn({err:r},"Failed to get remote metadata from Gitlab"),{}}}if(t.githubRepository){if(!t.gitMainBranch||!t.gitCommitSha)return{};try{let[r,o]=t.githubRepository.split("/"),i=await e.getMergeBaseCommitFromGithub(r,o,t.gitMainBranch,t.gitCommitSha);return{lastCommitOnMainSha:i.sha,lastCommitOnMainTimestamp:i.committer.date}}catch(r){return n.warn({err:r},"Failed to get remote metadata from Github"),{}}}return{}}async function Xo(n,e,t){let r=await nP(t),o=await rP(n,r.gitMainBranch),i={...r,...o},a=await oP(n,e,i);return{...r,...o,...a}}import cM from"http";import{z as Hd}from"zod";var M="v1",va="2.0.2";var iP=9e4,aP=15e3,hn=class extends Error{status;rawError;constructor(e,t,r,o={}){super(r,o),this.status=e,this.rawError=t}};async function sP(n){return n.text().then(e=>{try{return JSON.parse(e).error}catch{return e}})}var zd=class{baseUrl;logger;constructor(e){this.baseUrl=e.baseUrl,this.logger=e.logger}getHeaders(){let e={"Content-Type":"application/json"};return va&&(e[_h]=va),e}async sendRequest(e,t,r=3,o=iP){let i=r,a,s={path:e,baseUrl:this.baseUrl,method:t.method};for(;r>0;)try{return r--,await this.sendSingleRequestHelper(e,t,o)}catch(l){if(a=l,l instanceof hn&&l.status>=400&&l.status<500||r===0)throw l;let c=1500,d=i-r,p=Math.min(c*Math.pow(2,d-1),aP);await new Promise(m=>setTimeout(m,p))}throw this.logger.warn({...s,err:a},"Got fatal error response from Momentic server"),a}async sendSingleRequestHelper(e,t,r){let o={path:e,baseUrl:this.baseUrl,method:t.method},i=new AbortController,a=setTimeout(()=>i.abort(),r),s=()=>i.abort();t.signal&&t.signal.addEventListener("abort",s);let l={...this.getHeaders(),...t.extraHeaders};try{let c=await fetch(`${this.baseUrl}${e}`,{method:t.method,body:t.body?JSON.stringify(t.body):void 0,headers:l,signal:i.signal});if(!c.ok){let p=await sP(c);throw new hn(c.status,p,`Request to ${e} failed with status ${c.status}: ${p}`)}let d;if(c.status===204)d={};else{let p=await c.text();try{d=JSON.parse(p)}catch{d=p}}return this.logger&&!t.noLog&&d&&this.logger.debug({result:d,status:c.status,...o},"Got response from Momentic server"),d}finally{clearTimeout(a),t.signal&&t.signal.removeEventListener("abort",s)}}},kt=class extends zd{apiKey;constructor(e){super(e),this.apiKey=e.apiKey}getHeaders(){return{...super.getHeaders(),Authorization:`Bearer ${this.apiKey}`}}};var lt=class extends kt{constructor(e){super(e)}getAppUrl(){return this.baseUrl.replace(/\/\/api/,"//app")}async getAuthInfo(){let e=await this.sendRequest(`/${M}/auth/check`,{method:"GET",noLog:!0},10,5e3),{orgId:t,userId:r}=ag.parse(e);return{orgId:t,userId:r}}async bulkGetRunStatus(e){let t=await this.sendRequest(`/${M}/runs/status`,{method:"POST",body:e,noLog:!0},3,1e4);return tg.parse(t)}async createRunGroup(e){let t=await this.sendRequest(`/${M}/run-groups`,{method:"POST",body:e,noLog:!0},10,5e3);return Xh.parse(t)}async updateRunGroup(e,t){await this.sendRequest(`/${M}/run-groups/${e}`,{method:"PATCH",body:t,noLog:!0},5,5e3)}async createRun(e){let t=await this.sendRequest(`/${M}/runs`,{method:"POST",body:e,noLog:!0},10,5e3);return eg.parse(t)}async updateRun(e,t){await this.sendRequest(`/${M}/runs/${e}`,{method:"PATCH",body:t,noLog:!0},3,5e3)}async createRunAttempt(e){let t=await this.sendRequest(`/${M}/runs/${e}/attempts`,{method:"POST",noLog:!0},10,5e3);return rg.parse(t)}async updateRunAttempt(e,t,r){await this.sendRequest(`/${M}/runs/${e}/attempts/${t}`,{method:"PATCH",body:r,noLog:!0},3,5e3)}async getTest(e){let t=await this.sendRequest(`/${M}/tests/${e}`,{method:"GET"},3,5e3);return Vh.parse(t)}async getAllTestIds(){let e=await this.sendRequest(`/${M}/tests`,{method:"GET"},3,5e3);return qh.parse(e)}async getTestYAMLExport(e){let t=await this.sendRequest(`/${M}/tests/export`,{method:"POST",body:e},3,5e3);return Kh.parse(t)}async updateTestWithYAML(e){await this.sendRequest(`/${M}/tests/update`,{method:"POST",body:e},3,5e3)}async updateStepCaches(e,t){await this.sendRequest(`/${M}/cache`,{method:"PATCH",body:e,extraHeaders:t},3,1e4)}async getStepCacheForTest(e,t){let r=await this.sendRequest(`/${M}/cache`,{method:"POST",body:e,extraHeaders:t},10,1e4);return Yh.parse(r)}async queueTests(e){let t=await this.sendRequest(`/${M}/tests/queue`,{method:"POST",body:e},3,1e4);return Wh.parse(t)}async uploadScreenshot(e){let t=await this.sendRequest(`/${M}/screenshots`,{method:"POST",body:e,noLog:!0},3,5e3);return ig.parse(t)}async getAllEnvironments(){let e=await this.sendRequest(`/${M}/environments`,{method:"GET"},3,5e3);return sg.parse(e)}async getEnvironment(e){let t=await this.sendRequest(`/${M}/environments/${e}`,{method:"GET"},3,5e3);return Xa.parse(t)}async getAllFeatureFlags(){let e=await this.sendRequest(`/${M}/auth/flags`,{method:"GET",noLog:!0},10,1e4);return lg.parse(e)}async acquireCacheLock(e,t){let r=await this.sendRequest(`/${M}/result-cache/lock`,{method:"POST",body:e,signal:t},3,3e4);return fg.parse(r)}async releaseCacheLock(e){await this.sendRequest(`/${M}/result-cache/lock`,{method:"DELETE",body:{key:e}},3,5e3)}async deleteCacheResult(e){await this.sendRequest(`/${M}/result-cache/entry`,{method:"DELETE",body:e},3,5e3)}async setCacheResult(e){await this.sendRequest(`/${M}/result-cache/entry`,{method:"PATCH",body:e},3,5e3)}async getCacheResult(e){try{return await this.sendRequest(`/${M}/result-cache/entry`,{method:"POST",body:e},3,5e3)}catch(t){if(t instanceof Error&&t.message.includes("404"))return null;throw t}}async queueSuiteRuns(e){let t=await this.sendRequest(`/${M}/suites/queue`,{method:"POST",body:e},3,5e3);return cg.parse(t)}async bulkGetSuiteStatus(e){let t={suiteRunIds:e},r=await this.sendRequest(`/${M}/suites/status`,{method:"POST",body:t,noLog:!0},3,5e3);return dg.parse(r)}async bulkGetRunGroupStatus(e){let t={runGroupIds:e},r=await this.sendRequest(`/${M}/run-groups/status`,{method:"POST",body:t,noLog:!0},3,5e3);return Bm.array().parse(r)}async updateCacheLastUsedDate(e,t,r,o){try{await this.sendRequest(`/${M}/cache/last-used-at`,{method:"PATCH",body:{uniqueKeys:t,testId:e},noLog:!0,extraHeaders:o},3,5e3)}catch(i){r.error({err:i},"Failed to update cache last used date")}}async uploadProposedSteps(e,t){try{await this.sendRequest(`/${M}/test-fragments/`,{method:"POST",body:e},3,1e4)}catch(r){t.error({err:r},"Failed to upload proposed steps")}}async uploadSnapshotScreenshot(e,t,r){try{await this.sendRequest(`/${M}/snapshots/${t}/screenshot`,{method:"POST",body:r,noLog:!0},3,1e4)}catch(o){e.error({err:o},"Failed to upload screenshot")}}async generateConsoleLogsForRunAttemptUploadUrl(e,t,r){let o=await this.sendRequest(`/${M}/runs/${t}/attempts/${r}/console-logs`,{method:"POST",noLog:!0},3,5e3);return Lo.parse(o)}async generateNetworkLogsForRunAttemptUploadUrl(e,t,r){let o=await this.sendRequest(`/${M}/runs/${t}/attempts/${r}/network-logs`,{method:"POST",noLog:!0},3,1e4);return Lo.parse(o)}async generateHtmlSnapshotUploadUrl(e,t){let r=await this.sendRequest(`/${M}/snapshots/${t}/html`,{method:"POST",noLog:!0},3,1e4);return Lo.parse(r)}async generateA11yTreeSnapshotUploadUrl(e,t){let r=await this.sendRequest(`/${M}/snapshots/${t}/a11y`,{method:"POST",noLog:!0},3,1e4);return Lo.parse(r)}async reportBillableEvents(e,t){try{await this.sendRequest(`/${M}/billing/events`,{method:"POST",body:t,noLog:!0},10,5e3)}catch(r){e.error({err:r},"Failed to report billable event")}}async fetchTestFragment(e){let t=await this.sendRequest(`/${M}/test-fragments/${e}`,{method:"GET",noLog:!0});return pg.parse(t)}async patchTestFragment(e,t){await this.sendRequest(`/${M}/test-fragments/${e}`,{method:"PATCH",body:t},3,5e3)}async getPastTestResults(e,t){let r=await this.sendRequest(`/${M}/results/tests/${e}`,{method:"POST",body:t},3,1e4);return ug.parse(r)}async generateTestResultsUploadUrl(){let e=await this.sendRequest(`/${M}/results/uploads`,{method:"POST",noLog:!0},3,1e4);return mg.parse(e)}async startProcessingResultsUpload(e){let t=await this.sendRequest(`/${M}/results/uploads/${e}/process`,{method:"POST",noLog:!0},3,1e4);return hg.parse(t)}async fetchIconKnowledgeBase(e,t){try{let r=await this.sendRequest(`/${M}/knowledge-base/icons`,{method:"GET",noLog:!0},3,5e3);return Tg.parse(r)}catch(r){return t.error({err:r},"Failed to fetch icon knowledge base"),null}}async saveNewIcons(e,t){try{await this.sendRequest(`/${M}/knowledge-base/icons`,{method:"POST",body:e,noLog:!0},3,5e3)}catch(r){t.error({err:r},"Failed to save new icons to icon knowledge base")}}async getMergeBaseCommitFromGithub(e,t,r,o){let i=new URLSearchParams;i.set("base",r),i.set("head",o);let a=await this.sendRequest(`/${M}/git/github/${e}/${t}/merge-base-commit?${i.toString()}`,{method:"GET",noLog:!0},3,1e4);return Qc.parse(a)}async getMergeBaseCommitFromGitlab(e,t,r){let o=new URLSearchParams;o.set("base",t),o.set("head",r);let i=await this.sendRequest(`/${M}/git/gitlab/${e}/merge-base-commit?${o.toString()}`,{method:"GET",noLog:!0},3,5e3);return Qc.parse(i)}async getAgentConfig(){let e=await this.sendRequest(`/${M}/web-agent/agent-config`,{method:"GET",noLog:!0},3,5e3);return Hd.record(Hd.string(),Hd.string()).parse(e)}};import{randomUUID as BS}from"crypto";var nl=class{apiClient;constructor(e){this.apiClient=e}async reportBillableEvent(e,t,r){try{return await this.apiClient.reportBillableEvents(e,[{event:t,timestamp:new Date().toISOString(),transactionId:r?.eventId??BS(),properties:jc({},r)}])}catch(o){e.error({err:o},"Failed to report billable event")}}async reportCreditsUsed(e,t,r,o){if(r)try{return await this.apiClient.reportBillableEvents(e,[{event:"credits-used",timestamp:new Date().toISOString(),transactionId:o?.eventId??BS(),properties:jc({creditsUsed:r,usedBy:t},o)}])}catch(i){e.error({err:i},"Failed to report credits used")}}};function Zo(n,e,t){return fetch(n,{method:"PUT",body:t,headers:{"Content-Type":e}})}var rl=class{constructor(e){this.client=e}async storeConsoleLogsForRunAttempt(e,t,r,o){try{let i=JSON.stringify(o),{uploadUrl:a}=await this.client.generateConsoleLogsForRunAttemptUploadUrl(e,t,r),s=await Zo(a,"application/json",i);if(!s.ok)throw new Error(`Failed to upload network logs: ${s.statusText}`)}catch(i){e.error({err:i},"Failed to upload console logs")}}async storeNetworkLogsForRunAttempt(e,t,r,o){let i=JSON.stringify(o);try{let{uploadUrl:a}=await this.client.generateNetworkLogsForRunAttemptUploadUrl(e,t,r),s=await Zo(a,"application/json",i);if(!s.ok)throw new Error(`Failed to upload network logs: ${s.statusText}`)}catch(a){e.error({err:a},"Failed to upload network logs")}}async storeHtmlSnapshot(e,t,r){try{let{uploadUrl:o}=await this.client.generateHtmlSnapshotUploadUrl(e,t),i=await Zo(o,"text/html",r);if(!i.ok)throw new Error(`Failed to upload network logs: ${i.statusText}`)}catch(o){e.error({err:o},"Failed to upload html snapshot")}}async storeScreenshot(e,t,r){try{await this.client.uploadSnapshotScreenshot(e,t,{screenshot:r.toString("base64")})}catch(o){e.error({err:o},"Failed to upload screenshot")}}async storeA11yTreeSnapshot(e,t,r){return Promise.resolve()}async getConsoleLogsForRunAttempt(e,t,r){}async getNetworkLogsForRunAttempt(e,t,r){}async getHtmlSnapshot(e,t){}async getA11yTreeSnapshot(e,t){}async getScreenshot(e,t){}};var Qo=class{constructor(e,t){this.client=e;this.orgId=t}async acquireCacheLock(e,t){return this.client.acquireCacheLock(e,t)}async uploadScreenshot(e){return(await this.client.uploadScreenshot({screenshot:e.toString("base64")})).key}async releaseCacheLock(e){return this.client.releaseCacheLock(e)}async deleteCacheResult(e){return this.client.deleteCacheResult(e)}async setCacheResult(e){return this.client.setCacheResult(e)}async getCacheResult(e){return this.client.getCacheResult(e)}fetchIconKnowledgeBase(e,t){return this.client.fetchIconKnowledgeBase(e,t)}saveNewIcons(e,t,r){return this.client.saveNewIcons(t,r)}};import{Faker as lP,en as cP}from"@faker-js/faker";var ei="v1",dr=class{httpClient;fakerInstance;type="API_CLIENT";sms={send:this.sendSms.bind(this),fetchLatest:this.fetchLatestSms.bind(this)};email={send:this.sendEmail.bind(this),fetchLatest:this.fetchLatestEmail.bind(this),fetchAll:this.fetchAllEmails.bind(this)};ai={generate:this.sendAiGenerate.bind(this)};constructor(e){this.httpClient=e.httpClient,e.fakerSeed&&(this.fakerInstance=new lP({locale:cP}),this.fakerInstance.seed(e.fakerSeed))}async sendAiGenerate(e){let t=typeof e=="string"?{input:e}:e;return this.httpClient.sendRequest(`/${ei}/tools/ai/generate`,{method:"POST",body:t}).catch(r=>{throw r instanceof hn?new Error(r.rawError):new Error(`Failed to send AI generation: ${r.message}`)})}async sendSms(e){return this.httpClient.sendRequest(`/${ei}/tools/sms/send`,{method:"POST",body:e}).then(()=>{}).catch(t=>{throw t instanceof hn?new Error(t.rawError):new Error(`Failed to send sms: ${t.message}`)})}async fetchLatestSms(e){return this.httpClient.sendRequest(`/${ei}/tools/sms/fetchLatest`,{method:"POST",body:e}).catch(t=>{throw t instanceof hn?new Error(t.rawError):t})}async sendEmail(e){return this.httpClient.sendRequest(`/${ei}/tools/email/send`,{method:"POST",body:e}).then(()=>{}).catch(t=>{throw t instanceof hn?new Error(t.rawError):new Error(`Failed to send email: ${t.message}`)})}async fetchAllEmails(e){return this.httpClient.sendRequest(`/${ei}/tools/email/fetchAll`,{method:"POST",body:e}).catch(t=>{throw t instanceof hn?new Error(t.rawError):new Error(`Failed to fetch all emails: ${t.message}`)})}async fetchLatestEmail(e){return this.httpClient.sendRequest(`/${ei}/tools/email/fetchLatest`,{method:"POST",body:e}).catch(t=>{throw t instanceof hn?new Error(t.rawError):new Error(`Failed to fetch latest emails: ${t.message}`)})}};import{z as dP}from"zod";var ti=class extends kt{agentConfig;constructor(e,t){super(t),this.agentConfig=e}async rankChunksWithAi(e,t){let r={...e,loggerTags:t.loggerTags},o=await this.sendRequest(`/${M}/web-agent/recommend-chunks-ai`,{method:"POST",body:r,signal:t.abortSignal});return eh.parse(o)}async rankChunksWithRag(e,t){let r=await this.sendRequest(`/${M}/web-agent/recommend-chunks`,{method:"POST",body:{cliVersion:va,...e},signal:t.abortSignal});return Qm.parse(r)}async getScreenshotFromS3(e){let t=await this.sendRequest(`/${M}/s3/visual-diff-screenshot`,{method:"POST",body:{url:e}});return dP.string().parse(t)}async getElementLocation(e,t){let r={...e,disableCache:t.disableCache,loggerTags:t.loggerTags,agentConfigVersion:this.agentConfig?.locator},o=await this.sendRequest(`/${M}/web-agent/locate-element`,{method:"POST",body:r,signal:t.abortSignal});return $h.parse(o)}async getAssertionResult(e,t){let r={...e,disableCache:!!t.disableCache,useConsensus:!!t.useConsensus,attemptNumber:t.attemptNumber,loggerTags:t.loggerTags,agentConfigVersion:this.agentConfig?.locator},o=await this.sendRequest(`/${M}/web-agent/assertion`,{method:"POST",body:r,signal:t.abortSignal});return Xc.parse(o)}async getLintStepResult(e,t){let r={...e,disableCache:!!t.disableCache,loggerTags:t.loggerTags},o=await this.sendRequest(`/${M}/web-agent/lint/step`,{method:"POST",body:r,signal:t.abortSignal});return jh.parse(o)}async getVisualAssertionResult(e,t){let r={...e,disableCache:!!t.disableCache,useConsensus:!!t.useConsensus,loggerTags:t.loggerTags},o=await this.sendRequest(`/${M}/web-agent/visual-assertion`,{method:"POST",body:r,signal:t.abortSignal});return Xc.parse(o)}async getAiActionCommand(e,t){let r=await this.sendRequest(`/${M}/web-agent/next-command-dynamic`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Hh.parse(r)}async getMultiturnAiActionCommand(e,t){return await this.sendRequest(`/${M}/web-agent/ai-action/next-command`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal})}async getMultiturnAiActionEvaluation(e,t){let r=await this.sendRequest(`/${M}/web-agent/ai-action/evaluate`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Sc.parse(r)}async getReverseMappedDescription(e,t){let r=await this.sendRequest(`/${M}/web-agent/reverse-mapped-description`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Gh.parse(r)}async getTextExtraction(e,t){let r={...e,disableCache:t.disableCache,loggerTags:t.loggerTags},o=await this.sendRequest(`/${M}/web-agent/text-extraction`,{method:"POST",body:r,signal:t.abortSignal});return fc.parse(o)}async getTestResultClassification(e,t){let r=await this.sendRequest(`/${M}/web-agent/result-classification`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return Ic.parse(r)}async getExtractedKeywords(e,t){let r=await this.sendRequest(`/${M}/web-agent/extract-keywords`,{method:"POST",body:{goal:e,disableCache:t.disableCache,context:e},signal:t.abortSignal});return Zm.parse(r)}async getAutohealingProposal(e,t){let r=await this.sendRequest(`/${M}/web-agent/autoheal-section`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return ju.parse(r)}async getFailureRecoveryProposal(e,t){let r=await this.sendRequest(`/${M}/web-agent/failure-recovery`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return $u.parse(r)}async getIframeRegex(e,t){let r=await this.sendRequest(`/${M}/web-agent/iframe-regex`,{method:"POST",body:e,signal:t.abortSignal});return xu.parse(r)}};var ni=class extends kt{generator;constructor(e,t){super(e),this.generator=t}async runTemplateMatching(e,t={}){let r=await this.sendRequest(`/${M}/web-agent/template-matching`,{method:"POST",body:e,signal:t?.signal});return Eu.parse(r)}async constructIframeRegex(e,t={}){return this.generator.getIframeRegex(e,{abortSignal:t.signal})}};var ol=class{constructor(e){this.client=e}async uploadResultsArchive(e){let{uploadUrl:t,id:r}=await this.client.generateTestResultsUploadUrl(),o=await Zo(t,"application/zip",e);if(!o.ok)throw new Error(`Failed to upload test results: ${await o.text()}`);let{runGroupId:i}=await this.client.startProcessingResultsUpload(r);return i}};function ri({client:n,gitMetadata:e,alwaysSaveCache:t,noCache:r}){return r?new Ts:new jd(n,e,t)}var jd=class{constructor(e,{gitMainBranch:t,gitBranchName:r,gitProtectedBranches:o,gitCommitTimestamp:i,lastCommitOnMainSha:a,lastCommitOnMainTimestamp:s},l){this.client=e;this.cacheHeaders={},t&&(this.cacheHeaders[Dh]=t),r&&(this.cacheHeaders[Fh]=r),i&&(this.cacheHeaders[Uh]=i.toISOString()),a&&(this.cacheHeaders[Bh]=a),s&&(this.cacheHeaders[zh]=s.toISOString()),l?this.writeCaches=!0:r?this.writeCaches=!o.includes(r):this.writeCaches=!0}cacheHeaders;writeCaches;async saveStepCacheEntries(e,t,r){if(!this.writeCaches){r.debug("Skipping cache storage because branch is protected");return}try{await this.client.updateStepCaches({entries:e,testId:t},this.cacheHeaders)}catch(o){r.error({err:o},"Failed to save step cache entries")}}async resolveStepCacheEntries(e){let t=await this.client.getStepCacheForTest({testId:e.testId,organizationId:e.organizationId,steps:e.steps,schemaVersion:e.schemaVersion},this.cacheHeaders);if(!this.writeCaches){e.logger.debug("Skipping cache last used at update because branch is protected");return}let{uniqueKeysHit:r}=Oo({steps:e.steps,stepCacheEntries:t,logger:e.logger});this.client.updateCacheLastUsedDate(e.testId,r,e.logger,this.cacheHeaders)}};import{Server as Bk}from"socket.io";import{cloneDeep as pP}from"lodash-es";var uP={showOverlay:!1},$d=class{sessions=new Map;sessionCountByIp=new Map;getCurrentConnectionsByIp(e){return this.sessionCountByIp.get(e)??0}getCurrentSessionsByIp(){return Object.fromEntries(this.sessionCountByIp)}reserveCapacityByIp(e){e&&this.sessionCountByIp.set(e,(this.sessionCountByIp.get(e)??0)+1)}releaseCapacityByIp(e){e&&this.sessionCountByIp.set(e,Math.max(this.getCurrentConnectionsByIp(e)-1,0))}registerSession({controller:e,context:t,cleanup:r,clientIp:o,sessionId:i,browserbaseSessionId:a}){return this.sessions.set(i,{controller:e,context:t,cleanup:r,clientIp:o,browserbaseSessionId:a,browserBehavior:pP(uP)}),i}removeSession(e,t){(async()=>{let o=this.sessions.get(e);if(!o)return;this.releaseCapacityByIp(o.clientIp);let{controller:i}=o;try{i.setClosed(),await i.browser.cleanup()}catch(a){t.error({err:a},"Error cleaning up browser in global state manager")}try{await o.cleanup?.()}catch(a){t.error({err:a},"Error running cleanup function in global state manager")}this.sessions.delete(e)})()}getSession(e){return this.sessions.get(e)}},Q=new $d;function zS(n,e,t){let r=Date.now(),o=Date.now(),i,a,s,l,c=!1,d=async(h,g)=>{if(!h.closed&&!h.isInPageLoad)try{let f=s;s=void 0;let S=h.url(),b=g.toEditorDisplayCopy();JSON.stringify(b)===JSON.stringify(i)&&S===l&&r>o||(n.emit("browserState",{logsPerPage:f?.logsPerPage,harPages:f?.harPages,harEntries:f?.harEntries,viewport:h.getViewport(),url:S,iframeSrcUrls:a??[],context:b,isInPageLoad:h.isInPageLoad}),r=Date.now()),l=S,i=b}catch(f){if(!n.connected)return;let S=f instanceof Error?f.message:`${f}`;if(S.includes("Frame was detached")||S.includes("Not attached to an active page")||S.includes("browser has been closed")||S.includes("UserInfrastructureError"))return;t.error({err:f,sessionId:e},"Error grabbing browser state")}},p=setInterval(()=>{let h=Q.getSession(e),g=h?.controller?.browser;if(!g||g.closed){t.debug("Clearing browser state socket cron due to the browser being closed"),clearInterval(p);return}d(g,h.context)},1e3),m=(h,g)=>!!(JSON.stringify(h)!==JSON.stringify(a)||g.logsPerPage.some(f=>f.length>0)||g.harPages&&Object.keys(g.harPages).length>0||g.harEntries&&Object.keys(g.harEntries).length>0),u=setInterval(async()=>{let g=Q.getSession(e)?.controller?.browser;if(!g||g.closed){clearInterval(u);return}else if(c)return;c=!0;try{let f=await g.getAllFrameUrls(),S=g.retrieveAndClearDebugData();m(f,S)&&(a=f,s=S,o=Date.now())}catch(f){t.warn({err:f},"Failed to fetch extended details")}finally{c=!1}},2500);return{timers:[p,u]}}var pr={};var mP=n=>()=>{let{sessionId:e}=n.metadata;pr[e]?.abort?.abort()},HS={event:"cancelApiTest",createHandler:mP};import{CookieJar as OP}from"tough-cookie";import{randomUUID as vP}from"crypto";import{faker as hP}from"@faker-js/faker";import gP from"assert";import fP from"axios";import SP from"moment";import*as yP from"otpauth";import bP from"pg";var oi=class extends Error{constructor(e){super(e),this.name="TimeoutError"}};var jS=n=>{let e=n.reason===void 0?new DOMException("This operation was aborted.","AbortError"):n.reason;return e instanceof Error?e:new DOMException(e,"AbortError")};async function D(n,e){let{milliseconds:t,fallback:r,message:o,customTimers:i={setTimeout,clearTimeout}}=e,a,s;return new Promise((l,c)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(e.signal){let{signal:p}=e;p.aborted&&c(jS(p)),s=()=>{c(jS(p))},p.addEventListener("abort",s)}if(t===Number.POSITIVE_INFINITY){n.then(l,c);return}let d=new oi;a=i.setTimeout.call(void 0,()=>{if(r){try{l(r())}catch(p){c(p)}return}"cancel"in n&&typeof n.cancel=="function"&&n.cancel(),o instanceof Error?c(o):(d.message=o??`Promise timed out after ${t} milliseconds`,c(d))},t),(async()=>{try{l(await n)}catch(p){c(p)}})()}).catch(l=>{throw l}).finally(()=>{a!==void 0&&i.clearTimeout.call(void 0,a),s!==void 0&&e.signal&&e.signal.removeEventListener("abort",s)})}async function $S(n){let e;try{e=new URL(n.url).hostname}catch{}let t=[];return n.headers.getSetCookie()?.forEach(r=>{let o=gs(r,e);t.push(...o)}),t}var wP=Object.getPrototypeOf(async function(){}).constructor;async function GS(n,e,t){let r=e.code;e.options.fragment&&(r=`return ${e.code}`);let{env:o}=e.bindings,i=e.tools,a={},s=(f,S)=>{o[f]=S,a[f]=S},l={},c=(f,S)=>{o[f]=S,l[f]=S},d;r.includes("Octokit")&&(d=(await import("@octokit/rest")).Octokit);let p;r.includes("createAppAuth")&&(p=(await import("@octokit/auth-app")).createAppAuth);let m=async()=>await Promise.resolve(new wP("axios","moment","faker","assert","pg","Octokit","createAppAuth","OTPAuth","extractCookiesFromResponse","env","setVariable","setPersistentVariable","sendSms","waitForLatestSms","email","sms","ai",r)(fP,SP,i.fakerInstance??hP,gP,bP,d,p,yP,$S,o,s,c,S=>i.sms.send(S),S=>i.sms.fetchLatest(S),i.email,i.sms,i.ai)),u=!0,h,g;try{h=await D(m(),{milliseconds:e.options.timeoutMs,message:`Timeout of ${e.options.timeoutMs}ms exceeded for code execution`,signal:e.signal})}catch(f){t.error({err:f,env:o,evalCode:r},`[${n}] Error executing code: ${f}`),u=!1,f instanceof oi?g=`Timeout of ${e.options.timeoutMs}ms exceeded for code execution`:g=f instanceof Error?f.message:`${f}`}return{result:h,variableUpdates:a,persistentVariableUpdates:l,success:u,error:g}}async function WS({code:n,fragment:e,context:t,localTools:r,logger:o,signal:i,timeoutMs:a=tr}){let s=vP(),l=await GS(s,{code:n,options:{fragment:e,timeoutMs:a},bindings:t.toObjectCopy(),tools:r,signal:i},o);return y.debug(`[${s}] Got execution result: ${JSON.stringify(l)}`),l}import{createHmac as TP,randomUUID as xP}from"crypto";import EP from"fetch-retry";var CP=EP(global.fetch,{retries:3,retryOn:function(n,e,t){return!!(e!==null||t&&t.status>=500)},retryDelay:function(n){return Math.pow(2,n)*500}}),VS=process.env.GCP_JS_EVAL_FUNCTION_ENDPOINT,qS=process.env.MOMENTIC_LAMBDA_AUTH_SECRET;async function KS({orgId:n,code:e,fragment:t,context:r,timeoutMs:o=tr,retries:i=2,signal:a,logger:s}){if(!VS)throw new Error("GCP_JS_EVAL_FUNCTION_ENDPOINT environment variable not set");let l,c,d=0;if(!qS)throw new Error("Missing lambda auth secret.");let p=TP("sha256",qS).update(n).digest("hex");for(;d<=i;){d++,a?.throwIfAborted();let u={id:xP(),orgId:n,momenticLambdaAuthHash:p,code:e,fragment:t,state:r.toObjectCopy(),timeoutMs:o};try{if(l=await D(CP(VS,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(u)}),{milliseconds:o,message:`Timeout of ${o}ms exceeded for code execution`,signal:a}),!l)throw new Error("Got empty response from code evaluation server");if(!l.ok)throw new Error(`Code evaluation server returned error code ${l.status}`);c=void 0;break}catch(h){c=h}}if(c)throw s.error({err:c},"Failed to evaluate code remotely"),c;if(!l)throw new Error(`An unexpected code evaluation error occurred${c?`: ${c}`:""}`);let m;try{m=lh.parse(await l.json())}catch(u){throw new Error(`Code evaluation server returned invalid response: ${u}`)}if(m.error)throw new Error(`Code evaluation error: ${m.error}`);return m}async function jn(n){let e;if(process.env.GCP_JS_EVAL_FUNCTION_ENDPOINT)e=await KS(n);else if(n.localTools)e=await WS({...n,localTools:n.localTools});else throw new Error("No code evaluation environment available");if(e.error){let t=`Failed to evaluate code:
50
50
  ${e.error}
51
51
  Code received:
52
- ${n.code}`;throw n.logger.error({err:e.error,code:n.code,env:n.context.toObjectCopy()},t),new Error(t)}if(e.variableUpdates)for(let[t,r]of Object.entries(e.variableUpdates))n.context.setVariable(t,r);if(e.persistentVariableUpdates&&Object.keys(e.persistentVariableUpdates).length>0){await n.callbacks?.onPersistentVariableUpdates?.(e.persistentVariableUpdates);for(let[t,r]of Object.entries(e.persistentVariableUpdates))n.context.setVariable(t,r)}return e.result}async function Bt(n){let{orgId:e,s:t,context:r,logger:o,signal:i,flagStore:a,retries:s=2,timeoutMs:l=tr,allowUndefined:c=!1}=n,d=/{{(.*?)}}/g,p=t.matchAll(d),m=t;for(let u of p){if(u.length<2)continue;let h=u[1].trim(),g;try{g=await jn({orgId:e,code:h,fragment:!0,context:r,timeoutMs:l,logger:o,retries:s,localTools:n.localTools,signal:i,flagStore:a})}catch(S){throw o.error({err:S,value:t},"Error evaluating template string"),S}if(g===void 0&&!c)throw new R("UserConfigurationError",`Template fragment '${h}' evaluated to undefined. Please ensure that the variable name is spelled correctly and it is only referenced after being assigned a value.`);let f=typeof g=="string"?g:`${g}`;f=f.replaceAll(/\$/g,"$$$$"),m=m.replace(u[0],f)}return m}async function ai(n){return YS(n)}async function YS({obj:n,bannedKeys:e,allowList:t,context:r,prefixPath:o="",replacements:i={},...a}){for(let s in n){if(e.includes(s))continue;let l=!1;if(t)if(t.includes(s))l=!0;else continue;let c=n[s],d=o?`${o}.${s}`:s;if(typeof c=="string"&&c.includes("{{")){let p=await Bt({s:c,context:r,...a});if(c===p)continue;i[d]=c,n[s]=p}else typeof c=="object"&&c!==null&&!Array.isArray(c)&&await YS({obj:c,bannedKeys:e,context:r,prefixPath:d,replacements:i,allowList:l?void 0:t,...a})}return i}import RP from"fetch-retry";var WJ=process.env.MAILINATOR_API_KEY,VJ=RP(global.fetch,{retryOn:function(n,e,t){return n>3?!1:!!(e!==null||t&&t.status>=400)},retryDelay:function(n){return 500}});import IP from"fetch-cookie";import{cloneDeep as PP}from"lodash-es";var AP=3e4;async function il({command:n,logger:e,baseUrl:t,fetchImplementation:r=fetch}){let o=n.timeout??AP/1e3,i=Object.fromEntries(Object.entries(n.headers||{}).filter(([u,h])=>u&&h)),a=new URLSearchParams;Object.entries(n.params||{}).filter(([u,h])=>u&&h).forEach(([u,h])=>{a.append(u,h)});let s=a.toString(),l;if(Mo(n.url)&&(l=n.url),t&&No(n.url,t)&&(l=new URL(n.url,t).toString()),!l)throw new R("ActionFailureError",`Invalid URL: ${n.url}`);e.debug({url:l,searchParams:s,headers:i,body:n.body,method:n.method},"Making HTTP request");let d=await D((async()=>{let u=s?`${l}?${s}`:l;try{return await r(u,{headers:i,method:n.method,body:n.body})}catch(h){throw e.error({err:h},"Failed to make HTTP request"),new Error(`Failed to make HTTP request: ${h}`)}})(),{milliseconds:o*1e3,fallback:()=>{throw new R("ActionFailureError",`Fetch request timed out after ${o} seconds`)}});if(!d.ok){let u;try{u=await d.text()}catch(h){u=`Failed to read response body: ${h}`}throw new R("ActionFailureError",`Fetch request failed with status ${d.status}: ${u}`)}let p={};d.headers.forEach((u,h)=>{p[h]=u});let m={status:d.status,headers:p};return d.headers.get("content-type")?.includes("json")?m.json=await d.json():d.headers.get("content-type")?.includes("text")&&(m.text=await d.text()),m}async function JS(n){let{fixtures:e,inputs:t}=n,{context:r}=e,{orgId:o,step:i}=t,a=PP(i);await ai({obj:a,orgId:o,bannedKeys:["code"],...e});let s=await LP(n);return a.envKey&&s.data&&r.setVariable(a.envKey,s.data),s}async function LP(n){let{fixtures:e,inputs:t}=n,{step:r,orgId:o,baseUrl:i}=t,{cookieJar:a}=e,s=new Date;switch(r.type){case"JAVASCRIPT":{let c=await jn({code:r.code,orgId:o,fragment:!!r.fragment,timeoutMs:r.timeout?r.timeout*1e3:void 0,...e});try{JSON.stringify(c)}catch(d){return{...r,startedAt:s,finishedAt:new Date,status:"FAILED",message:`JavaScript return value is not serializable: ${d instanceof Error?d.message:`${d}`}`}}return{...r,startedAt:s,finishedAt:new Date,message:"JavaScript code executed successfully",status:"SUCCESS",data:c}}case"REQUEST":{let c=IP(fetch,a),d=await il({command:r,logger:e.logger,baseUrl:i,fetchImplementation:c});return{...r,startedAt:s,finishedAt:new Date,status:"SUCCESS",message:"Request executed successfully",data:d}}default:return(c=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(r)}}async function XS(n){let{inputs:e,fixtures:t,callbacks:r}=n,{signal:o}=t,{steps:i,orgId:a,baseUrl:s}=e,{test:l,step:c}=r,d={startedAt:new Date,status:"RUNNING",results:[]},p=d.results,m=new OP,u={cookieJar:m,...t};for(let h of i){let g=new Date;c.onStarted?.(h.id);let f;try{o?.throwIfAborted(),f=await JS({inputs:{step:h,baseUrl:s,orgId:a},fixtures:u})}catch(S){o?.aborted?f={...h,startedAt:g,finishedAt:new Date,status:"CANCELLED",message:"Step cancelled by user."}:f={...h,startedAt:g,finishedAt:new Date,status:"FAILED",message:`Step failed: ${S instanceof Error?S.message:`${S}`}`}}if(p.push(f),c.onFinished?.({result:f,cookies:Ss(m,new URL(s).hostname)}),l.updateAttemptProgress?.({results:p}),f.status!=="SUCCESS"){d.status=f.status==="CANCELLED"?"CANCELLED":"FAILED";break}}return d.status==="RUNNING"&&(d.status="PASSED"),d.finishedAt=new Date,l.onFinished?.(),d}async function ZS(n){let{socket:e,storage:t}=n,r=n.socket.id,{testId:o}=e.handshake.query;if(typeof o!="string")throw new Error(`Received invalid test ID that does not parse as a string: ${o}`);let i=await t.getOrgId({type:"api-test",testId:o}),{baseUrl:a,envName:s,environmentVariables:l}=await Gd({testId:o,orgId:i,logger:n.logger,storage:t,authorization:n.authorization}),c={type:"api-test",orgId:await n.storage.getOrgId({type:"api-test",testId:o}),testId:o,sessionId:r,latestContext:new At({baseUrl:a||"",currentUrl:a||"",variablesFromEnvironment:l,envName:s})};return pr[r]=c,c}async function Gd({testId:n,orgId:e,logger:t,storage:r,authorization:o}){let i=await r.fetchApiTestMetadata(n,e,t);if(!i)throw new Error(`Failed to fetch API test metadata for test ID: ${n}`);let a;o?.type==="API_KEY"&&(a=new dr({httpClient:new kt({...o,logger:t}),fakerSeed:void 0}));let s=i.envs?.find(p=>p.default),l;s&&(l=await r.fetchEnvironment(e,s.name,t));let c=i.baseUrl||l?.variables?.[Ge];if(!c)throw new Error("Base URL is empty in both API test options and the configured environment");let d={...l?.variables};return{baseUrl:c,envName:l?.name,environmentVariables:d,localCodeEvalTools:a}}var kP=n=>async(e,t)=>{let{steps:r}=e,{authorization:o,metadata:i,socket:a,storage:s,logger:l,flagStoreFactory:c}=n,{orgId:d,testId:p,sessionId:m}=i,u=l.child({testId:p,orgId:d,sessionId:m}),h=pr[m];if(!h)throw new Error(`No api testing session with id ${m} could be found. Please reconnect and try again.`);let g=new AbortController;h.abort=g;let f=h.latestContext,{localCodeEvalTools:S,baseUrl:b}=await Gd({testId:p,orgId:d,logger:u,storage:s,authorization:o}),w={context:f,logger:u,localTools:S,signal:g.signal,flagStore:await c(d)},C=await XS({inputs:{steps:r,orgId:d,baseUrl:b},fixtures:w,callbacks:{test:{onFinished:()=>{a.emit("apiTestFinished")}},step:{onStarted:A=>{a.emit("apiStepStarted",A)},onFinished:A=>{a.emit("apiStepFinished",A)}}}});t({result:C})},QS={event:"executeApiTest",createHandler:kP};var MP=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async()=>{e.info({sessionId:t},"Cancel event received");let r=Q.getSession(t);if(!r)throw new Error("No active session found");try{r.controller.setClosed()}catch{}}},ey={event:"cancel",createHandler:MP};var NP=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async(r,o)=>{let i=Q.getSession(t);if(!i)throw new Error("No active session found");i.controller.setOpen();let a=i.controller.browser;try{let s=await a.getBrowserState({skipWait:!0});o({a11yTree:s.serialize()})}catch(s){e.error({err:s},"Error fetching a11y tree from the browser"),o({err:s.message})}}},ty={event:"fetchA11yTree",createHandler:NP};var _P=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async(r,o)=>{let i=Q.getSession(t);if(!i)throw new Error("No active session found");i.controller.setOpen();let a=i.controller.browser;try{let s=await a.html();o({html:s})}catch(s){e.error({err:s},"Error fetching DOM from the browser"),s.name==="TimeoutError"?o({err:"Timed out fetching DOM tree. This page may be too large for Momentic to process."}):o({err:s.message})}}},ny={event:"fetchDom",createHandler:_P};var DP=({metadata:n,logger:e})=>{let{sessionId:t,type:r}=n;return o=>{e.info({sessionId:t,reason:o},`Disconnect event received (${o})`),r==="e2e"?Q.removeSession(t,e):r==="api-test"&&delete pr[t]}},ry={event:"disconnect",createHandler:DP};function en(n){let{result:e,nestedResults:t}=n;if(!n.nestedResults.length)return;let{firstMetadata:r,lastMetadata:o}=FP(t);UP(e,r,o);let i=[...n.asyncTasks];n.asyncTasks.push((async()=>{try{await BP(i,e,r,o)}catch(a){n.logger.error({result:n.result,err:a},"Error hoisting scalar result metadata")}})())}function FP(n){let e=n[0],t;for(;;){switch(e.type){case"PRESET_ACTION":{t=e;break}case"CONDITIONAL":if(e.assertion){t=e;break}break;case"AI_ACTION_DYNAMIC":case"AI_ACTION":case"MODULE":case"SECTION":case"IFRAME":if(!e.results.length){t=e;break}e=e.results[e.results.length-1];break;default:return(a=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(e)}if(t)break}let r=n[n.length-1],o;for(;;){switch(r.type){case"PRESET_ACTION":{o=r;break}case"AI_ACTION_DYNAMIC":case"CONDITIONAL":case"AI_ACTION":case"MODULE":case"SECTION":case"IFRAME":if(!r.results.length){o=r;break}r=r.results[r.results.length-1];break;default:return(a=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(r)}if(o)break}return{firstMetadata:t,lastMetadata:o}}function UP(n,e,t){e&&(n.beforeUrl=e.beforeUrl),t&&(n.afterUrl=t.afterUrl,n.data=t.data,t.status!=="SUCCESS"&&(n.message=t.message))}async function BP(n,e,t,r){await Promise.allSettled(n),t&&(e.beforeSnapshot=t.beforeSnapshot),r&&(e.afterSnapshot=r.afterSnapshot)}import Ta from"os";import zP from"v8";var oy,Cn,HP=Ta.platform(),jP=Ta.cpus().map(n=>({model:n.model,speed:n.speed}));function iy(n){let e=()=>{try{let t=!1,r=$P(),o=GP();r.freeMemory<1e6&&(t=!0);let i=zP.getHeapStatistics(),a=i.used_heap_size,s=i.heap_size_limit;a/s>.9&&(t=!0),t?n.warn({memory:r,cpu:o,heapStats:i},"Critical resource usage metrics detected"):n.debug({memory:r,cpu:o},"Got machine resource usage metrics")}catch{}};return e(),{interval:setInterval(e,1e4),cpuMetadata:jP,platform:HP}}function $P(){let n=Ta.totalmem(),e=Ta.freemem(),t=n-e;return{totalMemory:n,freeMemory:e,usedMemory:t}}function GP(){let n=Ta.cpus(),e=Date.now(),t={measurementTime:e,user:0,nice:0,sys:0,idle:0,irq:0,total:0};for(let o of n)t.user+=o.times.user,t.nice+=o.times.nice,t.sys+=o.times.sys,t.idle+=o.times.idle,t.irq+=o.times.irq;if(t.total=t.user+t.nice+t.sys+t.idle+t.irq,!Cn)return Cn=t,null;let r={user:t.user-Cn.user,nice:t.nice-Cn.nice,sys:t.sys-Cn.sys,idle:t.idle-Cn.idle,irq:t.irq-Cn.irq,total:t.total-Cn.total};return oy={measurementTime:e,intervalMs:e-Cn.measurementTime,user:r.user/r.total*100,nice:r.nice/r.total*100,sys:r.sys/r.total*100,idle:r.idle/r.total*100,irq:r.irq/r.total*100,total:100-r.idle/r.total*100},Cn=t,oy}import{hostname as YP}from"os";async function sy(n){let{command:e,tracer:t,timeoutMs:r,targetingWrapper:o,disableCache:i,fixtures:a}=n,{logger:s,abortSignal:l}=a;if(e.target&&!Xn(e.target))throw new Error("Element assertion with x/y is not supported yet");let c=e.assertion.type==="ELEMENT_EXISTENCE"&&e.assertion.negated,d=Date.now(),p=0,m,u=500;for(;p<2||Date.now()-d<r;){p++,p>1&&await te(u,l),l?.throwIfAborted();try{let{newTarget:h,elementInteractedDisplayString:g,result:f}=await o({ctx:a.ctx,tracer:t,command:e,target:e.target,cache:e.cache?.target,action:async S=>WP(S.locator,n),options:{disableCache:i,useSelector:!!e.useSelector,iframeUrl:e.iframeUrl,disableGlobalLocatorRedirect:!0,source:Rr(e)}});if(m={success:f.success,data:f.data,err:f.err,newTarget:h,elementInteractedDisplayString:g},!f.success){m=f,u=Math.min(u*2,1e4);continue}return m}catch(h){if(l?.throwIfAborted(),c)return{success:!0,thoughts:`The element described does not exist on the page: ${h.message}`};if(s.warn({err:h},"Element assertion ended in error, retrying..."),!(h instanceof R)||h.reason!="ActionFailureError")throw h;m={success:!1,err:h}}}if(!m)throw new Error(`Failed to evaluate manual element assertion in ${r}ms.`);return m}async function WP(n,{command:e,fixtures:t}){let r=e.assertion;await t.browser.highlight(n);let o=!0,i,a;switch(r.type){case"ELEMENT_CONTENT":{let s=await n.textContent()??"";if(a={elementTextContent:He(s,500,!0)},!ay(s,r.value,r.operation,!!r.negated)){let l=r.negated?or[r.operation]:ir[r.operation];o=!1,i=new R("AssertionFailureError",`The content ${l} '${r.value}': ${s}`)}break}case"ELEMENT_ATTRIBUTE":{a={elementOuterHtml:He(await n.evaluate(l=>l.cloneNode(!1).outerHTML),500,!0)};let s;try{s=await n.getAttribute(r.attr,{timeout:3e3})??""}catch(l){i=new R("AssertionFailureError",`The element does not have an attribute named ${r.attr}: ${l}`),o=!1;break}if(!ay(s,r.value,r.operation,!!r.negated)){let l=r.negated?or[r.operation]:ir[r.operation];o=!1,r.operation==="EXISTS"?i=r.negated?new R("AssertionFailureError",`The attribute ${r.attr} ${l}: ${s}`):new R("AssertionFailureError",`The attribute ${r.attr} ${l}`):i=new R("AssertionFailureError",`The attribute ${r.attr} ${l} '${r.value}': ${s}`)}break}case"ELEMENT_EXISTENCE":{switch(r.condition){case"VISIBLE":{o=await n.isVisible({timeout:wn*1e3});break}case"EDITABLE":{o=await n.isEditable({timeout:wn*1e3});break}case"EXISTS":{o=!0;break}case"ENABLED":{o=await n.isEnabled({timeout:wn*1e3});break}default:return(l=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(r.condition)}if(o=r.negated?!o:o,!o){let s=r.negated?od[r.condition]:id[r.condition];i=new R("AssertionFailureError",`The element ${s}`)}break}}return{success:o,data:a,err:i}}function ay(n,e,t,r){let o;switch(t){case"CONTAINS":{o=n.includes(e);break}case"EQUALS":{o=n.trim()===e.trim();break}case"STARTS_WITH":{o=n.trim().startsWith(e);break}case"EXISTS":{o=n.trim().length>0;break}default:return(a=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(t)}return r?!o:o}import{Jimp as VP}from"jimp";async function xa(n,e){let t=await n.screenshot(e),r=await VP.fromBuffer(t);return{buffer:t,width:Math.ceil(r.bitmap.width??0),height:Math.ceil(r.bitmap.height??0)}}import{Jimp as ly}from"jimp";import Wd from"jpeg-js";import qP from"pixelmatch";async function cy({ctx:n,tracer:e,command:t,disableCache:r,browser:o,targetingWrapper:i,logger:a,screenshotStorage:s}){if(t.target&&!Xn(t.target))throw new Error("Visual Diff with x/y is not supported yet");await o.waitForDOMStability({logger:a});let l={clearHighlights:!0,hideCaret:!0},c;t.target?.elementDescriptor?c=(await i({ctx:n,tracer:e,command:t,target:t.target,cache:t.cache?.target??t.target?.a11yData,action:async F=>xa(o,{locator:F.locator,...l}),options:{disableCache:!!r,useSelector:!!t.useSelector,iframeUrl:t.iframeUrl,disableGlobalLocatorRedirect:!0}})).result:c=await xa(o,l);let d=await s.prepareGoldenScreenshotForComparison(a,t,c);if((c.height!==d.height||c.width!==d.width)&&a.debug({currHeight:c.height,currWidth:c.width,savedHeight:d.height,savedWidth:d.width},"Mismatched before and after visual diff screenshot sizes"),Math.abs(c.height-d.height)>10||Math.abs(c.width-d.width)>10){let H=`${c.width}x${c.height}`,F=`${d.width}x${d.height}`;return{fail:!0,thoughts:`Current screenshot (${H}) does not match saved screenshot dimensions (${F}) - did you change the size of the target or the viewport?`,beforeScreenshotOverride:d.buffer,afterScreenshotOverride:c.buffer,succeedImmediately:!1,urlAfterCommand:o.url()}}let p=await ly.fromBuffer(c.buffer),m={width:c.width,height:c.height},u=await ly.fromBuffer(d.buffer),h={width:d.width,height:d.height},g,f=m.width*m.height,S=h.width*h.height,b=Math.abs(m.height-h.height),w=Math.abs(m.width-h.width);if(f>S){let H=p.cover({w:h.width,h:h.height});c.buffer=await H.getBuffer("image/jpeg"),g="current",c.width=h.width,c.height=h.height}else if(S>f){let H=u.cover({w:m.width,h:m.height});d.buffer=await H.getBuffer("image/jpeg"),g="saved"}let v={data:Buffer.alloc(c.width*c.height*4),width:c.width,height:c.height},x=t.threshold??.1,A=qP(Wd.decode(d.buffer).data,Wd.decode(c.buffer).data,v.data,c.width,c.height,{threshold:x,diffColorAlt:[0,255,0]})/(c.width*c.height)*100,N=A>x*100,O=`Visual diff of ${A.toFixed(2)}% detected, which is ${N?"over":"under"} the threshold of ${x*100}%.`;if(g&&(O+=` The ${g} screenshot was cropped since it was taller by ${b} pixels and wider by ${w} pixels.`),N)throw new R("ActionFailureError",O);return{fail:N,thoughts:O,beforeScreenshotOverride:c.buffer,afterScreenshotOverride:Wd.encode(v,75).data,succeedImmediately:!1,urlAfterCommand:o.url()}}var KP=5e3;async function al({timeout:n=wn,...e}){let t=Date.now(),r=n*1e3,o=r+1e4,i,a=0,s=500;for(;a-t<r;){if(Date.now()-t>o){e.logger.warn("Exceeded max system timeout for page assertion, exiting...");break}e.signal.throwIfAborted();let l=Date.now();i=await dy(e),a=Date.now();let c=a-l;if(c>1e3&&e.logger.warn({pageAssertDuration:c},"Page assertion took longer than expected"),!i.success)await te(s,e.signal),s=Math.min(Math.floor(s*1.5),KP);else return i}return i=await dy(e),i}async function dy({assertion:n,browser:e,flagStore:t}){switch(n.type){case"CONTENT":{let o,i=!1,a;try{let s;if(t.isBooleanFlagEnabled("auto_expand_iframes")){let l=await e.evaluateFunctionInAllFrames(py,{value:n.value,negated:!!n.negated,returnHtml:!1});i=n.negated?l.every(c=>c.evaluation):l.some(c=>c.evaluation),s=l.find(c=>c.pageHtml)?.pageHtml}else({evaluation:i,pageHtml:s}=await e.evaluateFunctionInPage(py,{value:n.value,negated:!!n.negated,returnHtml:!0}));if(!i){let l=n.negated?or.CONTAINS:ir.CONTAINS;a=new R("AssertionFailureError",`The page ${l} '${n.value}'.`),o=s}}catch(s){a=new R("AssertionFailureError",`Failed to evaluate page content assertion: ${s instanceof Error?s.message:`${s}`}`)}return{success:i,err:a,data:i||!o?void 0:{pageContent:o}}}default:return(o=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n.type)}}function py({value:n,negated:e,returnHtml:t}){let r=document.documentElement.outerHTML,o=r.includes(n)===!e;return r.length>1e4&&(r=r.slice(0,1e4)+"...TRUNCATED"),{evaluation:o,pageHtml:!o&&t?r:void 0}}var Vd=async n=>{let{step:e,resolvedInputs:t}=n.moduleParams,{logger:r,context:o,storage:i,codeEvalTools:a,controller:s}=n.fixtures,l=s.browser,{orgId:c,runId:d}=n.inputs,p=s.executeAbortController.signal;Object.keys(t).length>0&&(o.setInputs(t),r.debug({inputs:t,moduleId:e.moduleId},"Set module inputs"));let m,u=!1,h,g;if(e.cacheConfig||e.defaultCacheAllInvocations){let f=e.cacheConfig?.cacheKey||e.defaultCacheKey||"",S=await Bt({orgId:c,s:f,context:o,logger:r,localTools:a,signal:p,flagStore:s.flagStore});g={orgId:c,cacheKeys:[S,...Object.entries(t).map(([w,v])=>`${w}:${v}`)]},r.debug({original:f,keyParams:g},"Module cache key params");let b=Date.now();for(;Date.now()-b<Mh;){p?.throwIfAborted();let w=await i.getCacheResult(g);if(w){r.debug({cacheResult:w},"Got result from module execution cache"),m=sl(e,t,"SUCCESS"),m.message="Used cached module result.",m.data=JSON.parse(w),u=!0;break}else r.debug({cacheKey:f,keyParams:g},"No cache result found, continuing with lock acquisition");let v=await i.acquireCacheLock({keyParams:g,clientMetadata:`hostName:${YP()};runId:${d}`},p);if(v.acquired){h=v.keyPrefix,r.info({cacheKeyPrefixIfLockAcquired:h,cacheKey:f,keyParams:g},"Acquired cache lock and proceeding with module execution");break}else r.debug({cacheKeyPrefixIfLockAcquired:h,cacheKey:f,keyParams:g},"Failed to acquire cache lock, retrying...");await te(2500+Math.random()*1e4,p)}}try{if(!m)m=await JP(n);else if(e.autoAuth){let f=fs.safeParse(m.data);if(!f.success)throw new R("UserConfigurationError",`Cached authentication module result is not a valid storage state: ${f.error.message}`);r.debug("Automatically loading auth state after cached module result"),await l.loadAuthState(f.data);let S=!1,b=e.advanced?.cacheInvalidation;if(b&&b.type==="PAGE_CHECK"){let w={type:"CONTENT",value:b.substring},v=await al({timeout:wn,assertion:w,browser:l,flagStore:s.flagStore,logger:r,signal:p});v.success?r.debug({invalResult:v},"Cached result still valid after page check, continuing..."):(r.info({invalResult:v},"Invalidating cached result due to page check failure"),S=!0)}if(g&&S)return await i.deleteCacheResult(g),Vd(n)}}finally{try{h!==void 0&&!u&&m?.status==="SUCCESS"&&await XP({step:e,result:m,browser:s.browser,cacheKeyPrefix:h,logger:r,storage:i})}finally{h!==void 0&&await i.releaseCacheLock(h)}}return m},JP=async n=>{let{step:e,tracer:t}=n.moduleParams,r=sl(e,n.moduleParams.resolvedInputs,"SUCCESS"),o=await t.startSubSteps(),{status:i,results:a}=await ur(n.work,()=>n.executeStepList({...n,listParams:{steps:e.steps,containerName:`module ('${e.name}')`,tracer:o}}));return r.results=a,r.status=i,r.finishedAt=new Date,en({asyncTasks:n.work.asyncTasks,nestedResults:a,result:r,logger:n.fixtures.logger}),r};function sl(n,e,t){let r={};return Object.entries(e).forEach(([i,a])=>{r[i]=JSON.stringify(a)}),{type:"MODULE",id:n.id,moduleId:n.moduleId,moduleName:n.name,startedAt:new Date,cacheConfig:n.cacheConfig,inputs:r,results:[],finishedAt:new Date,status:t}}async function uy({orgId:n,step:e,context:t,logger:r,flagStore:o,codeEvalTools:i,signal:a}){let s={};try{for(let l of e.parameters??[]){let c=e.inputs?.[l]??e.defaultParameters?.[l];if(!c){r.warn(`No value or default found for parameter '${l}' that is required by module '${e.name}'`);continue}s[l]=await jn({orgId:n,code:c,fragment:!0,context:t,logger:r,localTools:i,signal:a,flagStore:o})}return s}catch(l){throw a?.throwIfAborted(),new R("UserConfigurationError",`Failed to evaluate module inputs: ${l}`)}}async function XP({step:n,result:e,browser:t,cacheKeyPrefix:r,logger:o,storage:i}){let a=n.cacheConfig?.cacheExpiryMs;(!a||a===Sg)&&(a=n.defaultCacheTtl??yg);let s;n.autoAuth?s=JSON.stringify(await t.saveAuthState()):e.data!==void 0?s=JSON.stringify(e.data):s='""',o.debug({cacheKeyPrefix:r,ttlMs:a,truncatedCacheResultJson:Gg(s)},"Setting module cache result"),await i.setCacheResult({result:s,keyPrefix:r,ttlMs:a})}async function mr(n,e,t){let r=new Date;try{return t.throwIfAborted(),await e()}catch(o){let i=new Date,a="FAILED",s;if(t.aborted||o instanceof DOMException&&o.name==="AbortError"?(s="Step aborted by user.",a="CANCELLED"):o instanceof R?s=`${o}`:s=`An unexpected error occurred: ${o.message}`,n.type==="RESOLVED_MODULE"){let l=sl(n,{},"FAILED");return l.message=s,l.startedAt=r,l.finishedAt=i,l}return{...ks(n),startedAt:r,finishedAt:i,status:a,data:null,message:s,results:[]}}}async function ur(n,e){let t=!1;try{return n&&!n.state.failureRecoveryDisabled&&(n.state.failureRecoveryDisabled=!0,t=!0),await e()}finally{n&&t&&(n.state.failureRecoveryDisabled=void 0)}}import{randomUUID as my}from"crypto";import{cloneDeep as QP}from"lodash-es";function ll(n,e){n.state.healingDetails?n.state.healingDetails.push(e):n.state.healingDetails=[e]}var cl=async n=>{let{step:e,tracer:t}=n.presetParams,{logger:r,controller:o,context:i,billingReporter:a}=n.fixtures,{collectDebugData:s}=n.options,{testMetadata:l,suiteMetadata:c}=n.inputs,d=e.command.type,p=r.child({commandType:d,stepId:e.id,commandId:e.command.id}),m=Ki(e.command);n.work.asyncTasks.push(a.reportCreditsUsed(p,d,m,{testId:l?.id,testName:l?.name,suiteId:c?.id,suiteName:c?.name}));let u=o.browser.url(),h=new Date,g,f=my(),S=my();if(s)try{g=await o.browser.screenshot({retries:1,clearHighlights:!0});let C=await o.browser.getRawCondensedHtml();t.attachBeforeHtmlSnapshot({logger:p,snapshotId:f,html:C}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeHtmlSnapshot(p,f,C))}catch(C){p.debug({err:C},"Failed to take screenshot before step, likely because the page is still loading. This is non-fatal and does not affect the test.")}let b,w,v,x=us();try{let C=await o.executePresetCommand(x,t,e.command,i,l?.advanced.disableAICaching??!1);C.beforeScreenshotOverride&&(g=C.beforeScreenshotOverride),v=C.afterScreenshotOverride;let{proposedStep:A}=eL({work:n.work,step:e,newTargets:C.newTargets,logger:p}),N=new Date,O=o.browser.url();w={beforeUrl:u,afterUrl:O,startedAt:h,finishedAt:N,viewport:o.browser.getViewport(),status:C.fail?"FAILED":"SUCCESS",elementInteracted:C.elementInteracted},b={...e,message:C.thoughts??tL(C.newTargets)??"Successfully executed preset action.",beforeUrl:u,afterUrl:O,finishedAt:N,startedAt:h,status:C.fail?"FAILED":"SUCCESS",data:C.data,results:[w],details:x.details,proposedStep:A},"assertion"in e.command&&(b.message=C.thoughts||"Assertion passed.")}catch(C){p.error({message:C.message,stack:C.stack},`Failed executing preset step ${_r(e.command)}`);let A=o.browser.url(),N=new Date,O=C instanceof Error?C.message:`${C}`;C instanceof R&&C.getLastScreenshotBuffer()&&(v=C.getLastScreenshotBuffer()),w={beforeUrl:u,afterUrl:A,startedAt:h,finishedAt:N,viewport:o.browser.getViewport(),status:C instanceof DOMException&&C.name==="AbortError"?"CANCELLED":"FAILED",message:O},b={...e,startedAt:h,finishedAt:N,beforeUrl:u,afterUrl:A,status:C instanceof DOMException&&C.name==="AbortError"?"CANCELLED":"FAILED",message:O,failureReason:C instanceof R?C.reason:void 0,results:[w],details:x.details}}if(s)try{v||(v=await o.browser.screenshot({retries:1}));let C=await o.browser.getRawCondensedHtml();t.attachAfterHtmlSnapshot({logger:p,snapshotId:S,html:C}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeHtmlSnapshot(p,S,C))}catch(C){p.debug({err:C},"Failed store debug data after step, likely because the page is still loading. This is non-fatal and does not affect the test.")}return w.beforeSnapshot=f,b.beforeSnapshot=f,w.afterSnapshot=S,b.afterSnapshot=S,g&&(t.attachBeforeScreenshot({logger:p,snapshotId:f,screenshot:g}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(p,f,g))),v&&(t.attachAfterScreenshot({logger:p,snapshotId:S,screenshot:v}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(p,S,v))),b};function eL({work:n,step:e,newTargets:t,logger:r}){if(!t?.length)return{proposedStep:void 0};let o=e.command;Fg(o,t,r);let i=t[0]?.description;if(i&&"target"in o&&o.target&&o.target.type==="description"){let a={...o,target:{...o.target,elementDescriptor:i}},s={...QP(e),command:a};return ll(n,{type:"DESCRIPTION_UPDATE",thoughts:`Updated element description after the original element could not be found on the page. New element location reasoning: ${t[0]?.thoughts}`}),{proposedStep:s}}return{proposedStep:void 0}}function tL(n){if(n?.length){if(n.length===1&&n[0]?.thoughts)return n[0].thoughts;if(n.length===2&&n.every(e=>e.thoughts))return`Located first element: ${n[0]?.thoughts}
52
+ ${n.code}`;throw n.logger.error({err:e.error,code:n.code,env:n.context.toObjectCopy()},t),new Error(t)}if(e.variableUpdates)for(let[t,r]of Object.entries(e.variableUpdates))n.context.setVariable(t,r);if(e.persistentVariableUpdates&&Object.keys(e.persistentVariableUpdates).length>0){await n.callbacks?.onPersistentVariableUpdates?.(e.persistentVariableUpdates);for(let[t,r]of Object.entries(e.persistentVariableUpdates))n.context.setVariable(t,r)}return e.result}async function Bt(n){let{orgId:e,s:t,context:r,logger:o,signal:i,flagStore:a,retries:s=2,timeoutMs:l=tr,allowUndefined:c=!1}=n,d=/{{(.*?)}}/g,p=t.matchAll(d),m=t;for(let u of p){if(u.length<2)continue;let h=u[1].trim(),g;try{g=await jn({orgId:e,code:h,fragment:!0,context:r,timeoutMs:l,logger:o,retries:s,localTools:n.localTools,signal:i,flagStore:a})}catch(S){throw o.error({err:S,value:t},"Error evaluating template string"),S}if(g===void 0&&!c)throw new R("UserConfigurationError",`Template fragment '${h}' evaluated to undefined. Please ensure that the variable name is spelled correctly and it is only referenced after being assigned a value.`);let f=typeof g=="string"?g:`${g}`;f=f.replaceAll(/\$/g,"$$$$"),m=m.replace(u[0],f)}return m}async function ii(n){return YS(n)}async function YS({obj:n,bannedKeys:e,allowList:t,context:r,prefixPath:o="",replacements:i={},...a}){for(let s in n){if(e.includes(s))continue;let l=!1;if(t)if(t.includes(s))l=!0;else continue;let c=n[s],d=o?`${o}.${s}`:s;if(typeof c=="string"&&c.includes("{{")){let p=await Bt({s:c,context:r,...a});if(c===p)continue;i[d]=c,n[s]=p}else typeof c=="object"&&c!==null&&!Array.isArray(c)&&await YS({obj:c,bannedKeys:e,context:r,prefixPath:d,replacements:i,allowList:l?void 0:t,...a})}return i}import RP from"fetch-retry";var WJ=process.env.MAILINATOR_API_KEY,VJ=RP(global.fetch,{retryOn:function(n,e,t){return n>3?!1:!!(e!==null||t&&t.status>=400)},retryDelay:function(n){return 500}});import IP from"fetch-cookie";import{cloneDeep as PP}from"lodash-es";var AP=3e4;async function il({command:n,logger:e,baseUrl:t,fetchImplementation:r=fetch}){let o=n.timeout??AP/1e3,i=Object.fromEntries(Object.entries(n.headers||{}).filter(([u,h])=>u&&h)),a=new URLSearchParams;Object.entries(n.params||{}).filter(([u,h])=>u&&h).forEach(([u,h])=>{a.append(u,h)});let s=a.toString(),l;if(ko(n.url)&&(l=n.url),t&&Mo(n.url,t)&&(l=new URL(n.url,t).toString()),!l)throw new R("ActionFailureError",`Invalid URL: ${n.url}`);e.debug({url:l,searchParams:s,headers:i,body:n.body,method:n.method},"Making HTTP request");let d=await D((async()=>{let u=s?`${l}?${s}`:l;try{return await r(u,{headers:i,method:n.method,body:n.body})}catch(h){throw e.error({err:h},"Failed to make HTTP request"),new Error(`Failed to make HTTP request: ${h}`)}})(),{milliseconds:o*1e3,fallback:()=>{throw new R("ActionFailureError",`Fetch request timed out after ${o} seconds`)}});if(!d.ok){let u;try{u=await d.text()}catch(h){u=`Failed to read response body: ${h}`}throw new R("ActionFailureError",`Fetch request failed with status ${d.status}: ${u}`)}let p={};d.headers.forEach((u,h)=>{p[h]=u});let m={status:d.status,headers:p};return d.headers.get("content-type")?.includes("json")?m.json=await d.json():d.headers.get("content-type")?.includes("text")&&(m.text=await d.text()),m}async function JS(n){let{fixtures:e,inputs:t}=n,{context:r}=e,{orgId:o,step:i}=t,a=PP(i);await ii({obj:a,orgId:o,bannedKeys:["code"],...e});let s=await LP(n);return a.envKey&&s.data&&r.setVariable(a.envKey,s.data),s}async function LP(n){let{fixtures:e,inputs:t}=n,{step:r,orgId:o,baseUrl:i}=t,{cookieJar:a}=e,s=new Date;switch(r.type){case"JAVASCRIPT":{let c=await jn({code:r.code,orgId:o,fragment:!!r.fragment,timeoutMs:r.timeout?r.timeout*1e3:void 0,...e});try{JSON.stringify(c)}catch(d){return{...r,startedAt:s,finishedAt:new Date,status:"FAILED",message:`JavaScript return value is not serializable: ${d instanceof Error?d.message:`${d}`}`}}return{...r,startedAt:s,finishedAt:new Date,message:"JavaScript code executed successfully",status:"SUCCESS",data:c}}case"REQUEST":{let c=IP(fetch,a),d=await il({command:r,logger:e.logger,baseUrl:i,fetchImplementation:c});return{...r,startedAt:s,finishedAt:new Date,status:"SUCCESS",message:"Request executed successfully",data:d}}default:return(c=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(r)}}async function XS(n){let{inputs:e,fixtures:t,callbacks:r}=n,{signal:o}=t,{steps:i,orgId:a,baseUrl:s}=e,{test:l,step:c}=r,d={startedAt:new Date,status:"RUNNING",results:[]},p=d.results,m=new OP,u={cookieJar:m,...t};for(let h of i){let g=new Date;c.onStarted?.(h.id);let f;try{o?.throwIfAborted(),f=await JS({inputs:{step:h,baseUrl:s,orgId:a},fixtures:u})}catch(S){o?.aborted?f={...h,startedAt:g,finishedAt:new Date,status:"CANCELLED",message:"Step cancelled by user."}:f={...h,startedAt:g,finishedAt:new Date,status:"FAILED",message:`Step failed: ${S instanceof Error?S.message:`${S}`}`}}if(p.push(f),c.onFinished?.({result:f,cookies:Ss(m,new URL(s).hostname)}),l.updateAttemptProgress?.({results:p}),f.status!=="SUCCESS"){d.status=f.status==="CANCELLED"?"CANCELLED":"FAILED";break}}return d.status==="RUNNING"&&(d.status="PASSED"),d.finishedAt=new Date,l.onFinished?.(),d}async function ZS(n){let{socket:e,storage:t}=n,r=n.socket.id,{testId:o}=e.handshake.query;if(typeof o!="string")throw new Error(`Received invalid test ID that does not parse as a string: ${o}`);let i=await t.getOrgId({type:"api-test",testId:o}),{baseUrl:a,envName:s,environmentVariables:l}=await Gd({testId:o,orgId:i,logger:n.logger,storage:t,authorization:n.authorization}),c={type:"api-test",orgId:await n.storage.getOrgId({type:"api-test",testId:o}),testId:o,sessionId:r,latestContext:new At({baseUrl:a||"",currentUrl:a||"",variablesFromEnvironment:l,envName:s})};return pr[r]=c,c}async function Gd({testId:n,orgId:e,logger:t,storage:r,authorization:o}){let i=await r.fetchApiTestMetadata(n,e,t);if(!i)throw new Error(`Failed to fetch API test metadata for test ID: ${n}`);let a;o?.type==="API_KEY"&&(a=new dr({httpClient:new kt({...o,logger:t}),fakerSeed:void 0}));let s=i.envs?.find(p=>p.default),l;s&&(l=await r.fetchEnvironment(e,s.name,t));let c=i.baseUrl||l?.variables?.[Ge];if(!c)throw new Error("Base URL is empty in both API test options and the configured environment");let d={...l?.variables};return{baseUrl:c,envName:l?.name,environmentVariables:d,localCodeEvalTools:a}}var kP=n=>async(e,t)=>{let{steps:r}=e,{authorization:o,metadata:i,socket:a,storage:s,logger:l,flagStoreFactory:c}=n,{orgId:d,testId:p,sessionId:m}=i,u=l.child({testId:p,orgId:d,sessionId:m}),h=pr[m];if(!h)throw new Error(`No api testing session with id ${m} could be found. Please reconnect and try again.`);let g=new AbortController;h.abort=g;let f=h.latestContext,{localCodeEvalTools:S,baseUrl:b}=await Gd({testId:p,orgId:d,logger:u,storage:s,authorization:o}),w={context:f,logger:u,localTools:S,signal:g.signal,flagStore:await c(d)},C=await XS({inputs:{steps:r,orgId:d,baseUrl:b},fixtures:w,callbacks:{test:{onFinished:()=>{a.emit("apiTestFinished")}},step:{onStarted:A=>{a.emit("apiStepStarted",A)},onFinished:A=>{a.emit("apiStepFinished",A)}}}});t({result:C})},QS={event:"executeApiTest",createHandler:kP};var MP=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async()=>{e.info({sessionId:t},"Cancel event received");let r=Q.getSession(t);if(!r)throw new Error("No active session found");try{r.controller.setClosed()}catch{}}},ey={event:"cancel",createHandler:MP};var NP=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async(r,o)=>{let i=Q.getSession(t);if(!i)throw new Error("No active session found");i.controller.setOpen();let a=i.controller.browser;try{let s=await a.getBrowserState({skipWait:!0});o({a11yTree:s.serialize()})}catch(s){e.error({err:s},"Error fetching a11y tree from the browser"),o({err:s.message})}}},ty={event:"fetchA11yTree",createHandler:NP};var _P=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async(r,o)=>{let i=Q.getSession(t);if(!i)throw new Error("No active session found");i.controller.setOpen();let a=i.controller.browser;try{let s=await a.html();o({html:s})}catch(s){e.error({err:s},"Error fetching DOM from the browser"),s.name==="TimeoutError"?o({err:"Timed out fetching DOM tree. This page may be too large for Momentic to process."}):o({err:s.message})}}},ny={event:"fetchDom",createHandler:_P};var DP=({metadata:n,logger:e})=>{let{sessionId:t,type:r}=n;return o=>{e.info({sessionId:t,reason:o},`Disconnect event received (${o})`),r==="e2e"?Q.removeSession(t,e):r==="api-test"&&delete pr[t]}},ry={event:"disconnect",createHandler:DP};function en(n){let{result:e,nestedResults:t}=n;if(!n.nestedResults.length)return;let{firstMetadata:r,lastMetadata:o}=FP(t);UP(e,r,o);let i=[...n.asyncTasks];n.asyncTasks.push((async()=>{try{await BP(i,e,r,o)}catch(a){n.logger.error({result:n.result,err:a},"Error hoisting scalar result metadata")}})())}function FP(n){let e=n[0],t;for(;;){switch(e.type){case"PRESET_ACTION":{t=e;break}case"CONDITIONAL":if(e.assertion){t=e;break}break;case"AI_ACTION_DYNAMIC":case"AI_ACTION":case"MODULE":case"SECTION":case"IFRAME":if(!e.results.length){t=e;break}e=e.results[e.results.length-1];break;default:return(a=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(e)}if(t)break}let r=n[n.length-1],o;for(;;){switch(r.type){case"PRESET_ACTION":{o=r;break}case"AI_ACTION_DYNAMIC":case"CONDITIONAL":case"AI_ACTION":case"MODULE":case"SECTION":case"IFRAME":if(!r.results.length){o=r;break}r=r.results[r.results.length-1];break;default:return(a=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(r)}if(o)break}return{firstMetadata:t,lastMetadata:o}}function UP(n,e,t){e&&(n.beforeUrl=e.beforeUrl),t&&(n.afterUrl=t.afterUrl,n.data=t.data,t.status!=="SUCCESS"&&(n.message=t.message))}async function BP(n,e,t,r){await Promise.allSettled(n),t&&(e.beforeSnapshot=t.beforeSnapshot),r&&(e.afterSnapshot=r.afterSnapshot)}import Ta from"os";import zP from"v8";var oy,Cn,HP=Ta.platform(),jP=Ta.cpus().map(n=>({model:n.model,speed:n.speed}));function iy(n){let e=()=>{try{let t=!1,r=$P(),o=GP();r.freeMemory<1e6&&(t=!0);let i=zP.getHeapStatistics(),a=i.used_heap_size,s=i.heap_size_limit;a/s>.9&&(t=!0),t?n.warn({memory:r,cpu:o,heapStats:i},"Critical resource usage metrics detected"):n.debug({memory:r,cpu:o},"Got machine resource usage metrics")}catch{}};return e(),{interval:setInterval(e,1e4),cpuMetadata:jP,platform:HP}}function $P(){let n=Ta.totalmem(),e=Ta.freemem(),t=n-e;return{totalMemory:n,freeMemory:e,usedMemory:t}}function GP(){let n=Ta.cpus(),e=Date.now(),t={measurementTime:e,user:0,nice:0,sys:0,idle:0,irq:0,total:0};for(let o of n)t.user+=o.times.user,t.nice+=o.times.nice,t.sys+=o.times.sys,t.idle+=o.times.idle,t.irq+=o.times.irq;if(t.total=t.user+t.nice+t.sys+t.idle+t.irq,!Cn)return Cn=t,null;let r={user:t.user-Cn.user,nice:t.nice-Cn.nice,sys:t.sys-Cn.sys,idle:t.idle-Cn.idle,irq:t.irq-Cn.irq,total:t.total-Cn.total};return oy={measurementTime:e,intervalMs:e-Cn.measurementTime,user:r.user/r.total*100,nice:r.nice/r.total*100,sys:r.sys/r.total*100,idle:r.idle/r.total*100,irq:r.irq/r.total*100,total:100-r.idle/r.total*100},Cn=t,oy}import{hostname as YP}from"os";async function sy(n){let{command:e,tracer:t,timeoutMs:r,targetingWrapper:o,disableCache:i,fixtures:a}=n,{logger:s,abortSignal:l}=a;if(e.target&&!Xn(e.target))throw new Error("Element assertion with x/y is not supported yet");let c=e.assertion.type==="ELEMENT_EXISTENCE"&&e.assertion.negated,d=Date.now(),p=0,m,u=500;for(;p<2||Date.now()-d<r;){p++,p>1&&await te(u,l),l?.throwIfAborted();try{let{newTarget:h,elementInteractedDisplayString:g,result:f}=await o({ctx:a.ctx,tracer:t,command:e,target:e.target,cache:e.cache?.target,action:async S=>WP(S.locator,n),options:{disableCache:i,useSelector:!!e.useSelector,iframeUrl:e.iframeUrl,disableGlobalLocatorRedirect:!0,source:Rr(e)}});if(m={success:f.success,data:f.data,err:f.err,newTarget:h,elementInteractedDisplayString:g},!f.success){m=f,u=Math.min(u*2,1e4);continue}return m}catch(h){if(l?.throwIfAborted(),c)return{success:!0,thoughts:`The element described does not exist on the page: ${h.message}`};if(s.warn({err:h},"Element assertion ended in error, retrying..."),!(h instanceof R)||h.reason!="ActionFailureError")throw h;m={success:!1,err:h}}}if(!m)throw new Error(`Failed to evaluate manual element assertion in ${r}ms.`);return m}async function WP(n,{command:e,fixtures:t}){let r=e.assertion;await t.browser.highlight(n);let o=!0,i,a;switch(r.type){case"ELEMENT_CONTENT":{let s=await n.textContent()??"";if(a={elementTextContent:He(s,500,!0)},!ay(s,r.value,r.operation,!!r.negated)){let l=r.negated?or[r.operation]:ir[r.operation];o=!1,i=new R("AssertionFailureError",`The content ${l} '${r.value}': ${s}`)}break}case"ELEMENT_ATTRIBUTE":{a={elementOuterHtml:He(await n.evaluate(l=>l.cloneNode(!1).outerHTML),500,!0)};let s;try{s=await n.getAttribute(r.attr,{timeout:3e3})??""}catch(l){i=new R("AssertionFailureError",`The element does not have an attribute named ${r.attr}: ${l}`),o=!1;break}if(!ay(s,r.value,r.operation,!!r.negated)){let l=r.negated?or[r.operation]:ir[r.operation];o=!1,r.operation==="EXISTS"?i=r.negated?new R("AssertionFailureError",`The attribute ${r.attr} ${l}: ${s}`):new R("AssertionFailureError",`The attribute ${r.attr} ${l}`):i=new R("AssertionFailureError",`The attribute ${r.attr} ${l} '${r.value}': ${s}`)}break}case"ELEMENT_EXISTENCE":{switch(r.condition){case"VISIBLE":{o=await n.isVisible({timeout:wn*1e3});break}case"EDITABLE":{o=await n.isEditable({timeout:wn*1e3});break}case"EXISTS":{o=!0;break}case"ENABLED":{o=await n.isEnabled({timeout:wn*1e3});break}default:return(l=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(r.condition)}if(o=r.negated?!o:o,!o){let s=r.negated?od[r.condition]:id[r.condition];i=new R("AssertionFailureError",`The element ${s}`)}break}}return{success:o,data:a,err:i}}function ay(n,e,t,r){let o;switch(t){case"CONTAINS":{o=n.includes(e);break}case"EQUALS":{o=n.trim()===e.trim();break}case"STARTS_WITH":{o=n.trim().startsWith(e);break}case"EXISTS":{o=n.trim().length>0;break}default:return(a=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(t)}return r?!o:o}import{Jimp as VP}from"jimp";async function xa(n,e){let t=await n.screenshot(e),r=await VP.fromBuffer(t);return{buffer:t,width:Math.ceil(r.bitmap.width??0),height:Math.ceil(r.bitmap.height??0)}}import{Jimp as ly}from"jimp";import Wd from"jpeg-js";import qP from"pixelmatch";async function cy({ctx:n,tracer:e,command:t,disableCache:r,browser:o,targetingWrapper:i,logger:a,screenshotStorage:s}){if(t.target&&!Xn(t.target))throw new Error("Visual Diff with x/y is not supported yet");await o.waitForDOMStability({logger:a});let l={clearHighlights:!0,hideCaret:!0},c;t.target?.elementDescriptor?c=(await i({ctx:n,tracer:e,command:t,target:t.target,cache:t.cache?.target??t.target?.a11yData,action:async F=>xa(o,{locator:F.locator,...l}),options:{disableCache:!!r,useSelector:!!t.useSelector,iframeUrl:t.iframeUrl,disableGlobalLocatorRedirect:!0}})).result:c=await xa(o,l);let d=await s.prepareGoldenScreenshotForComparison(a,t,c);if((c.height!==d.height||c.width!==d.width)&&a.debug({currHeight:c.height,currWidth:c.width,savedHeight:d.height,savedWidth:d.width},"Mismatched before and after visual diff screenshot sizes"),Math.abs(c.height-d.height)>10||Math.abs(c.width-d.width)>10){let H=`${c.width}x${c.height}`,F=`${d.width}x${d.height}`;return{fail:!0,thoughts:`Current screenshot (${H}) does not match saved screenshot dimensions (${F}) - did you change the size of the target or the viewport?`,beforeScreenshotOverride:d.buffer,afterScreenshotOverride:c.buffer,succeedImmediately:!1,urlAfterCommand:o.url()}}let p=await ly.fromBuffer(c.buffer),m={width:c.width,height:c.height},u=await ly.fromBuffer(d.buffer),h={width:d.width,height:d.height},g,f=m.width*m.height,S=h.width*h.height,b=Math.abs(m.height-h.height),w=Math.abs(m.width-h.width);if(f>S){let H=p.cover({w:h.width,h:h.height});c.buffer=await H.getBuffer("image/jpeg"),g="current",c.width=h.width,c.height=h.height}else if(S>f){let H=u.cover({w:m.width,h:m.height});d.buffer=await H.getBuffer("image/jpeg"),g="saved"}let v={data:Buffer.alloc(c.width*c.height*4),width:c.width,height:c.height},x=t.threshold??.1,A=qP(Wd.decode(d.buffer).data,Wd.decode(c.buffer).data,v.data,c.width,c.height,{threshold:x,diffColorAlt:[0,255,0]})/(c.width*c.height)*100,N=A>x*100,O=`Visual diff of ${A.toFixed(2)}% detected, which is ${N?"over":"under"} the threshold of ${x*100}%.`;if(g&&(O+=` The ${g} screenshot was cropped since it was taller by ${b} pixels and wider by ${w} pixels.`),N)throw new R("ActionFailureError",O);return{fail:N,thoughts:O,beforeScreenshotOverride:c.buffer,afterScreenshotOverride:Wd.encode(v,75).data,succeedImmediately:!1,urlAfterCommand:o.url()}}var KP=5e3;async function al({timeout:n=wn,...e}){let t=Date.now(),r=n*1e3,o=r+1e4,i,a=0,s=500;for(;a-t<r;){if(Date.now()-t>o){e.logger.warn("Exceeded max system timeout for page assertion, exiting...");break}e.signal.throwIfAborted();let l=Date.now();i=await dy(e),a=Date.now();let c=a-l;if(c>1e3&&e.logger.warn({pageAssertDuration:c},"Page assertion took longer than expected"),!i.success)await te(s,e.signal),s=Math.min(Math.floor(s*1.5),KP);else return i}return i=await dy(e),i}async function dy({assertion:n,browser:e,flagStore:t}){switch(n.type){case"CONTENT":{let o,i=!1,a;try{let s;if(t.isBooleanFlagEnabled("auto_expand_iframes")){let l=await e.evaluateFunctionInAllFrames(py,{value:n.value,negated:!!n.negated,returnHtml:!1});i=n.negated?l.every(c=>c.evaluation):l.some(c=>c.evaluation),s=l.find(c=>c.pageHtml)?.pageHtml}else({evaluation:i,pageHtml:s}=await e.evaluateFunctionInPage(py,{value:n.value,negated:!!n.negated,returnHtml:!0}));if(!i){let l=n.negated?or.CONTAINS:ir.CONTAINS;a=new R("AssertionFailureError",`The page ${l} '${n.value}'.`),o=s}}catch(s){a=new R("AssertionFailureError",`Failed to evaluate page content assertion: ${s instanceof Error?s.message:`${s}`}`)}return{success:i,err:a,data:i||!o?void 0:{pageContent:o}}}default:return(o=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n.type)}}function py({value:n,negated:e,returnHtml:t}){let r=document.documentElement.outerHTML,o=r.includes(n)===!e;return r.length>1e4&&(r=r.slice(0,1e4)+"...TRUNCATED"),{evaluation:o,pageHtml:!o&&t?r:void 0}}var Vd=async n=>{let{step:e,resolvedInputs:t}=n.moduleParams,{logger:r,context:o,storage:i,codeEvalTools:a,controller:s}=n.fixtures,l=s.browser,{orgId:c,runId:d}=n.inputs,p=s.executeAbortController.signal;Object.keys(t).length>0&&(o.setInputs(t),r.debug({inputs:t,moduleId:e.moduleId},"Set module inputs"));let m,u=!1,h,g;if(e.cacheConfig||e.defaultCacheAllInvocations){let f=e.cacheConfig?.cacheKey||e.defaultCacheKey||"",S=await Bt({orgId:c,s:f,context:o,logger:r,localTools:a,signal:p,flagStore:s.flagStore});g={orgId:c,cacheKeys:[S,...Object.entries(t).map(([w,v])=>`${w}:${v}`)]},r.debug({original:f,keyParams:g},"Module cache key params");let b=Date.now();for(;Date.now()-b<Mh;){p?.throwIfAborted();let w=await i.getCacheResult(g);if(w){r.debug({cacheResult:w},"Got result from module execution cache"),m=sl(e,t,"SUCCESS"),m.message="Used cached module result.",m.data=JSON.parse(w),u=!0;break}else r.debug({cacheKey:f,keyParams:g},"No cache result found, continuing with lock acquisition");let v=await i.acquireCacheLock({keyParams:g,clientMetadata:`hostName:${YP()};runId:${d}`},p);if(v.acquired){h=v.keyPrefix,r.info({cacheKeyPrefixIfLockAcquired:h,cacheKey:f,keyParams:g},"Acquired cache lock and proceeding with module execution");break}else r.debug({cacheKeyPrefixIfLockAcquired:h,cacheKey:f,keyParams:g},"Failed to acquire cache lock, retrying...");await te(2500+Math.random()*1e4,p)}}try{if(!m)m=await JP(n);else if(e.autoAuth){let f=fs.safeParse(m.data);if(!f.success)throw new R("UserConfigurationError",`Cached authentication module result is not a valid storage state: ${f.error.message}`);r.debug("Automatically loading auth state after cached module result"),await l.loadAuthState(f.data);let S=!1,b=e.advanced?.cacheInvalidation;if(b&&b.type==="PAGE_CHECK"){let w={type:"CONTENT",value:b.substring},v=await al({timeout:wn,assertion:w,browser:l,flagStore:s.flagStore,logger:r,signal:p});v.success?r.debug({invalResult:v},"Cached result still valid after page check, continuing..."):(r.info({invalResult:v},"Invalidating cached result due to page check failure"),S=!0)}if(g&&S)return await i.deleteCacheResult(g),Vd(n)}}finally{try{h!==void 0&&!u&&m?.status==="SUCCESS"&&await XP({step:e,result:m,browser:s.browser,cacheKeyPrefix:h,logger:r,storage:i})}finally{h!==void 0&&await i.releaseCacheLock(h)}}return m},JP=async n=>{let{step:e,tracer:t}=n.moduleParams,r=sl(e,n.moduleParams.resolvedInputs,"SUCCESS"),o=await t.startSubSteps(),{status:i,results:a}=await ur(n.work,()=>n.executeStepList({...n,listParams:{steps:e.steps,containerName:`module ('${e.name}')`,tracer:o}}));return r.results=a,r.status=i,r.finishedAt=new Date,en({asyncTasks:n.work.asyncTasks,nestedResults:a,result:r,logger:n.fixtures.logger}),r};function sl(n,e,t){let r={};return Object.entries(e).forEach(([i,a])=>{r[i]=JSON.stringify(a)}),{type:"MODULE",id:n.id,moduleId:n.moduleId,moduleName:n.name,startedAt:new Date,cacheConfig:n.cacheConfig,inputs:r,results:[],finishedAt:new Date,status:t}}async function uy({orgId:n,step:e,context:t,logger:r,flagStore:o,codeEvalTools:i,signal:a}){let s={};try{for(let l of e.parameters??[]){let c=e.inputs?.[l]??e.defaultParameters?.[l];if(!c){r.warn(`No value or default found for parameter '${l}' that is required by module '${e.name}'`);continue}s[l]=await jn({orgId:n,code:c,fragment:!0,context:t,logger:r,localTools:i,signal:a,flagStore:o})}return s}catch(l){throw a?.throwIfAborted(),new R("UserConfigurationError",`Failed to evaluate module inputs: ${l}`)}}async function XP({step:n,result:e,browser:t,cacheKeyPrefix:r,logger:o,storage:i}){let a=n.cacheConfig?.cacheExpiryMs;(!a||a===Sg)&&(a=n.defaultCacheTtl??yg);let s;n.autoAuth?s=JSON.stringify(await t.saveAuthState()):e.data!==void 0?s=JSON.stringify(e.data):s='""',o.debug({cacheKeyPrefix:r,ttlMs:a,truncatedCacheResultJson:Gg(s)},"Setting module cache result"),await i.setCacheResult({result:s,keyPrefix:r,ttlMs:a})}async function mr(n,e,t){let r=new Date;try{return t.throwIfAborted(),await e()}catch(o){let i=new Date,a="FAILED",s;if(t.aborted||o instanceof DOMException&&o.name==="AbortError"?(s="Step aborted by user.",a="CANCELLED"):o instanceof R?s=`${o}`:s=`An unexpected error occurred: ${o.message}`,n.type==="RESOLVED_MODULE"){let l=sl(n,{},"FAILED");return l.message=s,l.startedAt=r,l.finishedAt=i,l}return{...ks(n),startedAt:r,finishedAt:i,status:a,data:null,message:s,results:[]}}}async function ur(n,e){let t=!1;try{return n&&!n.state.failureRecoveryDisabled&&(n.state.failureRecoveryDisabled=!0,t=!0),await e()}finally{n&&t&&(n.state.failureRecoveryDisabled=void 0)}}import{randomUUID as my}from"crypto";import{cloneDeep as QP}from"lodash-es";function ll(n,e){n.state.healingDetails?n.state.healingDetails.push(e):n.state.healingDetails=[e]}var cl=async n=>{let{step:e,tracer:t}=n.presetParams,{logger:r,controller:o,context:i,billingReporter:a}=n.fixtures,{collectDebugData:s}=n.options,{testMetadata:l,suiteMetadata:c}=n.inputs,d=e.command.type,p=r.child({commandType:d,stepId:e.id,commandId:e.command.id}),m=Ki(e.command);n.work.asyncTasks.push(a.reportCreditsUsed(p,d,m,{testId:l?.id,testName:l?.name,suiteId:c?.id,suiteName:c?.name}));let u=o.browser.url(),h=new Date,g,f=my(),S=my();if(s)try{g=await o.browser.screenshot({retries:1,clearHighlights:!0});let C=await o.browser.getRawCondensedHtml();t.attachBeforeHtmlSnapshot({logger:p,snapshotId:f,html:C}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeHtmlSnapshot(p,f,C))}catch(C){p.debug({err:C},"Failed to take screenshot before step, likely because the page is still loading. This is non-fatal and does not affect the test.")}let b,w,v,x=us();try{let C=await o.executePresetCommand(x,t,e.command,i,l?.advanced.disableAICaching??!1);C.beforeScreenshotOverride&&(g=C.beforeScreenshotOverride),v=C.afterScreenshotOverride;let{proposedStep:A}=eL({work:n.work,step:e,newTargets:C.newTargets,logger:p}),N=new Date,O=o.browser.url();w={beforeUrl:u,afterUrl:O,startedAt:h,finishedAt:N,viewport:o.browser.getViewport(),status:C.fail?"FAILED":"SUCCESS",elementInteracted:C.elementInteracted},b={...e,message:C.thoughts??tL(C.newTargets)??"Successfully executed preset action.",beforeUrl:u,afterUrl:O,finishedAt:N,startedAt:h,status:C.fail?"FAILED":"SUCCESS",data:C.data,results:[w],details:x.details,proposedStep:A},"assertion"in e.command&&(b.message=C.thoughts||"Assertion passed.")}catch(C){p.error({message:C.message,stack:C.stack},`Failed executing preset step ${_r(e.command)}`);let A=o.browser.url(),N=new Date,O=C instanceof Error?C.message:`${C}`;C instanceof R&&C.getLastScreenshotBuffer()&&(v=C.getLastScreenshotBuffer()),w={beforeUrl:u,afterUrl:A,startedAt:h,finishedAt:N,viewport:o.browser.getViewport(),status:C instanceof DOMException&&C.name==="AbortError"?"CANCELLED":"FAILED",message:O},b={...e,startedAt:h,finishedAt:N,beforeUrl:u,afterUrl:A,status:C instanceof DOMException&&C.name==="AbortError"?"CANCELLED":"FAILED",message:O,failureReason:C instanceof R?C.reason:void 0,results:[w],details:x.details}}if(s)try{v||(v=await o.browser.screenshot({retries:1}));let C=await o.browser.getRawCondensedHtml();t.attachAfterHtmlSnapshot({logger:p,snapshotId:S,html:C}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeHtmlSnapshot(p,S,C))}catch(C){p.debug({err:C},"Failed store debug data after step, likely because the page is still loading. This is non-fatal and does not affect the test.")}return w.beforeSnapshot=f,b.beforeSnapshot=f,w.afterSnapshot=S,b.afterSnapshot=S,g&&(t.attachBeforeScreenshot({logger:p,snapshotId:f,screenshot:g}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(p,f,g))),v&&(t.attachAfterScreenshot({logger:p,snapshotId:S,screenshot:v}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(p,S,v))),b};function eL({work:n,step:e,newTargets:t,logger:r}){if(!t?.length)return{proposedStep:void 0};let o=e.command;Fg(o,t,r);let i=t[0]?.description;if(i&&"target"in o&&o.target&&o.target.type==="description"){let a={...o,target:{...o.target,elementDescriptor:i}},s={...QP(e),command:a};return ll(n,{type:"DESCRIPTION_UPDATE",thoughts:`Updated element description after the original element could not be found on the page. New element location reasoning: ${t[0]?.thoughts}`}),{proposedStep:s}}return{proposedStep:void 0}}function tL(n){if(n?.length){if(n.length===1&&n[0]?.thoughts)return n[0].thoughts;if(n.length===2&&n.every(e=>e.thoughts))return`Located first element: ${n[0]?.thoughts}
53
53
  Located second element: ${n[1]?.thoughts}`}}var qd=["ability","able","aboard","about","above","accept","accident","according","account","accurate","acres","across","act","action","active","activity","actual","actually","add","addition","additional","adjective","adult","adventure","advice","affect","afraid","after","afternoon","again","against","age","ago","agree","ahead","aid","air","airplane","alike","alive","all","allow","almost","alone","along","aloud","alphabet","already","also","although","am","among","amount","ancient","angle","angry","animal","announced","another","answer","ants","any","anybody","anyone","anything","anyway","anywhere","apart","apartment","appearance","apple","applied","appropriate","are","area","arm","army","around","arrange","arrangement","arrive","arrow","art","article","as","aside","ask","asleep","at","ate","atmosphere","atom","atomic","attached","attack","attempt","attention","audience","author","automobile","available","average","avoid","aware","away","baby","back","bad","badly","bag","balance","ball","balloon","band","bank","bar","bare","bark","barn","base","baseball","basic","basis","basket","bat","battle","be","bean","bear","beat","beautiful","beauty","became","because","become","becoming","bee","been","before","began","beginning","begun","behavior","behind","being","believed","bell","belong","below","belt","bend","beneath","bent","beside","best","bet","better","between","beyond","bicycle","bigger","biggest","bill","birds","birth","birthday","bit","bite","black","blank","blanket","blew","blind","block","blood","blow","blue","board","boat","body","bone","book","border","born","both","bottle","bottom","bound","bow","bowl","box","boy","brain","branch","brass","brave","bread","break","breakfast","breath","breathe","breathing","breeze","brick","bridge","brief","bright","bring","broad","broke","broken","brother","brought","brown","brush","buffalo","build","building","built","buried","burn","burst","bus","bush","business","busy","but","butter","buy","by","cabin","cage","cake","call","calm","came","camera","camp","can","canal","cannot","cap","capital","captain","captured","car","carbon","card","care","careful","carefully","carried","carry","case","cast","castle","cat","catch","cattle","caught","cause","cave","cell","cent","center","central","century","certain","certainly","chain","chair","chamber","chance","change","changing","chapter","character","characteristic","charge","chart","check","cheese","chemical","chest","chicken","chief","child","children","choice","choose","chose","chosen","church","circle","circus","citizen","city","class","classroom","claws","clay","clean","clear","clearly","climate","climb","clock","close","closely","closer","cloth","clothes","clothing","cloud","club","coach","coal","coast","coat","coffee","cold","collect","college","colony","color","column","combination","combine","come","comfortable","coming","command","common","community","company","compare","compass","complete","completely","complex","composed","composition","compound","concerned","condition","congress","connected","consider","consist","consonant","constantly","construction","contain","continent","continued","contrast","control","conversation","cook","cookies","cool","copper","copy","corn","corner","correct","correctly","cost","cotton","could","count","country","couple","courage","course","court","cover","cow","cowboy","crack","cream","create","creature","crew","crop","cross","crowd","cry","cup","curious","current","curve","customs","cut","cutting","daily","damage","dance","danger","dangerous","dark","darkness","date","daughter","dawn","day","dead","deal","dear","death","decide","declared","deep","deeply","deer","definition","degree","depend","depth","describe","desert","design","desk","detail","determine","develop","development","diagram","diameter","did","die","differ","difference","different","difficult","difficulty","dig","dinner","direct","direction","directly","dirt","dirty","disappear","discover","discovery","discuss","discussion","disease","dish","distance","distant","divide","division","do","doctor","does","dog","doing","doll","dollar","done","donkey","door","dot","double","doubt","down","dozen","draw","drawn","dream","dress","drew","dried","drink","drive","driven","driver","driving","drop","dropped","drove","dry","duck","due","dug","dull","during","dust","duty","each","eager","ear","earlier","early","earn","earth","easier","easily","east","easy","eat","eaten","edge","education","effect","effort","egg","eight","either","electric","electricity","element","elephant","eleven","else","empty","end","enemy","energy","engine","engineer","enjoy","enough","enter","entire","entirely","environment","equal","equally","equator","equipment","escape","especially","essential","establish","even","evening","event","eventually","ever","every","everybody","everyone","everything","everywhere","evidence","exact","exactly","examine","example","excellent","except","exchange","excited","excitement","exciting","exclaimed","exercise","exist","expect","experience","experiment","explain","explanation","explore","express","expression","extra","eye","face","facing","fact","factor","factory","failed","fair","fairly","fall","fallen","familiar","family","famous","far","farm","farmer","farther","fast","fastened","faster","fat","father","favorite","fear","feathers","feature","fed","feed","feel","feet","fell","fellow","felt","fence","few","fewer","field","fierce","fifteen","fifth","fifty","fight","fighting","figure","fill","film","final","finally","find","fine","finest","finger","finish","fire","fireplace","firm","first","fish","five","fix","flag","flame","flat","flew","flies","flight","floating","floor","flow","flower","fly","fog","folks","follow","food","foot","football","for","force","foreign","forest","forget","forgot","forgotten","form","former","fort","forth","forty","forward","fought","found","four","fourth","fox","frame","free","freedom","frequently","fresh","friend","friendly","frighten","frog","from","front","frozen","fruit","fuel","full","fully","fun","function","funny","fur","furniture","further","future","gain","game","garage","garden","gas","gasoline","gate","gather","gave","general","generally","gentle","gently","get","getting","giant","gift","girl","give","given","giving","glad","glass","globe","go","goes","gold","golden","gone","good","goose","got","government","grabbed","grade","gradually","grain","grandfather","grandmother","graph","grass","gravity","gray","great","greater","greatest","greatly","green","grew","ground","group","grow","grown","growth","guard","guess","guide","gulf","gun","habit","had","hair","half","halfway","hall","hand","handle","handsome","hang","happen","happened","happily","happy","harbor","hard","harder","hardly","has","hat","have","having","hay","he","headed","heading","health","heard","hearing","heart","heat","heavy","height","held","hello","help","helpful","her","herd","here","herself","hidden","hide","high","higher","highest","highway","hill","him","himself","his","history","hit","hold","hole","hollow","home","honor","hope","horn","horse","hospital","hot","hour","house","how","however","huge","human","hundred","hung","hungry","hunt","hunter","hurried","hurry","hurt","husband","ice","idea","identity","if","ill","image","imagine","immediately","importance","important","impossible","improve","in","inch","include","including","income","increase","indeed","independent","indicate","individual","industrial","industry","influence","information","inside","instance","instant","instead","instrument","interest","interior","into","introduced","invented","involved","iron","is","island","it","its","itself","jack","jar","jet","job","join","joined","journey","joy","judge","jump","jungle","just","keep","kept","key","kids","kill","kind","kitchen","knew","knife","know","knowledge","known","label","labor","lack","lady","laid","lake","lamp","land","language","large","larger","largest","last","late","later","laugh","law","lay","layers","lead","leader","leaf","learn","least","leather","leave","leaving","led","left","leg","length","lesson","let","letter","level","library","lie","life","lift","light","like","likely","limited","line","lion","lips","liquid","list","listen","little","live","living","load","local","locate","location","log","lonely","long","longer","look","loose","lose","loss","lost","lot","loud","love","lovely","low","lower","luck","lucky","lunch","lungs","lying","machine","machinery","mad","made","magic","magnet","mail","main","mainly","major","make","making","man","managed","manner","manufacturing","many","map","mark","market","married","mass","massage","master","material","mathematics","matter","may","maybe","me","meal","mean","means","meant","measure","meat","medicine","meet","melted","member","memory","men","mental","merely","met","metal","method","mice","middle","might","mighty","mile","military","milk","mill","mind","mine","minerals","minute","mirror","missing","mission","mistake","mix","mixture","model","modern","molecular","moment","money","monkey","month","mood","moon","more","morning","most","mostly","mother","motion","motor","mountain","mouse","mouth","move","movement","movie","moving","mud","muscle","music","musical","must","my","myself","mysterious","nails","name","nation","national","native","natural","naturally","nature","near","nearby","nearer","nearest","nearly","necessary","neck","needed","needle","needs","negative","neighbor","neighborhood","nervous","nest","never","new","news","newspaper","next","nice","night","nine","no","nobody","nodded","noise","none","noon","nor","north","nose","not","note","noted","nothing","notice","noun","now","number","numeral","nuts","object","observe","obtain","occasionally","occur","ocean","of","off","offer","office","officer","official","oil","old","older","oldest","on","once","one","only","onto","open","operation","opinion","opportunity","opposite","or","orange","orbit","order","ordinary","organization","organized","origin","original","other","ought","our","ourselves","out","outer","outline","outside","over","own","owner","oxygen","pack","package","page","paid","pain","paint","pair","palace","pale","pan","paper","paragraph","parallel","parent","park","part","particles","particular","particularly","partly","parts","party","pass","passage","past","path","pattern","pay","peace","pen","pencil","people","per","percent","perfect","perfectly","perhaps","period","person","personal","pet","phrase","physical","piano","pick","picture","pictured","pie","piece","pig","pile","pilot","pine","pink","pipe","pitch","place","plain","plan","plane","planet","planned","planning","plant","plastic","plate","plates","play","pleasant","please","pleasure","plenty","plural","plus","pocket","poem","poet","poetry","point","pole","police","policeman","political","pond","pony","pool","poor","popular","population","porch","port","position","positive","possible","possibly","post","pot","potatoes","pound","pour","powder","power","powerful","practical","practice","prepare","present","president","press","pressure","pretty","prevent","previous","price","pride","primitive","principal","principle","printed","private","prize","probably","problem","process","produce","product","production","program","progress","promised","proper","properly","property","protection","proud","prove","provide","public","pull","pupil","pure","purple","purpose","push","put","putting","quarter","queen","question","quick","quickly","quiet","quietly","quite","rabbit","race","radio","railroad","rain","raise","ran","ranch","range","rapidly","rate","rather","raw","rays","reach","read","reader","ready","real","realize","rear","reason","recall","receive","recent","recently","recognize","record","red","refer","refused","region","regular","related","relationship","religious","remain","remarkable","remember","remove","repeat","replace","replied","report","represent","require","research","respect","rest","result","return","review","rhyme","rhythm","rice","rich","ride","riding","right","ring","rise","rising","river","road","roar","rock","rocket","rocky","rod","roll","roof","room","root","rope","rose","rough","round","route","row","rubbed","rubber","rule","ruler","run","running","rush","sad","saddle","safe","safety","said","sail","sale","salmon","salt","same","sand","sang","sat","satellites","satisfied","save","saved","saw","say","scale","scared","scene","school","science","scientific","scientist","score","screen","sea","search","season","seat","second","secret","section","see","seed","seeing","seems","seen","seldom","select","selection","sell","send","sense","sent","sentence","separate","series","serious","serve","service","sets","setting","settle","settlers","seven","several","shade","shadow","shake","shaking","shall","shallow","shape","share","sharp","she","sheep","sheet","shelf","shells","shelter","shine","shinning","ship","shirt","shoe","shoot","shop","shore","short","shorter","shot","should","shoulder","shout","show","shown","shut","sick","sides","sight","sign","signal","silence","silent","silk","silly","silver","similar","simple","simplest","simply","since","sing","single","sink","sister","sit","sitting","situation","six","size","skill","skin","sky","slabs","slave","sleep","slept","slide","slight","slightly","slip","slipped","slope","slow","slowly","small","smaller","smallest","smell","smile","smoke","smooth","snake","snow","so","soap","social","society","soft","softly","soil","solar","sold","soldier","solid","solution","solve","some","somebody","somehow","someone","something","sometime","somewhere","son","song","soon","sort","sound","source","south","southern","space","speak","special","species","specific","speech","speed","spell","spend","spent","spider","spin","spirit","spite","split","spoken","sport","spread","spring","square","stage","stairs","stand","standard","star","stared","start","state","statement","station","stay","steady","steam","steel","steep","stems","step","stepped","stick","stiff","still","stock","stomach","stone","stood","stop","stopped","store","storm","story","stove","straight","strange","stranger","straw","stream","street","strength","stretch","strike","string","strip","strong","stronger","struck","structure","struggle","stuck","student","studied","studying","subject","substance","success","successful","such","sudden","suddenly","sugar","suggest","suit","sum","summer","sun","sunlight","supper","supply","support","suppose","sure","surface","surprise","surrounded","swam","sweet","swept","swim","swimming","swing","swung","syllable","symbol","system","table","tail","take","taken","tales","talk","tall","tank","tape","task","taste","taught","tax","tea","teach","teacher","team","tears","teeth","telephone","television","tell","temperature","ten","tent","term","terrible","test","than","thank","that","thee","them","themselves","then","theory","there","therefore","these","they","thick","thin","thing","think","third","thirty","this","those","thou","though","thought","thousand","thread","three","threw","throat","through","throughout","throw","thrown","thumb","thus","thy","tide","tie","tight","tightly","till","time","tin","tiny","tip","tired","title","to","tobacco","today","together","told","tomorrow","tone","tongue","tonight","too","took","tool","top","topic","torn","total","touch","toward","tower","town","toy","trace","track","trade","traffic","trail","train","transportation","trap","travel","treated","tree","triangle","tribe","trick","tried","trip","troops","tropical","trouble","truck","trunk","truth","try","tube","tune","turn","twelve","twenty","twice","two","type","typical","uncle","under","underline","understanding","unhappy","union","unit","universe","unknown","unless","until","unusual","up","upon","upper","upward","us","use","useful","using","usual","usually","valley","valuable","value","vapor","variety","various","vast","vegetable","verb","vertical","very","vessels","victory","view","village","visit","visitor","voice","volume","vote","vowel","voyage","wagon","wait","walk","wall","want","war","warm","warn","was","wash","waste","watch","water","wave","way","we","weak","wealth","wear","weather","week","weigh","weight","welcome","well","went","were","west","western","wet","whale","what","whatever","wheat","wheel","when","whenever","where","wherever","whether","which","while","whispered","whistle","white","who","whole","whom","whose","why","wide","widely","wife","wild","will","willing","win","wind","window","wing","winter","wire","wise","wish","with","within","without","wolf","women","won","wonder","wonderful","wood","wooden","wool","word","wore","work","worker","world","worried","worry","worse","worth","would","wrapped","write","writer","writing","written","wrong","wrote","yard","year","yellow","yes","yesterday","yet","you","young","younger","your","yourself","youth","zero","zebra","zipper","zoo","zulu"];function hy(n){return new Array(n).fill(0).map(()=>qd[Math.floor(Math.random()*qd.length)]).join("-")}async function gy({codePath:n,screenshotBuff:e,storage:t,logger:r}){if(e)try{let o=await t.uploadScreenshot(e);return r.debug({screenshotUrl:o,codePath:n},"Saved screenshot for debugging"),o}catch(o){r.error({err:o,codePath:n},"Failed to save screenshot for debugging")}}async function Rn({frameConfig:n,action:e,browser:t}){let r=t.getActiveFrameConfig();n?t.setActiveFrameConfig(n):r?.type==="auto"&&t.setActiveFrameConfig(void 0);try{return await e()}finally{t.setActiveFrameConfig(r)}}var nL=["NAVIGATE","NEW_TAB","TAB","REFRESH","WAIT_FOR_URL"];async function fy({beforeUrl:n,beforePages:e,browser:t,command:r,logger:o}){if(nL.includes(r.type))return;let s=("cache"in r&&r.cache&&"target"in r.cache?r.cache.target:void 0)?.nodeOnlySerializedHtml?.includes("<a")??!1?300:3e3,l=Date.now(),c=0;for(;c===0||Date.now()-l<s;){await te(250),c++;let d=(await t.getOpenPages()).map(m=>m.url),p=t.url();if(d.length!==e.length)for(let m=d.length-1;m>=e.length;m--){let u=d[m];if(zr(u,o)&&u!==n&&u!==p){o.info({beforePages:e,afterPages:d,beforeUrl:n},"Auto-following new tab after preset action"),await t.switchToPage({type:"INDEX",index:String(m)});break}}}}var Sy="MOMENTIC_RUN_ID",yy="FINAL_SCREENSHOT_URL";import{cloneDeep as pL}from"lodash-es";async function by(n){let{step:e,tracer:t}=n.conditionalParams,{logger:r,controller:o}=n.fixtures,i=new Date,a=ks(e),s=e.elseSteps,l=!0,c=[],d,p=us();for(let f=0;f<e.blocks.length;f++){r.info(`Evaluating condition ${f} in conditional step`);let S=e.blocks[f];try{let b=await cl({...n,presetParams:{tracer:t,step:S.assertion}});c.push(b),r.info(`Condition ${f} resolved to true, executing the corresponding ${S.steps.length} steps`),l=!1,s=S.steps,d=b}catch(b){r.info({err:b},`Condition ${f} resolved to false`)}finally{o.throwIfClosed()}}if(s)l&&r.info("No conditions resolved to true, executing the else block steps");else return r.warn("No conditions resolved to true and no else block was provided, causing the entire conditional step to be skipped"),{...a,status:"SUCCESS",startedAt:i,data:c[c.length-1]?.data,message:c[c.length-1]?.message,results:[],finishedAt:new Date,details:p.details};r.info(`Executing ${s.length} steps in the selected conditional block`);let m=await n.conditionalParams.tracer.startSubSteps(),u=await n.executeStepList({...n,listParams:{steps:s,containerName:"conditional block",tracer:m}}),g={...a,assertion:d,...u,startedAt:i,finishedAt:new Date};return en({asyncTasks:n.work.asyncTasks,nestedResults:[...c,...u.results],result:g,logger:r}),g}import{randomUUID as wy}from"crypto";var vy=async n=>{let{controller:e}=n.fixtures;await e.browser.waitForDOMStability();let t=await e.browser.screenshot({}),r=await rL(n);r.finishedAt=new Date,en({asyncTasks:n.work.asyncTasks,result:r,nestedResults:r.results,logger:n.fixtures.logger});let o=await e.browser.screenshot({}),i=wy();r.beforeSnapshot=i,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,i,t));let a=wy();return r.afterSnapshot=a,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,a,o)),r},rL=async n=>{let{step:e,tracer:t}=n.aiStepParams,{controller:r,context:o,logger:i}=n.fixtures,a={...e,startedAt:new Date,beforeTestContext:o.toRedactedDisplayCopy(),finishedAt:new Date,results:[],status:"SUCCESS"};if(!("steps"in e&&e.steps&&e.steps.length>0&&e.steps[e.steps.length-1]?.command.type==="SUCCESS"))throw new R("UserConfigurationError","AI action has been fully deprecated. Please delete this step and transition to Dynamic AI Action.");try{let l=await t.startSubSteps(),{status:c}=await n.executeStepList({...n,listParams:{steps:e.steps,containerName:"AI action",results:a.results,tracer:l}});return a.finishedAt=new Date,a.status=c,a}catch(l){i.warn({err:l},"Failed executing saved deprecated AI action steps");let c=r.executeAbortController.signal.aborted;a.message=l instanceof Error?l.message:`${l}`,a.status=c?"CANCELLED":"FAILED"}return a};import{randomUUID as Kd}from"crypto";var Ty=15,oL=7,xy=async n=>{let{controller:e}=n.fixtures;await e.browser.waitForDOMStability();let t=await e.browser.screenshot({}),r=await iL(n);r.finishedAt=new Date,en({asyncTasks:n.work.asyncTasks,result:r,nestedResults:r.results,logger:n.fixtures.logger});let o=await e.browser.screenshot({}),i=Kd();r.beforeSnapshot=i,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,i,t));let a=Kd();return r.afterSnapshot=a,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,a,o)),r},iL=async n=>{let{step:e,tracer:t}=n.aiStepParams,{testMetadata:r,orgId:o}=n.inputs,{controller:i,context:a,logger:s,codeEvalTools:l}=n.fixtures,{step:c}=n.callbacks,d=`${e.id}-${Date.now()}`,p=s.child({stepId:e.id,langfuseSessionId:d}),m={...e,startedAt:new Date,beforeTestContext:a.toRedactedDisplayCopy(),results:[],finishedAt:new Date,status:"SUCCESS"},u=await Bt({orgId:o,s:e.text,context:a,logger:p,localTools:l,flagStore:i.flagStore});await i.browser.waitForDOMStability({logger:p});let g=`data:image/jpeg;base64,${(await i.browser.screenshot({clearHighlights:!0,retries:2})).toString("base64")}`,f=[],S=0,b=0,w,v;for(;;){if(S>Ty)return m.message=`Exceeded the maximum number of commands allowed per AI step (${Ty})`,m.status="FAILED",m;if(i.executeAbortController.signal.aborted)return m.message="Test execution was cancelled",m.status="CANCELLED",m;c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Evaluating current state..."});let x=await i.evaluateAiAction({goal:u,startingScreenshot:S===0?void 0:g,history:f,logger:p,langfuseSessionId:d,lastError:v}),{evaluation:C,reasoning:A,summary:N}=x;p.info(x,"Got AI evaluation");let O=m.results[S-1]?.id;switch(C.type){case"DONE":return m.message=`Our AI evaluator confirmed all tasks are complete: ${A}`,m.status="SUCCESS",O&&c.onDynamicAIActionEvaluatingEvent?.({stepId:O,status:"SUCCESS",message:`${N}
54
54
  ${A}`}),m;case"RIGHT_TRACK":{w=void 0,S===0?c.onDynamicAIActionEvaluatingEvent?.({stepId:e.id,status:"RUNNING",message:A}):O&&c.onDynamicAIActionEvaluatingEvent?.({stepId:O,status:"SUCCESS",message:A});break}case"WRONG_TRACK":{if(w=`${A}
55
55
  ${C.feedback}`,b++,b>=oL)return m.message=`Our AI agent requires additional information to achieve this goal:
56
56
  ${A}
57
- ${C.feedback}`,m.status="FAILED",c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,status:"FAILED",message:m.message}),m;O&&c.onDynamicAIActionEvaluatingEvent?.({stepId:O,status:"FAILED",message:C.feedback});break}case"IMPOSSIBLE":return m.message=`Our AI evaluator determined this task cannot be achieved: ${A}`,m.status="FAILED",c.onDynamicAIActionEvaluatingEvent?.({stepId:O??e.id,status:"FAILED",message:m.message}),m}let H=setTimeout(()=>{c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Deciding what to do next..."})},1500);p.info({commandIndex:S,lastActionHint:w},`Generating new sub-command ${S} within AI action`);let F,L;try{({command:F,reasoning:L}=await i.promptToCommand({goal:u,history:f,startingScreenshot:g,disableCache:r?.advanced.disableAICaching??!1,logger:p,actionHint:w,langfuseSessionId:d})),p.info({command:F,reasoning:L},"Got proposed command")}finally{clearTimeout(H)}if(F.type==="FAILURE")return clearTimeout(H),m.status="FAILED",m.message=`Our AI agent determined that no supported actions can fulfill the goals: ${L}`,m;let B={id:Kd(),type:"PRESET_ACTION",command:F},P={substepIndex:S+1,message:L||"Generated new command."};c.onDynamicCommandGenerated?.({...P,step:B,parentStepId:e.id}),p.info({commandId:F.id},`Executing sub-command ${S} within AI step: ${_r(F)}`);let K=await t.startSubSteps(),Y=(await n.executeStepList({...n,options:{...n.options,disableHealing:!0},listParams:{containerName:"AI action newly generated step",steps:[B],tracer:K}})).results[0];c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Waiting for page to stabilize before next action..."}),await i.browser.waitForDOMStability({logger:p});let Z=await i.browser.screenshot({clearHighlights:!0,retries:1});m.results.push(Y),f.push({screenshotBase64AfterCommand:`data:image/jpeg;base64,${Z.toString("base64")}`,urlAfterCommand:i.browser.url(),serializedCommand:_r(F),elementInteracted:Y.results[0]?.elementInteracted,thoughts:L});let ft={substepIndex:S,output:{...Y,message:Y.message??"Successfully executed preset action."},step:B,parentStepId:e.id};if(c.onDynamicCommandExecuted?.(ft),await t.finish({output:ts.parse(Y),step:Y,message:Y.message}),Y.status==="FAILED")if(m.status="FAILED",m.message=Y.message,b<3)b++,v=`The last attempted action resulted in a Momentic error. A different element may need to be targeted. Error: ${Y.message}`;else return m;else if(Y.status==="CANCELLED")return m.status="CANCELLED",m.message=Y.message,m;S++}};async function Cy(n){let{results:e}=n.failureRecoveryParams,t=e[e.length-1],r=sL(t);if(r)return n.fixtures.logger.info({failedResult:t,isNotEligible:r},"Skipping failure recovery because of ineligible failure"),null;try{return await aL(n)}catch(o){return n.fixtures.logger.error({err:o},"Error during failure recovery attempt"),null}}async function Ey({screenshot:n,controller:e,currentPageState:t,newStep:r,patch:o,logger:i}){if(r.aiSuggested=!0,r.type==="PRESET_ACTION"&&"cache"in r.command&&r.command.cache&&"target"in r.command.cache&&"target"in r.command&&r.command.target?.type==="description")try{let a=r.command.cache.target.id,s=await e.getReverseMappedDescription({browserState:t,targetId:a,disableCache:!1,screenshot:n});r.command.target.elementDescriptor=s}catch(a){i.error({err:a},"Error while reverse mapping target in failure recovery")}r.type==="PRESET_ACTION"&&(r.command.thoughts=o.thoughts)}async function aL(n){let{fixtures:e,work:t,failureRecoveryParams:r}=n,{controller:o,logger:i}=e,{results:a,failedStep:s,nextSteps:l,tracer:c}=r;if(!a.length)throw new Error("Attempted failure recovery with no failed results");await Promise.allSettled(t.asyncTasks??[]);let d=o.browser.url(),p=`data:image/jpeg;base64,${(await o.browser.screenshot({})).toString("base64")}`,m=(await o.browser.getBrowserState({skipWait:!0})).serialize(),{results:u}=await Rs(i,e.debugDataStorage,a,{numScreenshots:3,addIndices:!0}),h=l.map(w=>ln(w)),g=await o.runFailureRecovery({currentUrl:d,currentScreenshot:p,failedResults:u,currentPageState:m,nextStepsSerialized:h});if(g.scenario==="INELIGIBLE"||!g.patch)return null;let f=[];if(g.patch.op==="add"){let w=g.patch.value;if(!w)throw new Error("No value in add patch in failure recovery");await Ey({screenshot:p,controller:o,currentPageState:m,newStep:w,patch:g.patch,logger:i}),f=[w,s]}else if(g.patch.op==="replace"){let w=g.patch.value;if(!w)throw new Error("No value in replace patch in failure recovery");await Ey({screenshot:p,controller:o,currentPageState:m,newStep:w,patch:g.patch,logger:i}),f=[w]}else if(g.patch.op==="remove"&&s.type==="PRESET_ACTION"&&["AI_ASSERTION","PAGE_CHECK","ELEMENT_CHECK"].includes(s.command.type))throw new Error("Cannot modify assertion step in failure recovery");let S=await c.startSubSteps(),b;if(f.length){b=await ur(n.work,()=>n.executeStepList({...n,fixtures:{...n.fixtures},listParams:{steps:f,containerName:"AI-recovered step list",tracer:S}}));for(let w of b.results)w.aiSuggested&&w.type==="PRESET_ACTION"&&(w.message=`AI suggested step: ${w.command.thoughts}`)}else b={status:"SUCCESS",results:[],proposedSteps:[]};return ll(t,{type:"FAILURE_RECOVERY",thoughts:g.reasoning}),t.state.failureRecoveryDisabled=!0,b}function sL(n){if(!n)return"No failed result";if(n.type!=="PRESET_ACTION")return"Not a preset action";let e=n.message;return e?e.includes("AbortError:")?"AbortError":Pm.some(t=>e.includes(t))?"User fault and likely irrecoverable":"":"No error message available"}async function Ry(n){let{step:e,tracer:t}=n.frameParams,{logger:r,controller:o}=n.fixtures,i=new Date,a=o.browser.getActiveFrameConfig();o.browser.setActiveFrameConfig(e.identifier);let s;try{let d=await t.startSubSteps();s=await n.executeStepList({...n,listParams:{steps:e.steps,containerName:"frame step list",tracer:d}})}finally{o.browser.setActiveFrameConfig(a)}let c={...e,...s,startedAt:i,finishedAt:new Date};return en({asyncTasks:n.work.asyncTasks,nestedResults:s.results,result:c,logger:r}),c}import{randomUUID as dl}from"crypto";import lL from"fast-json-patch";import{cloneDeep as cL}from"lodash-es";async function Ay(n){let e=n.failedResults,t=[],{sectionParams:r,fixtures:o,work:i,startingUrl:a,startingContextSnapshot:s,tracer:l}=n,{step:c}=r,{controller:d,logger:p,debugDataStorage:m}=o,u=c?.autohealingConfig,h=u?.restartBehavior??{type:"GO_TO_SECTION_START"},g=u?.attempts??1;for(let f=0;f<g;f++){if(!e.terminalResult?.message)throw new Error("No error message in terminal result");let S=cL(c.steps);await Promise.allSettled(i.asyncTasks??[]);let{results:b}=await Rs(p,m,e.results,{numScreenshots:4}),w=await d.runSectionAutohealing({results:b,errorMessage:e.terminalResult?.message,goal:c.description});S=lL.applyPatch(S,w.patches).newDocument;let v=At.fromSnapshot({snapshot:s,environmentVariables:o.context.getVariablesFromEnvironmentCopy()});await dL({logger:p,controller:d,tracer:l,context:v,restartConfig:h,startingUrl:a});let x=await ur(n.work,()=>n.executeStepList({...n,fixtures:{...n.fixtures,context:v},listParams:{steps:S,containerName:"auto-healed step list",tracer:l}}));if(t.push(x.results),x.status==="SUCCESS")return{successfulHealing:{proposedStep:{...c,steps:S},listResult:x,context:v},healingAttempts:t};e=x}return{healingAttempts:t}}async function dL({logger:n,controller:e,tracer:t,restartConfig:r,context:o,startingUrl:i}){switch(r.type){case"NAVIGATE_URL":{let a={id:dl(),type:"PRESET_ACTION",command:{id:dl(),type:"NAVIGATE",url:r.url}},s=await t.startStep({logger:n,step:a});await e.executePresetCommand(null,s,a.command,o,!1);break}case"GO_TO_SECTION_START":{let a={id:dl(),type:"PRESET_ACTION",command:{id:dl(),type:"NAVIGATE",url:i}},s=await t.startStep({logger:n,step:a});await e.executePresetCommand(null,s,a.command,o,!1);break}}}function Iy(n,e){switch(n||(n="ON_FAILURE"),n){case"ALWAYS":return!0;case"ON_FAILURE":return!0;case"ON_ACTION_FAILURE":return!(!e||e.type==="PRESET_ACTION"&&Nu(e.command.type))}}async function Py(n){let{step:e,tracer:t}=n.sectionParams,{logger:r,controller:o,context:i}=n.fixtures,a=new Date,s=o.browser.url(),l=i.toObjectCopy(),c=await t.startSubSteps(),d=async()=>n.executeStepList({...n,listParams:{steps:e.steps,containerName:"section step list",tracer:c}}),p=e.autohealingConfig?await ur(n.work,d):await d(),m,u;if(p.status==="FAILED"&&e.autohealingConfig&&!n.work.state.autoHealingDisabled&&Iy(e.autohealingConfig.trigger,p.terminalResult)){let g=await t.startSubSteps(),f=await Ay({...n,startingContextSnapshot:l,startingUrl:s,failedResults:p,tracer:g});f.successfulHealing&&(m=f.successfulHealing.proposedStep,p=f.successfulHealing.listResult,n.fixtures.context=f.successfulHealing.context),u=f.healingAttempts}let h={...e,...p,startedAt:a,finishedAt:new Date,proposedStep:m,healingAttempts:u};return en({asyncTasks:n.work.asyncTasks,nestedResults:p.results,result:h,logger:r}),h}async function An(n){let{results:e=[],containerName:t,steps:r,tracer:o}=n.listParams,{logger:i,context:a,controller:s,codeEvalTools:l,billingReporter:c,analytics:d}=n.fixtures,p=o.getParentStepIdChain(),{orgId:m,fromStep:u,toStep:h}=n.inputs,g=n.work,f=[],S="SUCCESS",b,w=0;for(w;w<r.length;w++){let v=r[w],x,C=ln(v);if(v.skipped)continue;if(g.fastForwardingToStep&&u){let re=JSON.stringify(p);if(v.id===u.fromStepId&&re===JSON.stringify(u.parentStepIdChain))g.fastForwardingToStep=!1;else if(!Lg(v,p,u.fromStepId,u.parentStepIdChain))continue}let A=new Date,N=d.child({step_id:v.id});N.track({type:"execution:step_start",step_type:v.type==="RESOLVED_MODULE"?"MODULE":v.type,command_type:"command"in v?v.command.type:void 0}),i.info({step:v},`Executing step ${w+1}/${r.length} in ${t}: ${C}`);let O=await o.startStep({logger:i,step:v}),H=pL(v),F=a.toRedactedDisplayCopy(),L=s.browser.url(),B=s.executeAbortController.signal,P=qi(v.type);g.asyncTasks.push(c.reportCreditsUsed(i,v.type,P,{testId:n.inputs.testMetadata?.id,testName:n.inputs.testMetadata?.name,suiteId:n.inputs.suiteMetadata?.id,suiteName:n.inputs.suiteMetadata?.name}));let K,U;switch(v.type){case"PRESET_ACTION":{K="Preset action",U=await mr(v,async()=>await cl({...n,presetParams:{tracer:O,step:v}}),B),"proposedStep"in U&&U.proposedStep&&(x=U.proposedStep,U.proposedStep=void 0);break}case"AI_ACTION":{K="AI action",U=await mr(v,()=>vy({...n,aiStepParams:{step:v,tracer:O},executeStepList:An}),B);break}case"AI_ACTION_DYNAMIC":{K="AI action",U=await mr(v,()=>xy({...n,aiStepParams:{step:v,tracer:O},executeStepList:An}),B);break}case"RESOLVED_MODULE":{K=`Module (${v.name})`,U=await mr(v,async()=>{let re=await uy({orgId:m,step:v,context:a,logger:i,flagStore:s.flagStore,codeEvalTools:l,signal:B});return Vd({...n,executeStepList:An,moduleParams:{step:v,resolvedInputs:re,tracer:O}})},B);break}case"CONDITIONAL":{K="Conditional step",U=await mr(v,()=>by({...n,conditionalParams:{step:v,tracer:O},executeStepList:An}),B);break}case"IFRAME":{K="Frame step",U=await mr(v,()=>Ry({...n,frameParams:{step:v,tracer:O},executeStepList:An}),B);break}case"SECTION":{K="Section";let re=await mr(v,()=>Py({...n,sectionParams:{step:v,tracer:O},executeStepList:An}),B);"proposedStep"in re&&re.proposedStep&&(x=re.proposedStep,re.proposedStep=void 0),U=re;break}default:return(we=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(v)}U.beforeUrl=U.beforeUrl??L,U.beforeTestContext=F,v.envKey&&a.setVariable(v.envKey,U.data);let Y=s.browser.url();a.setCurrentUrl(Y),U.afterUrl=U.afterUrl??Y,U.afterTestContext=a.toRedactedDisplayCopy(),e.push(U),await uL({startedAt:A,stepTypeName:K,result:U,callbacks:n.callbacks,analytics:N,globalWorkRef:n.work,tracer:O});let Z;if(U.status==="FAILED"&&!g.state.failureRecoveryDisabled&&u?.fromStepId===void 0&&h?.toStepId===void 0){let re=await Cy({...n,executeStepList:An,failureRecoveryParams:{failedStep:H,nextSteps:r.slice(w+1),results:e,tracer:O}});re&&re.status==="SUCCESS"&&(Z=re.proposedSteps,e.push(...re.results))}if(Z?f.push(...Z):x?f.push(x):f.push(v),g.fastForwardingToStep&&u&&u.fromStepId===v.id&&JSON.stringify(p)===JSON.stringify(u.parentStepIdChain)&&(g.fastForwardingToStep=!1),U.status!=="SUCCESS"&&!Z||s.closed){S=U.status,b=U;break}else if(h&&v.id===h.toStepId&&JSON.stringify(p)===JSON.stringify(h.parentStepIdChain)){s.setClosed();break}}return{status:S,results:e,terminalResult:b,proposedSteps:f}}async function uL({startedAt:n,stepTypeName:e,result:t,analytics:r,tracer:o}){let i=e.toLowerCase(),a=e.charAt(0).toUpperCase()+e.slice(1),s=new Date,l="";switch(t.status){case"SUCCESS":l=t.message??`${a} executed successfully.`,r.track({type:"execution:step_success",step_type:t.type,command_type:"command"in t?t.command.type:void 0,duration_ms:s.getTime()-n.getTime()});break;case"FAILED":l=t.message??`${a} failed.`,r.track({type:"execution:step_fail",step_type:t.type,command_type:"command"in t?t.command.type:void 0,duration_ms:s.getTime()-n.getTime(),fail_reason:t.message??`${a} failed.`});break;case"CANCELLED":l=t.message??`${a} cancelled.`,r.track({type:"execution:step_cancel",step_type:t.type,command_type:"command"in t?t.command.type:void 0,duration_ms:s.getTime()-n.getTime()});break;default:throw new Error(`Unexpected ${i} status: ${t.status}`)}await o.finish({step:t,message:l,output:ts.parse(t)})}import{randomUUID as Ly}from"crypto";async function Oy({browser:n,signal:e}){let t=new Date;try{return await n.navigate({url:n.baseUrl,initialNavigation:!0}),{status:"PASSED",results:[]}}catch(r){let o={id:Ly(),type:"PRESET_ACTION",status:e.aborted||r.name==="AbortError"?"CANCELLED":"FAILED",failureReason:"UserInfrastructureError",message:r.message,startedAt:t,finishedAt:new Date,results:[],command:{id:Ly(),type:"NAVIGATE",url:n.baseUrl}};return{status:e.aborted||r.name==="AbortError"?"CANCELLED":"FAILED",results:[],failedStepResult:o}}}var pl=async n=>{let{orgId:e,runId:t,runAttemptId:r,testMetadata:o,steps:i,beforeSteps:a,afterSteps:s}=n.inputs;n.fixtures.logger=n.fixtures.logger.child({orgId:e,runId:t,runAttemptId:r,testId:o?.id}),n.fixtures.analytics=n.fixtures.analytics.child({run_id:t,test_id:o?.id,test_name:o?.name});let{logger:l,controller:c}=n.fixtures,{onTestComplete:d,onTestSuccess:p}=n.callbacks.test,m=iy(l);if(n.options.reinitializeBrowser){let h=await Oy({browser:c.browser,signal:c.executeAbortController.signal});if(h.status!=="PASSED")return await d?.(),clearInterval(m?.interval),h}let u;try{return l.info({platform:m?.platform,cpuMetadata:m?.cpuMetadata},`Starting run for Momentic test '${o?.name??"Unnamed test"}'`),u=await mL(n),u}finally{if(l.info({status:u?.status},"Momentic test final result"),clearInterval(m?.interval),await d?.(),u?.status==="PASSED")try{await p?.({steps:i,beforeSteps:a,afterSteps:s})}catch(h){l.warn({err:h},"Error running test success handler, continuing...")}}},mL=async n=>{let{tracer:e}=n.testParams,{runId:t,runAttemptId:r,testMetadata:o,fromStep:i,toStep:a,steps:s,beforeSteps:l,afterSteps:c,orgId:d}=n.inputs,{logger:p,controller:m,context:u,storage:h}=n.fixtures,{collectDebugData:g,disableHealing:f}=n.options;u.setCurrentUrl(m.browser.url());let S="test",b=s,w=[],v=f||i!==void 0||a!==void 0||void 0,x={results:w,state:{failureRecoveryDisabled:v,autoHealingDisabled:v},asyncTasks:[]},C=!1;i?.fromStepId&&i.fromStepId===a?.toStepId?(S="filtered step",x.fastForwardingToStep=!0):i?.fromStepId?(S="partial steps list from step",x.fastForwardingToStep=!0):a?S="partial steps list until step":(S="entire test",C=!0);let A;if(C&&l&&l.length>0){let{status:P,results:K}=await ky(l,"beforeSteps",n);if(P!=="PASSED")return g&&My({tracer:e,debugDataStorage:n.fixtures.debugDataStorage,work:x,controller:m,storage:h,context:u,runId:t,runAttemptId:r,logger:p,status:P}),x.asyncTasks.push(Promise.resolve(n.callbacks.test.onSaveFinalRunResults?.({beforeResults:K,results:[]}))),{status:P,beforeResults:K,results:[]}}p.debug({stepsToExecute:b,fromStep:i,toStep:a},`Starting step execution for ${S}`);let N=await e.startStepList(),{status:O,terminalResult:H,proposedSteps:F}=await An({...n,work:x,listParams:{steps:b,containerName:S,results:w,tracer:N}}),L;if(C&&c&&c.length>0){p.debug("Starting step execution for after step list");try{let{results:P}=await ky(c,"afterSteps",n);L=P}catch(P){p.error({err:P},"Failed to execute after steps list, continuing...")}}if(g&&My({tracer:e,debugDataStorage:n.fixtures.debugDataStorage,work:x,controller:m,storage:h,context:u,runId:t,runAttemptId:r,logger:p,status:O}),await Promise.allSettled(x.asyncTasks),x.asyncTasks.push(Promise.resolve(n.callbacks.test.onSaveFinalRunResults?.({results:w,beforeResults:A,afterResults:L}))),O==="FAILED")return{status:"FAILED",results:w,beforeResults:A,afterResults:L,failedStepResult:H};if(O==="CANCELLED")return{status:"CANCELLED",results:w,beforeResults:A,afterResults:L};let B;if(F&&x.state.healingDetails&&o){let P=hy(3);await n.callbacks.test.onProposedTestSteps?.({name:P,testId:o.id,orgId:n.inputs.orgId,runId:n.inputs.runId,steps:F,details:x.state.healingDetails,purpose:"AUTO_HEALING"}),B={orgId:n.inputs.orgId,name:P}}return{proposedTest:B,status:"PASSED",results:w,beforeResults:A,afterResults:L}};async function ky(n,e,t){let r=t.fixtures.logger,o=await t.testParams.tracer.startStepList();r.debug({stepsToExecute:n},`Starting step execution for ${e}`);let i={results:[],asyncTasks:[],state:{autoHealingDisabled:!0,failureRecoveryDisabled:!0}},a={...t.callbacks,test:{...t.callbacks.test,onSaveFinalRunResults:void 0,onUpdateRun:void 0,onTestComplete:void 0,onTestSuccess:void 0,onProposedTestSteps:void 0}},{status:s,results:l}=await An({...t,work:i,callbacks:a,listParams:{steps:n,containerName:e,tracer:o}});await Promise.allSettled(i.asyncTasks);let c;return s==="SUCCESS"?c="PASSED":s==="CANCELLED"?c="CANCELLED":c="FAILED",{status:c,results:l}}function My({tracer:n,debugDataStorage:e,work:t,controller:r,storage:o,logger:i,context:a,runId:s,runAttemptId:l,status:c}){let d=r.browser.retrieveAndClearDebugData(),p=Ug(d.logsPerPage),m=Gc(d.harPages||{},d.harEntries||{});n.attachConsoleLogs({logger:i,logs:p}),n.attachNetworkLogs({logger:i,logs:m}),t.asyncTasks.push((async()=>{try{let u=await r.browser.screenshot({}),h=await gy({codePath:"test-complete-final",storage:o,screenshotBuff:u,logger:i}),g=await D(r.browser.html(),{milliseconds:2e3});a.setVariable(yy,h),c!=="PASSED"&&c!=="SUCCESS"&&(i.debug({finalPageHtml:g},"Final page state HTML"),i.debug({finalScreenshotUrl:h},"Uploaded final screenshot URL"))}catch{}})(),l?e.storeConsoleLogsForRunAttempt(i,s,l,p):Promise.resolve(null),l?e.storeNetworkLogsForRunAttempt(i,s,l,m):Promise.resolve(null))}async function ul({settings:n,customHeaders:e,envVariables:t,envName:r,baseUrl:o,logger:i,localTools:a,orgId:s,flagStore:l}){let c=ss.parse(n);e&&(c.extraHeaders={...c.extraHeaders,...e});let d=new At({baseUrl:o,envName:r,variablesFromEnvironment:t,currentUrl:o});await ai({obj:c,context:d,bannedKeys:[],allowList:_m,localTools:a,logger:i,orgId:s,flagStore:l});try{return ss.parse(c)}catch(p){throw new R("UserConfigurationError",`The templated browser settings configured by the user are invalid: ${p.message}`)}}import{cloneDeep as xk}from"lodash-es";var Yd={vimiumJs:'var K=Object.defineProperty;var P=Object.getOwnPropertySymbols;var z=Object.prototype.hasOwnProperty,B=Object.prototype.propertyIsEnumerable;var F=(t,e,n)=>e in t?K(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n,D=(t,e)=>{for(var n in e||(e={}))z.call(e,n)&&F(t,n,e[n]);if(P)for(var n of P(e))B.call(e,n)&&F(t,n,e[n]);return t};var g=(t,e,n)=>(F(t,typeof e!="symbol"?e+"":e,n),n);var _=(t,e,n)=>new Promise((o,r)=>{var i=s=>{try{d(n.next(s))}catch(l){r(l)}},a=s=>{try{d(n.throw(s))}catch(l){r(l)}},d=s=>s.done?o(s.value):Promise.resolve(s.value).then(i,a);d((n=n.apply(t,e)).next())});var E=t=>function(e){return e&&e.isTrusted?t.apply(this,arguments):!0};globalThis.forTrusted==null&&(globalThis.forTrusted=E);var k={create(t,e,n,o){return{bottom:o,top:e,left:t,right:n,width:n-t,height:o-e}},copy(t){return{bottom:t.bottom,top:t.top,left:t.left,right:t.right,width:t.width,height:t.height}},translate(t,e,n){return e==null&&(e=0),n==null&&(n=0),{bottom:t.bottom+n,top:t.top+n,left:t.left+e,right:t.right+e,width:t.width,height:t.height}},subtract(t,e){return e=this.create(Math.max(t.left,e.left),Math.max(t.top,e.top),Math.min(t.right,e.right),Math.min(t.bottom,e.bottom)),e.width<0||e.height<0?[k.copy(t)]:[this.create(t.left,t.top,e.left,e.top),this.create(e.left,t.top,e.right,e.top),this.create(e.right,t.top,t.right,e.top),this.create(t.left,e.top,e.left,e.bottom),this.create(e.right,e.top,t.right,e.bottom),this.create(t.left,e.bottom,e.left,t.bottom),this.create(e.left,e.bottom,e.right,t.bottom),this.create(e.right,e.bottom,t.right,t.bottom)].filter(o=>o.height>0&&o.width>0)},intersects(t,e){return t.right>e.left&&t.left<e.right&&t.bottom>e.top&&t.top<e.bottom},intersectsStrict(t,e){return t.right>=e.left&&t.left<=e.right&&t.bottom>=e.top&&t.top<=e.bottom},equals(t,e){for(let n of["top","bottom","left","right","width","height"])if(t[n]!==e[n])return!1;return!0},intersect(t,e){return this.create(Math.max(t.left,e.left),Math.max(t.top,e.top),Math.min(t.right,e.right),Math.min(t.bottom,e.bottom))}};var N={_browserInfoLoaded:!0,_firefoxVersion:null,_isFirefox:!1,isFirefox(){if(!this._browserInfoLoaded)throw Error("browserInfo has not yet loaded.");return this._isFirefox},firefoxVersion(){if(!this._browserInfoLoaded)throw Error("browserInfo has not yet loaded.");return this._firefoxVersion},isString(t){return typeof t=="string"||t instanceof String}};var f={isReady(){return document.readyState!=="loading"},documentReady:function(){let t=document.readyState!=="loading",e=[];if(!t){let n;globalThis.addEventListener("DOMContentLoaded",n=E(function(){globalThis.removeEventListener("DOMContentLoaded",n,!0),t=!0;for(let o of e)o();e=null}),!0)}return function(n){if(t)return n();e.push(n)}}(),documentComplete:function(){let t=document.readyState==="complete",e=[];if(!t){let n;globalThis.addEventListener("load",n=E(function(o){if(o.target===document){globalThis.removeEventListener("load",n,!0),t=!0;for(let r of e)r();e=null}}),!0)}return function(n){t?n():e.push(n)}}(),createElement(t){let e=document.createElement(t);return e instanceof HTMLElement?(this.createElement=n=>document.createElement(n),e):(this.createElement=n=>document.createElementNS("http://www.w3.org/1999/xhtml",n),this.createElement(t))},addElementsToPage(t,e){let n=this.createElement("div");e.id!=null&&(n.id=e.id),e.className!=null&&(n.className=e.className);for(let o of t)n.appendChild(o);return document.body.appendChild(n),n},removeElement(t){return t.parentNode.removeChild(t)},isTopFrame(){return globalThis.top===globalThis.self},makeXPath(t){let e=[];for(let n of t)e.push(".//"+n,".//xhtml:"+n);return e.join(" | ")},evaluateXPath(t,e){let n=document.webkitIsFullScreen?document.webkitFullscreenElement:document.documentElement,o=function(r){return r==="xhtml"?"http://www.w3.org/1999/xhtml":null};return document.evaluate(t,n,o,e,null)},getVisibleClientRect(t,e){let n;e==null&&(e=!1);let o=(()=>{let i=[];for(n of t.getClientRects())i.push(k.copy(n));return i})(),r=function(){let i=window.getComputedStyle(t,null),a=i.getPropertyValue("display").indexOf("inline")===0&&i.getPropertyValue("font-size")==="0px";return r=()=>a,a};for(n of o){let i;if((n.width===0||n.height===0)&&e)for(let a of Array.from(t.children)){i=window.getComputedStyle(a,null);let d=i.getPropertyValue("position");if(i.getPropertyValue("float")==="none"&&!["absolute","fixed"].includes(d)&&!(n.height===0&&r()&&i.getPropertyValue("display").indexOf("inline")===0))continue;let s=this.getVisibleClientRect(a,!0);if(!(s===null||s.width<3||s.height<3))return s}else{if(n=this.cropRectToVisible(n),n===null||n.width<3||n.height<3||(i=window.getComputedStyle(t,null),i.getPropertyValue("visibility")!=="visible"))continue;return n}}return null},cropRectToVisible(t){let e=k.create(Math.max(t.left,0),Math.max(t.top,0),t.right,t.bottom);return e.top>=window.innerHeight-4||e.left>=window.innerWidth-4?null:e},getClientRectsForAreas(t,e){let n=[];for(let o of e){let r,i,a,d,s=o.coords.split(",").map(p=>parseInt(p,10)),l=o.shape.toLowerCase();if(["rect","rectangle"].includes(l))s.length==4&&([r,a,i,d]=s);else if(["circle","circ"].includes(l)){if(s.length==3){let[p,w,v]=s,u=v/Math.sqrt(2);r=p-u,i=p+u,a=w-u,d=w+u}}else l==="default"?s.length==2&&([r,a,i,d]=[0,0,t.width,t.height]):s.length>=4&&([r,a,i,d]=s);let c=k.translate(k.create(r,a,i,d),t.left,t.top);c=this.cropRectToVisible(c),c&&!isNaN(c.top)&&!isNaN(c.left)&&!isNaN(c.width)&&!isNaN(c.height)&&n.push({element:o,rect:c})}return n},isSelectable(t){if(!(t instanceof Element))return!1;let e=["button","checkbox","color","file","hidden","image","radio","reset","submit"];return t.nodeName.toLowerCase()==="input"&&e.indexOf(t.type)===-1||t.nodeName.toLowerCase()==="textarea"||t.isContentEditable},isEditable(t){return this.isSelectable(t)||(t.nodeName!=null?t.nodeName.toLowerCase():void 0)==="select"},isEmbed(t){let e=t.nodeName!=null?t.nodeName.toLowerCase():null;return["embed","object"].includes(e)},isFocusable(t){return t&&(this.isEditable(t)||this.isEmbed(t))},isDOMDescendant(t,e){let n=e;for(;n!==null;){if(n===t)return!0;n=n.parentNode}return!1},isSelected(t){let e=document.getSelection();if(t.isContentEditable){let n=e.anchorNode;return n&&this.isDOMDescendant(t,n)}else if(f.getSelectionType(e)==="Range"&&e.isCollapsed){let n=e.anchorNode.childNodes[e.anchorOffset];return t===n}else return!1},simulateSelect(t){if(t===document.activeElement&&f.isEditable(document.activeElement))return handlerStack.bubbleEvent("click",{target:t});if(t.focus(),t.tagName.toLowerCase()!=="textarea"||t.value.indexOf(`\n`)<0)try{if(t.selectionStart===0&&t.selectionEnd===0)return t.setSelectionRange(t.value.length,t.value.length)}catch(e){}},simulateClick(t,e){e==null&&(e={});let n=["mouseover","mousedown","mouseup","click"],o=[];for(let r of n){let i=this.simulateMouseEvent(r,t,e);o.push(i)}return o},simulateMouseEvent(t,e,n){if(n==null&&(n={}),t==="mouseout"){if(e==null&&(e=this.lastHoveredElement),this.lastHoveredElement=void 0,e==null)return}else t==="mouseover"&&(this.simulateMouseEvent("mouseout",void 0,n),this.lastHoveredElement=e);let o=new MouseEvent(t,{bubbles:!0,cancelable:!0,composed:!0,view:window,detail:1,ctrlKey:n.ctrlKey,altKey:n.altKey,shiftKey:n.shiftKey,metaKey:n.metaKey});return e.dispatchEvent(o)},simulateClickDefaultAction(t,e){let n;if(e==null&&(e={}),(t.tagName!=null?t.tagName.toLowerCase():void 0)!=="a"||!t.href)return;let{ctrlKey:o,shiftKey:r,metaKey:i,altKey:a}=e;KeyboardUtils.platform==="Mac"?n=i===!0&&o===!1:n=i===!1&&o===!0,n?chrome.runtime.sendMessage({handler:"openUrlInNewTab",url:t.href,active:r===!0}):r===!0&&i===!1&&o===!1&&a===!1?chrome.runtime.sendMessage({handler:"openUrlInNewWindow",url:t.href}):t.target==="_blank"&&chrome.runtime.sendMessage({handler:"openUrlInNewTab",url:t.href,active:!0})},simulateHover(t,e){return e==null&&(e={}),this.simulateMouseEvent("mouseover",t,e)},simulateUnhover(t,e){return e==null&&(e={}),this.simulateMouseEvent("mouseout",t,e)},addFlashRect(t){let e=this.createElement("div");return e.classList.add("vimiumReset"),e.classList.add("vimiumFlash"),e.style.left=t.left+"px",e.style.top=t.top+"px",e.style.width=t.width+"px",e.style.height=t.height+"px",document.documentElement.appendChild(e),e},getViewportTopLeft(){let t=document.documentElement,e=getComputedStyle(t),n=t.getBoundingClientRect();if(e.position==="static"&&!/content|paint|strict/.test(e.contain||"")){let o=parseInt(e.marginTop),r=parseInt(e.marginLeft);return{top:-n.top+o,left:-n.left+r}}else{let o,r;return N.isFirefox()?(r=parseInt(e.borderTopWidth),o=parseInt(e.borderLeftWidth)):{clientTop:r,clientLeft:o}=t,{top:-n.top-r,left:-n.left-o}}},suppressPropagation(t){t.stopImmediatePropagation()},suppressEvent(t){t.preventDefault(),this.suppressPropagation(t)},consumeKeyup:function(){let t=null;return function(e,n=null,o){if(!e.repeat){t!=null&&handlerStack.remove(t);let{code:r}=e;t=handlerStack.push({_name:"dom_utils/consumeKeyup",keyup(i){return i.code!==r||(this.remove(),o?f.suppressPropagation(i):f.suppressEvent(i)),handlerStack.continueBubbling},blur(i){return i.target===window&&this.remove(),handlerStack.continueBubbling}})}return typeof n=="function"&&n(),o?(f.suppressPropagation(e),handlerStack.suppressPropagation):(f.suppressEvent(e),handlerStack.suppressEvent)}}(),getSelectionType(t){return t==null&&(t=document.getSelection()),t.type?t.type:t.rangeCount===0?"None":t.isCollapsed?"Caret":"Range"},getElementWithFocus(t,e){let n,o=n=t.getRangeAt(0);f.getSelectionType(t)==="Range"&&(o=n.cloneRange(),o.collapse(e)),n=o.startContainer,n.nodeType===1&&(n=n.childNodes[o.startOffset]);let r=n;for(;r&&r.nodeType!==1;)r=r.previousSibling;return n=r||(n!=null?n.parentNode:void 0),n},getSelectionFocusElement(){let t=window.getSelection(),e=t.focusNode;return e==null?null:(e===t.anchorNode&&t.focusOffset===t.anchorOffset&&(e=e.childNodes[t.focusOffset]||e),e.nodeType!==Node.ELEMENT_NODE?e.parentElement:e)},getContainingElement(t){return(typeof t.getDestinationInsertionPoints=="function"?t.getDestinationInsertionPoints()[0]:void 0)||t.parentElement},windowIsTooSmall(){return window.innerWidth<3||window.innerHeight<3},injectUserCss(){let t=document.createElement("style");t.type="text/css",t.textContent=Settings.get("userDefinedLinkHintCss"),document.head.appendChild(t)}};var O={MAX_CONTENT_LENGTH:1e3,MAX_ATTRIBUTE_LENGTH:500,MAX_NUM_DATA_ATTRIBUTES:10,commonAttributes:["id","className","title","aria-label","aria-labelledby"],attributeNamesMapping:new Map([["a",["href","title","rel","target"]],["label",["for"]],["input",["type","name","placeholder","checked","maximumLength"]],["textarea",["placeholder","maximumLength"]],["button",["type"]],["select",["name","multiple"]],["div",["role"]],["iframe",["src"]],["img",["src","alt"]]]),describe(t){var r,i;let e={};this.addAttributes(t,this.commonAttributes,e);let n=((i=(r=t.tagName).toLowerCase)==null?void 0:i.call(r))||"";this.attributeNamesMapping.has(n)&&this.addAttributes(t,this.attributeNamesMapping.get(n),e),this.addDataAttrs(t,e);let o=this.getContent(t);return this.additionalHandling(t,D({tag:n,attributes:e},o&&{content:o}))},getContent(t){var n,o;let e=((o=(n=t.tagName).toLowerCase)==null?void 0:o.call(n))||"";return["input","textarea"].includes(e)?t.value:["div","iframe","img","body"].includes(e)?null:(["a","button","select","label"].includes(e),t.innerText)},additionalHandling(t,e){var o,r;if((((r=(o=t.tagName).toLowerCase)==null?void 0:r.call(o))||"")=="label"&&t.hasAttribute("for")){let i=t.getAttribute("for"),a=document.getElementById(i);a&&(e.target=this.describe(a))}return e},addAttributes(t,e,n){n||(n={});for(let o of e)t.hasAttribute(o)&&(n[o]=t.getAttribute(o).substring(0,this.MAX_ATTRIBUTE_LENGTH));return n},addDataAttrs(t,e){let n=0;for(let o in t.dataset)if(e[`data-${o}`]=t.dataset[o].substring(0,this.MAX_ATTRIBUTE_LENGTH),n++,n>this.MAX_NUM_DATA_ATTRIBUTES)return e;return e}};var x=null,C=()=>G()||document.scrollingElement||document.body,W=function(t){return t?t<0?-1:1:0},U={x:{axisName:"scrollLeft",max:"scrollWidth",viewSize:"clientWidth"},y:{axisName:"scrollTop",max:"scrollHeight",viewSize:"clientHeight"}},X=function(t,e,n){if(N.isString(n)){let o=n;return o==="viewSize"&&t===C()?e==="x"?window.innerWidth:window.innerHeight:t[U[e][o]]}else return n},V=function(t,e,n){let o=U[e].axisName,r=t[o];if(t.scrollBy){let i={behavior:"instant"};i[e==="x"?"left":"top"]=n,t.scrollBy(i)}else t[o]+=n;return t[o]!==r},q=function(t,e){let n=window.getComputedStyle(t);return!(n.getPropertyValue(`overflow-${e}`)==="hidden"||["hidden","collapse"].includes(n.getPropertyValue("visibility"))||n.getPropertyValue("display")==="none")},T=function(t,e,n,o){let r=o*X(t,e,n)||-1;return r=W(r),V(t,e,r)&&V(t,e,-r)},$=function(t,e,n,o){return e==null&&(e="y"),n==null&&(n=1),o==null&&(o=1),T(t,e,n,o)&&q(t,e)},j=function(t=null){let e;if(!t){let n=C();if(T(n,"y",1,1)||T(n,"y",-1,1))return n;t=document.body||C()}if(T(t,"y",1,1)||T(t,"y",-1,1))return t;{let n=Array.from(t.children).map(o=>({element:o,rect:f.getVisibleClientRect(o)})).filter(o=>o.rect);n.map(o=>o.area=o.rect.width*o.rect.height);for(e of n.sort((o,r)=>r.area-o.area)){let o=j(e.element);if(o)return o}return null}},L={init(){x=null},isScrollableElement(t){return x||(x=C()&&j()||C()),t!==x&&$(t)}},G=function(){let t=J[window.location.host];if(t)return document.querySelector(t)},J={"twitter.com":"div.permalink-container div.permalink[role=main]","reddit.com":"#overlayScrollContainer","new.reddit.com":"#overlayScrollContainer","www.reddit.com":"#overlayScrollContainer","web.telegram.org":".MessageList"};window.Scroller=L;var A=function(){let t=null;return f.documentReady(()=>t=document.hasFocus()),globalThis.addEventListener("focus",E(function(e){return e.target===window&&(t=!0),!0}),!0),globalThis.addEventListener("blur",E(function(e){return e.target===window&&(t=!1),!0}),!0),()=>t}();Object.assign(globalThis,{windowIsFocused:A});var R=class{constructor(e){g(this,"element");g(this,"image");g(this,"rect");g(this,"linkText");g(this,"showLinkText");g(this,"reason");g(this,"secondClassCitizen");g(this,"possibleFalsePositive");Object.seal(this),e&&Object.assign(this,e)}},M={getLocalHintsForElement(t){var p,w,v;let e=((w=(p=t.tagName).toLowerCase)==null?void 0:w.call(p))||"",n=!1,o=!1,r=!1,i=[],a=[],d=null;if(e==="img"){let u=t.getAttribute("usemap");if(u){let h=t.getClientRects();u=u.replace(/^#/,"").replace(\'"\',\'\\\\"\');let m=document.querySelector(`map[name="${u}"]`);if(m&&h.length>0){n=!0;let y=m.getElementsByTagName("area"),S=f.getClientRectsForAreas(h[0],y);S=S.map(I=>Object.assign(I,{image:t})),a.push(...S)}}}let s=t.getAttribute("aria-disabled");if(s&&["","true"].includes(s.toLowerCase()))return[];if(this.checkForAngularJs||(this.checkForAngularJs=function(){if(document.getElementsByClassName("ng-scope").length===0)return()=>!1;{let h=[];for(let m of["","data-","x-"])for(let y of["-",":","_"])h.push(`${m}ng${y}click`);return function(m){for(let y of h)if(m.hasAttribute(y))return!0;return!1}}}()),n||(n=this.checkForAngularJs(t)),t.hasAttribute("onclick"))n=!0;else{let u=t.getAttribute("role"),h=["button","tab","link","checkbox","menuitem","menuitemcheckbox","menuitemradio","radio"];if(u!=null&&h.includes(u.toLowerCase()))n=!0;else{let m=t.getAttribute("contentEditable");m!=null&&["","contenteditable","true","plaintext-only"].includes(m.toLowerCase())&&(n=!0)}}if(!n&&t.hasAttribute("jsaction")){let u=t.getAttribute("jsaction").split(";");for(let h of u){let m=h.trim().split(":");if(m.length>=1&&m.length<=2){let[y,S,I]=m.length===1?["click",...m[0].trim().split("."),"_"]:[m[0],...m[1].trim().split("."),"_"];n||(n=y==="click"&&S!=="none"&&I!=="_")}}}switch(e){case"a":n=!0;break;case"textarea":n||(n=!t.disabled&&!t.readOnly);break;case"input":n||(n=!(((v=t.getAttribute("type"))==null?void 0:v.toLowerCase())=="hidden"||t.disabled||t.readOnly&&f.isSelectable(t)));break;case"button":case"select":n||(n=!t.disabled);break;case"object":case"embed":n=!0;break;case"label":n||(n=t.control!=null&&!t.control.disabled&&this.getLocalHintsForElement(t.control).length===0);break;case"body":n||(n=t===document.body&&!A()&&window.innerWidth>3&&window.innerHeight>3&&(document.body!=null?document.body.tagName.toLowerCase():void 0)!=="frameset"?d="Frame.":void 0),n||(n=t===document.body&&A()&&L.isScrollableElement(t)?d="Scroll.":void 0);break;case"img":n||(n=["zoom-in","zoom-out"].includes(t.style.cursor));break;case"div":case"ol":case"ul":n||(n=t.clientHeight<t.scrollHeight&&L.isScrollableElement(t)?d="Scroll.":void 0);break;case"details":n=!0,d="Open.";break}let l=t.getAttribute("class");!n&&(l!=null&&l.toLowerCase().includes("button"))&&(n=!0,r=!0);let c=t.getAttribute("tabindex"),b=c?parseInt(c):-1;if(!n&&!(b<0)&&!isNaN(b)&&(n=!0,o=!0),n)if(a.length>0){let u=a.map(h=>new R({element:h.element,image:t,rect:h.rect,secondClassCitizen:o,possibleFalsePositive:r,reason:d}));i.push(...u)}else{let u=f.getVisibleClientRect(t,!0);if(u!==null){let h=new R({element:t,rect:u,secondClassCitizen:o,possibleFalsePositive:r,reason:d});i.push(h)}}return i},getElementFromPoint(t,e,n,o){n==null&&(n=document),o==null&&(o=[]);let r=n.elementsFromPoint?n.elementsFromPoint(t,e)[0]:n.elementFromPoint(t,e);return o.includes(r)?r:(o.push(r),r&&r.shadowRoot?M.getElementFromPoint(t,e,r.shadowRoot,o):r)},getLocalHints(t){if(!document.body)return[];let e=(s,l)=>{l==null&&(l=[]);for(let c of Array.from(s.querySelectorAll("*")))l.push(c),c.shadowRoot&&e(c.shadowRoot,l);return l},n=e(document.body),o=[];for(let s of Array.from(n))if(!t||s.href){let l=this.getLocalHintsForElement(s);o.push(...l)}o=o.reverse();let r=[1,2,3];o=o.filter((s,l)=>{if(!s.possibleFalsePositive)return!0;let b=Math.max(0,l-6);for(;b<l;){let p=o[b].element;for(let w of r)if(p=p==null?void 0:p.parentElement,p===s.element)return!1;b+=1}return!0});let i=o.filter(s=>{if(s.secondClassCitizen)return!1;let l=s.rect,c=M.getElementFromPoint(l.left+l.width*.5,l.top+l.height*.5);if(c&&(s.element.contains(c)||c.contains(s.element))||s.element.localName=="area"&&c==s.image)return!0;let p=[l.top+.1,l.bottom-.1],w=[l.left+.1,l.right-.1];for(let v of p)for(let u of w){let h=M.getElementFromPoint(u,v);if(h&&(s.element.contains(h)||h.contains(s.element)))return!0}});i.reverse();let{top:a,left:d}=f.getViewportTopLeft();for(let s of i)s.rect.top+=a,s.rect.left+=d;return i}};var H=class{constructor(){this.hints=null;this.hintMarkers=null;this.markersDiv=null;this.enrichedMarkers=null}reset(){this.removeMarkers(),this.hints=null,this.hintMarkers=null,this.markersDiv=null}capture(){return _(this,null,function*(){this.reset(),this.createMarkers(),this.displayMarkers()})}createMarkers(){this.hints=M.getLocalHints(),this.hintMarkers=new Map,this.hints.forEach((e,n)=>{var i,a;let o=f.createElement("div"),r=(a=(i=e.element.attributes["data-momentic-id"])==null?void 0:i.value)!=null?a:void 0;if(!r){console.warn(`[MOMENTIC] No data-momentic-id found for interactive element ${e.element.outerHTML}`);return}o.style.left=e.rect.left+"px",o.style.top=e.rect.top+"px",o.style.zIndex=214e7+n,o.className="vimiumReset internalVimiumHintMarker vimiumHintMarker",Z(o,r),this.hintMarkers.set(r,{hint:e,marker:o})})}enrichMarkers(){if(this.hintMarkers){this.enrichedMarkers=[];for(let[e,n]of this.hintMarkers)this.enrichedMarkers.push(Object.assign(O.describe(n.hint.element),{hintString:e}))}}displayMarkers(){this.hintMarkers&&(this.markersDiv||(this.markersDiv=f.addElementsToPage(Array.from(this.hintMarkers.values()).map(e=>e.marker),{id:"vimiumHintMarkerContainer",className:"vimiumReset"})))}removeMarkers(){this.markersDiv&&(f.removeElement(this.markersDiv),this.markersDiv=null)}toggleMarkers(){this.markersDiv?this.removeMarkers():this.displayMarkers()}},Z=(t,e)=>{for(let n of e){let o=document.createElement("span");o.className="vimiumReset",o.textContent=n,t.appendChild(o)}};window.HintManager=H;\n',vimiumCss:'.vimiumReset,a.vimiumReset,a:hover.vimiumReset,a:link.vimiumReset,a:visited.vimiumReset,div.vimiumReset,span.vimiumReset,table.vimiumReset,td.vimiumReset,tr.vimiumReset{background:none;border:none;bottom:auto;box-shadow:none;color:#000;cursor:auto;display:inline;float:none;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:inherit;font-style:normal;font-variant:normal;font-weight:400;height:auto;left:auto;letter-spacing:0;line-height:100%;margin:0;max-height:none;max-width:none;min-height:0;min-width:0;opacity:1;padding:0;position:static;right:auto;text-align:left;text-decoration:none;text-indent:0;text-shadow:none;text-transform:none;top:auto;vertical-align:baseline;white-space:normal;width:auto;z-index:2140000000}tbody.vimiumReset,thead.vimiumReset{display:table-header-group}tbody.vimiumReset{display:table-row-group}div.internalVimiumHintMarker{background:linear-gradient(180deg,#fff785 0,#ffc542);border:1px solid #c38a22;border-radius:3px;box-shadow:0 3px 7px 0 rgba(0,0,0,.3);display:block;font-size:11px;left:-1px;overflow:hidden;padding:1px 3px 0;position:absolute;top:-1px;white-space:nowrap}div.internalVimiumHintMarker span{color:#302505;font-family:Helvetica,Arial,sans-serif;font-size:11px;font-weight:700;text-shadow:0 1px 0 hsla(0,0%,100%,.6)}div.internalVimiumHintMarker>.matchingCharacter{color:#d4ac3a}div>.vimiumActiveHintMarker span{color:#a07555!important}div.internalVimiumInputHint{background-color:rgba(255,247,133,.3);border:1px solid #c38a22;display:block;pointer-events:none;position:absolute}div.internalVimiumSelectedInputHint{background-color:hsla(0,100%,70%,.3);border:1px solid #933!important}div.internalVimiumSelectedInputHint span{color:#fff!important}div.vimiumHighlightedFrame{border:5px solid #ff0;box-sizing:border-box;margin:0;pointer-events:none}div.vimiumHighlightedFrame,iframe.vimiumHelpDialogFrame{height:100%;left:0;padding:0;position:fixed;top:0;width:100%}iframe.vimiumHelpDialogFrame{background-color:hsla(0,0%,4%,.6);border:none;display:block;z-index:2139999997}div#vimiumHelpDialogContainer{background-color:#fff;border:2px solid #b3b3b3;border-radius:6px;margin:50px auto;max-height:calc(100% - 100px);max-width:calc(100% - 100px);opacity:1;overflow-x:auto;overflow-y:auto;width:840px}div#vimiumHelpDialog{min-width:600px;padding:8px 12px}span#vimiumTitle,span#vimiumTitle *,span#vimiumTitle span{font-size:20px}#vimiumTitle{display:block;line-height:130%;white-space:nowrap}td.vimiumHelpDialogTopButtons{text-align:right;width:100%}#helpDialogOptionsPage,#helpDialogWikiPage{font-size:14px;padding-left:5px;padding-right:5px}div.vimiumColumn{float:left;font-size:11px;line-height:130%;width:50%}div.vimiumColumn tr{display:table-row}div.vimiumColumn td{display:table-cell;font-size:11px;line-height:130%}div.vimiumColumn table,div.vimiumColumn td,div.vimiumColumn tr{margin:0;padding:0}div.vimiumColumn table{table-layout:auto;width:100%}div.vimiumColumn td{padding:1px;vertical-align:top}div#vimiumHelpDialog div.vimiumColumn tr>td:first-of-type{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:14px;text-align:right;white-space:nowrap}span.vimiumHelpDialogKey{background-color:#f3f3f3;border:1px solid;border-color:#ccc #ccc #bbb;border-radius:3px;box-shadow:inset 0 -1px 0 #bbb;color:#212121;font-family:monospace;font-size:11px;margin-left:2px;padding:1px 4px}div#vimiumHelpDialog div.vimiumColumn tr>td:nth-of-type(3){width:100%}div#vimiumHelpDialog div.vimiumDivider{background-color:#9a9a9a;display:block;height:1px;margin:10px auto;width:100%}div#vimiumHelpDialog td.vimiumHelpSectionTitle{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:16px;font-weight:700;padding-top:3px}div#vimiumHelpDialog td.vimiumHelpDescription{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:14px}div#vimiumHelpDialog span.vimiumCopyCommandNameName{cursor:pointer;font-size:12px;font-style:italic}div#vimiumHelpDialog tr.advanced{display:none}div#vimiumHelpDialog.showAdvanced tr.advanced{display:table-row}div#vimiumHelpDialog div.advanced td:nth-of-type(3){color:#555}div#vimiumHelpDialog a.closeButton{color:#555;cursor:pointer;font-family:courier new;font-size:24px;font-weight:700;padding-left:5px;position:relative;text-decoration:none;top:3px}div#vimiumHelpDialog a{text-decoration:underline}div#vimiumHelpDialog a.closeButton:hover{color:#000;-webkit-user-select:none}div#vimiumHelpDialogFooter{display:block;margin-bottom:37px;position:relative}table.helpDialogBottom{width:100%}td.helpDialogBottomRight{float:right;text-align:right;width:100%}td.helpDialogBottomLeft,td.helpDialogBottomRight{padding:0}div#vimiumHelpDialogFooter *{font-size:10px}a#toggleAdvancedCommands,span#help-dialog-tip{font-size:10px;position:relative;top:19px;white-space:nowrap}a#toggleAdvancedCommands,a:active.vimiumHelDialogLink,a:hover.vimiumHelDialogLink,a:link.vimiumHelDialogLink,a:visited.vimiumHelDialogLink{color:#2f508e;cursor:pointer;text-decoration:underline}div.vimiumHUD{background:#f1f1f1;border:1px solid #aaa;border-radius:4px;bottom:8px;box-shadow:0 2px 10px rgba(0,0,0,.8);display:block;left:8px;position:fixed;text-align:left;width:calc(100% - 20px);z-index:2139999999}iframe.vimiumHUDFrame{background-color:transparent;border:none;bottom:-14px;display:block;height:58px;margin:0 0 0 -40%;min-width:300px;opacity:0;overflow:hidden;padding:0;position:fixed;right:20px;width:20%;z-index:2139999998}div.vimiumHUD .vimiumHUDSearchArea{background-color:#f1f1f1;border-radius:4px 4px 0 0;display:block;padding:3px}div.vimiumHUD .vimiumHUDSearchAreaInner{border-radius:3px;box-sizing:border-box;color:#777;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:14px;height:30px;line-height:20px;margin-bottom:0;outline:none;padding:2px 4px;width:100%}div.vimiumHUD .hud-find{background:#fff;border:1px solid #ccc}div.vimiumHUD span#hud-find-input,div.vimiumHUD span#hud-match-count{color:#000;display:inline;outline:none;overflow-y:hidden;white-space:nowrap}div.vimiumHUD span#hud-find-input:before{content:"/"}div.vimiumHUD span#hud-match-count{color:#aaa;font-size:12px}div.vimiumHUD span#hud-find-input br{display:none}div.vimiumHUD span#hud-find-input *{display:inline;white-space:nowrap}body.vimiumFindMode ::selection{background:#ff9632}iframe.vomnibarFrame{background-color:transparent;border:none;display:block;font-family:sans-serif;height:calc(100% - 70px);left:50%;margin:0 0 0 -40%;min-width:400px;overflow:hidden;padding:0;position:fixed;top:70px;width:calc(80% + 20px);z-index:2139999998}div.vimiumFlash{background-color:transparent;box-shadow:0 0 4px 2px #4183c4;padding:1px;position:absolute;z-index:2140000000}iframe.vimiumUIComponentHidden{display:none}iframe.vimiumUIComponentVisible{color-scheme:light dark;display:block}iframe.vimiumUIComponentReactivated{border:5px solid #ff0}iframe.vimiumNonClickable{pointer-events:none}@media (prefers-color-scheme:dark){iframe.reverseDarkReaderFilter{-webkit-filter:invert(100%) hue-rotate(180deg)!important;filter:invert(100%) hue-rotate(180deg)!important}body.vimiumBody{background-color:#292a2d;color:#fff}body.vimiumBody a,body.vimiumBody a:visited{color:#8ab4f8}body.vimiumBody input,body.vimiumBody textarea{background-color:#1d1d1f;border-color:#1d1d1f;color:#e8eaed}body.vimiumBody div.example{color:#9aa0a6}body.vimiumBody div#footer,body.vimiumBody div#state,div#vimiumHelpDialogContainer{background-color:#202124;border-color:hsla(0,0%,100%,.1)}div#vimiumHelpDialog{background-color:#292a2d;color:#fff}div#vimiumHelpDialog td.vimiumHelpDescription{color:#c9cccf}div#vimiumHelpDialog td.vimiumHelpSectionTitle,span#vimiumTitle{color:#fff}#vimiumTitle>span:first-child{color:#8ab4f8!important}div#vimiumHelpDialog a{color:#8ab4f8}div#vimiumHelpDialog div.vimiumDivider{background-color:hsla(0,0%,100%,.1)}span.vimiumHelpDialogKey{background-color:#1d1d1f;border:1px solid #000;box-shadow:none;color:#fff}}',htmlUtilsLibJs:`var __defProp = Object.defineProperty;
57
+ ${C.feedback}`,m.status="FAILED",c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,status:"FAILED",message:m.message}),m;O&&c.onDynamicAIActionEvaluatingEvent?.({stepId:O,status:"FAILED",message:C.feedback});break}case"IMPOSSIBLE":return m.message=`Our AI evaluator determined this task cannot be achieved: ${A}`,m.status="FAILED",c.onDynamicAIActionEvaluatingEvent?.({stepId:O??e.id,status:"FAILED",message:m.message}),m}let H=setTimeout(()=>{c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Deciding what to do next..."})},1500);p.info({commandIndex:S,lastActionHint:w},`Generating new sub-command ${S} within AI action`);let F,L;try{({command:F,reasoning:L}=await i.promptToCommand({goal:u,history:f,startingScreenshot:g,disableCache:r?.advanced.disableAICaching??!1,logger:p,actionHint:w,langfuseSessionId:d})),p.info({command:F,reasoning:L},"Got proposed command")}finally{clearTimeout(H)}if(F.type==="FAILURE")return clearTimeout(H),m.status="FAILED",m.message=`Our AI agent determined that no supported actions can fulfill the goals: ${L}`,m;let B={id:Kd(),type:"PRESET_ACTION",command:F},P={substepIndex:S+1,message:L||"Generated new command."};c.onDynamicCommandGenerated?.({...P,step:B,parentStepId:e.id}),p.info({commandId:F.id},`Executing sub-command ${S} within AI step: ${_r(F)}`);let K=await t.startSubSteps(),Y=(await n.executeStepList({...n,options:{...n.options,disableHealing:!0},listParams:{containerName:"AI action newly generated step",steps:[B],tracer:K}})).results[0];c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Waiting for page to stabilize before next action..."}),await i.browser.waitForDOMStability({logger:p});let Z=await i.browser.screenshot({clearHighlights:!0,retries:1});m.results.push(Y),f.push({screenshotBase64AfterCommand:`data:image/jpeg;base64,${Z.toString("base64")}`,urlAfterCommand:i.browser.url(),serializedCommand:_r(F),elementInteracted:Y.results[0]?.elementInteracted,thoughts:L});let ft={substepIndex:S,output:{...Y,message:Y.message??"Successfully executed preset action."},step:B,parentStepId:e.id};if(c.onDynamicCommandExecuted?.(ft),await t.finish({output:ts.parse(Y),step:Y,message:Y.message}),Y.status==="FAILED")if(m.status="FAILED",m.message=Y.message,b<3)b++,v=`The last attempted action resulted in a Momentic error. A different element may need to be targeted. Error: ${Y.message}`;else return m;else if(Y.status==="CANCELLED")return m.status="CANCELLED",m.message=Y.message,m;S++}};async function Cy(n){let{results:e}=n.failureRecoveryParams,t=e[e.length-1],r=sL(t);if(r)return n.fixtures.logger.info({failedResult:t,isNotEligible:r},"Skipping failure recovery because of ineligible failure"),null;try{return await aL(n)}catch(o){return n.fixtures.logger.error({err:o},"Error during failure recovery attempt"),null}}async function Ey({screenshot:n,controller:e,currentPageState:t,newStep:r,patch:o,logger:i}){if(r.aiSuggested=!0,r.type==="PRESET_ACTION"&&"cache"in r.command&&r.command.cache&&"target"in r.command.cache&&"target"in r.command&&r.command.target?.type==="description")try{let a=r.command.cache.target.id,s=await e.getReverseMappedDescription({browserState:t,targetId:a,disableCache:!1,screenshot:n});r.command.target.elementDescriptor=s}catch(a){i.error({err:a},"Error while reverse mapping target in failure recovery")}r.type==="PRESET_ACTION"&&(r.command.thoughts=o.thoughts)}async function aL(n){let{fixtures:e,work:t,failureRecoveryParams:r}=n,{controller:o,logger:i}=e,{results:a,failedStep:s,nextSteps:l,tracer:c}=r;if(!a.length)throw new Error("Attempted failure recovery with no failed results");await Promise.allSettled(t.asyncTasks??[]);let d=o.browser.url(),p=`data:image/jpeg;base64,${(await o.browser.screenshot({})).toString("base64")}`,m=(await o.browser.getBrowserState({skipWait:!0})).serialize(),{results:u}=await Rs(i,e.debugDataStorage,a,{numScreenshots:3,addIndices:!0}),h=l.map(w=>ln(w)),g=await o.runFailureRecovery({currentUrl:d,currentScreenshot:p,failedResults:u,currentPageState:m,nextStepsSerialized:h});if(g.scenario==="INELIGIBLE"||!g.patch)return null;let f=[];if(g.patch.op==="add"){let w=g.patch.value;if(!w)throw new Error("No value in add patch in failure recovery");await Ey({screenshot:p,controller:o,currentPageState:m,newStep:w,patch:g.patch,logger:i}),f=[w,s]}else if(g.patch.op==="replace"){let w=g.patch.value;if(!w)throw new Error("No value in replace patch in failure recovery");await Ey({screenshot:p,controller:o,currentPageState:m,newStep:w,patch:g.patch,logger:i}),f=[w]}else if(g.patch.op==="remove"&&s.type==="PRESET_ACTION"&&["AI_ASSERTION","PAGE_CHECK","ELEMENT_CHECK"].includes(s.command.type))throw new Error("Cannot modify assertion step in failure recovery");let S=await c.startSubSteps(),b;if(f.length){b=await ur(n.work,()=>n.executeStepList({...n,fixtures:{...n.fixtures},listParams:{steps:f,containerName:"AI-recovered step list",tracer:S}}));for(let w of b.results)w.aiSuggested&&w.type==="PRESET_ACTION"&&(w.message=`AI suggested step: ${w.command.thoughts}`)}else b={status:"SUCCESS",results:[],proposedSteps:[]};return ll(t,{type:"FAILURE_RECOVERY",thoughts:g.reasoning}),t.state.failureRecoveryDisabled=!0,b}function sL(n){if(!n)return"No failed result";if(n.type!=="PRESET_ACTION")return"Not a preset action";let e=n.message;return e?e.includes("AbortError:")?"AbortError":Pm.some(t=>e.includes(t))?"User fault and likely irrecoverable":"":"No error message available"}async function Ry(n){let{step:e,tracer:t}=n.frameParams,{logger:r,controller:o}=n.fixtures,i=new Date,a=o.browser.getActiveFrameConfig();o.browser.setActiveFrameConfig(e.identifier);let s;try{let d=await t.startSubSteps();s=await n.executeStepList({...n,listParams:{steps:e.steps,containerName:"frame step list",tracer:d}})}finally{o.browser.setActiveFrameConfig(a)}let c={...e,...s,startedAt:i,finishedAt:new Date};return en({asyncTasks:n.work.asyncTasks,nestedResults:s.results,result:c,logger:r}),c}import{randomUUID as dl}from"crypto";import lL from"fast-json-patch";import{cloneDeep as cL}from"lodash-es";async function Ay(n){let e=n.failedResults,t=[],{sectionParams:r,fixtures:o,work:i,startingUrl:a,startingContextSnapshot:s,tracer:l}=n,{step:c}=r,{controller:d,logger:p,debugDataStorage:m}=o,u=c?.autohealingConfig,h=u?.restartBehavior??{type:"GO_TO_SECTION_START"},g=u?.attempts??1;for(let f=0;f<g;f++){if(!e.terminalResult?.message)throw new Error("No error message in terminal result");let S=cL(c.steps);await Promise.allSettled(i.asyncTasks??[]);let{results:b}=await Rs(p,m,e.results,{numScreenshots:4}),w=await d.runSectionAutohealing({results:b,errorMessage:e.terminalResult?.message,goal:c.description});S=lL.applyPatch(S,w.patches).newDocument;let v=At.fromSnapshot({snapshot:s,environmentVariables:o.context.getVariablesFromEnvironmentCopy()});await dL({logger:p,controller:d,tracer:l,context:v,restartConfig:h,startingUrl:a});let x=await ur(n.work,()=>n.executeStepList({...n,fixtures:{...n.fixtures,context:v},listParams:{steps:S,containerName:"auto-healed step list",tracer:l}}));if(t.push(x.results),x.status==="SUCCESS")return{successfulHealing:{proposedStep:{...c,steps:S},listResult:x,context:v},healingAttempts:t};e=x}return{healingAttempts:t}}async function dL({logger:n,controller:e,tracer:t,restartConfig:r,context:o,startingUrl:i}){switch(r.type){case"NAVIGATE_URL":{let a={id:dl(),type:"PRESET_ACTION",command:{id:dl(),type:"NAVIGATE",url:r.url}},s=await t.startStep({logger:n,step:a});await e.executePresetCommand(null,s,a.command,o,!1);break}case"GO_TO_SECTION_START":{let a={id:dl(),type:"PRESET_ACTION",command:{id:dl(),type:"NAVIGATE",url:i}},s=await t.startStep({logger:n,step:a});await e.executePresetCommand(null,s,a.command,o,!1);break}}}function Iy(n,e){switch(n||(n="ON_FAILURE"),n){case"ALWAYS":return!0;case"ON_FAILURE":return!0;case"ON_ACTION_FAILURE":return!(!e||e.type==="PRESET_ACTION"&&Nu(e.command.type))}}async function Py(n){let{step:e,tracer:t}=n.sectionParams,{logger:r,controller:o,context:i}=n.fixtures,a=new Date,s=o.browser.url(),l=i.toObjectCopy(),c=await t.startSubSteps(),d=async()=>n.executeStepList({...n,listParams:{steps:e.steps,containerName:"section step list",tracer:c}}),p=e.autohealingConfig?await ur(n.work,d):await d(),m,u;if(p.status==="FAILED"&&e.autohealingConfig&&!n.work.state.autoHealingDisabled&&Iy(e.autohealingConfig.trigger,p.terminalResult)){let g=await t.startSubSteps(),f=await Ay({...n,startingContextSnapshot:l,startingUrl:s,failedResults:p,tracer:g});f.successfulHealing&&(m=f.successfulHealing.proposedStep,p=f.successfulHealing.listResult,n.fixtures.context=f.successfulHealing.context),u=f.healingAttempts}let h={...e,...p,startedAt:a,finishedAt:new Date,proposedStep:m,healingAttempts:u};return en({asyncTasks:n.work.asyncTasks,nestedResults:p.results,result:h,logger:r}),h}async function An(n){let{results:e=[],containerName:t,steps:r,tracer:o}=n.listParams,{logger:i,context:a,controller:s,codeEvalTools:l,billingReporter:c,analytics:d}=n.fixtures,p=o.getParentStepIdChain(),{orgId:m,fromStep:u,toStep:h}=n.inputs,g=n.work,f=[],S="SUCCESS",b,w=0;for(w;w<r.length;w++){let v=r[w],x,C=ln(v);if(v.skipped)continue;if(g.fastForwardingToStep&&u){let re=JSON.stringify(p);if(v.id===u.fromStepId&&re===JSON.stringify(u.parentStepIdChain))g.fastForwardingToStep=!1;else if(!Lg(v,p,u.fromStepId,u.parentStepIdChain))continue}let A=new Date,N=d.child({step_id:v.id});N.track({type:"execution:step_start",step_type:v.type==="RESOLVED_MODULE"?"MODULE":v.type,command_type:"command"in v?v.command.type:void 0}),i.info({step:v},`Executing step ${w+1}/${r.length} in ${t}: ${C}`);let O=await o.startStep({logger:i,step:v}),H=pL(v),F=a.toRedactedDisplayCopy(),L=s.browser.url(),B=s.executeAbortController.signal,P=qi(v.type);g.asyncTasks.push(c.reportCreditsUsed(i,v.type,P,{testId:n.inputs.testMetadata?.id,testName:n.inputs.testMetadata?.name,suiteId:n.inputs.suiteMetadata?.id,suiteName:n.inputs.suiteMetadata?.name}));let K,U;switch(v.type){case"PRESET_ACTION":{K="Preset action",U=await mr(v,async()=>await cl({...n,presetParams:{tracer:O,step:v}}),B),"proposedStep"in U&&U.proposedStep&&(x=U.proposedStep,U.proposedStep=void 0);break}case"AI_ACTION":{K="AI action",U=await mr(v,()=>vy({...n,aiStepParams:{step:v,tracer:O},executeStepList:An}),B);break}case"AI_ACTION_DYNAMIC":{K="AI action",U=await mr(v,()=>xy({...n,aiStepParams:{step:v,tracer:O},executeStepList:An}),B);break}case"RESOLVED_MODULE":{K=`Module (${v.name})`,U=await mr(v,async()=>{let re=await uy({orgId:m,step:v,context:a,logger:i,flagStore:s.flagStore,codeEvalTools:l,signal:B});return Vd({...n,executeStepList:An,moduleParams:{step:v,resolvedInputs:re,tracer:O}})},B);break}case"CONDITIONAL":{K="Conditional step",U=await mr(v,()=>by({...n,conditionalParams:{step:v,tracer:O},executeStepList:An}),B);break}case"IFRAME":{K="Frame step",U=await mr(v,()=>Ry({...n,frameParams:{step:v,tracer:O},executeStepList:An}),B);break}case"SECTION":{K="Section";let re=await mr(v,()=>Py({...n,sectionParams:{step:v,tracer:O},executeStepList:An}),B);"proposedStep"in re&&re.proposedStep&&(x=re.proposedStep,re.proposedStep=void 0),U=re;break}default:return(we=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(v)}U.beforeUrl=U.beforeUrl??L,U.beforeTestContext=F,v.envKey&&a.setVariable(v.envKey,U.data);let Y=s.browser.url();a.setCurrentUrl(Y),U.afterUrl=U.afterUrl??Y,U.afterTestContext=a.toRedactedDisplayCopy(),e.push(U),await uL({startedAt:A,stepTypeName:K,result:U,callbacks:n.callbacks,analytics:N,globalWorkRef:n.work,tracer:O});let Z;if(U.status==="FAILED"&&!g.state.failureRecoveryDisabled&&u?.fromStepId===void 0&&h?.toStepId===void 0){let re=await Cy({...n,executeStepList:An,failureRecoveryParams:{failedStep:H,nextSteps:r.slice(w+1),results:e,tracer:O}});re&&re.status==="SUCCESS"&&(Z=re.proposedSteps,e.push(...re.results))}if(Z?f.push(...Z):x?f.push(x):f.push(v),g.fastForwardingToStep&&u&&u.fromStepId===v.id&&JSON.stringify(p)===JSON.stringify(u.parentStepIdChain)&&(g.fastForwardingToStep=!1),U.status!=="SUCCESS"&&!Z||s.closed){S=U.status,b=U;break}else if(h&&v.id===h.toStepId&&JSON.stringify(p)===JSON.stringify(h.parentStepIdChain)){s.setClosed();break}}return{status:S,results:e,terminalResult:b,proposedSteps:f}}async function uL({startedAt:n,stepTypeName:e,result:t,analytics:r,tracer:o}){let i=e.toLowerCase(),a=e.charAt(0).toUpperCase()+e.slice(1),s=new Date,l="";switch(t.status){case"SUCCESS":l=t.message??`${a} executed successfully.`,r.track({type:"execution:step_success",step_type:t.type,command_type:"command"in t?t.command.type:void 0,duration_ms:s.getTime()-n.getTime()});break;case"FAILED":l=t.message??`${a} failed.`,r.track({type:"execution:step_fail",step_type:t.type,command_type:"command"in t?t.command.type:void 0,duration_ms:s.getTime()-n.getTime(),fail_reason:t.message??`${a} failed.`});break;case"CANCELLED":l=t.message??`${a} cancelled.`,r.track({type:"execution:step_cancel",step_type:t.type,command_type:"command"in t?t.command.type:void 0,duration_ms:s.getTime()-n.getTime()});break;default:throw new Error(`Unexpected ${i} status: ${t.status}`)}await o.finish({step:t,message:l,output:ts.parse(t)})}import{randomUUID as Ly}from"crypto";async function Oy({browser:n,signal:e}){let t=new Date;try{return await n.navigate({url:n.baseUrl,initialNavigation:!0}),{status:"PASSED",results:[]}}catch(r){let o={id:Ly(),type:"PRESET_ACTION",status:e.aborted||r.name==="AbortError"?"CANCELLED":"FAILED",failureReason:"UserInfrastructureError",message:r.message,startedAt:t,finishedAt:new Date,results:[],command:{id:Ly(),type:"NAVIGATE",url:n.baseUrl}};return{status:e.aborted||r.name==="AbortError"?"CANCELLED":"FAILED",results:[],failedStepResult:o}}}var pl=async n=>{let{orgId:e,runId:t,runAttemptId:r,testMetadata:o,steps:i,beforeSteps:a,afterSteps:s}=n.inputs;n.fixtures.logger=n.fixtures.logger.child({orgId:e,runId:t,runAttemptId:r,testId:o?.id}),n.fixtures.analytics=n.fixtures.analytics.child({run_id:t,test_id:o?.id,test_name:o?.name});let{logger:l,controller:c}=n.fixtures,{onTestComplete:d,onTestSuccess:p}=n.callbacks.test,m=iy(l);if(n.options.reinitializeBrowser){let h=await Oy({browser:c.browser,signal:c.executeAbortController.signal});if(h.status!=="PASSED")return await d?.(),clearInterval(m?.interval),h}let u;try{return l.info({platform:m?.platform,cpuMetadata:m?.cpuMetadata},`Starting run for Momentic test '${o?.name??"Unnamed test"}'`),u=await mL(n),u}finally{if(l.info({status:u?.status},"Momentic test final result"),clearInterval(m?.interval),await d?.(),u?.status==="PASSED")try{await p?.({steps:i,beforeSteps:a,afterSteps:s})}catch(h){l.warn({err:h},"Error running test success handler, continuing...")}}},mL=async n=>{let{tracer:e}=n.testParams,{runId:t,runAttemptId:r,testMetadata:o,fromStep:i,toStep:a,steps:s,beforeSteps:l,afterSteps:c,orgId:d}=n.inputs,{logger:p,controller:m,context:u,storage:h}=n.fixtures,{collectDebugData:g,disableHealing:f}=n.options;u.setCurrentUrl(m.browser.url());let S="test",b=s,w=[],v=f||i!==void 0||a!==void 0||void 0,x={results:w,state:{failureRecoveryDisabled:v,autoHealingDisabled:v},asyncTasks:[]},C=!1;i?.fromStepId&&i.fromStepId===a?.toStepId?(S="filtered step",x.fastForwardingToStep=!0):i?.fromStepId?(S="partial steps list from step",x.fastForwardingToStep=!0):a?S="partial steps list until step":(S="entire test",C=!0);let A;if(C&&l&&l.length>0){let{status:P,results:K}=await ky(l,"beforeSteps",n);if(P!=="PASSED")return g&&My({tracer:e,debugDataStorage:n.fixtures.debugDataStorage,work:x,controller:m,storage:h,context:u,runId:t,runAttemptId:r,logger:p,status:P}),x.asyncTasks.push(Promise.resolve(n.callbacks.test.onSaveFinalRunResults?.({beforeResults:K,results:[]}))),{status:P,beforeResults:K,results:[]}}p.debug({stepsToExecute:b,fromStep:i,toStep:a},`Starting step execution for ${S}`);let N=await e.startStepList(),{status:O,terminalResult:H,proposedSteps:F}=await An({...n,work:x,listParams:{steps:b,containerName:S,results:w,tracer:N}}),L;if(C&&c&&c.length>0){p.debug("Starting step execution for after step list");try{let{results:P}=await ky(c,"afterSteps",n);L=P}catch(P){p.error({err:P},"Failed to execute after steps list, continuing...")}}if(g&&My({tracer:e,debugDataStorage:n.fixtures.debugDataStorage,work:x,controller:m,storage:h,context:u,runId:t,runAttemptId:r,logger:p,status:O}),await Promise.allSettled(x.asyncTasks),x.asyncTasks.push(Promise.resolve(n.callbacks.test.onSaveFinalRunResults?.({results:w,beforeResults:A,afterResults:L}))),O==="FAILED")return{status:"FAILED",results:w,beforeResults:A,afterResults:L,failedStepResult:H};if(O==="CANCELLED")return{status:"CANCELLED",results:w,beforeResults:A,afterResults:L};let B;if(F&&x.state.healingDetails&&o){let P=hy(3);await n.callbacks.test.onProposedTestSteps?.({name:P,testId:o.id,orgId:n.inputs.orgId,runId:n.inputs.runId,steps:F,details:x.state.healingDetails,purpose:"AUTO_HEALING"}),B={orgId:n.inputs.orgId,name:P}}return{proposedTest:B,status:"PASSED",results:w,beforeResults:A,afterResults:L}};async function ky(n,e,t){let r=t.fixtures.logger,o=await t.testParams.tracer.startStepList();r.debug({stepsToExecute:n},`Starting step execution for ${e}`);let i={results:[],asyncTasks:[],state:{autoHealingDisabled:!0,failureRecoveryDisabled:!0}},a={...t.callbacks,test:{...t.callbacks.test,onSaveFinalRunResults:void 0,onUpdateRun:void 0,onTestComplete:void 0,onTestSuccess:void 0,onProposedTestSteps:void 0}},{status:s,results:l}=await An({...t,work:i,callbacks:a,listParams:{steps:n,containerName:e,tracer:o}});await Promise.allSettled(i.asyncTasks);let c;return s==="SUCCESS"?c="PASSED":s==="CANCELLED"?c="CANCELLED":c="FAILED",{status:c,results:l}}function My({tracer:n,debugDataStorage:e,work:t,controller:r,storage:o,logger:i,context:a,runId:s,runAttemptId:l,status:c}){let d=r.browser.retrieveAndClearDebugData(),p=Ug(d.logsPerPage),m=Gc(d.harPages||{},d.harEntries||{});n.attachConsoleLogs({logger:i,logs:p}),n.attachNetworkLogs({logger:i,logs:m}),t.asyncTasks.push((async()=>{try{let u=await r.browser.screenshot({}),h=await gy({codePath:"test-complete-final",storage:o,screenshotBuff:u,logger:i}),g=await D(r.browser.html(),{milliseconds:2e3});a.setVariable(yy,h),c!=="PASSED"&&c!=="SUCCESS"&&(i.debug({finalPageHtml:g},"Final page state HTML"),i.debug({finalScreenshotUrl:h},"Uploaded final screenshot URL"))}catch{}})(),l?e.storeConsoleLogsForRunAttempt(i,s,l,p):Promise.resolve(null),l?e.storeNetworkLogsForRunAttempt(i,s,l,m):Promise.resolve(null))}async function ul({settings:n,customHeaders:e,envVariables:t,envName:r,baseUrl:o,logger:i,localTools:a,orgId:s,flagStore:l}){let c=ss.parse(n);e&&(c.extraHeaders={...c.extraHeaders,...e});let d=new At({baseUrl:o,envName:r,variablesFromEnvironment:t,currentUrl:o});await ii({obj:c,context:d,bannedKeys:[],allowList:_m,localTools:a,logger:i,orgId:s,flagStore:l});try{return ss.parse(c)}catch(p){throw new R("UserConfigurationError",`The templated browser settings configured by the user are invalid: ${p.message}`)}}import{cloneDeep as xk}from"lodash-es";var Yd={vimiumJs:'var K=Object.defineProperty;var P=Object.getOwnPropertySymbols;var z=Object.prototype.hasOwnProperty,B=Object.prototype.propertyIsEnumerable;var F=(t,e,n)=>e in t?K(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n,D=(t,e)=>{for(var n in e||(e={}))z.call(e,n)&&F(t,n,e[n]);if(P)for(var n of P(e))B.call(e,n)&&F(t,n,e[n]);return t};var g=(t,e,n)=>(F(t,typeof e!="symbol"?e+"":e,n),n);var _=(t,e,n)=>new Promise((o,r)=>{var i=s=>{try{d(n.next(s))}catch(l){r(l)}},a=s=>{try{d(n.throw(s))}catch(l){r(l)}},d=s=>s.done?o(s.value):Promise.resolve(s.value).then(i,a);d((n=n.apply(t,e)).next())});var E=t=>function(e){return e&&e.isTrusted?t.apply(this,arguments):!0};globalThis.forTrusted==null&&(globalThis.forTrusted=E);var k={create(t,e,n,o){return{bottom:o,top:e,left:t,right:n,width:n-t,height:o-e}},copy(t){return{bottom:t.bottom,top:t.top,left:t.left,right:t.right,width:t.width,height:t.height}},translate(t,e,n){return e==null&&(e=0),n==null&&(n=0),{bottom:t.bottom+n,top:t.top+n,left:t.left+e,right:t.right+e,width:t.width,height:t.height}},subtract(t,e){return e=this.create(Math.max(t.left,e.left),Math.max(t.top,e.top),Math.min(t.right,e.right),Math.min(t.bottom,e.bottom)),e.width<0||e.height<0?[k.copy(t)]:[this.create(t.left,t.top,e.left,e.top),this.create(e.left,t.top,e.right,e.top),this.create(e.right,t.top,t.right,e.top),this.create(t.left,e.top,e.left,e.bottom),this.create(e.right,e.top,t.right,e.bottom),this.create(t.left,e.bottom,e.left,t.bottom),this.create(e.left,e.bottom,e.right,t.bottom),this.create(e.right,e.bottom,t.right,t.bottom)].filter(o=>o.height>0&&o.width>0)},intersects(t,e){return t.right>e.left&&t.left<e.right&&t.bottom>e.top&&t.top<e.bottom},intersectsStrict(t,e){return t.right>=e.left&&t.left<=e.right&&t.bottom>=e.top&&t.top<=e.bottom},equals(t,e){for(let n of["top","bottom","left","right","width","height"])if(t[n]!==e[n])return!1;return!0},intersect(t,e){return this.create(Math.max(t.left,e.left),Math.max(t.top,e.top),Math.min(t.right,e.right),Math.min(t.bottom,e.bottom))}};var N={_browserInfoLoaded:!0,_firefoxVersion:null,_isFirefox:!1,isFirefox(){if(!this._browserInfoLoaded)throw Error("browserInfo has not yet loaded.");return this._isFirefox},firefoxVersion(){if(!this._browserInfoLoaded)throw Error("browserInfo has not yet loaded.");return this._firefoxVersion},isString(t){return typeof t=="string"||t instanceof String}};var f={isReady(){return document.readyState!=="loading"},documentReady:function(){let t=document.readyState!=="loading",e=[];if(!t){let n;globalThis.addEventListener("DOMContentLoaded",n=E(function(){globalThis.removeEventListener("DOMContentLoaded",n,!0),t=!0;for(let o of e)o();e=null}),!0)}return function(n){if(t)return n();e.push(n)}}(),documentComplete:function(){let t=document.readyState==="complete",e=[];if(!t){let n;globalThis.addEventListener("load",n=E(function(o){if(o.target===document){globalThis.removeEventListener("load",n,!0),t=!0;for(let r of e)r();e=null}}),!0)}return function(n){t?n():e.push(n)}}(),createElement(t){let e=document.createElement(t);return e instanceof HTMLElement?(this.createElement=n=>document.createElement(n),e):(this.createElement=n=>document.createElementNS("http://www.w3.org/1999/xhtml",n),this.createElement(t))},addElementsToPage(t,e){let n=this.createElement("div");e.id!=null&&(n.id=e.id),e.className!=null&&(n.className=e.className);for(let o of t)n.appendChild(o);return document.body.appendChild(n),n},removeElement(t){return t.parentNode.removeChild(t)},isTopFrame(){return globalThis.top===globalThis.self},makeXPath(t){let e=[];for(let n of t)e.push(".//"+n,".//xhtml:"+n);return e.join(" | ")},evaluateXPath(t,e){let n=document.webkitIsFullScreen?document.webkitFullscreenElement:document.documentElement,o=function(r){return r==="xhtml"?"http://www.w3.org/1999/xhtml":null};return document.evaluate(t,n,o,e,null)},getVisibleClientRect(t,e){let n;e==null&&(e=!1);let o=(()=>{let i=[];for(n of t.getClientRects())i.push(k.copy(n));return i})(),r=function(){let i=window.getComputedStyle(t,null),a=i.getPropertyValue("display").indexOf("inline")===0&&i.getPropertyValue("font-size")==="0px";return r=()=>a,a};for(n of o){let i;if((n.width===0||n.height===0)&&e)for(let a of Array.from(t.children)){i=window.getComputedStyle(a,null);let d=i.getPropertyValue("position");if(i.getPropertyValue("float")==="none"&&!["absolute","fixed"].includes(d)&&!(n.height===0&&r()&&i.getPropertyValue("display").indexOf("inline")===0))continue;let s=this.getVisibleClientRect(a,!0);if(!(s===null||s.width<3||s.height<3))return s}else{if(n=this.cropRectToVisible(n),n===null||n.width<3||n.height<3||(i=window.getComputedStyle(t,null),i.getPropertyValue("visibility")!=="visible"))continue;return n}}return null},cropRectToVisible(t){let e=k.create(Math.max(t.left,0),Math.max(t.top,0),t.right,t.bottom);return e.top>=window.innerHeight-4||e.left>=window.innerWidth-4?null:e},getClientRectsForAreas(t,e){let n=[];for(let o of e){let r,i,a,d,s=o.coords.split(",").map(p=>parseInt(p,10)),l=o.shape.toLowerCase();if(["rect","rectangle"].includes(l))s.length==4&&([r,a,i,d]=s);else if(["circle","circ"].includes(l)){if(s.length==3){let[p,w,v]=s,u=v/Math.sqrt(2);r=p-u,i=p+u,a=w-u,d=w+u}}else l==="default"?s.length==2&&([r,a,i,d]=[0,0,t.width,t.height]):s.length>=4&&([r,a,i,d]=s);let c=k.translate(k.create(r,a,i,d),t.left,t.top);c=this.cropRectToVisible(c),c&&!isNaN(c.top)&&!isNaN(c.left)&&!isNaN(c.width)&&!isNaN(c.height)&&n.push({element:o,rect:c})}return n},isSelectable(t){if(!(t instanceof Element))return!1;let e=["button","checkbox","color","file","hidden","image","radio","reset","submit"];return t.nodeName.toLowerCase()==="input"&&e.indexOf(t.type)===-1||t.nodeName.toLowerCase()==="textarea"||t.isContentEditable},isEditable(t){return this.isSelectable(t)||(t.nodeName!=null?t.nodeName.toLowerCase():void 0)==="select"},isEmbed(t){let e=t.nodeName!=null?t.nodeName.toLowerCase():null;return["embed","object"].includes(e)},isFocusable(t){return t&&(this.isEditable(t)||this.isEmbed(t))},isDOMDescendant(t,e){let n=e;for(;n!==null;){if(n===t)return!0;n=n.parentNode}return!1},isSelected(t){let e=document.getSelection();if(t.isContentEditable){let n=e.anchorNode;return n&&this.isDOMDescendant(t,n)}else if(f.getSelectionType(e)==="Range"&&e.isCollapsed){let n=e.anchorNode.childNodes[e.anchorOffset];return t===n}else return!1},simulateSelect(t){if(t===document.activeElement&&f.isEditable(document.activeElement))return handlerStack.bubbleEvent("click",{target:t});if(t.focus(),t.tagName.toLowerCase()!=="textarea"||t.value.indexOf(`\n`)<0)try{if(t.selectionStart===0&&t.selectionEnd===0)return t.setSelectionRange(t.value.length,t.value.length)}catch(e){}},simulateClick(t,e){e==null&&(e={});let n=["mouseover","mousedown","mouseup","click"],o=[];for(let r of n){let i=this.simulateMouseEvent(r,t,e);o.push(i)}return o},simulateMouseEvent(t,e,n){if(n==null&&(n={}),t==="mouseout"){if(e==null&&(e=this.lastHoveredElement),this.lastHoveredElement=void 0,e==null)return}else t==="mouseover"&&(this.simulateMouseEvent("mouseout",void 0,n),this.lastHoveredElement=e);let o=new MouseEvent(t,{bubbles:!0,cancelable:!0,composed:!0,view:window,detail:1,ctrlKey:n.ctrlKey,altKey:n.altKey,shiftKey:n.shiftKey,metaKey:n.metaKey});return e.dispatchEvent(o)},simulateClickDefaultAction(t,e){let n;if(e==null&&(e={}),(t.tagName!=null?t.tagName.toLowerCase():void 0)!=="a"||!t.href)return;let{ctrlKey:o,shiftKey:r,metaKey:i,altKey:a}=e;KeyboardUtils.platform==="Mac"?n=i===!0&&o===!1:n=i===!1&&o===!0,n?chrome.runtime.sendMessage({handler:"openUrlInNewTab",url:t.href,active:r===!0}):r===!0&&i===!1&&o===!1&&a===!1?chrome.runtime.sendMessage({handler:"openUrlInNewWindow",url:t.href}):t.target==="_blank"&&chrome.runtime.sendMessage({handler:"openUrlInNewTab",url:t.href,active:!0})},simulateHover(t,e){return e==null&&(e={}),this.simulateMouseEvent("mouseover",t,e)},simulateUnhover(t,e){return e==null&&(e={}),this.simulateMouseEvent("mouseout",t,e)},addFlashRect(t){let e=this.createElement("div");return e.classList.add("vimiumReset"),e.classList.add("vimiumFlash"),e.style.left=t.left+"px",e.style.top=t.top+"px",e.style.width=t.width+"px",e.style.height=t.height+"px",document.documentElement.appendChild(e),e},getViewportTopLeft(){let t=document.documentElement,e=getComputedStyle(t),n=t.getBoundingClientRect();if(e.position==="static"&&!/content|paint|strict/.test(e.contain||"")){let o=parseInt(e.marginTop),r=parseInt(e.marginLeft);return{top:-n.top+o,left:-n.left+r}}else{let o,r;return N.isFirefox()?(r=parseInt(e.borderTopWidth),o=parseInt(e.borderLeftWidth)):{clientTop:r,clientLeft:o}=t,{top:-n.top-r,left:-n.left-o}}},suppressPropagation(t){t.stopImmediatePropagation()},suppressEvent(t){t.preventDefault(),this.suppressPropagation(t)},consumeKeyup:function(){let t=null;return function(e,n=null,o){if(!e.repeat){t!=null&&handlerStack.remove(t);let{code:r}=e;t=handlerStack.push({_name:"dom_utils/consumeKeyup",keyup(i){return i.code!==r||(this.remove(),o?f.suppressPropagation(i):f.suppressEvent(i)),handlerStack.continueBubbling},blur(i){return i.target===window&&this.remove(),handlerStack.continueBubbling}})}return typeof n=="function"&&n(),o?(f.suppressPropagation(e),handlerStack.suppressPropagation):(f.suppressEvent(e),handlerStack.suppressEvent)}}(),getSelectionType(t){return t==null&&(t=document.getSelection()),t.type?t.type:t.rangeCount===0?"None":t.isCollapsed?"Caret":"Range"},getElementWithFocus(t,e){let n,o=n=t.getRangeAt(0);f.getSelectionType(t)==="Range"&&(o=n.cloneRange(),o.collapse(e)),n=o.startContainer,n.nodeType===1&&(n=n.childNodes[o.startOffset]);let r=n;for(;r&&r.nodeType!==1;)r=r.previousSibling;return n=r||(n!=null?n.parentNode:void 0),n},getSelectionFocusElement(){let t=window.getSelection(),e=t.focusNode;return e==null?null:(e===t.anchorNode&&t.focusOffset===t.anchorOffset&&(e=e.childNodes[t.focusOffset]||e),e.nodeType!==Node.ELEMENT_NODE?e.parentElement:e)},getContainingElement(t){return(typeof t.getDestinationInsertionPoints=="function"?t.getDestinationInsertionPoints()[0]:void 0)||t.parentElement},windowIsTooSmall(){return window.innerWidth<3||window.innerHeight<3},injectUserCss(){let t=document.createElement("style");t.type="text/css",t.textContent=Settings.get("userDefinedLinkHintCss"),document.head.appendChild(t)}};var O={MAX_CONTENT_LENGTH:1e3,MAX_ATTRIBUTE_LENGTH:500,MAX_NUM_DATA_ATTRIBUTES:10,commonAttributes:["id","className","title","aria-label","aria-labelledby"],attributeNamesMapping:new Map([["a",["href","title","rel","target"]],["label",["for"]],["input",["type","name","placeholder","checked","maximumLength"]],["textarea",["placeholder","maximumLength"]],["button",["type"]],["select",["name","multiple"]],["div",["role"]],["iframe",["src"]],["img",["src","alt"]]]),describe(t){var r,i;let e={};this.addAttributes(t,this.commonAttributes,e);let n=((i=(r=t.tagName).toLowerCase)==null?void 0:i.call(r))||"";this.attributeNamesMapping.has(n)&&this.addAttributes(t,this.attributeNamesMapping.get(n),e),this.addDataAttrs(t,e);let o=this.getContent(t);return this.additionalHandling(t,D({tag:n,attributes:e},o&&{content:o}))},getContent(t){var n,o;let e=((o=(n=t.tagName).toLowerCase)==null?void 0:o.call(n))||"";return["input","textarea"].includes(e)?t.value:["div","iframe","img","body"].includes(e)?null:(["a","button","select","label"].includes(e),t.innerText)},additionalHandling(t,e){var o,r;if((((r=(o=t.tagName).toLowerCase)==null?void 0:r.call(o))||"")=="label"&&t.hasAttribute("for")){let i=t.getAttribute("for"),a=document.getElementById(i);a&&(e.target=this.describe(a))}return e},addAttributes(t,e,n){n||(n={});for(let o of e)t.hasAttribute(o)&&(n[o]=t.getAttribute(o).substring(0,this.MAX_ATTRIBUTE_LENGTH));return n},addDataAttrs(t,e){let n=0;for(let o in t.dataset)if(e[`data-${o}`]=t.dataset[o].substring(0,this.MAX_ATTRIBUTE_LENGTH),n++,n>this.MAX_NUM_DATA_ATTRIBUTES)return e;return e}};var x=null,C=()=>G()||document.scrollingElement||document.body,W=function(t){return t?t<0?-1:1:0},U={x:{axisName:"scrollLeft",max:"scrollWidth",viewSize:"clientWidth"},y:{axisName:"scrollTop",max:"scrollHeight",viewSize:"clientHeight"}},X=function(t,e,n){if(N.isString(n)){let o=n;return o==="viewSize"&&t===C()?e==="x"?window.innerWidth:window.innerHeight:t[U[e][o]]}else return n},V=function(t,e,n){let o=U[e].axisName,r=t[o];if(t.scrollBy){let i={behavior:"instant"};i[e==="x"?"left":"top"]=n,t.scrollBy(i)}else t[o]+=n;return t[o]!==r},q=function(t,e){let n=window.getComputedStyle(t);return!(n.getPropertyValue(`overflow-${e}`)==="hidden"||["hidden","collapse"].includes(n.getPropertyValue("visibility"))||n.getPropertyValue("display")==="none")},T=function(t,e,n,o){let r=o*X(t,e,n)||-1;return r=W(r),V(t,e,r)&&V(t,e,-r)},$=function(t,e,n,o){return e==null&&(e="y"),n==null&&(n=1),o==null&&(o=1),T(t,e,n,o)&&q(t,e)},j=function(t=null){let e;if(!t){let n=C();if(T(n,"y",1,1)||T(n,"y",-1,1))return n;t=document.body||C()}if(T(t,"y",1,1)||T(t,"y",-1,1))return t;{let n=Array.from(t.children).map(o=>({element:o,rect:f.getVisibleClientRect(o)})).filter(o=>o.rect);n.map(o=>o.area=o.rect.width*o.rect.height);for(e of n.sort((o,r)=>r.area-o.area)){let o=j(e.element);if(o)return o}return null}},L={init(){x=null},isScrollableElement(t){return x||(x=C()&&j()||C()),t!==x&&$(t)}},G=function(){let t=J[window.location.host];if(t)return document.querySelector(t)},J={"twitter.com":"div.permalink-container div.permalink[role=main]","reddit.com":"#overlayScrollContainer","new.reddit.com":"#overlayScrollContainer","www.reddit.com":"#overlayScrollContainer","web.telegram.org":".MessageList"};window.Scroller=L;var A=function(){let t=null;return f.documentReady(()=>t=document.hasFocus()),globalThis.addEventListener("focus",E(function(e){return e.target===window&&(t=!0),!0}),!0),globalThis.addEventListener("blur",E(function(e){return e.target===window&&(t=!1),!0}),!0),()=>t}();Object.assign(globalThis,{windowIsFocused:A});var R=class{constructor(e){g(this,"element");g(this,"image");g(this,"rect");g(this,"linkText");g(this,"showLinkText");g(this,"reason");g(this,"secondClassCitizen");g(this,"possibleFalsePositive");Object.seal(this),e&&Object.assign(this,e)}},M={getLocalHintsForElement(t){var p,w,v;let e=((w=(p=t.tagName).toLowerCase)==null?void 0:w.call(p))||"",n=!1,o=!1,r=!1,i=[],a=[],d=null;if(e==="img"){let u=t.getAttribute("usemap");if(u){let h=t.getClientRects();u=u.replace(/^#/,"").replace(\'"\',\'\\\\"\');let m=document.querySelector(`map[name="${u}"]`);if(m&&h.length>0){n=!0;let y=m.getElementsByTagName("area"),S=f.getClientRectsForAreas(h[0],y);S=S.map(I=>Object.assign(I,{image:t})),a.push(...S)}}}let s=t.getAttribute("aria-disabled");if(s&&["","true"].includes(s.toLowerCase()))return[];if(this.checkForAngularJs||(this.checkForAngularJs=function(){if(document.getElementsByClassName("ng-scope").length===0)return()=>!1;{let h=[];for(let m of["","data-","x-"])for(let y of["-",":","_"])h.push(`${m}ng${y}click`);return function(m){for(let y of h)if(m.hasAttribute(y))return!0;return!1}}}()),n||(n=this.checkForAngularJs(t)),t.hasAttribute("onclick"))n=!0;else{let u=t.getAttribute("role"),h=["button","tab","link","checkbox","menuitem","menuitemcheckbox","menuitemradio","radio"];if(u!=null&&h.includes(u.toLowerCase()))n=!0;else{let m=t.getAttribute("contentEditable");m!=null&&["","contenteditable","true","plaintext-only"].includes(m.toLowerCase())&&(n=!0)}}if(!n&&t.hasAttribute("jsaction")){let u=t.getAttribute("jsaction").split(";");for(let h of u){let m=h.trim().split(":");if(m.length>=1&&m.length<=2){let[y,S,I]=m.length===1?["click",...m[0].trim().split("."),"_"]:[m[0],...m[1].trim().split("."),"_"];n||(n=y==="click"&&S!=="none"&&I!=="_")}}}switch(e){case"a":n=!0;break;case"textarea":n||(n=!t.disabled&&!t.readOnly);break;case"input":n||(n=!(((v=t.getAttribute("type"))==null?void 0:v.toLowerCase())=="hidden"||t.disabled||t.readOnly&&f.isSelectable(t)));break;case"button":case"select":n||(n=!t.disabled);break;case"object":case"embed":n=!0;break;case"label":n||(n=t.control!=null&&!t.control.disabled&&this.getLocalHintsForElement(t.control).length===0);break;case"body":n||(n=t===document.body&&!A()&&window.innerWidth>3&&window.innerHeight>3&&(document.body!=null?document.body.tagName.toLowerCase():void 0)!=="frameset"?d="Frame.":void 0),n||(n=t===document.body&&A()&&L.isScrollableElement(t)?d="Scroll.":void 0);break;case"img":n||(n=["zoom-in","zoom-out"].includes(t.style.cursor));break;case"div":case"ol":case"ul":n||(n=t.clientHeight<t.scrollHeight&&L.isScrollableElement(t)?d="Scroll.":void 0);break;case"details":n=!0,d="Open.";break}let l=t.getAttribute("class");!n&&(l!=null&&l.toLowerCase().includes("button"))&&(n=!0,r=!0);let c=t.getAttribute("tabindex"),b=c?parseInt(c):-1;if(!n&&!(b<0)&&!isNaN(b)&&(n=!0,o=!0),n)if(a.length>0){let u=a.map(h=>new R({element:h.element,image:t,rect:h.rect,secondClassCitizen:o,possibleFalsePositive:r,reason:d}));i.push(...u)}else{let u=f.getVisibleClientRect(t,!0);if(u!==null){let h=new R({element:t,rect:u,secondClassCitizen:o,possibleFalsePositive:r,reason:d});i.push(h)}}return i},getElementFromPoint(t,e,n,o){n==null&&(n=document),o==null&&(o=[]);let r=n.elementsFromPoint?n.elementsFromPoint(t,e)[0]:n.elementFromPoint(t,e);return o.includes(r)?r:(o.push(r),r&&r.shadowRoot?M.getElementFromPoint(t,e,r.shadowRoot,o):r)},getLocalHints(t){if(!document.body)return[];let e=(s,l)=>{l==null&&(l=[]);for(let c of Array.from(s.querySelectorAll("*")))l.push(c),c.shadowRoot&&e(c.shadowRoot,l);return l},n=e(document.body),o=[];for(let s of Array.from(n))if(!t||s.href){let l=this.getLocalHintsForElement(s);o.push(...l)}o=o.reverse();let r=[1,2,3];o=o.filter((s,l)=>{if(!s.possibleFalsePositive)return!0;let b=Math.max(0,l-6);for(;b<l;){let p=o[b].element;for(let w of r)if(p=p==null?void 0:p.parentElement,p===s.element)return!1;b+=1}return!0});let i=o.filter(s=>{if(s.secondClassCitizen)return!1;let l=s.rect,c=M.getElementFromPoint(l.left+l.width*.5,l.top+l.height*.5);if(c&&(s.element.contains(c)||c.contains(s.element))||s.element.localName=="area"&&c==s.image)return!0;let p=[l.top+.1,l.bottom-.1],w=[l.left+.1,l.right-.1];for(let v of p)for(let u of w){let h=M.getElementFromPoint(u,v);if(h&&(s.element.contains(h)||h.contains(s.element)))return!0}});i.reverse();let{top:a,left:d}=f.getViewportTopLeft();for(let s of i)s.rect.top+=a,s.rect.left+=d;return i}};var H=class{constructor(){this.hints=null;this.hintMarkers=null;this.markersDiv=null;this.enrichedMarkers=null}reset(){this.removeMarkers(),this.hints=null,this.hintMarkers=null,this.markersDiv=null}capture(){return _(this,null,function*(){this.reset(),this.createMarkers(),this.displayMarkers()})}createMarkers(){this.hints=M.getLocalHints(),this.hintMarkers=new Map,this.hints.forEach((e,n)=>{var i,a;let o=f.createElement("div"),r=(a=(i=e.element.attributes["data-momentic-id"])==null?void 0:i.value)!=null?a:void 0;if(!r){console.warn(`[MOMENTIC] No data-momentic-id found for interactive element ${e.element.outerHTML}`);return}o.style.left=e.rect.left+"px",o.style.top=e.rect.top+"px",o.style.zIndex=214e7+n,o.className="vimiumReset internalVimiumHintMarker vimiumHintMarker",Z(o,r),this.hintMarkers.set(r,{hint:e,marker:o})})}enrichMarkers(){if(this.hintMarkers){this.enrichedMarkers=[];for(let[e,n]of this.hintMarkers)this.enrichedMarkers.push(Object.assign(O.describe(n.hint.element),{hintString:e}))}}displayMarkers(){this.hintMarkers&&(this.markersDiv||(this.markersDiv=f.addElementsToPage(Array.from(this.hintMarkers.values()).map(e=>e.marker),{id:"vimiumHintMarkerContainer",className:"vimiumReset"})))}removeMarkers(){this.markersDiv&&(f.removeElement(this.markersDiv),this.markersDiv=null)}toggleMarkers(){this.markersDiv?this.removeMarkers():this.displayMarkers()}},Z=(t,e)=>{for(let n of e){let o=document.createElement("span");o.className="vimiumReset",o.textContent=n,t.appendChild(o)}};window.HintManager=H;\n',vimiumCss:'.vimiumReset,a.vimiumReset,a:hover.vimiumReset,a:link.vimiumReset,a:visited.vimiumReset,div.vimiumReset,span.vimiumReset,table.vimiumReset,td.vimiumReset,tr.vimiumReset{background:none;border:none;bottom:auto;box-shadow:none;color:#000;cursor:auto;display:inline;float:none;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:inherit;font-style:normal;font-variant:normal;font-weight:400;height:auto;left:auto;letter-spacing:0;line-height:100%;margin:0;max-height:none;max-width:none;min-height:0;min-width:0;opacity:1;padding:0;position:static;right:auto;text-align:left;text-decoration:none;text-indent:0;text-shadow:none;text-transform:none;top:auto;vertical-align:baseline;white-space:normal;width:auto;z-index:2140000000}tbody.vimiumReset,thead.vimiumReset{display:table-header-group}tbody.vimiumReset{display:table-row-group}div.internalVimiumHintMarker{background:linear-gradient(180deg,#fff785 0,#ffc542);border:1px solid #c38a22;border-radius:3px;box-shadow:0 3px 7px 0 rgba(0,0,0,.3);display:block;font-size:11px;left:-1px;overflow:hidden;padding:1px 3px 0;position:absolute;top:-1px;white-space:nowrap}div.internalVimiumHintMarker span{color:#302505;font-family:Helvetica,Arial,sans-serif;font-size:11px;font-weight:700;text-shadow:0 1px 0 hsla(0,0%,100%,.6)}div.internalVimiumHintMarker>.matchingCharacter{color:#d4ac3a}div>.vimiumActiveHintMarker span{color:#a07555!important}div.internalVimiumInputHint{background-color:rgba(255,247,133,.3);border:1px solid #c38a22;display:block;pointer-events:none;position:absolute}div.internalVimiumSelectedInputHint{background-color:hsla(0,100%,70%,.3);border:1px solid #933!important}div.internalVimiumSelectedInputHint span{color:#fff!important}div.vimiumHighlightedFrame{border:5px solid #ff0;box-sizing:border-box;margin:0;pointer-events:none}div.vimiumHighlightedFrame,iframe.vimiumHelpDialogFrame{height:100%;left:0;padding:0;position:fixed;top:0;width:100%}iframe.vimiumHelpDialogFrame{background-color:hsla(0,0%,4%,.6);border:none;display:block;z-index:2139999997}div#vimiumHelpDialogContainer{background-color:#fff;border:2px solid #b3b3b3;border-radius:6px;margin:50px auto;max-height:calc(100% - 100px);max-width:calc(100% - 100px);opacity:1;overflow-x:auto;overflow-y:auto;width:840px}div#vimiumHelpDialog{min-width:600px;padding:8px 12px}span#vimiumTitle,span#vimiumTitle *,span#vimiumTitle span{font-size:20px}#vimiumTitle{display:block;line-height:130%;white-space:nowrap}td.vimiumHelpDialogTopButtons{text-align:right;width:100%}#helpDialogOptionsPage,#helpDialogWikiPage{font-size:14px;padding-left:5px;padding-right:5px}div.vimiumColumn{float:left;font-size:11px;line-height:130%;width:50%}div.vimiumColumn tr{display:table-row}div.vimiumColumn td{display:table-cell;font-size:11px;line-height:130%}div.vimiumColumn table,div.vimiumColumn td,div.vimiumColumn tr{margin:0;padding:0}div.vimiumColumn table{table-layout:auto;width:100%}div.vimiumColumn td{padding:1px;vertical-align:top}div#vimiumHelpDialog div.vimiumColumn tr>td:first-of-type{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:14px;text-align:right;white-space:nowrap}span.vimiumHelpDialogKey{background-color:#f3f3f3;border:1px solid;border-color:#ccc #ccc #bbb;border-radius:3px;box-shadow:inset 0 -1px 0 #bbb;color:#212121;font-family:monospace;font-size:11px;margin-left:2px;padding:1px 4px}div#vimiumHelpDialog div.vimiumColumn tr>td:nth-of-type(3){width:100%}div#vimiumHelpDialog div.vimiumDivider{background-color:#9a9a9a;display:block;height:1px;margin:10px auto;width:100%}div#vimiumHelpDialog td.vimiumHelpSectionTitle{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:16px;font-weight:700;padding-top:3px}div#vimiumHelpDialog td.vimiumHelpDescription{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:14px}div#vimiumHelpDialog span.vimiumCopyCommandNameName{cursor:pointer;font-size:12px;font-style:italic}div#vimiumHelpDialog tr.advanced{display:none}div#vimiumHelpDialog.showAdvanced tr.advanced{display:table-row}div#vimiumHelpDialog div.advanced td:nth-of-type(3){color:#555}div#vimiumHelpDialog a.closeButton{color:#555;cursor:pointer;font-family:courier new;font-size:24px;font-weight:700;padding-left:5px;position:relative;text-decoration:none;top:3px}div#vimiumHelpDialog a{text-decoration:underline}div#vimiumHelpDialog a.closeButton:hover{color:#000;-webkit-user-select:none}div#vimiumHelpDialogFooter{display:block;margin-bottom:37px;position:relative}table.helpDialogBottom{width:100%}td.helpDialogBottomRight{float:right;text-align:right;width:100%}td.helpDialogBottomLeft,td.helpDialogBottomRight{padding:0}div#vimiumHelpDialogFooter *{font-size:10px}a#toggleAdvancedCommands,span#help-dialog-tip{font-size:10px;position:relative;top:19px;white-space:nowrap}a#toggleAdvancedCommands,a:active.vimiumHelDialogLink,a:hover.vimiumHelDialogLink,a:link.vimiumHelDialogLink,a:visited.vimiumHelDialogLink{color:#2f508e;cursor:pointer;text-decoration:underline}div.vimiumHUD{background:#f1f1f1;border:1px solid #aaa;border-radius:4px;bottom:8px;box-shadow:0 2px 10px rgba(0,0,0,.8);display:block;left:8px;position:fixed;text-align:left;width:calc(100% - 20px);z-index:2139999999}iframe.vimiumHUDFrame{background-color:transparent;border:none;bottom:-14px;display:block;height:58px;margin:0 0 0 -40%;min-width:300px;opacity:0;overflow:hidden;padding:0;position:fixed;right:20px;width:20%;z-index:2139999998}div.vimiumHUD .vimiumHUDSearchArea{background-color:#f1f1f1;border-radius:4px 4px 0 0;display:block;padding:3px}div.vimiumHUD .vimiumHUDSearchAreaInner{border-radius:3px;box-sizing:border-box;color:#777;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:14px;height:30px;line-height:20px;margin-bottom:0;outline:none;padding:2px 4px;width:100%}div.vimiumHUD .hud-find{background:#fff;border:1px solid #ccc}div.vimiumHUD span#hud-find-input,div.vimiumHUD span#hud-match-count{color:#000;display:inline;outline:none;overflow-y:hidden;white-space:nowrap}div.vimiumHUD span#hud-find-input:before{content:"/"}div.vimiumHUD span#hud-match-count{color:#aaa;font-size:12px}div.vimiumHUD span#hud-find-input br{display:none}div.vimiumHUD span#hud-find-input *{display:inline;white-space:nowrap}body.vimiumFindMode ::selection{background:#ff9632}iframe.vomnibarFrame{background-color:transparent;border:none;display:block;font-family:sans-serif;height:calc(100% - 70px);left:50%;margin:0 0 0 -40%;min-width:400px;overflow:hidden;padding:0;position:fixed;top:70px;width:calc(80% + 20px);z-index:2139999998}div.vimiumFlash{background-color:transparent;box-shadow:0 0 4px 2px #4183c4;padding:1px;position:absolute;z-index:2140000000}iframe.vimiumUIComponentHidden{display:none}iframe.vimiumUIComponentVisible{color-scheme:light dark;display:block}iframe.vimiumUIComponentReactivated{border:5px solid #ff0}iframe.vimiumNonClickable{pointer-events:none}@media (prefers-color-scheme:dark){iframe.reverseDarkReaderFilter{-webkit-filter:invert(100%) hue-rotate(180deg)!important;filter:invert(100%) hue-rotate(180deg)!important}body.vimiumBody{background-color:#292a2d;color:#fff}body.vimiumBody a,body.vimiumBody a:visited{color:#8ab4f8}body.vimiumBody input,body.vimiumBody textarea{background-color:#1d1d1f;border-color:#1d1d1f;color:#e8eaed}body.vimiumBody div.example{color:#9aa0a6}body.vimiumBody div#footer,body.vimiumBody div#state,div#vimiumHelpDialogContainer{background-color:#202124;border-color:hsla(0,0%,100%,.1)}div#vimiumHelpDialog{background-color:#292a2d;color:#fff}div#vimiumHelpDialog td.vimiumHelpDescription{color:#c9cccf}div#vimiumHelpDialog td.vimiumHelpSectionTitle,span#vimiumTitle{color:#fff}#vimiumTitle>span:first-child{color:#8ab4f8!important}div#vimiumHelpDialog a{color:#8ab4f8}div#vimiumHelpDialog div.vimiumDivider{background-color:hsla(0,0%,100%,.1)}span.vimiumHelpDialogKey{background-color:#1d1d1f;border:1px solid #000;box-shadow:none;color:#fff}}',htmlUtilsLibJs:`var __defProp = Object.defineProperty;
58
58
  var __getOwnPropSymbols = Object.getOwnPropertySymbols;
59
59
  var __hasOwnProp = Object.prototype.hasOwnProperty;
60
60
  var __propIsEnum = Object.prototype.propertyIsEnumerable;
@@ -3586,7 +3586,7 @@ function registerAllMomenticListeners() {
3586
3586
 
3587
3587
  // src/html/index.ts
3588
3588
  registerAllMomenticListeners();
3589
- `,cssGeneratorLibJs:'// Taken from https://cdn.jsdelivr.net/npm/css-selector-generator@3.6.8/build/index.min.js\n!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.CssSelectorGenerator=e():t.CssSelectorGenerator=e()}(self,(()=>(()=>{"use strict";var t={d:(e,n)=>{for(var o in n)t.o(n,o)&&!t.o(e,o)&&Object.defineProperty(e,o,{enumerable:!0,get:n[o]})},o:(t,e)=>Object.prototype.hasOwnProperty.call(t,e),r:t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})}},e={};function n(t){return"object"==typeof t&&null!==t&&t.nodeType===Node.ELEMENT_NODE}t.r(e),t.d(e,{default:()=>K,getCssSelector:()=>J});const o={NONE:"",DESCENDANT:" ",CHILD:" > "},r={id:"id",class:"class",tag:"tag",attribute:"attribute",nthchild:"nthchild",nthoftype:"nthoftype"},i="CssSelectorGenerator";function c(t="unknown problem",...e){console.warn(`${i}: ${t}`,...e)}const u={selectors:[r.id,r.class,r.tag,r.attribute],includeTag:!1,whitelist:[],blacklist:[],combineWithinSelector:!0,combineBetweenSelectors:!0,root:null,maxCombinations:Number.POSITIVE_INFINITY,maxCandidates:Number.POSITIVE_INFINITY};function s(t){return t instanceof RegExp}function a(t){return["string","function"].includes(typeof t)||s(t)}function l(t){return Array.isArray(t)?t.filter(a):[]}function f(t){const e=[Node.DOCUMENT_NODE,Node.DOCUMENT_FRAGMENT_NODE,Node.ELEMENT_NODE];return function(t){return t instanceof Node}(t)&&e.includes(t.nodeType)}function d(t,e){if(f(t))return t.contains(e)||c("element root mismatch","Provided root does not contain the element. This will most likely result in producing a fallback selector using element\'s real root node. If you plan to use the selector using provided root (e.g. `root.querySelector`), it will nto work as intended."),t;const n=e.getRootNode({composed:!1});return f(n)?(n!==document&&c("shadow root inferred","You did not provide a root and the element is a child of Shadow DOM. This will produce a selector using ShadowRoot as a root. If you plan to use the selector using document as a root (e.g. `document.querySelector`), it will not work as intended."),n):e.ownerDocument.querySelector(":root")}function m(t){return"number"==typeof t?t:Number.POSITIVE_INFINITY}function p(t=[]){const[e=[],...n]=t;return 0===n.length?e:n.reduce(((t,e)=>t.filter((t=>e.includes(t)))),e)}function h(t){return[].concat(...t)}function g(t){const e=t.map((t=>{if(s(t))return e=>t.test(e);if("function"==typeof t)return e=>{const n=t(e);return"boolean"!=typeof n?(c("pattern matcher function invalid","Provided pattern matching function does not return boolean. It\'s result will be ignored.",t),!1):n};if("string"==typeof t){const e=new RegExp("^"+t.replace(/[|\\\\{}()[\\]^$+?.]/g,"\\\\$&").replace(/\\*/g,".+")+"$");return t=>e.test(t)}return c("pattern matcher invalid","Pattern matching only accepts strings, regular expressions and/or functions. This item is invalid and will be ignored.",t),()=>!1}));return t=>e.some((e=>e(t)))}function y(t,e,n){const o=Array.from(d(n,t[0]).querySelectorAll(e));return o.length===t.length&&t.every((t=>o.includes(t)))}function b(t,e){e=null!=e?e:function(t){return t.ownerDocument.querySelector(":root")}(t);const o=[];let r=t;for(;n(r)&&r!==e;)o.push(r),r=r.parentElement;return o}function N(t,e){return p(t.map((t=>b(t,e))))}const S=", ",E=new RegExp(["^$","\\\\s"].join("|")),w=new RegExp(["^$"].join("|")),I=[r.nthoftype,r.tag,r.id,r.class,r.attribute,r.nthchild],v=g(["class","id","ng-*"]);function T({name:t}){return`[${t}]`}function C({name:t,value:e}){return`[${t}=\'${e}\']`}function O({nodeName:t,nodeValue:e}){return{name:V(t),value:V(e)}}function x(t){const e=Array.from(t.attributes).filter((e=>function({nodeName:t},e){const n=e.tagName.toLowerCase();return!(["input","option"].includes(n)&&"value"===t||v(t))}(e,t))).map(O);return[...e.map(T),...e.map(C)]}function j(t){return(t.getAttribute("class")||"").trim().split(/\\s+/).filter((t=>!w.test(t))).map((t=>`.${V(t)}`))}function A(t){const e=t.getAttribute("id")||"",n=`#${V(e)}`,o=t.getRootNode({composed:!1});return!E.test(e)&&y([t],n,o)?[n]:[]}function $(t){const e=t.parentNode;if(e){const o=Array.from(e.childNodes).filter(n).indexOf(t);if(o>-1)return[`:nth-child(${o+1})`]}return[]}function D(t){return[V(t.tagName.toLowerCase())]}function R(t){const e=[...new Set(h(t.map(D)))];return 0===e.length||e.length>1?[]:[e[0]]}function P(t){const e=R([t])[0],n=t.parentElement;if(n){const o=Array.from(n.children).filter((t=>t.tagName.toLowerCase()===e)),r=o.indexOf(t);if(r>-1)return[`${e}:nth-of-type(${r+1})`]}return[]}function _(t=[],{maxResults:e=Number.POSITIVE_INFINITY}={}){return Array.from(function*(t=[],{maxResults:e=Number.POSITIVE_INFINITY}={}){let n=0,o=L(1);for(;o.length<=t.length&&n<e;){n+=1;const e=o.map((e=>t[e]));yield e,o=k(o,t.length-1)}}(t,{maxResults:e}))}function k(t=[],e=0){const n=t.length;if(0===n)return[];const o=[...t];o[n-1]+=1;for(let t=n-1;t>=0;t--)if(o[t]>e){if(0===t)return L(n+1);o[t-1]++,o[t]=o[t-1]+1}return o[n-1]>e?L(n+1):o}function L(t=1){return Array.from(Array(t).keys())}const M=":".charCodeAt(0).toString(16).toUpperCase(),F=/[ !"#$%&\'()\\[\\]{|}<>*+,./;=?@^`~\\\\]/;function V(t=""){var e,n;return null!==(n=null===(e=null===CSS||void 0===CSS?void 0:CSS.escape)||void 0===e?void 0:e.call(CSS,t))&&void 0!==n?n:function(t=""){return t.split("").map((t=>":"===t?`\\\\${M} `:F.test(t)?`\\\\${t}`:escape(t).replace(/%/g,"\\\\"))).join("")}(t)}const Y={tag:R,id:function(t){return 0===t.length||t.length>1?[]:A(t[0])},class:function(t){return p(t.map(j))},attribute:function(t){return p(t.map(x))},nthchild:function(t){return p(t.map($))},nthoftype:function(t){return p(t.map(P))}},q={tag:D,id:A,class:j,attribute:x,nthchild:$,nthoftype:P};function B(t){return t.includes(r.tag)||t.includes(r.nthoftype)?[...t]:[...t,r.tag]}function G(t={}){const e=[...I];return t[r.tag]&&t[r.nthoftype]&&e.splice(e.indexOf(r.tag),1),e.map((e=>{return(o=t)[n=e]?o[n].join(""):"";var n,o})).join("")}function H(t,e,n="",r){const i=function(t,e){return""===e?t:function(t,e){return[...t.map((t=>e+o.DESCENDANT+t)),...t.map((t=>e+o.CHILD+t))]}(t,e)}(function(t,e,n){const o=function(t,e){const{blacklist:n,whitelist:o,combineWithinSelector:r,maxCombinations:i}=e,c=g(n),u=g(o);return function(t){const{selectors:e,includeTag:n}=t,o=[].concat(e);return n&&!o.includes("tag")&&o.push("tag"),o}(e).reduce(((e,n)=>{const o=function(t,e){var n;return(null!==(n=Y[e])&&void 0!==n?n:()=>[])(t)}(t,n),s=function(t=[],e,n){return t.filter((t=>n(t)||!e(t)))}(o,c,u),a=function(t=[],e){return t.sort(((t,n)=>{const o=e(t),r=e(n);return o&&!r?-1:!o&&r?1:0}))}(s,u);return e[n]=r?_(a,{maxResults:i}):a.map((t=>[t])),e}),{})}(t,n),r=function(t,e){return function(t){const{selectors:e,combineBetweenSelectors:n,includeTag:o,maxCandidates:r}=t,i=n?_(e,{maxResults:r}):e.map((t=>[t]));return o?i.map(B):i}(e).map((e=>function(t,e){const n={};return t.forEach((t=>{const o=e[t];o.length>0&&(n[t]=o)})),function(t={}){let e=[];return Object.entries(t).forEach((([t,n])=>{e=n.flatMap((n=>0===e.length?[{[t]:n}]:e.map((e=>Object.assign(Object.assign({},e),{[t]:n})))))})),e}(n).map(G)}(e,t))).filter((t=>t.length>0))}(o,n),i=h(r);return[...new Set(i)]}(t,r.root,r),n);for(const e of i)if(y(t,e,r.root))return e;return null}function W(t){return{value:t,include:!1}}function U({selectors:t,operator:e}){let n=[...I];t[r.tag]&&t[r.nthoftype]&&(n=n.filter((t=>t!==r.tag)));let o="";return n.forEach((e=>{(t[e]||[]).forEach((({value:t,include:e})=>{e&&(o+=t)}))})),e+o}function z(t){return[":root",...b(t).reverse().map((t=>{const e=function(t,e,n=o.NONE){const r={};return e.forEach((e=>{Reflect.set(r,e,function(t,e){return q[e](t)}(t,e).map(W))})),{element:t,operator:n,selectors:r}}(t,[r.nthchild],o.CHILD);return e.selectors.nthchild.forEach((t=>{t.include=!0})),e})).map(U)].join("")}function J(t,e={}){const o=function(t){(t instanceof NodeList||t instanceof HTMLCollection)&&(t=Array.from(t));const e=(Array.isArray(t)?t:[t]).filter(n);return[...new Set(e)]}(t),i=function(t,e={}){const n=Object.assign(Object.assign({},u),e);return{selectors:(o=n.selectors,Array.isArray(o)?o.filter((t=>{return e=r,n=t,Object.values(e).includes(n);var e,n})):[]),whitelist:l(n.whitelist),blacklist:l(n.blacklist),root:d(n.root,t),combineWithinSelector:!!n.combineWithinSelector,combineBetweenSelectors:!!n.combineBetweenSelectors,includeTag:!!n.includeTag,maxCombinations:m(n.maxCombinations),maxCandidates:m(n.maxCandidates)};var o}(o[0],e);let c="",s=i.root;function a(){return function(t,e,n="",o){if(0===t.length)return null;const r=[t.length>1?t:[],...N(t,e).map((t=>[t]))];for(const t of r){const e=H(t,0,n,o);if(e)return{foundElements:t,selector:e}}return null}(o,s,c,i)}let f=a();for(;f;){const{foundElements:t,selector:e}=f;if(y(o,e,i.root))return e;s=t[0],c=e,f=a()}return o.length>1?o.map((t=>J(t,i))).join(S):function(t){return t.map(z).join(S)}(o)}const K=J;return e})()));'};import{execSync as jO}from"child_process";import{randomUUID as Fb}from"crypto";import{existsSync as El,mkdirSync as $O,readFileSync as GO,writeFileSync as WO}from"fs";import{Jimp as Ub}from"jimp";import VO from"js-beautify";import{cloneDeep as Bb}from"lodash-es";var Ny={"application/prs.cww":["cww"],"application/prs.xsf+xml":["xsf"],"application/vnd.1000minds.decision-model+xml":["1km"],"application/vnd.3gpp.pic-bw-large":["plb"],"application/vnd.3gpp.pic-bw-small":["psb"],"application/vnd.3gpp.pic-bw-var":["pvb"],"application/vnd.3gpp2.tcap":["tcap"],"application/vnd.3m.post-it-notes":["pwn"],"application/vnd.accpac.simply.aso":["aso"],"application/vnd.accpac.simply.imp":["imp"],"application/vnd.acucobol":["acu"],"application/vnd.acucorp":["atc","acutc"],"application/vnd.adobe.air-application-installer-package+zip":["air"],"application/vnd.adobe.formscentral.fcdt":["fcdt"],"application/vnd.adobe.fxp":["fxp","fxpl"],"application/vnd.adobe.xdp+xml":["xdp"],"application/vnd.adobe.xfdf":["*xfdf"],"application/vnd.age":["age"],"application/vnd.ahead.space":["ahead"],"application/vnd.airzip.filesecure.azf":["azf"],"application/vnd.airzip.filesecure.azs":["azs"],"application/vnd.amazon.ebook":["azw"],"application/vnd.americandynamics.acc":["acc"],"application/vnd.amiga.ami":["ami"],"application/vnd.android.package-archive":["apk"],"application/vnd.anser-web-certificate-issue-initiation":["cii"],"application/vnd.anser-web-funds-transfer-initiation":["fti"],"application/vnd.antix.game-component":["atx"],"application/vnd.apple.installer+xml":["mpkg"],"application/vnd.apple.keynote":["key"],"application/vnd.apple.mpegurl":["m3u8"],"application/vnd.apple.numbers":["numbers"],"application/vnd.apple.pages":["pages"],"application/vnd.apple.pkpass":["pkpass"],"application/vnd.aristanetworks.swi":["swi"],"application/vnd.astraea-software.iota":["iota"],"application/vnd.audiograph":["aep"],"application/vnd.balsamiq.bmml+xml":["bmml"],"application/vnd.blueice.multipass":["mpm"],"application/vnd.bmi":["bmi"],"application/vnd.businessobjects":["rep"],"application/vnd.chemdraw+xml":["cdxml"],"application/vnd.chipnuts.karaoke-mmd":["mmd"],"application/vnd.cinderella":["cdy"],"application/vnd.citationstyles.style+xml":["csl"],"application/vnd.claymore":["cla"],"application/vnd.cloanto.rp9":["rp9"],"application/vnd.clonk.c4group":["c4g","c4d","c4f","c4p","c4u"],"application/vnd.cluetrust.cartomobile-config":["c11amc"],"application/vnd.cluetrust.cartomobile-config-pkg":["c11amz"],"application/vnd.commonspace":["csp"],"application/vnd.contact.cmsg":["cdbcmsg"],"application/vnd.cosmocaller":["cmc"],"application/vnd.crick.clicker":["clkx"],"application/vnd.crick.clicker.keyboard":["clkk"],"application/vnd.crick.clicker.palette":["clkp"],"application/vnd.crick.clicker.template":["clkt"],"application/vnd.crick.clicker.wordbank":["clkw"],"application/vnd.criticaltools.wbs+xml":["wbs"],"application/vnd.ctc-posml":["pml"],"application/vnd.cups-ppd":["ppd"],"application/vnd.curl.car":["car"],"application/vnd.curl.pcurl":["pcurl"],"application/vnd.dart":["dart"],"application/vnd.data-vision.rdz":["rdz"],"application/vnd.dbf":["dbf"],"application/vnd.dece.data":["uvf","uvvf","uvd","uvvd"],"application/vnd.dece.ttml+xml":["uvt","uvvt"],"application/vnd.dece.unspecified":["uvx","uvvx"],"application/vnd.dece.zip":["uvz","uvvz"],"application/vnd.denovo.fcselayout-link":["fe_launch"],"application/vnd.dna":["dna"],"application/vnd.dolby.mlp":["mlp"],"application/vnd.dpgraph":["dpg"],"application/vnd.dreamfactory":["dfac"],"application/vnd.ds-keypoint":["kpxx"],"application/vnd.dvb.ait":["ait"],"application/vnd.dvb.service":["svc"],"application/vnd.dynageo":["geo"],"application/vnd.ecowin.chart":["mag"],"application/vnd.enliven":["nml"],"application/vnd.epson.esf":["esf"],"application/vnd.epson.msf":["msf"],"application/vnd.epson.quickanime":["qam"],"application/vnd.epson.salt":["slt"],"application/vnd.epson.ssf":["ssf"],"application/vnd.eszigno3+xml":["es3","et3"],"application/vnd.ezpix-album":["ez2"],"application/vnd.ezpix-package":["ez3"],"application/vnd.fdf":["*fdf"],"application/vnd.fdsn.mseed":["mseed"],"application/vnd.fdsn.seed":["seed","dataless"],"application/vnd.flographit":["gph"],"application/vnd.fluxtime.clip":["ftc"],"application/vnd.framemaker":["fm","frame","maker","book"],"application/vnd.frogans.fnc":["fnc"],"application/vnd.frogans.ltf":["ltf"],"application/vnd.fsc.weblaunch":["fsc"],"application/vnd.fujitsu.oasys":["oas"],"application/vnd.fujitsu.oasys2":["oa2"],"application/vnd.fujitsu.oasys3":["oa3"],"application/vnd.fujitsu.oasysgp":["fg5"],"application/vnd.fujitsu.oasysprs":["bh2"],"application/vnd.fujixerox.ddd":["ddd"],"application/vnd.fujixerox.docuworks":["xdw"],"application/vnd.fujixerox.docuworks.binder":["xbd"],"application/vnd.fuzzysheet":["fzs"],"application/vnd.genomatix.tuxedo":["txd"],"application/vnd.geogebra.file":["ggb"],"application/vnd.geogebra.tool":["ggt"],"application/vnd.geometry-explorer":["gex","gre"],"application/vnd.geonext":["gxt"],"application/vnd.geoplan":["g2w"],"application/vnd.geospace":["g3w"],"application/vnd.gmx":["gmx"],"application/vnd.google-apps.document":["gdoc"],"application/vnd.google-apps.presentation":["gslides"],"application/vnd.google-apps.spreadsheet":["gsheet"],"application/vnd.google-earth.kml+xml":["kml"],"application/vnd.google-earth.kmz":["kmz"],"application/vnd.grafeq":["gqf","gqs"],"application/vnd.groove-account":["gac"],"application/vnd.groove-help":["ghf"],"application/vnd.groove-identity-message":["gim"],"application/vnd.groove-injector":["grv"],"application/vnd.groove-tool-message":["gtm"],"application/vnd.groove-tool-template":["tpl"],"application/vnd.groove-vcard":["vcg"],"application/vnd.hal+xml":["hal"],"application/vnd.handheld-entertainment+xml":["zmm"],"application/vnd.hbci":["hbci"],"application/vnd.hhe.lesson-player":["les"],"application/vnd.hp-hpgl":["hpgl"],"application/vnd.hp-hpid":["hpid"],"application/vnd.hp-hps":["hps"],"application/vnd.hp-jlyt":["jlt"],"application/vnd.hp-pcl":["pcl"],"application/vnd.hp-pclxl":["pclxl"],"application/vnd.hydrostatix.sof-data":["sfd-hdstx"],"application/vnd.ibm.minipay":["mpy"],"application/vnd.ibm.modcap":["afp","listafp","list3820"],"application/vnd.ibm.rights-management":["irm"],"application/vnd.ibm.secure-container":["sc"],"application/vnd.iccprofile":["icc","icm"],"application/vnd.igloader":["igl"],"application/vnd.immervision-ivp":["ivp"],"application/vnd.immervision-ivu":["ivu"],"application/vnd.insors.igm":["igm"],"application/vnd.intercon.formnet":["xpw","xpx"],"application/vnd.intergeo":["i2g"],"application/vnd.intu.qbo":["qbo"],"application/vnd.intu.qfx":["qfx"],"application/vnd.ipunplugged.rcprofile":["rcprofile"],"application/vnd.irepository.package+xml":["irp"],"application/vnd.is-xpr":["xpr"],"application/vnd.isac.fcs":["fcs"],"application/vnd.jam":["jam"],"application/vnd.jcp.javame.midlet-rms":["rms"],"application/vnd.jisp":["jisp"],"application/vnd.joost.joda-archive":["joda"],"application/vnd.kahootz":["ktz","ktr"],"application/vnd.kde.karbon":["karbon"],"application/vnd.kde.kchart":["chrt"],"application/vnd.kde.kformula":["kfo"],"application/vnd.kde.kivio":["flw"],"application/vnd.kde.kontour":["kon"],"application/vnd.kde.kpresenter":["kpr","kpt"],"application/vnd.kde.kspread":["ksp"],"application/vnd.kde.kword":["kwd","kwt"],"application/vnd.kenameaapp":["htke"],"application/vnd.kidspiration":["kia"],"application/vnd.kinar":["kne","knp"],"application/vnd.koan":["skp","skd","skt","skm"],"application/vnd.kodak-descriptor":["sse"],"application/vnd.las.las+xml":["lasxml"],"application/vnd.llamagraphics.life-balance.desktop":["lbd"],"application/vnd.llamagraphics.life-balance.exchange+xml":["lbe"],"application/vnd.lotus-1-2-3":["123"],"application/vnd.lotus-approach":["apr"],"application/vnd.lotus-freelance":["pre"],"application/vnd.lotus-notes":["nsf"],"application/vnd.lotus-organizer":["org"],"application/vnd.lotus-screencam":["scm"],"application/vnd.lotus-wordpro":["lwp"],"application/vnd.macports.portpkg":["portpkg"],"application/vnd.mapbox-vector-tile":["mvt"],"application/vnd.mcd":["mcd"],"application/vnd.medcalcdata":["mc1"],"application/vnd.mediastation.cdkey":["cdkey"],"application/vnd.mfer":["mwf"],"application/vnd.mfmp":["mfm"],"application/vnd.micrografx.flo":["flo"],"application/vnd.micrografx.igx":["igx"],"application/vnd.mif":["mif"],"application/vnd.mobius.daf":["daf"],"application/vnd.mobius.dis":["dis"],"application/vnd.mobius.mbk":["mbk"],"application/vnd.mobius.mqy":["mqy"],"application/vnd.mobius.msl":["msl"],"application/vnd.mobius.plc":["plc"],"application/vnd.mobius.txf":["txf"],"application/vnd.mophun.application":["mpn"],"application/vnd.mophun.certificate":["mpc"],"application/vnd.mozilla.xul+xml":["xul"],"application/vnd.ms-artgalry":["cil"],"application/vnd.ms-cab-compressed":["cab"],"application/vnd.ms-excel":["xls","xlm","xla","xlc","xlt","xlw"],"application/vnd.ms-excel.addin.macroenabled.12":["xlam"],"application/vnd.ms-excel.sheet.binary.macroenabled.12":["xlsb"],"application/vnd.ms-excel.sheet.macroenabled.12":["xlsm"],"application/vnd.ms-excel.template.macroenabled.12":["xltm"],"application/vnd.ms-fontobject":["eot"],"application/vnd.ms-htmlhelp":["chm"],"application/vnd.ms-ims":["ims"],"application/vnd.ms-lrm":["lrm"],"application/vnd.ms-officetheme":["thmx"],"application/vnd.ms-outlook":["msg"],"application/vnd.ms-pki.seccat":["cat"],"application/vnd.ms-pki.stl":["*stl"],"application/vnd.ms-powerpoint":["ppt","pps","pot"],"application/vnd.ms-powerpoint.addin.macroenabled.12":["ppam"],"application/vnd.ms-powerpoint.presentation.macroenabled.12":["pptm"],"application/vnd.ms-powerpoint.slide.macroenabled.12":["sldm"],"application/vnd.ms-powerpoint.slideshow.macroenabled.12":["ppsm"],"application/vnd.ms-powerpoint.template.macroenabled.12":["potm"],"application/vnd.ms-project":["*mpp","mpt"],"application/vnd.ms-word.document.macroenabled.12":["docm"],"application/vnd.ms-word.template.macroenabled.12":["dotm"],"application/vnd.ms-works":["wps","wks","wcm","wdb"],"application/vnd.ms-wpl":["wpl"],"application/vnd.ms-xpsdocument":["xps"],"application/vnd.mseq":["mseq"],"application/vnd.musician":["mus"],"application/vnd.muvee.style":["msty"],"application/vnd.mynfc":["taglet"],"application/vnd.neurolanguage.nlu":["nlu"],"application/vnd.nitf":["ntf","nitf"],"application/vnd.noblenet-directory":["nnd"],"application/vnd.noblenet-sealer":["nns"],"application/vnd.noblenet-web":["nnw"],"application/vnd.nokia.n-gage.ac+xml":["*ac"],"application/vnd.nokia.n-gage.data":["ngdat"],"application/vnd.nokia.n-gage.symbian.install":["n-gage"],"application/vnd.nokia.radio-preset":["rpst"],"application/vnd.nokia.radio-presets":["rpss"],"application/vnd.novadigm.edm":["edm"],"application/vnd.novadigm.edx":["edx"],"application/vnd.novadigm.ext":["ext"],"application/vnd.oasis.opendocument.chart":["odc"],"application/vnd.oasis.opendocument.chart-template":["otc"],"application/vnd.oasis.opendocument.database":["odb"],"application/vnd.oasis.opendocument.formula":["odf"],"application/vnd.oasis.opendocument.formula-template":["odft"],"application/vnd.oasis.opendocument.graphics":["odg"],"application/vnd.oasis.opendocument.graphics-template":["otg"],"application/vnd.oasis.opendocument.image":["odi"],"application/vnd.oasis.opendocument.image-template":["oti"],"application/vnd.oasis.opendocument.presentation":["odp"],"application/vnd.oasis.opendocument.presentation-template":["otp"],"application/vnd.oasis.opendocument.spreadsheet":["ods"],"application/vnd.oasis.opendocument.spreadsheet-template":["ots"],"application/vnd.oasis.opendocument.text":["odt"],"application/vnd.oasis.opendocument.text-master":["odm"],"application/vnd.oasis.opendocument.text-template":["ott"],"application/vnd.oasis.opendocument.text-web":["oth"],"application/vnd.olpc-sugar":["xo"],"application/vnd.oma.dd2+xml":["dd2"],"application/vnd.openblox.game+xml":["obgx"],"application/vnd.openofficeorg.extension":["oxt"],"application/vnd.openstreetmap.data+xml":["osm"],"application/vnd.openxmlformats-officedocument.presentationml.presentation":["pptx"],"application/vnd.openxmlformats-officedocument.presentationml.slide":["sldx"],"application/vnd.openxmlformats-officedocument.presentationml.slideshow":["ppsx"],"application/vnd.openxmlformats-officedocument.presentationml.template":["potx"],"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet":["xlsx"],"application/vnd.openxmlformats-officedocument.spreadsheetml.template":["xltx"],"application/vnd.openxmlformats-officedocument.wordprocessingml.document":["docx"],"application/vnd.openxmlformats-officedocument.wordprocessingml.template":["dotx"],"application/vnd.osgeo.mapguide.package":["mgp"],"application/vnd.osgi.dp":["dp"],"application/vnd.osgi.subsystem":["esa"],"application/vnd.palm":["pdb","pqa","oprc"],"application/vnd.pawaafile":["paw"],"application/vnd.pg.format":["str"],"application/vnd.pg.osasli":["ei6"],"application/vnd.picsel":["efif"],"application/vnd.pmi.widget":["wg"],"application/vnd.pocketlearn":["plf"],"application/vnd.powerbuilder6":["pbd"],"application/vnd.previewsystems.box":["box"],"application/vnd.proteus.magazine":["mgz"],"application/vnd.publishare-delta-tree":["qps"],"application/vnd.pvi.ptid1":["ptid"],"application/vnd.pwg-xhtml-print+xml":["xhtm"],"application/vnd.quark.quarkxpress":["qxd","qxt","qwd","qwt","qxl","qxb"],"application/vnd.rar":["rar"],"application/vnd.realvnc.bed":["bed"],"application/vnd.recordare.musicxml":["mxl"],"application/vnd.recordare.musicxml+xml":["musicxml"],"application/vnd.rig.cryptonote":["cryptonote"],"application/vnd.rim.cod":["cod"],"application/vnd.rn-realmedia":["rm"],"application/vnd.rn-realmedia-vbr":["rmvb"],"application/vnd.route66.link66+xml":["link66"],"application/vnd.sailingtracker.track":["st"],"application/vnd.seemail":["see"],"application/vnd.sema":["sema"],"application/vnd.semd":["semd"],"application/vnd.semf":["semf"],"application/vnd.shana.informed.formdata":["ifm"],"application/vnd.shana.informed.formtemplate":["itp"],"application/vnd.shana.informed.interchange":["iif"],"application/vnd.shana.informed.package":["ipk"],"application/vnd.simtech-mindmapper":["twd","twds"],"application/vnd.smaf":["mmf"],"application/vnd.smart.teacher":["teacher"],"application/vnd.software602.filler.form+xml":["fo"],"application/vnd.solent.sdkm+xml":["sdkm","sdkd"],"application/vnd.spotfire.dxp":["dxp"],"application/vnd.spotfire.sfs":["sfs"],"application/vnd.stardivision.calc":["sdc"],"application/vnd.stardivision.draw":["sda"],"application/vnd.stardivision.impress":["sdd"],"application/vnd.stardivision.math":["smf"],"application/vnd.stardivision.writer":["sdw","vor"],"application/vnd.stardivision.writer-global":["sgl"],"application/vnd.stepmania.package":["smzip"],"application/vnd.stepmania.stepchart":["sm"],"application/vnd.sun.wadl+xml":["wadl"],"application/vnd.sun.xml.calc":["sxc"],"application/vnd.sun.xml.calc.template":["stc"],"application/vnd.sun.xml.draw":["sxd"],"application/vnd.sun.xml.draw.template":["std"],"application/vnd.sun.xml.impress":["sxi"],"application/vnd.sun.xml.impress.template":["sti"],"application/vnd.sun.xml.math":["sxm"],"application/vnd.sun.xml.writer":["sxw"],"application/vnd.sun.xml.writer.global":["sxg"],"application/vnd.sun.xml.writer.template":["stw"],"application/vnd.sus-calendar":["sus","susp"],"application/vnd.svd":["svd"],"application/vnd.symbian.install":["sis","sisx"],"application/vnd.syncml+xml":["xsm"],"application/vnd.syncml.dm+wbxml":["bdm"],"application/vnd.syncml.dm+xml":["xdm"],"application/vnd.syncml.dmddf+xml":["ddf"],"application/vnd.tao.intent-module-archive":["tao"],"application/vnd.tcpdump.pcap":["pcap","cap","dmp"],"application/vnd.tmobile-livetv":["tmo"],"application/vnd.trid.tpt":["tpt"],"application/vnd.triscape.mxs":["mxs"],"application/vnd.trueapp":["tra"],"application/vnd.ufdl":["ufd","ufdl"],"application/vnd.uiq.theme":["utz"],"application/vnd.umajin":["umj"],"application/vnd.unity":["unityweb"],"application/vnd.uoml+xml":["uoml","uo"],"application/vnd.vcx":["vcx"],"application/vnd.visio":["vsd","vst","vss","vsw"],"application/vnd.visionary":["vis"],"application/vnd.vsf":["vsf"],"application/vnd.wap.wbxml":["wbxml"],"application/vnd.wap.wmlc":["wmlc"],"application/vnd.wap.wmlscriptc":["wmlsc"],"application/vnd.webturbo":["wtb"],"application/vnd.wolfram.player":["nbp"],"application/vnd.wordperfect":["wpd"],"application/vnd.wqd":["wqd"],"application/vnd.wt.stf":["stf"],"application/vnd.xara":["xar"],"application/vnd.xfdl":["xfdl"],"application/vnd.yamaha.hv-dic":["hvd"],"application/vnd.yamaha.hv-script":["hvs"],"application/vnd.yamaha.hv-voice":["hvp"],"application/vnd.yamaha.openscoreformat":["osf"],"application/vnd.yamaha.openscoreformat.osfpvg+xml":["osfpvg"],"application/vnd.yamaha.smaf-audio":["saf"],"application/vnd.yamaha.smaf-phrase":["spf"],"application/vnd.yellowriver-custom-menu":["cmp"],"application/vnd.zul":["zir","zirz"],"application/vnd.zzazz.deck+xml":["zaz"],"application/x-7z-compressed":["7z"],"application/x-abiword":["abw"],"application/x-ace-compressed":["ace"],"application/x-apple-diskimage":["*dmg"],"application/x-arj":["arj"],"application/x-authorware-bin":["aab","x32","u32","vox"],"application/x-authorware-map":["aam"],"application/x-authorware-seg":["aas"],"application/x-bcpio":["bcpio"],"application/x-bdoc":["*bdoc"],"application/x-bittorrent":["torrent"],"application/x-blorb":["blb","blorb"],"application/x-bzip":["bz"],"application/x-bzip2":["bz2","boz"],"application/x-cbr":["cbr","cba","cbt","cbz","cb7"],"application/x-cdlink":["vcd"],"application/x-cfs-compressed":["cfs"],"application/x-chat":["chat"],"application/x-chess-pgn":["pgn"],"application/x-chrome-extension":["crx"],"application/x-cocoa":["cco"],"application/x-conference":["nsc"],"application/x-cpio":["cpio"],"application/x-csh":["csh"],"application/x-debian-package":["*deb","udeb"],"application/x-dgc-compressed":["dgc"],"application/x-director":["dir","dcr","dxr","cst","cct","cxt","w3d","fgd","swa"],"application/x-doom":["wad"],"application/x-dtbncx+xml":["ncx"],"application/x-dtbook+xml":["dtb"],"application/x-dtbresource+xml":["res"],"application/x-dvi":["dvi"],"application/x-envoy":["evy"],"application/x-eva":["eva"],"application/x-font-bdf":["bdf"],"application/x-font-ghostscript":["gsf"],"application/x-font-linux-psf":["psf"],"application/x-font-pcf":["pcf"],"application/x-font-snf":["snf"],"application/x-font-type1":["pfa","pfb","pfm","afm"],"application/x-freearc":["arc"],"application/x-futuresplash":["spl"],"application/x-gca-compressed":["gca"],"application/x-glulx":["ulx"],"application/x-gnumeric":["gnumeric"],"application/x-gramps-xml":["gramps"],"application/x-gtar":["gtar"],"application/x-hdf":["hdf"],"application/x-httpd-php":["php"],"application/x-install-instructions":["install"],"application/x-iso9660-image":["*iso"],"application/x-iwork-keynote-sffkey":["*key"],"application/x-iwork-numbers-sffnumbers":["*numbers"],"application/x-iwork-pages-sffpages":["*pages"],"application/x-java-archive-diff":["jardiff"],"application/x-java-jnlp-file":["jnlp"],"application/x-keepass2":["kdbx"],"application/x-latex":["latex"],"application/x-lua-bytecode":["luac"],"application/x-lzh-compressed":["lzh","lha"],"application/x-makeself":["run"],"application/x-mie":["mie"],"application/x-mobipocket-ebook":["*prc","mobi"],"application/x-ms-application":["application"],"application/x-ms-shortcut":["lnk"],"application/x-ms-wmd":["wmd"],"application/x-ms-wmz":["wmz"],"application/x-ms-xbap":["xbap"],"application/x-msaccess":["mdb"],"application/x-msbinder":["obd"],"application/x-mscardfile":["crd"],"application/x-msclip":["clp"],"application/x-msdos-program":["*exe"],"application/x-msdownload":["*exe","*dll","com","bat","*msi"],"application/x-msmediaview":["mvb","m13","m14"],"application/x-msmetafile":["*wmf","*wmz","*emf","emz"],"application/x-msmoney":["mny"],"application/x-mspublisher":["pub"],"application/x-msschedule":["scd"],"application/x-msterminal":["trm"],"application/x-mswrite":["wri"],"application/x-netcdf":["nc","cdf"],"application/x-ns-proxy-autoconfig":["pac"],"application/x-nzb":["nzb"],"application/x-perl":["pl","pm"],"application/x-pilot":["*prc","*pdb"],"application/x-pkcs12":["p12","pfx"],"application/x-pkcs7-certificates":["p7b","spc"],"application/x-pkcs7-certreqresp":["p7r"],"application/x-rar-compressed":["*rar"],"application/x-redhat-package-manager":["rpm"],"application/x-research-info-systems":["ris"],"application/x-sea":["sea"],"application/x-sh":["sh"],"application/x-shar":["shar"],"application/x-shockwave-flash":["swf"],"application/x-silverlight-app":["xap"],"application/x-sql":["*sql"],"application/x-stuffit":["sit"],"application/x-stuffitx":["sitx"],"application/x-subrip":["srt"],"application/x-sv4cpio":["sv4cpio"],"application/x-sv4crc":["sv4crc"],"application/x-t3vm-image":["t3"],"application/x-tads":["gam"],"application/x-tar":["tar"],"application/x-tcl":["tcl","tk"],"application/x-tex":["tex"],"application/x-tex-tfm":["tfm"],"application/x-texinfo":["texinfo","texi"],"application/x-tgif":["*obj"],"application/x-ustar":["ustar"],"application/x-virtualbox-hdd":["hdd"],"application/x-virtualbox-ova":["ova"],"application/x-virtualbox-ovf":["ovf"],"application/x-virtualbox-vbox":["vbox"],"application/x-virtualbox-vbox-extpack":["vbox-extpack"],"application/x-virtualbox-vdi":["vdi"],"application/x-virtualbox-vhd":["vhd"],"application/x-virtualbox-vmdk":["vmdk"],"application/x-wais-source":["src"],"application/x-web-app-manifest+json":["webapp"],"application/x-x509-ca-cert":["der","crt","pem"],"application/x-xfig":["fig"],"application/x-xliff+xml":["*xlf"],"application/x-xpinstall":["xpi"],"application/x-xz":["xz"],"application/x-zmachine":["z1","z2","z3","z4","z5","z6","z7","z8"],"audio/vnd.dece.audio":["uva","uvva"],"audio/vnd.digital-winds":["eol"],"audio/vnd.dra":["dra"],"audio/vnd.dts":["dts"],"audio/vnd.dts.hd":["dtshd"],"audio/vnd.lucent.voice":["lvp"],"audio/vnd.ms-playready.media.pya":["pya"],"audio/vnd.nuera.ecelp4800":["ecelp4800"],"audio/vnd.nuera.ecelp7470":["ecelp7470"],"audio/vnd.nuera.ecelp9600":["ecelp9600"],"audio/vnd.rip":["rip"],"audio/x-aac":["*aac"],"audio/x-aiff":["aif","aiff","aifc"],"audio/x-caf":["caf"],"audio/x-flac":["flac"],"audio/x-m4a":["*m4a"],"audio/x-matroska":["mka"],"audio/x-mpegurl":["m3u"],"audio/x-ms-wax":["wax"],"audio/x-ms-wma":["wma"],"audio/x-pn-realaudio":["ram","ra"],"audio/x-pn-realaudio-plugin":["rmp"],"audio/x-realaudio":["*ra"],"audio/x-wav":["*wav"],"chemical/x-cdx":["cdx"],"chemical/x-cif":["cif"],"chemical/x-cmdf":["cmdf"],"chemical/x-cml":["cml"],"chemical/x-csml":["csml"],"chemical/x-xyz":["xyz"],"image/prs.btif":["btif","btf"],"image/prs.pti":["pti"],"image/vnd.adobe.photoshop":["psd"],"image/vnd.airzip.accelerator.azv":["azv"],"image/vnd.dece.graphic":["uvi","uvvi","uvg","uvvg"],"image/vnd.djvu":["djvu","djv"],"image/vnd.dvb.subtitle":["*sub"],"image/vnd.dwg":["dwg"],"image/vnd.dxf":["dxf"],"image/vnd.fastbidsheet":["fbs"],"image/vnd.fpx":["fpx"],"image/vnd.fst":["fst"],"image/vnd.fujixerox.edmics-mmr":["mmr"],"image/vnd.fujixerox.edmics-rlc":["rlc"],"image/vnd.microsoft.icon":["ico"],"image/vnd.ms-dds":["dds"],"image/vnd.ms-modi":["mdi"],"image/vnd.ms-photo":["wdp"],"image/vnd.net-fpx":["npx"],"image/vnd.pco.b16":["b16"],"image/vnd.tencent.tap":["tap"],"image/vnd.valve.source.texture":["vtf"],"image/vnd.wap.wbmp":["wbmp"],"image/vnd.xiff":["xif"],"image/vnd.zbrush.pcx":["pcx"],"image/x-3ds":["3ds"],"image/x-cmu-raster":["ras"],"image/x-cmx":["cmx"],"image/x-freehand":["fh","fhc","fh4","fh5","fh7"],"image/x-icon":["*ico"],"image/x-jng":["jng"],"image/x-mrsid-image":["sid"],"image/x-ms-bmp":["*bmp"],"image/x-pcx":["*pcx"],"image/x-pict":["pic","pct"],"image/x-portable-anymap":["pnm"],"image/x-portable-bitmap":["pbm"],"image/x-portable-graymap":["pgm"],"image/x-portable-pixmap":["ppm"],"image/x-rgb":["rgb"],"image/x-tga":["tga"],"image/x-xbitmap":["xbm"],"image/x-xpixmap":["xpm"],"image/x-xwindowdump":["xwd"],"message/vnd.wfa.wsc":["wsc"],"model/vnd.cld":["cld"],"model/vnd.collada+xml":["dae"],"model/vnd.dwf":["dwf"],"model/vnd.gdl":["gdl"],"model/vnd.gtw":["gtw"],"model/vnd.mts":["mts"],"model/vnd.opengex":["ogex"],"model/vnd.parasolid.transmit.binary":["x_b"],"model/vnd.parasolid.transmit.text":["x_t"],"model/vnd.pytha.pyox":["pyo","pyox"],"model/vnd.sap.vds":["vds"],"model/vnd.usda":["usda"],"model/vnd.usdz+zip":["usdz"],"model/vnd.valve.source.compiled-map":["bsp"],"model/vnd.vtu":["vtu"],"text/prs.lines.tag":["dsc"],"text/vnd.curl":["curl"],"text/vnd.curl.dcurl":["dcurl"],"text/vnd.curl.mcurl":["mcurl"],"text/vnd.curl.scurl":["scurl"],"text/vnd.dvb.subtitle":["sub"],"text/vnd.familysearch.gedcom":["ged"],"text/vnd.fly":["fly"],"text/vnd.fmi.flexstor":["flx"],"text/vnd.graphviz":["gv"],"text/vnd.in3d.3dml":["3dml"],"text/vnd.in3d.spot":["spot"],"text/vnd.sun.j2me.app-descriptor":["jad"],"text/vnd.wap.wml":["wml"],"text/vnd.wap.wmlscript":["wmls"],"text/x-asm":["s","asm"],"text/x-c":["c","cc","cxx","cpp","h","hh","dic"],"text/x-component":["htc"],"text/x-fortran":["f","for","f77","f90"],"text/x-handlebars-template":["hbs"],"text/x-java-source":["java"],"text/x-lua":["lua"],"text/x-markdown":["mkd"],"text/x-nfo":["nfo"],"text/x-opml":["opml"],"text/x-org":["*org"],"text/x-pascal":["p","pas"],"text/x-processing":["pde"],"text/x-sass":["sass"],"text/x-scss":["scss"],"text/x-setext":["etx"],"text/x-sfv":["sfv"],"text/x-suse-ymp":["ymp"],"text/x-uuencode":["uu"],"text/x-vcalendar":["vcs"],"text/x-vcard":["vcf"],"video/vnd.dece.hd":["uvh","uvvh"],"video/vnd.dece.mobile":["uvm","uvvm"],"video/vnd.dece.pd":["uvp","uvvp"],"video/vnd.dece.sd":["uvs","uvvs"],"video/vnd.dece.video":["uvv","uvvv"],"video/vnd.dvb.file":["dvb"],"video/vnd.fvt":["fvt"],"video/vnd.mpegurl":["mxu","m4u"],"video/vnd.ms-playready.media.pyv":["pyv"],"video/vnd.uvvu.mp4":["uvu","uvvu"],"video/vnd.vivo":["viv"],"video/x-f4v":["f4v"],"video/x-fli":["fli"],"video/x-flv":["flv"],"video/x-m4v":["m4v"],"video/x-matroska":["mkv","mk3d","mks"],"video/x-mng":["mng"],"video/x-ms-asf":["asf","asx"],"video/x-ms-vob":["vob"],"video/x-ms-wm":["wm"],"video/x-ms-wmv":["wmv"],"video/x-ms-wmx":["wmx"],"video/x-ms-wvx":["wvx"],"video/x-msvideo":["avi"],"video/x-sgi-movie":["movie"],"video/x-smv":["smv"],"x-conference/x-cooltalk":["ice"]};Object.freeze(Ny);var _y=Ny;var Dy={"application/andrew-inset":["ez"],"application/appinstaller":["appinstaller"],"application/applixware":["aw"],"application/appx":["appx"],"application/appxbundle":["appxbundle"],"application/atom+xml":["atom"],"application/atomcat+xml":["atomcat"],"application/atomdeleted+xml":["atomdeleted"],"application/atomsvc+xml":["atomsvc"],"application/atsc-dwd+xml":["dwd"],"application/atsc-held+xml":["held"],"application/atsc-rsat+xml":["rsat"],"application/automationml-aml+xml":["aml"],"application/automationml-amlx+zip":["amlx"],"application/bdoc":["bdoc"],"application/calendar+xml":["xcs"],"application/ccxml+xml":["ccxml"],"application/cdfx+xml":["cdfx"],"application/cdmi-capability":["cdmia"],"application/cdmi-container":["cdmic"],"application/cdmi-domain":["cdmid"],"application/cdmi-object":["cdmio"],"application/cdmi-queue":["cdmiq"],"application/cpl+xml":["cpl"],"application/cu-seeme":["cu"],"application/cwl":["cwl"],"application/dash+xml":["mpd"],"application/dash-patch+xml":["mpp"],"application/davmount+xml":["davmount"],"application/docbook+xml":["dbk"],"application/dssc+der":["dssc"],"application/dssc+xml":["xdssc"],"application/ecmascript":["ecma"],"application/emma+xml":["emma"],"application/emotionml+xml":["emotionml"],"application/epub+zip":["epub"],"application/exi":["exi"],"application/express":["exp"],"application/fdf":["fdf"],"application/fdt+xml":["fdt"],"application/font-tdpfr":["pfr"],"application/geo+json":["geojson"],"application/gml+xml":["gml"],"application/gpx+xml":["gpx"],"application/gxf":["gxf"],"application/gzip":["gz"],"application/hjson":["hjson"],"application/hyperstudio":["stk"],"application/inkml+xml":["ink","inkml"],"application/ipfix":["ipfix"],"application/its+xml":["its"],"application/java-archive":["jar","war","ear"],"application/java-serialized-object":["ser"],"application/java-vm":["class"],"application/javascript":["*js"],"application/json":["json","map"],"application/json5":["json5"],"application/jsonml+json":["jsonml"],"application/ld+json":["jsonld"],"application/lgr+xml":["lgr"],"application/lost+xml":["lostxml"],"application/mac-binhex40":["hqx"],"application/mac-compactpro":["cpt"],"application/mads+xml":["mads"],"application/manifest+json":["webmanifest"],"application/marc":["mrc"],"application/marcxml+xml":["mrcx"],"application/mathematica":["ma","nb","mb"],"application/mathml+xml":["mathml"],"application/mbox":["mbox"],"application/media-policy-dataset+xml":["mpf"],"application/mediaservercontrol+xml":["mscml"],"application/metalink+xml":["metalink"],"application/metalink4+xml":["meta4"],"application/mets+xml":["mets"],"application/mmt-aei+xml":["maei"],"application/mmt-usd+xml":["musd"],"application/mods+xml":["mods"],"application/mp21":["m21","mp21"],"application/mp4":["*mp4","*mpg4","mp4s","m4p"],"application/msix":["msix"],"application/msixbundle":["msixbundle"],"application/msword":["doc","dot"],"application/mxf":["mxf"],"application/n-quads":["nq"],"application/n-triples":["nt"],"application/node":["cjs"],"application/octet-stream":["bin","dms","lrf","mar","so","dist","distz","pkg","bpk","dump","elc","deploy","exe","dll","deb","dmg","iso","img","msi","msp","msm","buffer"],"application/oda":["oda"],"application/oebps-package+xml":["opf"],"application/ogg":["ogx"],"application/omdoc+xml":["omdoc"],"application/onenote":["onetoc","onetoc2","onetmp","onepkg"],"application/oxps":["oxps"],"application/p2p-overlay+xml":["relo"],"application/patch-ops-error+xml":["xer"],"application/pdf":["pdf"],"application/pgp-encrypted":["pgp"],"application/pgp-keys":["asc"],"application/pgp-signature":["sig","*asc"],"application/pics-rules":["prf"],"application/pkcs10":["p10"],"application/pkcs7-mime":["p7m","p7c"],"application/pkcs7-signature":["p7s"],"application/pkcs8":["p8"],"application/pkix-attr-cert":["ac"],"application/pkix-cert":["cer"],"application/pkix-crl":["crl"],"application/pkix-pkipath":["pkipath"],"application/pkixcmp":["pki"],"application/pls+xml":["pls"],"application/postscript":["ai","eps","ps"],"application/provenance+xml":["provx"],"application/pskc+xml":["pskcxml"],"application/raml+yaml":["raml"],"application/rdf+xml":["rdf","owl"],"application/reginfo+xml":["rif"],"application/relax-ng-compact-syntax":["rnc"],"application/resource-lists+xml":["rl"],"application/resource-lists-diff+xml":["rld"],"application/rls-services+xml":["rs"],"application/route-apd+xml":["rapd"],"application/route-s-tsid+xml":["sls"],"application/route-usd+xml":["rusd"],"application/rpki-ghostbusters":["gbr"],"application/rpki-manifest":["mft"],"application/rpki-roa":["roa"],"application/rsd+xml":["rsd"],"application/rss+xml":["rss"],"application/rtf":["rtf"],"application/sbml+xml":["sbml"],"application/scvp-cv-request":["scq"],"application/scvp-cv-response":["scs"],"application/scvp-vp-request":["spq"],"application/scvp-vp-response":["spp"],"application/sdp":["sdp"],"application/senml+xml":["senmlx"],"application/sensml+xml":["sensmlx"],"application/set-payment-initiation":["setpay"],"application/set-registration-initiation":["setreg"],"application/shf+xml":["shf"],"application/sieve":["siv","sieve"],"application/smil+xml":["smi","smil"],"application/sparql-query":["rq"],"application/sparql-results+xml":["srx"],"application/sql":["sql"],"application/srgs":["gram"],"application/srgs+xml":["grxml"],"application/sru+xml":["sru"],"application/ssdl+xml":["ssdl"],"application/ssml+xml":["ssml"],"application/swid+xml":["swidtag"],"application/tei+xml":["tei","teicorpus"],"application/thraud+xml":["tfi"],"application/timestamped-data":["tsd"],"application/toml":["toml"],"application/trig":["trig"],"application/ttml+xml":["ttml"],"application/ubjson":["ubj"],"application/urc-ressheet+xml":["rsheet"],"application/urc-targetdesc+xml":["td"],"application/voicexml+xml":["vxml"],"application/wasm":["wasm"],"application/watcherinfo+xml":["wif"],"application/widget":["wgt"],"application/winhlp":["hlp"],"application/wsdl+xml":["wsdl"],"application/wspolicy+xml":["wspolicy"],"application/xaml+xml":["xaml"],"application/xcap-att+xml":["xav"],"application/xcap-caps+xml":["xca"],"application/xcap-diff+xml":["xdf"],"application/xcap-el+xml":["xel"],"application/xcap-ns+xml":["xns"],"application/xenc+xml":["xenc"],"application/xfdf":["xfdf"],"application/xhtml+xml":["xhtml","xht"],"application/xliff+xml":["xlf"],"application/xml":["xml","xsl","xsd","rng"],"application/xml-dtd":["dtd"],"application/xop+xml":["xop"],"application/xproc+xml":["xpl"],"application/xslt+xml":["*xsl","xslt"],"application/xspf+xml":["xspf"],"application/xv+xml":["mxml","xhvml","xvml","xvm"],"application/yang":["yang"],"application/yin+xml":["yin"],"application/zip":["zip"],"audio/3gpp":["*3gpp"],"audio/aac":["adts","aac"],"audio/adpcm":["adp"],"audio/amr":["amr"],"audio/basic":["au","snd"],"audio/midi":["mid","midi","kar","rmi"],"audio/mobile-xmf":["mxmf"],"audio/mp3":["*mp3"],"audio/mp4":["m4a","mp4a"],"audio/mpeg":["mpga","mp2","mp2a","mp3","m2a","m3a"],"audio/ogg":["oga","ogg","spx","opus"],"audio/s3m":["s3m"],"audio/silk":["sil"],"audio/wav":["wav"],"audio/wave":["*wav"],"audio/webm":["weba"],"audio/xm":["xm"],"font/collection":["ttc"],"font/otf":["otf"],"font/ttf":["ttf"],"font/woff":["woff"],"font/woff2":["woff2"],"image/aces":["exr"],"image/apng":["apng"],"image/avci":["avci"],"image/avcs":["avcs"],"image/avif":["avif"],"image/bmp":["bmp","dib"],"image/cgm":["cgm"],"image/dicom-rle":["drle"],"image/dpx":["dpx"],"image/emf":["emf"],"image/fits":["fits"],"image/g3fax":["g3"],"image/gif":["gif"],"image/heic":["heic"],"image/heic-sequence":["heics"],"image/heif":["heif"],"image/heif-sequence":["heifs"],"image/hej2k":["hej2"],"image/hsj2":["hsj2"],"image/ief":["ief"],"image/jls":["jls"],"image/jp2":["jp2","jpg2"],"image/jpeg":["jpeg","jpg","jpe"],"image/jph":["jph"],"image/jphc":["jhc"],"image/jpm":["jpm","jpgm"],"image/jpx":["jpx","jpf"],"image/jxr":["jxr"],"image/jxra":["jxra"],"image/jxrs":["jxrs"],"image/jxs":["jxs"],"image/jxsc":["jxsc"],"image/jxsi":["jxsi"],"image/jxss":["jxss"],"image/ktx":["ktx"],"image/ktx2":["ktx2"],"image/png":["png"],"image/sgi":["sgi"],"image/svg+xml":["svg","svgz"],"image/t38":["t38"],"image/tiff":["tif","tiff"],"image/tiff-fx":["tfx"],"image/webp":["webp"],"image/wmf":["wmf"],"message/disposition-notification":["disposition-notification"],"message/global":["u8msg"],"message/global-delivery-status":["u8dsn"],"message/global-disposition-notification":["u8mdn"],"message/global-headers":["u8hdr"],"message/rfc822":["eml","mime"],"model/3mf":["3mf"],"model/gltf+json":["gltf"],"model/gltf-binary":["glb"],"model/iges":["igs","iges"],"model/jt":["jt"],"model/mesh":["msh","mesh","silo"],"model/mtl":["mtl"],"model/obj":["obj"],"model/prc":["prc"],"model/step+xml":["stpx"],"model/step+zip":["stpz"],"model/step-xml+zip":["stpxz"],"model/stl":["stl"],"model/u3d":["u3d"],"model/vrml":["wrl","vrml"],"model/x3d+binary":["*x3db","x3dbz"],"model/x3d+fastinfoset":["x3db"],"model/x3d+vrml":["*x3dv","x3dvz"],"model/x3d+xml":["x3d","x3dz"],"model/x3d-vrml":["x3dv"],"text/cache-manifest":["appcache","manifest"],"text/calendar":["ics","ifb"],"text/coffeescript":["coffee","litcoffee"],"text/css":["css"],"text/csv":["csv"],"text/html":["html","htm","shtml"],"text/jade":["jade"],"text/javascript":["js","mjs"],"text/jsx":["jsx"],"text/less":["less"],"text/markdown":["md","markdown"],"text/mathml":["mml"],"text/mdx":["mdx"],"text/n3":["n3"],"text/plain":["txt","text","conf","def","list","log","in","ini"],"text/richtext":["rtx"],"text/rtf":["*rtf"],"text/sgml":["sgml","sgm"],"text/shex":["shex"],"text/slim":["slim","slm"],"text/spdx":["spdx"],"text/stylus":["stylus","styl"],"text/tab-separated-values":["tsv"],"text/troff":["t","tr","roff","man","me","ms"],"text/turtle":["ttl"],"text/uri-list":["uri","uris","urls"],"text/vcard":["vcard"],"text/vtt":["vtt"],"text/wgsl":["wgsl"],"text/xml":["*xml"],"text/yaml":["yaml","yml"],"video/3gpp":["3gp","3gpp"],"video/3gpp2":["3g2"],"video/h261":["h261"],"video/h263":["h263"],"video/h264":["h264"],"video/iso.segment":["m4s"],"video/jpeg":["jpgv"],"video/jpm":["*jpm","*jpgm"],"video/mj2":["mj2","mjp2"],"video/mp2t":["ts"],"video/mp4":["mp4","mp4v","mpg4"],"video/mpeg":["mpeg","mpg","mpe","m1v","m2v"],"video/ogg":["ogv"],"video/quicktime":["qt","mov"],"video/webm":["webm"]};Object.freeze(Dy);var Fy=Dy;var tn=function(n,e,t,r){if(t==="a"&&!r)throw new TypeError("Private accessor was defined without a getter");if(typeof e=="function"?n!==e||!r:!e.has(n))throw new TypeError("Cannot read private member from an object whose class did not declare it");return t==="m"?r:t==="a"?r.call(n):r?r.value:e.get(n)},si,Ea,Kr,Jd=class{constructor(...e){si.set(this,new Map),Ea.set(this,new Map),Kr.set(this,new Map);for(let t of e)this.define(t)}define(e,t=!1){for(let[r,o]of Object.entries(e)){r=r.toLowerCase(),o=o.map(s=>s.toLowerCase()),tn(this,Kr,"f").has(r)||tn(this,Kr,"f").set(r,new Set);let i=tn(this,Kr,"f").get(r),a=!0;for(let s of o){let l=s.startsWith("*");if(s=l?s.slice(1):s,i?.add(s),a&&tn(this,Ea,"f").set(r,s),a=!1,l)continue;let c=tn(this,si,"f").get(s);if(c&&c!=r&&!t)throw new Error(`"${r} -> ${s}" conflicts with "${c} -> ${s}". Pass \`force=true\` to override this definition.`);tn(this,si,"f").set(s,r)}}return this}getType(e){if(typeof e!="string")return null;let t=e.replace(/^.*[/\\]/,"").toLowerCase(),r=t.replace(/^.*\./,"").toLowerCase(),o=t.length<e.length;return!(r.length<t.length-1)&&o?null:tn(this,si,"f").get(r)??null}getExtension(e){return typeof e!="string"?null:(e=e?.split?.(";")[0],(e&&tn(this,Ea,"f").get(e.trim().toLowerCase()))??null)}getAllExtensions(e){return typeof e!="string"?null:tn(this,Kr,"f").get(e.toLowerCase())??null}_freeze(){this.define=()=>{throw new Error("define() not allowed for built-in Mime objects. See https://github.com/broofa/mime/blob/main/README.md#custom-mime-instances")},Object.freeze(this);for(let e of tn(this,Kr,"f").values())Object.freeze(e);return this}_getTestState(){return{types:tn(this,si,"f"),extensions:tn(this,Ea,"f")}}};si=new WeakMap,Ea=new WeakMap,Kr=new WeakMap;var Xd=Jd;var Uy=new Xd(Fy,_y)._freeze();import{homedir as vp,hostname as qO,platform as KO}from"os";import{basename as YO,extname as JO,join as di,resolve as XO}from"path";import{chromium as Hb,devices as ZO}from"playwright";import{addExtra as QO}from"playwright-extra";import ek from"puppeteer-extra-plugin-recaptcha";import{v4 as tk}from"uuid";import{rmSync as xb}from"fs";import{basename as gO,join as fO}from"path";import{errors as SO}from"playwright-core";var $n={bannedClassSubstrings:["relative","flex","center","justify","auto","sticky","absolute","top","right","left","bottom","items-center","notion-selectable","notion-page-block","notion-collection-item","MuiSvgIcon","css-","rt-"],nonDynamicInputTypes:["button","file","hidden","image","radio","reset","submit"],generalStateAttributes:["aria-expanded","aria-haspopup","aria-checked","aria-pressed","aria-selected","aria-invalid","checked","open","aria-busy"],bannedElementTagNames:["html","head","meta","script","style","path","br","::marker","noscript","polygon","defs"],bannedElementAttributes:["data-momentic-id","aria-keyshortcuts","data-ved","aria-controls","d"],relevantElementAttributes:["name","id","value","type","class","height","width","target","title","href","src","alt","role","headers","scope","checked","required","action","tooltip","min","max","minlength","maxlength","multiple","pattern","placeholder","accept","contenteditable","data-value","data-testid","data-cy","data-pw","data-test-id","data-test","data-role","data-type","data-key","data-action","data-aria-hidden","data-hidden","data-automation-id","data-content-editable-leaf","data-wf-icon","data-tns","data-handleid","data-handlepos","data-col-index","data-row-index","data-row","data-col","col-index","row-index","row","col","data-momentic-description","aria-label","aria-role","aria-selected","aria-disabled","aria-hidden","aria-describedby","aria-valuenow","aria-valuemin","aria-valuemax"],alwaysUsefulAttributesForCssSelectorGeneration:["src","href","aria-describedby","aria-labelledby","aria-label"],alwaysInterestingClassNames:["cm-line","cm-activeLine","cm-content"],alwaysInterestingClassPrefixes:["notion-",".w-"],alwaysInterestingTruthyPropertyNames:["contenteditable"],visualAttributesForSvgSerialization:["fill","stroke","color","patternContentUnits","xlink:href","transform","path","d","points","viewBox","preserveAspectRatio","r","rx","ry","cx","cy","x1","y1","x2","y2","font","text-anchor","dominant-baseline","gradient","pattern","stop-color"]};var gL=new Set(["b","c","d","f","g","h","j","k","l","m","n","p","q","r","s","t","v","w","x","y","z"]),fL=new Set(["a","e","i","o","u","y"]);function By(n){if(n.length>75)return!1;if(n[0]?.match(/[0-9a-zA-Z]/)===null)return!0;if(n.length>10){let m=Math.floor(n.length/8);if((n.match(/[-_:A-Z/ ]/g)??[]).length<m)return!0}if((n.match(/[^0-9a-zA-Z-_.]/g)??[]).length/n.length>.2)return!0;let t=(n.match(/[0-9]/g)??[]).length;if(t/n.length>.3)return!0;let r=(n.toLowerCase().match(/[aeiou]/gi)??[]).length;if((n.toLowerCase().match(/[bcdfghjklmnpqrstvwxyz]/gi)??[]).length/r>5)return!0;let i=0,a=0;for(let m of n.toLowerCase())gL.has(m)?(a++,a>i&&(i=a)):a=0;if(i>4)return!0;let s=0,l=0;for(let m of n.toLowerCase())m>="a"&&m<="z"&&!fL.has(m)?(l++,l>s&&(s=l)):l=0;if(s>4)return!0;let c=(n.match(/[A-Z]/g)??[]).length,d=(n.match(/[a-z]/g)??[]).length,p=Math.ceil(n.length*.3);return!!(d&&t&&Math.abs(d-t)<p||d&&c&&Math.abs(d-c)<p)}function zy(n,e,t){if(n.length<t)return n;let r=n.indexOf(e);if(r===-1)return n;let o=Math.max(0,r-t/3),i=Math.min(r+t/3,n.length),a=n.indexOf(`
3589
+ `,cssGeneratorLibJs:'// Taken from https://cdn.jsdelivr.net/npm/css-selector-generator@3.6.8/build/index.min.js\n!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.CssSelectorGenerator=e():t.CssSelectorGenerator=e()}(self,(()=>(()=>{"use strict";var t={d:(e,n)=>{for(var o in n)t.o(n,o)&&!t.o(e,o)&&Object.defineProperty(e,o,{enumerable:!0,get:n[o]})},o:(t,e)=>Object.prototype.hasOwnProperty.call(t,e),r:t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})}},e={};function n(t){return"object"==typeof t&&null!==t&&t.nodeType===Node.ELEMENT_NODE}t.r(e),t.d(e,{default:()=>K,getCssSelector:()=>J});const o={NONE:"",DESCENDANT:" ",CHILD:" > "},r={id:"id",class:"class",tag:"tag",attribute:"attribute",nthchild:"nthchild",nthoftype:"nthoftype"},i="CssSelectorGenerator";function c(t="unknown problem",...e){console.warn(`${i}: ${t}`,...e)}const u={selectors:[r.id,r.class,r.tag,r.attribute],includeTag:!1,whitelist:[],blacklist:[],combineWithinSelector:!0,combineBetweenSelectors:!0,root:null,maxCombinations:Number.POSITIVE_INFINITY,maxCandidates:Number.POSITIVE_INFINITY};function s(t){return t instanceof RegExp}function a(t){return["string","function"].includes(typeof t)||s(t)}function l(t){return Array.isArray(t)?t.filter(a):[]}function f(t){const e=[Node.DOCUMENT_NODE,Node.DOCUMENT_FRAGMENT_NODE,Node.ELEMENT_NODE];return function(t){return t instanceof Node}(t)&&e.includes(t.nodeType)}function d(t,e){if(f(t))return t.contains(e)||c("element root mismatch","Provided root does not contain the element. This will most likely result in producing a fallback selector using element\'s real root node. If you plan to use the selector using provided root (e.g. `root.querySelector`), it will nto work as intended."),t;const n=e.getRootNode({composed:!1});return f(n)?(n!==document&&c("shadow root inferred","You did not provide a root and the element is a child of Shadow DOM. This will produce a selector using ShadowRoot as a root. If you plan to use the selector using document as a root (e.g. `document.querySelector`), it will not work as intended."),n):e.ownerDocument.querySelector(":root")}function m(t){return"number"==typeof t?t:Number.POSITIVE_INFINITY}function p(t=[]){const[e=[],...n]=t;return 0===n.length?e:n.reduce(((t,e)=>t.filter((t=>e.includes(t)))),e)}function h(t){return[].concat(...t)}function g(t){const e=t.map((t=>{if(s(t))return e=>t.test(e);if("function"==typeof t)return e=>{const n=t(e);return"boolean"!=typeof n?(c("pattern matcher function invalid","Provided pattern matching function does not return boolean. It\'s result will be ignored.",t),!1):n};if("string"==typeof t){const e=new RegExp("^"+t.replace(/[|\\\\{}()[\\]^$+?.]/g,"\\\\$&").replace(/\\*/g,".+")+"$");return t=>e.test(t)}return c("pattern matcher invalid","Pattern matching only accepts strings, regular expressions and/or functions. This item is invalid and will be ignored.",t),()=>!1}));return t=>e.some((e=>e(t)))}function y(t,e,n){const o=Array.from(d(n,t[0]).querySelectorAll(e));return o.length===t.length&&t.every((t=>o.includes(t)))}function b(t,e){e=null!=e?e:function(t){return t.ownerDocument.querySelector(":root")}(t);const o=[];let r=t;for(;n(r)&&r!==e;)o.push(r),r=r.parentElement;return o}function N(t,e){return p(t.map((t=>b(t,e))))}const S=", ",E=new RegExp(["^$","\\\\s"].join("|")),w=new RegExp(["^$"].join("|")),I=[r.nthoftype,r.tag,r.id,r.class,r.attribute,r.nthchild],v=g(["class","id","ng-*"]);function T({name:t}){return`[${t}]`}function C({name:t,value:e}){return`[${t}=\'${e}\']`}function O({nodeName:t,nodeValue:e}){return{name:V(t),value:V(e)}}function x(t){const e=Array.from(t.attributes).filter((e=>function({nodeName:t},e){const n=e.tagName.toLowerCase();return!(["input","option"].includes(n)&&"value"===t||v(t))}(e,t))).map(O);return[...e.map(T),...e.map(C)]}function j(t){return(t.getAttribute("class")||"").trim().split(/\\s+/).filter((t=>!w.test(t))).map((t=>`.${V(t)}`))}function A(t){const e=t.getAttribute("id")||"",n=`#${V(e)}`,o=t.getRootNode({composed:!1});return!E.test(e)&&y([t],n,o)?[n]:[]}function $(t){const e=t.parentNode;if(e){const o=Array.from(e.childNodes).filter(n).indexOf(t);if(o>-1)return[`:nth-child(${o+1})`]}return[]}function D(t){return[V(t.tagName.toLowerCase())]}function R(t){const e=[...new Set(h(t.map(D)))];return 0===e.length||e.length>1?[]:[e[0]]}function P(t){const e=R([t])[0],n=t.parentElement;if(n){const o=Array.from(n.children).filter((t=>t.tagName.toLowerCase()===e)),r=o.indexOf(t);if(r>-1)return[`${e}:nth-of-type(${r+1})`]}return[]}function _(t=[],{maxResults:e=Number.POSITIVE_INFINITY}={}){return Array.from(function*(t=[],{maxResults:e=Number.POSITIVE_INFINITY}={}){let n=0,o=L(1);for(;o.length<=t.length&&n<e;){n+=1;const e=o.map((e=>t[e]));yield e,o=k(o,t.length-1)}}(t,{maxResults:e}))}function k(t=[],e=0){const n=t.length;if(0===n)return[];const o=[...t];o[n-1]+=1;for(let t=n-1;t>=0;t--)if(o[t]>e){if(0===t)return L(n+1);o[t-1]++,o[t]=o[t-1]+1}return o[n-1]>e?L(n+1):o}function L(t=1){return Array.from(Array(t).keys())}const M=":".charCodeAt(0).toString(16).toUpperCase(),F=/[ !"#$%&\'()\\[\\]{|}<>*+,./;=?@^`~\\\\]/;function V(t=""){var e,n;return null!==(n=null===(e=null===CSS||void 0===CSS?void 0:CSS.escape)||void 0===e?void 0:e.call(CSS,t))&&void 0!==n?n:function(t=""){return t.split("").map((t=>":"===t?`\\\\${M} `:F.test(t)?`\\\\${t}`:escape(t).replace(/%/g,"\\\\"))).join("")}(t)}const Y={tag:R,id:function(t){return 0===t.length||t.length>1?[]:A(t[0])},class:function(t){return p(t.map(j))},attribute:function(t){return p(t.map(x))},nthchild:function(t){return p(t.map($))},nthoftype:function(t){return p(t.map(P))}},q={tag:D,id:A,class:j,attribute:x,nthchild:$,nthoftype:P};function B(t){return t.includes(r.tag)||t.includes(r.nthoftype)?[...t]:[...t,r.tag]}function G(t={}){const e=[...I];return t[r.tag]&&t[r.nthoftype]&&e.splice(e.indexOf(r.tag),1),e.map((e=>{return(o=t)[n=e]?o[n].join(""):"";var n,o})).join("")}function H(t,e,n="",r){const i=function(t,e){return""===e?t:function(t,e){return[...t.map((t=>e+o.DESCENDANT+t)),...t.map((t=>e+o.CHILD+t))]}(t,e)}(function(t,e,n){const o=function(t,e){const{blacklist:n,whitelist:o,combineWithinSelector:r,maxCombinations:i}=e,c=g(n),u=g(o);return function(t){const{selectors:e,includeTag:n}=t,o=[].concat(e);return n&&!o.includes("tag")&&o.push("tag"),o}(e).reduce(((e,n)=>{const o=function(t,e){var n;return(null!==(n=Y[e])&&void 0!==n?n:()=>[])(t)}(t,n),s=function(t=[],e,n){return t.filter((t=>n(t)||!e(t)))}(o,c,u),a=function(t=[],e){return t.sort(((t,n)=>{const o=e(t),r=e(n);return o&&!r?-1:!o&&r?1:0}))}(s,u);return e[n]=r?_(a,{maxResults:i}):a.map((t=>[t])),e}),{})}(t,n),r=function(t,e){return function(t){const{selectors:e,combineBetweenSelectors:n,includeTag:o,maxCandidates:r}=t,i=n?_(e,{maxResults:r}):e.map((t=>[t]));return o?i.map(B):i}(e).map((e=>function(t,e){const n={};return t.forEach((t=>{const o=e[t];o.length>0&&(n[t]=o)})),function(t={}){let e=[];return Object.entries(t).forEach((([t,n])=>{e=n.flatMap((n=>0===e.length?[{[t]:n}]:e.map((e=>Object.assign(Object.assign({},e),{[t]:n})))))})),e}(n).map(G)}(e,t))).filter((t=>t.length>0))}(o,n),i=h(r);return[...new Set(i)]}(t,r.root,r),n);for(const e of i)if(y(t,e,r.root))return e;return null}function W(t){return{value:t,include:!1}}function U({selectors:t,operator:e}){let n=[...I];t[r.tag]&&t[r.nthoftype]&&(n=n.filter((t=>t!==r.tag)));let o="";return n.forEach((e=>{(t[e]||[]).forEach((({value:t,include:e})=>{e&&(o+=t)}))})),e+o}function z(t){return[":root",...b(t).reverse().map((t=>{const e=function(t,e,n=o.NONE){const r={};return e.forEach((e=>{Reflect.set(r,e,function(t,e){return q[e](t)}(t,e).map(W))})),{element:t,operator:n,selectors:r}}(t,[r.nthchild],o.CHILD);return e.selectors.nthchild.forEach((t=>{t.include=!0})),e})).map(U)].join("")}function J(t,e={}){const o=function(t){(t instanceof NodeList||t instanceof HTMLCollection)&&(t=Array.from(t));const e=(Array.isArray(t)?t:[t]).filter(n);return[...new Set(e)]}(t),i=function(t,e={}){const n=Object.assign(Object.assign({},u),e);return{selectors:(o=n.selectors,Array.isArray(o)?o.filter((t=>{return e=r,n=t,Object.values(e).includes(n);var e,n})):[]),whitelist:l(n.whitelist),blacklist:l(n.blacklist),root:d(n.root,t),combineWithinSelector:!!n.combineWithinSelector,combineBetweenSelectors:!!n.combineBetweenSelectors,includeTag:!!n.includeTag,maxCombinations:m(n.maxCombinations),maxCandidates:m(n.maxCandidates)};var o}(o[0],e);let c="",s=i.root;function a(){return function(t,e,n="",o){if(0===t.length)return null;const r=[t.length>1?t:[],...N(t,e).map((t=>[t]))];for(const t of r){const e=H(t,0,n,o);if(e)return{foundElements:t,selector:e}}return null}(o,s,c,i)}let f=a();for(;f;){const{foundElements:t,selector:e}=f;if(y(o,e,i.root))return e;s=t[0],c=e,f=a()}return o.length>1?o.map((t=>J(t,i))).join(S):function(t){return t.map(z).join(S)}(o)}const K=J;return e})()));'};import{execSync as jO}from"child_process";import{randomUUID as Fb}from"crypto";import{existsSync as El,mkdirSync as $O,readFileSync as GO,writeFileSync as WO}from"fs";import{Jimp as Ub}from"jimp";import VO from"js-beautify";import{cloneDeep as Bb}from"lodash-es";var Ny={"application/prs.cww":["cww"],"application/prs.xsf+xml":["xsf"],"application/vnd.1000minds.decision-model+xml":["1km"],"application/vnd.3gpp.pic-bw-large":["plb"],"application/vnd.3gpp.pic-bw-small":["psb"],"application/vnd.3gpp.pic-bw-var":["pvb"],"application/vnd.3gpp2.tcap":["tcap"],"application/vnd.3m.post-it-notes":["pwn"],"application/vnd.accpac.simply.aso":["aso"],"application/vnd.accpac.simply.imp":["imp"],"application/vnd.acucobol":["acu"],"application/vnd.acucorp":["atc","acutc"],"application/vnd.adobe.air-application-installer-package+zip":["air"],"application/vnd.adobe.formscentral.fcdt":["fcdt"],"application/vnd.adobe.fxp":["fxp","fxpl"],"application/vnd.adobe.xdp+xml":["xdp"],"application/vnd.adobe.xfdf":["*xfdf"],"application/vnd.age":["age"],"application/vnd.ahead.space":["ahead"],"application/vnd.airzip.filesecure.azf":["azf"],"application/vnd.airzip.filesecure.azs":["azs"],"application/vnd.amazon.ebook":["azw"],"application/vnd.americandynamics.acc":["acc"],"application/vnd.amiga.ami":["ami"],"application/vnd.android.package-archive":["apk"],"application/vnd.anser-web-certificate-issue-initiation":["cii"],"application/vnd.anser-web-funds-transfer-initiation":["fti"],"application/vnd.antix.game-component":["atx"],"application/vnd.apple.installer+xml":["mpkg"],"application/vnd.apple.keynote":["key"],"application/vnd.apple.mpegurl":["m3u8"],"application/vnd.apple.numbers":["numbers"],"application/vnd.apple.pages":["pages"],"application/vnd.apple.pkpass":["pkpass"],"application/vnd.aristanetworks.swi":["swi"],"application/vnd.astraea-software.iota":["iota"],"application/vnd.audiograph":["aep"],"application/vnd.balsamiq.bmml+xml":["bmml"],"application/vnd.blueice.multipass":["mpm"],"application/vnd.bmi":["bmi"],"application/vnd.businessobjects":["rep"],"application/vnd.chemdraw+xml":["cdxml"],"application/vnd.chipnuts.karaoke-mmd":["mmd"],"application/vnd.cinderella":["cdy"],"application/vnd.citationstyles.style+xml":["csl"],"application/vnd.claymore":["cla"],"application/vnd.cloanto.rp9":["rp9"],"application/vnd.clonk.c4group":["c4g","c4d","c4f","c4p","c4u"],"application/vnd.cluetrust.cartomobile-config":["c11amc"],"application/vnd.cluetrust.cartomobile-config-pkg":["c11amz"],"application/vnd.commonspace":["csp"],"application/vnd.contact.cmsg":["cdbcmsg"],"application/vnd.cosmocaller":["cmc"],"application/vnd.crick.clicker":["clkx"],"application/vnd.crick.clicker.keyboard":["clkk"],"application/vnd.crick.clicker.palette":["clkp"],"application/vnd.crick.clicker.template":["clkt"],"application/vnd.crick.clicker.wordbank":["clkw"],"application/vnd.criticaltools.wbs+xml":["wbs"],"application/vnd.ctc-posml":["pml"],"application/vnd.cups-ppd":["ppd"],"application/vnd.curl.car":["car"],"application/vnd.curl.pcurl":["pcurl"],"application/vnd.dart":["dart"],"application/vnd.data-vision.rdz":["rdz"],"application/vnd.dbf":["dbf"],"application/vnd.dece.data":["uvf","uvvf","uvd","uvvd"],"application/vnd.dece.ttml+xml":["uvt","uvvt"],"application/vnd.dece.unspecified":["uvx","uvvx"],"application/vnd.dece.zip":["uvz","uvvz"],"application/vnd.denovo.fcselayout-link":["fe_launch"],"application/vnd.dna":["dna"],"application/vnd.dolby.mlp":["mlp"],"application/vnd.dpgraph":["dpg"],"application/vnd.dreamfactory":["dfac"],"application/vnd.ds-keypoint":["kpxx"],"application/vnd.dvb.ait":["ait"],"application/vnd.dvb.service":["svc"],"application/vnd.dynageo":["geo"],"application/vnd.ecowin.chart":["mag"],"application/vnd.enliven":["nml"],"application/vnd.epson.esf":["esf"],"application/vnd.epson.msf":["msf"],"application/vnd.epson.quickanime":["qam"],"application/vnd.epson.salt":["slt"],"application/vnd.epson.ssf":["ssf"],"application/vnd.eszigno3+xml":["es3","et3"],"application/vnd.ezpix-album":["ez2"],"application/vnd.ezpix-package":["ez3"],"application/vnd.fdf":["*fdf"],"application/vnd.fdsn.mseed":["mseed"],"application/vnd.fdsn.seed":["seed","dataless"],"application/vnd.flographit":["gph"],"application/vnd.fluxtime.clip":["ftc"],"application/vnd.framemaker":["fm","frame","maker","book"],"application/vnd.frogans.fnc":["fnc"],"application/vnd.frogans.ltf":["ltf"],"application/vnd.fsc.weblaunch":["fsc"],"application/vnd.fujitsu.oasys":["oas"],"application/vnd.fujitsu.oasys2":["oa2"],"application/vnd.fujitsu.oasys3":["oa3"],"application/vnd.fujitsu.oasysgp":["fg5"],"application/vnd.fujitsu.oasysprs":["bh2"],"application/vnd.fujixerox.ddd":["ddd"],"application/vnd.fujixerox.docuworks":["xdw"],"application/vnd.fujixerox.docuworks.binder":["xbd"],"application/vnd.fuzzysheet":["fzs"],"application/vnd.genomatix.tuxedo":["txd"],"application/vnd.geogebra.file":["ggb"],"application/vnd.geogebra.tool":["ggt"],"application/vnd.geometry-explorer":["gex","gre"],"application/vnd.geonext":["gxt"],"application/vnd.geoplan":["g2w"],"application/vnd.geospace":["g3w"],"application/vnd.gmx":["gmx"],"application/vnd.google-apps.document":["gdoc"],"application/vnd.google-apps.presentation":["gslides"],"application/vnd.google-apps.spreadsheet":["gsheet"],"application/vnd.google-earth.kml+xml":["kml"],"application/vnd.google-earth.kmz":["kmz"],"application/vnd.grafeq":["gqf","gqs"],"application/vnd.groove-account":["gac"],"application/vnd.groove-help":["ghf"],"application/vnd.groove-identity-message":["gim"],"application/vnd.groove-injector":["grv"],"application/vnd.groove-tool-message":["gtm"],"application/vnd.groove-tool-template":["tpl"],"application/vnd.groove-vcard":["vcg"],"application/vnd.hal+xml":["hal"],"application/vnd.handheld-entertainment+xml":["zmm"],"application/vnd.hbci":["hbci"],"application/vnd.hhe.lesson-player":["les"],"application/vnd.hp-hpgl":["hpgl"],"application/vnd.hp-hpid":["hpid"],"application/vnd.hp-hps":["hps"],"application/vnd.hp-jlyt":["jlt"],"application/vnd.hp-pcl":["pcl"],"application/vnd.hp-pclxl":["pclxl"],"application/vnd.hydrostatix.sof-data":["sfd-hdstx"],"application/vnd.ibm.minipay":["mpy"],"application/vnd.ibm.modcap":["afp","listafp","list3820"],"application/vnd.ibm.rights-management":["irm"],"application/vnd.ibm.secure-container":["sc"],"application/vnd.iccprofile":["icc","icm"],"application/vnd.igloader":["igl"],"application/vnd.immervision-ivp":["ivp"],"application/vnd.immervision-ivu":["ivu"],"application/vnd.insors.igm":["igm"],"application/vnd.intercon.formnet":["xpw","xpx"],"application/vnd.intergeo":["i2g"],"application/vnd.intu.qbo":["qbo"],"application/vnd.intu.qfx":["qfx"],"application/vnd.ipunplugged.rcprofile":["rcprofile"],"application/vnd.irepository.package+xml":["irp"],"application/vnd.is-xpr":["xpr"],"application/vnd.isac.fcs":["fcs"],"application/vnd.jam":["jam"],"application/vnd.jcp.javame.midlet-rms":["rms"],"application/vnd.jisp":["jisp"],"application/vnd.joost.joda-archive":["joda"],"application/vnd.kahootz":["ktz","ktr"],"application/vnd.kde.karbon":["karbon"],"application/vnd.kde.kchart":["chrt"],"application/vnd.kde.kformula":["kfo"],"application/vnd.kde.kivio":["flw"],"application/vnd.kde.kontour":["kon"],"application/vnd.kde.kpresenter":["kpr","kpt"],"application/vnd.kde.kspread":["ksp"],"application/vnd.kde.kword":["kwd","kwt"],"application/vnd.kenameaapp":["htke"],"application/vnd.kidspiration":["kia"],"application/vnd.kinar":["kne","knp"],"application/vnd.koan":["skp","skd","skt","skm"],"application/vnd.kodak-descriptor":["sse"],"application/vnd.las.las+xml":["lasxml"],"application/vnd.llamagraphics.life-balance.desktop":["lbd"],"application/vnd.llamagraphics.life-balance.exchange+xml":["lbe"],"application/vnd.lotus-1-2-3":["123"],"application/vnd.lotus-approach":["apr"],"application/vnd.lotus-freelance":["pre"],"application/vnd.lotus-notes":["nsf"],"application/vnd.lotus-organizer":["org"],"application/vnd.lotus-screencam":["scm"],"application/vnd.lotus-wordpro":["lwp"],"application/vnd.macports.portpkg":["portpkg"],"application/vnd.mapbox-vector-tile":["mvt"],"application/vnd.mcd":["mcd"],"application/vnd.medcalcdata":["mc1"],"application/vnd.mediastation.cdkey":["cdkey"],"application/vnd.mfer":["mwf"],"application/vnd.mfmp":["mfm"],"application/vnd.micrografx.flo":["flo"],"application/vnd.micrografx.igx":["igx"],"application/vnd.mif":["mif"],"application/vnd.mobius.daf":["daf"],"application/vnd.mobius.dis":["dis"],"application/vnd.mobius.mbk":["mbk"],"application/vnd.mobius.mqy":["mqy"],"application/vnd.mobius.msl":["msl"],"application/vnd.mobius.plc":["plc"],"application/vnd.mobius.txf":["txf"],"application/vnd.mophun.application":["mpn"],"application/vnd.mophun.certificate":["mpc"],"application/vnd.mozilla.xul+xml":["xul"],"application/vnd.ms-artgalry":["cil"],"application/vnd.ms-cab-compressed":["cab"],"application/vnd.ms-excel":["xls","xlm","xla","xlc","xlt","xlw"],"application/vnd.ms-excel.addin.macroenabled.12":["xlam"],"application/vnd.ms-excel.sheet.binary.macroenabled.12":["xlsb"],"application/vnd.ms-excel.sheet.macroenabled.12":["xlsm"],"application/vnd.ms-excel.template.macroenabled.12":["xltm"],"application/vnd.ms-fontobject":["eot"],"application/vnd.ms-htmlhelp":["chm"],"application/vnd.ms-ims":["ims"],"application/vnd.ms-lrm":["lrm"],"application/vnd.ms-officetheme":["thmx"],"application/vnd.ms-outlook":["msg"],"application/vnd.ms-pki.seccat":["cat"],"application/vnd.ms-pki.stl":["*stl"],"application/vnd.ms-powerpoint":["ppt","pps","pot"],"application/vnd.ms-powerpoint.addin.macroenabled.12":["ppam"],"application/vnd.ms-powerpoint.presentation.macroenabled.12":["pptm"],"application/vnd.ms-powerpoint.slide.macroenabled.12":["sldm"],"application/vnd.ms-powerpoint.slideshow.macroenabled.12":["ppsm"],"application/vnd.ms-powerpoint.template.macroenabled.12":["potm"],"application/vnd.ms-project":["*mpp","mpt"],"application/vnd.ms-word.document.macroenabled.12":["docm"],"application/vnd.ms-word.template.macroenabled.12":["dotm"],"application/vnd.ms-works":["wps","wks","wcm","wdb"],"application/vnd.ms-wpl":["wpl"],"application/vnd.ms-xpsdocument":["xps"],"application/vnd.mseq":["mseq"],"application/vnd.musician":["mus"],"application/vnd.muvee.style":["msty"],"application/vnd.mynfc":["taglet"],"application/vnd.neurolanguage.nlu":["nlu"],"application/vnd.nitf":["ntf","nitf"],"application/vnd.noblenet-directory":["nnd"],"application/vnd.noblenet-sealer":["nns"],"application/vnd.noblenet-web":["nnw"],"application/vnd.nokia.n-gage.ac+xml":["*ac"],"application/vnd.nokia.n-gage.data":["ngdat"],"application/vnd.nokia.n-gage.symbian.install":["n-gage"],"application/vnd.nokia.radio-preset":["rpst"],"application/vnd.nokia.radio-presets":["rpss"],"application/vnd.novadigm.edm":["edm"],"application/vnd.novadigm.edx":["edx"],"application/vnd.novadigm.ext":["ext"],"application/vnd.oasis.opendocument.chart":["odc"],"application/vnd.oasis.opendocument.chart-template":["otc"],"application/vnd.oasis.opendocument.database":["odb"],"application/vnd.oasis.opendocument.formula":["odf"],"application/vnd.oasis.opendocument.formula-template":["odft"],"application/vnd.oasis.opendocument.graphics":["odg"],"application/vnd.oasis.opendocument.graphics-template":["otg"],"application/vnd.oasis.opendocument.image":["odi"],"application/vnd.oasis.opendocument.image-template":["oti"],"application/vnd.oasis.opendocument.presentation":["odp"],"application/vnd.oasis.opendocument.presentation-template":["otp"],"application/vnd.oasis.opendocument.spreadsheet":["ods"],"application/vnd.oasis.opendocument.spreadsheet-template":["ots"],"application/vnd.oasis.opendocument.text":["odt"],"application/vnd.oasis.opendocument.text-master":["odm"],"application/vnd.oasis.opendocument.text-template":["ott"],"application/vnd.oasis.opendocument.text-web":["oth"],"application/vnd.olpc-sugar":["xo"],"application/vnd.oma.dd2+xml":["dd2"],"application/vnd.openblox.game+xml":["obgx"],"application/vnd.openofficeorg.extension":["oxt"],"application/vnd.openstreetmap.data+xml":["osm"],"application/vnd.openxmlformats-officedocument.presentationml.presentation":["pptx"],"application/vnd.openxmlformats-officedocument.presentationml.slide":["sldx"],"application/vnd.openxmlformats-officedocument.presentationml.slideshow":["ppsx"],"application/vnd.openxmlformats-officedocument.presentationml.template":["potx"],"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet":["xlsx"],"application/vnd.openxmlformats-officedocument.spreadsheetml.template":["xltx"],"application/vnd.openxmlformats-officedocument.wordprocessingml.document":["docx"],"application/vnd.openxmlformats-officedocument.wordprocessingml.template":["dotx"],"application/vnd.osgeo.mapguide.package":["mgp"],"application/vnd.osgi.dp":["dp"],"application/vnd.osgi.subsystem":["esa"],"application/vnd.palm":["pdb","pqa","oprc"],"application/vnd.pawaafile":["paw"],"application/vnd.pg.format":["str"],"application/vnd.pg.osasli":["ei6"],"application/vnd.picsel":["efif"],"application/vnd.pmi.widget":["wg"],"application/vnd.pocketlearn":["plf"],"application/vnd.powerbuilder6":["pbd"],"application/vnd.previewsystems.box":["box"],"application/vnd.proteus.magazine":["mgz"],"application/vnd.publishare-delta-tree":["qps"],"application/vnd.pvi.ptid1":["ptid"],"application/vnd.pwg-xhtml-print+xml":["xhtm"],"application/vnd.quark.quarkxpress":["qxd","qxt","qwd","qwt","qxl","qxb"],"application/vnd.rar":["rar"],"application/vnd.realvnc.bed":["bed"],"application/vnd.recordare.musicxml":["mxl"],"application/vnd.recordare.musicxml+xml":["musicxml"],"application/vnd.rig.cryptonote":["cryptonote"],"application/vnd.rim.cod":["cod"],"application/vnd.rn-realmedia":["rm"],"application/vnd.rn-realmedia-vbr":["rmvb"],"application/vnd.route66.link66+xml":["link66"],"application/vnd.sailingtracker.track":["st"],"application/vnd.seemail":["see"],"application/vnd.sema":["sema"],"application/vnd.semd":["semd"],"application/vnd.semf":["semf"],"application/vnd.shana.informed.formdata":["ifm"],"application/vnd.shana.informed.formtemplate":["itp"],"application/vnd.shana.informed.interchange":["iif"],"application/vnd.shana.informed.package":["ipk"],"application/vnd.simtech-mindmapper":["twd","twds"],"application/vnd.smaf":["mmf"],"application/vnd.smart.teacher":["teacher"],"application/vnd.software602.filler.form+xml":["fo"],"application/vnd.solent.sdkm+xml":["sdkm","sdkd"],"application/vnd.spotfire.dxp":["dxp"],"application/vnd.spotfire.sfs":["sfs"],"application/vnd.stardivision.calc":["sdc"],"application/vnd.stardivision.draw":["sda"],"application/vnd.stardivision.impress":["sdd"],"application/vnd.stardivision.math":["smf"],"application/vnd.stardivision.writer":["sdw","vor"],"application/vnd.stardivision.writer-global":["sgl"],"application/vnd.stepmania.package":["smzip"],"application/vnd.stepmania.stepchart":["sm"],"application/vnd.sun.wadl+xml":["wadl"],"application/vnd.sun.xml.calc":["sxc"],"application/vnd.sun.xml.calc.template":["stc"],"application/vnd.sun.xml.draw":["sxd"],"application/vnd.sun.xml.draw.template":["std"],"application/vnd.sun.xml.impress":["sxi"],"application/vnd.sun.xml.impress.template":["sti"],"application/vnd.sun.xml.math":["sxm"],"application/vnd.sun.xml.writer":["sxw"],"application/vnd.sun.xml.writer.global":["sxg"],"application/vnd.sun.xml.writer.template":["stw"],"application/vnd.sus-calendar":["sus","susp"],"application/vnd.svd":["svd"],"application/vnd.symbian.install":["sis","sisx"],"application/vnd.syncml+xml":["xsm"],"application/vnd.syncml.dm+wbxml":["bdm"],"application/vnd.syncml.dm+xml":["xdm"],"application/vnd.syncml.dmddf+xml":["ddf"],"application/vnd.tao.intent-module-archive":["tao"],"application/vnd.tcpdump.pcap":["pcap","cap","dmp"],"application/vnd.tmobile-livetv":["tmo"],"application/vnd.trid.tpt":["tpt"],"application/vnd.triscape.mxs":["mxs"],"application/vnd.trueapp":["tra"],"application/vnd.ufdl":["ufd","ufdl"],"application/vnd.uiq.theme":["utz"],"application/vnd.umajin":["umj"],"application/vnd.unity":["unityweb"],"application/vnd.uoml+xml":["uoml","uo"],"application/vnd.vcx":["vcx"],"application/vnd.visio":["vsd","vst","vss","vsw"],"application/vnd.visionary":["vis"],"application/vnd.vsf":["vsf"],"application/vnd.wap.wbxml":["wbxml"],"application/vnd.wap.wmlc":["wmlc"],"application/vnd.wap.wmlscriptc":["wmlsc"],"application/vnd.webturbo":["wtb"],"application/vnd.wolfram.player":["nbp"],"application/vnd.wordperfect":["wpd"],"application/vnd.wqd":["wqd"],"application/vnd.wt.stf":["stf"],"application/vnd.xara":["xar"],"application/vnd.xfdl":["xfdl"],"application/vnd.yamaha.hv-dic":["hvd"],"application/vnd.yamaha.hv-script":["hvs"],"application/vnd.yamaha.hv-voice":["hvp"],"application/vnd.yamaha.openscoreformat":["osf"],"application/vnd.yamaha.openscoreformat.osfpvg+xml":["osfpvg"],"application/vnd.yamaha.smaf-audio":["saf"],"application/vnd.yamaha.smaf-phrase":["spf"],"application/vnd.yellowriver-custom-menu":["cmp"],"application/vnd.zul":["zir","zirz"],"application/vnd.zzazz.deck+xml":["zaz"],"application/x-7z-compressed":["7z"],"application/x-abiword":["abw"],"application/x-ace-compressed":["ace"],"application/x-apple-diskimage":["*dmg"],"application/x-arj":["arj"],"application/x-authorware-bin":["aab","x32","u32","vox"],"application/x-authorware-map":["aam"],"application/x-authorware-seg":["aas"],"application/x-bcpio":["bcpio"],"application/x-bdoc":["*bdoc"],"application/x-bittorrent":["torrent"],"application/x-blorb":["blb","blorb"],"application/x-bzip":["bz"],"application/x-bzip2":["bz2","boz"],"application/x-cbr":["cbr","cba","cbt","cbz","cb7"],"application/x-cdlink":["vcd"],"application/x-cfs-compressed":["cfs"],"application/x-chat":["chat"],"application/x-chess-pgn":["pgn"],"application/x-chrome-extension":["crx"],"application/x-cocoa":["cco"],"application/x-conference":["nsc"],"application/x-cpio":["cpio"],"application/x-csh":["csh"],"application/x-debian-package":["*deb","udeb"],"application/x-dgc-compressed":["dgc"],"application/x-director":["dir","dcr","dxr","cst","cct","cxt","w3d","fgd","swa"],"application/x-doom":["wad"],"application/x-dtbncx+xml":["ncx"],"application/x-dtbook+xml":["dtb"],"application/x-dtbresource+xml":["res"],"application/x-dvi":["dvi"],"application/x-envoy":["evy"],"application/x-eva":["eva"],"application/x-font-bdf":["bdf"],"application/x-font-ghostscript":["gsf"],"application/x-font-linux-psf":["psf"],"application/x-font-pcf":["pcf"],"application/x-font-snf":["snf"],"application/x-font-type1":["pfa","pfb","pfm","afm"],"application/x-freearc":["arc"],"application/x-futuresplash":["spl"],"application/x-gca-compressed":["gca"],"application/x-glulx":["ulx"],"application/x-gnumeric":["gnumeric"],"application/x-gramps-xml":["gramps"],"application/x-gtar":["gtar"],"application/x-hdf":["hdf"],"application/x-httpd-php":["php"],"application/x-install-instructions":["install"],"application/x-iso9660-image":["*iso"],"application/x-iwork-keynote-sffkey":["*key"],"application/x-iwork-numbers-sffnumbers":["*numbers"],"application/x-iwork-pages-sffpages":["*pages"],"application/x-java-archive-diff":["jardiff"],"application/x-java-jnlp-file":["jnlp"],"application/x-keepass2":["kdbx"],"application/x-latex":["latex"],"application/x-lua-bytecode":["luac"],"application/x-lzh-compressed":["lzh","lha"],"application/x-makeself":["run"],"application/x-mie":["mie"],"application/x-mobipocket-ebook":["*prc","mobi"],"application/x-ms-application":["application"],"application/x-ms-shortcut":["lnk"],"application/x-ms-wmd":["wmd"],"application/x-ms-wmz":["wmz"],"application/x-ms-xbap":["xbap"],"application/x-msaccess":["mdb"],"application/x-msbinder":["obd"],"application/x-mscardfile":["crd"],"application/x-msclip":["clp"],"application/x-msdos-program":["*exe"],"application/x-msdownload":["*exe","*dll","com","bat","*msi"],"application/x-msmediaview":["mvb","m13","m14"],"application/x-msmetafile":["*wmf","*wmz","*emf","emz"],"application/x-msmoney":["mny"],"application/x-mspublisher":["pub"],"application/x-msschedule":["scd"],"application/x-msterminal":["trm"],"application/x-mswrite":["wri"],"application/x-netcdf":["nc","cdf"],"application/x-ns-proxy-autoconfig":["pac"],"application/x-nzb":["nzb"],"application/x-perl":["pl","pm"],"application/x-pilot":["*prc","*pdb"],"application/x-pkcs12":["p12","pfx"],"application/x-pkcs7-certificates":["p7b","spc"],"application/x-pkcs7-certreqresp":["p7r"],"application/x-rar-compressed":["*rar"],"application/x-redhat-package-manager":["rpm"],"application/x-research-info-systems":["ris"],"application/x-sea":["sea"],"application/x-sh":["sh"],"application/x-shar":["shar"],"application/x-shockwave-flash":["swf"],"application/x-silverlight-app":["xap"],"application/x-sql":["*sql"],"application/x-stuffit":["sit"],"application/x-stuffitx":["sitx"],"application/x-subrip":["srt"],"application/x-sv4cpio":["sv4cpio"],"application/x-sv4crc":["sv4crc"],"application/x-t3vm-image":["t3"],"application/x-tads":["gam"],"application/x-tar":["tar"],"application/x-tcl":["tcl","tk"],"application/x-tex":["tex"],"application/x-tex-tfm":["tfm"],"application/x-texinfo":["texinfo","texi"],"application/x-tgif":["*obj"],"application/x-ustar":["ustar"],"application/x-virtualbox-hdd":["hdd"],"application/x-virtualbox-ova":["ova"],"application/x-virtualbox-ovf":["ovf"],"application/x-virtualbox-vbox":["vbox"],"application/x-virtualbox-vbox-extpack":["vbox-extpack"],"application/x-virtualbox-vdi":["vdi"],"application/x-virtualbox-vhd":["vhd"],"application/x-virtualbox-vmdk":["vmdk"],"application/x-wais-source":["src"],"application/x-web-app-manifest+json":["webapp"],"application/x-x509-ca-cert":["der","crt","pem"],"application/x-xfig":["fig"],"application/x-xliff+xml":["*xlf"],"application/x-xpinstall":["xpi"],"application/x-xz":["xz"],"application/x-zmachine":["z1","z2","z3","z4","z5","z6","z7","z8"],"audio/vnd.dece.audio":["uva","uvva"],"audio/vnd.digital-winds":["eol"],"audio/vnd.dra":["dra"],"audio/vnd.dts":["dts"],"audio/vnd.dts.hd":["dtshd"],"audio/vnd.lucent.voice":["lvp"],"audio/vnd.ms-playready.media.pya":["pya"],"audio/vnd.nuera.ecelp4800":["ecelp4800"],"audio/vnd.nuera.ecelp7470":["ecelp7470"],"audio/vnd.nuera.ecelp9600":["ecelp9600"],"audio/vnd.rip":["rip"],"audio/x-aac":["*aac"],"audio/x-aiff":["aif","aiff","aifc"],"audio/x-caf":["caf"],"audio/x-flac":["flac"],"audio/x-m4a":["*m4a"],"audio/x-matroska":["mka"],"audio/x-mpegurl":["m3u"],"audio/x-ms-wax":["wax"],"audio/x-ms-wma":["wma"],"audio/x-pn-realaudio":["ram","ra"],"audio/x-pn-realaudio-plugin":["rmp"],"audio/x-realaudio":["*ra"],"audio/x-wav":["*wav"],"chemical/x-cdx":["cdx"],"chemical/x-cif":["cif"],"chemical/x-cmdf":["cmdf"],"chemical/x-cml":["cml"],"chemical/x-csml":["csml"],"chemical/x-xyz":["xyz"],"image/prs.btif":["btif","btf"],"image/prs.pti":["pti"],"image/vnd.adobe.photoshop":["psd"],"image/vnd.airzip.accelerator.azv":["azv"],"image/vnd.dece.graphic":["uvi","uvvi","uvg","uvvg"],"image/vnd.djvu":["djvu","djv"],"image/vnd.dvb.subtitle":["*sub"],"image/vnd.dwg":["dwg"],"image/vnd.dxf":["dxf"],"image/vnd.fastbidsheet":["fbs"],"image/vnd.fpx":["fpx"],"image/vnd.fst":["fst"],"image/vnd.fujixerox.edmics-mmr":["mmr"],"image/vnd.fujixerox.edmics-rlc":["rlc"],"image/vnd.microsoft.icon":["ico"],"image/vnd.ms-dds":["dds"],"image/vnd.ms-modi":["mdi"],"image/vnd.ms-photo":["wdp"],"image/vnd.net-fpx":["npx"],"image/vnd.pco.b16":["b16"],"image/vnd.tencent.tap":["tap"],"image/vnd.valve.source.texture":["vtf"],"image/vnd.wap.wbmp":["wbmp"],"image/vnd.xiff":["xif"],"image/vnd.zbrush.pcx":["pcx"],"image/x-3ds":["3ds"],"image/x-cmu-raster":["ras"],"image/x-cmx":["cmx"],"image/x-freehand":["fh","fhc","fh4","fh5","fh7"],"image/x-icon":["*ico"],"image/x-jng":["jng"],"image/x-mrsid-image":["sid"],"image/x-ms-bmp":["*bmp"],"image/x-pcx":["*pcx"],"image/x-pict":["pic","pct"],"image/x-portable-anymap":["pnm"],"image/x-portable-bitmap":["pbm"],"image/x-portable-graymap":["pgm"],"image/x-portable-pixmap":["ppm"],"image/x-rgb":["rgb"],"image/x-tga":["tga"],"image/x-xbitmap":["xbm"],"image/x-xpixmap":["xpm"],"image/x-xwindowdump":["xwd"],"message/vnd.wfa.wsc":["wsc"],"model/vnd.cld":["cld"],"model/vnd.collada+xml":["dae"],"model/vnd.dwf":["dwf"],"model/vnd.gdl":["gdl"],"model/vnd.gtw":["gtw"],"model/vnd.mts":["mts"],"model/vnd.opengex":["ogex"],"model/vnd.parasolid.transmit.binary":["x_b"],"model/vnd.parasolid.transmit.text":["x_t"],"model/vnd.pytha.pyox":["pyo","pyox"],"model/vnd.sap.vds":["vds"],"model/vnd.usda":["usda"],"model/vnd.usdz+zip":["usdz"],"model/vnd.valve.source.compiled-map":["bsp"],"model/vnd.vtu":["vtu"],"text/prs.lines.tag":["dsc"],"text/vnd.curl":["curl"],"text/vnd.curl.dcurl":["dcurl"],"text/vnd.curl.mcurl":["mcurl"],"text/vnd.curl.scurl":["scurl"],"text/vnd.dvb.subtitle":["sub"],"text/vnd.familysearch.gedcom":["ged"],"text/vnd.fly":["fly"],"text/vnd.fmi.flexstor":["flx"],"text/vnd.graphviz":["gv"],"text/vnd.in3d.3dml":["3dml"],"text/vnd.in3d.spot":["spot"],"text/vnd.sun.j2me.app-descriptor":["jad"],"text/vnd.wap.wml":["wml"],"text/vnd.wap.wmlscript":["wmls"],"text/x-asm":["s","asm"],"text/x-c":["c","cc","cxx","cpp","h","hh","dic"],"text/x-component":["htc"],"text/x-fortran":["f","for","f77","f90"],"text/x-handlebars-template":["hbs"],"text/x-java-source":["java"],"text/x-lua":["lua"],"text/x-markdown":["mkd"],"text/x-nfo":["nfo"],"text/x-opml":["opml"],"text/x-org":["*org"],"text/x-pascal":["p","pas"],"text/x-processing":["pde"],"text/x-sass":["sass"],"text/x-scss":["scss"],"text/x-setext":["etx"],"text/x-sfv":["sfv"],"text/x-suse-ymp":["ymp"],"text/x-uuencode":["uu"],"text/x-vcalendar":["vcs"],"text/x-vcard":["vcf"],"video/vnd.dece.hd":["uvh","uvvh"],"video/vnd.dece.mobile":["uvm","uvvm"],"video/vnd.dece.pd":["uvp","uvvp"],"video/vnd.dece.sd":["uvs","uvvs"],"video/vnd.dece.video":["uvv","uvvv"],"video/vnd.dvb.file":["dvb"],"video/vnd.fvt":["fvt"],"video/vnd.mpegurl":["mxu","m4u"],"video/vnd.ms-playready.media.pyv":["pyv"],"video/vnd.uvvu.mp4":["uvu","uvvu"],"video/vnd.vivo":["viv"],"video/x-f4v":["f4v"],"video/x-fli":["fli"],"video/x-flv":["flv"],"video/x-m4v":["m4v"],"video/x-matroska":["mkv","mk3d","mks"],"video/x-mng":["mng"],"video/x-ms-asf":["asf","asx"],"video/x-ms-vob":["vob"],"video/x-ms-wm":["wm"],"video/x-ms-wmv":["wmv"],"video/x-ms-wmx":["wmx"],"video/x-ms-wvx":["wvx"],"video/x-msvideo":["avi"],"video/x-sgi-movie":["movie"],"video/x-smv":["smv"],"x-conference/x-cooltalk":["ice"]};Object.freeze(Ny);var _y=Ny;var Dy={"application/andrew-inset":["ez"],"application/appinstaller":["appinstaller"],"application/applixware":["aw"],"application/appx":["appx"],"application/appxbundle":["appxbundle"],"application/atom+xml":["atom"],"application/atomcat+xml":["atomcat"],"application/atomdeleted+xml":["atomdeleted"],"application/atomsvc+xml":["atomsvc"],"application/atsc-dwd+xml":["dwd"],"application/atsc-held+xml":["held"],"application/atsc-rsat+xml":["rsat"],"application/automationml-aml+xml":["aml"],"application/automationml-amlx+zip":["amlx"],"application/bdoc":["bdoc"],"application/calendar+xml":["xcs"],"application/ccxml+xml":["ccxml"],"application/cdfx+xml":["cdfx"],"application/cdmi-capability":["cdmia"],"application/cdmi-container":["cdmic"],"application/cdmi-domain":["cdmid"],"application/cdmi-object":["cdmio"],"application/cdmi-queue":["cdmiq"],"application/cpl+xml":["cpl"],"application/cu-seeme":["cu"],"application/cwl":["cwl"],"application/dash+xml":["mpd"],"application/dash-patch+xml":["mpp"],"application/davmount+xml":["davmount"],"application/docbook+xml":["dbk"],"application/dssc+der":["dssc"],"application/dssc+xml":["xdssc"],"application/ecmascript":["ecma"],"application/emma+xml":["emma"],"application/emotionml+xml":["emotionml"],"application/epub+zip":["epub"],"application/exi":["exi"],"application/express":["exp"],"application/fdf":["fdf"],"application/fdt+xml":["fdt"],"application/font-tdpfr":["pfr"],"application/geo+json":["geojson"],"application/gml+xml":["gml"],"application/gpx+xml":["gpx"],"application/gxf":["gxf"],"application/gzip":["gz"],"application/hjson":["hjson"],"application/hyperstudio":["stk"],"application/inkml+xml":["ink","inkml"],"application/ipfix":["ipfix"],"application/its+xml":["its"],"application/java-archive":["jar","war","ear"],"application/java-serialized-object":["ser"],"application/java-vm":["class"],"application/javascript":["*js"],"application/json":["json","map"],"application/json5":["json5"],"application/jsonml+json":["jsonml"],"application/ld+json":["jsonld"],"application/lgr+xml":["lgr"],"application/lost+xml":["lostxml"],"application/mac-binhex40":["hqx"],"application/mac-compactpro":["cpt"],"application/mads+xml":["mads"],"application/manifest+json":["webmanifest"],"application/marc":["mrc"],"application/marcxml+xml":["mrcx"],"application/mathematica":["ma","nb","mb"],"application/mathml+xml":["mathml"],"application/mbox":["mbox"],"application/media-policy-dataset+xml":["mpf"],"application/mediaservercontrol+xml":["mscml"],"application/metalink+xml":["metalink"],"application/metalink4+xml":["meta4"],"application/mets+xml":["mets"],"application/mmt-aei+xml":["maei"],"application/mmt-usd+xml":["musd"],"application/mods+xml":["mods"],"application/mp21":["m21","mp21"],"application/mp4":["*mp4","*mpg4","mp4s","m4p"],"application/msix":["msix"],"application/msixbundle":["msixbundle"],"application/msword":["doc","dot"],"application/mxf":["mxf"],"application/n-quads":["nq"],"application/n-triples":["nt"],"application/node":["cjs"],"application/octet-stream":["bin","dms","lrf","mar","so","dist","distz","pkg","bpk","dump","elc","deploy","exe","dll","deb","dmg","iso","img","msi","msp","msm","buffer"],"application/oda":["oda"],"application/oebps-package+xml":["opf"],"application/ogg":["ogx"],"application/omdoc+xml":["omdoc"],"application/onenote":["onetoc","onetoc2","onetmp","onepkg"],"application/oxps":["oxps"],"application/p2p-overlay+xml":["relo"],"application/patch-ops-error+xml":["xer"],"application/pdf":["pdf"],"application/pgp-encrypted":["pgp"],"application/pgp-keys":["asc"],"application/pgp-signature":["sig","*asc"],"application/pics-rules":["prf"],"application/pkcs10":["p10"],"application/pkcs7-mime":["p7m","p7c"],"application/pkcs7-signature":["p7s"],"application/pkcs8":["p8"],"application/pkix-attr-cert":["ac"],"application/pkix-cert":["cer"],"application/pkix-crl":["crl"],"application/pkix-pkipath":["pkipath"],"application/pkixcmp":["pki"],"application/pls+xml":["pls"],"application/postscript":["ai","eps","ps"],"application/provenance+xml":["provx"],"application/pskc+xml":["pskcxml"],"application/raml+yaml":["raml"],"application/rdf+xml":["rdf","owl"],"application/reginfo+xml":["rif"],"application/relax-ng-compact-syntax":["rnc"],"application/resource-lists+xml":["rl"],"application/resource-lists-diff+xml":["rld"],"application/rls-services+xml":["rs"],"application/route-apd+xml":["rapd"],"application/route-s-tsid+xml":["sls"],"application/route-usd+xml":["rusd"],"application/rpki-ghostbusters":["gbr"],"application/rpki-manifest":["mft"],"application/rpki-roa":["roa"],"application/rsd+xml":["rsd"],"application/rss+xml":["rss"],"application/rtf":["rtf"],"application/sbml+xml":["sbml"],"application/scvp-cv-request":["scq"],"application/scvp-cv-response":["scs"],"application/scvp-vp-request":["spq"],"application/scvp-vp-response":["spp"],"application/sdp":["sdp"],"application/senml+xml":["senmlx"],"application/sensml+xml":["sensmlx"],"application/set-payment-initiation":["setpay"],"application/set-registration-initiation":["setreg"],"application/shf+xml":["shf"],"application/sieve":["siv","sieve"],"application/smil+xml":["smi","smil"],"application/sparql-query":["rq"],"application/sparql-results+xml":["srx"],"application/sql":["sql"],"application/srgs":["gram"],"application/srgs+xml":["grxml"],"application/sru+xml":["sru"],"application/ssdl+xml":["ssdl"],"application/ssml+xml":["ssml"],"application/swid+xml":["swidtag"],"application/tei+xml":["tei","teicorpus"],"application/thraud+xml":["tfi"],"application/timestamped-data":["tsd"],"application/toml":["toml"],"application/trig":["trig"],"application/ttml+xml":["ttml"],"application/ubjson":["ubj"],"application/urc-ressheet+xml":["rsheet"],"application/urc-targetdesc+xml":["td"],"application/voicexml+xml":["vxml"],"application/wasm":["wasm"],"application/watcherinfo+xml":["wif"],"application/widget":["wgt"],"application/winhlp":["hlp"],"application/wsdl+xml":["wsdl"],"application/wspolicy+xml":["wspolicy"],"application/xaml+xml":["xaml"],"application/xcap-att+xml":["xav"],"application/xcap-caps+xml":["xca"],"application/xcap-diff+xml":["xdf"],"application/xcap-el+xml":["xel"],"application/xcap-ns+xml":["xns"],"application/xenc+xml":["xenc"],"application/xfdf":["xfdf"],"application/xhtml+xml":["xhtml","xht"],"application/xliff+xml":["xlf"],"application/xml":["xml","xsl","xsd","rng"],"application/xml-dtd":["dtd"],"application/xop+xml":["xop"],"application/xproc+xml":["xpl"],"application/xslt+xml":["*xsl","xslt"],"application/xspf+xml":["xspf"],"application/xv+xml":["mxml","xhvml","xvml","xvm"],"application/yang":["yang"],"application/yin+xml":["yin"],"application/zip":["zip"],"audio/3gpp":["*3gpp"],"audio/aac":["adts","aac"],"audio/adpcm":["adp"],"audio/amr":["amr"],"audio/basic":["au","snd"],"audio/midi":["mid","midi","kar","rmi"],"audio/mobile-xmf":["mxmf"],"audio/mp3":["*mp3"],"audio/mp4":["m4a","mp4a"],"audio/mpeg":["mpga","mp2","mp2a","mp3","m2a","m3a"],"audio/ogg":["oga","ogg","spx","opus"],"audio/s3m":["s3m"],"audio/silk":["sil"],"audio/wav":["wav"],"audio/wave":["*wav"],"audio/webm":["weba"],"audio/xm":["xm"],"font/collection":["ttc"],"font/otf":["otf"],"font/ttf":["ttf"],"font/woff":["woff"],"font/woff2":["woff2"],"image/aces":["exr"],"image/apng":["apng"],"image/avci":["avci"],"image/avcs":["avcs"],"image/avif":["avif"],"image/bmp":["bmp","dib"],"image/cgm":["cgm"],"image/dicom-rle":["drle"],"image/dpx":["dpx"],"image/emf":["emf"],"image/fits":["fits"],"image/g3fax":["g3"],"image/gif":["gif"],"image/heic":["heic"],"image/heic-sequence":["heics"],"image/heif":["heif"],"image/heif-sequence":["heifs"],"image/hej2k":["hej2"],"image/hsj2":["hsj2"],"image/ief":["ief"],"image/jls":["jls"],"image/jp2":["jp2","jpg2"],"image/jpeg":["jpeg","jpg","jpe"],"image/jph":["jph"],"image/jphc":["jhc"],"image/jpm":["jpm","jpgm"],"image/jpx":["jpx","jpf"],"image/jxr":["jxr"],"image/jxra":["jxra"],"image/jxrs":["jxrs"],"image/jxs":["jxs"],"image/jxsc":["jxsc"],"image/jxsi":["jxsi"],"image/jxss":["jxss"],"image/ktx":["ktx"],"image/ktx2":["ktx2"],"image/png":["png"],"image/sgi":["sgi"],"image/svg+xml":["svg","svgz"],"image/t38":["t38"],"image/tiff":["tif","tiff"],"image/tiff-fx":["tfx"],"image/webp":["webp"],"image/wmf":["wmf"],"message/disposition-notification":["disposition-notification"],"message/global":["u8msg"],"message/global-delivery-status":["u8dsn"],"message/global-disposition-notification":["u8mdn"],"message/global-headers":["u8hdr"],"message/rfc822":["eml","mime"],"model/3mf":["3mf"],"model/gltf+json":["gltf"],"model/gltf-binary":["glb"],"model/iges":["igs","iges"],"model/jt":["jt"],"model/mesh":["msh","mesh","silo"],"model/mtl":["mtl"],"model/obj":["obj"],"model/prc":["prc"],"model/step+xml":["stpx"],"model/step+zip":["stpz"],"model/step-xml+zip":["stpxz"],"model/stl":["stl"],"model/u3d":["u3d"],"model/vrml":["wrl","vrml"],"model/x3d+binary":["*x3db","x3dbz"],"model/x3d+fastinfoset":["x3db"],"model/x3d+vrml":["*x3dv","x3dvz"],"model/x3d+xml":["x3d","x3dz"],"model/x3d-vrml":["x3dv"],"text/cache-manifest":["appcache","manifest"],"text/calendar":["ics","ifb"],"text/coffeescript":["coffee","litcoffee"],"text/css":["css"],"text/csv":["csv"],"text/html":["html","htm","shtml"],"text/jade":["jade"],"text/javascript":["js","mjs"],"text/jsx":["jsx"],"text/less":["less"],"text/markdown":["md","markdown"],"text/mathml":["mml"],"text/mdx":["mdx"],"text/n3":["n3"],"text/plain":["txt","text","conf","def","list","log","in","ini"],"text/richtext":["rtx"],"text/rtf":["*rtf"],"text/sgml":["sgml","sgm"],"text/shex":["shex"],"text/slim":["slim","slm"],"text/spdx":["spdx"],"text/stylus":["stylus","styl"],"text/tab-separated-values":["tsv"],"text/troff":["t","tr","roff","man","me","ms"],"text/turtle":["ttl"],"text/uri-list":["uri","uris","urls"],"text/vcard":["vcard"],"text/vtt":["vtt"],"text/wgsl":["wgsl"],"text/xml":["*xml"],"text/yaml":["yaml","yml"],"video/3gpp":["3gp","3gpp"],"video/3gpp2":["3g2"],"video/h261":["h261"],"video/h263":["h263"],"video/h264":["h264"],"video/iso.segment":["m4s"],"video/jpeg":["jpgv"],"video/jpm":["*jpm","*jpgm"],"video/mj2":["mj2","mjp2"],"video/mp2t":["ts"],"video/mp4":["mp4","mp4v","mpg4"],"video/mpeg":["mpeg","mpg","mpe","m1v","m2v"],"video/ogg":["ogv"],"video/quicktime":["qt","mov"],"video/webm":["webm"]};Object.freeze(Dy);var Fy=Dy;var tn=function(n,e,t,r){if(t==="a"&&!r)throw new TypeError("Private accessor was defined without a getter");if(typeof e=="function"?n!==e||!r:!e.has(n))throw new TypeError("Cannot read private member from an object whose class did not declare it");return t==="m"?r:t==="a"?r.call(n):r?r.value:e.get(n)},ai,Ea,Kr,Jd=class{constructor(...e){ai.set(this,new Map),Ea.set(this,new Map),Kr.set(this,new Map);for(let t of e)this.define(t)}define(e,t=!1){for(let[r,o]of Object.entries(e)){r=r.toLowerCase(),o=o.map(s=>s.toLowerCase()),tn(this,Kr,"f").has(r)||tn(this,Kr,"f").set(r,new Set);let i=tn(this,Kr,"f").get(r),a=!0;for(let s of o){let l=s.startsWith("*");if(s=l?s.slice(1):s,i?.add(s),a&&tn(this,Ea,"f").set(r,s),a=!1,l)continue;let c=tn(this,ai,"f").get(s);if(c&&c!=r&&!t)throw new Error(`"${r} -> ${s}" conflicts with "${c} -> ${s}". Pass \`force=true\` to override this definition.`);tn(this,ai,"f").set(s,r)}}return this}getType(e){if(typeof e!="string")return null;let t=e.replace(/^.*[/\\]/,"").toLowerCase(),r=t.replace(/^.*\./,"").toLowerCase(),o=t.length<e.length;return!(r.length<t.length-1)&&o?null:tn(this,ai,"f").get(r)??null}getExtension(e){return typeof e!="string"?null:(e=e?.split?.(";")[0],(e&&tn(this,Ea,"f").get(e.trim().toLowerCase()))??null)}getAllExtensions(e){return typeof e!="string"?null:tn(this,Kr,"f").get(e.toLowerCase())??null}_freeze(){this.define=()=>{throw new Error("define() not allowed for built-in Mime objects. See https://github.com/broofa/mime/blob/main/README.md#custom-mime-instances")},Object.freeze(this);for(let e of tn(this,Kr,"f").values())Object.freeze(e);return this}_getTestState(){return{types:tn(this,ai,"f"),extensions:tn(this,Ea,"f")}}};ai=new WeakMap,Ea=new WeakMap,Kr=new WeakMap;var Xd=Jd;var Uy=new Xd(Fy,_y)._freeze();import{homedir as vp,hostname as qO,platform as KO}from"os";import{basename as YO,extname as JO,join as ci,resolve as XO}from"path";import{chromium as Hb,devices as ZO}from"playwright";import{addExtra as QO}from"playwright-extra";import ek from"puppeteer-extra-plugin-recaptcha";import{v4 as tk}from"uuid";import{rmSync as xb}from"fs";import{basename as gO,join as fO}from"path";import{errors as SO}from"playwright-core";var $n={bannedClassSubstrings:["relative","flex","center","justify","auto","sticky","absolute","top","right","left","bottom","items-center","notion-selectable","notion-page-block","notion-collection-item","MuiSvgIcon","css-","rt-"],nonDynamicInputTypes:["button","file","hidden","image","radio","reset","submit"],generalStateAttributes:["aria-expanded","aria-haspopup","aria-checked","aria-pressed","aria-selected","aria-invalid","checked","open","aria-busy"],bannedElementTagNames:["html","head","meta","script","style","path","br","::marker","noscript","polygon","defs"],bannedElementAttributes:["data-momentic-id","aria-keyshortcuts","data-ved","aria-controls","d"],relevantElementAttributes:["name","id","value","type","class","height","width","target","title","href","src","alt","role","headers","scope","checked","required","action","tooltip","min","max","minlength","maxlength","multiple","pattern","placeholder","accept","contenteditable","data-value","data-testid","data-cy","data-pw","data-test-id","data-test","data-role","data-type","data-key","data-action","data-aria-hidden","data-hidden","data-automation-id","data-content-editable-leaf","data-wf-icon","data-tns","data-handleid","data-handlepos","data-col-index","data-row-index","data-row","data-col","col-index","row-index","row","col","data-momentic-description","aria-label","aria-role","aria-selected","aria-disabled","aria-hidden","aria-describedby","aria-valuenow","aria-valuemin","aria-valuemax"],alwaysUsefulAttributesForCssSelectorGeneration:["src","href","aria-describedby","aria-labelledby","aria-label"],alwaysInterestingClassNames:["cm-line","cm-activeLine","cm-content"],alwaysInterestingClassPrefixes:["notion-",".w-"],alwaysInterestingTruthyPropertyNames:["contenteditable"],visualAttributesForSvgSerialization:["fill","stroke","color","patternContentUnits","xlink:href","transform","path","d","points","viewBox","preserveAspectRatio","r","rx","ry","cx","cy","x1","y1","x2","y2","font","text-anchor","dominant-baseline","gradient","pattern","stop-color"]};var gL=new Set(["b","c","d","f","g","h","j","k","l","m","n","p","q","r","s","t","v","w","x","y","z"]),fL=new Set(["a","e","i","o","u","y"]);function By(n){if(n.length>75)return!1;if(n[0]?.match(/[0-9a-zA-Z]/)===null)return!0;if(n.length>10){let m=Math.floor(n.length/8);if((n.match(/[-_:A-Z/ ]/g)??[]).length<m)return!0}if((n.match(/[^0-9a-zA-Z-_.]/g)??[]).length/n.length>.2)return!0;let t=(n.match(/[0-9]/g)??[]).length;if(t/n.length>.3)return!0;let r=(n.toLowerCase().match(/[aeiou]/gi)??[]).length;if((n.toLowerCase().match(/[bcdfghjklmnpqrstvwxyz]/gi)??[]).length/r>5)return!0;let i=0,a=0;for(let m of n.toLowerCase())gL.has(m)?(a++,a>i&&(i=a)):a=0;if(i>4)return!0;let s=0,l=0;for(let m of n.toLowerCase())m>="a"&&m<="z"&&!fL.has(m)?(l++,l>s&&(s=l)):l=0;if(s>4)return!0;let c=(n.match(/[A-Z]/g)??[]).length,d=(n.match(/[a-z]/g)??[]).length,p=Math.ceil(n.length*.3);return!!(d&&t&&Math.abs(d-t)<p||d&&c&&Math.abs(d-c)<p)}function zy(n,e,t){if(n.length<t)return n;let r=n.indexOf(e);if(r===-1)return n;let o=Math.max(0,r-t/3),i=Math.min(r+t/3,n.length),a=n.indexOf(`
3590
3590
  `,o);a>0&&a<r&&(o=a);let s=i,l=0;for(;l<1e3&&s>r&&n[s]!==`
3591
3591
  `;)l++,s--;return s>r&&n[s]===`
3592
3592
  `&&(i=s),n.slice(o,i)}import{randomUUID as RL}from"crypto";import{cloneDeep as np}from"lodash-es";import{randomUUID as TL}from"crypto";var Hy=new Set(["about:blank","chrome-error://chromewebdata/"]);var Tt="data-momentic-id";var Zd=["button","image","generic","graphics-symbol","tab","link","menuitem","group"],Qd=1e4,Ca=500;function hr(n,e){let t=n.findIndex(r=>r===e);if(!(t===-1||!n[t+1]))return n[t+1]}import{createHash as SL}from"crypto";var yL="v1";function ml(n,e){if(n.tagName.toLowerCase()==="svg"&&!wL(n))try{let t=jy(n,e),r=bL(JSON.stringify(t));return{version:yL,json:t,hash:r}}catch{return}}function bL(n){return SL("md5").update(n).digest("hex")}function jy(n,e){let t=n.tagName.toLowerCase(),r=vL(n);if(t==="image"&&r["xlink:href"])throw new Error("Image tags within SVGs are not supported");let o={type:t,props:r,children:[]};for(let i of n.childrenBackendIds){let a=e.backendIdToNode[i];if(a&&a.nodeType===1){let s=jy(a,e);s&&o.children.push(s)}}return o}function wL(n){let e=n.computedStyles.display,t=n.computedStyles.visibility,r=n.computedStyles.opacity;return e==="none"||t==="hidden"||r==="0"}function vL(n){let e={},t=n.attributes;for(let r of Object.keys(t))$n.visualAttributesForSvgSerialization.includes(r)&&(e[r]=t[r]);return t.id&&n.tagName.toLowerCase()!=="svg"&&(e.id=t.id),e}var Yr={r:147,g:196,b:125,a:.55},Wy={showRulers:!1,showStyles:!1,showExtensionLines:!1,contrastAlgorithm:"aa",contentColor:Yr,paddingColor:Yr,borderColor:Yr,marginColor:Yr,eventTargetColor:Yr,shapeColor:Yr,shapeMarginColor:Yr,showInfo:!0,showAccessibilityInfo:!0},hl=["display","opacity","visibility","height","position"];function Vy({snapshot:n,devicePixelRatio:e,logger:t}){let r=n.strings,o=n.documents,i={},a={},s={roots:[],backendIdToNode:i,frameIndexToIframeNode:a};return o.forEach((l,c)=>{let d=xL({allDocuments:o,stringConstants:r,frameIndex:c,devicePixelRatio:e,backendIdToNode:i,frameIndexToIframeNode:a,logger:t});s.roots.push(d)}),s}function xL({allDocuments:n,stringConstants:e,devicePixelRatio:t,frameIndex:r,frameIndexToIframeNode:o,backendIdToNode:i,logger:a}){let s=n[r],l=s.layout,c={};l.nodeIndex.forEach((C,A)=>{c[C]=A});let d=l.styles,p=l.bounds??[],m=s.nodes,u=m.contentDocumentIndex??{index:[],value:[]},h=m.backendNodeId??[],g=m.attributes??[],f=m.parentIndex??[],S=m.nodeName??[],b=m.nodeType??[],w=m.pseudoType??{index:[],value:[]},v=m.inputChecked??{index:[]},x=e[s.frameId];for(let C=0;C<h.length;C++){let A=h[C],N=b[C],O=g[C]??[],H=f[C]!==void 0&&f[C]>=0?f[C]:void 0,F=H!==void 0?h[H]:void 0,L=F!==void 0?i[F]:void 0,B=w.index.indexOf(C),P=B!==-1?e[w.value[B]]:void 0,K=c[C],U;K?U=p[K]??[]:U=[];let Y=S[C]!==void 0?e[S[C]]?.toLowerCase():void 0;if(!Y){a.warn({backendNodeId:A,frameId:x,frameIndex:r,nodeBounds:U},"DOM node has no tag name");continue}let Z={backendNodeId:A,psuedoType:P,nodeType:N,frameIndex:r,parentFrameId:x,ownedFrameId:void 0,bounds:{x:U[0]??null,y:U[1]??null,width:U[2]??null,height:U[3]??null},computedStyles:{},attributes:{},parentBackendNodeId:F??null,tagName:Y,parent:L??void 0,childrenBackendIds:[],momenticIgnored:void 0,mPathSelector:void 0};L&&L.childrenBackendIds.push(A);let ft=u.index.indexOf(C);if(ft!==-1){let we=u.value[ft];o[we]=Z;let Me=n[we]?.frameId;Z.ownedFrameId=Me!==void 0?e[Me]:void 0}for(let we of Object.keys(Z.bounds)){let Me=we;Z.bounds[Me]!==null&&(Z.bounds[Me]/=t)}let re=K!==void 0?d[K]??[]:[];for(let we=0;we<re.length&&!(we>=hl.length);we++){let Me=re[we];if(Me===void 0||isNaN(Me))continue;let _t=e[Me];if(_t===void 0)continue;let on=hl[we];Z.computedStyles[on]=_t}for(let we=0;we<O.length;we+=2){let Me=O[we],_t=O[we+1];if(!Me||!_t)continue;let on=e[Me],j=e[_t];!on||!j||(Z.attributes[on]=j)}v.index.includes(C)&&(Z.attributes.checked="true"),i[Z.backendNodeId]=Z}return i[h[0]]}function tp(n,e){if(n.mPathSelector)return n.mPathSelector;let t=n.parent,r;if(!t)r=n.tagName;else if(n.tagName==="body")r="body";else{let i=t.childrenBackendIds.filter(l=>e.backendIdToNode[l]?.nodeType===1&&!e.backendIdToNode[l]?.psuedoType).indexOf(n.backendNodeId),a=` > ${n.tagName}:nth-child(${i+1})`;r=`${tp(t,e)}${a}`}return n.mPathSelector=r,r}function $y({originalNode:n,candidate:e,logKey:t,logger:r}){if(!e.bounds)return r.debug({candidate:e},"Filtering out click candidate since it has no bounding box"),!1;let o=n.bounds,i=o.x??0,a=o.width??0,s=o.height??0,l=i+a,c=o.y??0,d=c+(o.height??0),p=e.bounds,m=p.width??0,u=p.height??0,h=p.x??0,g=h+(p.width??0),f=p.y??0,S=f+(p.height??0);return h<l&&g>i&&f<d&&S>c?Math.abs(a-m)<200||Math.abs(s-u)<200?!0:(Mr({logger:r,logKey:t,maxCount:5,intervalMs:3e3},{candidate:e,originalNode:n},"Filtering out click candidate since it has a significantly different area"),!1):(Mr({logger:r,logKey:t,maxCount:5,intervalMs:3e3},{candidate:e},"Filtering out click candidate since it does not intersect with the original node"),!1)}function gl(n,e,t){let r=Object.values(e.backendIdToNode),o,i=TL();for(let c of r)if(c.attributes?.[Tt]===n){o=c;break}if(!o)return[];let a=[],s=e.backendIdToNode[o.parentBackendNodeId??-1];for(;s&&(s?.momenticIgnored||!$y({originalNode:o,candidate:s,logKey:i,logger:t}));)s=e.backendIdToNode[s.parentBackendNodeId??-1];s&&a.push(s);let l=[o];for(;l.length;){let c=l.shift();for(let d of c.childrenBackendIds??[]){let p=e.backendIdToNode[d];p&&!p.momenticIgnored&&$y({originalNode:o,candidate:p,logKey:i,logger:t})?a.push(p):p&&l.push(p)}}return a}function Gy(n,e){return n.parentBackendNodeId!==null?e.backendIdToNode[n.parentBackendNodeId]:n.frameIndex===0?void 0:e.frameIndexToIframeNode[n.frameIndex]}var EL=["html","#document","#document-fragment"];function qy({node:n,domGraph:e}){let t=[],r=n,o=Gy(n,e);if(!o)return[n.tagName];let i=()=>{if(r=o,o=Gy(o,e),!o&&r.frameIndex!==0)throw new Error("No parent node but not in main frame")},a=0;for(;o&&a<1e6;){if(a++,EL.includes(r.tagName)){i();continue}if(r.tagName==="body")t.push("body");else{let l=!1,c=1;for(let d=0;d<o.childrenBackendIds.length;d++){let p=o.childrenBackendIds[d],m=e.backendIdToNode[p];if(p===r.backendNodeId){t.push(`${r.tagName}:nth-child(${c})`),l=!0;break}else m?.nodeType===1&&!m.psuedoType&&c++}if(!l)throw new Error(`Could not find child (${r.tagName}) in parent's children list (${o.tagName})`)}i()}return t.reverse()}function Ky(n,e){let t=n.locator("html"),r=[];for(let o=0;o<e.length;o++){let i=e[o];if(r.push(i),i.startsWith("iframe")){let a=r.join(" > ");r=[],o<e.length-1?t=t.frameLocator(a):t=t.locator(a)}}if(r.length&&(t=t.locator(r.join(" > "))),"owner"in t)throw new Error("Final locator from mpath is a frame locator");return t}async function Yy(n,e){await n.send({method:"DOM.getDocument",params:{depth:0},timeout:2e3});let t=await n.send({method:"DOM.requestNode",params:{objectId:e},timeout:2e3}),o=(await n.send({method:"DOM.getAttributes",params:{nodeId:t.nodeId},timeout:2e3})).attributes,i=hr(o,Tt);if(!i)throw new Error(`Could not find attribute ${Tt} for object ${e}`);return i}function Jy(n){let e=[];for(let t=0;t<n.domGraph.roots.length;t++){let r=n.domGraph.roots[t],o=CL({root:r,domGraph:n.domGraph,existingHashes:n.existingHashes,flagStore:n.flagStore,logger:n.logger});e=e.concat(o)}return e}function CL(n){let{root:e,domGraph:t,existingHashes:r}=n,o=[],i=[e];for(;i.length;){let a=i.pop();if(a.nodeType===1&&a.tagName.toLowerCase()==="svg"){let s=ml(a,t);s&&!r[s.hash]&&o.push(s)}for(let s of a.childrenBackendIds){let l=t.backendIdToNode[s];l&&i.push(l)}}return o}var AL=["focusable","keyshortcuts","controls","live","relevant","orientation"],IL=["selected","readonly","modal","required","invalid"],PL=["id","name","role","content"],Xy=["absolute","fixed","sticky"],LL=["path"],OL=["statictext","textbox","checkbox","combobox","iframe","rootwebarea","table","caption","columnheader","rowheader","gridcell","grid","row","rowgroup","cell","image","graphics-symbol","graphics-document","graphics-object","svgroot","button","link","list","listitem","tablist","tabpanel","tab","searchbox","menu","menubar","form","dialog","alertdialog","banner","navigation","main","menuitem","menuitemcheckbox","menuitemradio","option","radio","progressbar","switch","tree","treeitem","separator"],kL=["activeAriaModalDialog","activeFullscreenElement","activeModalDialog","ariaHiddenElement","ariaHiddenSubtree","hiddenByChildTree","inertElement","inertSubtree","notRendered","notVisible"],ML=["menulistpopup","statictext","inlinetextbox"],NL=80,Zy=100,fl=["StaticText","ListMarker","RootWebArea","LineBreak","emphasis","::before","::after"],_L=["cite"],DL={LabelText:["label"],listitem:["li"],image:["img","svg"],link:["a"],RootWebArea:["#document"],paragraph:["p"],LineBreak:["br"],separator:["hr"],"graphics-symbol":["svg","rect"],gridcell:["td","th"],SvgRoot:["svg"],navigation:["nav"],cell:["td","th"],row:["tr"],list:["ul"],heading:["h1","h2","h3","h4","h5","h6"]},FL={name:!0,value:!0,title:!0,alt:!0,placeholder:!0,checked:!0,selected:!0,contenteditable:!0},Qy={indentLevel:0},rp=class n{id;role;name;nameSources;tagName;content;properties;internalProperties;dataMomenticId;pathFromRoot;parent;children;parentFrame;domNode;backendNodeId;ignoredByCDP;constructor(e){if(this.id=e.id,this.role=e.role,this.name=e.name,this.nameSources=e.nameSources,this.content=e.content,this.properties={},this.pathFromRoot=e.pathFromRoot,this.children=e.children,this.backendNodeId=e.backendNodeID,this.ignoredByCDP=e.ignoredByCDP,this.internalProperties=e.internalProperties??{},this.parentFrame=e.parentFrame,e.properties&&e.properties.forEach(t=>{t.name==="keyshortcuts"?this.dataMomenticId=parseInt(t.value.value):this.properties[t.name]=t.value.value}),e.domNode){this.domNode=e.domNode,this.tagName=e.domNode.tagName||void 0;let t=e.domNode.attributes.id;this.name=this.name||e.domNode.attributes.name||(t&&!By(t)?t:""),this.role=this.role||(e.domNode.attributes.role??""),HL(this.properties,e.domNode)}$L(this)}getSerializedFormWithContext(){return this.serialize({noId:!0,maxLevel:1,neighbors:1})}getNodeOnlySerializedForm(){return this.serialize({noId:!0,noChildren:!0,noContent:!0})}getLogForm(){return JSON.stringify({id:this.id,name:this.name??"",role:this.role??"",backendNodeId:this.backendNodeId})}isInteresting(){if(this.domNode&&this.domNode.tagName==="div"&&!this.domNode.bounds.x&&!this.domNode.bounds.y&&!this.domNode.bounds.width&&!this.domNode.bounds.height||this.domNode&&LL.includes(this.domNode.tagName))return!1;if(OL.includes(this.role.toLowerCase()))return!0;if(this.domNode?.computedStyles.display==="contents")return!1;if(this.role.toLowerCase()==="inlinetextbox"&&this.tagName||!this.properties.hidden&&(this.properties.focusable||this.properties.settable)||$n.alwaysInterestingTruthyPropertyNames.some(t=>!!this.properties[t]))return!0;let e=this.properties.class;return typeof e=="string"&&e.split(" ").some(t=>rb(t))?!0:this.children.every(t=>t.role==="StaticText")&&this.internalProperties?.inCodeMirrorEditor?!1:this.children.some(t=>t.role==="StaticText")?!0:!!this.name.trim()||!!this.content||Object.keys(this.properties).some(t=>t.startsWith("data"))}serialize(e=Qy){let t=Object.assign({},Qy,e),{indentLevel:r,noChildren:o,noProperties:i,noId:a,noContent:s,condensedMode:l}=t,c=np(this.properties),d=" ".repeat(r),p=this.role||"",m=this.tagName??"unknown",u=this.name;p==="heading"&&u==="heading"&&(u=""),this.nameSources?.find(x=>!x.superseded&&x.type==="contents")&&this.children.length>0&&(u="");let g=this.nameSources?.find(x=>!x.superseded);if(g&&!g.nativeSource&&g.type==="relatedElement"){let x=g.attributeValue?.relatedNodes??[];x.length===1&&x[0].text&&x[0].text===u&&(u="")}let f=fl.includes(this.role)||_L.includes(this.tagName||"");if(this.role==="StaticText"||this.role==="ListMarker")return`${d}${u}
@@ -3599,17 +3599,17 @@ ${x}${d}</${m}>
3599
3599
  ${S}
3600
3600
  ${A||""}`}return S}shallowClone(){let e=new n({id:this.id,role:this.role,name:this.name,nameSources:this.nameSources,content:this.content,properties:[],pathFromRoot:this.pathFromRoot,children:[],backendNodeID:this.backendNodeId,ignoredByCDP:this.ignoredByCDP,internalProperties:np(this.internalProperties),parentFrame:this.parentFrame});return e.tagName=this.tagName,e.dataMomenticId=this.dataMomenticId,e.properties=np(this.properties),e}},op=class n{constructor(e,t,r,o){this.root=e;this.a11yIdNodeMap=t;this.dataMomenticIdMap=r;this.selectorToNodeMap=o}serialize(e){return this.root.serialize(e)}pruneUsingRelevantIds(e){let t=this.root;if(!t)throw new Error("Cannot prune a11y tree with no root");function r(i,a=!1){let s=e.has(`${i.id}`)||i.id===t?.id,l=i.shallowClone(),c=i.children,d=!1,p=[];for(let m of c){let u=r(m,s||d);u&&(p.push(u),u.parent=l,d=!0)}if(l.children=p,s||d)return l;if(fl.includes(i.role)&&a)return l}let o=r(t);return new n(o,this.a11yIdNodeMap,this.dataMomenticIdMap,this.selectorToNodeMap)}};function UL(n){return n.name?.value?`"${n.name.value}"`:n.role?.value&&n.role.value!=="none"&&n.role.value!=="generic"?`"${n.role.value}"`:`"${n.nodeId}"`}function BL(n,e,t,r){return n.bounds.x===null||n.bounds.y===null||n.bounds.height===null||n.bounds.width===null||n.bounds.width===0||n.bounds.height===0?!0:n.bounds.x+n.bounds.width<e.leftBound||n.bounds.x>e.rightBound?(Mr({logger:t,logKey:r,maxCount:5,intervalMs:3e3},{domNode:n,logKey:r},"Filtering out node since it is not in the viewport horizontally"),!1):n.bounds.y+n.bounds.height<e.upperBound||n.bounds.y>e.lowerBound?(Mr({logger:t,logKey:r,maxCount:5,intervalMs:3e3},{domNode:n,logKey:r},"Filtering out node since it is not in the viewport vertically"),!1):n.computedStyles.display==="none"?(t.debug({domNode:n},"Filtering out node since it has display none"),!1):!0}async function eb({node:n,parent:e,frameId:t,frameContext:r,axGraph:o,domGraph:i,inputNodeMap:a,showZeroOpacityElements:s,filterByViewport:l,viewportDetails:c,useMPaths:d,cdpClient:p,logger:m,callId:u}){if(!e&&n.parentId)throw new Error(`Got no parent for accessibility node ${n.nodeId}: ${JSON.stringify(n)}`);let h=(L,B={})=>{},g=n.backendDOMNodeId,f=ML.includes((n.role?.value).toLowerCase());if(!f&&g===void 0)return h("Filtering out node since it doesn't exist in the DOM"),[];let S=g?i.backendIdToNode[g]:void 0;if(!f&&!S)try{let L=await D(p.send({method:"DOM.describeNode",params:{backendNodeId:g}}),{milliseconds:750,fallback:()=>{m.debug("Timeout getting node from CDP while processing a11y tree")}});if(L&&L.node.nodeName.toLowerCase()==="slot"&&L.node.distributedNodes?.length)m.debug({redirectedDomNode:S,parentAXNode:e?.getNodeOnlySerializedForm(),originalAXNode:n,cdpResult:L},"Redirecting node to assigned slot");else return h("Filtering out node since it doesn't exist in the DOM",{cdpResult:L}),[]}catch(L){return h("Filtering out node since it doesn't exist in the DOM",{err:L}),[]}if(S&&e&&l&&c&&n.backendDOMNodeId&&!BL(S,c,m,u))return S.momenticIgnored=!0,[];if(S&&S.computedStyles.display==="none")return m.debug({domNode:S},"Filtering out node since it has display none"),S.momenticIgnored=!0,[];if(S&&!s&&S.computedStyles.opacity==="0")return S.momenticIgnored=!0,[];if(S&&S.attributes.tabindex==="-1"&&S.tagName.toLowerCase()==="input"&&(S.bounds.width??0)<10&&(S.bounds.height??0)<10)return Mr({logger:m,logKey:u,maxCount:5,intervalMs:3e3},{attributes:S.attributes},"Filtering out node since it is likely an invisible input that is non-interactive"),S.momenticIgnored=!0,[];let b=n.name?.value?typeof n.name.value=="string"?n.name.value:`${n.name.value}`:"",w=n.value?.value?typeof n.value.value=="string"?n.value.value:`${n.value.value}`:"",v=new rp({domNode:S,id:parseInt(n.nodeId),role:n.role?.value||"",name:b,nameSources:n.name?.sources,content:w,properties:n.properties,children:[],pathFromRoot:(e?`${e.pathFromRoot} `:"")+UL(n),backendNodeID:n.backendDOMNodeId,ignoredByCDP:n.ignored,internalProperties:{inCodeMirrorEditor:e?.internalProperties?.inCodeMirrorEditor},parentFrame:r.type==="root"?void 0:r}),x=r,C=a[t],A=t;if(S?.tagName.toLowerCase()==="iframe"&&S.ownedFrameId){let L=r.childFrames.find(K=>K.frameId===S.ownedFrameId),B=o[L?.frameId??""]?.root,P=a[L?.frameId??""];if(L&&B&&P){n.childIds&&n.childIds.length>0&&m.debug("Replacing existing node's children with children from the iframe");let K=B;n.childIds=K.childIds,x=L,C=P,A=L.frameId}}let N=S?.childrenBackendIds?.length??0,O=n.childIds?.length??0;if(N>O){let L=n.childIds?.map(P=>C.get(parseInt(P))).filter(Boolean).map(P=>P?.backendDOMNodeId).filter(P=>P!==void 0)??[],B=0;for(let P of S?.childrenBackendIds??[]){if(L.includes(P)){B=(n.childIds?.findIndex(ft=>C.get(parseInt(ft))?.backendDOMNodeId===P)??0)+1;continue}let K=i.backendIdToNode[P];if(!K||K?.tagName.toLowerCase()!=="svg")continue;let U=Math.floor(-1*Math.random()*1e7),Y={nodeId:U.toString(),parentId:n.nodeId,ignored:!1,backendDOMNodeId:P,frameId:A,role:{type:"string",value:"graphics-symbol"}};C.set(U,Y),n.childIds||(n.childIds=[]),n.childIds.splice(B,0,U.toString()),B++}}for(let L of n.childIds??[]){if(!L)continue;let B=C.get(parseInt(L));if(!B)continue;let P=await eb({node:B,parent:v,domGraph:i,axGraph:o,frameId:A,frameContext:x,inputNodeMap:a,cdpClient:p,logger:m,callId:u,filterByViewport:l,showZeroOpacityElements:s,viewportDetails:c,useMPaths:d});P.length&&(v.children=v.children.concat(P))}if(v.role==="StaticText"&&(v.children=[]),v.children.length===1&&v.children[0].role==="StaticText"){let L=v.name,B=v.children[0]?.name;(L===B||!B)&&(v.children=[])}let H=[];for(let L=v.children.length-1;L>=0;L--){let B=v.children[L];if(B.role!=="StaticText"){H.push(B);continue}if(L===0||v.children[L-1].role!=="StaticText"){H.push(B);continue}v.children[L-1].name+=B.name}if(v.children=H.reverse(),v.role==="generic"&&v.children.length===1){let L=v.children[0];if(v.name&&!fl.includes(L.role)&&v.name===L.name)return S&&(S.momenticIgnored=!0),v.children}if(!v.isInteresting()&&n.parentId)return S&&(S.momenticIgnored=!0),v.children;for(let L of v.children)L.parent=v;return jL(v),S&&d&&tp(S,i),[v]}function tb({node:n,a11yIdNodeMap:e,dataMomenticIdMap:t,logger:r,callId:o,domGraph:i,useMPaths:a,selectorToNodeMap:s,iconKnowledgeBase:l,startId:c=1}){n.id=c,c+=1,e[n.id]=n,n.dataMomenticId?t[n.dataMomenticId]=n:fl.includes(n.role);let d=n.backendNodeId,p=d!==void 0?i.backendIdToNode[d]:void 0;if(a&&p&&p.mPathSelector&&(s[p.mPathSelector]=n),l&&p&&p.tagName?.toLowerCase()==="svg"){let m=ml(p,i),u=m?l[m.hash]:void 0,h=u?u.description:void 0;u&&(n.properties["data-momentic-description"]=h)}for(let m of n.children)c=tb({node:m,a11yIdNodeMap:e,dataMomenticIdMap:t,logger:r,callId:o,startId:c,useMPaths:a,domGraph:i,selectorToNodeMap:s,iconKnowledgeBase:l});return c}async function nb({rawA11yGraph:n,domGraph:e,startingFrameId:t,logger:r,cdpClient:o,filterByViewport:i,showZeroOpacityElements:a,viewportDetails:s,useMPaths:l,frameContext:c,iconKnowledgeBase:d}){let p=t??"root",m=n[p]?.root;if(!m)throw new Error("A11y tree has no root");let u=RL(),h=v=>{let x=v.allNodes.filter(A=>!A.ignoredReasons?.find(O=>kL.includes(O.name))),C=new Map;return x.forEach(A=>{C.set(parseInt(A.nodeId),A)}),C},g={};Object.entries(n).forEach(([v,x])=>{g[v]=h(x)});let f=await eb({node:m,domGraph:e,parent:null,inputNodeMap:g,axGraph:n,frameId:p,frameContext:c,cdpClient:o,logger:r,callId:u,showZeroOpacityElements:a,filterByViewport:i,viewportDetails:s,useMPaths:l});if(f.length>1)throw new Error(`Something went horribly wrong processing the a11y tree, we got: ${JSON.stringify(f)}`);if(f.length===0)throw new Error("There are no accessible elements on this page or frame. Are you sure this website loads properly?");let S={},b={},w={};return tb({node:f[0],a11yIdNodeMap:S,dataMomenticIdMap:b,selectorToNodeMap:w,domGraph:e,logger:r,callId:u,useMPaths:l,iconKnowledgeBase:d}),new op(f[0],S,b,w)}function zL(n,e,t){if(n==="class"){if(t.tagName?.toLowerCase()==="svg")return e.split(" ").filter(i=>i.length<50&&!$n.bannedClassSubstrings.some(a=>i.includes(a))).slice(0,3).join(" ");let r=e.split(" "),o=[];for(let i of r)if(rb(i)){o.push(i);continue}return o.length?o.join(" "):null}if(e==="true")return!0;if(e==="false")return!1;try{let r=parseInt(e);if(!isNaN(r))return r}catch{}return n==="src"&&e.includes("base64")?e.slice(0,e.indexOf("base64")+6)+"...":e.length>60?e.slice(0,50)+"...":e}function HL(n,e){if(!e)return;Object.entries(e.attributes).forEach(([i,a])=>{if($n.relevantElementAttributes.includes(i)&&!PL.includes(i)&&!n[i]&&!i.startsWith("aria")){let s=zL(i,a,e);s!==null&&(n[i]=s)}});let t,r=[];if(e.computedStyles.position&&Xy.includes(e.computedStyles.position))t=e.computedStyles.position;else if(e.attributes.style){for(let i of Xy)if(e.attributes.style.includes(`position: ${i}`)){t=i;break}}t&&r.push(`position: ${t}`);let o;(e.computedStyles.opacity&&e.computedStyles.opacity==="0"||e.attributes.style&&e.attributes.style.includes("opacity: 0"))&&(o="opacity: 0"),o&&r.push(o),r.length>0&&(n.style=r.join("; "))}function jL(n){let e=n.properties.class;if(typeof e=="string"&&e.includes("cm-content")){n.children.forEach((i,a)=>{i.properties["cm-line-number"]=`${a+1}`});return}if(typeof e=="string"&&e.includes("notion-page-content")){n.children.forEach((i,a)=>{i.properties["block-number"]=`${a+1}`}),n.children.length>0&&(n.children[n.children.length-1].properties.description="This is the last block in the document. Click here to add new text to the end.");return}if(n.tagName==="table"){let i=[],a=n.children.find(l=>l.tagName==="thead");if(a){let l=a.children.find(c=>c.tagName==="tr");if(l){let c=l.children.filter(d=>d.tagName==="th");c.forEach((d,p)=>{d.properties["col-index"]||(d.properties["col-index"]=p+1),i?.push(He(d.name,100,!1))}),i?.length!==c.length&&(i=void 0)}}let s=0;for(let l of n.children)if(l.tagName==="tbody")for(let c=0;c<l.children.length;c++){let d=l.children[c];if(d.tagName!=="tr")continue;if(c===0&&!i?.length){let u=d.children.filter(h=>h.tagName==="th");if(u.length){if(i=u.map(h=>He(h.name,100,!1)),i.length===u.length)continue;i=void 0}}s+=1,d.properties["row-index"]||(d.properties["row-index"]=s);let p=d.children.filter(u=>u.tagName==="td"||u.tagName==="th"),m=p.length===i?.length;p.forEach((u,h)=>{u.tagName!=="th"&&(u.properties["col-index"]||(u.properties["col-index"]=h+1),m&&(u.properties.col||(u.properties.col=i[h])))})}}}function $L(n){let e=n.properties.class,t=typeof e=="string"&&e.includes("cm-content");n.internalProperties.inCodeMirrorEditor=n.internalProperties?.inCodeMirrorEditor||t}function rb(n){if($n.bannedClassSubstrings.some(e=>n.includes(e)))return!1;if($n.alwaysInterestingClassNames.includes(n))return!0;for(let e of $n.alwaysInterestingClassPrefixes)if(n.startsWith(e))return!0;return!1}var Sl=class n{constructor(e,t,r,o,i){this.session=e;this.logger=t;this.contextGetter=r;this.pageGetter=o;this.defaultTimeoutMs=i}cdpInitializingPromise=void 0;cdpCrashDetails=void 0;cdpFullyDead=!1;loadEventLogs=[];static async init({logger:e,contextGetter:t,pageGetter:r,defaultTimeoutMs:o}){let i=t(),a=r(),s,l;for(let d=0;d<2;d++)try{s=await D(i.newCDPSession(a),{milliseconds:o*d,fallback:()=>{throw new R("UserInfrastructureError",`Failed to initialize Chrome session within the page load timeout (${a.url()})`)}});break}catch(p){await te(500),l=p}if(!s)throw l;let c=new n(s,e,t,r,o);try{await D(c.registerHandlers(s),{milliseconds:o,message:`CDP handler registration timed out after ${o}ms`})}catch(d){throw c.cdpFullyDead=!0,new R("UserInfrastructureError",`Failed to initialize CDP client: ${d}`)}return c}async registerHandlers(e){e.on("Target.attachedToTarget",async()=>{try{await e.send("Runtime.runIfWaitingForDebugger")}catch(t){this.logger.warn({err:t},"Failed to run Runtime.runIfWaitingForDebugger")}}),e.on("Target.targetCrashed",t=>{this.cdpCrashDetails={...this.cdpCrashDetails??{},targetCrashDetails:JSON.stringify(t)},this.logger.error({payload:t},"CDP session crashed, Momentic will likely not function correctly")}),e.on("Inspector.targetCrashed",t=>{this.cdpCrashDetails={...this.cdpCrashDetails??{},inspectorCrashDetails:JSON.stringify(t)},this.logger.error({payload:t},"CDP inspector session crashed, Momentic will likely not function correctly")}),e.on("Page.frameRequestedNavigation",t=>{this.loadEventLogs.push(`[${Date.now()}] Frame requested navigation: ${JSON.stringify(t)}`)}),e.on("Page.navigatedWithinDocument",t=>{this.loadEventLogs.push(`[${Date.now()}] Navigated within document: ${JSON.stringify(t)}`)}),e.on("Page.lifecycleEvent",t=>{this.loadEventLogs.push(`[${Date.now()}] Page lifecycle event: ${JSON.stringify(t)}`)}),e.on("Page.loadEventFired",()=>{this.loadEventLogs.push(`[${Date.now()}] Page load event fired`)}),await e.send("Accessibility.enable"),await e.send("Page.enable"),await e.send("DOM.enable"),await e.send("Overlay.enable"),await e.send("DOMSnapshot.enable"),await e.send("CSS.enable")}async send({method:e,params:t,timeout:r=this.defaultTimeoutMs,timeoutMsg:o}){for(;this.cdpInitializingPromise;)await this.cdpInitializingPromise;if(this.cdpCrashDetails){if(this.cdpFullyDead)throw new R("UserInfrastructureError",`The browser inspector session encountered a critical crash: ${JSON.stringify(this.cdpCrashDetails)}`);this.logger.warn(`Detected crashed CDP client before method ${e}, reinitializing before proceeding...`),await this.reinitialize()}try{return await D(this.session.send(e,t),{milliseconds:r,message:o??`Chrome command ${e} timed out after ${r}ms. This is likely an infrastructure issue caused by a lack of compute resources or a crash at the browser level.`})}catch(i){throw["Internal error","Target crashed"].some(a=>i.message.includes(a))&&!this.cdpInitializingPromise&&(this.logger.warn({err:i},`CDP crashed during CDP method ${e}, re-initializing client`),await this.reinitialize()),i}}async createRawCDPSession(e=this.defaultTimeoutMs){let t=e,r=this.pageGetter(),o=await D(this.contextGetter().newCDPSession(r),{milliseconds:t,fallback:()=>{throw this.logger.error(`Failed to initialize CDP session within the page load timeout (${r.url()})`),new R("UserInfrastructureError",`Failed to initialize CDP session within the page load timeout (${r.url()})`)}});return this.logger.debug(`Created new CDP session for ${r.url()}`),o}async reinitialize(e=this.defaultTimeoutMs){await this.cdpInitializingPromise,this.cdpInitializingPromise=(async()=>{try{let t=this.session;this.session=await this.createRawCDPSession(e),await this.registerHandlers(this.session),this.logger.debug("Successfully reinitialized and attached new handlers to CDP session");try{await D(t.detach(),{milliseconds:1e3})}catch(r){this.logger.warn({err:r},"Failed to detach old CDP session after reinitialization, continuing...")}this.cdpCrashDetails=void 0,this.cdpFullyDead=!1}catch(t){this.cdpCrashDetails={...this.cdpCrashDetails??{},reinitializeError:`${t}`},this.cdpFullyDead=!0}finally{this.cdpInitializingPromise=void 0}})(),await this.cdpInitializingPromise}on(e,t){return this.session.on(e,t),this.session}off(e,t){return this.session.off(e,t),this.session}addListener(e,t){return this.session.addListener(e,t),this.session}removeListener(e,t){return this.session.removeListener(e,t),this.session}};import{mkdirSync as GL,rmSync as ob,statSync as WL}from"fs";import*as sp from"node:fs";import VL from"nodejs-file-downloader";import{tmpdir as qL}from"os";import gr,{basename as KL,dirname as YL}from"path";var lp="file://",ap=gr.join(qL(),"momentic","downloads"),ip=1e4,JL=50*1024*1024;async function ib(n){let{uri:e}=n;return e.startsWith(lp)?ZL(n):e.startsWith("http")?eO(n):QL(n)}function XL(n,e){let t=gr.join(ap,n,e.slice(lp.length)),r=gr.join(ap,n),o=t.startsWith(r);if(!sp.existsSync(t)||!o)throw new R("UserConfigurationError",`The referenced file (${e}) does not exist. Please make sure that it has been downloaded successfully.`);return t}async function ZL({uri:n,orgId:e}){let t=XL(e,n);return{filePath:t,cleanup:()=>{ob(YL(t),{recursive:!0,force:!0})}}}async function QL({uri:n}){let e=gr.resolve(n);if(!sp.existsSync(e))throw new R("UserConfigurationError",`The referenced file (${n}) does not exist on disk. Please make sure that it has been downloaded successfully.`);return{filePath:e,cleanup:()=>{}}}async function eO({uri:n,logger:e,orgId:t}){let r=new URL(n);r.search&&(r.search="");let o=KL(r.href),i=dp(o),a=gr.extname(i);if(wh.includes(a))throw new Error(`Downloading files with extension ${a} is not allowed.`);let s=cp(t),l=new VL({url:n,fileName:i,directory:s,maxAttempts:2,headers:{"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/93.0.4577.82 Safari/537.36"},timeout:ip}),{downloadStatus:c,filePath:d}=await D(l.download(),{milliseconds:ip,message:`Download timed out after ${ip}ms`});if(c!=="COMPLETE")throw new Error(`Download ended in non-success status: ${c}`);if(!d)throw new Error("File path of successfully downloaded file was empty");let m=WL(d).size;if(m>JL)throw new Error("File size exceeds the maximum limit of 50MB");e.info({fileSizeInBytes:m,filePath:d,fileName:i},"Downloaded file to disk");let u;return{filePath:d,cleanup:()=>{clearTimeout(u),u=setTimeout(()=>ob(s,{recursive:!0,force:!0}),10*60*1e3)}}}function ab(n,e){return`${lp}${n}/${e}`}function cp(n){let e=Math.random().toString(36).substring(4),t=gr.join(ap,n,e);return GL(t,{recursive:!0}),t}function dp(n){let e=gr.extname(n),t=gr.basename(n,e);return n=(t.length>100?t.slice(t.length-100):t)+e,n=n.trim().replaceAll(" ","_"),n}async function gn(n,e){try{return await n.evaluate(r=>window.serializeElementOnlyWithText?.(r,{truncateToLength:500}),void 0,{timeout:1e3})}catch(t){e.debug({err:t},"Failed to get HTML from locator for Playwright error translation");return}}var yl=class{limit;windowMs;userActions;constructor(e,t){this.limit=e,this.windowMs=t,this.userActions=new Map}_cleanup(e,t="DEFAULT_USER"){let r=Date.now(),o=`${t}:${e}`;if(this.userActions.has(o)){let a=this.userActions.get(o)?.filter(s=>r-s<=this.windowMs)??[];a.length>0?this.userActions.set(o,a):this.userActions.delete(o)}}increment(e,t="DEFAULT_USER"){let r=Date.now(),o=`${t}:${e}`;this._cleanup(t,e),this.userActions.has(o)||this.userActions.set(o,[]);let i=this.userActions.get(o);return i.length>=this.limit?!0:(i.push(r),!1)}};async function sb(n,e){let t=n.evaluate(async()=>{let i=window,a={};try{let s=await indexedDB.databases();for(let l of s){if(!l.name)continue;let c=await i.exportIdbToObject?.(l.name,l.version);c&&(a[l.name]=c)}return[a,void 0]}catch(s){return[void 0,s.message]}}),[r,o]=await D(t,{milliseconds:3e3});return o&&e.warn({err:o},"Failed to fetch indexedDB data"),r}async function lb(n,e,t){if(e){t.debug("Importing indexedDB data");try{let r=n.evaluate(async o=>{let i=window;for(let[a,s]of Object.entries(o))await i.importObjectToIdb?.(a,s)},e);await D(r,{milliseconds:3e3})}catch(r){t.warn({err:r},"Failed to import indexedDB data")}}}async function cb(n,e){try{let t=n.evaluate(async()=>{window.localStorage.clear(),window.sessionStorage.clear(),await indexedDB.databases().then(r=>{r.forEach(o=>{o.name&&indexedDB.deleteDatabase(o.name)})})});await D(t,{milliseconds:3e3})}catch(t){e.debug({err:t},"Failed clearing index db data, continuing...")}}async function db(n,e,t,r,o){try{await tO(n,e,t,r)}catch(i){o.error({err:i,tabIndex:e},"Error handling new console log")}}async function tO(n,e,t,r){let o=r.text();o.length>Ca&&(o=o.slice(0,Ca)+"...(TRUNCATED)");let i=[];for(let a of r.args())try{let s=await a.jsonValue(),l=JSON.stringify(s);l.length>Ca?i.push(l.slice(0,Ca)+"...(TRUNCATED)"):(typeof s!="object"||Object.keys(s).length>0)&&i.push(s)}catch{}pp(n,t,e,{url:n.url(),location:r.location(),type:r.type(),text:r.text(),args:i})}function pp(n,e,t,r){let o=Date.now(),i=e.logsPerPage;if(i.length<=t||i[t]===void 0){i[t]=[];for(let a=0;a<t;a++)i[a]===void 0&&(i[a]=[])}i[t].length>Qd&&(i[t]=i[t].slice(Math.floor(Qd/2)),i[t]?.push({url:n.url(),timestamp:o,type:"warning",text:"[MOMENTIC] Truncated console logs due to buffer overflow",tabIndex:t})),i[t].push({...r,tabIndex:t,timestamp:o})}async function nn({fn:n,codePath:e,logObject:t,signal:r,logger:o}){r?.throwIfAborted();let i=Date.now(),a=await ta({promiseGenerator:n,signal:r,codePath:e,logger:o}),s=Date.now();return t[e]=s-i,a}import{randomUUID as nO}from"crypto";var rO="[redacted due to size]",oO=1e4;async function gb(n,e,t){let r=new Date().toISOString();e.harPages||(e.harPages={}),e.harPages[n]={id:n,startedDateTime:r,title:void 0,pageTimings:{}}}async function fb(n,e,t,r){try{await iO(n,e,t)}catch(o){o.message.includes("browser has been closed")||r.warn({err:o,pageId:n},"Error handling new network request, skipping...")}}function Jr(n){return n<0?0:n}function pb(n){return{timings:{blocked:Jr(n.domainLookupStart),dns:Jr(n.domainLookupEnd-n.domainLookupStart),connect:Jr(n.connectEnd-n.connectStart),send:Jr(n.responseStart-n.requestStart),wait:0,receive:Jr(n.responseEnd-n.responseStart),ssl:Jr(n.connectEnd-n.secureConnectionStart)},total:Jr(n.responseEnd)}}async function iO(n,e,t){let r=nO(),o=t.timing(),i=new URL(t.url()),a=[...i.searchParams.entries()].map(([h,g])=>({name:h,value:g})),s={...await hb(t),url:i.toString(),method:t.method(),queryString:a,postData:await sO(t)},l={pageref:n,_resourceType:t.resourceType(),startedDateTime:new Date(o.startTime).toISOString(),request:s,timings:pb(o).timings};ub(e,l,r);let c=await t.response();if(c){await c.finished();let h={};try{h=await lO(c)}catch{}let g={...await hb(c),status:c.status(),statusText:c.statusText(),content:h,redirectURL:c.headers().location};l.response=g}let d;try{d=await t.sizes(),l.request.bodySize=d.requestBodySize,l.request.headersSize=d.requestHeadersSize}catch{}l.response&&d&&(l.response.bodySize=d.responseBodySize,l.response.headersSize=d.responseHeadersSize,l.response.content.size=d.responseBodySize);let p=t.timing(),{timings:m,total:u}=pb(p);l.time=u,l.timings=m,ub(e,l,r)}function ub(n,e,t){n.harEntries||(n.harEntries={}),n.harEntries[t]=e}function mb(n){try{return new Date(n).toISOString()}catch{return}}function aO(n){let e={name:"",value:""},t=!0;for(let r of n.split(/; */)){let o=r.indexOf("="),i=o!==-1?r.substring(0,o).trim():r.trim(),a=o!==-1?r.substring(o+1,r.length).trim():"";if(t){t=!1,e.name=In(i),e.value=In(a);continue}i==="Domain"&&(e.domain=In(a)),i==="Expires"&&(e.expires=mb(a)),i==="HttpOnly"&&(e.httpOnly=!0),i==="Max-Age"&&(e.expires=mb(Date.now()+ +a*1e3)),i==="Path"&&(e.path=In(a)),i==="Secure"&&(e.secure=!0)}return e}async function hb(n){let e=await n.headersArray(),t=[];for(let r of e.filter(o=>o.name.toLowerCase()==="cookie"))t.push(...r.value.split(";").map(aO));return{headers:e.map(r=>({name:In(r.name),value:In(r.value)})),cookies:t}}async function sO(n){let e=n.postData();if(!e)return;let t=await n.headerValue("content-type"),r={mimeType:t??"application/octet-stream",text:In(e),params:[]};if(t==="application/x-www-form-urlencoded"){let o=new URLSearchParams(e.toString());for(let[i,a]of o.entries())r.params.push({name:In(i),value:a?In(a):void 0})}return r}async function lO(n){return{mimeType:await n.headerValue("content-type")??void 0,text:In(await n.text()),encoding:await n.headerValue("content-encoding")??void 0}}function In(n){return n.length>oO?rO:n}function Sb(){return async n=>{let{fragment:e,code:t,context:r}=n,{env:o}=r||{},i=Object.getPrototypeOf(async function(){}).constructor;return{result:await Promise.resolve(new i("env",e?`return ${t}`:t)(o))}}}async function Xe({root:n,fn:e,arg:t,timeout:r,waitForPageLoad:o,codePath:i}){return await o(),await D(n.evaluate(e,t),{milliseconds:r,message:`Timed out executing code path ${i} after ${r}ms`})}function up(){return window.lastCursorPos}import{errors as cO}from"playwright-core";async function Xr({func:n,action:e,logger:t,callbacks:r,retryTimeoutMs:o,targetingResult:i}){let a=Date.now(),s;for(;Date.now()-a<o;)try{return await n(i)}catch(l){let c=l;if(Ji(c)){t.warn("Attempting to recover from removed data-momentic-ids by re-adding ids to DOM");let[d]=await Promise.all([n(i),r.getBrowserState({skipWaitForPageLoad:!0,skipWait:!0})]);return d}else if(c instanceof cO.TimeoutError)t.warn({err:c,rootUrl:(await r.state.getRoot()).url()},`Encountered Playwright error while performing ${e}`),s=await dO(c,i.locator,r,t);else throw c}throw s instanceof R?s:new R("ActionFailureError",`Failed to interact with targeted element. Error: ${s.message}`,{errOptions:{cause:s}})}async function dO(n,e,t,r){return n.message.includes("attempt #")?pO(n,e,t,r):uO(n)}async function pO(n,e,t,r){let o=n.message.split(/- retrying \w+ action, attempt #\d+/).filter(l=>l.length>0);if(!o.length)return r.warn({err:n},"Failed to parse Playwright error message for translation, returning raw message"),n;let i=o.length>2?o[o.length-2]:o[0];i=i.replace(/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g,"").replaceAll(" - ","").trim().replaceAll(`
3601
3601
  `,";").replace(/\s+/g," ");let a="",s=await gn(e,r);if(s&&(a=`Target element HTML: ${He(s,100,!0)}`),i.includes("element is not enabled"))return new R("ActionFailureError",`The element you attempted to interact with was disabled for the entire timeout duration. Please explicitly wait for the element to be enabled, change the element description to target an interactive element, or turn on the 'disable stability checks' option. ${a}`,{errOptions:{cause:n}});if(i.includes("intercepts pointer events")){let l="",c=i.match(/<.*?data-momentic-id="(\d+)".*?intercepts pointer events/)?.[1];if(c){let d=(await t.state.getRoot()).locator(`[data-momentic-id="${c}"]`),p=await gn(d,r);p&&(l=`Covering element HTML: ${He(p,100,!0)}`)}return new R("ActionFailureError",`The element you attempted to interact with was covered by another element such as dropdown, popup, or dialog for the entire timeout duration. Please add a step to hide the covering element or turn on the 'disable stability checks' option. ${a}
3602
- ${l}`,{errOptions:{cause:n}})}if(i.includes("element is not visible")){let l="The element you attempted to interact with has no bounding box or is explicitly hidden.";try{let c=await e.boundingBox({timeout:1e3});c?c.height===0?l="The element you attempted to interact with has zero height.":c.width===0&&(l="The element you attempted to interact with has zero width."):l="The element you attempted to interact with has no bounding box."}catch{}return new R("ActionFailureError",`${l} Please explicitly wait for the element to be visible or turn on the 'disable stability checks' option. ${a}`,{errOptions:{cause:n}})}return i.includes("element is outside of the viewport")?new R("ActionFailureError",`The element requested was outside of the browser viewport for the entire duration of the action. Please ensure you are not using non-standard zoom settings and the element is visible on the page. ${a}`):n}function uO(n){let e=n.message;if(e.includes("waiting for locator")&&e.includes("data-momentic-id")&&!e.match(/attempting \w+ action/)&&!e.includes("locator.evaluate"))throw new R("ActionFailureError",`Interacting with the element timed out. This is usually caused by the web page itself performing too many CPU-intensive operations or a lack of resources on your machine. Error: ${e}`,{errOptions:{cause:n}});return n}async function yb(n){try{return await mO(n)}catch(e){n.logger.warn({err:e},"Failed to transform locator for Chakra click, continuing...");return}}async function mO({locator:n,logger:e}){let[t,r]=await n.evaluate(l=>[l.id,l.tagName.toLowerCase()],{timeout:1e3}),o=await gn(n,e),i=await n.boundingBox({timeout:1e3});if(i===null){e.warn({elementDisplayString:o},"Attempting to click on element with no bounding box, not performing Chakra redirection");return}if(i.width>5||i.height>5)return;if(r==="input"&&t)try{let l=n.page().locator(`label[for=${JSON.stringify(t)}]`);return await l.waitFor({state:"visible",timeout:1e3}),{locator:l,relativePoint:void 0}}catch{}let a=await n.evaluate(l=>{let c=window;if(!c.CssSelectorGenerator)return{type:"error",error:"[MOMENTIC] Missing CSS selector libraries"};let d=l.parentElement;if(!d)return{type:"error",error:"Input click target has no parent for redirection"};let p=c.CssSelectorGenerator.getCssSelector(d,{}),m=l.getBoundingClientRect(),u=d.getBoundingClientRect();if(u.width===0||u.height===0)return{type:"error",error:"Parent element has no width or height"};let h={x:Math.min(Math.max(1,m.left-u.left),u.width-1),y:Math.min(Math.max(1,m.top-u.top),u.height-1)};return{type:"result",selector:p,relativePoint:h,serializedForm:d.outerHTML.slice(0,500)}},{timeout:1e3});if(a.type==="error")throw new Error(a.error);let s=n.page().locator(a.selector);return await s.waitFor({state:"visible",timeout:1e3}),e.info({parentElementResult:a,originalElementDisplayString:o},`Redirected click to parent element with selector: ${a.selector}`),{locator:s,relativePoint:a.relativePoint}}var wb=["date","datetime-local","month","time","week"],bb={date:/^\d{4}-\d{2}-\d{2}$/,"datetime-local":/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}$/,month:/^\d{4}-\d{2}$/,time:/^\d{2}:\d{2}$/,week:/^\d{4}-W\d{2}$/};async function vb(n){try{await D(hO(n),{milliseconds:3e3})}catch(e){n.logger.warn({err:e},"Failed to transform native datetime input, continuing...")}}async function hO({root:n,text:e,options:t,logger:r,callbacks:o}){let i=(await Xe({root:n,fn:()=>document.activeElement?.getAttribute("type")??"",timeout:1e3,arg:void 0,waitForPageLoad:o.waitForPageLoad,codePath:"transformNativeDateTimeInputFillHelper"})).toLowerCase();if(!bb[i])return;bb[i].test(e)&&r.warn(`Detected datetime input (${e}) in normalized format - this may fail to fill correctly as it is not how the user would input the value`),t.clearContent=!1,r.debug("Transforming datetime input to use sequential key presses")}async function bl({locator:n,callbacks:e,logger:t,timeoutMs:r=1e3}){try{await mp(e,r);let o=n.evaluate(i=>{let a=window;a.momenticIsEligible=p=>{let u=window.getComputedStyle(p,null).getPropertyValue("display");if(u==="none"||u==="contents")return!1;let h=p.getBoundingClientRect();return!(!h.height||!h.width)},a.removeHighlightTimers=a.removeHighlightTimers||[],a.removeHighlightFunctions=a.removeHighlightFunctions||{};let s=0;for(;!a.momenticIsEligible(i)&&s<3;){if(!i.parentElement)throw new Error("No eligible non-empty parent found for highlighting");i=i.parentElement,s++}let l=i.style.getPropertyValue("outline"),c=i.style.getPropertyPriority("outline");i.style.setProperty("outline","5px dashed rgb(255, 0, 153)","important");let d=`momentic${Math.floor(Math.random()*1e7)}`;a[d]=()=>{i.style.removeProperty("outline"),i.style.setProperty("outline",l,c),i.getAttribute("style")||i.removeAttribute("style")},a.removeHighlightTimers.push(setTimeout(()=>{a[d](),a.removeHighlightFunctions?.[d]&&delete a.removeHighlightFunctions[d]},5e3)),a.removeHighlightFunctions[d]=a[d]},void 0,{timeout:r});return await D(o,{milliseconds:r}),!0}catch(o){return t.debug({err:o},"Failed to add node highlight, a page navigation likely occurred. This is non-fatal for tests."),!1}}async function mp(n,e=1e3){let t=await n.state.getRoot();await Xe({root:t,fn:()=>{let o=window,i=o.removeHighlightTimers||[];for(;i.length;){let a=i.pop();clearTimeout(a)}Object.values(o.removeHighlightFunctions??{}).forEach(a=>{a()})},timeout:e,arg:void 0,waitForPageLoad:n.waitForPageLoad,codePath:"removeAllHighlights"})}async function gp(n){let e=n.flagStore.isBooleanFlagEnabled("visual_actions");return Xr({action:"clicking element",targetingResult:n.targetingResult,logger:n.logger,retryTimeoutMs:n.retryTimeoutMs,callbacks:n.browserCallbacks,func:async t=>hp({...n,targetingResult:t,useVisualClick:e})})}async function yO(n,e){let{redirectionAttempts:t=0}=e;if(t>=2)throw n;try{return await bO(n,e)}catch(r){throw e.redirectionAttempts===0?(e.logger.error({redirectionAttemptError:r,originalError:n},"Error handling click error, rethrowing original error"),n):r}}async function bO(n,e){let{logger:t,redirectionAttempts:r=0,browserCallbacks:o,actionSource:i}=e,a=e.targetingResult.locator,s=o.state.getDomGraph();if(n.message.includes("label")&&n.message.includes("for=")&&n.message.includes("intercepts pointer events")){let l=await a.getAttribute("id",{timeout:1e3});if(!l)throw n;let c=a.page().locator(`[for=${JSON.stringify(l)}]`);return await c.waitFor({state:"visible",timeout:1e3}),t.warn({err:n},"Attempting locator redirection due to input being covered by label"),hp({...e,targetingResult:{locator:c},redirectionAttempts:r+1})}else if(i==="click"&&s&&n.message.includes("intercepts pointer events")){t.warn({err:n},"Attempting locator redirection due to covering error");let l=await EO(a,s,t);if(l)return hp({...e,targetingResult:{locator:l},redirectionAttempts:r+1});throw t.error({err:n},"No updated locator could be found to fix covering error, rethrowing"),n}else throw t.error({err:n},"Click error does not match any known recoverable patterns, rethrowing"),n}async function wO(n){let{browserCallbacks:e,logger:t,targetingResult:r,position:o,options:i}=n,a=await e.state.getRoot(),s=a&&a!==r.locator.page()&&"frameElement"in a?await a.frameElement():null,l;try{l=s?await Br({promiseGenerator:async()=>s.boundingBox(),timeoutMs:3e3,logger:t}):null}catch(u){throw new R("UserInfrastructureError",`The frame containing the element Momentic was instructed to interact with was removed. Error: ${u.message}`)}finally{await s?.dispose()}let c=Date.now(),{clickX:d,clickY:p,reason:m}=await xO({frameCoordinates:l,logger:t,targetingResult:r,position:o,options:i});t.debug({frameCoordinates:l,position:o,targetingResultHints:r.hints,options:i,clickLocation:{clickX:d,clickY:p,reason:m},duration:Date.now()-c},"Visual click")}async function vO(n){let{actionSource:e,targetingResult:t,options:r,logger:o}=n,i=n.targetingResult.locator,a=r?.relativePosition??n.position;if(e==="click"&&!a){let l=await yb({locator:i,logger:o});l&&(i=l.locator,a=l.relativePoint??a)}let s=r?.force||t.hints?.force||!1;try{r?.doubleClick?await i.dblclick({button:r.rightClick?"right":"left",timeout:3e3,position:a,delay:r?.delayMs??25,force:s}):await i.click({button:r?.rightClick?"right":"left",timeout:3e3,position:a,delay:r?.delayMs??25,force:s})}catch(l){let c=l;if(RO(c))o.warn({err:c},"Click action timed out while waiting for navigation after completion, continuing...");else return o.error({err:c},"Error clicking on locator, attempting to recover..."),yO(c,{...n,targetingResult:{...i,locator:i}})}}async function hp(n){let{options:e,logger:t,browserCallbacks:r,controllerCallbacks:o,useVisualClick:i,targetingResult:a}=n,s;e?.waitForDownload&&(s=(async()=>{let l=e.downloadTimeoutMs??3e4;try{return await a.locator.page().waitForEvent("download",{timeout:l})}catch(c){return c instanceof SO.TimeoutError?new R("ActionFailureError",`Download did not complete in ${l}ms`):new R("ActionFailureError",`Download failed: ${c.message}`)}})());try{await bl({locator:a.locator,callbacks:r,logger:t,timeoutMs:1e3})}catch(l){t.warn({err:l},"Error highlighting locator in click, continuing...")}if(i?await wO(n):await vO(n),e?.waitForDownload)if(s){if(!o?.createIsolatedFolder)throw new R("InternalWebAgentError","Cannot wait for download without a callback to create an isolated folder");t.info("Waiting for download to start and complete");let l=await D(s,{milliseconds:e.downloadTimeoutMs??3e4});if(l instanceof Error)throw l;return{downloadedFile:await CO(l,o.createIsolatedFolder,t)}}else throw new Error("No download promise or error but the step requested to wait for a download")}async function TO(n,e){if(e.hints?.clickableXY){let i=(n?.x??0)+e.hints.clickableXY.x,a=(n?.y??0)+e.hints.clickableXY.y;return[{x:i,y:a},"targeting hint"]}let t=await e.locator.boundingBox({timeout:1e3});if(!t)throw new R("ActionFailureError","Element does not have a bounding box");let r=t.x+t.width/2,o=t.y+t.height/2;return[{x:r,y:o},"halfway point of the bounding box"]}async function xO({frameCoordinates:n,logger:e,options:t,targetingResult:r,position:o}){let i,a,s;if(o){let p=await r.locator.boundingBox({timeout:3e3});i=(n?.x??0)+(p?.x??0)+o.x,a=(n?.y??0)+(p?.y??0)+o.y,s="predefined position"}else{let[p,m]=await TO(n,r);i=p.x,a=p.y,s=m}let l=r.locator.page(),c=t?.rightClick?"right":"left",d=t?.delayMs??25;return t?.doubleClick?await l.mouse.dblclick(i,a,{button:c,delay:d}):await l.mouse.click(i,a,{button:c,delay:d}),{clickX:i,clickY:a,reason:s}}async function EO(n,e,t){let r=await n.evaluate(s=>s.getAttribute("data-momentic-id"));if(!r)return;let o=gl(r,e,t);if(!o.length){t.error("No candidates found for parent-based locator redirection");return}let i=parseInt(o[0].attributes?.[Tt]??"");if(isNaN(i))return;n=n.page().locator(`[data-momentic-id="${i}"]`);let a=await gn(n,t);return t.warn({candidateMomenticId:i,serializedHtml:a},"Trying new locator based on parent-direction after covering error"),n}async function CO(n,e,t){t.info("Download detected, saving file to disk");let r=await n.path(),o=dp(n.suggestedFilename()),i=e();await n.saveAs(fO(i,o)),xb(r,{force:!0}),setTimeout(()=>{xb(i,{recursive:!0,force:!0})},5*60*1e3);let a=ab(gO(i),o);return t.debug({uri:a,downloadFolder:i},"Saved download to isolated folder"),a}function RO(n){return n.message.includes("locator.click: Timeout")&&n.message.includes("click action done")}import{platform as AO}from"os";var IO={goToNextWord:{win32:"Control+ArrowRight",darwin:"Alt+ArrowRight",linux:"Control+ArrowRight"},goToPreviousWord:{win32:"Control+ArrowLeft",darwin:"Alt+ArrowLeft",linux:"Control+ArrowLeft"},selectNextWord:{win32:"Control+Shift+ArrowRight",darwin:"Alt+Shift+ArrowRight",linux:"Control+Shift+ArrowRight"},selectPreviousWord:{win32:"Control+Shift+ArrowLeft",darwin:"Alt+Shift+ArrowLeft",linux:"Control+Shift+ArrowLeft"},selectToStartOfLine:{win32:"Shift+Home",darwin:"Meta+Shift+LeftArrow",linux:"Shift+Home"},selectToEndOfLine:{win32:"Shift+End",darwin:"Meta+Shift+RightArrow",linux:"Shift+End"},deleteNextWord:{win32:"Control+Delete",darwin:"Alt+Fn+Delete",linux:"Control+Delete"},deletePreviousWord:{win32:"Control+Backspace",darwin:"Alt+Delete",linux:"Control+Backspace"}};function PO(){let n=AO();return n==="win32"?"win32":n==="darwin"?"darwin":"linux"}function Eb(n){return JSON.stringify(n.split("+").sort())}function Cb(n){let e=PO(),t=Eb(n);for(let r of Object.values(IO))if(Object.values(r).some(o=>Eb(o)===t))return r[e];return process.platform==="darwin"?n=n.replaceAll("Control","Meta"):n=n.replaceAll("Meta","Control"),n}async function fp({frame:n,page:e,deltaX:t,directionX:r,deltaY:o,directionY:i,signal:a,callbacks:s}){if(!t&&!o)return;let l=r==="left"?-1:1,c=i==="up"?-1:1;if(n)await Xe({root:n,fn:([d,p,m,u])=>window.scrollTo(window.scrollX+(d??window.innerWidth)*m,window.scrollY+(p??window.innerHeight)*u),arg:[t,o,l,c],waitForPageLoad:s.waitForPageLoad,timeout:2e3,codePath:"scrollFrame"});else{let d=e.viewportSize()||Gt,p=await Xe({root:e,fn:()=>document.body.scrollHeight,arg:void 0,waitForPageLoad:s.waitForPageLoad,timeout:2e3,codePath:"scrollPageGetHeight"}),[m,u,h]=await Xe({root:e,fn:()=>{let f=document.activeElement;if(!f)return[void 0,void 0,void 0];let S=f.getBoundingClientRect();return[f.scrollTop,S.x,S.y]},arg:void 0,waitForPageLoad:s.waitForPageLoad,timeout:2e3,codePath:"scrollPage"});await e.mouse.wheel((t??d.width)*l,(o??d.height)*c);let g=Date.now();for(;Date.now()-g<2e3;){a?.throwIfAborted();let f=await D(e.evaluate(()=>document.body.scrollHeight),{milliseconds:1e3}),[S,b,w]=await D(e.evaluate(()=>{let v=document.activeElement;if(!v)return[void 0,void 0,void 0];let x=v.getBoundingClientRect();return[v.scrollTop,x.x,x.y]}),{milliseconds:1e3});if(f===p&&S===m&&b===u&&w===h)break;p=f,m=S,u=b,h=w,await te(500)}}}async function Sp(n,e){let t,r;for(let o=0;o<4;o++)try{return t=n.pages(),await Promise.all(t.map(async i=>{let a="";try{a=e?.getTitles?await i.title():""}catch{a="Unknown page"}return{title:a,url:i.url()}}))}catch(i){r=i,await te(500)}throw new Error(`Failed to get tab titles after all retries: ${r?.message}`)}var li="<empty>";function LO(n){return n.includes("doubleclick.net")||n.includes("googletagmanager.com")||n.includes("googlesyndication.com")||n.includes("s.amazon-adsystem.com")||n.includes("smartadserver.com")||n.includes("omnitagjs.com")||n.includes("x.adroll.com")}function Ab(n){let e=n.adFrameStatus?.adFrameType;return e==="child"||e==="root"||LO(n.url)}async function OO(n,e){let t=await n.send({timeout:3e3,method:"DOM.getFrameOwner",params:{frameId:e}}),o=(await n.send({timeout:3e3,method:"DOM.pushNodesByBackendIdsToFrontend",params:{backendNodeIds:[t.backendNodeId]}})).nodeIds[0],a=(await n.send({timeout:3e3,method:"DOM.describeNode",params:{backendNodeId:t.backendNodeId}})).node;return a.nodeId=o,a}async function ci({cdpClient:n,page:e,logger:t}){let r={type:"root",childFrames:[],page:e},o=[],[i]=await Promise.all([n.send({timeout:3e3,method:"Page.getFrameTree",params:{}}),n.send({timeout:3e3,method:"DOM.getDocument",params:{}})]),l=(i.frameTree.childFrames??[]).map(async(d,p)=>{if(Ab(d.frame))return null;try{return await Ib({cdpClient:n,rawFrameTree:d,indices:[p],parent:r,warnings:o,logger:t})}catch(m){return o.push(`Failed to get child frame: ${m}`),null}}),c=await Promise.all(l);return r.childFrames=c.filter(d=>d!==null),o.length&&t?.warn({warnings:o},"Got warnings when fetching frame tree"),r}async function Ib({cdpClient:n,rawFrameTree:e,indices:t,parent:r,warnings:o,logger:i}){let a=e.frame.id,s=await OO(n,a),l=s.attributes??[],c=null,d=[];for(let h of["src","name","id","title","srcdoc","sandbox"]){let g=hr(l,h);g&&(d.push(`${h}=${JSON.stringify(g)}`),h==="src"&&(c=g))}let p={type:"frame",cdpFrame:e.frame,url:e.frame.url,frameId:a,locationData:{indices:t,attributeSelectors:d},src:c,childFrames:[],parent:r,domNode:s},u=(e.childFrames??[]).map(async(h,g)=>{if(Ab(h.frame))return null;try{return await Ib({cdpClient:n,rawFrameTree:h,indices:[...t,g],parent:p,warnings:o,logger:i})}catch(f){return o.push(`Failed to get child frame (child ${g} of frame with url ${e.frame.url}): ${f}`),null}});return p.childFrames=(await Promise.all(u)).filter(h=>h!==null),p}async function kO(n){try{return await n.owner().count()===1}catch{return!1}}async function MO(n){try{return await n.count()===1}catch{return!1}}async function Pn(n,e){let t=[],r=n;for(;r.parent.type==="frame";)t.push(r.parent),r=r.parent;t.reverse();let o=e,i=[];for(let c of t){let d=!1;for(let p of[...c.locationData.attributeSelectors,li]){let m=o.frameLocator(p===li?"iframe":`iframe[${p}]`);if(await kO(m)){d=!0,o=m,i.push(p);break}}if(!d)throw new R("ActionFailureError",`Failed to find a unique attribute to identify intermediate frame with url matching '${c.url}'. Please attach a unique 'id', 'name', 'title', or 'src' attribute to the frame.`)}let a;for(let c of[...n.locationData.attributeSelectors,li]){let d=o.locator(c===li?"iframe":`iframe[${c}]`);if(await MO(d)){a=d,i.push(c);break}}if(!a)throw new R("ActionFailureError",`Failed to find a unique attribute to identify target frame with url matching '${n.url}'. Please attach a unique 'id', 'name', 'title', or 'src' attribute to the frame.`);let s=await a.evaluateHandle(c=>c,{timeout:1e3}),l=await s.asElement().contentFrame();if(!l)throw new R("InternalWebAgentError",`Failed to load Playwright Frame for iframe with url '${n.url}'`);return await s.dispose(),{frame:l,mPathSelectorTokens:i}}function Rb(n,e){let t=[...n],r=[];for(;t.length;){let o=t.shift();e(o)&&r.push(o),t.push(...o.childFrames)}return r}async function Pb({page:n,frameTree:e,cache:t}){let r,o=e.childFrames,i=[];if(t.mPathSelectorTokens.length){let s=o;for(let d=0;d<t.mPathSelectorTokens.length-1;d++){let p=t.mPathSelectorTokens[d];p===li?s=s.length===1?s[0].childFrames:[]:s=s.filter(m=>m.locationData.attributeSelectors.includes(p)).map(m=>m.childFrames).flat()}let l=[],c=t.mPathSelectorTokens[t.mPathSelectorTokens.length-1];if(c===li?l=s:l=s.filter(d=>d.locationData.attributeSelectors.includes(c)),l.length===1)return r=l[0],i.push(`Found unique frame with mpath ${t.mPathSelectorTokens.join(" > ")}`),{resolution:{type:"auto",frame:(await Pn(r,n)).frame,handle:r,mPathSelectorTokens:t.mPathSelectorTokens,frameTree:e},logs:i};i.push(`Found ${l.length} frames with mpath ${t.mPathSelectorTokens.join(" > ")}`)}if(t.frameSrcRegex){let s=new RegExp(t.frameSrcRegex),l=Rb(o,c=>!!c.src&&s.test(c.src));if(l.length===1)return r=l[0],i.push(`Found unique frame with src regex ${t.frameSrcRegex}`),{resolution:{type:"auto",frame:(await Pn(r,n)).frame,handle:r,mPathSelectorTokens:t.mPathSelectorTokens,frameTree:e},logs:i};i.push(`Found ${l.length} frames with src regex ${t.frameSrcRegex}`),t.frameSrcRegex=void 0}if(t.frameUrlRegex){let s=new RegExp(t.frameUrlRegex),l=Rb(o,c=>!!c.url&&s.test(c.url));if(l.length===1)return r=l[0],i.push(`Found unique frame with url regex ${t.frameUrlRegex}`),{resolution:{type:"auto",frame:(await Pn(r,n)).frame,handle:r,mPathSelectorTokens:t.mPathSelectorTokens,frameTree:e},logs:i};i.push(`Found ${l.length} frames with url regex ${t.frameUrlRegex}`),t.frameUrlRegex=void 0}let a=o;for(let s=0;s<t.indices.length-1;s++)a=a[t.indices[s]]?.childFrames??[];if(r=a[t.indices[t.indices.length-1]],r)return i.push(`Found unique frame with indices ${t.indices.join(" > ")}`),{resolution:{type:"auto",frame:(await Pn(r,n)).frame,handle:r,mPathSelectorTokens:t.mPathSelectorTokens,frameTree:e},logs:i};throw i.push(`Found ${a.length} frames with indices ${t.indices}`),new nr("Failed to find the iframe that previously contained this element",[{type:"AUTO_FRAME",matched:!1,logs:i}])}function wl(n){return n.type==="auto"?JSON.stringify({type:"auto",frameId:n.handle.frameId}):JSON.stringify(n)}function yp(n){for(;n.parent.type==="frame";)n=n.parent;return n.parent}function Lb(n){let e=yp(n),t=n.src??"",r=n.url??"",o=[],i=[],a=[...e.childFrames];for(;a.length;){let s=a.shift();s.src&&o.push(s.src),s.url&&i.push(s.url),a.push(...s.childFrames)}return{srcs:o,urls:i,desiredSrc:t,desiredUrl:r}}function Ob(n){return n.type==="auto"?{type:"auto",frameId:n.handle.frameId,url:n.handle.url,src:n.handle.src??"",mPathSelectorTokens:n.mPathSelectorTokens.join(" > ")}:{type:"url",url:n.url}}async function kb({frame:n,logger:e,signal:t}){let r;try{r=await n.frameElement(),await NO({frameElementHandle:r,logger:e,signal:t})}catch(o){e.warn({err:o},"Failed to scroll iframe into view, continuing...")}finally{await r?.dispose()}}async function NO({frameElementHandle:n,logger:e,signal:t}){let r=await n.boundingBox();if(!r){e.warn("Active frame element has null bounding box, skipping scroll");return}await Br({promiseGenerator:async()=>n.evaluate(async(i,{x:a,y:s})=>{window.scrollTo(window.scrollX+a,window.scrollY+s);let l=Date.now(),c,d,p;for(;Date.now()-l<1500;){let m=document.activeElement,u,h,g;if(!m)u=void 0,h=void 0,g=void 0;else{let f=m.getBoundingClientRect();u=m.scrollTop,h=f.x,g=f.y}if(c!==void 0&&d!==void 0&&p!==void 0&&u===c&&h===d&&g===p)break;c=u,d=h,p=g,await new Promise(f=>setTimeout(f,250))}},r),timeoutMs:2e3,codePath:"scrollIframeIntoView",signal:t}),e.info({bb:r},"Successfully scrolled iframe into view")}async function Mb({event:n,transformer:e,enricher:t,frame:r,lastScreenshotForRecording:o,logger:i}){let{warnings:a,error:s,properties:l}=n.target;if(s){i.error({error:s,warnings:a},"Error while capturing passive click");return}if(a.length&&i.warn({warnings:a},"Warnings while capturing passive click"),!l)return;let c=r.parentFrame()?r.url():void 0,p=r.page().frames().map(h=>h.url());i.debug({frameUrl:c,...n},"Passive click event captured on element");let m,u;if(c)try{let h=await r.frameElement();m=await D(h?.boundingBox(),{milliseconds:1e3})??void 0;let g=await t.constructIframeRegex({urls:p,srcs:[],desiredUrl:c});if(g.urlRegex)u={type:"url",url:`/${g.urlRegex}/`};else throw new Error(`Got no url regex options: ${JSON.stringify(g)}`)}catch(h){i.warn({err:h},"Failed to construct iframe details for recorded action, using hardcoded URL only"),u={type:"url",url:c}}(async()=>{try{await e.recordElementAction({...n,screenshotBase64:o,frameConfig:u,frameBoundingBox:m})}catch(h){i.error({err:h},"Failed to transform passive click action")}})()}import{randomUUID as Ln}from"crypto";import _O from"js-beautify";var DO=["Shift","CapsLock","Dead","Meta","AudioVolumeUp","AudioVolumeDown"];var vl=class{recordedSteps=new Map;callbacks;signal;generator;testId;orgId;nextStepOffset=0;logger;constructor({signal:e,callbacks:t,generator:r,testId:o,orgId:i,logger:a}){this.signal=e,this.logger=a,this.testId=o,this.orgId=i,this.callbacks={onStepRecorded:(s,l)=>{this.recordedSteps.set(l,{step:s}),t.onStepRecorded(s,l)},onActionReceived:(s,l)=>{this.recordedSteps.set(l,{step:s}),t.onActionReceived?.(s,l)}},this.generator=r}reserveIndexForCommand(e){let t=this.nextStepOffset;return this.recordedSteps.set(t,{step:{id:Ln(),type:"PRESET_ACTION",command:Nn(e)}}),this.nextStepOffset++,t}async recordElementAction(e){let{type:t,target:r,frameConfig:o}=e;if(this.signal.aborted){this.logger.debug("Transformer was already cleaned up, ignoring click...");return}let i,a,s=r.properties.attributes.nodeOnlySerializedHtml.trim(),l=s,c;switch(e.frameConfig?e.frameBoundingBox?c={x:e.frameBoundingBox.x+r.properties.boundingBox.x,y:e.frameBoundingBox.y+r.properties.boundingBox.y,width:r.properties.boundingBox.width,height:r.properties.boundingBox.height}:this.logger.warn(e,"No frame bounding box found, refusing to write bounding box"):c=r.properties.boundingBox,t){case"CLICK":{i="CLICK";let g=Nn(i);a={id:Ln(),type:"PRESET_ACTION",command:{...g,target:{type:"description",elementDescriptor:l},iframeUrl:o?.url,cache:{target:{id:-1,...r.properties.attributes,targetSource:"RECORDING",targetUpdateTime:new Date().toUTCString(),boundingBox:c}}}};break}case"SELECT":{i="SELECT_OPTION";let g=Nn(i);a={id:Ln(),type:"PRESET_ACTION",command:{...g,type:"SELECT_OPTION",iframeUrl:o?.url,target:{type:"description",elementDescriptor:l},cache:{target:{id:-1,...r.properties.attributes,targetSource:"RECORDING",targetUpdateTime:new Date().toUTCString(),boundingBox:c}},choice:{type:"VALUE",value:e.selectedValue??"Unknown option"}}};break}case"MOUSE_DRAG":{i="MOUSE_DRAG";let g=Nn(i);a={id:Ln(),type:"PRESET_ACTION",command:{...g,target:{type:"description",elementDescriptor:l},deltaX:e.deltaX.toString(),deltaY:e.deltaY.toString(),iframeUrl:o?.url,cache:{target:{id:-1,...r.properties.attributes,targetSource:"RECORDING",targetUpdateTime:new Date().toUTCString(),boundingBox:c}}}};break}default:throw new Error(`Unknown action type: ${t}`)}let d;e.offset===void 0?(d=this.nextStepOffset,this.nextStepOffset++):d=e.offset,this.callbacks.onActionReceived?.(a,d);let p=e.target.browserState;try{p=_O.html(p,{indent_size:1,indent_with_tabs:!1,preserve_newlines:!1}),p=zy(p,"data-momentic-interacted",4e4)}catch{}let m;try{m=(await this.generator.getReverseMappedDescription({target:p,screenshot:e.screenshotBase64?`data:image/jpeg;base64,${e.screenshotBase64}`:void 0,boundingBox:r.properties.boundingBox},{disableCache:!1,loggerTags:{testId:this.testId,...ze(this.logger)}})).phrase}catch(g){this.logger.error({err:g},"Error generating reverse mapping description"),m=s}let u=this.recordedSteps.get(d)?.step??a,h=u?.command;h&&"target"in h&&h.target?(h.target={type:"description",elementDescriptor:m},this.callbacks.onStepRecorded({...u,command:h},d)):this.logger.warn("Could not find existing command to update after description mapping")}recordKeystroke(e){let{key:t,combinable:r}=e;if(DO.includes(t)||this.signal.aborted)return;let o="normal";t.length>1&&(o="special");let i;if(o==="normal"){let p=Nn("TYPE");i={id:Ln(),type:"PRESET_ACTION",command:{...p,target:void 0,value:t,clearContent:!1}}}else{let p=Nn("PRESS");i={id:Ln(),type:"PRESET_ACTION",command:{...p,value:t}}}let a,s=this.nextStepOffset-1,l=this.recordedSteps.get(s),c=l?.step,d=c?.command;if(r){if(d?.type===i.command.type){let p=d.value,m=i.command.value;i={id:Ln(),type:"PRESET_ACTION",command:{...d,value:i.command.type==="PRESS"?`${p}+${m}`:`${p}${m}`}},a=s}else if(d?.type==="CLICK"&&i.command.type==="TYPE")c.command={...i.command,target:d.target,cache:d.cache},i=l.step,a=s;else if(d?.type==="TYPE"&&i.command.type==="PRESS"&&i.command.value==="Backspace"){let p=d.value;i={id:Ln(),type:"PRESET_ACTION",command:{...d,value:p.slice(0,p.length-1)}},a=s}}a===void 0&&(a=this.nextStepOffset,this.nextStepOffset++),this.callbacks.onStepRecorded(i,a)}recordScroll(e){if(this.signal.aborted)return;let t=()=>{let{deltaY:i}=e;if(!i)return;let a=this.nextStepOffset-1,s=this.recordedSteps.get(a)?.step.command,l;s?.type==="SCROLL_DOWN"&&s.deltaY?(i+=s.deltaY,l=a):s?.type==="SCROLL_UP"&&s.deltaY?(i-=s.deltaY,l=a):(l=this.nextStepOffset,this.nextStepOffset++);let c=i>0?"SCROLL_DOWN":"SCROLL_UP",d=Nn(c);d.deltaY=Math.abs(i);let p={id:Ln(),type:"PRESET_ACTION",command:d};this.callbacks.onStepRecorded(p,l)},r=()=>{let{deltaX:i}=e;if(!i)return;let a=this.nextStepOffset-1,s=this.recordedSteps.get(a)?.step.command,l;s?.type==="SCROLL_RIGHT"&&s.deltaX?(i+=s.deltaX,l=a):s?.type==="SCROLL_LEFT"&&s.deltaX?(i-=s.deltaX,l=a):(l=this.nextStepOffset,this.nextStepOffset++);let c=i>0?"SCROLL_RIGHT":"SCROLL_LEFT",d=Nn(c);d.deltaX=Math.abs(i);let p={id:Ln(),type:"PRESET_ACTION",command:d};this.callbacks.onStepRecorded(p,l)},o=this.recordedSteps.get(this.nextStepOffset-1);o?.step.command.type==="SCROLL_LEFT"||o?.step.command.type==="SCROLL_RIGHT"?(r(),e.deltaY>=20&&t()):(t(),e.deltaX>=20&&r())}};var Tl=class{smartWaitingTimeoutMs;pageLoadTimeoutMs;showZeroOpacityElements;allowPartialAccessibilityTree;logger;cdpClient;pageGetter;abortSignalGetter;flagStore;enricher;iconKnowledgeBase;activeFrameCache;activeFrameConfig;lastA11yIdToNodeMap={};lastDataMomenticIdToNodeMap={};lastSelectorToNodeMap={};lastA11yTreeRoot;lastDomGraph;constructor({smartWaitingTimeoutMs:e,pageLoadTimeoutMs:t,showZeroOpacityElements:r,allowPartialAccessibilityTree:o,logger:i,cdpClient:a,pageGetter:s,flagStore:l,abortSignalGetter:c,enricher:d,iconKnowledgeBase:p}){this.smartWaitingTimeoutMs=e,this.pageLoadTimeoutMs=t,this.showZeroOpacityElements=r,this.allowPartialAccessibilityTree=o,this.logger=i,this.cdpClient=a,this.pageGetter=s,this.flagStore=l,this.abortSignalGetter=c,this.enricher=d,this.iconKnowledgeBase=p}get frameConfig(){return this.activeFrameConfig}get domGraph(){return this.lastDomGraph}get selectorToNodeMap(){return this.lastSelectorToNodeMap}get dataMomenticIdToNodeMap(){return this.lastDataMomenticIdToNodeMap}get a11yIdToNodeMap(){return this.lastA11yIdToNodeMap}get a11yTreeRoot(){return this.lastA11yTreeRoot}setActiveFrameConfig(e){e?(this.activeFrameConfig=e,this.activeFrameCache=void 0):(this.activeFrameConfig=void 0,this.activeFrameCache=void 0)}reset(){this.activeFrameCache=void 0,this.activeFrameConfig=void 0,this.lastA11yIdToNodeMap={},this.lastDataMomenticIdToNodeMap={},this.lastSelectorToNodeMap={},this.lastA11yTreeRoot=void 0,this.lastDomGraph=void 0}saveAutoFrameCacheDetails(e){if(!this.activeFrameConfig||this.activeFrameConfig.type!=="auto"||!this.flagStore.isBooleanFlagEnabled("auto_expand_iframes"))return;let t={...e,indices:this.activeFrameConfig.handle.locationData.indices,mPathSelectorTokens:this.activeFrameConfig.mPathSelectorTokens};return this.constructIframeRegexAsync(this.activeFrameConfig.handle,t),t}async getAutoFrameDetailsFromHandle(e){let t=this.pageGetter(),r=yp(e),{frame:o,mPathSelectorTokens:i}=await Pn(e,t),a={indices:e.locationData.indices,mPathSelectorTokens:i};return this.constructIframeRegexAsync(e,a),{cache:a,config:{type:"auto",frame:o,handle:e,mPathSelectorTokens:i,frameTree:r,cache:a}}}async resolveAutoFrameCache(e){let t=this.pageGetter(),r=await ci({cdpClient:this.cdpClient,page:t,logger:this.logger}),{resolution:o,logs:i}=await Pb({page:t,frameTree:r,cache:e});return this.logger.debug({logs:i},"Resolved auto frame cache"),{...o,cache:e}}async resolveActiveFrameConfig({logger:e=this.logger,signal:t=this.abortSignalGetter()}){if(!this.frameConfig)return null;if(this.activeFrameCache)if(wl(this.frameConfig)!==this.activeFrameCache.frameIdentifierStringified)this.activeFrameCache=void 0;else if(this.activeFrameCache.frame&&"isDetached"in this.activeFrameCache.frame&&this.activeFrameCache.frame.isDetached())this.activeFrameCache=void 0;else return this.activeFrameCache;let r;return this.frameConfig.type==="url"?r=await this.resolveUrlMatcherFrameConfig({config:this.frameConfig,logger:e,signal:t}):r={source:"auto",frame:this.frameConfig.frame,handle:this.frameConfig.handle,frameIdentifierStringified:wl(this.frameConfig),cacheTime:Date.now(),frameTree:this.frameConfig.frameTree,mPathSelectorTokens:this.frameConfig.mPathSelectorTokens},await kb({frame:r.frame,logger:e,signal:t}),this.activeFrameCache=r,r}async executeFunctionInAllFrames(e,t){let r=this.pageGetter(),o=await ci({cdpClient:this.cdpClient,page:r,logger:this.logger}),i=[D(r.evaluate(e,t),{milliseconds:2e3})],a=Array.from(o.childFrames);for(;a.length>0;){let l=a.shift(),c=l.url;c==="about:blank"||c.startsWith("chrome-error://")||(a.push(...l.childFrames),i.push(Pn(l,r).then(({frame:d})=>D(d.evaluate(e,t),{milliseconds:2e3})).catch(d=>(this.logger.warn({err:d,frameUrl:l.url},"Failed to evaluate function in frame"),"MOMENTIC_FRAME_EVAL_ERROR"))))}return(await Promise.all(i)).filter(l=>l!=="MOMENTIC_FRAME_EVAL_ERROR")}async getAllChildFrameUrls(){let e=this.pageGetter(),t=await ci({cdpClient:this.cdpClient,page:e,logger:this.logger}),r=Array.from(t.childFrames),o=[];for(;r.length>0;){let i=r.shift();r.push(...i.childFrames),o.push(i.src??i.url)}return o}async getDomGraph({devicePixelRatio:e,signal:t,logger:r}){return this.getDOMTree({devicePixelRatio:e??1,signal:t,logger:r??this.logger})}async getA11yTree(e){let t={},r=e.logger??this.logger,o=e.abortSignal??this.abortSignalGetter(),i=this.pageGetter(),a,s,l=null;if(this.frameConfig?.type==="url"){if(a=await nn({fn:()=>this.resolveActiveFrameConfig({logger:r,signal:o}),codePath:"getActiveFrameDetails",logObject:t,signal:o,logger:r})??void 0,!a)throw new R("ActionFailureError","Got null frame details despite active frame config");s=a.handle,l=s.frameId}else this.flagStore.isBooleanFlagEnabled("auto_expand_iframes")?(s=await nn({fn:()=>ci({cdpClient:this.cdpClient,page:this.pageGetter(),logger:r}),codePath:"getMomenticFrameTree",logObject:t,signal:o,logger:r}),l=null):(s={type:"root",page:i,childFrames:[]},l=null);await nn({fn:async()=>this.addMomenticIds({rootPage:i,childFrames:s.childFrames,frameFilter:a?.frame,logger:r}),codePath:"addIdsToElement",logObject:t,signal:o,logger:r});let c=await nn({fn:()=>this.getDOMTree({devicePixelRatio:e.devicePixelRatio??1,signal:o,logger:r}),codePath:"domFetch",logObject:t,signal:o,logger:r}),d=await nn({fn:()=>this.getRawA11yGraph({cdpClient:this.cdpClient,frameId:l,childFrames:s.childFrames,logTimings:t,logger:r,signal:o}),codePath:"totalA11yFetch",logObject:t,signal:o,logger:r}),{tree:p}=await nn({fn:()=>this.composeA11yDomGraph({opts:e,a11yGraph:d,domGraph:c,startingFrameId:l,frameContext:s,logger:r,iconKnowledgeBase:this.iconKnowledgeBase}),codePath:"a11yProcess",logObject:t,signal:o,logger:r});return Object.values(t).some(m=>m>750)&&r.warn({logTimings:t},"A11y tree fetch component took a long time"),this.lastA11yIdToNodeMap=p.a11yIdNodeMap,this.lastDataMomenticIdToNodeMap=p.dataMomenticIdMap,this.lastA11yTreeRoot=p.root,this.lastDomGraph=c,this.lastSelectorToNodeMap=p.selectorToNodeMap,p}async fetchA11yTreeForRecording(e,t){if(await this.getA11yTree({devicePixelRatio:e,abortSignal:t,logger:kr,filterByViewport:!1}),Math.random()<.1){let r=this.lastA11yTreeRoot?.serialize();this.logger.debug({tree:r&&r.length>4e5?"REDACTED_DUE_TO_SIZE":r},"Refreshed a11y tree during recording")}}async getLocatorFromA11yNode({page:e,root:t,node:r}){if(r.backendNodeId===void 0)throw new Error(`Node with a11y id ${r.id} has no backend node ID: ${r.getNodeOnlySerializedForm()}`);if(this.flagStore.isBooleanFlagEnabled("visual_actions")){let o=this.domGraph?.backendIdToNode[r.backendNodeId];if(!o)throw new Error(`Could not find DOM node for backend node ID ${r.backendNodeId}`);let i=qy({node:o,domGraph:this.domGraph});return Ky(e,i)}else return this.getLocatorFromBackendId(t,r.backendNodeId)}async getLocatorFromBackendId(e,t){let r=await this.cdpClient.send({method:"DOM.resolveNode",params:{backendNodeId:t},timeout:2e3});if(!r||!r.object.objectId)throw new Error(`Could not resolve backend node ${t}`);let o;try{o=await Yy(this.cdpClient,r.object.objectId)}catch(i){throw this.logger.debug({err:i,object:JSON.stringify(r.object)},"Failed to get ID attribute"),i}return e.locator(`[${Tt}="${o}"]`)}getNodeUsingMPathSelector(e){let t=this.selectorToNodeMap[e];if(t)return t;let r=e.split(" > "),o="";for(let i=r.length-1;i>=0;i--){let a=r.slice(i).join(" > ");if(this.selectorToNodeMap[a]){o=a;break}}this.logger.warn({selectorMapSize:Object.keys(this.selectorToNodeMap).length,selector:e,closestSelector:o},"Could not find a11y node using mpath selector")}async resolveUrlMatcherFrameConfig({config:e,signal:t=this.abortSignalGetter(),logger:r=this.logger}){let o=Date.now(),i,a,s,l=0;for(;Date.now()-o<this.smartWaitingTimeoutMs;)try{i=await ci({cdpClient:this.cdpClient,page:this.pageGetter(),logger:r}),a=await this.getMatchingFrameByUrlWithCdp(i,e),r.debug({frameId:a.handle.frameId,url:a.handle.url,src:a.handle.src,locationData:a.handle.locationData},`Found matching frame using ${a.matchType}`);break}catch(c){if(s=c,c instanceof R&&c.reason==="UserInfrastructureError")throw c;l%3===0&&this.logger.debug({attempt:l,err:c},"Failed to resolve active frame, retrying..."),await te(500,t)}finally{l++}if(a)return{source:"url",frame:a.frame,handle:a.handle,frameIdentifierStringified:wl(e),cacheTime:Date.now(),frameTree:i,mPathSelectorTokens:[]};throw s}async getMatchingFrameByUrlWithCdp(e,t){let r=t.url,o=this.pageGetter(),i=Array.from(e.childFrames),a=[];for(;i.length>0;){let s=i.shift(),l=s.domNode;i.push(...s.childFrames);let c=hr(l.attributes??[],"src"),d=l.contentDocument?.documentURL;if(!c&&!d){this.logger.debug("Skipping frame with no URL or src");continue}for(let p of[c,d])if(p){if(r.startsWith("/")&&r.endsWith("/")){if(new RegExp(r.slice(1,-1)).test(p)){a.push({handle:s,matchType:"regex",...await Pn(s,o)});break}}else if(r.trim()===p.trim()){a.push({handle:s,matchType:"url",...await Pn(s,o)});break}}}if(a.length===1){let s=a[0];return this.flagStore.isBooleanFlagEnabled("auto_expand_iframes")||(s.handle.childFrames=[]),s}else throw a.length>1?new Error(`Found multiple frames with src matching '${r}'. Please use a more specific selector.`):new R("ActionFailureError",`Failed to find frame with src matching: ${r}`)}async composeA11yDomGraph({opts:e,a11yGraph:t,domGraph:r,startingFrameId:o,frameContext:i,logger:a,iconKnowledgeBase:s}){let l=await nb({rawA11yGraph:t,startingFrameId:o,frameContext:i,domGraph:r,logger:a,cdpClient:this.cdpClient,showZeroOpacityElements:this.showZeroOpacityElements,filterByViewport:e.filterByViewport,viewportDetails:void 0,iconKnowledgeBase:s,useMPaths:this.flagStore.isBooleanFlagEnabled("visual_actions")});if(!l||!l.root)throw new Error("Accessibility tree appears empty");return{tree:l}}async addMomenticIds({rootPage:e,childFrames:t,frameFilter:r,logger:o}){if(this.flagStore.isBooleanFlagEnabled("visual_actions"))return;let i=await this.addMomenticIdsHelper(r??e,1);if(!this.flagStore.isBooleanFlagEnabled("auto_expand_iframes")||r)return;let a=Array.from(t),s=[];for(;a.length>0;){let l=a.shift();a.push(...l.childFrames);let c=async()=>{try{let{frame:d}=await Pn(l,e);i=await this.addMomenticIdsHelper(d,i)}catch(d){l.url!=="about:blank"&&o.warn({err:d},"Error adding momentic IDs to child frame, continuing...")}};s.push(c())}await Promise.all(s)}async addMomenticIdsHelper(e,t){if(this.flagStore.isBooleanFlagEnabled("visual_actions"))return t;let r=this.logger;return await Xe({root:e,fn:i=>window.addIdsToElement?.(document.body,i),arg:t,timeout:2e3,waitForPageLoad:async()=>{try{await e.waitForLoadState("domcontentloaded",{timeout:this.smartWaitingTimeoutMs})}catch(i){r.warn({err:i},"Error loading frame root adding momentic ids, continuing...")}},codePath:"addMomenticIds"})??t}getPageDomain(e){try{let t=new URL(e);if(!t.hostname)return null;let r=t.hostname.split("."),o=r.length>2?r.slice(-2).join("."):t.hostname;return`${t.protocol}//${o}`}catch{return null}}async decideChildFrameUnrollEligibility({logger:e,warnings:t,handle:r}){try{let{shouldUnroll:o,reason:i}=await this.decideChildFrameUnrollEligibilityHelper({domNode:r.domNode});return{shouldUnroll:o,reason:i}}catch(o){if(o.message.includes("Could not compute box model"))return{shouldUnroll:!1};let i=`Got error when determining whether to filter frame ${r.frameId} with url ${r.url}, allowing it to be fetched: ${o}`;return t?.push(i),e?.warn({err:o},i),{shouldUnroll:!0}}}async decideChildFrameUnrollEligibilityHelper({domNode:e}){let t=e.attributes??[];if(hr(t,"aria-hidden")==="true")return{shouldUnroll:!1,reason:"aria-hidden"};let r=hr(t,"style");if(r?.includes("display: none")||r?.includes("visibility: hidden"))return{shouldUnroll:!1,reason:"hidden CSS style"};await this.cdpClient.send({timeout:3e3,method:"DOM.pushNodesByBackendIdsToFrontend",params:{backendNodeIds:[e.backendNodeId]}});let[o,i]=await Promise.all([this.cdpClient.send({timeout:3e3,method:"DOM.getBoxModel",params:{backendNodeId:e.backendNodeId}}),this.cdpClient.send({timeout:3e3,method:"CSS.getComputedStyleForNode",params:{nodeId:e.nodeId}})]);if(!o.model||!o.model.height||!o.model.width)return{shouldUnroll:!1,reason:"no bounding box"};if(o.model.height<10||o.model.width<10)return{shouldUnroll:!1,reason:"small bounding box"};for(let a of i.computedStyle){if(a.name==="display"&&a.value==="none")return{shouldUnroll:!1,reason:"display: none"};if(a.name==="visibility"&&a.value==="hidden")return{shouldUnroll:!1,reason:"visibility: hidden"};if(a.name==="opacity"&&a.value==="0")return{shouldUnroll:!1,reason:"opacity: 0"}}return{shouldUnroll:!0}}async getRawA11yGraph({cdpClient:e,frameId:t,childFrames:r,logTimings:o,logger:i=this.logger,signal:a=this.abortSignalGetter()}){let s=[];try{await this.pageGetter().waitForLoadState("load",{timeout:this.pageLoadTimeoutMs})}catch(u){i.warn({err:u},"Failed to wait for page load event before a11y tree fetch, attempting to continue without it..."),await this.cdpClient.reinitialize()}let l,c;for(let u=0;u<3;u++)try{c=await nn({fn:()=>this.getRawA11yTreeForFrame({frameId:t,timeoutMs:this.pageLoadTimeoutMs,logTimings:o}),codePath:"a11y-tree-fetch-root",logObject:o,signal:a,logger:i});break}catch(h){l=h,i.warn({err:h},"Reinitializing CDP client before retrying a11y graph fetch"),await this.cdpClient.reinitialize()}if(!c)throw new Error(`Failed to fetch accessibility tree for root page: ${l}`);let d={};if(d[t??"root"]=c,!this.flagStore.isBooleanFlagEnabled("auto_expand_iframes"))return d;let p=Array.from(r),m=[];for(;p.length>0;){let u=p.shift();try{let{shouldUnroll:g}=await this.decideChildFrameUnrollEligibility({handle:u,warnings:s});if(!g)continue}catch(g){if(g.message.includes("Could not compute box model"))continue;s.push(`Got error when determining whether to filter frame ${u.frameId} with url ${u.url}, allowing it to be fetched: ${g}`)}p.push(...u.childFrames);let h=async()=>{try{let g=await nn({fn:()=>this.getRawA11yTreeForFrame({frameId:u.frameId,timeoutMs:this.smartWaitingTimeoutMs,logTimings:o}),codePath:`a11y-tree-fetch-child-${u.frameId}`,logObject:o,signal:a,logger:i});d[u.frameId]=g}catch(g){i.warn({err:g,url:u.url,src:u.src},`Error getting raw a11y tree for child frame ${u.frameId}, continuing...`)}};m.push(h())}return await Promise.all(m),s.length>0&&this.logger.warn({warnings:s},"Got warnings when fetching the raw a11y graph"),d}async getRawA11yTreeForFrame({frameId:e,timeoutMs:t,logTimings:r}){let o;if(this.allowPartialAccessibilityTree)o=(await nn({fn:()=>this.cdpClient.send({method:"Accessibility.getFullAXTree",params:{frameId:e??void 0},timeout:t,timeoutMsg:`Fetching the document tree took over ${t}ms. This usually indicates that the current page is too large to be loaded at once, or your machine is severely resource constrained.`}),codePath:"cdp-query-ax-tree",logObject:r,signal:this.abortSignalGetter(),logger:this.logger})).nodes;else{let a=(await nn({fn:()=>this.cdpClient.send({method:"Accessibility.getRootAXNode",params:{frameId:e??void 0},timeout:2e3}),codePath:"cdp-get-root-ax-node",logObject:r,signal:this.abortSignalGetter(),logger:this.logger})).node.backendDOMNodeId;o=(await nn({fn:()=>this.cdpClient.send({method:"Accessibility.queryAXTree",params:{backendNodeId:a},timeout:t,timeoutMsg:`Fetching the document tree took over ${t}ms. This usually indicates that the current page is too large to be loaded at once, or your machine is severely resource constrained.`}),codePath:"cdp-query-ax-tree",logObject:r,signal:this.abortSignalGetter(),logger:this.logger})).nodes}if(!o||o.length<=1)throw new Error("Document is entirely empty");return{root:o[0],allNodes:o}}async getDOMTree({devicePixelRatio:e,signal:t,logger:r}){let o,i=0;for(;!o&&i<3;)try{if(o=await this.cdpClient.send({method:"DOMSnapshot.captureSnapshot",params:{computedStyles:hl},timeout:3e3}),!o||!o.documents.length)throw new Error("Got empty DOM tree")}catch(a){await te(500,t),r.debug({err:a},"Error fetching DOM tree"),i++}if(!o||!o.documents.length)throw new R("InternalWebAgentError","Got empty DOM snapshot with no documents");return Vy({snapshot:o,devicePixelRatio:e,logger:r})}constructIframeRegexAsync(e,t){if(t.frameSrcRegex||t.frameUrlRegex)return;let r=Lb(e);(async()=>{try{let o=await this.enricher?.constructIframeRegex(r);o?.srcRegex&&(t.frameSrcRegex=o.srcRegex),o?.urlRegex&&(t.frameUrlRegex=o.urlRegex),this.logger.debug({result:o,params:r},"Constructed iframe regex for cache")}catch(o){this.logger.warn({err:o},"Failed to construct iframe regex, skipping...")}})()}};var bp=di(vp(),"momentic","chromium"),nk=di(vp(),"video"),Cl=process.env.TWO_CAPTCHA_KEY,wp=QO(Hb);wp.use(ek({provider:{id:"2captcha",token:Cl},visualFeedback:!0}));var On=class n{static USER_AGENT=ZO["Desktop Chrome"].userAgent;abortSignal=void 0;contextInitialized=!1;browser;context;properties;page;userControlledBrowserSettings;pageLoadPromises={};lastTabChangeEventTimeout=void 0;clientCallbacks;iconKnowledgeBase;lastIconKnowledgeBaseUpdateTime=0;mockedServices;cdpClient;debugData={logsPerPage:[],harPages:{},harEntries:{}};recentFrameNavigations={};enricher;storage;flagStore;logger;stateManager;transformer;lastScreenshotForRecording=void 0;baseUrl;originsVisited=new Set;viewport;videos=[];constructor({storage:e,flagStore:t,enricher:r,browser:o,context:i,page:a,baseUrl:s,logger:l,mockedServices:c,userBrowserSettings:d,viewport:p,properties:m,clientCallbacks:u,iconKnowledgeBase:h}){if(xg(d),this.mockedServices=c,this.storage=e,this.flagStore=t,this.enricher=r,this.browser=o,this.context=i,this.page=a,this.baseUrl=s,this.logger=l,this.userControlledBrowserSettings=d,this.viewport=p||Gt,this.properties=m,this.clientCallbacks=u,m.recordVideo){let g=this.page.video();g&&this.videos.push(g)}this.iconKnowledgeBase=h}registerAbortSignal(e){this.abortSignal=e}async initialize(){if(this.contextInitialized)return;this.userControlledBrowserSettings.extraHeaders&&await this.context.setExtraHTTPHeaders(this.userControlledBrowserSettings.extraHeaders),await this.context.grantPermissions(["clipboard-read","clipboard-write","microphone","camera"]);let e=this.flagStore.getAllFlags(),t=[this.context.addInitScript({content:Yd.cssGeneratorLibJs}),this.context.addInitScript({content:Yd.htmlUtilsLibJs}),this.context.addInitScript({content:`window._MOMENTIC_BROWSER = true; window._MOMENTIC_FEATURE_FLAGS = ${JSON.stringify(e)}; window.addEventListener('load', (event) => { console.log('[MOMENTIC] Page loaded'); });`})],r=Promise.all(Object.entries(this.mockedServices).map(([a,s])=>this.context.route(a,l=>s.handle(l)))),o=a=>this.handleNewPageEvent(a);this.context.on("page",o),this.handleNewPageEventHelper(this.page),this.context.on("close",()=>{this.context.off("page",o)});let i=Promise.all(t);await Promise.all([i,r]),this.properties.systemDevicePixelRatio||(process.env.MOMENTIC_LOCAL_DEV==="1"&&KO()==="darwin"&&jO("system_profiler SPDisplaysDataType").toString().includes("Retina")?(y.warn("[DEV] Setting device pixel ratio to 2 in local dev since a Retina display was detected"),this.properties.systemDevicePixelRatio=2):this.properties.systemDevicePixelRatio=await this.page.evaluate(()=>window.devicePixelRatio)),this.cdpClient=await Sl.init({logger:this.logger,contextGetter:()=>this.context,pageGetter:()=>this.page,defaultTimeoutMs:this.pageLoadTimeout}),await this.initializeScreencast(),this.stateManager=new Tl({smartWaitingTimeoutMs:this.smartWaitingTimeout,pageLoadTimeoutMs:this.pageLoadTimeout,allowPartialAccessibilityTree:this.userControlledBrowserSettings.allowPartialAccessibilityTree??!1,logger:this.logger,cdpClient:this.cdpClient,pageGetter:()=>this.page,flagStore:this.flagStore,abortSignalGetter:()=>this.abortSignal,enricher:this.enricher,showZeroOpacityElements:this.userControlledBrowserSettings.showZeroOpacityElements??!1,iconKnowledgeBase:this.iconKnowledgeBase}),this.contextInitialized=!0}async fixViewportForNewHeadless(){this.properties.isNewHeadless&&await this.cdpClient.send({method:"Emulation.setDeviceMetricsOverride",params:{width:this.viewport.width,height:this.viewport.height,deviceScaleFactor:0,mobile:this.viewport.width<1e3}})}async initializeScreencast(){await this.fixViewportForNewHeadless(),this.clientCallbacks?.onScreencastFrame&&(await this.cdpClient.send({method:"Page.startScreencast",params:{format:"jpeg",quality:75,maxWidth:this.viewport.width,maxHeight:this.viewport.height}}),this.cdpClient.on("Page.screencastFrame",e=>{let t=e.sessionId,r=Buffer.from(e.data,"base64");this.lastScreenshotForRecording=r,this.clientCallbacks?.onScreencastFrame?.(r,()=>{(async()=>{try{await this.cdpClient.send({method:"Page.screencastFrameAck",params:{sessionId:t}})}catch{}})()})}))}static async init({baseUrl:e,logger:t,storage:r,flagStore:o,enricher:i,mockedServices:a,userBrowserSettings:s,contextArgs:l,browserbaseConnectUrl:c,recordVideo:d,iconKnowledgeBase:p,callbacks:m}){process.env.PW_TEST_SCREENSHOT_NO_FONTS_READY="1";let u;switch(s.browserType){case"Google Chrome":u="chrome";break;case"Chrome for Testing":u=void 0;break;case"Chromium":u="chromium";break;default:u="chromium";break}let h={headless:process.env.MOMENTIC_HEADFUL_BROWSER!=="true",handleSIGTERM:!1,chromiumSandbox:!1,channel:u},g={...l??{},geolocation:{latitude:37.7749,longitude:-122.4194},locale:l?.locale||Eo,timezoneId:l?.timezoneId||Co,colorScheme:l?.colorScheme,httpCredentials:s.basicAuthorization?{username:s.basicAuthorization.username??"",password:s.basicAuthorization.password??""}:void 0,javaScriptEnabled:s.disableJavaScript?!1:void 0,userAgent:s.userAgent??n.USER_AGENT,viewport:l?.viewport??Gt},f=["--disable-dev-shm-usage","--no-first-run","--renderer-process-limit=3","--browser-test","--disable-site-isolation-for-policy","--disable-site-isolation-trials","--disable-backgrounding-occluded-windows","--disable-background-timer-throttling","--disable-renderer-backgrounding","--autoplay-policy=user-gesture-required","--disable-add-to-shelf","--disable-desktop-notifications","--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"],S=null,b,w,v={systemDevicePixelRatio:l?.deviceScaleFactor,recordVideo:d,isNewHeadless:!1};(s.browserType==="Chromium"||s.browserType==="Google Chrome")&&(v.isNewHeadless=!0,h.headless&&f.push("--headless=new")),process.env.BROWSER_MEMORY_MB&&f.push(`--js-flags=--max_old_space_size=${process.env.BROWSER_MEMORY_MB}`),s.disableGpu&&f.push("--disable-3d-apis","--disable-gpu","--disable-software-rasterizer","--disable-accelerated-2d-canvas","--disable-accelerated-mjpeg-decode","--disable-accelerated-video-decode","--disable-accelerated-video-encode","--disable-gl-drawing-for-tests","--disable-webgl","--disable-audio-input","--disable-audio-output");let x=s.localChromeExtensionPaths?.map(A=>A.startsWith("~")?di(vp(),A.slice(1)):A);if(x?.length){if(s.browserType==="Chrome for Testing")throw new R("UserConfigurationError","Chrome extensions are only supported on Chromium and Google Chrome.");for(let H of x){let F=di(H,"manifest.json");if(!El(F))throw new R("UserConfigurationError",`Chrome extension path ${F} does not exist.`)}let A=di(bp,`momentic-session-${Date.now()}`);if(!El(A))try{$O(A,{recursive:!0})}catch(H){throw new R("UserConfigurationError",`Failed to create browser cache directory. Please make sure you have sufficient permissions to create the ${bp} folder: ${H}`)}let N=[...f],O=x.map(H=>XO(H)).join(",");N.push(`--disable-extensions-except=${O}`),g?.deviceScaleFactor&&N.push(`--force-device-scale-factor=${g.deviceScaleFactor}`,`--device-scale-factor=${g.deviceScaleFactor}`),g.viewport&&N.push(`--window-size=${g.viewport.width},${g.viewport.height}`),b=await Hb.launchPersistentContext(di(bp,`momentic-session-${Date.now()}`),{...h,...g,ignoreDefaultArgs:["--disable-extensions","--disable-component-extensions-with-background-pages"],args:N,baseURL:e}),t.debug({sharedContextOptions:g,sharedBrowserOptions:h,userBrowserSettings:s,chromeArgs:N,flags:o.getAllFlags()},"Browser initialization context args (persistent)"),w=b.pages()[0]}else if(c){S=await wp.connectOverCDP(c);let A=S.contexts()[0];if(!A)throw new Error("Failed to get browserbase default context");let N=A.pages()[0];if(!N)throw new Error("Failed to get browserbase default page");b=A,w=N}else{S=await wp.launch({...h,args:f});let A={...g,baseURL:e,recordVideo:d?{dir:nk}:void 0};b=await S.newContext(A),t.debug({contextArgs:A,sharedBrowserOptions:h,chromeArgs:f,userBrowserSettings:s,flags:o.getAllFlags()},"Browser initialization context args (standard)"),w=await b.newPage()}let C=new n({browser:S,context:b,page:w,baseUrl:e,logger:t,storage:r,flagStore:o,mockedServices:a||{},enricher:i,userBrowserSettings:s,viewport:g.viewport||Gt,properties:v,clientCallbacks:m,iconKnowledgeBase:p});return await C.initialize(),C}async handleAvailableTabsChangeHelper(){try{let e=await Sp(this.context,{getTitles:!0}),t=this.page.url();this.clientCallbacks?.onTabsChange?.(e,t)}catch(e){this.logger.error({err:e},"Error sending available tabs to frontend")}}handleAvailableTabsChange(){try{clearTimeout(this.lastTabChangeEventTimeout),this.lastTabChangeEventTimeout=setTimeout(()=>this.handleAvailableTabsChangeHelper(),500)}catch(e){this.logger.warn({err:e},"Error handling available tabs change")}}addToPageLoadPromises(e,t){let r=Fb(),o=`${e}-${r}`,i=Date.now(),a=!1,s=async()=>{try{await D(t(),{signal:this.abortSignal,milliseconds:this.pageLoadTimeout,message:`Page load promise for code path ${e} timed out after ${this.pageLoadTimeout}ms`})}catch(l){l.name!=="AbortError"&&this.logger.error({err:l,promiseKey:o,codePath:e,duration:Date.now()-i},`Page load promise for code path ${e} encountered error`)}finally{delete this.pageLoadPromises[o],a=!0}};this.pageLoadPromises[o]=s().catch(()=>{}),a&&delete this.pageLoadPromises[o]}handlePageClosedEvent(e){if(this.page!==e){this.logger.debug({url:e.url()},"Detected background page was closed, just updating available tabs only"),this.handleAvailableTabsChange();return}let t=async()=>{if(this.closed)return;this.logger.debug({url:e.url()},"Detected active page was closed, switching to another tab");let r=this.context.pages();for(let o=r.length-1;o>=0;o--){let i=r[o];if(!(!i||i.isClosed()||!zr(i.url()))){this.logger.info(`Automatically switching to tab ${o} after close: ${i.url()}`),await this.switchToPage({type:"INDEX",index:String(o)});break}}};this.addToPageLoadPromises("page closed handler",async()=>t())}handleNewPageEvent(e){let t=e.url();if(this.logger.info({url:t},"Detected new page event, registering handlers and waiting for load to complete"),this.properties.recordVideo){let r=e.video();r&&this.videos.push(r)}try{this.handleNewPageEventHelper(e)}catch(r){this.logger.warn({err:r},"Error handling new page open, continuing....")}}handleNewPageEventHelper(e){let t=Fb(),r="new-page-load-handler";e.on("close",a=>this.handlePageClosedEvent(a)),e.on("framenavigated",a=>this.handleFrameNavigationEvent(a)),e.on("crash",()=>{this.logger.error("Page crashed at the Playwright level!")});let o=this.context.pages().indexOf(e);e.on("console",a=>{db(e,o,this.debugData,a,this.logger)}),e.on("request",a=>{fb(t,this.debugData,a,this.logger)});let i=async()=>{await gb(t,this.debugData,e),await this.loadFrameAndRecordUrl({root:e,codePath:r}),this.handleAvailableTabsChange()};this.addToPageLoadPromises(r,async()=>i())}async handleCollectSvgs(e){if(!this.flagStore.isBooleanFlagEnabled("icon_knowledge_base")||this.page.isClosed()||this.page.mainFrame()!==e||!this.iconKnowledgeBase||!this.clientCallbacks?.onSvgsCollected||Date.now()-this.lastIconKnowledgeBaseUpdateTime<5e3)return;this.lastIconKnowledgeBaseUpdateTime=Date.now();let t=await this.stateManager.getDomGraph({devicePixelRatio:this.devicePixelRatio}),r=Jy({domGraph:t,flagStore:this.flagStore,logger:this.logger,existingHashes:this.iconKnowledgeBase});if(r.forEach(s=>{this.iconKnowledgeBase[s.hash]=s}),!r.length)return;let o=ze(this.logger),i={pageUrl:e.url(),firstSeenTime:Date.now(),hostname:qO()};for(let s of["runId","testId"])o[s]&&(i[s]=o[s]);let a={metadata:i,newSvgs:r};this.clientCallbacks.onSvgsCollected(a)}handleFrameNavigationEvent(e){let t=e.url(),r=e.parentFrame()?"has-parent":"no-parent",o=`frame-navigation-handler-${t.slice(0,50)}-${r}`;if(!t||t==="about:blank"||!zr(t)||this.recentFrameNavigations[o]&&Date.now()-this.recentFrameNavigations[o]<1e3)return;this.recentFrameNavigations[o]=Date.now();let i=async()=>{try{if(e.isDetached())return;await this.loadFrameAndRecordUrl({root:e,codePath:o,signal:this.abortSignal}),this.handleAvailableTabsChange(),!e.parentFrame()&&!e.isDetached()&&this.clientCallbacks?.onSvgsCollected&&(setTimeout(()=>{(async()=>{try{await this.handleCollectSvgs(e)}catch(s){this.logger.warn({err:s},"Failed to collect SVGs on page, continuing...")}})()},5e3),this.transformer&&await this.injectKnowledgeBaseIntoBrowser(e))}catch(a){a.name!=="AbortError"&&this.logger.warn({err:a},"Failed to handle frame navigation event, continuing...")}};this.addToPageLoadPromises(o,async()=>i())}async injectKnowledgeBaseIntoBrowser(e){try{if(!this.iconKnowledgeBase||await e.evaluate(()=>!!window._MOMENTIC_ICON_KNOWLEDGE_BASE))return;let r={};Object.keys(this.iconKnowledgeBase).forEach(o=>{this.iconKnowledgeBase[o]?.description&&(r[o]=this.iconKnowledgeBase[o].description)}),await e.evaluate(o=>{let i=window;i._MOMENTIC_ICON_KNOWLEDGE_BASE=o},r)}catch(t){this.logger.warn({err:t},"Failed to inject icon knowledge base into browser, continuing...")}}getBrowserCallbacks(){return{waitForPageLoad:()=>this.waitForPageLoad(),waitForUrl:e=>this.waitForUrl(e),getBrowserState:e=>this.getBrowserState(e),waitForDomStability:e=>this.waitForDOMStability(e),state:{url:()=>this.url(),getDomGraph:()=>this.stateManager.domGraph,getOpenPages:()=>this.getOpenPages(),getRoot:()=>this.getActivePageOrFrame()},pageLoadTimeoutMs:this.pageLoadTimeout,signal:this.abortSignal}}ping(){if(this.closed)throw new Error("Page has been closed")}setActiveFrameConfig(e){this.stateManager.setActiveFrameConfig(e)}async reset(e){for(this.abortSignal=void 0,this.debugData.logsPerPage=[],this.debugData.harPages={},this.debugData.harEntries={},this.pageLoadPromises={};this.videos.length>0;)this.videos.pop();await this.clearAuthState({closeNonActiveTabs:!0}),await this.stopScreencast(),await this.reinitializeCDPClient(),await this.navigate({url:e.newUrl??this.baseUrl,initialNavigation:!0,loadTimeoutMs:e.timeout}),this.stateManager.reset()}async clearHighlights(){try{await D(mp(this.getBrowserCallbacks()),{milliseconds:1e3})}catch(e){this.logger.debug({err:e},"Failed to clear highlights, continuing...")}}async cleanup(){this.abortSignal=void 0;try{this.originsVisited.clear(),await this.context.close(),await this.browser?.close(),this.browser=null}catch(e){this.logger.warn({err:e},"Error cleaning up browser, continuing...")}finally{this.browser=null}}get closed(){return this.context.pages().every(e=>e.isClosed())||!!this.browser&&!this.browser.isConnected()}async ensureMomenticBrowserScriptsLoaded(e,t,r){let o=Date.now(),i=0,a=0;for(;Date.now()-o<8e3;){a++,r?.throwIfAborted();try{if(await Xe({fn:()=>{let l=window;return!!(l.generateCssSelectors&&l.evaluateCssSelectors&&l.generateHtmlCacheAttributes&&l.ldist)},timeout:1e3,arg:void 0,waitForPageLoad:()=>this.waitForPageLoad(),root:e,codePath:"ensureMomenticBrowserScriptsLoaded"}))return}catch(s){if(i++,i>=3){t.warn({err:s},"Multiple errors checking if Momentic scripts are loaded, aborting...");return}}await te(500),a%2===0&&t.warn("Still waiting for momentic browser scripts to load...")}throw new Error(`Failed to load momentic browser scripts on page ${e.url()}`)}async html(){let e=await this.getActivePageOrFrame();return await this.ensureMomenticBrowserScriptsLoaded(e,this.logger),Xe({root:e,fn:()=>{let t=window;if(!t?.getFullHtmlTree)throw new Error("Missing Momentic HTML library when fetching page HTML");return t.getFullHtmlTree()},arg:void 0,timeout:3e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"getFullHtmlTree"})}url(){return this.page.url()}async screenshot(e){let{retries:t=1}=e,r=Date.now(),o=this.page.url();try{await this.fixViewportForNewHeadless();let i=await this.screenshotHelper({...e,retries:t});if(i.byteLength>5e6)this.logger.error("Page screenshot is greater than 5MB, which may cause performance issues with some AI models");else if(i.length===0)throw new Error("Got empty screenshot");return i}catch(i){if(t<=0||i.message.includes("has been closed"))throw i;return this.logger.debug({err:i,pageUrl:o},"Failed taking screenshot, retrying..."),await te(250),this.screenshot({...e,retries:t-1})}finally{Date.now()-r>1e3&&this.logger.warn({pageUrl:o,duration:Date.now()-r},"Screenshot took longer than expected")}}async screenshotHelper({locator:e,quality:t,saveToDiskPath:r,timeout:o,respectActiveFrame:i,clearHighlights:a=!1}){a&&await this.clearHighlights(),i&&this.stateManager.frameConfig&&(e=await(await this.getActivePageOrFrame()).frameElement());let s=await this.cdpClient.send({method:"Page.captureScreenshot",params:{format:"jpeg",quality:t,optimizeForSpeed:!0},timeout:o??2e3}),l=Buffer.from(s.data,"base64"),c=await Ub.fromBuffer(l),{width:d,height:p}=this.getViewport();if((c.bitmap.width!==d||c.bitmap.height!==p)&&(l=await c.resize({w:d,h:p}).getBuffer("image/jpeg")),r&&WO(r,l),this.lastScreenshotForRecording=l,!e)return l;let m=await e.boundingBox({timeout:1e3});if(!m)throw new Error("Attempted to screenshot an element that is not visible on the page");let{x:u,y:h,width:g,height:f}=m;if(!g||!f)throw new Error("Attempted to screenshot an element with zero width or height");if(u<0||h<0)throw new Error("Attempted to screenshot an element with negative coordinates");u=Math.floor(u),h=Math.floor(h),g=Math.floor(g),f=Math.floor(f);try{l=await(await Ub.fromBuffer(l)).crop({x:u,y:h,w:g,h:f}).getBuffer("image/jpeg")}catch(S){throw new Error(`Failed taking element screenshot at coordinates (${u}, ${h}) with size (${g}, ${f}): ${S}`)}return"dispose"in e&&await e?.dispose(),l}getViewport(){return this.viewport}async navigate({url:e,initialNavigation:t=!1,loadTimeoutMs:r=this.pageLoadTimeout}){Ef(e)&&(e=new URL(e,this.baseUrl).toString());let o=Date.now();t||(await this.waitForPageLoad(),await this.waitForDOMStability());let i=!1,a;for(let l=0;l<3;l++)try{await this.page.goto(e,{timeout:r,waitUntil:"domcontentloaded"}),i=!0;break}catch(c){if(a=c,this.abortSignal?.throwIfAborted(),this.logger.warn({err:c},`Error occurred during navigation${l===0?", retrying...":" (fatal)"}`),await te(500),a.message.includes("Timeout")&&a.message.includes("exceeded")||a.message.includes("net::ERR_CONNECTION_REFUSED"))break;await this.cdpClient.send({method:"Page.stopLoading",params:{},timeout:1e3})}if(!i)throw new R("UserInfrastructureError",a?.message??"Failed to load page");await this.loadFrameAndRecordUrl({root:this.page,signal:this.abortSignal,codePath:"navigate-step-wait-for-load"}),this.logger.debug({url:e},`Navigation complete in ${Math.floor(Date.now()-o)}ms`);let s=this.url();if(Hy.has(s))throw new R("UserInfrastructureError",`${e} took too long to load \u{1F61E}. Please ensure the site is accessible and returns content within the page load timeout.`);if(t)try{await this.exposeRecordingBindings()}catch(l){l instanceof Error&&l.message.includes("already registered")||this.logger.error({err:l},"Failed to install Momentic libraries for action recording")}await this.fixViewportForNewHeadless()}async type(e,t={},r=!1){await this.directTypeHelper(e,t,r)}async getActiveElement(e){try{return await Xe({root:e,fn:()=>{let r=document.activeElement?.textContent??void 0;return r&&r.length>100&&(r=r.slice(0,100)+"...[TRUNCATED]"),document.activeElement?{tag:document.activeElement.tagName.toLowerCase(),contentEditable:document.activeElement.getAttribute("contenteditable")??void 0,textContent:r}:void 0},arg:void 0,timeout:1e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"getActiveElement"})}catch(t){this.logger.warn({err:t},"Failed to get active element");return}}async directTypeHelper(e,t={},r=!1){let o=await this.getActivePageOrFrame();await vb({root:o,text:e,options:t,logger:this.logger,callbacks:this.getBrowserCallbacks()});let i=await this.getActiveElement(o);if(r){let a=Date.now();for(;Date.now()-a<this.smartWaitingTimeout&&(!i||i.tag==="body");)await te(250),this.abortSignal?.throwIfAborted(),i=await this.getActiveElement(o);i||this.logger.warn("No active element found to type into, attempting anyways")}t.clearContent&&(t.forceClearContent||i?.tag==="input"||i?.tag==="textarea"?(process.platform==="darwin"?await this.page.keyboard.press("Meta+A"):await this.page.keyboard.press("Control+A"),await this.page.keyboard.press("Backspace"),await this.page.waitForTimeout(25)):this.logger.warn({activeElementDetails:i},"Currently active element is not eligible for replace content, skipping...")),await this.page.keyboard.type(e,{delay:t.delay??Ou}),t.pressEnter&&await this.press("Enter",{})}async scrollIntoView(e){await e.scrollIntoViewIfNeeded({timeout:2e3})}async highlightA11yId(e){try{let{resolution:t}=await this.createTargetFromA11yId({id:e,description:null,targetSource:"AI",skipSaveToCache:!0});return await this.highlight(t.locator),!0}catch(t){return this.logger.debug({err:t,id:e},"Failed to highlight target"),!1}}async highlight(e){return bl({locator:e,callbacks:this.getBrowserCallbacks(),logger:this.logger})}recordUrlVisited(e){try{let t=new URL(e).origin;if(t==="null")return;this.originsVisited.add(t)}catch(t){this.logger.warn({err:t},"Failed to record origin visited")}}async waitForPageLoad(){let e=Date.now(),t=Object.values(this.pageLoadPromises),r=Object.keys(this.pageLoadPromises),o=-1,i=0;for(;t.length!==0;){if(Date.now()-e>this.pageLoadTimeout&&this.logger.error({outstandingPromiseKeys:r,outstandingPromises:t},"Still waiting on page load promises"),Date.now()-o<20&&(i++,i>2)){this.logger.error({outstandingPromiseKeys:r,outstandingPromises:t},"Synchronous waiting loop detected, exiting page load wait");return}o=Date.now(),await Promise.allSettled(t),t=Object.values(this.pageLoadPromises),r=Object.keys(this.pageLoadPromises)}}async clearAuthState(e){await this.context.clearCookies();for(let o of this.originsVisited)this.logger.debug({origin:o},`Clearing data using CDP for origin ${o}`),await this.cdpClient.send({method:"Storage.clearDataForOrigin",params:{origin:o,storageTypes:"all"},timeout:1e3}),this.originsVisited.delete(o);let t=this.context.pages().indexOf(this.page),r=[...this.context.pages()];for(let o=0;o<r.length;o++){let i=r[o];if(i.isClosed())continue;let a=i.url();try{this.originsVisited.delete(new URL(a).origin)}catch{}await cb(i,this.logger),o!==t&&e.closeNonActiveTabs&&(this.logger.debug(`Closing tab ${o} with URL ${a}`),await i.close())}}async loadAuthState(e){await this.waitForPageLoad(),await this.waitForDOMStability(),!e||Object.keys(e).length===0?await this.clearAuthState({closeNonActiveTabs:!1}):await this.loadAuthStateHelper(e),await this.refresh(),await this.waitForDOMStability()}async loadAuthStateHelper(e){let t=[];for(let i of e.cookies??[]){let a=await this.setCookie(i);t=t.concat(a)}this.logger.debug(`Loaded ${e.cookies?.length??0} cookies`),await this.cdpClient.send({method:"DOMStorage.enable",params:void 0,timeout:1e3});let r=0;for(let i of e.origins??[])for(let a of i.localStorage)try{await this.cdpClient.send({timeout:1e3,method:"DOMStorage.setDOMStorageItem",params:{storageId:{securityOrigin:new URL(i.origin).origin,isLocalStorage:!0},key:a.name,value:a.value}}),r++}catch(s){this.logger.warn({err:s,origin:i},"Failed to set local storage entry, continuing...");break}this.logger.debug(`Loaded ${r} local storage entries`);let o=e.idb;o&&Object.keys(o).length>0&&(await lb(this.page,o,this.logger),this.logger.debug(`Loaded ${Object.keys(o??{}).length} indexedDB databases`))}async saveAuthState(){let t=0,r=null;for(;t<=2;)try{await this.waitForPageLoad(),await this.waitForDOMStability();let o=await this.context.storageState();return o.idb=await sb(this.page,this.logger),o}catch(o){if(r=o,t++,t<=2){this.logger.warn({err:o,retryCount:t,maxRetries:2},`Error saving auth state, retrying (${t}/2)...`);let i=Math.pow(2,t)*100;await new Promise(a=>setTimeout(a,i))}}throw this.logger.error({err:r},"Failed to save auth state after 2 retries"),new R("ActionFailureError",`Failed to save auth state: ${r?.message}`)}async getOpenPages(e){return Sp(this.context,e)}saveA11yDetailsToCache(e,t){t.id=e.id,t.content=e.content,t.name=e.name,t.role=e.role,t.numChildren=e.children.length,t.serializedForm=e.getSerializedFormWithContext(),t.nodeOnlySerializedForm=e.getNodeOnlySerializedForm()}async saveNodeDetailsToCache({node:e,target:t,dataMomenticId:r,locator:o,generateNewCssSelectors:i,logger:a=this.logger}){if(e&&this.saveA11yDetailsToCache(e,t),t.frameCache=this.stateManager.saveAutoFrameCacheDetails(t.frameCache),r&&(t.dataMomenticId=r),o)try{let s=await this.fetchHtmlAttributes(o,a);s&&(t.serializedHtml=s.serializedHtml,t.nodeOnlySerializedHtml=s.nodeOnlySerializedHtml,i&&(t.generatedSelectors=s.generatedSelectors))}catch(s){a.warn({err:s},"Failed to fetch HTML attributes for target, continuing...")}try{await this.saveElementVisualAttributes(t,o,a)}catch(s){a.debug({err:s},"Failed to save element visual details, continuing...")}}async saveElementVisualAttributes(e,t,r){if(!t)return;await t.scrollIntoViewIfNeeded({timeout:1e3});let o=await t.boundingBox({timeout:1e3});if(!o||!o.width||!o.height){r.debug("Skipping visual attributes saving for element with no bounding box after action"),e.boundingBox=void 0,e.screenshotUrl=void 0;return}e.boundingBox=o;let{x:i=0,y:a=0,width:s=0,height:l=0}=o;if(e.boundingBox&&Math.abs(e.boundingBox.width-s)<1&&Math.abs(e.boundingBox.height-l)<1&&Math.abs((e.boundingBox.x??0)-i)<1&&Math.abs((e.boundingBox.y??0)-a)<1||!Zd.includes(e?.role??""))return;let c=await this.screenshot({locator:t,retries:0});e.screenshotUrl=await this.storage.uploadScreenshot(c)}async resolveTargetWithCssSelectors({root:e,target:t,logger:r}){if(!t.generatedSelectors||t.generatedSelectors.length<2||!t.nodeOnlySerializedHtml)throw new Yi("Insufficient data to resolve target using CSS selectors");let o=Bb(t.generatedSelectors),i;try{i=await Xe({fn:d=>window.evaluateCssSelectors(d),arg:{selectors:t.generatedSelectors,ldistThreshold:.05,serializedNodeWithText:t.nodeOnlySerializedHtml,requireBoundingBox:!0,ignoreHrefForCaching:this.userControlledBrowserSettings.ignoreHrefForCaching,requireMatchingBoundingBox:this.userControlledBrowserSettings.bustCacheOnBoundingBoxChange?t.boundingBox:void 0},root:e,timeout:2e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"evaluateCssSelectors"})}catch(d){throw new Error(`Failed to evaluate CSS selectors in browser: ${d}`)}let a=i.result;if(!a)throw new Error(`CSS selector evaluation returned no eligible elements:
3602
+ ${l}`,{errOptions:{cause:n}})}if(i.includes("element is not visible")){let l="The element you attempted to interact with has no bounding box or is explicitly hidden.";try{let c=await e.boundingBox({timeout:1e3});c?c.height===0?l="The element you attempted to interact with has zero height.":c.width===0&&(l="The element you attempted to interact with has zero width."):l="The element you attempted to interact with has no bounding box."}catch{}return new R("ActionFailureError",`${l} Please explicitly wait for the element to be visible or turn on the 'disable stability checks' option. ${a}`,{errOptions:{cause:n}})}return i.includes("element is outside of the viewport")?new R("ActionFailureError",`The element requested was outside of the browser viewport for the entire duration of the action. Please ensure you are not using non-standard zoom settings and the element is visible on the page. ${a}`):n}function uO(n){let e=n.message;if(e.includes("waiting for locator")&&e.includes("data-momentic-id")&&!e.match(/attempting \w+ action/)&&!e.includes("locator.evaluate"))throw new R("ActionFailureError",`Interacting with the element timed out. This is usually caused by the web page itself performing too many CPU-intensive operations or a lack of resources on your machine. Error: ${e}`,{errOptions:{cause:n}});return n}async function yb(n){try{return await mO(n)}catch(e){n.logger.warn({err:e},"Failed to transform locator for Chakra click, continuing...");return}}async function mO({locator:n,logger:e}){let[t,r]=await n.evaluate(l=>[l.id,l.tagName.toLowerCase()],{timeout:1e3}),o=await gn(n,e),i=await n.boundingBox({timeout:1e3});if(i===null){e.warn({elementDisplayString:o},"Attempting to click on element with no bounding box, not performing Chakra redirection");return}if(i.width>5||i.height>5)return;if(r==="input"&&t)try{let l=n.page().locator(`label[for=${JSON.stringify(t)}]`);return await l.waitFor({state:"visible",timeout:1e3}),{locator:l,relativePoint:void 0}}catch{}let a=await n.evaluate(l=>{let c=window;if(!c.CssSelectorGenerator)return{type:"error",error:"[MOMENTIC] Missing CSS selector libraries"};let d=l.parentElement;if(!d)return{type:"error",error:"Input click target has no parent for redirection"};let p=c.CssSelectorGenerator.getCssSelector(d,{}),m=l.getBoundingClientRect(),u=d.getBoundingClientRect();if(u.width===0||u.height===0)return{type:"error",error:"Parent element has no width or height"};let h={x:Math.min(Math.max(1,m.left-u.left),u.width-1),y:Math.min(Math.max(1,m.top-u.top),u.height-1)};return{type:"result",selector:p,relativePoint:h,serializedForm:d.outerHTML.slice(0,500)}},{timeout:1e3});if(a.type==="error")throw new Error(a.error);let s=n.page().locator(a.selector);return await s.waitFor({state:"visible",timeout:1e3}),e.info({parentElementResult:a,originalElementDisplayString:o},`Redirected click to parent element with selector: ${a.selector}`),{locator:s,relativePoint:a.relativePoint}}var wb=["date","datetime-local","month","time","week"],bb={date:/^\d{4}-\d{2}-\d{2}$/,"datetime-local":/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}$/,month:/^\d{4}-\d{2}$/,time:/^\d{2}:\d{2}$/,week:/^\d{4}-W\d{2}$/};async function vb(n){try{await D(hO(n),{milliseconds:3e3})}catch(e){n.logger.warn({err:e},"Failed to transform native datetime input, continuing...")}}async function hO({root:n,text:e,options:t,logger:r,callbacks:o}){let i=(await Xe({root:n,fn:()=>document.activeElement?.getAttribute("type")??"",timeout:1e3,arg:void 0,waitForPageLoad:o.waitForPageLoad,codePath:"transformNativeDateTimeInputFillHelper"})).toLowerCase();if(!bb[i])return;bb[i].test(e)&&r.warn(`Detected datetime input (${e}) in normalized format - this may fail to fill correctly as it is not how the user would input the value`),t.clearContent=!1,r.debug("Transforming datetime input to use sequential key presses")}async function bl({locator:n,callbacks:e,logger:t,timeoutMs:r=1e3}){try{await mp(e,r);let o=n.evaluate(i=>{let a=window;a.momenticIsEligible=p=>{let u=window.getComputedStyle(p,null).getPropertyValue("display");if(u==="none"||u==="contents")return!1;let h=p.getBoundingClientRect();return!(!h.height||!h.width)},a.removeHighlightTimers=a.removeHighlightTimers||[],a.removeHighlightFunctions=a.removeHighlightFunctions||{};let s=0;for(;!a.momenticIsEligible(i)&&s<3;){if(!i.parentElement)throw new Error("No eligible non-empty parent found for highlighting");i=i.parentElement,s++}let l=i.style.getPropertyValue("outline"),c=i.style.getPropertyPriority("outline");i.style.setProperty("outline","5px dashed rgb(255, 0, 153)","important");let d=`momentic${Math.floor(Math.random()*1e7)}`;a[d]=()=>{i.style.removeProperty("outline"),i.style.setProperty("outline",l,c),i.getAttribute("style")||i.removeAttribute("style")},a.removeHighlightTimers.push(setTimeout(()=>{a[d](),a.removeHighlightFunctions?.[d]&&delete a.removeHighlightFunctions[d]},5e3)),a.removeHighlightFunctions[d]=a[d]},void 0,{timeout:r});return await D(o,{milliseconds:r}),!0}catch(o){return t.debug({err:o},"Failed to add node highlight, a page navigation likely occurred. This is non-fatal for tests."),!1}}async function mp(n,e=1e3){let t=await n.state.getRoot();await Xe({root:t,fn:()=>{let o=window,i=o.removeHighlightTimers||[];for(;i.length;){let a=i.pop();clearTimeout(a)}Object.values(o.removeHighlightFunctions??{}).forEach(a=>{a()})},timeout:e,arg:void 0,waitForPageLoad:n.waitForPageLoad,codePath:"removeAllHighlights"})}async function gp(n){let e=n.flagStore.isBooleanFlagEnabled("visual_actions");return Xr({action:"clicking element",targetingResult:n.targetingResult,logger:n.logger,retryTimeoutMs:n.retryTimeoutMs,callbacks:n.browserCallbacks,func:async t=>hp({...n,targetingResult:t,useVisualClick:e})})}async function yO(n,e){let{redirectionAttempts:t=0}=e;if(t>=2)throw n;try{return await bO(n,e)}catch(r){throw e.redirectionAttempts===0?(e.logger.error({redirectionAttemptError:r,originalError:n},"Error handling click error, rethrowing original error"),n):r}}async function bO(n,e){let{logger:t,redirectionAttempts:r=0,browserCallbacks:o,actionSource:i}=e,a=e.targetingResult.locator,s=o.state.getDomGraph();if(n.message.includes("label")&&n.message.includes("for=")&&n.message.includes("intercepts pointer events")){let l=await a.getAttribute("id",{timeout:1e3});if(!l)throw n;let c=a.page().locator(`[for=${JSON.stringify(l)}]`);return await c.waitFor({state:"visible",timeout:1e3}),t.warn({err:n},"Attempting locator redirection due to input being covered by label"),hp({...e,targetingResult:{locator:c},redirectionAttempts:r+1})}else if(i==="click"&&s&&n.message.includes("intercepts pointer events")){t.warn({err:n},"Attempting locator redirection due to covering error");let l=await EO(a,s,t);if(l)return hp({...e,targetingResult:{locator:l},redirectionAttempts:r+1});throw t.error({err:n},"No updated locator could be found to fix covering error, rethrowing"),n}else throw t.error({err:n},"Click error does not match any known recoverable patterns, rethrowing"),n}async function wO(n){let{browserCallbacks:e,logger:t,targetingResult:r,position:o,options:i}=n,a=await e.state.getRoot(),s=a&&a!==r.locator.page()&&"frameElement"in a?await a.frameElement():null,l;try{l=s?await Br({promiseGenerator:async()=>s.boundingBox(),timeoutMs:3e3,logger:t}):null}catch(u){throw new R("UserInfrastructureError",`The frame containing the element Momentic was instructed to interact with was removed. Error: ${u.message}`)}finally{await s?.dispose()}let c=Date.now(),{clickX:d,clickY:p,reason:m}=await xO({frameCoordinates:l,logger:t,targetingResult:r,position:o,options:i});t.debug({frameCoordinates:l,position:o,targetingResultHints:r.hints,options:i,clickLocation:{clickX:d,clickY:p,reason:m},duration:Date.now()-c},"Visual click")}async function vO(n){let{actionSource:e,targetingResult:t,options:r,logger:o}=n,i=n.targetingResult.locator,a=r?.relativePosition??n.position;if(e==="click"&&!a){let l=await yb({locator:i,logger:o});l&&(i=l.locator,a=l.relativePoint??a)}let s=r?.force||t.hints?.force||!1;try{r?.doubleClick?await i.dblclick({button:r.rightClick?"right":"left",timeout:3e3,position:a,delay:r?.delayMs??25,force:s}):await i.click({button:r?.rightClick?"right":"left",timeout:3e3,position:a,delay:r?.delayMs??25,force:s})}catch(l){let c=l;if(RO(c))o.warn({err:c},"Click action timed out while waiting for navigation after completion, continuing...");else return o.error({err:c},"Error clicking on locator, attempting to recover..."),yO(c,{...n,targetingResult:{...i,locator:i}})}}async function hp(n){let{options:e,logger:t,browserCallbacks:r,controllerCallbacks:o,useVisualClick:i,targetingResult:a}=n,s;e?.waitForDownload&&(s=(async()=>{let l=e.downloadTimeoutMs??3e4;try{return await a.locator.page().waitForEvent("download",{timeout:l})}catch(c){return c instanceof SO.TimeoutError?new R("ActionFailureError",`Download did not complete in ${l}ms`):new R("ActionFailureError",`Download failed: ${c.message}`)}})());try{await bl({locator:a.locator,callbacks:r,logger:t,timeoutMs:1e3})}catch(l){t.warn({err:l},"Error highlighting locator in click, continuing...")}if(i?await wO(n):await vO(n),e?.waitForDownload)if(s){if(!o?.createIsolatedFolder)throw new R("InternalWebAgentError","Cannot wait for download without a callback to create an isolated folder");t.info("Waiting for download to start and complete");let l=await D(s,{milliseconds:e.downloadTimeoutMs??3e4});if(l instanceof Error)throw l;return{downloadedFile:await CO(l,o.createIsolatedFolder,t)}}else throw new Error("No download promise or error but the step requested to wait for a download")}async function TO(n,e){if(e.hints?.clickableXY){let i=(n?.x??0)+e.hints.clickableXY.x,a=(n?.y??0)+e.hints.clickableXY.y;return[{x:i,y:a},"targeting hint"]}let t=await e.locator.boundingBox({timeout:1e3});if(!t)throw new R("ActionFailureError","Element does not have a bounding box");let r=t.x+t.width/2,o=t.y+t.height/2;return[{x:r,y:o},"halfway point of the bounding box"]}async function xO({frameCoordinates:n,logger:e,options:t,targetingResult:r,position:o}){let i,a,s;if(o){let p=await r.locator.boundingBox({timeout:3e3});i=(n?.x??0)+(p?.x??0)+o.x,a=(n?.y??0)+(p?.y??0)+o.y,s="predefined position"}else{let[p,m]=await TO(n,r);i=p.x,a=p.y,s=m}let l=r.locator.page(),c=t?.rightClick?"right":"left",d=t?.delayMs??25;return t?.doubleClick?await l.mouse.dblclick(i,a,{button:c,delay:d}):await l.mouse.click(i,a,{button:c,delay:d}),{clickX:i,clickY:a,reason:s}}async function EO(n,e,t){let r=await n.evaluate(s=>s.getAttribute("data-momentic-id"));if(!r)return;let o=gl(r,e,t);if(!o.length){t.error("No candidates found for parent-based locator redirection");return}let i=parseInt(o[0].attributes?.[Tt]??"");if(isNaN(i))return;n=n.page().locator(`[data-momentic-id="${i}"]`);let a=await gn(n,t);return t.warn({candidateMomenticId:i,serializedHtml:a},"Trying new locator based on parent-direction after covering error"),n}async function CO(n,e,t){t.info("Download detected, saving file to disk");let r=await n.path(),o=dp(n.suggestedFilename()),i=e();await n.saveAs(fO(i,o)),xb(r,{force:!0}),setTimeout(()=>{xb(i,{recursive:!0,force:!0})},5*60*1e3);let a=ab(gO(i),o);return t.debug({uri:a,downloadFolder:i},"Saved download to isolated folder"),a}function RO(n){return n.message.includes("locator.click: Timeout")&&n.message.includes("click action done")}import{platform as AO}from"os";var IO={goToNextWord:{win32:"Control+ArrowRight",darwin:"Alt+ArrowRight",linux:"Control+ArrowRight"},goToPreviousWord:{win32:"Control+ArrowLeft",darwin:"Alt+ArrowLeft",linux:"Control+ArrowLeft"},selectNextWord:{win32:"Control+Shift+ArrowRight",darwin:"Alt+Shift+ArrowRight",linux:"Control+Shift+ArrowRight"},selectPreviousWord:{win32:"Control+Shift+ArrowLeft",darwin:"Alt+Shift+ArrowLeft",linux:"Control+Shift+ArrowLeft"},selectToStartOfLine:{win32:"Shift+Home",darwin:"Meta+Shift+LeftArrow",linux:"Shift+Home"},selectToEndOfLine:{win32:"Shift+End",darwin:"Meta+Shift+RightArrow",linux:"Shift+End"},deleteNextWord:{win32:"Control+Delete",darwin:"Alt+Fn+Delete",linux:"Control+Delete"},deletePreviousWord:{win32:"Control+Backspace",darwin:"Alt+Delete",linux:"Control+Backspace"}};function PO(){let n=AO();return n==="win32"?"win32":n==="darwin"?"darwin":"linux"}function Eb(n){return JSON.stringify(n.split("+").sort())}function Cb(n){let e=PO(),t=Eb(n);for(let r of Object.values(IO))if(Object.values(r).some(o=>Eb(o)===t))return r[e];return process.platform==="darwin"?n=n.replaceAll("Control","Meta"):n=n.replaceAll("Meta","Control"),n}async function fp({frame:n,page:e,deltaX:t,directionX:r,deltaY:o,directionY:i,signal:a,callbacks:s}){if(!t&&!o)return;let l=r==="left"?-1:1,c=i==="up"?-1:1;if(n)await Xe({root:n,fn:([d,p,m,u])=>window.scrollTo(window.scrollX+(d??window.innerWidth)*m,window.scrollY+(p??window.innerHeight)*u),arg:[t,o,l,c],waitForPageLoad:s.waitForPageLoad,timeout:2e3,codePath:"scrollFrame"});else{let d=e.viewportSize()||Gt,p=await Xe({root:e,fn:()=>document.body.scrollHeight,arg:void 0,waitForPageLoad:s.waitForPageLoad,timeout:2e3,codePath:"scrollPageGetHeight"}),[m,u,h]=await Xe({root:e,fn:()=>{let f=document.activeElement;if(!f)return[void 0,void 0,void 0];let S=f.getBoundingClientRect();return[f.scrollTop,S.x,S.y]},arg:void 0,waitForPageLoad:s.waitForPageLoad,timeout:2e3,codePath:"scrollPage"});await e.mouse.wheel((t??d.width)*l,(o??d.height)*c);let g=Date.now();for(;Date.now()-g<2e3;){a?.throwIfAborted();let f=await D(e.evaluate(()=>document.body.scrollHeight),{milliseconds:1e3}),[S,b,w]=await D(e.evaluate(()=>{let v=document.activeElement;if(!v)return[void 0,void 0,void 0];let x=v.getBoundingClientRect();return[v.scrollTop,x.x,x.y]}),{milliseconds:1e3});if(f===p&&S===m&&b===u&&w===h)break;p=f,m=S,u=b,h=w,await te(500)}}}async function Sp(n,e){let t,r;for(let o=0;o<4;o++)try{return t=n.pages(),await Promise.all(t.map(async i=>{let a="";try{a=e?.getTitles?await i.title():""}catch{a="Unknown page"}return{title:a,url:i.url()}}))}catch(i){r=i,await te(500)}throw new Error(`Failed to get tab titles after all retries: ${r?.message}`)}var si="<empty>";function LO(n){return n.includes("doubleclick.net")||n.includes("googletagmanager.com")||n.includes("googlesyndication.com")||n.includes("s.amazon-adsystem.com")||n.includes("smartadserver.com")||n.includes("omnitagjs.com")||n.includes("x.adroll.com")}function Ab(n){let e=n.adFrameStatus?.adFrameType;return e==="child"||e==="root"||LO(n.url)}async function OO(n,e){let t=await n.send({timeout:3e3,method:"DOM.getFrameOwner",params:{frameId:e}}),o=(await n.send({timeout:3e3,method:"DOM.pushNodesByBackendIdsToFrontend",params:{backendNodeIds:[t.backendNodeId]}})).nodeIds[0],a=(await n.send({timeout:3e3,method:"DOM.describeNode",params:{backendNodeId:t.backendNodeId}})).node;return a.nodeId=o,a}async function li({cdpClient:n,page:e,logger:t}){let r={type:"root",childFrames:[],page:e},o=[],[i]=await Promise.all([n.send({timeout:3e3,method:"Page.getFrameTree",params:{}}),n.send({timeout:3e3,method:"DOM.getDocument",params:{}})]),l=(i.frameTree.childFrames??[]).map(async(d,p)=>{if(Ab(d.frame))return null;try{return await Ib({cdpClient:n,rawFrameTree:d,indices:[p],parent:r,warnings:o,logger:t})}catch(m){return o.push(`Failed to get child frame: ${m}`),null}}),c=await Promise.all(l);return r.childFrames=c.filter(d=>d!==null),o.length&&t?.warn({warnings:o},"Got warnings when fetching frame tree"),r}async function Ib({cdpClient:n,rawFrameTree:e,indices:t,parent:r,warnings:o,logger:i}){let a=e.frame.id,s=await OO(n,a),l=s.attributes??[],c=null,d=[];for(let h of["src","name","id","title","srcdoc","sandbox"]){let g=hr(l,h);g&&(d.push(`${h}=${JSON.stringify(g)}`),h==="src"&&(c=g))}let p={type:"frame",cdpFrame:e.frame,url:e.frame.url,frameId:a,locationData:{indices:t,attributeSelectors:d},src:c,childFrames:[],parent:r,domNode:s},u=(e.childFrames??[]).map(async(h,g)=>{if(Ab(h.frame))return null;try{return await Ib({cdpClient:n,rawFrameTree:h,indices:[...t,g],parent:p,warnings:o,logger:i})}catch(f){return o.push(`Failed to get child frame (child ${g} of frame with url ${e.frame.url}): ${f}`),null}});return p.childFrames=(await Promise.all(u)).filter(h=>h!==null),p}async function kO(n){try{return await n.owner().count()===1}catch{return!1}}async function MO(n){try{return await n.count()===1}catch{return!1}}async function Pn(n,e){let t=[],r=n;for(;r.parent.type==="frame";)t.push(r.parent),r=r.parent;t.reverse();let o=e,i=[];for(let c of t){let d=!1;for(let p of[...c.locationData.attributeSelectors,si]){let m=o.frameLocator(p===si?"iframe":`iframe[${p}]`);if(await kO(m)){d=!0,o=m,i.push(p);break}}if(!d)throw new R("ActionFailureError",`Failed to find a unique attribute to identify intermediate frame with url matching '${c.url}'. Please attach a unique 'id', 'name', 'title', or 'src' attribute to the frame.`)}let a;for(let c of[...n.locationData.attributeSelectors,si]){let d=o.locator(c===si?"iframe":`iframe[${c}]`);if(await MO(d)){a=d,i.push(c);break}}if(!a)throw new R("ActionFailureError",`Failed to find a unique attribute to identify target frame with url matching '${n.url}'. Please attach a unique 'id', 'name', 'title', or 'src' attribute to the frame.`);let s=await a.evaluateHandle(c=>c,{timeout:1e3}),l=await s.asElement().contentFrame();if(!l)throw new R("InternalWebAgentError",`Failed to load Playwright Frame for iframe with url '${n.url}'`);return await s.dispose(),{frame:l,mPathSelectorTokens:i}}function Rb(n,e){let t=[...n],r=[];for(;t.length;){let o=t.shift();e(o)&&r.push(o),t.push(...o.childFrames)}return r}async function Pb({page:n,frameTree:e,cache:t}){let r,o=e.childFrames,i=[];if(t.mPathSelectorTokens.length){let s=o;for(let d=0;d<t.mPathSelectorTokens.length-1;d++){let p=t.mPathSelectorTokens[d];p===si?s=s.length===1?s[0].childFrames:[]:s=s.filter(m=>m.locationData.attributeSelectors.includes(p)).map(m=>m.childFrames).flat()}let l=[],c=t.mPathSelectorTokens[t.mPathSelectorTokens.length-1];if(c===si?l=s:l=s.filter(d=>d.locationData.attributeSelectors.includes(c)),l.length===1)return r=l[0],i.push(`Found unique frame with mpath ${t.mPathSelectorTokens.join(" > ")}`),{resolution:{type:"auto",frame:(await Pn(r,n)).frame,handle:r,mPathSelectorTokens:t.mPathSelectorTokens,frameTree:e},logs:i};i.push(`Found ${l.length} frames with mpath ${t.mPathSelectorTokens.join(" > ")}`)}if(t.frameSrcRegex){let s=new RegExp(t.frameSrcRegex),l=Rb(o,c=>!!c.src&&s.test(c.src));if(l.length===1)return r=l[0],i.push(`Found unique frame with src regex ${t.frameSrcRegex}`),{resolution:{type:"auto",frame:(await Pn(r,n)).frame,handle:r,mPathSelectorTokens:t.mPathSelectorTokens,frameTree:e},logs:i};i.push(`Found ${l.length} frames with src regex ${t.frameSrcRegex}`),t.frameSrcRegex=void 0}if(t.frameUrlRegex){let s=new RegExp(t.frameUrlRegex),l=Rb(o,c=>!!c.url&&s.test(c.url));if(l.length===1)return r=l[0],i.push(`Found unique frame with url regex ${t.frameUrlRegex}`),{resolution:{type:"auto",frame:(await Pn(r,n)).frame,handle:r,mPathSelectorTokens:t.mPathSelectorTokens,frameTree:e},logs:i};i.push(`Found ${l.length} frames with url regex ${t.frameUrlRegex}`),t.frameUrlRegex=void 0}let a=o;for(let s=0;s<t.indices.length-1;s++)a=a[t.indices[s]]?.childFrames??[];if(r=a[t.indices[t.indices.length-1]],r)return i.push(`Found unique frame with indices ${t.indices.join(" > ")}`),{resolution:{type:"auto",frame:(await Pn(r,n)).frame,handle:r,mPathSelectorTokens:t.mPathSelectorTokens,frameTree:e},logs:i};throw i.push(`Found ${a.length} frames with indices ${t.indices}`),new nr("Failed to find the iframe that previously contained this element",[{type:"AUTO_FRAME",matched:!1,logs:i}])}function wl(n){return n.type==="auto"?JSON.stringify({type:"auto",frameId:n.handle.frameId}):JSON.stringify(n)}function yp(n){for(;n.parent.type==="frame";)n=n.parent;return n.parent}function Lb(n){let e=yp(n),t=n.src??"",r=n.url??"",o=[],i=[],a=[...e.childFrames];for(;a.length;){let s=a.shift();s.src&&o.push(s.src),s.url&&i.push(s.url),a.push(...s.childFrames)}return{srcs:o,urls:i,desiredSrc:t,desiredUrl:r}}function Ob(n){return n.type==="auto"?{type:"auto",frameId:n.handle.frameId,url:n.handle.url,src:n.handle.src??"",mPathSelectorTokens:n.mPathSelectorTokens.join(" > ")}:{type:"url",url:n.url}}async function kb({frame:n,logger:e,signal:t}){let r;try{r=await n.frameElement(),await NO({frameElementHandle:r,logger:e,signal:t})}catch(o){e.warn({err:o},"Failed to scroll iframe into view, continuing...")}finally{await r?.dispose()}}async function NO({frameElementHandle:n,logger:e,signal:t}){let r=await n.boundingBox();if(!r){e.warn("Active frame element has null bounding box, skipping scroll");return}await Br({promiseGenerator:async()=>n.evaluate(async(i,{x:a,y:s})=>{window.scrollTo(window.scrollX+a,window.scrollY+s);let l=Date.now(),c,d,p;for(;Date.now()-l<1500;){let m=document.activeElement,u,h,g;if(!m)u=void 0,h=void 0,g=void 0;else{let f=m.getBoundingClientRect();u=m.scrollTop,h=f.x,g=f.y}if(c!==void 0&&d!==void 0&&p!==void 0&&u===c&&h===d&&g===p)break;c=u,d=h,p=g,await new Promise(f=>setTimeout(f,250))}},r),timeoutMs:2e3,codePath:"scrollIframeIntoView",signal:t}),e.info({bb:r},"Successfully scrolled iframe into view")}async function Mb({event:n,transformer:e,enricher:t,frame:r,lastScreenshotForRecording:o,logger:i}){let{warnings:a,error:s,properties:l}=n.target;if(s){i.error({error:s,warnings:a},"Error while capturing passive click");return}if(a.length&&i.warn({warnings:a},"Warnings while capturing passive click"),!l)return;let c=r.parentFrame()?r.url():void 0,p=r.page().frames().map(h=>h.url());i.debug({frameUrl:c,...n},"Passive click event captured on element");let m,u;if(c)try{let h=await r.frameElement();m=await D(h?.boundingBox(),{milliseconds:1e3})??void 0;let g=await t.constructIframeRegex({urls:p,srcs:[],desiredUrl:c});if(g.urlRegex)u={type:"url",url:`/${g.urlRegex}/`};else throw new Error(`Got no url regex options: ${JSON.stringify(g)}`)}catch(h){i.warn({err:h},"Failed to construct iframe details for recorded action, using hardcoded URL only"),u={type:"url",url:c}}(async()=>{try{await e.recordElementAction({...n,screenshotBase64:o,frameConfig:u,frameBoundingBox:m})}catch(h){i.error({err:h},"Failed to transform passive click action")}})()}import{randomUUID as Ln}from"crypto";import _O from"js-beautify";var DO=["Shift","CapsLock","Dead","Meta","AudioVolumeUp","AudioVolumeDown"];var vl=class{recordedSteps=new Map;callbacks;signal;generator;testId;orgId;nextStepOffset=0;logger;constructor({signal:e,callbacks:t,generator:r,testId:o,orgId:i,logger:a}){this.signal=e,this.logger=a,this.testId=o,this.orgId=i,this.callbacks={onStepRecorded:(s,l)=>{this.recordedSteps.set(l,{step:s}),t.onStepRecorded(s,l)},onActionReceived:(s,l)=>{this.recordedSteps.set(l,{step:s}),t.onActionReceived?.(s,l)}},this.generator=r}reserveIndexForCommand(e){let t=this.nextStepOffset;return this.recordedSteps.set(t,{step:{id:Ln(),type:"PRESET_ACTION",command:Nn(e)}}),this.nextStepOffset++,t}async recordElementAction(e){let{type:t,target:r,frameConfig:o}=e;if(this.signal.aborted){this.logger.debug("Transformer was already cleaned up, ignoring click...");return}let i,a,s=r.properties.attributes.nodeOnlySerializedHtml.trim(),l=s,c;switch(e.frameConfig?e.frameBoundingBox?c={x:e.frameBoundingBox.x+r.properties.boundingBox.x,y:e.frameBoundingBox.y+r.properties.boundingBox.y,width:r.properties.boundingBox.width,height:r.properties.boundingBox.height}:this.logger.warn(e,"No frame bounding box found, refusing to write bounding box"):c=r.properties.boundingBox,t){case"CLICK":{i="CLICK";let g=Nn(i);a={id:Ln(),type:"PRESET_ACTION",command:{...g,target:{type:"description",elementDescriptor:l},iframeUrl:o?.url,cache:{target:{id:-1,...r.properties.attributes,targetSource:"RECORDING",targetUpdateTime:new Date().toUTCString(),boundingBox:c}}}};break}case"SELECT":{i="SELECT_OPTION";let g=Nn(i);a={id:Ln(),type:"PRESET_ACTION",command:{...g,type:"SELECT_OPTION",iframeUrl:o?.url,target:{type:"description",elementDescriptor:l},cache:{target:{id:-1,...r.properties.attributes,targetSource:"RECORDING",targetUpdateTime:new Date().toUTCString(),boundingBox:c}},choice:{type:"VALUE",value:e.selectedValue??"Unknown option"}}};break}case"MOUSE_DRAG":{i="MOUSE_DRAG";let g=Nn(i);a={id:Ln(),type:"PRESET_ACTION",command:{...g,target:{type:"description",elementDescriptor:l},deltaX:e.deltaX.toString(),deltaY:e.deltaY.toString(),iframeUrl:o?.url,cache:{target:{id:-1,...r.properties.attributes,targetSource:"RECORDING",targetUpdateTime:new Date().toUTCString(),boundingBox:c}}}};break}default:throw new Error(`Unknown action type: ${t}`)}let d;e.offset===void 0?(d=this.nextStepOffset,this.nextStepOffset++):d=e.offset,this.callbacks.onActionReceived?.(a,d);let p=e.target.browserState;try{p=_O.html(p,{indent_size:1,indent_with_tabs:!1,preserve_newlines:!1}),p=zy(p,"data-momentic-interacted",4e4)}catch{}let m;try{m=(await this.generator.getReverseMappedDescription({target:p,screenshot:e.screenshotBase64?`data:image/jpeg;base64,${e.screenshotBase64}`:void 0,boundingBox:r.properties.boundingBox},{disableCache:!1,loggerTags:{testId:this.testId,...ze(this.logger)}})).phrase}catch(g){this.logger.error({err:g},"Error generating reverse mapping description"),m=s}let u=this.recordedSteps.get(d)?.step??a,h=u?.command;h&&"target"in h&&h.target?(h.target={type:"description",elementDescriptor:m},this.callbacks.onStepRecorded({...u,command:h},d)):this.logger.warn("Could not find existing command to update after description mapping")}recordKeystroke(e){let{key:t,combinable:r}=e;if(DO.includes(t)||this.signal.aborted)return;let o="normal";t.length>1&&(o="special");let i;if(o==="normal"){let p=Nn("TYPE");i={id:Ln(),type:"PRESET_ACTION",command:{...p,target:void 0,value:t,clearContent:!1}}}else{let p=Nn("PRESS");i={id:Ln(),type:"PRESET_ACTION",command:{...p,value:t}}}let a,s=this.nextStepOffset-1,l=this.recordedSteps.get(s),c=l?.step,d=c?.command;if(r){if(d?.type===i.command.type){let p=d.value,m=i.command.value;i={id:Ln(),type:"PRESET_ACTION",command:{...d,value:i.command.type==="PRESS"?`${p}+${m}`:`${p}${m}`}},a=s}else if(d?.type==="CLICK"&&i.command.type==="TYPE")c.command={...i.command,target:d.target,cache:d.cache},i=l.step,a=s;else if(d?.type==="TYPE"&&i.command.type==="PRESS"&&i.command.value==="Backspace"){let p=d.value;i={id:Ln(),type:"PRESET_ACTION",command:{...d,value:p.slice(0,p.length-1)}},a=s}}a===void 0&&(a=this.nextStepOffset,this.nextStepOffset++),this.callbacks.onStepRecorded(i,a)}recordScroll(e){if(this.signal.aborted)return;let t=()=>{let{deltaY:i}=e;if(!i)return;let a=this.nextStepOffset-1,s=this.recordedSteps.get(a)?.step.command,l;s?.type==="SCROLL_DOWN"&&s.deltaY?(i+=s.deltaY,l=a):s?.type==="SCROLL_UP"&&s.deltaY?(i-=s.deltaY,l=a):(l=this.nextStepOffset,this.nextStepOffset++);let c=i>0?"SCROLL_DOWN":"SCROLL_UP",d=Nn(c);d.deltaY=Math.abs(i);let p={id:Ln(),type:"PRESET_ACTION",command:d};this.callbacks.onStepRecorded(p,l)},r=()=>{let{deltaX:i}=e;if(!i)return;let a=this.nextStepOffset-1,s=this.recordedSteps.get(a)?.step.command,l;s?.type==="SCROLL_RIGHT"&&s.deltaX?(i+=s.deltaX,l=a):s?.type==="SCROLL_LEFT"&&s.deltaX?(i-=s.deltaX,l=a):(l=this.nextStepOffset,this.nextStepOffset++);let c=i>0?"SCROLL_RIGHT":"SCROLL_LEFT",d=Nn(c);d.deltaX=Math.abs(i);let p={id:Ln(),type:"PRESET_ACTION",command:d};this.callbacks.onStepRecorded(p,l)},o=this.recordedSteps.get(this.nextStepOffset-1);o?.step.command.type==="SCROLL_LEFT"||o?.step.command.type==="SCROLL_RIGHT"?(r(),e.deltaY>=20&&t()):(t(),e.deltaX>=20&&r())}};var Tl=class{smartWaitingTimeoutMs;pageLoadTimeoutMs;showZeroOpacityElements;allowPartialAccessibilityTree;logger;cdpClient;pageGetter;abortSignalGetter;flagStore;enricher;iconKnowledgeBase;activeFrameCache;activeFrameConfig;lastA11yIdToNodeMap={};lastDataMomenticIdToNodeMap={};lastSelectorToNodeMap={};lastA11yTreeRoot;lastDomGraph;constructor({smartWaitingTimeoutMs:e,pageLoadTimeoutMs:t,showZeroOpacityElements:r,allowPartialAccessibilityTree:o,logger:i,cdpClient:a,pageGetter:s,flagStore:l,abortSignalGetter:c,enricher:d,iconKnowledgeBase:p}){this.smartWaitingTimeoutMs=e,this.pageLoadTimeoutMs=t,this.showZeroOpacityElements=r,this.allowPartialAccessibilityTree=o,this.logger=i,this.cdpClient=a,this.pageGetter=s,this.flagStore=l,this.abortSignalGetter=c,this.enricher=d,this.iconKnowledgeBase=p}get frameConfig(){return this.activeFrameConfig}get domGraph(){return this.lastDomGraph}get selectorToNodeMap(){return this.lastSelectorToNodeMap}get dataMomenticIdToNodeMap(){return this.lastDataMomenticIdToNodeMap}get a11yIdToNodeMap(){return this.lastA11yIdToNodeMap}get a11yTreeRoot(){return this.lastA11yTreeRoot}setActiveFrameConfig(e){e?(this.activeFrameConfig=e,this.activeFrameCache=void 0):(this.activeFrameConfig=void 0,this.activeFrameCache=void 0)}reset(){this.activeFrameCache=void 0,this.activeFrameConfig=void 0,this.lastA11yIdToNodeMap={},this.lastDataMomenticIdToNodeMap={},this.lastSelectorToNodeMap={},this.lastA11yTreeRoot=void 0,this.lastDomGraph=void 0}saveAutoFrameCacheDetails(e){if(!this.activeFrameConfig||this.activeFrameConfig.type!=="auto"||!this.flagStore.isBooleanFlagEnabled("auto_expand_iframes"))return;let t={...e,indices:this.activeFrameConfig.handle.locationData.indices,mPathSelectorTokens:this.activeFrameConfig.mPathSelectorTokens};return this.constructIframeRegexAsync(this.activeFrameConfig.handle,t),t}async getAutoFrameDetailsFromHandle(e){let t=this.pageGetter(),r=yp(e),{frame:o,mPathSelectorTokens:i}=await Pn(e,t),a={indices:e.locationData.indices,mPathSelectorTokens:i};return this.constructIframeRegexAsync(e,a),{cache:a,config:{type:"auto",frame:o,handle:e,mPathSelectorTokens:i,frameTree:r,cache:a}}}async resolveAutoFrameCache(e){let t=this.pageGetter(),r=await li({cdpClient:this.cdpClient,page:t,logger:this.logger}),{resolution:o,logs:i}=await Pb({page:t,frameTree:r,cache:e});return this.logger.debug({logs:i},"Resolved auto frame cache"),{...o,cache:e}}async resolveActiveFrameConfig({logger:e=this.logger,signal:t=this.abortSignalGetter()}){if(!this.frameConfig)return null;if(this.activeFrameCache)if(wl(this.frameConfig)!==this.activeFrameCache.frameIdentifierStringified)this.activeFrameCache=void 0;else if(this.activeFrameCache.frame&&"isDetached"in this.activeFrameCache.frame&&this.activeFrameCache.frame.isDetached())this.activeFrameCache=void 0;else return this.activeFrameCache;let r;return this.frameConfig.type==="url"?r=await this.resolveUrlMatcherFrameConfig({config:this.frameConfig,logger:e,signal:t}):r={source:"auto",frame:this.frameConfig.frame,handle:this.frameConfig.handle,frameIdentifierStringified:wl(this.frameConfig),cacheTime:Date.now(),frameTree:this.frameConfig.frameTree,mPathSelectorTokens:this.frameConfig.mPathSelectorTokens},await kb({frame:r.frame,logger:e,signal:t}),this.activeFrameCache=r,r}async executeFunctionInAllFrames(e,t){let r=this.pageGetter(),o=await li({cdpClient:this.cdpClient,page:r,logger:this.logger}),i=[D(r.evaluate(e,t),{milliseconds:2e3})],a=Array.from(o.childFrames);for(;a.length>0;){let l=a.shift(),c=l.url;c==="about:blank"||c.startsWith("chrome-error://")||(a.push(...l.childFrames),i.push(Pn(l,r).then(({frame:d})=>D(d.evaluate(e,t),{milliseconds:2e3})).catch(d=>(this.logger.warn({err:d,frameUrl:l.url},"Failed to evaluate function in frame"),"MOMENTIC_FRAME_EVAL_ERROR"))))}return(await Promise.all(i)).filter(l=>l!=="MOMENTIC_FRAME_EVAL_ERROR")}async getAllChildFrameUrls(){let e=this.pageGetter(),t=await li({cdpClient:this.cdpClient,page:e,logger:this.logger}),r=Array.from(t.childFrames),o=[];for(;r.length>0;){let i=r.shift();r.push(...i.childFrames),o.push(i.src??i.url)}return o}async getDomGraph({devicePixelRatio:e,signal:t,logger:r}){return this.getDOMTree({devicePixelRatio:e??1,signal:t,logger:r??this.logger})}async getA11yTree(e){let t={},r=e.logger??this.logger,o=e.abortSignal??this.abortSignalGetter(),i=this.pageGetter(),a,s,l=null;if(this.frameConfig?.type==="url"){if(a=await nn({fn:()=>this.resolveActiveFrameConfig({logger:r,signal:o}),codePath:"getActiveFrameDetails",logObject:t,signal:o,logger:r})??void 0,!a)throw new R("ActionFailureError","Got null frame details despite active frame config");s=a.handle,l=s.frameId}else this.flagStore.isBooleanFlagEnabled("auto_expand_iframes")?(s=await nn({fn:()=>li({cdpClient:this.cdpClient,page:this.pageGetter(),logger:r}),codePath:"getMomenticFrameTree",logObject:t,signal:o,logger:r}),l=null):(s={type:"root",page:i,childFrames:[]},l=null);await nn({fn:async()=>this.addMomenticIds({rootPage:i,childFrames:s.childFrames,frameFilter:a?.frame,logger:r}),codePath:"addIdsToElement",logObject:t,signal:o,logger:r});let c=await nn({fn:()=>this.getDOMTree({devicePixelRatio:e.devicePixelRatio??1,signal:o,logger:r}),codePath:"domFetch",logObject:t,signal:o,logger:r}),d=await nn({fn:()=>this.getRawA11yGraph({cdpClient:this.cdpClient,frameId:l,childFrames:s.childFrames,logTimings:t,logger:r,signal:o}),codePath:"totalA11yFetch",logObject:t,signal:o,logger:r}),{tree:p}=await nn({fn:()=>this.composeA11yDomGraph({opts:e,a11yGraph:d,domGraph:c,startingFrameId:l,frameContext:s,logger:r,iconKnowledgeBase:this.iconKnowledgeBase}),codePath:"a11yProcess",logObject:t,signal:o,logger:r});return Object.values(t).some(m=>m>750)&&r.warn({logTimings:t},"A11y tree fetch component took a long time"),this.lastA11yIdToNodeMap=p.a11yIdNodeMap,this.lastDataMomenticIdToNodeMap=p.dataMomenticIdMap,this.lastA11yTreeRoot=p.root,this.lastDomGraph=c,this.lastSelectorToNodeMap=p.selectorToNodeMap,p}async fetchA11yTreeForRecording(e,t){if(await this.getA11yTree({devicePixelRatio:e,abortSignal:t,logger:kr,filterByViewport:!1}),Math.random()<.1){let r=this.lastA11yTreeRoot?.serialize();this.logger.debug({tree:r&&r.length>4e5?"REDACTED_DUE_TO_SIZE":r},"Refreshed a11y tree during recording")}}async getLocatorFromA11yNode({page:e,root:t,node:r}){if(r.backendNodeId===void 0)throw new Error(`Node with a11y id ${r.id} has no backend node ID: ${r.getNodeOnlySerializedForm()}`);if(this.flagStore.isBooleanFlagEnabled("visual_actions")){let o=this.domGraph?.backendIdToNode[r.backendNodeId];if(!o)throw new Error(`Could not find DOM node for backend node ID ${r.backendNodeId}`);let i=qy({node:o,domGraph:this.domGraph});return Ky(e,i)}else return this.getLocatorFromBackendId(t,r.backendNodeId)}async getLocatorFromBackendId(e,t){let r=await this.cdpClient.send({method:"DOM.resolveNode",params:{backendNodeId:t},timeout:2e3});if(!r||!r.object.objectId)throw new Error(`Could not resolve backend node ${t}`);let o;try{o=await Yy(this.cdpClient,r.object.objectId)}catch(i){throw this.logger.debug({err:i,object:JSON.stringify(r.object)},"Failed to get ID attribute"),i}return e.locator(`[${Tt}="${o}"]`)}getNodeUsingMPathSelector(e){let t=this.selectorToNodeMap[e];if(t)return t;let r=e.split(" > "),o="";for(let i=r.length-1;i>=0;i--){let a=r.slice(i).join(" > ");if(this.selectorToNodeMap[a]){o=a;break}}this.logger.warn({selectorMapSize:Object.keys(this.selectorToNodeMap).length,selector:e,closestSelector:o},"Could not find a11y node using mpath selector")}async resolveUrlMatcherFrameConfig({config:e,signal:t=this.abortSignalGetter(),logger:r=this.logger}){let o=Date.now(),i,a,s,l=0;for(;Date.now()-o<this.smartWaitingTimeoutMs;)try{i=await li({cdpClient:this.cdpClient,page:this.pageGetter(),logger:r}),a=await this.getMatchingFrameByUrlWithCdp(i,e),r.debug({frameId:a.handle.frameId,url:a.handle.url,src:a.handle.src,locationData:a.handle.locationData},`Found matching frame using ${a.matchType}`);break}catch(c){if(s=c,c instanceof R&&c.reason==="UserInfrastructureError")throw c;l%3===0&&this.logger.debug({attempt:l,err:c},"Failed to resolve active frame, retrying..."),await te(500,t)}finally{l++}if(a)return{source:"url",frame:a.frame,handle:a.handle,frameIdentifierStringified:wl(e),cacheTime:Date.now(),frameTree:i,mPathSelectorTokens:[]};throw s}async getMatchingFrameByUrlWithCdp(e,t){let r=t.url,o=this.pageGetter(),i=Array.from(e.childFrames),a=[];for(;i.length>0;){let s=i.shift(),l=s.domNode;i.push(...s.childFrames);let c=hr(l.attributes??[],"src"),d=l.contentDocument?.documentURL;if(!c&&!d){this.logger.debug("Skipping frame with no URL or src");continue}for(let p of[c,d])if(p){if(r.startsWith("/")&&r.endsWith("/")){if(new RegExp(r.slice(1,-1)).test(p)){a.push({handle:s,matchType:"regex",...await Pn(s,o)});break}}else if(r.trim()===p.trim()){a.push({handle:s,matchType:"url",...await Pn(s,o)});break}}}if(a.length===1){let s=a[0];return this.flagStore.isBooleanFlagEnabled("auto_expand_iframes")||(s.handle.childFrames=[]),s}else throw a.length>1?new Error(`Found multiple frames with src matching '${r}'. Please use a more specific selector.`):new R("ActionFailureError",`Failed to find frame with src matching: ${r}`)}async composeA11yDomGraph({opts:e,a11yGraph:t,domGraph:r,startingFrameId:o,frameContext:i,logger:a,iconKnowledgeBase:s}){let l=await nb({rawA11yGraph:t,startingFrameId:o,frameContext:i,domGraph:r,logger:a,cdpClient:this.cdpClient,showZeroOpacityElements:this.showZeroOpacityElements,filterByViewport:e.filterByViewport,viewportDetails:void 0,iconKnowledgeBase:s,useMPaths:this.flagStore.isBooleanFlagEnabled("visual_actions")});if(!l||!l.root)throw new Error("Accessibility tree appears empty");return{tree:l}}async addMomenticIds({rootPage:e,childFrames:t,frameFilter:r,logger:o}){if(this.flagStore.isBooleanFlagEnabled("visual_actions"))return;let i=await this.addMomenticIdsHelper(r??e,1);if(!this.flagStore.isBooleanFlagEnabled("auto_expand_iframes")||r)return;let a=Array.from(t),s=[];for(;a.length>0;){let l=a.shift();a.push(...l.childFrames);let c=async()=>{try{let{frame:d}=await Pn(l,e);i=await this.addMomenticIdsHelper(d,i)}catch(d){l.url!=="about:blank"&&o.warn({err:d},"Error adding momentic IDs to child frame, continuing...")}};s.push(c())}await Promise.all(s)}async addMomenticIdsHelper(e,t){if(this.flagStore.isBooleanFlagEnabled("visual_actions"))return t;let r=this.logger;return await Xe({root:e,fn:i=>window.addIdsToElement?.(document.body,i),arg:t,timeout:2e3,waitForPageLoad:async()=>{try{await e.waitForLoadState("domcontentloaded",{timeout:this.smartWaitingTimeoutMs})}catch(i){r.warn({err:i},"Error loading frame root adding momentic ids, continuing...")}},codePath:"addMomenticIds"})??t}getPageDomain(e){try{let t=new URL(e);if(!t.hostname)return null;let r=t.hostname.split("."),o=r.length>2?r.slice(-2).join("."):t.hostname;return`${t.protocol}//${o}`}catch{return null}}async decideChildFrameUnrollEligibility({logger:e,warnings:t,handle:r}){try{let{shouldUnroll:o,reason:i}=await this.decideChildFrameUnrollEligibilityHelper({domNode:r.domNode});return{shouldUnroll:o,reason:i}}catch(o){if(o.message.includes("Could not compute box model"))return{shouldUnroll:!1};let i=`Got error when determining whether to filter frame ${r.frameId} with url ${r.url}, allowing it to be fetched: ${o}`;return t?.push(i),e?.warn({err:o},i),{shouldUnroll:!0}}}async decideChildFrameUnrollEligibilityHelper({domNode:e}){let t=e.attributes??[];if(hr(t,"aria-hidden")==="true")return{shouldUnroll:!1,reason:"aria-hidden"};let r=hr(t,"style");if(r?.includes("display: none")||r?.includes("visibility: hidden"))return{shouldUnroll:!1,reason:"hidden CSS style"};await this.cdpClient.send({timeout:3e3,method:"DOM.pushNodesByBackendIdsToFrontend",params:{backendNodeIds:[e.backendNodeId]}});let[o,i]=await Promise.all([this.cdpClient.send({timeout:3e3,method:"DOM.getBoxModel",params:{backendNodeId:e.backendNodeId}}),this.cdpClient.send({timeout:3e3,method:"CSS.getComputedStyleForNode",params:{nodeId:e.nodeId}})]);if(!o.model||!o.model.height||!o.model.width)return{shouldUnroll:!1,reason:"no bounding box"};if(o.model.height<10||o.model.width<10)return{shouldUnroll:!1,reason:"small bounding box"};for(let a of i.computedStyle){if(a.name==="display"&&a.value==="none")return{shouldUnroll:!1,reason:"display: none"};if(a.name==="visibility"&&a.value==="hidden")return{shouldUnroll:!1,reason:"visibility: hidden"};if(a.name==="opacity"&&a.value==="0")return{shouldUnroll:!1,reason:"opacity: 0"}}return{shouldUnroll:!0}}async getRawA11yGraph({cdpClient:e,frameId:t,childFrames:r,logTimings:o,logger:i=this.logger,signal:a=this.abortSignalGetter()}){let s=[];try{await this.pageGetter().waitForLoadState("load",{timeout:this.pageLoadTimeoutMs})}catch(u){i.warn({err:u},"Failed to wait for page load event before a11y tree fetch, attempting to continue without it..."),await this.cdpClient.reinitialize()}let l,c;for(let u=0;u<3;u++)try{c=await nn({fn:()=>this.getRawA11yTreeForFrame({frameId:t,timeoutMs:this.pageLoadTimeoutMs,logTimings:o}),codePath:"a11y-tree-fetch-root",logObject:o,signal:a,logger:i});break}catch(h){l=h,i.warn({err:h},"Reinitializing CDP client before retrying a11y graph fetch"),await this.cdpClient.reinitialize()}if(!c)throw new Error(`Failed to fetch accessibility tree for root page: ${l}`);let d={};if(d[t??"root"]=c,!this.flagStore.isBooleanFlagEnabled("auto_expand_iframes"))return d;let p=Array.from(r),m=[];for(;p.length>0;){let u=p.shift();try{let{shouldUnroll:g}=await this.decideChildFrameUnrollEligibility({handle:u,warnings:s});if(!g)continue}catch(g){if(g.message.includes("Could not compute box model"))continue;s.push(`Got error when determining whether to filter frame ${u.frameId} with url ${u.url}, allowing it to be fetched: ${g}`)}p.push(...u.childFrames);let h=async()=>{try{let g=await nn({fn:()=>this.getRawA11yTreeForFrame({frameId:u.frameId,timeoutMs:this.smartWaitingTimeoutMs,logTimings:o}),codePath:`a11y-tree-fetch-child-${u.frameId}`,logObject:o,signal:a,logger:i});d[u.frameId]=g}catch(g){i.warn({err:g,url:u.url,src:u.src},`Error getting raw a11y tree for child frame ${u.frameId}, continuing...`)}};m.push(h())}return await Promise.all(m),s.length>0&&this.logger.warn({warnings:s},"Got warnings when fetching the raw a11y graph"),d}async getRawA11yTreeForFrame({frameId:e,timeoutMs:t,logTimings:r}){let o;if(this.allowPartialAccessibilityTree)o=(await nn({fn:()=>this.cdpClient.send({method:"Accessibility.getFullAXTree",params:{frameId:e??void 0},timeout:t,timeoutMsg:`Fetching the document tree took over ${t}ms. This usually indicates that the current page is too large to be loaded at once, or your machine is severely resource constrained.`}),codePath:"cdp-query-ax-tree",logObject:r,signal:this.abortSignalGetter(),logger:this.logger})).nodes;else{let a=(await nn({fn:()=>this.cdpClient.send({method:"Accessibility.getRootAXNode",params:{frameId:e??void 0},timeout:2e3}),codePath:"cdp-get-root-ax-node",logObject:r,signal:this.abortSignalGetter(),logger:this.logger})).node.backendDOMNodeId;o=(await nn({fn:()=>this.cdpClient.send({method:"Accessibility.queryAXTree",params:{backendNodeId:a},timeout:t,timeoutMsg:`Fetching the document tree took over ${t}ms. This usually indicates that the current page is too large to be loaded at once, or your machine is severely resource constrained.`}),codePath:"cdp-query-ax-tree",logObject:r,signal:this.abortSignalGetter(),logger:this.logger})).nodes}if(!o||o.length<=1)throw new Error("Document is entirely empty");return{root:o[0],allNodes:o}}async getDOMTree({devicePixelRatio:e,signal:t,logger:r}){let o,i=0;for(;!o&&i<3;)try{if(o=await this.cdpClient.send({method:"DOMSnapshot.captureSnapshot",params:{computedStyles:hl},timeout:3e3}),!o||!o.documents.length)throw new Error("Got empty DOM tree")}catch(a){await te(500,t),r.debug({err:a},"Error fetching DOM tree"),i++}if(!o||!o.documents.length)throw new R("InternalWebAgentError","Got empty DOM snapshot with no documents");return Vy({snapshot:o,devicePixelRatio:e,logger:r})}constructIframeRegexAsync(e,t){if(t.frameSrcRegex||t.frameUrlRegex)return;let r=Lb(e);(async()=>{try{let o=await this.enricher?.constructIframeRegex(r);o?.srcRegex&&(t.frameSrcRegex=o.srcRegex),o?.urlRegex&&(t.frameUrlRegex=o.urlRegex),this.logger.debug({result:o,params:r},"Constructed iframe regex for cache")}catch(o){this.logger.warn({err:o},"Failed to construct iframe regex, skipping...")}})()}};var bp=ci(vp(),"momentic","chromium"),nk=ci(vp(),"video"),Cl=process.env.TWO_CAPTCHA_KEY,wp=QO(Hb);wp.use(ek({provider:{id:"2captcha",token:Cl},visualFeedback:!0}));var On=class n{static USER_AGENT=ZO["Desktop Chrome"].userAgent;abortSignal=void 0;contextInitialized=!1;browser;context;properties;page;userControlledBrowserSettings;pageLoadPromises={};lastTabChangeEventTimeout=void 0;clientCallbacks;iconKnowledgeBase;lastIconKnowledgeBaseUpdateTime=0;mockedServices;cdpClient;debugData={logsPerPage:[],harPages:{},harEntries:{}};recentFrameNavigations={};enricher;storage;flagStore;logger;stateManager;transformer;lastScreenshotForRecording=void 0;baseUrl;originsVisited=new Set;viewport;videos=[];constructor({storage:e,flagStore:t,enricher:r,browser:o,context:i,page:a,baseUrl:s,logger:l,mockedServices:c,userBrowserSettings:d,viewport:p,properties:m,clientCallbacks:u,iconKnowledgeBase:h}){if(xg(d),this.mockedServices=c,this.storage=e,this.flagStore=t,this.enricher=r,this.browser=o,this.context=i,this.page=a,this.baseUrl=s,this.logger=l,this.userControlledBrowserSettings=d,this.viewport=p||Gt,this.properties=m,this.clientCallbacks=u,m.recordVideo){let g=this.page.video();g&&this.videos.push(g)}this.iconKnowledgeBase=h}registerAbortSignal(e){this.abortSignal=e}async initialize(){if(this.contextInitialized)return;this.userControlledBrowserSettings.extraHeaders&&await this.context.setExtraHTTPHeaders(this.userControlledBrowserSettings.extraHeaders),await this.context.grantPermissions(["clipboard-read","clipboard-write","microphone","camera"]);let e=this.flagStore.getAllFlags(),t=[this.context.addInitScript({content:Yd.cssGeneratorLibJs}),this.context.addInitScript({content:Yd.htmlUtilsLibJs}),this.context.addInitScript({content:`window._MOMENTIC_BROWSER = true; window._MOMENTIC_FEATURE_FLAGS = ${JSON.stringify(e)}; window.addEventListener('load', (event) => { console.log('[MOMENTIC] Page loaded'); });`})],r=Promise.all(Object.entries(this.mockedServices).map(([a,s])=>this.context.route(a,l=>s.handle(l)))),o=a=>this.handleNewPageEvent(a);this.context.on("page",o),this.handleNewPageEventHelper(this.page),this.context.on("close",()=>{this.context.off("page",o)});let i=Promise.all(t);await Promise.all([i,r]),this.properties.systemDevicePixelRatio||(process.env.MOMENTIC_LOCAL_DEV==="1"&&KO()==="darwin"&&jO("system_profiler SPDisplaysDataType").toString().includes("Retina")?(y.warn("[DEV] Setting device pixel ratio to 2 in local dev since a Retina display was detected"),this.properties.systemDevicePixelRatio=2):this.properties.systemDevicePixelRatio=await this.page.evaluate(()=>window.devicePixelRatio)),this.cdpClient=await Sl.init({logger:this.logger,contextGetter:()=>this.context,pageGetter:()=>this.page,defaultTimeoutMs:this.pageLoadTimeout}),await this.initializeScreencast(),this.stateManager=new Tl({smartWaitingTimeoutMs:this.smartWaitingTimeout,pageLoadTimeoutMs:this.pageLoadTimeout,allowPartialAccessibilityTree:this.userControlledBrowserSettings.allowPartialAccessibilityTree??!1,logger:this.logger,cdpClient:this.cdpClient,pageGetter:()=>this.page,flagStore:this.flagStore,abortSignalGetter:()=>this.abortSignal,enricher:this.enricher,showZeroOpacityElements:this.userControlledBrowserSettings.showZeroOpacityElements??!1,iconKnowledgeBase:this.iconKnowledgeBase}),this.contextInitialized=!0}async fixViewportForNewHeadless(){this.properties.isNewHeadless&&await this.cdpClient.send({method:"Emulation.setDeviceMetricsOverride",params:{width:this.viewport.width,height:this.viewport.height,deviceScaleFactor:0,mobile:this.viewport.width<1e3}})}async initializeScreencast(){await this.fixViewportForNewHeadless(),this.clientCallbacks?.onScreencastFrame&&(await this.cdpClient.send({method:"Page.startScreencast",params:{format:"jpeg",quality:75,maxWidth:this.viewport.width,maxHeight:this.viewport.height}}),this.cdpClient.on("Page.screencastFrame",e=>{let t=e.sessionId,r=Buffer.from(e.data,"base64");this.lastScreenshotForRecording=r,this.clientCallbacks?.onScreencastFrame?.(r,()=>{(async()=>{try{await this.cdpClient.send({method:"Page.screencastFrameAck",params:{sessionId:t}})}catch{}})()})}))}static async init({baseUrl:e,logger:t,storage:r,flagStore:o,enricher:i,mockedServices:a,userBrowserSettings:s,contextArgs:l,browserbaseConnectUrl:c,recordVideo:d,iconKnowledgeBase:p,callbacks:m}){process.env.PW_TEST_SCREENSHOT_NO_FONTS_READY="1";let u;switch(s.browserType){case"Google Chrome":u="chrome";break;case"Chrome for Testing":u=void 0;break;case"Chromium":u="chromium";break;default:u="chromium";break}let h={headless:process.env.MOMENTIC_HEADFUL_BROWSER!=="true",handleSIGTERM:!1,chromiumSandbox:!1,channel:u},g={...l??{},geolocation:{latitude:37.7749,longitude:-122.4194},locale:l?.locale||xo,timezoneId:l?.timezoneId||Eo,colorScheme:l?.colorScheme,httpCredentials:s.basicAuthorization?{username:s.basicAuthorization.username??"",password:s.basicAuthorization.password??""}:void 0,javaScriptEnabled:s.disableJavaScript?!1:void 0,userAgent:s.userAgent??n.USER_AGENT,viewport:l?.viewport??Gt},f=["--disable-dev-shm-usage","--no-first-run","--renderer-process-limit=3","--browser-test","--disable-site-isolation-for-policy","--disable-site-isolation-trials","--disable-backgrounding-occluded-windows","--disable-background-timer-throttling","--disable-renderer-backgrounding","--autoplay-policy=user-gesture-required","--disable-add-to-shelf","--disable-desktop-notifications","--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"],S=null,b,w,v={systemDevicePixelRatio:l?.deviceScaleFactor,recordVideo:d,isNewHeadless:!1};(s.browserType==="Chromium"||s.browserType==="Google Chrome")&&(v.isNewHeadless=!0,h.headless&&f.push("--headless=new")),process.env.BROWSER_MEMORY_MB&&f.push(`--js-flags=--max_old_space_size=${process.env.BROWSER_MEMORY_MB}`),s.disableGpu&&f.push("--disable-3d-apis","--disable-gpu","--disable-software-rasterizer","--disable-accelerated-2d-canvas","--disable-accelerated-mjpeg-decode","--disable-accelerated-video-decode","--disable-accelerated-video-encode","--disable-gl-drawing-for-tests","--disable-webgl","--disable-audio-input","--disable-audio-output");let x=s.localChromeExtensionPaths?.map(A=>A.startsWith("~")?ci(vp(),A.slice(1)):A);if(x?.length){if(s.browserType==="Chrome for Testing")throw new R("UserConfigurationError","Chrome extensions are only supported on Chromium and Google Chrome.");for(let H of x){let F=ci(H,"manifest.json");if(!El(F))throw new R("UserConfigurationError",`Chrome extension path ${F} does not exist.`)}let A=ci(bp,`momentic-session-${Date.now()}`);if(!El(A))try{$O(A,{recursive:!0})}catch(H){throw new R("UserConfigurationError",`Failed to create browser cache directory. Please make sure you have sufficient permissions to create the ${bp} folder: ${H}`)}let N=[...f],O=x.map(H=>XO(H)).join(",");N.push(`--disable-extensions-except=${O}`),g?.deviceScaleFactor&&N.push(`--force-device-scale-factor=${g.deviceScaleFactor}`,`--device-scale-factor=${g.deviceScaleFactor}`),g.viewport&&N.push(`--window-size=${g.viewport.width},${g.viewport.height}`),b=await Hb.launchPersistentContext(ci(bp,`momentic-session-${Date.now()}`),{...h,...g,ignoreDefaultArgs:["--disable-extensions","--disable-component-extensions-with-background-pages"],args:N,baseURL:e}),t.debug({sharedContextOptions:g,sharedBrowserOptions:h,userBrowserSettings:s,chromeArgs:N,flags:o.getAllFlags()},"Browser initialization context args (persistent)"),w=b.pages()[0]}else if(c){S=await wp.connectOverCDP(c);let A=S.contexts()[0];if(!A)throw new Error("Failed to get browserbase default context");let N=A.pages()[0];if(!N)throw new Error("Failed to get browserbase default page");b=A,w=N}else{S=await wp.launch({...h,args:f});let A={...g,baseURL:e,recordVideo:d?{dir:nk}:void 0};b=await S.newContext(A),t.debug({contextArgs:A,sharedBrowserOptions:h,chromeArgs:f,userBrowserSettings:s,flags:o.getAllFlags()},"Browser initialization context args (standard)"),w=await b.newPage()}let C=new n({browser:S,context:b,page:w,baseUrl:e,logger:t,storage:r,flagStore:o,mockedServices:a||{},enricher:i,userBrowserSettings:s,viewport:g.viewport||Gt,properties:v,clientCallbacks:m,iconKnowledgeBase:p});return await C.initialize(),C}async handleAvailableTabsChangeHelper(){try{let e=await Sp(this.context,{getTitles:!0}),t=this.page.url();this.clientCallbacks?.onTabsChange?.(e,t)}catch(e){this.logger.error({err:e},"Error sending available tabs to frontend")}}handleAvailableTabsChange(){try{clearTimeout(this.lastTabChangeEventTimeout),this.lastTabChangeEventTimeout=setTimeout(()=>this.handleAvailableTabsChangeHelper(),500)}catch(e){this.logger.warn({err:e},"Error handling available tabs change")}}addToPageLoadPromises(e,t){let r=Fb(),o=`${e}-${r}`,i=Date.now(),a=!1,s=async()=>{try{await D(t(),{signal:this.abortSignal,milliseconds:this.pageLoadTimeout,message:`Page load promise for code path ${e} timed out after ${this.pageLoadTimeout}ms`})}catch(l){l.name!=="AbortError"&&this.logger.error({err:l,promiseKey:o,codePath:e,duration:Date.now()-i},`Page load promise for code path ${e} encountered error`)}finally{delete this.pageLoadPromises[o],a=!0}};this.pageLoadPromises[o]=s().catch(()=>{}),a&&delete this.pageLoadPromises[o]}handlePageClosedEvent(e){if(this.page!==e){this.logger.debug({url:e.url()},"Detected background page was closed, just updating available tabs only"),this.handleAvailableTabsChange();return}let t=async()=>{if(this.closed)return;this.logger.debug({url:e.url()},"Detected active page was closed, switching to another tab");let r=this.context.pages();for(let o=r.length-1;o>=0;o--){let i=r[o];if(!(!i||i.isClosed()||!zr(i.url()))){this.logger.info(`Automatically switching to tab ${o} after close: ${i.url()}`),await this.switchToPage({type:"INDEX",index:String(o)});break}}};this.addToPageLoadPromises("page closed handler",async()=>t())}handleNewPageEvent(e){let t=e.url();if(this.logger.info({url:t},"Detected new page event, registering handlers and waiting for load to complete"),this.properties.recordVideo){let r=e.video();r&&this.videos.push(r)}try{this.handleNewPageEventHelper(e)}catch(r){this.logger.warn({err:r},"Error handling new page open, continuing....")}}handleNewPageEventHelper(e){let t=Fb(),r="new-page-load-handler";e.on("close",a=>this.handlePageClosedEvent(a)),e.on("framenavigated",a=>this.handleFrameNavigationEvent(a)),e.on("crash",()=>{this.logger.error("Page crashed at the Playwright level!")});let o=this.context.pages().indexOf(e);e.on("console",a=>{db(e,o,this.debugData,a,this.logger)}),e.on("request",a=>{fb(t,this.debugData,a,this.logger)});let i=async()=>{await gb(t,this.debugData,e),await this.loadFrameAndRecordUrl({root:e,codePath:r}),this.handleAvailableTabsChange()};this.addToPageLoadPromises(r,async()=>i())}async handleCollectSvgs(e){if(!this.flagStore.isBooleanFlagEnabled("icon_knowledge_base")||this.page.isClosed()||this.page.mainFrame()!==e||!this.iconKnowledgeBase||!this.clientCallbacks?.onSvgsCollected||Date.now()-this.lastIconKnowledgeBaseUpdateTime<5e3)return;this.lastIconKnowledgeBaseUpdateTime=Date.now();let t=await this.stateManager.getDomGraph({devicePixelRatio:this.devicePixelRatio}),r=Jy({domGraph:t,flagStore:this.flagStore,logger:this.logger,existingHashes:this.iconKnowledgeBase});if(r.forEach(s=>{this.iconKnowledgeBase[s.hash]=s}),!r.length)return;let o=ze(this.logger),i={pageUrl:e.url(),firstSeenTime:Date.now(),hostname:qO()};for(let s of["runId","testId"])o[s]&&(i[s]=o[s]);let a={metadata:i,newSvgs:r};this.clientCallbacks.onSvgsCollected(a)}handleFrameNavigationEvent(e){let t=e.url(),r=e.parentFrame()?"has-parent":"no-parent",o=`frame-navigation-handler-${t.slice(0,50)}-${r}`;if(!t||t==="about:blank"||!zr(t)||this.recentFrameNavigations[o]&&Date.now()-this.recentFrameNavigations[o]<1e3)return;this.recentFrameNavigations[o]=Date.now();let i=async()=>{try{if(e.isDetached())return;await this.loadFrameAndRecordUrl({root:e,codePath:o,signal:this.abortSignal}),this.handleAvailableTabsChange(),!e.parentFrame()&&!e.isDetached()&&this.clientCallbacks?.onSvgsCollected&&(setTimeout(()=>{(async()=>{try{await this.handleCollectSvgs(e)}catch(s){this.logger.warn({err:s},"Failed to collect SVGs on page, continuing...")}})()},5e3),this.transformer&&await this.injectKnowledgeBaseIntoBrowser(e))}catch(a){a.name!=="AbortError"&&this.logger.warn({err:a},"Failed to handle frame navigation event, continuing...")}};this.addToPageLoadPromises(o,async()=>i())}async injectKnowledgeBaseIntoBrowser(e){try{if(!this.iconKnowledgeBase||await e.evaluate(()=>!!window._MOMENTIC_ICON_KNOWLEDGE_BASE))return;let r={};Object.keys(this.iconKnowledgeBase).forEach(o=>{this.iconKnowledgeBase[o]?.description&&(r[o]=this.iconKnowledgeBase[o].description)}),await e.evaluate(o=>{let i=window;i._MOMENTIC_ICON_KNOWLEDGE_BASE=o},r)}catch(t){this.logger.warn({err:t},"Failed to inject icon knowledge base into browser, continuing...")}}getBrowserCallbacks(){return{waitForPageLoad:()=>this.waitForPageLoad(),waitForUrl:e=>this.waitForUrl(e),getBrowserState:e=>this.getBrowserState(e),waitForDomStability:e=>this.waitForDOMStability(e),state:{url:()=>this.url(),getDomGraph:()=>this.stateManager.domGraph,getOpenPages:()=>this.getOpenPages(),getRoot:()=>this.getActivePageOrFrame()},pageLoadTimeoutMs:this.pageLoadTimeout,signal:this.abortSignal}}ping(){if(this.closed)throw new Error("Page has been closed")}setActiveFrameConfig(e){this.stateManager.setActiveFrameConfig(e)}async reset(e){for(this.abortSignal=void 0,this.debugData.logsPerPage=[],this.debugData.harPages={},this.debugData.harEntries={},this.pageLoadPromises={};this.videos.length>0;)this.videos.pop();await this.clearAuthState({closeNonActiveTabs:!0}),await this.stopScreencast(),await this.reinitializeCDPClient(),await this.navigate({url:e.newUrl??this.baseUrl,initialNavigation:!0,loadTimeoutMs:e.timeout}),this.stateManager.reset()}async clearHighlights(){try{await D(mp(this.getBrowserCallbacks()),{milliseconds:1e3})}catch(e){this.logger.debug({err:e},"Failed to clear highlights, continuing...")}}async cleanup(){this.abortSignal=void 0;try{this.originsVisited.clear(),await this.context.close(),await this.browser?.close(),this.browser=null}catch(e){this.logger.warn({err:e},"Error cleaning up browser, continuing...")}finally{this.browser=null}}get closed(){return this.context.pages().every(e=>e.isClosed())||!!this.browser&&!this.browser.isConnected()}async ensureMomenticBrowserScriptsLoaded(e,t,r){let o=Date.now(),i=0,a=0;for(;Date.now()-o<8e3;){a++,r?.throwIfAborted();try{if(await Xe({fn:()=>{let l=window;return!!(l.generateCssSelectors&&l.evaluateCssSelectors&&l.generateHtmlCacheAttributes&&l.ldist)},timeout:1e3,arg:void 0,waitForPageLoad:()=>this.waitForPageLoad(),root:e,codePath:"ensureMomenticBrowserScriptsLoaded"}))return}catch(s){if(i++,i>=3){t.warn({err:s},"Multiple errors checking if Momentic scripts are loaded, aborting...");return}}await te(500),a%2===0&&t.warn("Still waiting for momentic browser scripts to load...")}throw new Error(`Failed to load momentic browser scripts on page ${e.url()}`)}async html(){let e=await this.getActivePageOrFrame();return await this.ensureMomenticBrowserScriptsLoaded(e,this.logger),Xe({root:e,fn:()=>{let t=window;if(!t?.getFullHtmlTree)throw new Error("Missing Momentic HTML library when fetching page HTML");return t.getFullHtmlTree()},arg:void 0,timeout:3e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"getFullHtmlTree"})}url(){return this.page.url()}async screenshot(e){let{retries:t=1}=e,r=Date.now(),o=this.page.url();try{await this.fixViewportForNewHeadless();let i=await this.screenshotHelper({...e,retries:t});if(i.byteLength>5e6)this.logger.error("Page screenshot is greater than 5MB, which may cause performance issues with some AI models");else if(i.length===0)throw new Error("Got empty screenshot");return i}catch(i){if(t<=0||i.message.includes("has been closed"))throw i;return this.logger.debug({err:i,pageUrl:o},"Failed taking screenshot, retrying..."),await te(250),this.screenshot({...e,retries:t-1})}finally{Date.now()-r>1e3&&this.logger.warn({pageUrl:o,duration:Date.now()-r},"Screenshot took longer than expected")}}async screenshotHelper({locator:e,quality:t,saveToDiskPath:r,timeout:o,respectActiveFrame:i,clearHighlights:a=!1}){a&&await this.clearHighlights(),i&&this.stateManager.frameConfig&&(e=await(await this.getActivePageOrFrame()).frameElement());let s=await this.cdpClient.send({method:"Page.captureScreenshot",params:{format:"jpeg",quality:t,optimizeForSpeed:!0},timeout:o??2e3}),l=Buffer.from(s.data,"base64"),c=await Ub.fromBuffer(l),{width:d,height:p}=this.getViewport();if((c.bitmap.width!==d||c.bitmap.height!==p)&&(l=await c.resize({w:d,h:p}).getBuffer("image/jpeg")),r&&WO(r,l),this.lastScreenshotForRecording=l,!e)return l;let m=await e.boundingBox({timeout:1e3});if(!m)throw new Error("Attempted to screenshot an element that is not visible on the page");let{x:u,y:h,width:g,height:f}=m;if(!g||!f)throw new Error("Attempted to screenshot an element with zero width or height");if(u<0||h<0)throw new Error("Attempted to screenshot an element with negative coordinates");u=Math.floor(u),h=Math.floor(h),g=Math.floor(g),f=Math.floor(f);try{l=await(await Ub.fromBuffer(l)).crop({x:u,y:h,w:g,h:f}).getBuffer("image/jpeg")}catch(S){throw new Error(`Failed taking element screenshot at coordinates (${u}, ${h}) with size (${g}, ${f}): ${S}`)}return"dispose"in e&&await e?.dispose(),l}getViewport(){return this.viewport}async navigate({url:e,initialNavigation:t=!1,loadTimeoutMs:r=this.pageLoadTimeout}){Ef(e)&&(e=new URL(e,this.baseUrl).toString());let o=Date.now();t||(await this.waitForPageLoad(),await this.waitForDOMStability());let i=!1,a;for(let l=0;l<3;l++)try{await this.page.goto(e,{timeout:r,waitUntil:"domcontentloaded"}),i=!0;break}catch(c){if(a=c,this.abortSignal?.throwIfAborted(),this.logger.warn({err:c},`Error occurred during navigation${l===0?", retrying...":" (fatal)"}`),await te(500),a.message.includes("Timeout")&&a.message.includes("exceeded")||a.message.includes("net::ERR_CONNECTION_REFUSED"))break;await this.cdpClient.send({method:"Page.stopLoading",params:{},timeout:1e3})}if(!i)throw new R("UserInfrastructureError",a?.message??"Failed to load page");await this.loadFrameAndRecordUrl({root:this.page,signal:this.abortSignal,codePath:"navigate-step-wait-for-load"}),this.logger.debug({url:e},`Navigation complete in ${Math.floor(Date.now()-o)}ms`);let s=this.url();if(Hy.has(s))throw new R("UserInfrastructureError",`${e} took too long to load \u{1F61E}. Please ensure the site is accessible and returns content within the page load timeout.`);if(t)try{await this.exposeRecordingBindings()}catch(l){l instanceof Error&&l.message.includes("already registered")||this.logger.error({err:l},"Failed to install Momentic libraries for action recording")}await this.fixViewportForNewHeadless()}async type(e,t={},r=!1){await this.directTypeHelper(e,t,r)}async getActiveElement(e){try{return await Xe({root:e,fn:()=>{let r=document.activeElement?.textContent??void 0;return r&&r.length>100&&(r=r.slice(0,100)+"...[TRUNCATED]"),document.activeElement?{tag:document.activeElement.tagName.toLowerCase(),contentEditable:document.activeElement.getAttribute("contenteditable")??void 0,textContent:r}:void 0},arg:void 0,timeout:1e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"getActiveElement"})}catch(t){this.logger.warn({err:t},"Failed to get active element");return}}async directTypeHelper(e,t={},r=!1){let o=await this.getActivePageOrFrame();await vb({root:o,text:e,options:t,logger:this.logger,callbacks:this.getBrowserCallbacks()});let i=await this.getActiveElement(o);if(r){let a=Date.now();for(;Date.now()-a<this.smartWaitingTimeout&&(!i||i.tag==="body");)await te(250),this.abortSignal?.throwIfAborted(),i=await this.getActiveElement(o);i||this.logger.warn("No active element found to type into, attempting anyways")}t.clearContent&&(t.forceClearContent||i?.tag==="input"||i?.tag==="textarea"?(process.platform==="darwin"?await this.page.keyboard.press("Meta+A"):await this.page.keyboard.press("Control+A"),await this.page.keyboard.press("Backspace"),await this.page.waitForTimeout(25)):this.logger.warn({activeElementDetails:i},"Currently active element is not eligible for replace content, skipping...")),await this.page.keyboard.type(e,{delay:t.delay??Ou}),t.pressEnter&&await this.press("Enter",{})}async scrollIntoView(e){await e.scrollIntoViewIfNeeded({timeout:2e3})}async highlightA11yId(e){try{let{resolution:t}=await this.createTargetFromA11yId({id:e,description:null,targetSource:"AI",skipSaveToCache:!0});return await this.highlight(t.locator),!0}catch(t){return this.logger.debug({err:t,id:e},"Failed to highlight target"),!1}}async highlight(e){return bl({locator:e,callbacks:this.getBrowserCallbacks(),logger:this.logger})}recordUrlVisited(e){try{let t=new URL(e).origin;if(t==="null")return;this.originsVisited.add(t)}catch(t){this.logger.warn({err:t},"Failed to record origin visited")}}async waitForPageLoad(){let e=Date.now(),t=Object.values(this.pageLoadPromises),r=Object.keys(this.pageLoadPromises),o=-1,i=0;for(;t.length!==0;){if(Date.now()-e>this.pageLoadTimeout&&this.logger.error({outstandingPromiseKeys:r,outstandingPromises:t},"Still waiting on page load promises"),Date.now()-o<20&&(i++,i>2)){this.logger.error({outstandingPromiseKeys:r,outstandingPromises:t},"Synchronous waiting loop detected, exiting page load wait");return}o=Date.now(),await Promise.allSettled(t),t=Object.values(this.pageLoadPromises),r=Object.keys(this.pageLoadPromises)}}async clearAuthState(e){await this.context.clearCookies();for(let o of this.originsVisited)this.logger.debug({origin:o},`Clearing data using CDP for origin ${o}`),await this.cdpClient.send({method:"Storage.clearDataForOrigin",params:{origin:o,storageTypes:"all"},timeout:1e3}),this.originsVisited.delete(o);let t=this.context.pages().indexOf(this.page),r=[...this.context.pages()];for(let o=0;o<r.length;o++){let i=r[o];if(i.isClosed())continue;let a=i.url();try{this.originsVisited.delete(new URL(a).origin)}catch{}await cb(i,this.logger),o!==t&&e.closeNonActiveTabs&&(this.logger.debug(`Closing tab ${o} with URL ${a}`),await i.close())}}async loadAuthState(e){await this.waitForPageLoad(),await this.waitForDOMStability(),!e||Object.keys(e).length===0?await this.clearAuthState({closeNonActiveTabs:!1}):await this.loadAuthStateHelper(e),await this.refresh(),await this.waitForDOMStability()}async loadAuthStateHelper(e){let t=[];for(let i of e.cookies??[]){let a=await this.setCookie(i);t=t.concat(a)}this.logger.debug(`Loaded ${e.cookies?.length??0} cookies`),await this.cdpClient.send({method:"DOMStorage.enable",params:void 0,timeout:1e3});let r=0;for(let i of e.origins??[])for(let a of i.localStorage)try{await this.cdpClient.send({timeout:1e3,method:"DOMStorage.setDOMStorageItem",params:{storageId:{securityOrigin:new URL(i.origin).origin,isLocalStorage:!0},key:a.name,value:a.value}}),r++}catch(s){this.logger.warn({err:s,origin:i},"Failed to set local storage entry, continuing...");break}this.logger.debug(`Loaded ${r} local storage entries`);let o=e.idb;o&&Object.keys(o).length>0&&(await lb(this.page,o,this.logger),this.logger.debug(`Loaded ${Object.keys(o??{}).length} indexedDB databases`))}async saveAuthState(){let t=0,r=null;for(;t<=2;)try{await this.waitForPageLoad(),await this.waitForDOMStability();let o=await this.context.storageState();return o.idb=await sb(this.page,this.logger),o}catch(o){if(r=o,t++,t<=2){this.logger.warn({err:o,retryCount:t,maxRetries:2},`Error saving auth state, retrying (${t}/2)...`);let i=Math.pow(2,t)*100;await new Promise(a=>setTimeout(a,i))}}throw this.logger.error({err:r},"Failed to save auth state after 2 retries"),new R("ActionFailureError",`Failed to save auth state: ${r?.message}`)}async getOpenPages(e){return Sp(this.context,e)}saveA11yDetailsToCache(e,t){t.id=e.id,t.content=e.content,t.name=e.name,t.role=e.role,t.numChildren=e.children.length,t.serializedForm=e.getSerializedFormWithContext(),t.nodeOnlySerializedForm=e.getNodeOnlySerializedForm()}async saveNodeDetailsToCache({node:e,target:t,dataMomenticId:r,locator:o,generateNewCssSelectors:i,logger:a=this.logger}){if(e&&this.saveA11yDetailsToCache(e,t),t.frameCache=this.stateManager.saveAutoFrameCacheDetails(t.frameCache),r&&(t.dataMomenticId=r),o)try{let s=await this.fetchHtmlAttributes(o,a);s&&(t.serializedHtml=s.serializedHtml,t.nodeOnlySerializedHtml=s.nodeOnlySerializedHtml,i&&(t.generatedSelectors=s.generatedSelectors))}catch(s){a.warn({err:s},"Failed to fetch HTML attributes for target, continuing...")}try{await this.saveElementVisualAttributes(t,o,a)}catch(s){a.debug({err:s},"Failed to save element visual details, continuing...")}}async saveElementVisualAttributes(e,t,r){if(!t)return;await t.scrollIntoViewIfNeeded({timeout:1e3});let o=await t.boundingBox({timeout:1e3});if(!o||!o.width||!o.height){r.debug("Skipping visual attributes saving for element with no bounding box after action"),e.boundingBox=void 0,e.screenshotUrl=void 0;return}e.boundingBox=o;let{x:i=0,y:a=0,width:s=0,height:l=0}=o;if(e.boundingBox&&Math.abs(e.boundingBox.width-s)<1&&Math.abs(e.boundingBox.height-l)<1&&Math.abs((e.boundingBox.x??0)-i)<1&&Math.abs((e.boundingBox.y??0)-a)<1||!Zd.includes(e?.role??""))return;let c=await this.screenshot({locator:t,retries:0});e.screenshotUrl=await this.storage.uploadScreenshot(c)}async resolveTargetWithCssSelectors({root:e,target:t,logger:r}){if(!t.generatedSelectors||t.generatedSelectors.length<2||!t.nodeOnlySerializedHtml)throw new Yi("Insufficient data to resolve target using CSS selectors");let o=Bb(t.generatedSelectors),i;try{i=await Xe({fn:d=>window.evaluateCssSelectors(d),arg:{selectors:t.generatedSelectors,ldistThreshold:.05,serializedNodeWithText:t.nodeOnlySerializedHtml,requireBoundingBox:!0,ignoreHrefForCaching:this.userControlledBrowserSettings.ignoreHrefForCaching,requireMatchingBoundingBox:this.userControlledBrowserSettings.bustCacheOnBoundingBoxChange?t.boundingBox:void 0},root:e,timeout:2e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"evaluateCssSelectors"})}catch(d){throw new Error(`Failed to evaluate CSS selectors in browser: ${d}`)}let a=i.result;if(!a)throw new Error(`CSS selector evaluation returned no eligible elements:
3603
3603
  ${i.logs.join(`
3604
3604
  `)}`);let s,l,c;if(this.flagStore.isBooleanFlagEnabled("visual_actions")){a.mPath||r.error({foundElement:a},"Found element did not have an mPath despite using visual actions");let p=a.mPath.join(" > ");s=e.locator(p),l=this.stateManager.getNodeUsingMPathSelector(p)}else c=parseInt(a.dataMomenticId),l=this.stateManager.dataMomenticIdToNodeMap[c],s=e.locator(a.workingSelectors[0]);return await this.saveNodeDetailsToCache({node:l,target:t,dataMomenticId:c,locator:s,logger:r,generateNewCssSelectors:a.workingSelectors.length<5}),{a11yNode:l,displayString:a.serializedElement,locator:s,decisions:[{type:"CSS_SELECTOR",matched:!0,logs:i.logs,reason:`${a.workingSelectors.length} CSS selectors matched the following element: ${a.serializedElement}`,selectors:a.workingSelectors.slice(0,5)}]}}async resolveAutoFrameCache(e){return this.stateManager.resolveAutoFrameCache(e)}async createTargetFromA11yId({id:e,description:t,targetSource:r,skipSaveToCache:o,logger:i=this.logger}){if(e<0)throw new R("InternalWebAgentError","Only positive IDs should be passed to resolveAllyIdToTarget");let a=this.stateManager.a11yIdToNodeMap[e];if(!a)throw new R("InternalWebAgentError",`Resolving target failed because id ${e} does not exist on the page. This generally indicates an incorrect element was targeted.`);let s=this.stateManager.frameConfig,l,c,d,p;if(this.flagStore.isBooleanFlagEnabled("auto_expand_iframes")&&!s&&a.parentFrame){let f=a.parentFrame,{cache:S,config:b}=await this.stateManager.getAutoFrameDetailsFromHandle(f);c=S,d=b,l=b.frame,p="auto iframe"}else a.parentFrame&&s?(d=s,l=await this.getActivePageOrFrame(),p="hardcoded url already on the state manager"):(l=await this.getActivePageOrFrame(),p="should not be possible");let m=await this.stateManager.getLocatorFromA11yNode({page:this.page,root:l,node:a}),u={id:e,inputDescription:t??void 0,targetSource:r,targetUpdateTime:new Date().toISOString(),frameCache:c},h,g=!1;o||(d&&(i.debug({frameConfigSource:p,frameConfig:Ob(d)},"A11y node was resolved to a target within an iframe"),h=this.stateManager.frameConfig,this.stateManager.setActiveFrameConfig(d),g=!0),await this.saveNodeDetailsToCache({node:a,target:u,dataMomenticId:a.dataMomenticId,locator:m,logger:i,generateNewCssSelectors:!0}));try{return{resolution:{locator:m,a11yNode:a,displayString:a.getNodeOnlySerializedForm(),decisions:[]},target:u,frameConfig:d,frameConfigSource:p}}finally{g&&this.stateManager.setActiveFrameConfig(h)}}async resolveTarget(e,t,r={}){let{skipFetchTree:o=!1,targetName:i,logger:a=this.logger,signal:s=this.abortSignal}=r;if(t.frameCache&&this.flagStore.isBooleanFlagEnabled("auto_expand_iframes")){let m,u=!1,h=Date.now();for(;Date.now()-h<this.smartWaitingTimeout;)try{let g=await this.stateManager.resolveAutoFrameCache(t.frameCache);this.setActiveFrameConfig(g),u=!0;break}catch(g){m=g,await te(500,s)}if(!u)throw m}let l=await this.getActivePageOrFrame();await this.ensureMomenticBrowserScriptsLoaded(l,a,s);let c=Date.now(),d=0,p;for(;Date.now()-c<this.smartWaitingTimeout;){this.abortSignal?.throwIfAborted(),d++;let m=d===1||Date.now()-c>this.smartWaitingTimeout-2e3&&d%2===0;try{p=await this.resolveTargetHelper({root:l,target:t,cssSelectorOnly:!0,skipFetchTree:o,logger:m?a:kr,signal:s});break}catch(u){if(u instanceof Yi)break;s?.throwIfAborted(),m&&a.debug({err:u},`Could not resolve target through CSS selectors only (x${d})`),await te(500,s)}}return p||(p=await this.resolveTargetHelper({root:l,target:t,cssSelectorOnly:!1,skipFetchTree:o,logger:a,signal:s}),t.targetSource="HEURISTIC_HEALED",t.targetUpdateTime=new Date().toISOString(),t.targetUpdateLoggerTags=ze(a),a.debug({decisions:p.decisions},"Target resolution succeeded after waiting")),e?.details?.push({type:"TARGETING",name:i,elementLocationDecisions:p?.decisions??[],pageState:void 0,targetSource:t.targetSource,targetUpdateTime:t.targetUpdateTime}),p}async resolveTargetHelper({root:e,target:t,cssSelectorOnly:r,skipFetchTree:o,logger:i,signal:a,skipSaveToCache:s}){let l=[],c;o||(c=(await this.getBrowserState({logger:i,abortSignal:a,skipWait:!0})).serialize(),i.debug({tree:c.length>4e5?c.slice(0,4e5):c},"Got a11y tree before attempting target resolution"));let d=this.stateManager.a11yIdToNodeMap[t.id],p=d?.getNodeOnlySerializedForm();if(!o&&!this.flagStore.isBooleanFlagEnabled("visual_actions")&&d&&t.serializedForm&&p===t.serializedForm){let u=await this.stateManager.getLocatorFromA11yNode({page:this.page,root:e,node:d});return s||await this.saveNodeDetailsToCache({node:d,target:t,dataMomenticId:d.dataMomenticId,locator:u,logger:i,generateNewCssSelectors:!1}),l.push({type:"A11Y_ID",matched:!0,reason:`An element with the same Chrome-internal accessibility node ID matched the saved content exactly: ${p}.`}),{locator:u,a11yNode:d,displayString:p,decisions:l,pageState:void 0}}let m;if(t.generatedSelectors){let u;try{u=await this.resolveTargetWithCssSelectors({root:e,target:t,logger:i})}catch(h){m=h}if(u)return{...u,pageState:void 0,decisions:[...l,...u.decisions]};r||(l.push({type:"CSS_SELECTOR",matched:!1,reason:m?.message,selectors:Bb(t.generatedSelectors)}),t.generatedSelectors=void 0)}if(r)throw m;if(!this.flagStore.isBooleanFlagEnabled("disable_secondary_cache_resolution")){let u=await this.resolveTargetWithSecondaryMethods({root:e,tree:c,target:t,decisions:l,logger:i,signal:a,skipSaveToCache:s});if(u)return u}throw i.warn({target:t,decisions:l},"Failed to find any relevant node"),new nr(`Could not find any relevant node given target: ${JSON.stringify(t)}`,l)}async resolveHardcodedCssSelector(e){let{ctx:t,selector:r,logger:o=this.logger,signal:i=this.abortSignal,timeoutMs:a=this.smartWaitingTimeout}=e,s=await this.getActivePageOrFrame(),l=Date.now(),c=0,d,p=[];for(;Date.now()-l<a;){i?.throwIfAborted(),c++;let m=s.locator(r),u;try{return await m.waitFor({state:"attached",timeout:1e3}),u=await gn(m,o)??"",p.push({type:"USER_SELECTOR",matched:!0,reason:`The user-provided CSS selector ${r} matched an element on the page.`}),t?.details?.push({type:"TARGETING",name:e.targetName,elementLocationDecisions:p,targetSource:"USER_CSS_SELECTOR",targetUpdateTime:new Date().toISOString()}),{locator:m,displayString:u,decisions:p}}catch(h){let g=h.message;d=new R("ActionFailureError",`CSS selector '${r}' failed to resolve after ${c} attempts: ${g.includes("locator.waitFor: Timeout")?"the selector did not match any element on the page":g}`),await te(500,i)}}throw d}async resolveTargetWithSecondaryMethods(e){if(!e.target.boundingBox)return;let t=await this.resolveTargetWithSecondaryMethodsHelper(e);if(!t)return;let{x:r,y:o,width:i,height:a}=e.target.boundingBox,s=await t.locator.boundingBox({timeout:1e3});if(!s){this.logger.debug({proposedNode:t.displayString},"Rejecting secondary matching result due to lack of a bounding box");return}let{x:l,y:c,width:d,height:p}=s;if(Math.abs(d-i)>50||Math.abs(p-a)>50){this.logger.debug({newW:d,oldW:i,newH:p,oldH:a,proposedNode:t.displayString},"Rejecting secondary matching result due to difference in dimensions");return}else if(r&&o&&(!l||!c)){this.logger.debug({oldX:r,oldY:o,proposedNode:t.displayString},"Rejecting secondary matching result due to new result not having x/y coords");return}else if(Math.abs((l??0)-(r??0))>200||Math.abs((c??0)-(o??0))>200){this.logger.debug({newX:l,newY:c,oldX:r,oldY:o,proposedNode:t.displayString},"Rejecting secondary matching result due to large difference in x/y coords");return}return t}async resolveTargetWithSecondaryMethodsHelper({root:e,target:t,decisions:r,logger:o,signal:i,skipSaveToCache:a}){if(t.nodeOnlySerializedHtml&&t.nodeOnlySerializedHtml.trim().length<10){let c="Refusing to attempt HTML comparison since the saved element is too short.";r.push({type:"HTML_DISTANCE",matched:!1,reason:c})}else if(t.nodeOnlySerializedHtml&&t.nodeOnlySerializedHtml.length>50)try{let c=await Xe({fn:p=>window.findClosestElementByLDist?.(p),arg:{nodeOnlySerializedHtml:t.nodeOnlySerializedHtml},timeout:2e3,root:e,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"findClosestElementByLDist"}),d=Math.floor(.05*t.nodeOnlySerializedHtml.length);if(c&&c.closestDistance&&c.closestDistance>=d){let p=`Closest HTML candidate still has too far distance (${c.closestDistance}) from threshold (${d})`;r.push({type:"HTML_DISTANCE",matched:!1,reason:p,distance:c.closestDistance,closestElement:c.closestNodeSerialized})}else{if(c?.error)throw new Error(c.error);if(c?.dataMomenticId||c?.mPathSelector){let p=c.dataMomenticId?parseInt(c.dataMomenticId):void 0,m,u;if(p)m=this.stateManager.dataMomenticIdToNodeMap[p],u=e.locator(`[${Tt}="${p}"]`);else if(c.mPathSelector)m=this.stateManager.getNodeUsingMPathSelector(c.mPathSelector),u=e.locator(c.mPathSelector);else throw new Error("HTML ldist comparison returned no error, data momentic id, or mPath selector");let h=c.closestNodeSerialized??await gn(u,o)??"unknown element";return o.warn({result:c,originalTarget:t,displayString:h},"Resolved cached target to new node with pure html levenshtein distance"),a||await this.saveNodeDetailsToCache({node:m,target:t,dataMomenticId:p,locator:u,logger:o,generateNewCssSelectors:!0}),r.push({type:"HTML_DISTANCE",matched:!0,reason:`Found an element on the page within ${d} string comparison distance of the saved element.`,logs:c.logs,distance:c.closestDistance,closestElement:h,savedElement:t.nodeOnlySerializedHtml}),{locator:u,a11yNode:m,displayString:h,decisions:r,pageState:void 0}}else throw new Error(`Got invalid HTML evaluation result: ${JSON.stringify(c)}`)}}catch(c){o.debug({err:c},"Failed to find closest HTML node using levenshtein distance"),r.push({type:"HTML_DISTANCE",matched:!1,reason:`Error finding closest HTML node by string distance: ${c}`})}let s=t.screenshotUrl,l=t.role??"";if(s&&Zd.includes(l))try{let c=await this.resolveTargetWithTemplateMatching({root:e,oldTarget:t,screenshotUrl:s,signal:i,skipSaveToCache:a});return{...c,decisions:[...r,...c.decisions],pageState:void 0}}catch(c){i?.throwIfAborted(),r.push({type:"TEMPLATE_MATCHING",matched:!1,reason:`Error finding closest element using saved screenshot: ${c}`,elementImageUrl:s}),o.warn({err:c},"Did not find any close element using saved screenshot")}}async resolveTargetWithTemplateMatching({root:e,screenshotUrl:t,oldTarget:r,signal:o,skipSaveToCache:i}){let a;if(!this.enricher)throw new Error("Enricher not available for screenshot resolution");let s=await this.screenshot({retries:0}),c=await(await fetch(t)).arrayBuffer(),d=tk(),p=await this.enricher.runTemplateMatching({id:d,searchImageBase64String:Buffer.from(c).toString("base64"),pageImageBase64String:s.toString("base64")},{signal:o});this.logger.debug({id:d,templateMatch:p},"Template matching got successful result");let{target:m,locator:u}=await this.getTargetFromPositionPercentages({percentX:p.x,percentY:p.y}),h=m.boundingBox?.width,g=m.boundingBox?.height;if(!h||!g)throw a="Rejecting target from screenshot due to no bounding box",new Error(a);let f=m.id,S=this.stateManager.a11yIdToNodeMap[f];return i||await this.saveNodeDetailsToCache({target:r,node:S,locator:u,dataMomenticId:f,generateNewCssSelectors:!0}),{locator:u,a11yNode:S,displayString:m.nodeOnlySerializedHtml??"",decisions:[{type:"TEMPLATE_MATCHING",matched:!0,reason:"Found element using screenshot",elementImageUrl:t}]}}async resolveTargetWithXY(e,t=!1){if(this.logger.debug({target:e,skipFetchTree:t},"Resolve target through x / y positioning called"),!t){let a=(await this.getBrowserState({})).serialize()}let r=await this.getActivePageOrFrame(),{target:o}=await this.getTargetFromPixelPosition(e);if((o.generatedSelectors??[]).length>0)return{locator:r.locator(o.generatedSelectors[0]),a11yNode:this.stateManager.a11yIdToNodeMap[o.id],displayString:o.nodeOnlySerializedHtml??o.nodeOnlySerializedForm??"Unknown element",decisions:[]};let i=this.stateManager.a11yIdToNodeMap[o.id];if(i&&i.dataMomenticId)return{locator:r.locator(`[${Tt}="${i.dataMomenticId}"]`),a11yNode:i,displayString:i.getNodeOnlySerializedForm(),decisions:[]};throw new Error("Could not resolve target with x / y through either raw HTML or the accessibility tree")}async typeIntoTarget(e,t,r={}){await this.highlight(t.locator);let o=await t.locator.getAttribute("type",{timeout:1e3})??"",i=wb.some(a=>a===o.toLowerCase());return await gp({targetingResult:t,options:{force:r.force},logger:this.logger,retryTimeoutMs:this.smartWaitingTimeout,position:i?{x:1,y:1}:void 0,actionSource:"type",browserCallbacks:this.getBrowserCallbacks(),flagStore:this.flagStore}),await this.page.waitForTimeout(150),this.directTypeHelper(e,r)}async click(e,t,r={}){return gp({targetingResult:e,options:r,logger:this.logger,actionSource:"click",retryTimeoutMs:this.smartWaitingTimeout,controllerCallbacks:t,browserCallbacks:this.getBrowserCallbacks(),flagStore:this.flagStore})}async waitForUrl({beforeUrl:e,matcher:t},r){let o=r?.timeout??this.pageLoadTimeout,i=Date.now(),a=!1,s=e;for(;Date.now()-i<o;){if(this.abortSignal?.throwIfAborted(),s=this.url(),xf(s,t,r)){a=!0;break}await te(500,this.abortSignal)}if(!a)throw new R("ActionFailureError",`The active page URL ${r?.negated?"still does":"does not"} ${ad(t)} in ${o}ms.
3605
3605
  Current tab: ${s}`);try{await this.loadFrameAndRecordUrl({root:this.page,signal:this.abortSignal,codePath:"wait-for-url-step"})}catch(l){this.logger.warn({err:l},"Failed waiting for page load after URL change, continuing...")}}async dragAndDrop(e,t,r={}){await this.hover({locator:e}),await this.page.mouse.down();let o=await t.boundingBox({timeout:1e3});if(!o)throw new R("ActionFailureError","Could not get bounding box of target element");let i=o.x+o.width/2,a=o.y+o.height/2,s=r.steps??5;await this.page.mouse.move(i,a,{steps:s}),await te(r.hoverSeconds?Math.min(r.hoverSeconds*1e3,2e3):500),await this.page.mouse.up()}async mouseDrag(e,t,r,o){o&&await this.hover({locator:o});let i=await(await this.getActivePageOrFrame()).evaluate(up);i||(this.logger.debug("Could not get current mouse position before mouse drag action, defaulting to 0,0"),i={left:0,top:0}),await this.page.mouse.down(),await this.page.mouse.move(e+i.left,t+i.top,{steps:r}),await te(250),await this.page.mouse.up()}async hover(e){await this.highlight(e.locator),await Xr({func:async t=>{await t.locator.scrollIntoViewIfNeeded({timeout:1e3});let r=await t.locator.boundingBox({timeout:1e3});if(!r)throw new Error("Attempted to hover over element with no bounding box");await this.page.mouse.move(r.x+r.width/2,r.y+r.height/2,{steps:3})},action:"hovering over element",logger:this.logger,retryTimeoutMs:this.smartWaitingTimeout,targetingResult:e,callbacks:this.getBrowserCallbacks()})}async focus(e){await this.highlight(e.locator),await Xr({func:t=>t.locator.focus({timeout:2e3}),action:"focusing element",logger:this.logger,retryTimeoutMs:this.smartWaitingTimeout,callbacks:this.getBrowserCallbacks(),targetingResult:e})}async blur(e){if(!e){let t=await this.getActivePageOrFrame();await Xe({fn:()=>{let r=document.activeElement;r&&r.nodeType===1&&r.blur()},root:t,arg:void 0,waitForPageLoad:()=>this.waitForPageLoad(),timeout:1e3,codePath:"blurCommand"});return}await this.highlight(e.locator),await Xr({func:t=>t.locator.blur({timeout:2e3}),action:"blurring element",logger:this.logger,retryTimeoutMs:this.smartWaitingTimeout,callbacks:this.getBrowserCallbacks(),targetingResult:e})}async selectOption(e,t,r=!1){await this.highlight(e.locator),await Xr({action:"selecting option from dropdown",logger:this.logger,retryTimeoutMs:this.smartWaitingTimeout,callbacks:this.getBrowserCallbacks(),func:async o=>{if(t.type==="INDEX"){let i=Number(t.index);if(isNaN(i))throw new R("UserConfigurationError",`Page index ${t.index} is not a number`)}await o.locator.selectOption({value:t.type==="VALUE"?t.value:void 0,label:t.type==="LABEL"?t.label:void 0,index:t.type==="INDEX"?Number(t.index):void 0},{force:r,timeout:3e3})},targetingResult:e})}async press(e,t){let r=t.repeat??1;if(t.convertMeta){let o=Cb(e);o!==e&&(this.logger.debug({key:e,convertedKey:o},"Converted platform dependent keys"),e=o)}for(let o=0;o<r;o++)await this.page.keyboard.press(e,{delay:t.delayMs??0})}async refresh(e){let t=e?.loadTimeoutMs??this.pageLoadTimeout;await this.waitForPageLoad();let r=0,o=2;for(;r<o;){r++;try{await this.page.reload({waitUntil:"domcontentloaded",timeout:t});break}catch(i){this.logger.warn({err:i,attempt:r},`Failed to reload page${r<o?", retrying...":", continuing..."}`)}}await this.loadFrameAndRecordUrl({root:this.page,signal:this.abortSignal,codePath:"reload-step"})}async getBrowserState(e){let{logger:t=this.logger,maxAttempts:r=2,skipWaitForPageLoad:o}=e,i=e.abortSignal??this.abortSignal;o||await this.waitForPageLoad(),e.skipWait||await this.waitForDOMStability({logger:t,signal:i});let a=0,s;for(;a<r;){a++;try{return await D(this.stateManager.getA11yTree({devicePixelRatio:this.devicePixelRatio,abortSignal:i,logger:t,filterByViewport:e.filterByViewport}),{milliseconds:this.pageLoadTimeout*a,signal:i,message:"Getting browser state took too long"})}catch(l){if(i?.throwIfAborted(),s=l instanceof Error?l.message:`${l}`,a>=r)throw l;t.debug({err:l,url:this.url()},"Error getting a11y tree, retrying...")}}throw new R("ActionFailureError",`Getting page content failed after ${r} attempts. Error: ${s}`)}async getViewportOffsetDetails(e){let[t,r,o,i,a]=await Xe({root:e,fn:()=>[window.scrollY,window.scrollX,window.screen.width,window.screen.height,window.devicePixelRatio],arg:void 0,timeout:3e3,waitForPageLoad:async()=>{},codePath:"getViewportOffsetDetails"});return{upperBound:t,lowerBound:t+i,leftBound:r,rightBound:r+o,width:o,height:i,devicePixelRatio:this.properties.systemDevicePixelRatio??a}}async waitForDOMStability(e){let{logger:t=this.logger,timeout:r=this.smartWaitingTimeout,signal:o}=e??{},i={value:Date.now()},a=m=>{i.value=Date.now()},s=()=>a("DOM.documentUpdated");this.cdpClient.addListener("DOM.documentUpdated",s);let l=()=>a("Page.frameDetached");this.cdpClient.addListener("Page.frameDetached",()=>l);let c=()=>a("Page.frameStartedLoading");this.cdpClient.addListener("Page.frameStartedLoading",c);let d=()=>a("Page.navigatedWithinDocument");this.cdpClient.addListener("Page.navigatedWithinDocument",d);let p=()=>a("frameRequestedNavListener");this.cdpClient.addListener("Page.frameRequestedNavigation",p);try{await this.waitForDOMStabilityHelper(i,t,r,o)}finally{this.cdpClient.removeListener("DOM.documentUpdated",s),this.cdpClient.removeListener("Page.frameDetached",l),this.cdpClient.removeListener("Page.frameStartedLoading",c),this.cdpClient.removeListener("Page.navigatedWithinDocument",d),this.cdpClient.removeListener("Page.frameRequestedNavigation",p)}}async waitForDOMStabilityHelper(e,t,r,o){let i=!1,a=Date.now(),s,l={quality:25,retries:0},c=!1,d=0;for(;Date.now()-a<r;){if(o?.throwIfAborted(),await te(500,this.abortSignal),s)try{let m=await this.screenshot(l);if(!m.equals(s)){s=m,c=!1;continue}c=!0}catch(m){d++,d%3===0&&t.warn({err:m,screenshotErrors:d},"Failed to take screenshot for DOM stability check"),o?.throwIfAborted()}else try{s=await this.screenshot(l)}catch(m){d++,d%3===0&&t.warn({err:m,screenshotErrors:d},"Failed to take screenshot for DOM stability check"),o?.throwIfAborted()}if(!(Date.now()-e.value<750)){i=!0;break}}let p={duration:Date.now()-a,a11yStableReceived:i,lastTreeUpdateMillisecondsAgo:Date.now()-e.value,screenshotStable:c};i||t.warn(p,"A11y wait phase completed due to timeout, continuing...")}async clickUsingVisualCoordinates(e,t){let{x:r,y:o}=e;this.logger.debug({x:r,y:o},"Executing mouse click with visual coordinates"),await this.waitForPageLoad(),await this.page.mouse.click(r,o,{button:t.rightClick?"right":"left",clickCount:t.doubleClick?2:1})}async dragAndDropUsingVisualCoordinates(e,t,r){await this.page.mouse.move(e.x,e.y,{steps:3}),await this.page.mouse.down(),await this.page.mouse.move(t.x,t.y,{steps:3}),await te(r.hoverSeconds?Math.min(r.hoverSeconds*1e3,8e3):500),await this.page.mouse.up()}async hoverUsingVisualCoordinates(e){await this.page.mouse.move(e.x,e.y)}async mouseDragUsingVisualCoordinates(e,t,r,o){await this.hoverUsingVisualCoordinates(o);let i=await(await this.getActivePageOrFrame()).evaluate(up);i||(this.logger.debug("Could not get current mouse position before mouse drag action, defaulting to 0,0"),i={left:0,top:0}),await this.page.mouse.down(),await this.page.mouse.move(e+i.left,t+i.top,{steps:r}),await te(250),await this.page.mouse.up()}async getElementLocation(e){let t=await this.cdpClient.send({method:"DOMSnapshot.captureSnapshot",params:{computedStyles:[],includeDOMRects:!0,includePaintOrder:!0},timeout:3e3}),r=await D(this.page.evaluate(()=>window.devicePixelRatio),{milliseconds:2e3});process.platform==="darwin"&&r===1&&(r=2);let o=t.documents[0],i=o.layout,a=o.nodes,s=a.nodeName||[],l=a.backendNodeId||[],c=i.nodeIndex,d=i.bounds,p=-1;for(let b=0;b<s.length;b++)if(l[b]===e){p=c.indexOf(b);break}if(p===-1)throw new Error(`Could not find any backend node with ID ${e}`);let[m=0,u=0,h=0,g=0]=d[p];m/=r,u/=r,h/=r,g/=r;let f=m+h/2,S=u+g/2;return{centerX:f,centerY:S}}async scrollVertical(e){return fp({frame:this.stateManager.frameConfig?await this.getActivePageOrFrame():null,page:this.page,deltaX:0,directionX:null,deltaY:e?Math.abs(e):null,directionY:e&&e>0?"down":"up",signal:this.abortSignal,callbacks:this.getBrowserCallbacks()})}async scrollHorizontal(e){return fp({frame:this.stateManager.frameConfig?await this.getActivePageOrFrame():null,page:this.page,deltaX:e?Math.abs(e):null,directionX:e&&e>0?"right":"left",deltaY:0,directionY:null,signal:this.abortSignal,callbacks:this.getBrowserCallbacks()})}async goForward(){await this.waitForPageLoad(),await this.page.goForward({waitUntil:"domcontentloaded",timeout:this.pageLoadTimeout}),await this.loadFrameAndRecordUrl({root:this.page,signal:this.abortSignal,codePath:"go-forward"})}async goBack(){await this.waitForPageLoad(),await this.page.goBack({waitUntil:"domcontentloaded",timeout:this.pageLoadTimeout}),await this.loadFrameAndRecordUrl({root:this.page,signal:this.abortSignal,codePath:"go-back"})}async createRawCDPSession(e){let t=await D(this.context.newCDPSession(this.page),{milliseconds:e??this.pageLoadTimeout,fallback:()=>{throw this.logger.error(`Timed out creating new CDP session for ${this.page.url()}`),new R("UserInfrastructureError",`Failed to initialize Chrome session within the page load timeout (${this.page.url()})`)}});return this.logger.debug(`Created new CDP session for ${this.page.url()}`),t}async reinitializeCDPClient(e){await this.cdpClient.reinitialize(e),await this.initializeScreencast()}async stopScreencast(){if(this.clientCallbacks?.onScreencastFrame)try{await this.cdpClient.send({method:"Page.stopScreencast",params:{}})}catch{}}async changeActivePage(e,t){await this.stopScreencast(),this.recordUrlVisited(e.url()),this.page=e,await this.reinitializeCDPClient(t??this.pageLoadTimeout)}async createNewTab(e,t){let r=await this.context.newPage();await this.changeActivePage(r,t?.loadTimeoutMs),await this.navigate({url:e,initialNavigation:!0,...t}),this.handleAvailableTabsChange()}async switchToPage(e,t){let r=!0,o,i=Date.now();for(;r||t?.retry&&Date.now()-i<this.smartWaitingTimeout;){r=!1;try{await this.switchToPageHelper(e,t);return}catch(a){this.logger.warn({err:a},"Error switching to page, retrying..."),o=a,await te(500)}}throw o}async switchToPageHelper(e,t){let r=this.context.pages().map((i,a)=>({page:i,url:i.url(),index:a})),o;if(e.type==="INDEX"){let i=Number(e.index);if(isNaN(i))throw new R("UserConfigurationError",`Page index ${e.index} is not a number`);if(i<0||i>=r.length)throw new Error(`Page index ${e.index} exceeds the number of available pages: ${JSON.stringify(r.map(a=>a.url))}`);o=r[i]}else{let i=r.filter(a=>e.type==="SUBSTRING"?a.url.includes(e.substring):a.url.match(e.pattern));i.length>1&&this.logger.warn(`More than one page matches the page switch criteria: ${JSON.stringify(i.map(a=>a.url))}`),o=i[i.length-1]}if(!o)throw new Error(`Could not find matching page using criteria: ${JSON.stringify(e)}.
3606
- Available pages:${JSON.stringify(r.map(i=>i.url))}`);if(!zr(o.url,this.logger)){this.logger.error(`Refusing to switch to page with invalid URL: ${o.url}`);return}this.logger.debug(`Switching to tab ${o.index} with url ${o.url}`),await this.changeActivePage(o.page,t?.loadTimeoutMs),await this.loadFrameAndRecordUrl({root:o.page,signal:this.abortSignal,codePath:"switch-to-tab-step"}),this.handleAvailableTabsChange()}async setCookie(e){let t;return typeof e=="string"?t=gs(e):t=[e],await this.context.addCookies(t),t}async setLocalStorage(e,t){let r=await this.getActivePageOrFrame();await D(r.evaluate(([o,i])=>{o&&localStorage.setItem(o,i||"")},[e,t]),{milliseconds:2e3})}async solveCaptcha(){await this.getBrowserState({});let e;for(let s of Object.values(this.stateManager.a11yIdToNodeMap))if(s.role==="image"&&s.name.toLowerCase().includes("captcha")){if(!s.backendNodeId)continue;e=await this.stateManager.getLocatorFromBackendId(this.page,s.backendNodeId);break}if(!e){let s=await(await this.getActivePageOrFrame()).solveRecaptchas();if(!s.captchas||!s.captchas.length)throw new Error("No captchas found on the page");return}let t=await e.screenshot({type:"jpeg",animations:"allow",caret:"hide",quality:100,timeout:3e3}),r=await fetch("https://api.2captcha.com/createTask",{method:"POST",body:JSON.stringify({clientKey:Cl,task:{type:"ImageToTextTask",body:t.toString("base64"),case:!0},languagePool:"en"})});if(!r.ok){let s=`Captcha solver API returned error response: ${r.statusText}`;throw this.logger.error({text:await r.text()},s),new Error(s)}let{taskId:o}=await r.json(),i=Date.now(),a="";for(;Date.now()-i<6e4;){await te(2500);let s=await fetch("https://api.2captcha.com/getTaskResult",{method:"POST",body:JSON.stringify({clientKey:Cl,taskId:o})});if(!s.ok){let c=`Captcha solution API returned error response: ${s.statusText}`;throw this.logger.error({text:await s.text()},c),new Error(c)}let l=await s.json();if(l.errorId){let c=`Captcha solution API returned error ID ${l.errorId}`;throw this.logger.error(c),new Error(c)}if(l.status==="ready"){a=l.solution.text;break}}if(!a)throw new Error("Captcha solution timed out");return a}getActiveFrameConfig(){return this.stateManager.frameConfig}async exposeRecordingBindings(){await this.context.exposeBinding("isRecordingActive",()=>this.transformer!==void 0,{handle:!1}),await this.context.exposeBinding("captureTargetedEvent",({frame:e},t)=>{this.transformer&&Mb({event:t,frame:e,transformer:this.transformer,enricher:this.enricher,lastScreenshotForRecording:this.lastScreenshotForRecording?.toString("base64"),logger:this.logger})},{handle:!1}),await this.context.exposeBinding("captureKeystroke",async(e,t)=>{this.transformer&&this.transformer.recordKeystroke(t)})}async startRecordingCrons(e){if(e.aborted)return;let t,r=(await this.getOpenPages()).map(s=>s.url),o=0,i=!1,a=async()=>{if(e.aborted||o>8){clearTimeout(t);return}i=!0;let s;try{s=(await this.getOpenPages()).map(c=>c.url),o=0}catch(c){this.logger.debug({err:c},"Failed getting new open pages during recording tab switch cron, skipping..."),o++;return}let l=this.url();for(let c=s.length-1;c>=r.length;c--){let d=s[c];zr(d,this.logger)&&d!==l&&this.logger.info({lastActivePages:r,currentUrl:l,newOpenPages:s},"Auto-following new tab during recording"),await this.switchToPage({type:"INDEX",index:String(c)});break}r=s};t=setInterval(async()=>{if(!i){i=!0;try{await a()}catch(s){this.logger.error({err:s},"Error while checking pages during recording")}finally{i=!1}}},500),e.addEventListener("abort",async()=>{clearInterval(t)})}async startRecording(e,t,r){this.logger.debug({isClickToRecord:r},"Starting recording mode in Chrome browser"),await this.startRecordingCrons(e),await this.page.evaluate(o=>{let i=window;i._MOMENTIC_RECORDING_ACTIVE=!0,i._MOMENTIC_CLICK_RECORD_ACTIVE=o},r),this.transformer=t,await this.injectKnowledgeBaseIntoBrowser(this.page),e.addEventListener("abort",async()=>{this.transformer=void 0,this.lastScreenshotForRecording=void 0;try{await this.page.evaluate(()=>{let o=window;o._MOMENTIC_RECORDING_ACTIVE=!1,o._MOMENTIC_CLICK_RECORD_ACTIVE=!1})}catch{}})}async getSelectOptions(e){return await e.evaluate(r=>Array.from(r.querySelectorAll("option")).map(i=>({value:i.value,label:i.label})),void 0,{timeout:1e3})}getActivePage(){return this.page}async getActivePageOrFrame(){let e=await this.stateManager.resolveActiveFrameConfig({});return e?(await this.loadFrameAndRecordUrl({root:e.frame,signal:this.abortSignal,codePath:"get-active-frame-locator"}),e.frame):this.page}async loadFrameAndRecordUrl({root:e,signal:t,codePath:r}){let o=this.pageLoadTimeout,i=e.url();if(i.includes("chrome-error://")){this.logger.warn({url:i,codePath:r},"Skipping load for chrome-error:// URL");return}try{await Br({promiseGenerator:async()=>e.waitForLoadState("domcontentloaded",{timeout:o}),signal:t,codePath:`loadFrameAndRecordUrlDomContentLoad-${r}`,logger:this.logger,timeoutMs:this.pageLoadTimeout})}catch(a){let s=a;if(s.name==="AbortError")throw new R("UserInfrastructureError",`The page with URL ${He(i,50)} did not load within the configured timeout (${o}ms): ${s}`);if(!s.message.includes("detached"))throw s}try{await Br({promiseGenerator:async()=>e.waitForLoadState("load",{timeout:o}),signal:t,codePath:`loadFrameAndRecordUrlPageLoad-${r}`,logger:this.logger,timeoutMs:this.pageLoadTimeout})}catch(a){this.logger.warn({err:a,codePath:r,url:i},"Failed waiting for current frame to load, continuing...")}this.recordUrlVisited(e.url())}async getCondensedHtml(e){let{skipWait:t=!1}=e??{};return t||(await this.waitForPageLoad(),await this.waitForDOMStability()),this.getCondensedHtmlHelper()}async getCondensedHtmlHelper(){let e=await this.getRawCondensedHtml();return VO.html(e,{indent_size:1,indent_with_tabs:!1,preserve_newlines:!1})}async getRawCondensedHtml(){let e=await this.getActivePageOrFrame();await this.ensureMomenticBrowserScriptsLoaded(e,this.logger,this.abortSignal);let{result:t,error:r}=await Xe({fn:()=>window.getCondensedHtmlTree(),root:e,arg:void 0,timeout:2e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"getCondensedHtmlTree"});if(r)throw new Error(`Failed to process page HTML: ${r}`);if(!t)throw new R("InternalWebAgentError","Got empty HTML tree - are you sure the page is fully loaded?");return t}registerDialogHandler(e){let t=async r=>{try{e==="ACCEPT"?await r.accept():await r.dismiss()}catch(o){this.logger.warn({err:o},"Failed to handle dialog")}};this.page.once("dialog",t)}async evaluateFunctionInAllFrames(e,t){return this.stateManager.executeFunctionInAllFrames(e,t)}async evaluateFunctionInPage(e,t){let r=await this.getActivePageOrFrame();return D(r.evaluate(e,t),{milliseconds:2e3})}async evaluateCodeInPage({code:e,fragment:t,context:r,timeoutMs:o=tr}){let i=Sb(),a={code:e,fragment:t,context:r},{result:s}=await D(this.page.evaluate(i,a),{milliseconds:o,fallback:()=>{throw this.abortSignal?.throwIfAborted(),new R("ActionFailureError",`Code evaluation in browser exceeded the allowed timeout of ${o/1e3} seconds`)},signal:this.abortSignal});return s}async getDomNodeFromPixelPosition(e,t){await this.cdpClient.send({method:"DOM.getDocument",params:{depth:0},timeout:2e3});let r;try{r=await this.cdpClient.send({method:"DOM.getNodeForLocation",params:{x:e,y:t},timeout:1e3})}catch(o){throw this.logger.error({err:o,x:e,y:t},"Failed to get DOM node from position percents"),new Error("No element was found at the given location")}return r}async getDomNodeFromPositionPercentages(e,{percentX:t,percentY:r}){if(t<0||t>1||r<0||r>1)throw new R("UserConfigurationError","Invalid percent passed to percentage location");let{width:o,height:i,upperBound:a,leftBound:s}=await this.getViewportOffsetDetails(e),l=Math.round(a),c=Math.round(s),d=Math.ceil(o*t),p=Math.ceil(i*r),m=d+c,u=p+l;return this.getDomNodeFromPixelPosition(m,u)}async highlightFromPositionPercentages(e){let t=await this.getActivePageOrFrame(),r;try{r=await this.getDomNodeFromPositionPercentages(t,e)}catch{}return r?(await this.cdpClient.send({method:"Overlay.highlightNode",timeout:1e3,params:{highlightConfig:Wy,backendNodeId:r.backendNodeId}}),async()=>{try{await this.cdpClient.send({timeout:1e3,method:"Overlay.hideHighlight",params:{backendNodeId:r?.backendNodeId}})}catch{}}):async()=>{}}async clearAllCdpHighlights(){try{await this.cdpClient.send({method:"Overlay.hideHighlight",params:void 0,timeout:1e3})}catch{}}async getTargetFromPixelPosition(e,t=!0){let r=await this.getActivePageOrFrame(),o=await this.getDomNodeFromPixelPosition(e.x,e.y);return this.getTargetFromBackendNodeId(r,o.backendNodeId,t)}async getTargetFromPositionPercentages(e,t=!0){let r=await this.getActivePageOrFrame(),o=await this.getDomNodeFromPositionPercentages(r,e);return this.getTargetFromBackendNodeId(r,o.backendNodeId,t)}async getTargetFromBackendNodeId(e,t,r){let o=this.stateManager.domGraph?.backendIdToNode[t];if(!o)throw new Error("No DOM node was found with the given backend ID");let i=o?.attributes[Tt],a=parseInt(i??"");if(!i||isNaN(a))throw new Error("No data-momentic-id was found on the DOM node");let s=e.locator(`[${Tt}="${i}"]`);if(r){for(let p of Object.values(this.stateManager.a11yIdToNodeMap)){if(p.backendNodeId!==t)continue;let m={id:p.id,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString()};return await this.saveNodeDetailsToCache({node:p,target:m,locator:s,dataMomenticId:parseInt(i),generateNewCssSelectors:!0}),this.logger.debug({target:m},"Tied backend id to existing a11y node"),{target:m,locator:s}}let d=gl(`${i}`,this.stateManager.domGraph,this.logger);for(let p of d){let m=parseInt(p.attributes?.[Tt]??"");if(isNaN(m))continue;let u=e.locator(`[${Tt}="${m}"]`),h=this.stateManager.dataMomenticIdToNodeMap[m],g=h?.id;if(!g)continue;let f={id:g,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString()};return await this.saveNodeDetailsToCache({node:h,target:f,dataMomenticId:parseInt(i),locator:u,generateNewCssSelectors:!0}),this.logger.debug({target:f},"Tied backend id on non-accessible element to nearest a11y node"),{target:f,locator:u}}}let l=await this.fetchHtmlAttributes(s,this.logger),c={id:-1,dataMomenticId:a,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString(),...l};return this.logger.debug({target:c},"Tied backend id to html node"),{target:c,locator:s}}async performTargetRedirection(e,t,r){try{return await e.scrollIntoViewIfNeeded({timeout:3e3}),await D(this.performTargetRedirectionHelper(e,t,r),{milliseconds:3e3})??{locator:e}}catch(o){return t.warn({err:o},"Error performing target redirection, using original element"),{locator:e}}}async performTargetRedirectionHelper(e,t,r){let o=Date.now(),i=await gn(e,t);if(r===void 0&&(r=await e.boundingBox({timeout:1e3})),!r){t.error(`Attempted to click on element with no bounding box: ${i}`);return}let{x:a,y:s,width:l,height:c}=r,d=this.getViewport();if(a<0||s<0||a+l>d.width||s+c>d.height){t.debug("Skipping locator redirection because the element is outside the viewport");return}let p=await this.getActivePageOrFrame(),{dataMomenticId:m,mPathSelector:u,error:h,serializedElement:g,point:f,force:S,logs:b}=await e.evaluate(v=>{let x=window;if(!x.performTargetRedirection)throw new Error("performTargetRedirection script is not defined");return x.performTargetRedirection(v)},void 0,{timeout:1e3}),w=Date.now()-o;if(h){t.warn({error:h,serializedElement:g,duration:w,force:S,logs:b},"Got error from target redirection with bounding box");return}else{if(m)return t.debug({newDataMomenticId:m,serializedElement:g,duration:w,force:S,logs:b},"Redirected target to new element with bounding box with data-momentic-id"),{locator:p.locator(`[data-momentic-id="${m}"]`),hints:{clickableXY:f,force:S}};if(u)return t.debug({newMPathSelector:u,serializedElement:g,duration:w,force:S,logs:b},"Redirected target to new element with bounding box with mPath"),{locator:p.locator(u),hints:{clickableXY:f,force:S}};if(f)return t.debug({point:f,serializedElement:g,duration:w,force:S,logs:b},"Chose specific visible point on original element"),{locator:e,hints:{clickableXY:f,force:S}};if(S)return t.debug({serializedElement:g,duration:w,force:S,logs:b},"Forcing click on original element"),{locator:e,hints:{force:S}}}}async fetchHtmlAttributes(e,t=this.logger){let r=await e.evaluate(o=>{let i=window;return i.generateHtmlCacheAttributes?i.generateHtmlCacheAttributes(o):{warnings:[],error:"generateHtmlCacheAttributes is not defined"}},void 0,{timeout:2e3});if("error"in r)throw new Error(r.error);return r.warnings.length?t.warn(r,"Got warnings while generating HTML attributes for target"):t.debug(r,"Generated HTML attributes for target"),r.attributes}async moveMouseFromPositionPercentages(e,t){let r=Math.ceil(this.viewport.width*e),o=Math.ceil(this.viewport.height*t);return await this.cdpClient.send({method:"Input.dispatchMouseEvent",params:{type:"mouseMoved",x:r,y:o,button:"left",clickCount:0}}),{x:r,y:o}}async clickMouseFromPositionPercentages(e,t,r){let o=Math.ceil(this.viewport.width*t),i=Math.ceil(this.viewport.height*r);await this.cdpClient.send({method:"Input.dispatchMouseEvent",params:{type:e==="down"?"mousePressed":"mouseReleased",x:o,y:i,button:"left",clickCount:e==="down"?1:0},timeout:1e3})}async scrollFromPositionPercentages(e,t,r,o){let i=Math.ceil(this.viewport.width*e),a=Math.ceil(this.viewport.height*t);return await this.cdpClient.send({method:"Input.dispatchMouseEvent",params:{type:"mouseWheel",deltaX:i,deltaY:a,x:r,y:o}}),{deltaX:i,deltaY:a}}canSolveCaptchas(){return!!Cl}async getAllFrameUrls(){return await this.stateManager.getAllChildFrameUrls()}async setFileChooserHandler(e){setTimeout(()=>{try{e.cleanup()}catch(t){this.logger.debug({err:t,filePath:e.filePath},"Failed cleaning up file after upload")}},3e4),await this.setFileChooserHandlerHelper(e)}logToUserConsole(e,t,r,...o){let i=this.context.pages().indexOf(e);i=i===-1?0:i,pp(e,this.debugData,i,{type:t,text:`[MOMENTIC] ${r}`,args:o})}async setFileChooserHandlerHelper({filePath:e,filename:t}){if(!El(e)){let l=`File chooser triggered after the source file ${e} has been cleaned up, ignoring...`;this.logger.error(l),this.logToUserConsole(this.page,"error",l);return}let r=t?.trim()||YO(e),o=GO(e),i=JO(e),a=qc[i];this.page.once("filechooser",async l=>{this.logger.info({filePath:e,fileName:r},"File chooser triggered");try{if(!El(e))throw new Error(`File chooser triggered after the source file ${e} has been cleaned up, ignoring...`);await l.setFiles({name:r,buffer:o,mimeType:Uy.getType(e)||"application/octet-stream"},{timeout:8e3})}catch(c){this.logger.error({err:c},"Error handling file chooser"),this.logToUserConsole(this.page,"error",c.message)}});let s=o.toString("base64");await(await this.getActivePageOrFrame()).evaluate(({fileName:l,base64Data:c,mimeType:d})=>{let p=window;p.momenticFileName=l,p.momenticFileBase64=c;let m=atob(c),u=new Array(m.length);for(let g=0;g<m.length;g++)u[g]=m.charCodeAt(g);let h=new Uint8Array(u);p.MomenticFile=class extends Blob{kind="file";name=p.momenticFileName;constructor(){super([h],{type:d})}isSameEntry(g){return g.name===this.name}queryPermission(g){return console.info("[MOMENTIC] MomenticFile.queryPermission called"),Promise.resolve("granted")}remove(){return console.info("[MOMENTIC] MomenticFile.remove called"),Promise.resolve()}async requestPermission(g){return console.info("[MOMENTIC] MomenticFile.requestPermission called"),Promise.resolve("granted")}async getFile(){console.info("[MOMENTIC] MomenticFile.getFile called");let g=new Blob([h]);return new File([g],p.momenticFileName,{type:d})}async createSyncAccessHandle(){throw console.error("[MOMENTIC] Not implemented"),new Error("Not implemented")}async createWritable(){throw console.error("[MOMENTIC] Not implemented"),new Error("Not implemented")}},p.showOpenFilePicker=async()=>(console.info("[MOMENTIC] showOpenFilePicker called"),[new p.MomenticFile])},{fileName:r,base64Data:s,mimeType:a})}getSerializedFormFromA11yId(e){return this.stateManager.a11yIdToNodeMap[e]?.getNodeOnlySerializedForm()}retrieveAndClearDebugData(){let e=this.cdpClient.loadEventLogs;e.length>0&&(this.logger.debug(e,"Load event logs"),this.cdpClient.loadEventLogs=[]);let t={...this.debugData};return this.debugData={logsPerPage:[],harPages:{},harEntries:{}},t}async copy(e){try{await this.evaluateFunctionInPage(t=>navigator.clipboard.writeText(t),e)}catch(t){if(t instanceof Error&&t.message.includes("Document is not focused")){await this.evaluateFunctionInPage(()=>{document.activeElement||document.body.focus()},void 0),await this.press("Tab",{}),await this.press("Shift+Tab",{}),await this.evaluateFunctionInPage(r=>navigator.clipboard.writeText(r),e);return}throw t}}async paste(){await this.waitForPageLoad(),await this.press("Meta+V",{convertMeta:!0})}async registerRequestListener(e){return this.page.waitForResponse(e)}get smartWaitingTimeout(){return this.userControlledBrowserSettings.smartWaitingTimeoutMs??5e3}get pageLoadTimeout(){return this.userControlledBrowserSettings.pageLoadTimeoutMs??8e3}get isInPageLoad(){return Object.values(this.pageLoadPromises).length>0}get devicePixelRatio(){return this.properties.systemDevicePixelRatio??1}};import yk from"fetch-cookie";import{cloneDeep as bk}from"lodash-es";import{CookieJar as wk}from"tough-cookie";import{z as Mt}from"zod";var xre=Mt.object({doubleClick:Mt.boolean().optional(),rightClick:Mt.boolean().optional(),force:Mt.boolean().optional(),waitForDownload:Mt.boolean().optional(),delayMs:Mt.number().optional(),downloadTimeoutMs:Mt.number().optional(),relativePosition:Mt.object({x:Mt.number(),y:Mt.number()}).optional()}),Ere=Mt.object({repeat:Mt.number().optional(),convertMeta:Mt.boolean().optional().describe("misleading name due to backcompat. converts keyshortcuts + meta/control to platform-specific combos. defaults to true"),delayMs:Mt.number().optional()});var Tp=(n,e,t)=>{let[r,...o]=e.split("."),i=r;return o.length>=1?Tp(n[i],o.join("."),t):n[i]=t,n};async function fr(n,e={}){let t=await n.getBrowserState(e),r=t.serialize();return e.logger?.debug({tree:r.length>4e5?r.slice(0,4e5):r,activeFrame:n.getActiveFrameConfig()},"Got a11y tree"),{serializedTree:r,tree:t}}var pi=3.1783027;function rk(n){let e=0;for(let t=0;t<n.length;t++){let r=n.charCodeAt(t);!(r>=48&&r<=57)&&!(r>=65&&r<=90)&&!(r>=97&&r<=122)&&e++}return e}function Ra(n){return Math.ceil(xp(n)/pi)}function xp(n){let e=0;if(typeof n=="string"){let t=n;t=t.replaceAll(`
3607
- `,""),t=t.replaceAll(" ","");let r=rk(t);return t.length-r+pi*r}if(typeof n>"u")return 0;if(typeof n=="number")return String(n).length;if(Array.isArray(n))return n.forEach(t=>{e+=xp(t)}),e;if(typeof n=="object"){let t=n;return Object.keys(t).forEach(r=>{e+=String(r).length,r==="image_url"?(t[r]??{}).detail==="high"?e+=1105*pi:e+=85*pi:e+=xp(t[r])}),e}if(typeof n=="boolean")return n?4:5;throw new Error(`Unsupported type passed to token length calculator '${typeof n}': ${n}`)}var $b={minChunkTokenCount:500,acceptableChunkTokenCount:3e3,maxChunkTokenCount:8e3,maxLineLength:4e3},Gb={minChunkTokenCount:5e3,acceptableChunkTokenCount:1e4,maxChunkTokenCount:15e3,maxLineLength:500},jb=/<(\S+) id="(\d+)".*?>/g,ok=/(<\/(\S+)>)|(<(\S+).*?\/>)/g,Wb=["h1","h2","section","footer","nav","aside","form","label","dialog"],ik=[...Wb,"span","div","h3"],ak=["table","select","form","ul","ol","menu","pre","code","dialog"],sk=["table","form","dialog","nav","section","ul","select"];function Ep(n){return n.serializedTree.length>n.maxCharacterLength&&(n.logger.warn({serializedTreeLength:n.serializedTree.length},"Serialized condensed tree is too long to chunk, truncating before chunking"),n.serializedTree=n.serializedTree.slice(0,n.maxCharacterLength)),lk(n)}function lk({serializedTree:n,options:e,logger:t}){let{minChunkTokenCount:r,acceptableChunkTokenCount:o,maxChunkTokenCount:i,maxLineLength:a}=e,s=[],l=n.split(`
3606
+ Available pages:${JSON.stringify(r.map(i=>i.url))}`);if(!zr(o.url,this.logger)){this.logger.error(`Refusing to switch to page with invalid URL: ${o.url}`);return}this.logger.debug(`Switching to tab ${o.index} with url ${o.url}`),await this.changeActivePage(o.page,t?.loadTimeoutMs),await this.loadFrameAndRecordUrl({root:o.page,signal:this.abortSignal,codePath:"switch-to-tab-step"}),this.handleAvailableTabsChange()}async setCookie(e){let t;return typeof e=="string"?t=gs(e):t=[e],await this.context.addCookies(t),t}async setLocalStorage(e,t){let r=await this.getActivePageOrFrame();await D(r.evaluate(([o,i])=>{o&&localStorage.setItem(o,i||"")},[e,t]),{milliseconds:2e3})}async solveCaptcha(){await this.getBrowserState({});let e;for(let s of Object.values(this.stateManager.a11yIdToNodeMap))if(s.role==="image"&&s.name.toLowerCase().includes("captcha")){if(!s.backendNodeId)continue;e=await this.stateManager.getLocatorFromBackendId(this.page,s.backendNodeId);break}if(!e){let s=await(await this.getActivePageOrFrame()).solveRecaptchas();if(!s.captchas||!s.captchas.length)throw new Error("No captchas found on the page");return}let t=await e.screenshot({type:"jpeg",animations:"allow",caret:"hide",quality:100,timeout:3e3}),r=await fetch("https://api.2captcha.com/createTask",{method:"POST",body:JSON.stringify({clientKey:Cl,task:{type:"ImageToTextTask",body:t.toString("base64"),case:!0},languagePool:"en"})});if(!r.ok){let s=`Captcha solver API returned error response: ${r.statusText}`;throw this.logger.error({text:await r.text()},s),new Error(s)}let{taskId:o}=await r.json(),i=Date.now(),a="";for(;Date.now()-i<6e4;){await te(2500);let s=await fetch("https://api.2captcha.com/getTaskResult",{method:"POST",body:JSON.stringify({clientKey:Cl,taskId:o})});if(!s.ok){let c=`Captcha solution API returned error response: ${s.statusText}`;throw this.logger.error({text:await s.text()},c),new Error(c)}let l=await s.json();if(l.errorId){let c=`Captcha solution API returned error ID ${l.errorId}`;throw this.logger.error(c),new Error(c)}if(l.status==="ready"){a=l.solution.text;break}}if(!a)throw new Error("Captcha solution timed out");return a}getActiveFrameConfig(){return this.stateManager.frameConfig}async exposeRecordingBindings(){await this.context.exposeBinding("isRecordingActive",()=>this.transformer!==void 0,{handle:!1}),await this.context.exposeBinding("captureTargetedEvent",({frame:e},t)=>{this.transformer&&Mb({event:t,frame:e,transformer:this.transformer,enricher:this.enricher,lastScreenshotForRecording:this.lastScreenshotForRecording?.toString("base64"),logger:this.logger})},{handle:!1}),await this.context.exposeBinding("captureKeystroke",async(e,t)=>{this.transformer&&this.transformer.recordKeystroke(t)})}async startRecordingCrons(e){if(e.aborted)return;let t,r=(await this.getOpenPages()).map(s=>s.url),o=0,i=!1,a=async()=>{if(e.aborted||o>8){clearTimeout(t);return}i=!0;let s;try{s=(await this.getOpenPages()).map(c=>c.url),o=0}catch(c){this.logger.debug({err:c},"Failed getting new open pages during recording tab switch cron, skipping..."),o++;return}let l=this.url();for(let c=s.length-1;c>=r.length;c--){let d=s[c];zr(d,this.logger)&&d!==l&&this.logger.info({lastActivePages:r,currentUrl:l,newOpenPages:s},"Auto-following new tab during recording"),await this.switchToPage({type:"INDEX",index:String(c)});break}r=s};t=setInterval(async()=>{if(!i){i=!0;try{await a()}catch(s){this.logger.error({err:s},"Error while checking pages during recording")}finally{i=!1}}},500),e.addEventListener("abort",async()=>{clearInterval(t)})}async startRecording(e,t,r){this.logger.debug({isClickToRecord:r},"Starting recording mode in Chrome browser"),await this.startRecordingCrons(e),await this.page.evaluate(o=>{let i=window;i._MOMENTIC_RECORDING_ACTIVE=!0,i._MOMENTIC_CLICK_RECORD_ACTIVE=o},r),this.transformer=t,await this.injectKnowledgeBaseIntoBrowser(this.page),e.addEventListener("abort",async()=>{this.transformer=void 0,this.lastScreenshotForRecording=void 0;try{await this.page.evaluate(()=>{let o=window;o._MOMENTIC_RECORDING_ACTIVE=!1,o._MOMENTIC_CLICK_RECORD_ACTIVE=!1})}catch{}})}async getSelectOptions(e){return await e.evaluate(r=>Array.from(r.querySelectorAll("option")).map(i=>({value:i.value,label:i.label})),void 0,{timeout:1e3})}getActivePage(){return this.page}async getActivePageOrFrame(){let e=await this.stateManager.resolveActiveFrameConfig({});return e?(await this.loadFrameAndRecordUrl({root:e.frame,signal:this.abortSignal,codePath:"get-active-frame-locator"}),e.frame):this.page}async loadFrameAndRecordUrl({root:e,signal:t,codePath:r}){let o=this.pageLoadTimeout,i=e.url();if(i.includes("chrome-error://")){this.logger.warn({url:i,codePath:r},"Skipping load for chrome-error:// URL");return}try{await Br({promiseGenerator:async()=>e.waitForLoadState("domcontentloaded",{timeout:o}),signal:t,codePath:`loadFrameAndRecordUrlDomContentLoad-${r}`,logger:this.logger,timeoutMs:this.pageLoadTimeout})}catch(a){let s=a;if(s.name==="AbortError")throw new R("UserInfrastructureError",`The page with URL ${He(i,50)} did not load within the configured timeout (${o}ms): ${s}`);if(!s.message.includes("detached"))throw s}try{await Br({promiseGenerator:async()=>e.waitForLoadState("load",{timeout:o}),signal:t,codePath:`loadFrameAndRecordUrlPageLoad-${r}`,logger:this.logger,timeoutMs:this.pageLoadTimeout})}catch(a){this.logger.warn({err:a,codePath:r,url:i},"Failed waiting for current frame to load, continuing...")}this.recordUrlVisited(e.url())}async getCondensedHtml(e){let{skipWait:t=!1}=e??{};return t||(await this.waitForPageLoad(),await this.waitForDOMStability()),this.getCondensedHtmlHelper()}async getCondensedHtmlHelper(){let e=await this.getRawCondensedHtml();return VO.html(e,{indent_size:1,indent_with_tabs:!1,preserve_newlines:!1})}async getRawCondensedHtml(){let e=await this.getActivePageOrFrame();await this.ensureMomenticBrowserScriptsLoaded(e,this.logger,this.abortSignal);let{result:t,error:r}=await Xe({fn:()=>window.getCondensedHtmlTree(),root:e,arg:void 0,timeout:2e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"getCondensedHtmlTree"});if(r)throw new Error(`Failed to process page HTML: ${r}`);if(!t)throw new R("InternalWebAgentError","Got empty HTML tree - are you sure the page is fully loaded?");return t}registerDialogHandler(e){let t=async r=>{try{e==="ACCEPT"?await r.accept():await r.dismiss()}catch(o){this.logger.warn({err:o},"Failed to handle dialog")}};this.page.once("dialog",t)}async evaluateFunctionInAllFrames(e,t){return this.stateManager.executeFunctionInAllFrames(e,t)}async evaluateFunctionInPage(e,t){let r=await this.getActivePageOrFrame();return D(r.evaluate(e,t),{milliseconds:2e3})}async evaluateCodeInPage({code:e,fragment:t,context:r,timeoutMs:o=tr}){let i=Sb(),a={code:e,fragment:t,context:r},{result:s}=await D(this.page.evaluate(i,a),{milliseconds:o,fallback:()=>{throw this.abortSignal?.throwIfAborted(),new R("ActionFailureError",`Code evaluation in browser exceeded the allowed timeout of ${o/1e3} seconds`)},signal:this.abortSignal});return s}async getDomNodeFromPixelPosition(e,t){await this.cdpClient.send({method:"DOM.getDocument",params:{depth:0},timeout:2e3});let r;try{r=await this.cdpClient.send({method:"DOM.getNodeForLocation",params:{x:e,y:t},timeout:1e3})}catch(o){throw this.logger.error({err:o,x:e,y:t},"Failed to get DOM node from position percents"),new Error("No element was found at the given location")}return r}async getDomNodeFromPositionPercentages(e,{percentX:t,percentY:r}){if(t<0||t>1||r<0||r>1)throw new R("UserConfigurationError","Invalid percent passed to percentage location");let{width:o,height:i,upperBound:a,leftBound:s}=await this.getViewportOffsetDetails(e),l=Math.round(a),c=Math.round(s),d=Math.ceil(o*t),p=Math.ceil(i*r),m=d+c,u=p+l;return this.getDomNodeFromPixelPosition(m,u)}async highlightFromPositionPercentages(e){let t=await this.getActivePageOrFrame(),r;try{r=await this.getDomNodeFromPositionPercentages(t,e)}catch{}return r?(await this.cdpClient.send({method:"Overlay.highlightNode",timeout:1e3,params:{highlightConfig:Wy,backendNodeId:r.backendNodeId}}),async()=>{try{await this.cdpClient.send({timeout:1e3,method:"Overlay.hideHighlight",params:{backendNodeId:r?.backendNodeId}})}catch{}}):async()=>{}}async clearAllCdpHighlights(){try{await this.cdpClient.send({method:"Overlay.hideHighlight",params:void 0,timeout:1e3})}catch{}}async getTargetFromPixelPosition(e,t=!0){let r=await this.getActivePageOrFrame(),o=await this.getDomNodeFromPixelPosition(e.x,e.y);return this.getTargetFromBackendNodeId(r,o.backendNodeId,t)}async getTargetFromPositionPercentages(e,t=!0){let r=await this.getActivePageOrFrame(),o=await this.getDomNodeFromPositionPercentages(r,e);return this.getTargetFromBackendNodeId(r,o.backendNodeId,t)}async getTargetFromBackendNodeId(e,t,r){let o=this.stateManager.domGraph?.backendIdToNode[t];if(!o)throw new Error("No DOM node was found with the given backend ID");let i=o?.attributes[Tt],a=parseInt(i??"");if(!i||isNaN(a))throw new Error("No data-momentic-id was found on the DOM node");let s=e.locator(`[${Tt}="${i}"]`);if(r){for(let p of Object.values(this.stateManager.a11yIdToNodeMap)){if(p.backendNodeId!==t)continue;let m={id:p.id,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString()};return await this.saveNodeDetailsToCache({node:p,target:m,locator:s,dataMomenticId:parseInt(i),generateNewCssSelectors:!0}),this.logger.debug({target:m},"Tied backend id to existing a11y node"),{target:m,locator:s}}let d=gl(`${i}`,this.stateManager.domGraph,this.logger);for(let p of d){let m=parseInt(p.attributes?.[Tt]??"");if(isNaN(m))continue;let u=e.locator(`[${Tt}="${m}"]`),h=this.stateManager.dataMomenticIdToNodeMap[m],g=h?.id;if(!g)continue;let f={id:g,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString()};return await this.saveNodeDetailsToCache({node:h,target:f,dataMomenticId:parseInt(i),locator:u,generateNewCssSelectors:!0}),this.logger.debug({target:f},"Tied backend id on non-accessible element to nearest a11y node"),{target:f,locator:u}}}let l=await this.fetchHtmlAttributes(s,this.logger),c={id:-1,dataMomenticId:a,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString(),...l};return this.logger.debug({target:c},"Tied backend id to html node"),{target:c,locator:s}}async performTargetRedirection(e,t,r){try{return await e.scrollIntoViewIfNeeded({timeout:3e3}),await D(this.performTargetRedirectionHelper(e,t,r),{milliseconds:3e3})??{locator:e}}catch(o){return t.warn({err:o},"Error performing target redirection, using original element"),{locator:e}}}async performTargetRedirectionHelper(e,t,r){let o=Date.now(),i=await gn(e,t);if(r===void 0&&(r=await e.boundingBox({timeout:1e3})),!r){t.error(`Attempted to click on element with no bounding box: ${i}`);return}let{x:a,y:s,width:l,height:c}=r,d=this.getViewport();if(a<0||s<0||a+l>d.width||s+c>d.height){t.debug("Skipping locator redirection because the element is outside the viewport");return}let p=await this.getActivePageOrFrame(),{dataMomenticId:m,mPathSelector:u,error:h,serializedElement:g,point:f,force:S,logs:b}=await e.evaluate(v=>{let x=window;if(!x.performTargetRedirection)throw new Error("performTargetRedirection script is not defined");return x.performTargetRedirection(v)},void 0,{timeout:1e3}),w=Date.now()-o;if(h){t.warn({error:h,serializedElement:g,duration:w,force:S,logs:b},"Got error from target redirection with bounding box");return}else{if(m)return t.debug({newDataMomenticId:m,serializedElement:g,duration:w,force:S,logs:b},"Redirected target to new element with bounding box with data-momentic-id"),{locator:p.locator(`[data-momentic-id="${m}"]`),hints:{clickableXY:f,force:S}};if(u)return t.debug({newMPathSelector:u,serializedElement:g,duration:w,force:S,logs:b},"Redirected target to new element with bounding box with mPath"),{locator:p.locator(u),hints:{clickableXY:f,force:S}};if(f)return t.debug({point:f,serializedElement:g,duration:w,force:S,logs:b},"Chose specific visible point on original element"),{locator:e,hints:{clickableXY:f,force:S}};if(S)return t.debug({serializedElement:g,duration:w,force:S,logs:b},"Forcing click on original element"),{locator:e,hints:{force:S}}}}async fetchHtmlAttributes(e,t=this.logger){let r=await e.evaluate(o=>{let i=window;return i.generateHtmlCacheAttributes?i.generateHtmlCacheAttributes(o):{warnings:[],error:"generateHtmlCacheAttributes is not defined"}},void 0,{timeout:2e3});if("error"in r)throw new Error(r.error);return r.warnings.length?t.warn(r,"Got warnings while generating HTML attributes for target"):t.debug(r,"Generated HTML attributes for target"),r.attributes}async moveMouseFromPositionPercentages(e,t){let r=Math.ceil(this.viewport.width*e),o=Math.ceil(this.viewport.height*t);return await this.cdpClient.send({method:"Input.dispatchMouseEvent",params:{type:"mouseMoved",x:r,y:o,button:"left",clickCount:0}}),{x:r,y:o}}async clickMouseFromPositionPercentages(e,t,r){let o=Math.ceil(this.viewport.width*t),i=Math.ceil(this.viewport.height*r);await this.cdpClient.send({method:"Input.dispatchMouseEvent",params:{type:e==="down"?"mousePressed":"mouseReleased",x:o,y:i,button:"left",clickCount:e==="down"?1:0},timeout:1e3})}async scrollFromPositionPercentages(e,t,r,o){let i=Math.ceil(this.viewport.width*e),a=Math.ceil(this.viewport.height*t);return await this.cdpClient.send({method:"Input.dispatchMouseEvent",params:{type:"mouseWheel",deltaX:i,deltaY:a,x:r,y:o}}),{deltaX:i,deltaY:a}}canSolveCaptchas(){return!!Cl}async getAllFrameUrls(){return await this.stateManager.getAllChildFrameUrls()}async setFileChooserHandler(e){setTimeout(()=>{try{e.cleanup()}catch(t){this.logger.debug({err:t,filePath:e.filePath},"Failed cleaning up file after upload")}},3e4),await this.setFileChooserHandlerHelper(e)}logToUserConsole(e,t,r,...o){let i=this.context.pages().indexOf(e);i=i===-1?0:i,pp(e,this.debugData,i,{type:t,text:`[MOMENTIC] ${r}`,args:o})}async setFileChooserHandlerHelper({filePath:e,filename:t}){if(!El(e)){let l=`File chooser triggered after the source file ${e} has been cleaned up, ignoring...`;this.logger.error(l),this.logToUserConsole(this.page,"error",l);return}let r=t?.trim()||YO(e),o=GO(e),i=JO(e),a=qc[i];this.page.once("filechooser",async l=>{this.logger.info({filePath:e,fileName:r},"File chooser triggered");try{if(!El(e))throw new Error(`File chooser triggered after the source file ${e} has been cleaned up, ignoring...`);await l.setFiles({name:r,buffer:o,mimeType:Uy.getType(e)||"application/octet-stream"},{timeout:8e3})}catch(c){this.logger.error({err:c},"Error handling file chooser"),this.logToUserConsole(this.page,"error",c.message)}});let s=o.toString("base64");await(await this.getActivePageOrFrame()).evaluate(({fileName:l,base64Data:c,mimeType:d})=>{let p=window;p.momenticFileName=l,p.momenticFileBase64=c;let m=atob(c),u=new Array(m.length);for(let g=0;g<m.length;g++)u[g]=m.charCodeAt(g);let h=new Uint8Array(u);p.MomenticFile=class extends Blob{kind="file";name=p.momenticFileName;constructor(){super([h],{type:d})}isSameEntry(g){return g.name===this.name}queryPermission(g){return console.info("[MOMENTIC] MomenticFile.queryPermission called"),Promise.resolve("granted")}remove(){return console.info("[MOMENTIC] MomenticFile.remove called"),Promise.resolve()}async requestPermission(g){return console.info("[MOMENTIC] MomenticFile.requestPermission called"),Promise.resolve("granted")}async getFile(){console.info("[MOMENTIC] MomenticFile.getFile called");let g=new Blob([h]);return new File([g],p.momenticFileName,{type:d})}async createSyncAccessHandle(){throw console.error("[MOMENTIC] Not implemented"),new Error("Not implemented")}async createWritable(){throw console.error("[MOMENTIC] Not implemented"),new Error("Not implemented")}},p.showOpenFilePicker=async()=>(console.info("[MOMENTIC] showOpenFilePicker called"),[new p.MomenticFile])},{fileName:r,base64Data:s,mimeType:a})}getSerializedFormFromA11yId(e){return this.stateManager.a11yIdToNodeMap[e]?.getNodeOnlySerializedForm()}retrieveAndClearDebugData(){let e=this.cdpClient.loadEventLogs;e.length>0&&(this.logger.debug(e,"Load event logs"),this.cdpClient.loadEventLogs=[]);let t={...this.debugData};return this.debugData={logsPerPage:[],harPages:{},harEntries:{}},t}async copy(e){try{await this.evaluateFunctionInPage(t=>navigator.clipboard.writeText(t),e)}catch(t){if(t instanceof Error&&t.message.includes("Document is not focused")){await this.evaluateFunctionInPage(()=>{document.activeElement||document.body.focus()},void 0),await this.press("Tab",{}),await this.press("Shift+Tab",{}),await this.evaluateFunctionInPage(r=>navigator.clipboard.writeText(r),e);return}throw t}}async paste(){await this.waitForPageLoad(),await this.press("Meta+V",{convertMeta:!0})}async registerRequestListener(e){return this.page.waitForResponse(e)}get smartWaitingTimeout(){return this.userControlledBrowserSettings.smartWaitingTimeoutMs??5e3}get pageLoadTimeout(){return this.userControlledBrowserSettings.pageLoadTimeoutMs??8e3}get isInPageLoad(){return Object.values(this.pageLoadPromises).length>0}get devicePixelRatio(){return this.properties.systemDevicePixelRatio??1}};import yk from"fetch-cookie";import{cloneDeep as bk}from"lodash-es";import{CookieJar as wk}from"tough-cookie";import{z as Mt}from"zod";var xre=Mt.object({doubleClick:Mt.boolean().optional(),rightClick:Mt.boolean().optional(),force:Mt.boolean().optional(),waitForDownload:Mt.boolean().optional(),delayMs:Mt.number().optional(),downloadTimeoutMs:Mt.number().optional(),relativePosition:Mt.object({x:Mt.number(),y:Mt.number()}).optional()}),Ere=Mt.object({repeat:Mt.number().optional(),convertMeta:Mt.boolean().optional().describe("misleading name due to backcompat. converts keyshortcuts + meta/control to platform-specific combos. defaults to true"),delayMs:Mt.number().optional()});var Tp=(n,e,t)=>{let[r,...o]=e.split("."),i=r;return o.length>=1?Tp(n[i],o.join("."),t):n[i]=t,n};async function fr(n,e={}){let t=await n.getBrowserState(e),r=t.serialize();return e.logger?.debug({tree:r.length>4e5?r.slice(0,4e5):r,activeFrame:n.getActiveFrameConfig()},"Got a11y tree"),{serializedTree:r,tree:t}}var di=3.1783027;function rk(n){let e=0;for(let t=0;t<n.length;t++){let r=n.charCodeAt(t);!(r>=48&&r<=57)&&!(r>=65&&r<=90)&&!(r>=97&&r<=122)&&e++}return e}function Ra(n){return Math.ceil(xp(n)/di)}function xp(n){let e=0;if(typeof n=="string"){let t=n;t=t.replaceAll(`
3607
+ `,""),t=t.replaceAll(" ","");let r=rk(t);return t.length-r+di*r}if(typeof n>"u")return 0;if(typeof n=="number")return String(n).length;if(Array.isArray(n))return n.forEach(t=>{e+=xp(t)}),e;if(typeof n=="object"){let t=n;return Object.keys(t).forEach(r=>{e+=String(r).length,r==="image_url"?(t[r]??{}).detail==="high"?e+=1105*di:e+=85*di:e+=xp(t[r])}),e}if(typeof n=="boolean")return n?4:5;throw new Error(`Unsupported type passed to token length calculator '${typeof n}': ${n}`)}var $b={minChunkTokenCount:500,acceptableChunkTokenCount:3e3,maxChunkTokenCount:8e3,maxLineLength:4e3},Gb={minChunkTokenCount:5e3,acceptableChunkTokenCount:1e4,maxChunkTokenCount:15e3,maxLineLength:500},jb=/<(\S+) id="(\d+)".*?>/g,ok=/(<\/(\S+)>)|(<(\S+).*?\/>)/g,Wb=["h1","h2","section","footer","nav","aside","form","label","dialog"],ik=[...Wb,"span","div","h3"],ak=["table","select","form","ul","ol","menu","pre","code","dialog"],sk=["table","form","dialog","nav","section","ul","select"];function Ep(n){return n.serializedTree.length>n.maxCharacterLength&&(n.logger.warn({serializedTreeLength:n.serializedTree.length},"Serialized condensed tree is too long to chunk, truncating before chunking"),n.serializedTree=n.serializedTree.slice(0,n.maxCharacterLength)),lk(n)}function lk({serializedTree:n,options:e,logger:t}){let{minChunkTokenCount:r,acceptableChunkTokenCount:o,maxChunkTokenCount:i,maxLineLength:a}=e,s=[],l=n.split(`
3608
3608
  `),c=0,d=[],p=0,m=[],u=[],h=!1;for(;c<l.length;){h&&(s.push({ids:m,content:d.join(`
3609
3609
  `),tokenLength:p}),d=[],p=0,m=u.length?[u[u.length-1].id]:[],h=!1);let g=l[c],f=Ra(g);p+=f,g.length>a&&(g=g.slice(0,a));let w=Array.from(g.matchAll(jb)).map(P=>P&&P.length>=3?{tagName:P[1],id:P[2]}:void 0).filter(P=>!!P),x=Array.from(g.matchAll(ok)).map(P=>P&&(P[2]||P[4])).filter(P=>!!P);x.reverse();let C=g.replace(/ id="[0-9]+"/g,"");d.push(C);for(let P of w)m.push(P.id),u.push(P);for(let P of x){let K=u[u.length-1];K&&K.tagName===P&&u.pop()}let A=u.some(P=>ak.includes(P.tagName)),N=l[c+1]??"",O=Ra(N),F=Array.from(N.matchAll(jb)).map(P=>P&&P.length>2?P[1]:void 0).filter(P=>!!P),L=F.some(P=>Wb.includes(P)),B=F.some(P=>ik.includes(P));p+O>=i&&(h=!0),p>=r&&(L&&!A||x.some(P=>sk.includes(P)))&&(h=!0),p>=o&&B&&!A&&(h=!0),c++}return d.length&&s.push({ids:m,content:d.join(`
3610
- `),tokenLength:p}),s.forEach((g,f)=>{t.debug({chunk:g},`Chunk for page filtering (index ${f+1}/${s.length})`)}),{chunks:s}}var Cp=4e4,Rp=8e4;async function Zr(n){let{serializedTree:e,logger:t,flagStore:r,softTokenLimit:o=Cp}=n;if(Ra(e)<o)return e;let a=r.isBooleanFlagEnabled("rag_v2"),s;a?s=Ep({serializedTree:e,options:Gb,logger:t,maxCharacterLength:1e6}):s=Ep({serializedTree:e,options:$b,logger:t,maxCharacterLength:3e6});try{return a?await D(ck({...n,chunks:s.chunks}),{milliseconds:2e4}):await D(pk({...n,chunkResult:s}),{milliseconds:15e3})}catch(l){t.warn({err:l},"Error executing page filtering, attempting AI keyword fallback");try{return await dk({...n,chunks:s.chunks})}catch(c){return t.warn({err:c},"Error executing page filtering using keyword matching, using naive truncation"),e.slice(0,Rp*pi)}}}async function ck({chunks:n,generator:e,description:t,type:r,logger:o,signal:i,tree:a,softTokenLimit:s=Cp,hardTokenLimit:l=Rp}){let c=await e.rankChunksWithAi({chunks:n,description:t,type:r,softTokenLimit:s,hardTokenLimit:l},{abortSignal:i,logger:o,loggerTags:ze(o)}),d=[];n.forEach((m,u)=>{c.indices.includes(u)&&(d=d.concat(m.ids))});let p=a.pruneUsingRelevantIds(new Set(d)).serialize();return o.debug({description:t,type:r,selectedChunks:c,tree:p},"Pruned a11y tree with AI page filtering"),p}async function dk(n){let{type:e,description:t,generator:r,tree:o,logger:i,hardTokenLimit:a=Rp}=n;if(!t.trim())throw new Error("Empty description passed to page filtering");let s=await r.getExtractedKeywords({goal:t},{logger:n.logger,loggerTags:ze(n.logger)});for(let l of s.keywords){let c=n.chunks.filter(u=>u.content.toLowerCase().includes(l.toLowerCase()));if(!c.length||c.reduce((u,h)=>u+h.tokenLength,0)>a&&c.length>1)continue;let p=c.flatMap(u=>u.ids),m=o.pruneUsingRelevantIds(new Set(p)).serialize();return i.debug({description:t,type:e,selectedChunks:c,tree:m},"Pruned a11y tree with keyword page filtering"),m}throw new Error("No keywords were unique enough for page filtering")}async function pk(n){let{description:e,generator:t,tree:r,logger:o,signal:i,chunkResult:a,softTokenLimit:s=Cp}=n,l=await t.rankChunksWithRag({description:e,chunks:a.chunks,tokenLimit:s},{abortSignal:i,logger:o,loggerTags:ze(o)});if(l.ids.length===0)throw new Error("RAG returned no important ids");{let c=r.pruneUsingRelevantIds(new Set(l.ids.map(d=>`${d}`))).serialize();return o.debug({browserState:c},"Pruned a11y tree with RAG"),c}}async function Ip(n,e){if(!n.description)throw new R("ActionFailureError","Cannot locate element with empty description");return Rn({action:async()=>uk(n,e),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,browser:e.browser,logger:e.logger})}async function uk(n,e){let{disableCache:t,testContext:r,filterByViewport:o,skipWait:i,source:a}=n,{ctx:s,orgId:l,logger:c,browser:d,localCodeEvalTools:p,generator:m,abortSignal:u,flagStore:h}=e,g=n.description;r&&(g=await Bt({orgId:l,s:g,context:r,logger:e.logger,localTools:p,signal:e.abortSignal,flagStore:h})),a&&(g=mk(g,a));let{serializedTree:f,tree:S}=await fr(d,{filterByViewport:o,abortSignal:u,skipWait:i,logger:c}),b,w=Date.now(),v;for(;!b&&Date.now()-w<3e3;){u.throwIfAborted();try{b=await d.screenshot({clearHighlights:!0,respectActiveFrame:!0,retries:2})}catch(P){v=P}}if(!b)throw new R("ActionFailureError",`Failed to take screenshot of page to locate element. The page may be unresponsive, or your machine might be severely resource constrained. Error: ${v?.message}`);let x=f,C=!1;x=await Zr({type:"locator",description:g,serializedTree:f,flagStore:e.flagStore,tree:S,logger:c,generator:m}),x!==f&&(C=!0);let N=`data:image/jpeg;base64,${b.toString("base64")}`,O=await m.getElementLocation({browserState:x,goal:g,screenshot:N,source:a},{disableCache:t,abortSignal:u,loggerTags:ze(c)});c.debug({usedRag:C,result:O},"Got locator result");let H=O.id>0;if(s?.details?.push({type:"AI_LOCATION",matched:H,pageState:x,ragUsed:C,thoughts:O.thoughts}),!H)throw new R("ActionFailureError",`Could not find any relevant element: ${O.thoughts}`);let{resolution:F,target:L,frameConfig:B}=await d.createTargetFromA11yId({id:O.id,description:g,targetSource:"AI",logger:c});if(F.a11yNode?.properties?.hidden&&F.a11yNode?.properties?.hidden!=="false")throw new R("ActionFailureError",`Momentic's AI found a relevant element to interact with, but it is explicitly marked with an 'aria-hidden' attribute. Please remove this attribute or adjust the element description to locate a different element. Element chosen: ${F.displayString}`);return{thoughts:O.thoughts,target:L,resolution:F,frameConfig:B,screenshot:N}}var Vb="<select> element:",qb="text input or contenteditable element:",Kb="Element exactly matching the description below. Interpret the description narrowly and do not assume there are any typos or errors. Err on the side of returning -1 unless there is a perfect match. Description:",Yb="Element closely matching the description below. Interpret the description narrowly and do not return elements that are merely loosely related. Description:",Ap=[Vb,qb,Kb,Yb];function Jb(n,e){if(n===e)return!0;for(let t of Ap){if(!n.startsWith(t))continue;let r=n.slice(t.length).trim();if(Ap.some(o=>e.startsWith(o)&&e.slice(o.length).trim()===r)||r===e.trim())return!0}return!!Ap.some(t=>e.startsWith(t)&&e.slice(t.length).trim()===n.trim())}function mk(n,e){if(!n||!e)return n;switch(e){case"SELECT_OPTION":return`${Vb} ${n}`;case"TYPE":return`${qb} ${n}`;case"NEGATED_CHECK":return`${Kb}
3610
+ `),tokenLength:p}),s.forEach((g,f)=>{t.debug({chunk:g},`Chunk for page filtering (index ${f+1}/${s.length})`)}),{chunks:s}}var Cp=4e4,Rp=8e4;async function Zr(n){let{serializedTree:e,logger:t,flagStore:r,softTokenLimit:o=Cp}=n;if(Ra(e)<o)return e;let a=r.isBooleanFlagEnabled("rag_v2"),s;a?s=Ep({serializedTree:e,options:Gb,logger:t,maxCharacterLength:1e6}):s=Ep({serializedTree:e,options:$b,logger:t,maxCharacterLength:3e6});try{return a?await D(ck({...n,chunks:s.chunks}),{milliseconds:2e4}):await D(pk({...n,chunkResult:s}),{milliseconds:15e3})}catch(l){t.warn({err:l},"Error executing page filtering, attempting AI keyword fallback");try{return await dk({...n,chunks:s.chunks})}catch(c){return t.warn({err:c},"Error executing page filtering using keyword matching, using naive truncation"),e.slice(0,Rp*di)}}}async function ck({chunks:n,generator:e,description:t,type:r,logger:o,signal:i,tree:a,softTokenLimit:s=Cp,hardTokenLimit:l=Rp}){let c=await e.rankChunksWithAi({chunks:n,description:t,type:r,softTokenLimit:s,hardTokenLimit:l},{abortSignal:i,logger:o,loggerTags:ze(o)}),d=[];n.forEach((m,u)=>{c.indices.includes(u)&&(d=d.concat(m.ids))});let p=a.pruneUsingRelevantIds(new Set(d)).serialize();return o.debug({description:t,type:r,selectedChunks:c,tree:p},"Pruned a11y tree with AI page filtering"),p}async function dk(n){let{type:e,description:t,generator:r,tree:o,logger:i,hardTokenLimit:a=Rp}=n;if(!t.trim())throw new Error("Empty description passed to page filtering");let s=await r.getExtractedKeywords({goal:t},{logger:n.logger,loggerTags:ze(n.logger)});for(let l of s.keywords){let c=n.chunks.filter(u=>u.content.toLowerCase().includes(l.toLowerCase()));if(!c.length||c.reduce((u,h)=>u+h.tokenLength,0)>a&&c.length>1)continue;let p=c.flatMap(u=>u.ids),m=o.pruneUsingRelevantIds(new Set(p)).serialize();return i.debug({description:t,type:e,selectedChunks:c,tree:m},"Pruned a11y tree with keyword page filtering"),m}throw new Error("No keywords were unique enough for page filtering")}async function pk(n){let{description:e,generator:t,tree:r,logger:o,signal:i,chunkResult:a,softTokenLimit:s=Cp}=n,l=await t.rankChunksWithRag({description:e,chunks:a.chunks,tokenLimit:s},{abortSignal:i,logger:o,loggerTags:ze(o)});if(l.ids.length===0)throw new Error("RAG returned no important ids");{let c=r.pruneUsingRelevantIds(new Set(l.ids.map(d=>`${d}`))).serialize();return o.debug({browserState:c},"Pruned a11y tree with RAG"),c}}async function Ip(n,e){if(!n.description)throw new R("ActionFailureError","Cannot locate element with empty description");return Rn({action:async()=>uk(n,e),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,browser:e.browser,logger:e.logger})}async function uk(n,e){let{disableCache:t,testContext:r,filterByViewport:o,skipWait:i,source:a}=n,{ctx:s,orgId:l,logger:c,browser:d,localCodeEvalTools:p,generator:m,abortSignal:u,flagStore:h}=e,g=n.description;r&&(g=await Bt({orgId:l,s:g,context:r,logger:e.logger,localTools:p,signal:e.abortSignal,flagStore:h})),a&&(g=mk(g,a));let{serializedTree:f,tree:S}=await fr(d,{filterByViewport:o,abortSignal:u,skipWait:i,logger:c}),b,w=Date.now(),v;for(;!b&&Date.now()-w<3e3;){u.throwIfAborted();try{b=await d.screenshot({clearHighlights:!0,respectActiveFrame:!0,retries:2})}catch(P){v=P}}if(!b)throw new R("ActionFailureError",`Failed to take screenshot of page to locate element. The page may be unresponsive, or your machine might be severely resource constrained. Error: ${v?.message}`);let x=f,C=!1;x=await Zr({type:"locator",description:g,serializedTree:f,flagStore:e.flagStore,tree:S,logger:c,generator:m}),x!==f&&(C=!0);let N=`data:image/jpeg;base64,${b.toString("base64")}`,O=await m.getElementLocation({browserState:x,goal:g,screenshot:N,source:a},{disableCache:t,abortSignal:u,loggerTags:ze(c)});c.debug({usedRag:C,result:O},"Got locator result");let H=O.id>0;if(s?.details?.push({type:"AI_LOCATION",matched:H,pageState:x,ragUsed:C,thoughts:O.thoughts}),!H)throw new R("ActionFailureError",`Could not find any relevant element: ${O.thoughts}`);let{resolution:F,target:L,frameConfig:B}=await d.createTargetFromA11yId({id:O.id,description:g,targetSource:"AI",logger:c});if(F.a11yNode?.properties?.hidden&&F.a11yNode?.properties?.hidden!=="false")throw new R("ActionFailureError",`Momentic's AI found a relevant element to interact with, but it is explicitly marked with an 'aria-hidden' attribute. Please remove this attribute or adjust the element description to locate a different element. Element chosen: ${F.displayString}`);return{thoughts:O.thoughts,target:L,resolution:F,frameConfig:B,screenshot:N}}var Vb="<select> element:",qb="text input or contenteditable element:",Kb="Element exactly matching the description below. Interpret the description narrowly and do not assume there are any typos or errors. Err on the side of returning -1 unless there is a perfect match. Description:",Yb="Element closely matching the description below. Interpret the description narrowly and do not return elements that are merely loosely related. Description:",Ap=[Vb,qb,Kb,Yb];function Jb(n,e){if(n===e)return!0;for(let t of Ap){if(!n.startsWith(t))continue;let r=n.slice(t.length).trim();if(Ap.some(o=>e.startsWith(o)&&e.slice(o.length).trim()===r)||r===e.trim())return!0}return!!Ap.some(t=>e.startsWith(t)&&e.slice(t.length).trim()===n.trim())}function mk(n,e){if(!n||!e)return n;switch(e){case"SELECT_OPTION":return`${Vb} ${n}`;case"TYPE":return`${qb} ${n}`;case"NEGATED_CHECK":return`${Kb}
3611
3611
  ${n}`;case"ELEMENT_CHECK":return`${Yb}
3612
- ${n}`;default:return n}}var hk=15;async function Pp({command:n,fixtures:e}){if(!n.assertion.trim())throw new R("ActionFailureError","Assertion command is missing the assertion content");let{browser:t,logger:r}=e,o=n.timeout?n.timeout*1e3:t.smartWaitingTimeout,i=gk(o),a=0,s=Date.now(),l,c,d;try{await Rn({action:()=>t.clearHighlights(),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,browser:t,logger:r})}catch(m){r.warn({err:m},"Failed to clear highlights before AI assertion, continuing...")}let p;for(;a<hk&&(!p||p-s<o);){e.abortSignal.throwIfAborted(),a!==0&&(r.info(`Waiting ${i}ms before retrying AI assertion`),await te(i,e.abortSignal)),p=Date.now();try{let m=await Rn({action:async()=>{let u=await Xb(t,r,e.abortSignal);return c&&c.serializedTree===u.serializedTree&&c.screenshotBuff.equals(u.screenshotBuff)?!1:(c=u,Zb({command:n,state:u,fixtures:e,useConsensus:!1,highlightElementsOnFailure:!1,attemptNumber:a}))},frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,logger:r,browser:t});if(!m)continue;l=m;break}catch(m){e.abortSignal.throwIfAborted(),d=m instanceof Error?m:new Error(`${m}`),r.info({err:m},`AI check assert attempt ${a} failed, retrying...`)}finally{a++}}if(!l)try{l=await Rn({action:async()=>Zb({command:n,state:await Xb(t,r,e.abortSignal),fixtures:e,useConsensus:!0,highlightElementsOnFailure:!0,attemptNumber:a}),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,logger:r,browser:t})}catch(m){e.abortSignal.throwIfAborted(),d=m instanceof Error?m:new Error(`${m}`)}finally{a++}if(!l){let m=`AI assertion still failing after ${a} attempts.`;throw d&&(m+=` Latest result: ${d.message}`),new R("AssertionFailureError",m,{lastScreenshotBuffer:c?.screenshotBuff})}return l}async function Xb(n,e,t){let[r,o]=await Promise.all([fr(n,{abortSignal:t,skipWait:!0,skipWaitForPageLoad:!0,logger:e}),n.screenshot({retries:1,respectActiveFrame:!0})]);return{...r,screenshotBuff:o}}async function Zb({command:n,state:e,fixtures:t,useConsensus:r,highlightElementsOnFailure:o,attemptNumber:i}){let{browser:a,logger:s,generator:l,abortSignal:c}=t,d={type:"ASSERTION"},{serializedTree:p,tree:m}=e,u=e.screenshotBuff,h=a.url(),g=p;g=await Zr({type:"assertion",serializedTree:p,description:n.assertion,flagStore:t.flagStore,tree:m,generator:l,logger:s,signal:c}),g!==p&&(d.ragUsed=!0),d.pageState=g;let f={goal:n.assertion,url:h,browserState:g,screenshot:u.toString("base64"),contextChoice:n.contextChoice},b=await(n.contextChoice==="VISION_ONLY"?(w,v)=>l.getVisualAssertionResult(w,v):(w,v)=>l.getAssertionResult(w,v))(f,{useConsensus:r,attemptNumber:i,disableCache:!!n.disableCache,logger:s,abortSignal:c,loggerTags:ze(s)});if((b.result||o)&&b.relevantElements&&(d.relevantElementsSerialized=b.relevantElements.map(w=>a.getSerializedFormFromA11yId(w)).filter(w=>!!w),await fk(b.relevantElements,a,s)),!b.result)throw new R("AssertionFailureError",b.thoughts);return{succeedImmediately:!1,thoughts:b.thoughts,urlAfterCommand:h,afterScreenshotOverride:u}}function gk(n){let e;return n>10*60*1e3?e=2*60*1e3:n>60*1e3?e=20*1e3:n>10*1e3?e=2*1e3:e=1e3,e}async function fk(n,e,t){let r=Date.now();for(let o of n){if(Date.now()-r>2e3){t.debug("Highlighting relevant elements took over 2s, aborting...");return}try{let i=new AbortController;await D(e.highlightA11yId(o),{milliseconds:1e3,fallback:()=>{throw i.abort(),new Error("Timed out waiting for highlighting to complete")}})}catch(i){t.debug({err:i},"Failed to highlight relevant element after assertion, continuing...");return}}}var Sk=3e4;async function Qb({command:n,logger:e,baseUrl:t,fetchImplementation:r=fetch}){let o=n.timeout??Sk/1e3,i=new AbortController,a=Object.fromEntries(Object.entries(n.headers||{}).filter(([p,m])=>p&&m)),s;if(Mo(n.url)&&(s=n.url),t&&No(n.url,t)&&(s=new URL(n.url,t).toString()),!s)throw new R("ActionFailureError",`Invalid URL: ${n.url}`);let c=await D((async()=>{try{return await r(s,{headers:a,method:"POST",body:JSON.stringify({query:n.query,variables:n.variables}),signal:i.signal})}catch(p){e.error({err:p},"Failed to make HTTP request")}})(),{milliseconds:o*1e3});if(!c)throw new R("ActionFailureError",`GraphQL request timed out after ${o} seconds`);if(!c.ok){let p;try{p=await c.json()}catch{throw new R("ActionFailureError",`GraphQL request failed with status ${c.status}: ${await c.text()}`)}throw p?.errors?.length&&p?.errors[0]?.message?new R("ActionFailureError",`GraphQL request failed with status ${c.status}: ${p.errors[0].message}`):new R("ActionFailureError",`GraphQL request failed with status ${c.status}: ${await c.text()}`)}let d={};return c.headers.forEach((p,m)=>{d[m]=p}),{status:c.status,headers:d,json:await c.json()}}var ui=class{flagStore;orgId;options;storage;localCodeEvalTools;uploadedFileStorage;visualDiffScreenshotStorage;browser;generator;executeAbortController=new AbortController;logger;analytics;recordAbortController=null;registeredListeners={};constructor({browser:e,generator:t,logger:r,analytics:o,flagStore:i,storage:a,orgId:s,localCodeEvalTools:l,uploadedFileStorage:c,visualDiffScreenshotStorage:d,options:p}){this.orgId=s,this.options=p,this.browser=e,this.browser.registerAbortSignal(this.executeAbortController.signal),this.storage=a,this.uploadedFileStorage=c,this.visualDiffScreenshotStorage=d,this.localCodeEvalTools=l,this.generator=t,this.logger=r,this.analytics=o,this.flagStore=i}setOpen(){this.executeAbortController=new AbortController,this.browser.registerAbortSignal(this.executeAbortController.signal)}setClosed(){this.executeAbortController.abort()}throwIfClosed(){this.executeAbortController.signal.throwIfAborted()}get closed(){return this.executeAbortController.signal.aborted}async evaluateAiAction({goal:e,startingScreenshot:t,history:r,disableCache:o,langfuseSessionId:i,lastError:a,logger:s=this.logger}){let[l,c]=await Promise.all([fr(this.browser,{abortSignal:this.executeAbortController.signal,skipWait:!0,skipWaitForPageLoad:!0,logger:s}),this.browser.screenshot({retries:1,clearHighlights:!0})]),d=await Zr({type:"ai-action",description:e,serializedTree:l.serializedTree,tree:l.tree,logger:s,generator:this.generator,flagStore:this.flagStore,softTokenLimit:25e3,hardTokenLimit:5e4}),p=`data:image/jpeg;base64,${c.toString("base64")}`,m={url:this.browser.url(),browserState:d,startingScreenshot:t,history:r,goal:e,screenshot:p,lastError:a};return await this.generator.getMultiturnAiActionEvaluation(m,{disableCache:o,abortSignal:this.executeAbortController.signal,loggerTags:{...ze(s)},langfuseSessionId:i})}async promptToCommand({goal:e,startingScreenshot:t,history:r,actionHint:o,disableCache:i,logger:a=this.logger,langfuseSessionId:s}){let l=this.browser.url(),[c,d]=await Promise.all([fr(this.browser,{abortSignal:this.executeAbortController.signal,skipWait:!0,skipWaitForPageLoad:!0,logger:a}),this.browser.screenshot({retries:1,clearHighlights:!0})]),p=`data:image/jpeg;base64,${d.toString("base64")}`,m=await Zr({type:"ai-action",description:e,serializedTree:c.serializedTree,tree:c.tree,logger:a,generator:this.generator,flagStore:this.flagStore,softTokenLimit:25e3,hardTokenLimit:5e4}),u={url:l,browserState:m,startingScreenshot:t,history:r,goal:e,actionHint:o,screenshot:p};try{return await this.generator.getMultiturnAiActionCommand(u,{disableCache:i,abortSignal:this.executeAbortController.signal,loggerTags:{...ze(a)},langfuseSessionId:s})}catch(h){throw new R("InternalWebAgentError",`Error generating command: ${h instanceof Error?h.message:h}`,{errOptions:{cause:h}})}}async getBrowserState(e){return fr(this.browser,e)}async locateElement(e){return Ip(e,this.getControllerFixtures())}async locateElementWithSelector(e,t){return Rn({action:async()=>{let r=await this.browser.resolveHardcodedCssSelector({ctx:null,selector:e,timeoutMs:2e3,logger:this.logger});return{thoughts:"Located element with selector",target:{id:-1,selector:e,targetSource:"USER_CSS_SELECTOR",targetUpdateTime:new Date().toUTCString()},resolution:r}},frameConfig:t?{type:"url",url:t}:void 0,browser:this.browser,logger:this.logger})}getControllerFixtures(e){return{ctx:e??null,browser:this.browser,generator:this.generator,logger:this.logger,orgId:this.orgId,flagStore:this.flagStore,storage:this.storage,localCodeEvalTools:this.localCodeEvalTools,abortSignal:this.executeAbortController.signal}}async wrapMultiElementTargetingCommand({ctx:e,tracer:t,command:r,targetNames:o,descriptions:i,caches:a,action:s,options:l,retriesWithAI:c=1}){let d=[];for(let p=0;p<i.length;p++){let m=i[p],u=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:m,cache:a[p],action:async h=>h,options:{...l,skipFetchTree:p!==0,targetName:o[p]}});d.push(u)}try{return{result:await s(...d.map(m=>m.result)),elementInteractedDisplayStrings:d.map(m=>m.elementInteractedDisplayString),newTargets:d.map(m=>m.newTarget)}}catch(p){if(this.throwIfClosed(),c>0)return this.logger.debug({err:p},"Failed to execute action with multiple cached targets, retrying with AI"),this.wrapMultiElementTargetingCommand({ctx:e,tracer:t,command:r,targetNames:o,descriptions:i,caches:i.map(()=>{}),action:s,options:l,retriesWithAI:c-1});throw new R("ActionFailureError",p.message,{errOptions:{cause:p}})}}async wrapElementTargetingCommand(e){let t=this.logger.child({commandId:e.command.id}),r;for(let o=0;o<2;o++)try{return await Rn({action:()=>this.wrapElementTargetingCommandHelper(e),frameConfig:e.options.iframeUrl?{type:"url",url:e.options.iframeUrl}:void 0,browser:this.browser,logger:t})}catch(i){if(r=i,this.flagStore.isBooleanFlagEnabled("visual_actions")&&Vc(i)){t.warn({err:i},"Invalid mpath error, retrying element targeting command");continue}if(!this.flagStore.isBooleanFlagEnabled("visual_actions")&&Ji(i)){t.warn({err:i},"Invalid momentic id error, retrying element targeting command");continue}throw i}throw r instanceof R?r:new R("ActionFailureError",r?.message??"An unknown error occurred during element targeting")}async wrapHardcodedCssTargetingCommandHelper({ctx:e,target:t,action:r,options:o,command:i}){let a=this.logger.child({commandId:i.id}),{targetName:s="target"}=o;if(t.type!=="description")throw new R("ActionFailureError","Cannot use selector with non-description target");let l=await this.browser.resolveHardcodedCssSelector({ctx:e,selector:t.elementDescriptor,targetName:s,logger:a});return{result:await r({locator:l.locator}),elementInteractedDisplayString:l.displayString,newTarget:{cache:{id:-1,selector:t.elementDescriptor,targetSource:"USER_CSS_SELECTOR",targetUpdateTime:new Date().toUTCString()}}}}async wrapElementTargetingCommandHelper(e){let{ctx:t,tracer:r,target:o,action:i,options:a,command:s}=e,{disableCache:l,useSelector:c,targetName:d="target",targetHealingInProgress:p,source:m}=a,u=this.logger.child({commandId:s.id}),h=a.retriesWithAI??1,g=!1,f=e.cache;if((!f||l)&&!Ql(o))throw new R("ActionFailureError","Cannot target element with no cached data or element descriptor");if(c)return this.wrapHardcodedCssTargetingCommandHelper(e);l&&(u.debug("Cache explicitly disabled for this step"),g=!0,f=void 0),f?.inputDescription&&!Jb(o.elementDescriptor,f.inputDescription)&&(u.warn({old:f.inputDescription,new:o.elementDescriptor},"Target cache was generated with a different description, clearing it automatically"),g=!0,f=void 0);let S=!!f&&Iu(f);if(!f){let b=new Date;u.debug({targetHealingInProgress:p,cacheBustedBeforeAction:g},"Prompting AI for an updated element location"),g&&await te(this.browser.smartWaitingTimeout,this.executeAbortController.signal),h--;let w=await Ip({description:o.elementDescriptor,disableCache:l,iframeUrl:a.iframeUrl,source:m},this.getControllerFixtures(t));w.frameConfig&&this.browser.setActiveFrameConfig(w.frameConfig);let v=a.disableGlobalLocatorRedirect?{locator:w.resolution.locator}:await this.attemptLocatorRedirect(w.resolution.locator,u),x=await i(v),C;if(p){r.heal({healType:"AI"}),this.analytics.track({type:"execution:step_heal",heal_type:"AI",step_type:"PRESET_ACTION",command_type:s.type,duration_ms:Date.now()-b.getTime()}),w.target.targetSource="AI_HEALED",w.target.targetUpdateTime=new Date().toUTCString(),w.target.targetUpdateLoggerTags=ze(u);let A=w.resolution.pageState;if(A)try{C=await this.getReverseMappedDescription({browserState:A,targetId:w.target.id,disableCache:!0,screenshot:w.screenshot})}catch(N){u.warn({err:N},"Failed to reverse map element auto-healed by AI, continuing...")}}return{result:x,elementInteractedDisplayString:w.resolution.displayString,newTarget:{cache:w.target,thoughts:w.thoughts,description:C}}}try{let b=new Date,w=await this.browser.resolveTarget(t,f,{targetName:d,logger:u});(this.flagStore.isBooleanFlagEnabled("global_locator_redirect")||this.flagStore.isBooleanFlagEnabled("visual_actions"))&&await w.locator.scrollIntoViewIfNeeded({timeout:2e3});let v=a.disableGlobalLocatorRedirect?{locator:w.locator}:await this.attemptLocatorRedirect(w.locator,u),x=await i(v);if(S){let C=w.decisions.filter(A=>A.matched);if(C.length!==1)u.warn({decisions:w.decisions},"Expected exactly 1 matching method for element location, got more or less");else{let A=C[0].type;r.heal({healType:A}),this.analytics.track({type:"execution:step_heal",heal_type:A,step_type:"PRESET_ACTION",command_type:s.type,duration_ms:Date.now()-b.getTime()})}}return{result:x,elementInteractedDisplayString:w.displayString,newTarget:{cache:f}}}catch(b){this.throwIfClosed();let w=yh(b)&&!Vc(b)&&!Ji(b);if(b instanceof R&&!w)throw b;if(h>0&&o)return u.debug({err:b,cache:f},"Failed to execute action with cached target, retrying with AI"),this.wrapElementTargetingCommand({ctx:t,tracer:r,command:s,target:o,cache:void 0,action:i,options:{...a,retriesWithAI:h,targetHealingInProgress:!0}});throw new R("ActionFailureError",b.message,{errOptions:{cause:b}})}}async attemptLocatorRedirect(e,t){return this.flagStore.isBooleanFlagEnabled("global_locator_redirect")?this.browser.performTargetRedirection(e,t):{locator:e}}async screenshotWithDimensions(e){return xa(this.browser,e)}async executePresetCommand(e,t,r,o,i){this.options?.slowMoMs&&await te(this.options.slowMoMs);let a=await this.browser.getOpenPages(),s=this.browser.url(),l;try{l=await this.resolveCommandTemplateStrings(r,o)}catch(c){throw this.throwIfClosed(),new R("ActionFailureError",`Failed to substitute template strings in command: ${c.message}`,{errOptions:{cause:c}})}try{let c=await this.executePresetCommandHelper(e,t,r,o,i);return this.flagStore.isBooleanFlagEnabled("visual_actions")&&Mu(r)?await this.browser.waitForDOMStability({timeout:2e3}):!this.flagStore.isBooleanFlagEnabled("visual_actions")&&["PRESS","TYPE"].includes(r.type)&&await this.browser.waitForDOMStability({timeout:1e3}),this.options?.autoFollowNewTabs&&await fy({beforeUrl:s,command:r,beforePages:a.map(d=>d.url),browser:this.browser,logger:this.logger}),c}catch(c){throw c.name!=="AbortError"&&this.logger.error({err:c},"Error thrown in action controller"),c}finally{this.restoreCommandTemplateReplacements(r,l)}}restoreCommandTemplateReplacements(e,t={}){for(let[r,o]of Object.entries(t))Tp(e,r,o)}createCallbacksForBrowser(e){return{createIsolatedFolder:()=>cp(e)}}async resolveCommandTemplateStrings(e,t){return ai({obj:e,context:t,bannedKeys:["type","a11yData","thoughts","cache","code"],orgId:this.orgId,logger:this.logger,signal:this.executeAbortController.signal,localTools:this.localCodeEvalTools,flagStore:this.flagStore})}async executePresetCommandHelper(e,t,r,o,i){switch(i=i||"disableCache"in r&&!!r.disableCache,r.type){case"SUCCESS":let a=r.condition;return a?.assertion.trim()?Pp({command:a,fixtures:this.getControllerFixtures(e)}):{succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"AI_ASSERTION":{if(!r.assertion.trim())throw new R("ActionFailureError","Missing assertion");if(r.timeout&&r.timeout>1800)throw new R("AssertionFailureError",`AI assertion timeout of ${r.timeout} exceeds the maximum allowed value of 30 minutes.`);return Pp({command:{...r,type:"AI_ASSERTION"},fixtures:this.getControllerFixtures(e)})}case"AI_EXTRACT":{if(!r.goal.trim())throw new R("ActionFailureError","Cannot perform AI extraction without goal");let u=await this.browser.getCondensedHtml(),h=await this.browser.screenshot({retries:2});try{let g=await this.generator.getTextExtraction({goal:r.goal,browserState:u,returnSchema:r.schema,screenshot:`data:image/jpeg;base64,${h.toString("base64")}`},{disableCache:i,abortSignal:this.executeAbortController.signal,loggerTags:ze(this.logger)});if(g.result==="NOT_FOUND")throw new R("ActionFailureError","No relevant data found for extraction goal on this page");if(g.thoughts?.includes("MaxGenerationLengthExceededError"))throw new R("UserConfigurationError",g.thoughts);return{thoughts:g.thoughts||void 0,data:g.result,succeedImmediately:!1,urlAfterCommand:this.browser.url()}}catch(g){let f=g.message;throw f.includes("MaxGenerationLengthExceededError")?new R("UserConfigurationError","You tried to extract too much data. Please rephrase your query to limit the results returned or use a JavaScript step in the browser instead."):f.includes("AIProviderError")&&f.includes("time")?new R("AIProviderError","The AI provider responded with an error. This may be because you tried to extract too much data. Please limit extraction results to 2000 characters.",{errOptions:{cause:g}}):g}}case"NAVIGATE":if(!Mo(r.url)&&!No(r.url,this.browser.baseUrl))throw new R("ActionFailureError",`Invalid URL provided to navigate command: ${r.url}`);await this.browser.navigate({url:r.url,loadTimeoutMs:r.loadTimeout?r.loadTimeout*1e3:void 0});break;case"DIALOG":this.browser.registerDialogHandler(r.action);break;case"CAPTCHA":if(!this.browser.canSolveCaptchas())break;let s=await this.browser.solveCaptcha();s&&(await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:{type:"description",elementDescriptor:"the captcha image solution input"},cache:void 0,action:u=>this.browser.click(u,this.createCallbacksForBrowser(this.orgId),{}),options:{disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl}}),await this.browser.type(s,{clearContent:!0,pressEnter:!0},!0));break;case"GO_BACK":await this.browser.goBack();break;case"GO_FORWARD":await this.browser.goForward();break;case"SCROLL_LEFT":case"SCROLL_RIGHT":case"SCROLL_DOWN":case"SCROLL_UP":{let u,h=[];if(r.target&&yn(r.target))await this.browser.hoverUsingVisualCoordinates(r.target.pixels);else if(r.target&&r.target.elementDescriptor.trim()){let{newTarget:g,elementInteractedDisplayString:f}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:S=>this.browser.hover(S),options:{disableGlobalLocatorRedirect:!0,disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl}});u=f,h.push(g)}switch(r.type){case"SCROLL_UP":await this.browser.scrollVertical(-(r.deltaY??this.browser.getViewport().height));break;case"SCROLL_DOWN":await this.browser.scrollVertical(r.deltaY??this.browser.getViewport().height);break;case"SCROLL_LEFT":await this.browser.scrollHorizontal(-(r.deltaX??this.browser.getViewport().width));break;case"SCROLL_RIGHT":await this.browser.scrollHorizontal(r.deltaX??this.browser.getViewport().width);break}return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:u,newTargets:h}}case"WAIT_FOR_URL":{if(r.timeout&&r.timeout>1800)throw new R("UserConfigurationError",`Wait for URL timeout of ${r.timeout} exceeds the maximum allowed value of 30 minutes.`);let u=r.matcher;await this.browser.waitForUrl({beforeUrl:this.browser.url(),matcher:u},{timeout:r.timeout?r.timeout*1e3:void 0,negated:r.negated,caseInsensitive:r.caseInsensitive});break}case"WAIT":if(r.delay>1800)throw new R("UserConfigurationError",`Wait timeout of ${r.delay} seconds exceeds the maximum allowed value of 30 minutes`);let l=r.delay*1e3;await te(l,this.executeAbortController.signal);break;case"REFRESH":await this.browser.refresh({loadTimeoutMs:r.loadTimeout?r.loadTimeout*1e3:void 0});break;case"CLICK":{if(yn(r.target)){await this.browser.clickUsingVisualCoordinates(r.target.pixels,r);break}let u=this.browser.url(),h={disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl},{elementInteractedDisplayString:g,newTarget:f,result:S}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,target:r.target,command:r,cache:r.cache?.target,action:w=>this.browser.click(w,this.createCallbacksForBrowser(this.orgId),r),options:h});f.cache&&(r.cache={target:f.cache});let b={urlAfterCommand:this.browser.url(),succeedImmediately:!1,elementInteracted:g,newTargets:[f],data:S};return Ms(u,b.urlAfterCommand)&&(b.succeedImmediately=!0,b.succeedImmediatelyReason="URL changed"),b}case"COPY":return await this.browser.copy(r.value),{succeedImmediately:!1,data:r.value,urlAfterCommand:this.browser.url()};case"PASTE":{await this.browser.paste();break}case"DRAG":{if(yn(r.fromTarget)&&yn(r.toTarget)){await this.browser.dragAndDropUsingVisualCoordinates(r.fromTarget.pixels,r.toTarget.pixels,{hoverSeconds:r.hoverSeconds});break}if(yn(r.fromTarget)||yn(r.toTarget))throw new Error("Drag and drop targets must be both coordinates or both descriptions");let{newTargets:u,elementInteractedDisplayStrings:h}=await this.wrapMultiElementTargetingCommand({ctx:e,tracer:t,command:r,targetNames:["from target","to target"],descriptions:[r.fromTarget,r.toTarget],caches:[r.cache?.fromTarget,r.cache?.toTarget],action:(g,f)=>this.browser.dragAndDrop(g.locator,f.locator,{hoverSeconds:r.hoverSeconds,steps:r.steps}),options:{useSelector:!!r.useSelector,disableCache:i}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:h[0],newTargets:u}}case"MOUSE_DRAG":{let u=parseInt(r.deltaX),h=parseInt(r.deltaY),g=r.steps??5;if(isNaN(u)||isNaN(h))throw new R("ActionFailureError",`Invalid pixel values passed to mouse drag command: (${r.deltaX}, ${r.deltaY})`);if(r.target&&yn(r.target)){await this.browser.mouseDragUsingVisualCoordinates(u,h,g,r.target.pixels,{force:r.force});break}let f,S,b=[];if(r.target?.elementDescriptor){let{newTarget:w,elementInteractedDisplayString:v,result:x}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:async C=>C.locator,options:{useSelector:!!r.useSelector,iframeUrl:r.iframeUrl,disableCache:i}});f=x,S=v,b.push(w)}return await this.browser.mouseDrag(u,h,g,f,{force:r.force}),{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:S,newTargets:b}}case"SELECT_OPTION":{if(!Xn(r.target))throw new Error("Select with x/y is not supported yet");let u=r.target.elementDescriptor,h=r.choice,{newTarget:g,elementInteractedDisplayString:f}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:{type:"description",elementDescriptor:u},cache:r.cache?.target,action:S=>this.browser.selectOption(S,h,r.force),options:{disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl,source:Rr(r)}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:f,newTargets:[g]}}case"TAB":{let u={loadTimeoutMs:r.loadTimeout?r.loadTimeout*1e3:void 0,retry:!0};await this.browser.switchToPage(r.action,u);break}case"NEW_TAB":await this.browser.createNewTab(r.url,{loadTimeoutMs:r.loadTimeout?r.loadTimeout*1e3:void 0});break;case"COOKIE":if(!r.value)break;let c=await this.browser.setCookie(r.value);this.logger.debug({results:c},"Set cookies");break;case"LOCAL_STORAGE":if(!r.value||!r.key)break;await this.browser.setLocalStorage(r.key,r.value);break;case"JAVASCRIPT":{let u;try{r.environment==="BROWSER"?(u=await this.browser.evaluateCodeInPage({code:r.code,fragment:r.fragment??!1,context:o.toObjectCopy(),timeoutMs:r.timeout?r.timeout*1e3:void 0}),this.logger.debug({result:u},"Executed JavaScript in browser")):u=await jn({orgId:this.orgId,code:r.code,fragment:!!r.fragment,context:o,timeoutMs:r.timeout?r.timeout*1e3:void 0,logger:this.logger,localTools:this.localCodeEvalTools,signal:this.executeAbortController.signal,flagStore:this.flagStore,callbacks:{onPersistentVariableUpdates:async h=>{if(!this.options?.scratchPadId){this.logger.warn({updates:h},"Got persistent variable updates but scratch pad is not available");return}await this.storage.savePersistentVariables?.({scratchPadId:this.options?.scratchPadId,orgId:this.orgId,updates:h,logger:this.logger})}}})}catch(h){throw this.throwIfClosed(),new R("ActionFailureError",h instanceof Error?h.message:`${h}`,{errOptions:{cause:h}})}try{JSON.stringify(u)}catch(h){throw new R("ActionFailureError",`Return value is not serializable: ${h instanceof Error?h.message:`${h}`}`,{errOptions:{cause:h}})}return{urlAfterCommand:this.browser.url(),succeedImmediately:!1,data:u}}case"TYPE":{if(r.target&&yn(r.target)){await this.browser.clickUsingVisualCoordinates(r.target.pixels,r),await this.browser.type(r.value,{force:r.force,clearContent:r.clearContent,forceClearContent:r.forceClearContent,delay:r.delay,pressEnter:r.pressEnter},!0);break}let u=this.browser.url(),h,g=[],f=bk(r.target);if(f){let{elementInteractedDisplayString:b,newTarget:w}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:f,cache:r.cache?.target,action:v=>this.browser.typeIntoTarget(r.value,v,{force:r.force,clearContent:r.clearContent,forceClearContent:r.forceClearContent,delay:r.delay,pressEnter:r.pressEnter}),options:{disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl,disableGlobalLocatorRedirect:!0,source:Rr(r)}});g.push(w),h=b}else await this.browser.type(r.value,{force:r.force,clearContent:r.clearContent,forceClearContent:r.forceClearContent,delay:r.delay,pressEnter:r.pressEnter},!0);let S={urlAfterCommand:this.browser.url(),succeedImmediately:!1,elementInteracted:h,newTargets:g};return Ms(u,S.urlAfterCommand)&&(S.succeedImmediately=!0,S.succeedImmediatelyReason="URL changed"),S}case"HOVER":{if(yn(r.target)){await this.browser.hoverUsingVisualCoordinates(r.target.pixels);break}let{newTarget:u,elementInteractedDisplayString:h}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:g=>this.browser.hover(g),options:{disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:h,newTargets:[u]}}case"FOCUS":{if(!Xn(r.target))throw new Error("Focus with x/y is not supported yet");let{elementInteractedDisplayString:u,newTarget:h}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:g=>this.browser.focus(g),options:{disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:u,newTargets:[h]}}case"BLUR":{if(r.target&&!Xn(r.target))throw new Error("Blur with x/y is not supported yet");if(!r.target||!r.target.elementDescriptor)return await this.browser.blur(null),{succeedImmediately:!1,urlAfterCommand:this.browser.url()};let{newTarget:u,elementInteractedDisplayString:h}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,target:r.target,command:r,cache:r.cache?.target,action:g=>this.browser.blur(g),options:{disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:h,newTargets:[u]}}case"PRESS":let d=this.browser.url();await this.browser.press(r.value,{repeat:r.repeat,convertMeta:r.convertMeta??!0,delayMs:r.delayMs});let p={urlAfterCommand:this.browser.url(),succeedImmediately:!1};return Ms(d,p.urlAfterCommand)&&(p.succeedImmediately=!0,p.succeedImmediatelyReason="URL changed"),p;case"REQUEST":{let u=new wk,h=yk(fetch,u),g;try{g=new URL(r.url).hostname}catch{}return{data:{...await il({command:r,baseUrl:this.browser.baseUrl,logger:this.logger,fetchImplementation:h}),cookies:Ss(u,g)},succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"GRAPHQL_REQUEST":return{data:await Qb({command:r,baseUrl:this.browser.baseUrl,logger:this.logger}),succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"VISUAL_DIFF":return cy({ctx:e,tracer:t,command:r,disableCache:i,browser:this.browser,logger:this.logger,storage:this.storage,screenshotStorage:this.visualDiffScreenshotStorage,targetingWrapper:u=>this.wrapElementTargetingCommand(u)});case"FILE_UPLOAD":{let u,h;if(r.fileSource.type==="URL"?(h=r.fileSource.url,u=await ib({uri:r.fileSource.url,logger:this.logger,orgId:this.orgId})):r.fileSource.type==="USER_FILE"&&(h=r.fileSource.name,u=await this.uploadedFileStorage?.getFileForUpload(r.fileSource.name,this.orgId)),!u)throw new R("UserConfigurationError",`Attempted to use non-existent file for upload step: ${h}`);await this.browser.setFileChooserHandler({...u,filename:r.filename});break}case"AUTH_SAVE":return{data:await this.browser.saveAuthState(),succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"AUTH_LOAD":{let u;if(!r.storageState.trim())u=void 0;else if(u=await jn({orgId:this.orgId,code:r.storageState,fragment:!1,context:o,logger:this.logger,localTools:this.localCodeEvalTools,signal:this.executeAbortController.signal,flagStore:this.flagStore}),typeof u!="object")throw new R("ActionFailureError",`Credentials must evaluate to an object (received ${typeof u} instead)`);let h;try{h=fs.optional().parse(u)}catch(g){throw new R("ActionFailureError",`Credentials provided do not follow the required format: ${g}`)}await this.browser.loadAuthState(h);break}case"ELEMENT_CHECK":{let u=(r.timeout??wn)*1e3,h=await sy({command:r,tracer:t,timeoutMs:u,targetingWrapper:g=>this.wrapElementTargetingCommand(g),fixtures:this.getControllerFixtures(e),disableCache:i});return{fail:!h.success,data:h.data,elementInteracted:h.elementInteractedDisplayString,newTargets:h.newTarget?[h.newTarget]:[],thoughts:h.err?.message??h.thoughts??`Element assertion ${h.success?"succeeded":"failed"}.`,succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"PAGE_CHECK":{let u=await Rn({action:async()=>al({assertion:r.assertion,browser:this.browser,logger:this.logger,timeout:r.timeout,signal:this.executeAbortController.signal,flagStore:this.flagStore}),frameConfig:r.iframeUrl?{type:"url",url:r.iframeUrl}:void 0,browser:this.browser,logger:this.logger});return{fail:!u.success,data:u.data,thoughts:u.success?"Page assertion passed.":u.err?.message??`Page assertion still failing after ${r.timeout} seconds.`,urlAfterCommand:this.browser.url(),succeedImmediately:!1}}case"REGISTER_REQUEST_LISTENER":{let u;try{u=new RegExp(r.pattern)}catch(f){throw new R("UserConfigurationError",`The provided regex expression was invalid: ${f}`)}let g=this.browser.registerRequestListener(u).then(async f=>{let S={status:f?.status(),headers:f.headers()};return(await f.headerValue("content-type"))?.includes("json")?S.json=await f.json():(await f.headerValue("content-type"))?.includes("text")&&(S.text=await f.text()),S}).catch(f=>{this.logger.error({err:f},"Failed to get request listener response")});return this.registeredListeners[r.key]=g,{succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"AWAIT_LISTENER":{let u=this.registeredListeners[r.key];if(!u)throw new R("ActionFailureError",`No listener registered with key: ${r.key}`);return{data:await D(u,{milliseconds:(r.timeout??10)*1e3,message:`Request listener timed out after ${r.timeout} seconds`}),succeedImmediately:!1,urlAfterCommand:this.browser.url()}}default:return(u=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(r)}return{succeedImmediately:!1,urlAfterCommand:this.browser.url()}}async getReverseMappedDescription({browserState:e,targetId:t,disableCache:r,screenshot:o}){return(await this.generator.getReverseMappedDescription({browserState:e,target:t,screenshot:o},{disableCache:r,abortSignal:this.executeAbortController.signal,loggerTags:ze(this.logger)})).phrase}async stopRecordMode(){this.recordAbortController?.abort(),await this.browser.clearAllCdpHighlights()}async startRecordMode({params:e,abortController:t,isClickToRecord:r}){this.recordAbortController=t;let o=new vl({signal:t.signal,...e});return await this.browser.startRecording(this.recordAbortController.signal,o,r),o}async runSectionAutohealing(e){return this.generator.getAutohealingProposal(e,{disableCache:!0,abortSignal:this.executeAbortController.signal,loggerTags:ze(this.logger)})}async runFailureRecovery(e){return this.generator.getFailureRecoveryProposal(e,{disableCache:!0,abortSignal:this.executeAbortController.signal,loggerTags:ze(this.logger)})}};var vk=4;async function ew({socket:n,logger:e,analytics:t,storage:r,uploadedFileStorage:o,visualDiffScreenshotStorage:i,serviceMocker:a,devicePixelRatio:s,generatorFactory:l,enricherFactory:c,browserbase:d,authorization:p,flagStoreFactory:m,settingsFactory:u}){let h=n.id,g=n.handshake.query.testId;if(!g)throw new Error("Socket connection request is missing testId");let f=await r.getOrgId({type:"e2e",testId:g});e=e.child({testId:g,orgId:f,sessionId:h});let S=await l(f,e),b=await c(f,e),w=await m(f),v=await u(f,e),{testMetadata:x,baseUrl:C,envName:A,browserConfig:N,environmentVariables:O,localCodeEvalTools:H}=await Qr({testId:g,orgId:f,logger:e,storage:r,authorization:p,flagStore:w,settings:v}),F=Q.getSession(h);if(F)return e.info("Associating connection with existing session (likely reconnect)"),await F.controller.browser.clearAllCdpHighlights(),{type:"e2e",sessionId:h,orgId:f,testId:g};let L=n.handshake.headers["x-forwarded-for"]?.split(",")[0];if(e.info({clientIp:L,event:"connect",args:n.handshake.query},"Websocket event (connect)"),L&&Q.getCurrentConnectionsByIp(L)>=vk)throw e.error({clientIp:L,sessions:Q.getCurrentSessionsByIp(),...n.handshake.query},"Socket connection browser creation rate limit triggered"),new Error("You have exceeded the maximum number of connections allowed. Momentic limits the number of simultaneously open tabs to uphold browser reliability. Please close duplicate tabs and try again later.");Q.reserveCapacityByIp(L);try{await Tk({socket:n,baseUrl:C,envName:A,testMetadata:x,orgId:f,sessionId:h,logger:e,analytics:t,environmentVariables:O,clientIp:L,devicePixelRatio:s,storage:r,uploadedFileStorage:o,visualDiffScreenshotStorage:i,serviceMocker:a,localCodeEvalTools:H,generator:S,enricher:b,browserbase:d,browserConfig:N,flagStore:w})}catch(B){throw e.warn({err:B},"Error setting up socket session, possibly due to client closing the connection"),Q.releaseCapacityByIp(L),B}return{type:"e2e",sessionId:h,testId:g,orgId:f}}async function Tk({socket:n,baseUrl:e,envName:t,devicePixelRatio:r,testMetadata:o,orgId:i,sessionId:a,logger:s,analytics:l,storage:c,uploadedFileStorage:d,visualDiffScreenshotStorage:p,serviceMocker:m,localCodeEvalTools:u,generator:h,environmentVariables:g,browserConfig:f,clientIp:S,enricher:b,flagStore:w}){let v={viewport:o.advanced?.viewport??Gt,locale:o.advanced?.locale??Eo,timezoneId:o.advanced?.timezone??Co,colorScheme:o.advanced?.colorScheme};r&&(v.deviceScaleFactor=r);let x=o.id,C=await m?.initializeServicesForTest(i,x),A=await ul({settings:f,orgId:i,baseUrl:e,envName:t,localTools:u,envVariables:g,logger:s,customHeaders:void 0,flagStore:w});s=s.child({orgId:i,sessionId:a,testId:x});let N=!1,O=w.isBooleanFlagEnabled("icon_knowledge_base")?await c.fetchIconKnowledgeBase(i,s):null,H=await On.init({baseUrl:e,userBrowserSettings:A,enricher:b,storage:c,flagStore:w,mockedServices:C,logger:s,contextArgs:v,iconKnowledgeBase:O,callbacks:{onTabsChange:(K,U)=>{n.emit("tabs",{tabs:K,activeTab:U})},onScreencastFrame:(K,U)=>{let Y=n;N&&(Y=n.compress(!0)),Y.emit("screenshot",{buffer:K},()=>{U()})},onSvgsCollected:K=>{n.emit("newIconDetected",{numIcons:K.newSvgs.length}),c.saveNewIcons(i,K,s)}}});await H.navigate({url:e,initialNavigation:!0});let F=new ui({browser:H,generator:h,logger:s,analytics:l,flagStore:w,orgId:i,options:{scratchPadId:void 0,slowMoMs:A.slowMoMs,autoFollowNewTabs:A.autoFollowNewTabs},storage:c,localCodeEvalTools:u,uploadedFileStorage:d,visualDiffScreenshotStorage:p}),L=zS(n,a,s),B=async()=>{L.timers.forEach(K=>clearInterval(K))},P=new At({baseUrl:e,currentUrl:F.browser.url(),variablesFromEnvironment:g,envName:t});if(!n.connected)throw await H.cleanup(),new Error("Socket not connected anymore, not proceeding with session setup");n.emit("session",{url:e,userAgent:On.USER_AGENT,viewport:F.browser.getViewport(),sessionId:a}),Q.registerSession({controller:F,context:P,sessionId:a,cleanup:B,clientIp:S})}async function Qr({testId:n,orgId:e,logger:t,storage:r,authorization:o,flagStore:i,settings:a}){let s=await r.fetchTestMetadata(n,e,t);if(!s)throw new Error(`Test metadata could not found for test ${n}`);let l;o?.type==="API_KEY"&&(l=new dr({httpClient:new kt({...o,logger:t}),fakerSeed:void 0}));let c=s.envs?.find(g=>g.default),d;c&&(d=await r.fetchEnvironment(e,c.name,t));let p=d&&"browser"in d?d.browser:void 0,m={...a.browser,...p,...s.advanced},u=s.baseUrl||d?.variables?.[Ge];if(!u)throw new Error("Base URL is empty in both test options and the configured environment");let h={...d?.variables};return await Promise.all((s.parameters??[]).map(async g=>{let f=await Bt({orgId:e,s:g.defaultValue,context:At.dummyContext(d?.name,h),logger:t,flagStore:i,localTools:l});h[g.name]=f})),{localCodeEvalTools:l,baseUrl:u,envName:d?.name,browserConfig:m,environmentVariables:h,testMetadata:s}}var Lp=class{parentTracer=null;socket;step;constructor({step:e,socket:t,parentTracer:r}){this.socket=t,this.parentTracer=r,this.step=e}getParentStepIdChain(){return this.parentTracer?this.parentTracer?.getParentStepIdChain()??[]:[]}attachBeforeScreenshot(){}attachAfterScreenshot(){}attachBeforeHtmlSnapshot(){}attachAfterHtmlSnapshot(){}heal(){}async finish(e){switch(e.step.status){case"SUCCESS":this.socket.emit("success",{...e,parentStepIdChain:this.getParentStepIdChain()});return;case"FAILED":this.socket.emit("failure",{...e,parentStepIdChain:this.getParentStepIdChain()});return;case"CANCELLED":this.socket.emit("cancelled",{...e,parentStepIdChain:this.getParentStepIdChain()});return}}async startSubSteps(){return new Rl({parentStep:this.step,socket:this.socket,parentTracer:this})}},Rl=class{parentTracer;parentStep;socket;constructor({parentStep:e,socket:t,parentTracer:r}){this.parentTracer=r,this.parentStep=e,this.socket=t}getParentStepIdChain(){return this.parentStep?[...this.parentTracer?.getParentStepIdChain()??[],this.parentStep.id]:[]}async startStep(e){return this.socket.emit("started",{stepId:e.step.id,parentStepIdChain:this.getParentStepIdChain()}),new Lp({step:e.step,parentTracer:this,socket:this.socket})}},Al=class{constructor(e,t,r,o,i){this.socket=e;this.storage=t;this.orgId=r;this.testId=o;this.stepsBeforeRun=i}trackStatus(){}attachConsoleLogs(){}attachNetworkLogs(){}async finish(){this.socket.emit("finished")}async startStepList(){return new Rl({parentStep:null,parentTracer:null,socket:this.socket})}};var Op={currentlyExecutingRequests:{}},Ek=n=>async(e,t)=>{let{testId:r,orgId:o}=n.metadata,i=await n.flagStoreFactory(o),a=await n.settingsFactory(o,n.logger),s,l=await Qr({testId:r,orgId:o,logger:n.logger,storage:n.storage,authorization:n.authorization,flagStore:i,settings:a}),c=`${r}|${l.baseUrl}`;try{let d=Op.currentlyExecutingRequests[c]??0;Op.currentlyExecutingRequests[c]=d+1,s=await Ck({...n,...e,...l,done:t})}finally{n.logger.info({result:s,sessionId:n.metadata.sessionId},"Test execution complete"),Op.currentlyExecutingRequests[c]--}},Ck=async({socket:n,steps:e,baseUrl:t,testMetadata:r,reInitialize:o,toStep:i,fromStep:a,storage:s,metadata:l,logger:c,analytics:d,envName:p,environmentVariables:m,localCodeEvalTools:u,done:h,cacheStorageFactory:g})=>{let{testId:f,sessionId:S,orgId:b}=l,w=S,v=Q.getSession(S);if(!v)throw new Error("No active session found");let{controller:x,context:C}=v;x.setOpen(),c=c.child({testId:f,orgId:b,sessionId:S,runId:w}),c.info({steps:e.map(Z=>`${Z.type}${"command"in Z?` - ${Z.command.type}`:""}`),toStep:i,fromStep:a,reInitialize:o,envName:p,baseUrl:t,context:C,flags:x.flagStore.getAllFlags()},"Socket execution parameters");let A=m??{},N=async()=>{o&&(await x.browser.reset({newUrl:t}),C.reset({baseUrl:t,currentUrl:x.browser.url(),variablesFromEnvironment:A,envName:p}))},O=await g(b),H=async()=>{try{await O.resolveStepCacheEntries({schemaVersion:r.schemaVersion,organizationId:b,testId:f,steps:e,logger:c})}catch(Z){c.error({err:Z},"Failed to fetch step cache entries from Momentic server. This can drastically reduce test reliability and performance.")}};try{await ta({promiseGenerator:async()=>Promise.all([N(),H()]),signal:x.executeAbortController.signal,codePath:"resolveStepCacheAndInitBrowser"}),x.setOpen()}catch(Z){if(n.emit("finished"),Z.name!=="AbortError")throw new Error(`Failed to setup browser for execution: ${Z}`)}let F=xk(e),L={collectDebugData:!1,reinitializeBrowser:!1,disableHealing:!0},B={orgId:b,runId:w,testMetadata:r,steps:e,fromStep:a,toStep:i},P={controller:x,context:C,storage:s,debugDataStorage:new Or,codeEvalTools:u,billingReporter:new Lo,logger:c,analytics:d},K={test:{},step:{onDynamicAIActionStatusUpdateEvent:Z=>{n.emit("dynamicCommandStatusUpdate",Z)},onDynamicAIActionEvaluatingEvent:Z=>{n.emit("dynamicCommandEvaluating",Z)},onDynamicCommandGenerated:Z=>{n.emit("dynamicCommandGenerated",Z)},onDynamicCommandExecuted:Z=>{n.emit("dynamicCommandExecuted",Z)}}},U=new Al(n,s,b,f,F),Y=await pl({fixtures:P,options:L,callbacks:K,inputs:B,testParams:{tracer:U}});return Y?.status==="PASSED"&&await Cs({logger:c,cacheStorage:O,orgId:b,testId:f,originalSteps:{steps:F},updatedSteps:{steps:e}}),await U.finish(),h?.(Y),Y.status};var tw={event:"execute",createHandler:Ek};import{cloneDeep as Rk}from"lodash-es";var Ak=n=>async({command:e},t)=>{let{logger:r,generatorFactory:o,metadata:i}=n,a=Rk(e),s=Wg(a);if(s.category!=="NO_DESCRIPTION_PROVIDED"){if(s.category!=="NONE"){t?.({result:s});return}"cache"in a&&(a.cache=void 0,a.id=void 0);try{let c=await(await o(i.orgId,r)).getLintStepResult({command:a},{logger:r});t?.({result:c})}catch(l){r.error({event:"lint",err:l},"Failed to lint step"),t?.({result:void 0})}}},nw={event:"lintStep",createHandler:Ak};var Ik=({metadata:n,logger:e,storage:t})=>{let{sessionId:r}=n;return async(o,i)=>{let{description:a,command:s,testMetadata:l,returnScreenshot:c}=o;e.info({params:o},`Locate handler called - ${a}`);let d=Q.getSession(r);if(!d)throw new Error("No active session found");let{controller:p,context:m}=d;p.setOpen();let u=Ro.parse(l.advanced??{}),h={},g;if(a){if("useSelector"in s&&s.useSelector)try{let f=await p.locateElementWithSelector(a,"iframeUrl"in s?s.iframeUrl:void 0);g=f.resolution.locator,h={target:f.target,thoughts:f.thoughts}}catch(f){e.warn({err:f},"Failed resolving target with selector"),i({err:`Failed locating element: ${f.message}`,decisions:f instanceof nr?f.decisions:void 0});return}else try{let f=await p.locateElement({description:a,disableCache:u.disableAICaching??!1,iframeUrl:"iframeUrl"in s?s.iframeUrl:void 0,skipWait:!0,testContext:m,source:Rr(s)});h={target:f.target,thoughts:f.thoughts},g=f.resolution.locator}catch(f){(async()=>{try{let S=await p.browser.getCondensedHtml({skipWait:!0});e.warn({err:f,html:S.slice(0,1e5)},"Failed locating element with AI")}catch(S){e.warn({err:S},"Failed grabbing HTML after trying to locate element with AI")}})(),i({err:`Failed locating element with AI: ${f.message}`});return}if(s.type==="SELECT_OPTION"&&g)try{h.options=await p.browser.getSelectOptions(g)}catch(f){e.warn({err:f},"Failed getting select options"),i({err:`Failed getting select options: ${f.message}`});return}e.info({result:h},"Locate handler result")}if(c)try{let{buffer:f,width:S,height:b}=await p.screenshotWithDimensions({clearHighlights:!0,locator:g}),w=await t.uploadScreenshot(f);h.screenshot={data:w,width:S,height:b},e.info({width:S,height:b},"Captured screenshot during locate")}catch(f){e.error({err:f},"Error capturing screenshot during locate"),i({err:`Error taking screenshot: ${f.message}`});return}if(i({result:h}),g)try{await Promise.all([p.browser.scrollIntoView(g),p.browser.highlight(g)])}catch(f){e.warn({err:f},"Error highlighting element, continuing...")}}},rw={event:"locate",createHandler:Ik};var Pk=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({event:r,percentX:o,percentY:i})=>{let a=Q.getSession(t);if(!a)throw new Error("No active session found");let s=a.controller.browser;if(s.closed||s.getActivePage().isClosed()){e.warn("Ignoring mouse move because the browser is closed");return}try{await s.clickMouseFromPositionPercentages(r,o,i)}catch(l){e.error({err:l},"Error performing click during cloud recording in control mode")}}},ow={event:"mouseClickEvent",createHandler:Pk};var Lk=({metadata:n,generatorFactory:e,logger:t,socket:r})=>{let{sessionId:o,orgId:i,testId:a}=n;return async({stepId:s,parentStepIdChain:l,attribute:c})=>{let d=Q.getSession(o);if(!d)throw new Error("No active session found");let{controller:p}=d,m=await e(i,t);p.setOpen(),d.browserBehavior.showOverlay=!0;let u=new AbortController;u.signal.addEventListener("abort",async()=>{try{d.browserBehavior.showOverlay=!1,await p.stopRecordMode()}catch(f){t.warn({err:f},"Failed to stop record mode in target click socket handler")}});let h=!1,g=(f,S)=>{S.type!=="PRESET_ACTION"||S.command.type!=="CLICK"||(r.emit("targetRecordingUpdate",{type:f,stepId:s,parentStepIdChain:l,command:S.command,attribute:c}),u.abort(),h=!0)};setTimeout(()=>{h||(u.abort(),r.emit("targetRecordingUpdate",{type:"error",err:"Timed out waiting for click event",stepId:s,parentStepIdChain:l,attribute:c}))},1e4),await p.startRecordMode({params:{generator:m,logger:t,testId:a,orgId:i,callbacks:{onActionReceived:f=>g("clickReceived",f),onStepRecorded:f=>g("descriptionGenerated",f)}},abortController:u,isClickToRecord:!0}),r.emit("targetRecordingUpdate",{type:"listenersInitialized",stepId:s,parentStepIdChain:l,attribute:c})}},iw={event:"recordTargetClick",createHandler:Lk};var Ok=["Dead","Meta","AudioVolumeUp","AudioVolumeDown"],kk=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({key:r})=>{let o=Q.getSession(t);if(!o)throw new Error("No active session found");if(Ok.includes(r))return;let{controller:i}=o;if(i.browser.closed||i.browser.getActivePage().isClosed()){e.debug({sessionId:t},"Browser is closed, ignoring keyboard press socket event");return}try{i.setOpen(),r.length>1?await i.browser.press(r,{}):await i.browser.type(r,{clearContent:!1})}catch(a){if(a.message.includes("has been closed")){e.debug({sessionId:t,err:a},"Browser is closed, ignoring keyboard press socket event error");return}throw a}}},aw={event:"keyboardPressEvent",createHandler:kk};var Mk=({metadata:n,logger:e})=>{let{sessionId:t}=n,r,o=0,i=(l,c)=>{let d=async()=>{r=void 0};clearTimeout(r),r=setTimeout(d,Math.min(1e3,250*(o+1)))},a,s=0;return async l=>{let c=Q.getSession(t);if(!c)throw new Error("No active session found");let{controller:d,browserBehavior:p}=c,m=d.browser;if(m.closed||m.getActivePage().isClosed()){e.warn("Ignoring mouse move because the page is closed");return}if(l.event==="scroll"){let u=await m.scrollFromPositionPercentages(l.percentX,l.percentY,a?.x??0,a?.y??0),h=c.browserBehavior.recordingState?.transformer;h&&u&&h.recordScroll(u);return}p.showOverlay&&i(m,l);try{let u=await m.moveMouseFromPositionPercentages(l.percentX,l.percentY);s=0,a=u}catch(u){s++,s%5===0&&e.warn({err:u,mouseErrors:s},"Error in socket mouse move handler")}}},sw={event:"mouseMoveEvent",createHandler:Mk};var Nk=({metadata:n,generatorFactory:e,socket:t,logger:r})=>{let{sessionId:o,orgId:i,testId:a}=n;return async({stepId:s})=>{let l=Q.getSession(o);if(!l)throw new Error("No active session found");let{controller:c,browserBehavior:d}=l,p=await e(i,r);r.info("Starting cloud recording");let m=new AbortController,u=await c.startRecordMode({params:{generator:p,logger:r,testId:a,orgId:i,callbacks:{onActionReceived:(h,g)=>{t.emit("stepRecorded",{stepId:s,step:h,offset:g})},onStepRecorded:(h,g)=>{t.emit("stepRecorded",{stepId:s,step:h,offset:g})}}},abortController:m,isClickToRecord:!1});d.recordingState={transformer:u}}},lw={event:"recordingStart",createHandler:Nk};var _k=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async()=>{let r=Q.getSession(t);if(!r)throw new Error("No active session found");e.info("Stopping cloud recording"),await r.controller.stopRecordMode(),r.browserBehavior.recordingState=void 0,r.browserBehavior.showOverlay=!1}},cw={event:"recordingStop",createHandler:_k};var Dk=({socket:n,metadata:e,logger:t,storage:r,authorization:o,flagStoreFactory:i,settingsFactory:a})=>async(s,l)=>{let{testId:c,sessionId:d,orgId:p}=e;t.info({testId:c,sessionId:d},"Refresh event received");let m=await i(p),u=await a(p,t),{baseUrl:h}=await Qr({testId:c,orgId:p,logger:t,storage:r,authorization:o,flagStore:m,settings:u}),g=Q.getSession(d);if(!g){n.emit("error",{message:"No session to refresh"});return}let{controller:f}=g;f.setOpen(),await f.browser.refresh();let S=f.browser.getViewport();t.info({baseUrl:h,viewport:S},`Session refreshed for test ${c} at ${h}`),l()},dw={event:"refresh",createHandler:Dk};var Fk=({socket:n,metadata:e,logger:t,storage:r,authorization:o,flagStoreFactory:i,settingsFactory:a})=>async()=>{let{testId:s,sessionId:l,orgId:c}=e;t.info({testId:s,sessionId:l},"Reset event received");let d=await i(c),p=await a(c,t),{baseUrl:m,envName:u,environmentVariables:h}=await Qr({testId:s,orgId:c,logger:t,storage:r,authorization:o,flagStore:d,settings:p}),g=Q.getSession(l);if(!g){n.emit("error",{message:"No session to reset"});return}let{controller:f,context:S}=g;await f.browser.reset({newUrl:m});let b=f.browser.baseUrl;S.reset({baseUrl:b,currentUrl:f.browser.url(),variablesFromEnvironment:h,envName:u});let w=f.browser.getViewport(),v=On.USER_AGENT;t.info({baseUrl:m,viewport:w},`Session reset for test ${s} at ${b}`),n.emit("session",{url:b,userAgent:v,viewport:w,sessionId:l})},pw={event:"reset",createHandler:Fk};var Uk=({metadata:n})=>{let{sessionId:e}=n;return async({url:t})=>{let r=Q.getSession(e);if(!r)throw new Error("No active session found");await r.controller.browser.switchToPage({type:"SUBSTRING",substring:t})}},uw={event:"switchTab",createHandler:Uk};async function mw(n){let{socket:e}=n;return e.handshake.query.type==="api-test"?ZS(n):ew(n)}var hw=[ry,tw,rw,pw,dw,ey,uw,nw,iw,lw,cw,sw,ow,aw,QS,HS,ny,ty];var gw=n=>{let{logger:e}=n,t=new Bk(n.baseServer,{cors:{origin:"*",methods:["GET","POST"]},pingTimeout:15*60*1e3,pingInterval:15*60*1e3,maxHttpBufferSize:1e7,perMessageDeflate:!0});return t.on("connection",async r=>{let o;try{e.info({event:"connection",transport:r.conn.transport.name},"Websocket connection established"),o=await mw({...n,socket:r,logger:e}),e=e.child(o)}catch(i){e.error({event:"connection",type:"websocket",err:i},"Failed to setup connection"),r.emit("error",{message:i instanceof Error?i.message:`${i}`}),r.disconnect(!0);return}hw.forEach(i=>zk(i,{socket:r,metadata:o,...n,logger:e}))}),t},zk=(n,e)=>{let t=n.createHandler(e),r=(...o)=>{["mouseMoveEvent","keyboardPressEvent","mouseClickEvent","lintStep"].includes(n.event)||e.logger.debug({...e.metadata,event:n.event,args:o},`Websocket event (${n.event})`);let i=a=>{e.logger.error({event:n.event,type:"websocket",args:o,err:a instanceof Error?a:new Error(`${a}`)},"Unhandled exception in socket handler"),e.socket.emit("error",{message:a instanceof Error?a.message:`${a}`})};try{let a=t.apply(void 0,o);a&&typeof a.catch=="function"&&a.catch(i)}catch(a){i(a)}};e.socket.on(n.event,r)};import{Router as Kk}from"express";import _p from"fs";import Wk from"path";import Sw,{multistream as Hk}from"pino";import jk from"pino-pretty";var fw=["lastScreenshotBuffer"];var kp=new Map,$k=!0,Mp=class n{consoleLogger;ddClientToken;hostname;bindingAttributes;disableConsoleLogs;site="https://http-intake.logs.us5.datadoghq.com/api/v2/logs";constructor({bindings:e,clientToken:t,hostname:r,disableConsoleLogs:o}){this.ddClientToken=t,this.hostname=r,this.disableConsoleLogs=o,this.bindingAttributes={...e,env:"production"};let i={base:this.bindingAttributes,errorKey:"err",level:"debug"};this.consoleLogger=$k?Sw(i):Sw(i,Hk([{stream:jk({colorize:!0})}]))}child(e){return new n({clientToken:this.ddClientToken,bindings:{...this.bindingAttributes,...e},hostname:this.hostname,disableConsoleLogs:this.disableConsoleLogs})}flush(e){this.disableConsoleLogs||this.consoleLogger.flush(e)}log(e,t,r,...o){if(t&&r===void 0&&(r=`${t}`,t={}),this.disableConsoleLogs||this.consoleLogger[e](e==="error"?t:{testId:t.testId,runId:t.runId},r,...o),typeof t=="object"&&t&&"err"in t&&t.err instanceof Error){let a={};for(let s of Object.getOwnPropertyNames(t.err))fw.includes(s)||(a[s]=t.err[s]);a.name=t.err.name,t.err=a}let i=Object.assign({},this.bindingAttributes,t&&typeof t=="object"?t:{});o.length>0&&(i.args=o),(async()=>{try{let a=await fetch(this.site,{method:"POST",headers:{Accept:"application/json","Content-Type":"application/json","DD-API-KEY":this.ddClientToken},body:JSON.stringify([{ddsource:this.bindingAttributes.app,ddtags:["env:production"],hostname:this.hostname??"vercel",service:"momentic",message:{message:r||"",...i,level:e}}])});if(!a.ok)throw new Error(`Failed to log to Datadog: ${a.statusText})}`)}catch(a){this.disableConsoleLogs||this.consoleLogger.warn({obj:t,msg:r,args:o,err:a},"Failed to log to Datadog")}})()}debug(e,t,...r){this.log("debug",e,t,...r)}info(e,t,...r){this.log("info",e,t,...r)}warn(e,t,...r){this.log("warn",e,t,...r)}error(e,t,...r){this.log("error",e,t,...r)}bindings(){return this.bindingAttributes}addBinding(e,t){this.bindingAttributes[e]=t}setMinLevel(e){this.consoleLogger.level=e}enableConsoleLogs(){this.disableConsoleLogs=!1}},Il=({app:n,clientToken:e,hostname:t,disableConsoleLogs:r})=>{if(!process.env.DD_CLIENT_TOKEN&&!process.env.NEXT_PUBLIC_DD_CLIENT_TOKEN&&!e)throw new Error("Missing DD_CLIENT_TOKEN");return kp.has(n)||kp.set(n,new Mp({bindings:{app:n},hostname:t,clientToken:e||process.env.NEXT_PUBLIC_DD_CLIENT_TOKEN||process.env.DD_CLIENT_TOKEN,disableConsoleLogs:r})),kp.get(n)};import{hostname as Gk}from"os";var $e=Il({app:"desktop-server",clientToken:"pubcfd7516a5c0ba852b42675cd97bee027",hostname:Gk(),disableConsoleLogs:!0}),yw=n=>{$e.addBinding("version",n)};var Vk=new yl(30,60*1e3),Up="https://api.momentic.ai",Bp,Np,bw=n=>{Up=n},Pl=()=>Up,ww=(n,e)=>{Bp=n,Np?.abort(),Np=new AbortController;let t=Np.signal,r=[n.configFilePath];n.config.environments?.forEach(o=>{if(!o.envFile)return;let i=Wk.resolve(n.rootDir,o.envFile);try{if(_p.lstatSync(i).isSymbolicLink())return;_p.existsSync(i)&&r.push(i)}catch(a){$e.warn({err:a},`Failed to check if env file ${i} exists`)}});try{qk({filesToWatch:r,revalidator:e,signal:t,project:n})}catch(o){$e.error({err:o},"Failed to start config file watchers")}},me=()=>Bp,mi,Dp,Fp,vw=async n=>{if(mi)return mi;let e=new lt({baseUrl:Up,apiKey:n,logger:$e});try{let t=await e.getAuthInfo();return mi=t.orgId,Dp=t.userId,Fp=n,mi}catch(t){throw new Error(`Error checking API key against server: ${t}`)}},Sr=()=>{if(!mi)throw new Error("Your organization ID is invalid.");return mi},Ll=()=>{if(!Dp)throw new Error("Your user ID is invalid.");return Dp},Tw=()=>{if(!Fp)throw new Error("Your API key is invalid.");return Fp};function qk({filesToWatch:n,revalidator:e,signal:t,project:r}){n.forEach(o=>{_p.watch(o,{signal:t,persistent:!1,recursive:!1},(i,a)=>{a&&(Vk.increment("setLocalProject")&&y.warn(`A file change under the ${r.rootDir} directory has caused Momentic to reload its configuration more than 30 times in the last minute. Rapid changes to files may indicate your momentic.config.yaml 'include' glob is incorrect. Please ensure temporary, library, and auto-generated files are not included in Momentic's context.`),Bp=e(r.configFilePath))})})}function Ce(n){return function(...e){let t=e[e.length-1],r=n(...e);Promise.resolve(r).catch(t)}}var xw=Kk();xw.get("/",Ce((n,e)=>{let t=kf(me(),$e);e.status(200).json(t)}));var Ew=xw;import{Router as Yk}from"express";var Ol=class extends ei{constructor(t,r){super(t,r);this.client=t;this.orgId=r}async getOrgId(t){return this.orgId}async fetchTestMetadata(t,r,o){let i=me(),s=Oe(i,o).tests[t];if(s)return _s(s.relativePath,i)}async fetchApiTestMetadata(t,r,o){throw new Error("API tests are not available in the desktop app")}async fetchEnvironment(t,r,o){let i=me();return oa(r,i,kr)}async fetchIconKnowledgeBase(t,r){try{return await this.client.fetchIconKnowledgeBase(t,r)}catch(o){return r.error({err:o},"Failed to fetch icon knowledge base"),null}}async fetchCloudOrgSettings(t,r){}};var Cw=Yk();Cw.get("/",Ce((n,e)=>{e.status(200).json({userId:Ll(),orgId:Sr()})}));var Rw=Cw;import{Router as Jk}from"express";var Aw=Jk();Aw.get("/",Ce((n,e)=>{let t=me(),r=Oe(t,y),o=new Set;r?.tests&&Object.values(r.tests).forEach(a=>{a.labels?.forEach(s=>o.add(s))});let i=Array.from(o).sort();e.status(200).json(i)}));var Iw=Aw;import{Router as Xk}from"express";import Pw from"fs";import Zk from"path";var Aa=Xk();Aa.get("/",Ce(async(n,e)=>{let t=me(),r=Oe(t,y),i=(await Ns(r,$e)).map(a=>{let s=r.modules[a.moduleId];if(!s){y.warn(`Found a dangling module with ID ${a.moduleId} that could not be found on disk.`);return}return{...s,content:a}}).filter(a=>a!==void 0);e.status(200).json(i)}));Aa.post("/",Ce(async(n,e)=>{let t;try{t=Ah.parse(n.body)}catch(s){e.status(400).json({error:`Invalid request body: ${s}`});return}try{Po(t.name)}catch(s){e.status(400).json({error:`Invalid module name: ${s}`});return}let r=me(),o=Oe(r,y).modules;if(Object.values(o).find(s=>s.name===t.name)){e.status(400).send(`A module with the name "${t.name}" already exists. Please choose a different name.`);return}let i=Zk.join(r.rootDir,t.folderPath??"");if(!Pw.existsSync(i)||!Pw.statSync(i).isDirectory()){e.status(400).json({error:`The folder configured for module creation '${i}' does not exist.`});return}let a=await Af({...t,folder:i,project:r});e.status(201).json(a)}));Aa.get("/:moduleId",Ce(async(n,e)=>{if(!n.params.moduleId){e.status(400).json({error:"Missing moduleId in url path."});return}let t=Oe(me(),y),r=t.modules[n.params.moduleId];if(!r){e.status(404).json({error:"Module not found."});return}try{let o=await cd(r,t,y);e.json(o)}catch(o){e.status(400).json({err:o})}}));Aa.patch("/:moduleId/metadata",Ce(async(n,e)=>{if(!n.params.moduleId){e.status(400).json({error:"Missing moduleId in url path."});return}let t;try{t=Ih.parse(n.body)}catch(i){e.status(400).json({error:`Invalid request body: ${i}`});return}let r=me(),o=Oe(r,y);Rf({moduleId:n.params.moduleId,content:t,momenticFiles:o,logger:y,project:r}),e.status(201).json({message:"ok"})}));var Lw=Aa;import{Router as Qk}from"express";var kl=Qk();kl.get("/",Ce((n,e)=>{let t=Fd().map(r=>({name:r.config.name,configFilePath:r.configFilePath}));e.status(200).json(t)}));kl.get("/current",Ce((n,e)=>{let t=me(),r={name:t.config.name,configFilePath:t.configFilePath};e.status(200).json(r)}));kl.post("/set",Ce((n,e)=>{let t;try{t=Lh.parse(n.body)}catch(r){e.status(400).json({error:`Invalid request body: ${r}`});return}try{let r=Qt({configFilePath:t.configFilePath});ww(r,o=>Qt({configFilePath:o}))}catch(r){e.status(400).json({error:`Error setting project: ${r}`});return}e.sendStatus(204)}));var Ow=kl;import{Router as eM}from"express";var kw=eM();kw.get("/",Ce((n,e)=>{let r={ai:me().config.ai};e.status(200).json(r)}));var Mw=kw;import{Router as rM}from"express";import Nw from"fs";import eo from"path";import{v4 as _w}from"uuid";import oM from"yaml";import{randomUUID as tM}from"node:crypto";import{PostHog as nM}from"posthog-node";var hi=class{identify(){return this}child(){return this}track(){return this}async shutdown(){}},gi=class n{bindings;client;options;constructor(e,t={}){this.bindings=e,this.options=t,this.client=new nM("phc_oy1FexHsc0S3axxOMXCm46yZsW35zROAoV4SOzpDSXH",{host:"https://us.i.posthog.com",...t})}async shutdown(){await this.client.shutdown()}identify(e){return this.bindings={...this.bindings,...e},this}child(e){return new n({...this.bindings,...e},this.options)}track(e,t){if(!th(this.bindings))return console.error(`Cannot track ${e.type} event without required bindings.`,this.bindings),this;let{type:r,...o}=e;return this.client.capture({distinctId:tM(),event:r,timestamp:t?.timestamp,properties:{...this.bindings,...o}}),this}};var fi=new gi({platform:"local_app"},{flushAt:1,flushInterval:0});var yr=rM();function Dw(n){let e=Oe(n,y);return Object.values(e.tests)}yr.get("/",Ce((n,e)=>{let t=Dw(me());e.status(200).json(t)}));yr.post("/",Ce(async(n,e)=>{let t;try{t=Ch.parse(n.body)}catch(d){e.status(400).json({error:`Invalid request body: ${d}`});return}try{Po(t.name)}catch(d){e.status(400).json({error:d.message});return}let o={id:_w(),name:t.name,description:t.description,baseUrl:t.baseUrl,schemaVersion:Fe,advanced:{disableAICaching:!1,browserType:t.browserType??"Chromium",viewport:t.viewport??Gt},retries:0,steps:[]};t.environment&&(o.envs=[{name:t.environment,default:!0}]);let i=me();if(Dw(i).find(d=>d.name===t.name)){e.status(400).send(`A test with the name "${t.name}" already exists. Please use a different name.`);return}let s=eo.join(i.rootDir,t.folderPath??""),l=await Pf({test:o,name:t.name,folder:s}),c={...o,relativeFilePath:eo.relative(i.rootDir,l)};fi.track({type:"test_editor:test_create"}),e.status(201).json(c)}));yr.get("/:testPath",Ce(async(n,e)=>{let{testPath:t}=n.params;if(!t){e.status(400).json({error:"Missing testPath in url path."});return}let r=me(),o=Oe(r,y),i;try{i=await ra(eo.join(r.rootDir,t),$e,o),e.status(200).json(i)}catch(a){e.status(400).send({error:a.message});return}(async()=>{try{let{stepsToSave:a,moduleUpdates:s}=await Yt({stepLists:{steps:i.steps,beforeSteps:i.beforeSteps,afterSteps:i.afterSteps}});s.forEach(l=>{jr({content:l,schemaVersion:Fe,momenticFiles:o,project:r})}),Bn({relativeTestPath:t,steps:a,schemaVersion:Fe,project:r})}catch(a){$e.error({err:a},"Failed to save migrated test to disk after initial fetch")}})()}));yr.patch("/:testPath/metadata",Ce(async(n,e)=>{if(!n.params.testPath){e.status(400).json({error:"Missing testPath in url path."});return}let t;try{t=Eh.parse(n.body)}catch(i){e.status(400).json({error:`Invalid request body: ${i}`});return}let o={message:"ok",newRelativeTestPath:dd(n.params.testPath,t,me()).newRelativeTestPath};e.status(200).json(o)}));yr.patch("/:testPath",Ce(async(n,e)=>{let{testPath:t}=n.params;if(!t){e.status(400).json({error:"Missing testPath in url path."});return}let r;try{r=xh.parse(n.body)}catch(u){e.status(400).json({error:`Invalid request body: ${u}`});return}let o=me(),i=Oe(o,y),a;try{a=_s(t,o)}catch(u){e.status(400).json({error:`Existing test file on disk is invalid: ${u}`});return}let{stepsToSave:s,moduleUpdates:l,cachesToSave:c}=await Yt({stepLists:r.stepLists,cacheCreationParams:{testId:a.id,orgId:Sr()}}),d=new lt({apiKey:Tw(),baseUrl:Pl(),logger:$e}),p=await Zo($e,d,o);await oi({client:d,gitMetadata:p}).saveStepCacheEntries(c,a.id,$e),l.forEach(u=>{jr({content:u,schemaVersion:r.schemaVersion,momenticFiles:i,project:o})}),Bn({relativeTestPath:t,steps:s,schemaVersion:r.schemaVersion,project:o}),e.status(201).json({message:"ok"})}));yr.patch("/:testPath/environments",Ce(async(n,e)=>{let{testPath:t}=n.params;if(!t){e.status(400).json({error:"Missing testPath in url path."});return}let r;try{r=Ph.parse(n.body)}catch(o){e.status(400).json({error:`Invalid request body: ${o}`});return}dd(t,{envs:r.defaultEnv?[{name:r.defaultEnv,default:!0}]:[]},me()),e.status(201).json({message:"ok"})}));yr.post("/:testPath/duplicate",Ce(async(n,e)=>{let{testPath:t}=n.params;if(!t){e.status(400).json({error:"Missing testPath in url path."});return}let r;try{r=Rh.parse(n.body)}catch(f){e.status(400).json({error:`Invalid request body: ${f}`});return}try{Po(r.name)}catch(f){e.status(400).json({error:f.message});return}let o=me(),i=eo.join(o.rootDir,t);if(!Nw.existsSync(i)){e.status(404).json({error:"Test not found."});return}let a=Oe(o,y),s;try{s=await ra(i,$e,a)}catch(f){e.status(400).send({error:f.message});return}let l=_w(),c=Kt.parse({...s,name:r.name,id:l}),{stepsToSave:d}=await Yt({stepLists:{steps:s.steps,beforeSteps:s.beforeSteps,afterSteps:s.afterSteps},createNewCacheIds:!0,cacheCreationParams:{testId:l,orgId:Sr()}}),p=Fn({fileType:Ee.TEST,...c,beforeSteps:d.beforeSteps??void 0,steps:d.steps,afterSteps:d.afterSteps??void 0}),m=eo.dirname(i),u=eo.join(m,`${r.name}.${Ot.TEST}`),h=oM.stringify(p);Nw.writeFileSync(u,h,"utf-8");let g={relativeFilePath:eo.relative(o.rootDir,u)};fi.track({type:"test_editor:test_create"}),e.status(201).json(g)}));var Fw=yr;var Ia=class{async prepareGoldenScreenshotForComparison(e,t,r){return await new Jo(me(),!1).prepareGoldenScreenshotForComparison(e,t,r)}};async function Hw(n){let{momenticServerUrl:e,apiKey:t,serverPort:r,staticDir:o,devicePixelRatio:i,version:a,logger:s=$e,alwaysSaveCache:l,noCache:c}=n;yw(a),e&&bw(e),await vw(t);let d=Sr(),p=Ll();fi.identify({user_id:p,org_id:d}),s.debug({params:n,orgId:d,userId:p},"Desktop server init and api key check done");let m=dM(o,r,s),u=`http://localhost:${r}`;y.info(`Desktop server is running at ${u}`),await new Promise(x=>{try{m.listen(r,()=>{s.info(`Desktop server is running at ${u}`),x()})}catch(C){C.message.includes("EADDRINUSE")?jw(r):y.error(`An unexpected error occurred while starting the server: ${C.message}`),process.exit(1)}});let g={type:"API_KEY",baseUrl:Pl(),apiKey:t,logger:s},f=async()=>{let x=me();return new ni(x.config.ai?.agentConfig,g)},S=async()=>new ri(g,await f()),b=new lt(g),w=new Ol(b,Sr()),v=new Ia;gw({baseServer:m,generatorFactory:f,enricherFactory:S,cacheStorageFactory:async()=>{let x=me(),C=await Zo(s,b,x);return oi({client:b,gitMetadata:C,alwaysSaveCache:l,noCache:c})},flagStoreFactory:async x=>{let C=me();return new Xo(C.config)},settingsFactory:async()=>{let x=me();return{ai:{},browser:{},...x.config}},storage:w,logger:s,devicePixelRatio:i,authorization:g,visualDiffScreenshotStorage:v,analytics:fi})}var zw="25mb";function dM(n,e,t){let r=Bw();r.use(iM()),r.use(Uw.json({limit:zw})),r.use(Uw.urlencoded({extended:!1,limit:zw}));let o=lM();if(o.use("/tests",Fw),o.use("/modules",Lw),o.use("/environments",Ew),o.use("/projects",Ow),o.use("/labels",Iw),o.use("/settings",Mw),o.use("/identify",Rw),r.use("/api",o),r.use((a,s,l)=>{a.path!=="/healthcheck"&&!a.path.startsWith("/assets")&&t.debug({url:a.url,path:a.path,query:a.query,method:a.method,body:a.body,headers:a.rawHeaders,client:a.ip},"Received desktop-server request"),s.on("close",()=>{s.statusCode>=400&&t.error({url:a.url,method:a.method,statusCode:s.statusCode},"Request completed in error")}),l()}),r.use((a,s,l,c)=>{if(a instanceof Error&&a.message.includes("BadRequestError: request aborted")){l.status(400).send("Client disconnected");return}t.error({stack:a.stack,msg:a.message,err:a,url:s.url,method:s.method},"Unhandled exception leading to 500 on desktop-server"),y.error(`Oh no! We seem to have hit an unexpected snag \u{1F61E}. Please contact Momentic Support with the following error: ${a.message}
3612
+ ${n}`;default:return n}}var hk=15;async function Pp({command:n,fixtures:e}){if(!n.assertion.trim())throw new R("ActionFailureError","Assertion command is missing the assertion content");let{browser:t,logger:r}=e,o=n.timeout?n.timeout*1e3:t.smartWaitingTimeout,i=gk(o),a=0,s=Date.now(),l,c,d;try{await Rn({action:()=>t.clearHighlights(),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,browser:t,logger:r})}catch(m){r.warn({err:m},"Failed to clear highlights before AI assertion, continuing...")}let p;for(;a<hk&&(!p||p-s<o);){e.abortSignal.throwIfAborted(),a!==0&&(r.info(`Waiting ${i}ms before retrying AI assertion`),await te(i,e.abortSignal)),p=Date.now();try{let m=await Rn({action:async()=>{let u=await Xb(t,r,e.abortSignal);return c&&c.serializedTree===u.serializedTree&&c.screenshotBuff.equals(u.screenshotBuff)?!1:(c=u,Zb({command:n,state:u,fixtures:e,useConsensus:!1,highlightElementsOnFailure:!1,attemptNumber:a}))},frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,logger:r,browser:t});if(!m)continue;l=m;break}catch(m){e.abortSignal.throwIfAborted(),d=m instanceof Error?m:new Error(`${m}`),r.info({err:m},`AI check assert attempt ${a} failed, retrying...`)}finally{a++}}if(!l)try{l=await Rn({action:async()=>Zb({command:n,state:await Xb(t,r,e.abortSignal),fixtures:e,useConsensus:!0,highlightElementsOnFailure:!0,attemptNumber:a}),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,logger:r,browser:t})}catch(m){e.abortSignal.throwIfAborted(),d=m instanceof Error?m:new Error(`${m}`)}finally{a++}if(!l){let m=`AI assertion still failing after ${a} attempts.`;throw d&&(m+=` Latest result: ${d.message}`),new R("AssertionFailureError",m,{lastScreenshotBuffer:c?.screenshotBuff})}return l}async function Xb(n,e,t){let[r,o]=await Promise.all([fr(n,{abortSignal:t,skipWait:!0,skipWaitForPageLoad:!0,logger:e}),n.screenshot({retries:1,respectActiveFrame:!0})]);return{...r,screenshotBuff:o}}async function Zb({command:n,state:e,fixtures:t,useConsensus:r,highlightElementsOnFailure:o,attemptNumber:i}){let{browser:a,logger:s,generator:l,abortSignal:c}=t,d={type:"ASSERTION"},{serializedTree:p,tree:m}=e,u=e.screenshotBuff,h=a.url(),g=p;g=await Zr({type:"assertion",serializedTree:p,description:n.assertion,flagStore:t.flagStore,tree:m,generator:l,logger:s,signal:c}),g!==p&&(d.ragUsed=!0),d.pageState=g;let f={goal:n.assertion,url:h,browserState:g,screenshot:u.toString("base64"),contextChoice:n.contextChoice},b=await(n.contextChoice==="VISION_ONLY"?(w,v)=>l.getVisualAssertionResult(w,v):(w,v)=>l.getAssertionResult(w,v))(f,{useConsensus:r,attemptNumber:i,disableCache:!!n.disableCache,logger:s,abortSignal:c,loggerTags:ze(s)});if((b.result||o)&&b.relevantElements&&(d.relevantElementsSerialized=b.relevantElements.map(w=>a.getSerializedFormFromA11yId(w)).filter(w=>!!w),await fk(b.relevantElements,a,s)),!b.result)throw new R("AssertionFailureError",b.thoughts);return{succeedImmediately:!1,thoughts:b.thoughts,urlAfterCommand:h,afterScreenshotOverride:u}}function gk(n){let e;return n>10*60*1e3?e=2*60*1e3:n>60*1e3?e=20*1e3:n>10*1e3?e=2*1e3:e=1e3,e}async function fk(n,e,t){let r=Date.now();for(let o of n){if(Date.now()-r>2e3){t.debug("Highlighting relevant elements took over 2s, aborting...");return}try{let i=new AbortController;await D(e.highlightA11yId(o),{milliseconds:1e3,fallback:()=>{throw i.abort(),new Error("Timed out waiting for highlighting to complete")}})}catch(i){t.debug({err:i},"Failed to highlight relevant element after assertion, continuing...");return}}}var Sk=3e4;async function Qb({command:n,logger:e,baseUrl:t,fetchImplementation:r=fetch}){let o=n.timeout??Sk/1e3,i=new AbortController,a=Object.fromEntries(Object.entries(n.headers||{}).filter(([p,m])=>p&&m)),s;if(ko(n.url)&&(s=n.url),t&&Mo(n.url,t)&&(s=new URL(n.url,t).toString()),!s)throw new R("ActionFailureError",`Invalid URL: ${n.url}`);let c=await D((async()=>{try{return await r(s,{headers:a,method:"POST",body:JSON.stringify({query:n.query,variables:n.variables}),signal:i.signal})}catch(p){e.error({err:p},"Failed to make HTTP request")}})(),{milliseconds:o*1e3});if(!c)throw new R("ActionFailureError",`GraphQL request timed out after ${o} seconds`);if(!c.ok){let p;try{p=await c.json()}catch{throw new R("ActionFailureError",`GraphQL request failed with status ${c.status}: ${await c.text()}`)}throw p?.errors?.length&&p?.errors[0]?.message?new R("ActionFailureError",`GraphQL request failed with status ${c.status}: ${p.errors[0].message}`):new R("ActionFailureError",`GraphQL request failed with status ${c.status}: ${await c.text()}`)}let d={};return c.headers.forEach((p,m)=>{d[m]=p}),{status:c.status,headers:d,json:await c.json()}}var pi=class{flagStore;orgId;options;storage;localCodeEvalTools;uploadedFileStorage;visualDiffScreenshotStorage;browser;generator;executeAbortController=new AbortController;logger;analytics;recordAbortController=null;registeredListeners={};constructor({browser:e,generator:t,logger:r,analytics:o,flagStore:i,storage:a,orgId:s,localCodeEvalTools:l,uploadedFileStorage:c,visualDiffScreenshotStorage:d,options:p}){this.orgId=s,this.options=p,this.browser=e,this.browser.registerAbortSignal(this.executeAbortController.signal),this.storage=a,this.uploadedFileStorage=c,this.visualDiffScreenshotStorage=d,this.localCodeEvalTools=l,this.generator=t,this.logger=r,this.analytics=o,this.flagStore=i}setOpen(){this.executeAbortController=new AbortController,this.browser.registerAbortSignal(this.executeAbortController.signal)}setClosed(){this.executeAbortController.abort()}throwIfClosed(){this.executeAbortController.signal.throwIfAborted()}get closed(){return this.executeAbortController.signal.aborted}async evaluateAiAction({goal:e,startingScreenshot:t,history:r,disableCache:o,langfuseSessionId:i,lastError:a,logger:s=this.logger}){let[l,c]=await Promise.all([fr(this.browser,{abortSignal:this.executeAbortController.signal,skipWait:!0,skipWaitForPageLoad:!0,logger:s}),this.browser.screenshot({retries:1,clearHighlights:!0})]),d=await Zr({type:"ai-action",description:e,serializedTree:l.serializedTree,tree:l.tree,logger:s,generator:this.generator,flagStore:this.flagStore,softTokenLimit:25e3,hardTokenLimit:5e4}),p=`data:image/jpeg;base64,${c.toString("base64")}`,m={url:this.browser.url(),browserState:d,startingScreenshot:t,history:r,goal:e,screenshot:p,lastError:a};return await this.generator.getMultiturnAiActionEvaluation(m,{disableCache:o,abortSignal:this.executeAbortController.signal,loggerTags:{...ze(s)},langfuseSessionId:i})}async promptToCommand({goal:e,startingScreenshot:t,history:r,actionHint:o,disableCache:i,logger:a=this.logger,langfuseSessionId:s}){let l=this.browser.url(),[c,d]=await Promise.all([fr(this.browser,{abortSignal:this.executeAbortController.signal,skipWait:!0,skipWaitForPageLoad:!0,logger:a}),this.browser.screenshot({retries:1,clearHighlights:!0})]),p=`data:image/jpeg;base64,${d.toString("base64")}`,m=await Zr({type:"ai-action",description:e,serializedTree:c.serializedTree,tree:c.tree,logger:a,generator:this.generator,flagStore:this.flagStore,softTokenLimit:25e3,hardTokenLimit:5e4}),u={url:l,browserState:m,startingScreenshot:t,history:r,goal:e,actionHint:o,screenshot:p};try{return await this.generator.getMultiturnAiActionCommand(u,{disableCache:i,abortSignal:this.executeAbortController.signal,loggerTags:{...ze(a)},langfuseSessionId:s})}catch(h){throw new R("InternalWebAgentError",`Error generating command: ${h instanceof Error?h.message:h}`,{errOptions:{cause:h}})}}async getBrowserState(e){return fr(this.browser,e)}async locateElement(e){return Ip(e,this.getControllerFixtures())}async locateElementWithSelector(e,t){return Rn({action:async()=>{let r=await this.browser.resolveHardcodedCssSelector({ctx:null,selector:e,timeoutMs:2e3,logger:this.logger});return{thoughts:"Located element with selector",target:{id:-1,selector:e,targetSource:"USER_CSS_SELECTOR",targetUpdateTime:new Date().toUTCString()},resolution:r}},frameConfig:t?{type:"url",url:t}:void 0,browser:this.browser,logger:this.logger})}getControllerFixtures(e){return{ctx:e??null,browser:this.browser,generator:this.generator,logger:this.logger,orgId:this.orgId,flagStore:this.flagStore,storage:this.storage,localCodeEvalTools:this.localCodeEvalTools,abortSignal:this.executeAbortController.signal}}async wrapMultiElementTargetingCommand({ctx:e,tracer:t,command:r,targetNames:o,descriptions:i,caches:a,action:s,options:l,retriesWithAI:c=1}){let d=[];for(let p=0;p<i.length;p++){let m=i[p],u=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:m,cache:a[p],action:async h=>h,options:{...l,skipFetchTree:p!==0,targetName:o[p]}});d.push(u)}try{return{result:await s(...d.map(m=>m.result)),elementInteractedDisplayStrings:d.map(m=>m.elementInteractedDisplayString),newTargets:d.map(m=>m.newTarget)}}catch(p){if(this.throwIfClosed(),c>0)return this.logger.debug({err:p},"Failed to execute action with multiple cached targets, retrying with AI"),this.wrapMultiElementTargetingCommand({ctx:e,tracer:t,command:r,targetNames:o,descriptions:i,caches:i.map(()=>{}),action:s,options:l,retriesWithAI:c-1});throw new R("ActionFailureError",p.message,{errOptions:{cause:p}})}}async wrapElementTargetingCommand(e){let t=this.logger.child({commandId:e.command.id}),r;for(let o=0;o<2;o++)try{return await Rn({action:()=>this.wrapElementTargetingCommandHelper(e),frameConfig:e.options.iframeUrl?{type:"url",url:e.options.iframeUrl}:void 0,browser:this.browser,logger:t})}catch(i){if(r=i,this.flagStore.isBooleanFlagEnabled("visual_actions")&&Vc(i)){t.warn({err:i},"Invalid mpath error, retrying element targeting command");continue}if(!this.flagStore.isBooleanFlagEnabled("visual_actions")&&Ji(i)){t.warn({err:i},"Invalid momentic id error, retrying element targeting command");continue}throw i}throw r instanceof R?r:new R("ActionFailureError",r?.message??"An unknown error occurred during element targeting")}async wrapHardcodedCssTargetingCommandHelper({ctx:e,target:t,action:r,options:o,command:i}){let a=this.logger.child({commandId:i.id}),{targetName:s="target"}=o;if(t.type!=="description")throw new R("ActionFailureError","Cannot use selector with non-description target");let l=await this.browser.resolveHardcodedCssSelector({ctx:e,selector:t.elementDescriptor,targetName:s,logger:a});return{result:await r({locator:l.locator}),elementInteractedDisplayString:l.displayString,newTarget:{cache:{id:-1,selector:t.elementDescriptor,targetSource:"USER_CSS_SELECTOR",targetUpdateTime:new Date().toUTCString()}}}}async wrapElementTargetingCommandHelper(e){let{ctx:t,tracer:r,target:o,action:i,options:a,command:s}=e,{disableCache:l,useSelector:c,targetName:d="target",targetHealingInProgress:p,source:m}=a,u=this.logger.child({commandId:s.id}),h=a.retriesWithAI??1,g=!1,f=e.cache;if((!f||l)&&!Ql(o))throw new R("ActionFailureError","Cannot target element with no cached data or element descriptor");if(c)return this.wrapHardcodedCssTargetingCommandHelper(e);l&&(u.debug("Cache explicitly disabled for this step"),g=!0,f=void 0),f?.inputDescription&&!Jb(o.elementDescriptor,f.inputDescription)&&(u.warn({old:f.inputDescription,new:o.elementDescriptor},"Target cache was generated with a different description, clearing it automatically"),g=!0,f=void 0);let S=!!f&&Iu(f);if(!f){let b=new Date;u.debug({targetHealingInProgress:p,cacheBustedBeforeAction:g},"Prompting AI for an updated element location"),g&&await te(this.browser.smartWaitingTimeout,this.executeAbortController.signal),h--;let w=await Ip({description:o.elementDescriptor,disableCache:l,iframeUrl:a.iframeUrl,source:m},this.getControllerFixtures(t));w.frameConfig&&this.browser.setActiveFrameConfig(w.frameConfig);let v=a.disableGlobalLocatorRedirect?{locator:w.resolution.locator}:await this.attemptLocatorRedirect(w.resolution.locator,u),x=await i(v),C;if(p){r.heal({healType:"AI"}),this.analytics.track({type:"execution:step_heal",heal_type:"AI",step_type:"PRESET_ACTION",command_type:s.type,duration_ms:Date.now()-b.getTime()}),w.target.targetSource="AI_HEALED",w.target.targetUpdateTime=new Date().toUTCString(),w.target.targetUpdateLoggerTags=ze(u);let A=w.resolution.pageState;if(A)try{C=await this.getReverseMappedDescription({browserState:A,targetId:w.target.id,disableCache:!0,screenshot:w.screenshot})}catch(N){u.warn({err:N},"Failed to reverse map element auto-healed by AI, continuing...")}}return{result:x,elementInteractedDisplayString:w.resolution.displayString,newTarget:{cache:w.target,thoughts:w.thoughts,description:C}}}try{let b=new Date,w=await this.browser.resolveTarget(t,f,{targetName:d,logger:u});(this.flagStore.isBooleanFlagEnabled("global_locator_redirect")||this.flagStore.isBooleanFlagEnabled("visual_actions"))&&await w.locator.scrollIntoViewIfNeeded({timeout:2e3});let v=a.disableGlobalLocatorRedirect?{locator:w.locator}:await this.attemptLocatorRedirect(w.locator,u),x=await i(v);if(S){let C=w.decisions.filter(A=>A.matched);if(C.length!==1)u.warn({decisions:w.decisions},"Expected exactly 1 matching method for element location, got more or less");else{let A=C[0].type;r.heal({healType:A}),this.analytics.track({type:"execution:step_heal",heal_type:A,step_type:"PRESET_ACTION",command_type:s.type,duration_ms:Date.now()-b.getTime()})}}return{result:x,elementInteractedDisplayString:w.displayString,newTarget:{cache:f}}}catch(b){this.throwIfClosed();let w=yh(b)&&!Vc(b)&&!Ji(b);if(b instanceof R&&!w)throw b;if(h>0&&o)return u.debug({err:b,cache:f},"Failed to execute action with cached target, retrying with AI"),this.wrapElementTargetingCommand({ctx:t,tracer:r,command:s,target:o,cache:void 0,action:i,options:{...a,retriesWithAI:h,targetHealingInProgress:!0}});throw new R("ActionFailureError",b.message,{errOptions:{cause:b}})}}async attemptLocatorRedirect(e,t){return this.flagStore.isBooleanFlagEnabled("global_locator_redirect")?this.browser.performTargetRedirection(e,t):{locator:e}}async screenshotWithDimensions(e){return xa(this.browser,e)}async executePresetCommand(e,t,r,o,i){this.options?.slowMoMs&&await te(this.options.slowMoMs);let a=await this.browser.getOpenPages(),s=this.browser.url(),l;try{l=await this.resolveCommandTemplateStrings(r,o)}catch(c){throw this.throwIfClosed(),new R("ActionFailureError",`Failed to substitute template strings in command: ${c.message}`,{errOptions:{cause:c}})}try{let c=await this.executePresetCommandHelper(e,t,r,o,i);return this.flagStore.isBooleanFlagEnabled("visual_actions")&&Mu(r)?await this.browser.waitForDOMStability({timeout:2e3}):!this.flagStore.isBooleanFlagEnabled("visual_actions")&&["PRESS","TYPE"].includes(r.type)&&await this.browser.waitForDOMStability({timeout:1e3}),this.options?.autoFollowNewTabs&&await fy({beforeUrl:s,command:r,beforePages:a.map(d=>d.url),browser:this.browser,logger:this.logger}),c}catch(c){throw c.name!=="AbortError"&&this.logger.error({err:c},"Error thrown in action controller"),c}finally{this.restoreCommandTemplateReplacements(r,l)}}restoreCommandTemplateReplacements(e,t={}){for(let[r,o]of Object.entries(t))Tp(e,r,o)}createCallbacksForBrowser(e){return{createIsolatedFolder:()=>cp(e)}}async resolveCommandTemplateStrings(e,t){return ii({obj:e,context:t,bannedKeys:["type","a11yData","thoughts","cache","code"],orgId:this.orgId,logger:this.logger,signal:this.executeAbortController.signal,localTools:this.localCodeEvalTools,flagStore:this.flagStore})}async executePresetCommandHelper(e,t,r,o,i){switch(i=i||"disableCache"in r&&!!r.disableCache,r.type){case"SUCCESS":let a=r.condition;return a?.assertion.trim()?Pp({command:a,fixtures:this.getControllerFixtures(e)}):{succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"AI_ASSERTION":{if(!r.assertion.trim())throw new R("ActionFailureError","Missing assertion");if(r.timeout&&r.timeout>1800)throw new R("AssertionFailureError",`AI assertion timeout of ${r.timeout} exceeds the maximum allowed value of 30 minutes.`);return Pp({command:{...r,type:"AI_ASSERTION"},fixtures:this.getControllerFixtures(e)})}case"AI_EXTRACT":{if(!r.goal.trim())throw new R("ActionFailureError","Cannot perform AI extraction without goal");let u=await this.browser.getCondensedHtml(),h=await this.browser.screenshot({retries:2});try{let g=await this.generator.getTextExtraction({goal:r.goal,browserState:u,returnSchema:r.schema,screenshot:`data:image/jpeg;base64,${h.toString("base64")}`},{disableCache:i,abortSignal:this.executeAbortController.signal,loggerTags:ze(this.logger)});if(g.result==="NOT_FOUND")throw new R("ActionFailureError","No relevant data found for extraction goal on this page");if(g.thoughts?.includes("MaxGenerationLengthExceededError"))throw new R("UserConfigurationError",g.thoughts);return{thoughts:g.thoughts||void 0,data:g.result,succeedImmediately:!1,urlAfterCommand:this.browser.url()}}catch(g){let f=g.message;throw f.includes("MaxGenerationLengthExceededError")?new R("UserConfigurationError","You tried to extract too much data. Please rephrase your query to limit the results returned or use a JavaScript step in the browser instead."):f.includes("AIProviderError")&&f.includes("time")?new R("AIProviderError","The AI provider responded with an error. This may be because you tried to extract too much data. Please limit extraction results to 2000 characters.",{errOptions:{cause:g}}):g}}case"NAVIGATE":if(!ko(r.url)&&!Mo(r.url,this.browser.baseUrl))throw new R("ActionFailureError",`Invalid URL provided to navigate command: ${r.url}`);await this.browser.navigate({url:r.url,loadTimeoutMs:r.loadTimeout?r.loadTimeout*1e3:void 0});break;case"DIALOG":this.browser.registerDialogHandler(r.action);break;case"CAPTCHA":if(!this.browser.canSolveCaptchas())break;let s=await this.browser.solveCaptcha();s&&(await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:{type:"description",elementDescriptor:"the captcha image solution input"},cache:void 0,action:u=>this.browser.click(u,this.createCallbacksForBrowser(this.orgId),{}),options:{disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl}}),await this.browser.type(s,{clearContent:!0,pressEnter:!0},!0));break;case"GO_BACK":await this.browser.goBack();break;case"GO_FORWARD":await this.browser.goForward();break;case"SCROLL_LEFT":case"SCROLL_RIGHT":case"SCROLL_DOWN":case"SCROLL_UP":{let u,h=[];if(r.target&&yn(r.target))await this.browser.hoverUsingVisualCoordinates(r.target.pixels);else if(r.target&&r.target.elementDescriptor.trim()){let{newTarget:g,elementInteractedDisplayString:f}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:S=>this.browser.hover(S),options:{disableGlobalLocatorRedirect:!0,disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl}});u=f,h.push(g)}switch(r.type){case"SCROLL_UP":await this.browser.scrollVertical(-(r.deltaY??this.browser.getViewport().height));break;case"SCROLL_DOWN":await this.browser.scrollVertical(r.deltaY??this.browser.getViewport().height);break;case"SCROLL_LEFT":await this.browser.scrollHorizontal(-(r.deltaX??this.browser.getViewport().width));break;case"SCROLL_RIGHT":await this.browser.scrollHorizontal(r.deltaX??this.browser.getViewport().width);break}return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:u,newTargets:h}}case"WAIT_FOR_URL":{if(r.timeout&&r.timeout>1800)throw new R("UserConfigurationError",`Wait for URL timeout of ${r.timeout} exceeds the maximum allowed value of 30 minutes.`);let u=r.matcher;await this.browser.waitForUrl({beforeUrl:this.browser.url(),matcher:u},{timeout:r.timeout?r.timeout*1e3:void 0,negated:r.negated,caseInsensitive:r.caseInsensitive});break}case"WAIT":if(r.delay>1800)throw new R("UserConfigurationError",`Wait timeout of ${r.delay} seconds exceeds the maximum allowed value of 30 minutes`);let l=r.delay*1e3;await te(l,this.executeAbortController.signal);break;case"REFRESH":await this.browser.refresh({loadTimeoutMs:r.loadTimeout?r.loadTimeout*1e3:void 0});break;case"CLICK":{if(yn(r.target)){await this.browser.clickUsingVisualCoordinates(r.target.pixels,r);break}let u=this.browser.url(),h={disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl},{elementInteractedDisplayString:g,newTarget:f,result:S}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,target:r.target,command:r,cache:r.cache?.target,action:w=>this.browser.click(w,this.createCallbacksForBrowser(this.orgId),r),options:h});f.cache&&(r.cache={target:f.cache});let b={urlAfterCommand:this.browser.url(),succeedImmediately:!1,elementInteracted:g,newTargets:[f],data:S};return Ms(u,b.urlAfterCommand)&&(b.succeedImmediately=!0,b.succeedImmediatelyReason="URL changed"),b}case"COPY":return await this.browser.copy(r.value),{succeedImmediately:!1,data:r.value,urlAfterCommand:this.browser.url()};case"PASTE":{await this.browser.paste();break}case"DRAG":{if(yn(r.fromTarget)&&yn(r.toTarget)){await this.browser.dragAndDropUsingVisualCoordinates(r.fromTarget.pixels,r.toTarget.pixels,{hoverSeconds:r.hoverSeconds});break}if(yn(r.fromTarget)||yn(r.toTarget))throw new Error("Drag and drop targets must be both coordinates or both descriptions");let{newTargets:u,elementInteractedDisplayStrings:h}=await this.wrapMultiElementTargetingCommand({ctx:e,tracer:t,command:r,targetNames:["from target","to target"],descriptions:[r.fromTarget,r.toTarget],caches:[r.cache?.fromTarget,r.cache?.toTarget],action:(g,f)=>this.browser.dragAndDrop(g.locator,f.locator,{hoverSeconds:r.hoverSeconds,steps:r.steps}),options:{useSelector:!!r.useSelector,disableCache:i}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:h[0],newTargets:u}}case"MOUSE_DRAG":{let u=parseInt(r.deltaX),h=parseInt(r.deltaY),g=r.steps??5;if(isNaN(u)||isNaN(h))throw new R("ActionFailureError",`Invalid pixel values passed to mouse drag command: (${r.deltaX}, ${r.deltaY})`);if(r.target&&yn(r.target)){await this.browser.mouseDragUsingVisualCoordinates(u,h,g,r.target.pixels,{force:r.force});break}let f,S,b=[];if(r.target?.elementDescriptor){let{newTarget:w,elementInteractedDisplayString:v,result:x}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:async C=>C.locator,options:{useSelector:!!r.useSelector,iframeUrl:r.iframeUrl,disableCache:i}});f=x,S=v,b.push(w)}return await this.browser.mouseDrag(u,h,g,f,{force:r.force}),{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:S,newTargets:b}}case"SELECT_OPTION":{if(!Xn(r.target))throw new Error("Select with x/y is not supported yet");let u=r.target.elementDescriptor,h=r.choice,{newTarget:g,elementInteractedDisplayString:f}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:{type:"description",elementDescriptor:u},cache:r.cache?.target,action:S=>this.browser.selectOption(S,h,r.force),options:{disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl,source:Rr(r)}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:f,newTargets:[g]}}case"TAB":{let u={loadTimeoutMs:r.loadTimeout?r.loadTimeout*1e3:void 0,retry:!0};await this.browser.switchToPage(r.action,u);break}case"NEW_TAB":await this.browser.createNewTab(r.url,{loadTimeoutMs:r.loadTimeout?r.loadTimeout*1e3:void 0});break;case"COOKIE":if(!r.value)break;let c=await this.browser.setCookie(r.value);this.logger.debug({results:c},"Set cookies");break;case"LOCAL_STORAGE":if(!r.value||!r.key)break;await this.browser.setLocalStorage(r.key,r.value);break;case"JAVASCRIPT":{let u;try{r.environment==="BROWSER"?(u=await this.browser.evaluateCodeInPage({code:r.code,fragment:r.fragment??!1,context:o.toObjectCopy(),timeoutMs:r.timeout?r.timeout*1e3:void 0}),this.logger.debug({result:u},"Executed JavaScript in browser")):u=await jn({orgId:this.orgId,code:r.code,fragment:!!r.fragment,context:o,timeoutMs:r.timeout?r.timeout*1e3:void 0,logger:this.logger,localTools:this.localCodeEvalTools,signal:this.executeAbortController.signal,flagStore:this.flagStore,callbacks:{onPersistentVariableUpdates:async h=>{if(!this.options?.scratchPadId){this.logger.warn({updates:h},"Got persistent variable updates but scratch pad is not available");return}await this.storage.savePersistentVariables?.({scratchPadId:this.options?.scratchPadId,orgId:this.orgId,updates:h,logger:this.logger})}}})}catch(h){throw this.throwIfClosed(),new R("ActionFailureError",h instanceof Error?h.message:`${h}`,{errOptions:{cause:h}})}try{JSON.stringify(u)}catch(h){throw new R("ActionFailureError",`Return value is not serializable: ${h instanceof Error?h.message:`${h}`}`,{errOptions:{cause:h}})}return{urlAfterCommand:this.browser.url(),succeedImmediately:!1,data:u}}case"TYPE":{if(r.target&&yn(r.target)){await this.browser.clickUsingVisualCoordinates(r.target.pixels,r),await this.browser.type(r.value,{force:r.force,clearContent:r.clearContent,forceClearContent:r.forceClearContent,delay:r.delay,pressEnter:r.pressEnter},!0);break}let u=this.browser.url(),h,g=[],f=bk(r.target);if(f){let{elementInteractedDisplayString:b,newTarget:w}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:f,cache:r.cache?.target,action:v=>this.browser.typeIntoTarget(r.value,v,{force:r.force,clearContent:r.clearContent,forceClearContent:r.forceClearContent,delay:r.delay,pressEnter:r.pressEnter}),options:{disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl,disableGlobalLocatorRedirect:!0,source:Rr(r)}});g.push(w),h=b}else await this.browser.type(r.value,{force:r.force,clearContent:r.clearContent,forceClearContent:r.forceClearContent,delay:r.delay,pressEnter:r.pressEnter},!0);let S={urlAfterCommand:this.browser.url(),succeedImmediately:!1,elementInteracted:h,newTargets:g};return Ms(u,S.urlAfterCommand)&&(S.succeedImmediately=!0,S.succeedImmediatelyReason="URL changed"),S}case"HOVER":{if(yn(r.target)){await this.browser.hoverUsingVisualCoordinates(r.target.pixels);break}let{newTarget:u,elementInteractedDisplayString:h}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:g=>this.browser.hover(g),options:{disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:h,newTargets:[u]}}case"FOCUS":{if(!Xn(r.target))throw new Error("Focus with x/y is not supported yet");let{elementInteractedDisplayString:u,newTarget:h}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:g=>this.browser.focus(g),options:{disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:u,newTargets:[h]}}case"BLUR":{if(r.target&&!Xn(r.target))throw new Error("Blur with x/y is not supported yet");if(!r.target||!r.target.elementDescriptor)return await this.browser.blur(null),{succeedImmediately:!1,urlAfterCommand:this.browser.url()};let{newTarget:u,elementInteractedDisplayString:h}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,target:r.target,command:r,cache:r.cache?.target,action:g=>this.browser.blur(g),options:{disableCache:i,useSelector:!!r.useSelector,iframeUrl:r.iframeUrl}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:h,newTargets:[u]}}case"PRESS":let d=this.browser.url();await this.browser.press(r.value,{repeat:r.repeat,convertMeta:r.convertMeta??!0,delayMs:r.delayMs});let p={urlAfterCommand:this.browser.url(),succeedImmediately:!1};return Ms(d,p.urlAfterCommand)&&(p.succeedImmediately=!0,p.succeedImmediatelyReason="URL changed"),p;case"REQUEST":{let u=new wk,h=yk(fetch,u),g;try{g=new URL(r.url).hostname}catch{}return{data:{...await il({command:r,baseUrl:this.browser.baseUrl,logger:this.logger,fetchImplementation:h}),cookies:Ss(u,g)},succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"GRAPHQL_REQUEST":return{data:await Qb({command:r,baseUrl:this.browser.baseUrl,logger:this.logger}),succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"VISUAL_DIFF":return cy({ctx:e,tracer:t,command:r,disableCache:i,browser:this.browser,logger:this.logger,storage:this.storage,screenshotStorage:this.visualDiffScreenshotStorage,targetingWrapper:u=>this.wrapElementTargetingCommand(u)});case"FILE_UPLOAD":{let u,h;if(r.fileSource.type==="URL"?(h=r.fileSource.url,u=await ib({uri:r.fileSource.url,logger:this.logger,orgId:this.orgId})):r.fileSource.type==="USER_FILE"&&(h=r.fileSource.name,u=await this.uploadedFileStorage?.getFileForUpload(r.fileSource.name,this.orgId)),!u)throw new R("UserConfigurationError",`Attempted to use non-existent file for upload step: ${h}`);await this.browser.setFileChooserHandler({...u,filename:r.filename});break}case"AUTH_SAVE":return{data:await this.browser.saveAuthState(),succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"AUTH_LOAD":{let u;if(!r.storageState.trim())u=void 0;else if(u=await jn({orgId:this.orgId,code:r.storageState,fragment:!1,context:o,logger:this.logger,localTools:this.localCodeEvalTools,signal:this.executeAbortController.signal,flagStore:this.flagStore}),typeof u!="object")throw new R("ActionFailureError",`Credentials must evaluate to an object (received ${typeof u} instead)`);let h;try{h=fs.optional().parse(u)}catch(g){throw new R("ActionFailureError",`Credentials provided do not follow the required format: ${g}`)}await this.browser.loadAuthState(h);break}case"ELEMENT_CHECK":{let u=(r.timeout??wn)*1e3,h=await sy({command:r,tracer:t,timeoutMs:u,targetingWrapper:g=>this.wrapElementTargetingCommand(g),fixtures:this.getControllerFixtures(e),disableCache:i});return{fail:!h.success,data:h.data,elementInteracted:h.elementInteractedDisplayString,newTargets:h.newTarget?[h.newTarget]:[],thoughts:h.err?.message??h.thoughts??`Element assertion ${h.success?"succeeded":"failed"}.`,succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"PAGE_CHECK":{let u=await Rn({action:async()=>al({assertion:r.assertion,browser:this.browser,logger:this.logger,timeout:r.timeout,signal:this.executeAbortController.signal,flagStore:this.flagStore}),frameConfig:r.iframeUrl?{type:"url",url:r.iframeUrl}:void 0,browser:this.browser,logger:this.logger});return{fail:!u.success,data:u.data,thoughts:u.success?"Page assertion passed.":u.err?.message??`Page assertion still failing after ${r.timeout} seconds.`,urlAfterCommand:this.browser.url(),succeedImmediately:!1}}case"REGISTER_REQUEST_LISTENER":{let u;try{u=new RegExp(r.pattern)}catch(f){throw new R("UserConfigurationError",`The provided regex expression was invalid: ${f}`)}let g=this.browser.registerRequestListener(u).then(async f=>{let S={status:f?.status(),headers:f.headers()};return(await f.headerValue("content-type"))?.includes("json")?S.json=await f.json():(await f.headerValue("content-type"))?.includes("text")&&(S.text=await f.text()),S}).catch(f=>{this.logger.error({err:f},"Failed to get request listener response")});return this.registeredListeners[r.key]=g,{succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"AWAIT_LISTENER":{let u=this.registeredListeners[r.key];if(!u)throw new R("ActionFailureError",`No listener registered with key: ${r.key}`);return{data:await D(u,{milliseconds:(r.timeout??10)*1e3,message:`Request listener timed out after ${r.timeout} seconds`}),succeedImmediately:!1,urlAfterCommand:this.browser.url()}}default:return(u=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(r)}return{succeedImmediately:!1,urlAfterCommand:this.browser.url()}}async getReverseMappedDescription({browserState:e,targetId:t,disableCache:r,screenshot:o}){return(await this.generator.getReverseMappedDescription({browserState:e,target:t,screenshot:o},{disableCache:r,abortSignal:this.executeAbortController.signal,loggerTags:ze(this.logger)})).phrase}async stopRecordMode(){this.recordAbortController?.abort(),await this.browser.clearAllCdpHighlights()}async startRecordMode({params:e,abortController:t,isClickToRecord:r}){this.recordAbortController=t;let o=new vl({signal:t.signal,...e});return await this.browser.startRecording(this.recordAbortController.signal,o,r),o}async runSectionAutohealing(e){return this.generator.getAutohealingProposal(e,{disableCache:!0,abortSignal:this.executeAbortController.signal,loggerTags:ze(this.logger)})}async runFailureRecovery(e){return this.generator.getFailureRecoveryProposal(e,{disableCache:!0,abortSignal:this.executeAbortController.signal,loggerTags:ze(this.logger)})}};var vk=4;async function ew({socket:n,logger:e,analytics:t,storage:r,uploadedFileStorage:o,visualDiffScreenshotStorage:i,serviceMocker:a,devicePixelRatio:s,generatorFactory:l,enricherFactory:c,browserbase:d,authorization:p,flagStoreFactory:m,settingsFactory:u}){let h=n.id,g=n.handshake.query.testId;if(!g)throw new Error("Socket connection request is missing testId");let f=await r.getOrgId({type:"e2e",testId:g});e=e.child({testId:g,orgId:f,sessionId:h});let S=await l(f,e),b=await c(f,e),w=await m(f),v=await u(f,e),{testMetadata:x,baseUrl:C,envName:A,browserConfig:N,environmentVariables:O,localCodeEvalTools:H}=await Qr({testId:g,orgId:f,logger:e,storage:r,authorization:p,flagStore:w,settings:v}),F=Q.getSession(h);if(F)return e.info("Associating connection with existing session (likely reconnect)"),await F.controller.browser.clearAllCdpHighlights(),{type:"e2e",sessionId:h,orgId:f,testId:g};let L=n.handshake.headers["x-forwarded-for"]?.split(",")[0];if(e.info({clientIp:L,event:"connect",args:n.handshake.query},"Websocket event (connect)"),L&&Q.getCurrentConnectionsByIp(L)>=vk)throw e.error({clientIp:L,sessions:Q.getCurrentSessionsByIp(),...n.handshake.query},"Socket connection browser creation rate limit triggered"),new Error("You have exceeded the maximum number of connections allowed. Momentic limits the number of simultaneously open tabs to uphold browser reliability. Please close duplicate tabs and try again later.");Q.reserveCapacityByIp(L);try{await Tk({socket:n,baseUrl:C,envName:A,testMetadata:x,orgId:f,sessionId:h,logger:e,analytics:t,environmentVariables:O,clientIp:L,devicePixelRatio:s,storage:r,uploadedFileStorage:o,visualDiffScreenshotStorage:i,serviceMocker:a,localCodeEvalTools:H,generator:S,enricher:b,browserbase:d,browserConfig:N,flagStore:w})}catch(B){throw e.warn({err:B},"Error setting up socket session, possibly due to client closing the connection"),Q.releaseCapacityByIp(L),B}return{type:"e2e",sessionId:h,testId:g,orgId:f}}async function Tk({socket:n,baseUrl:e,envName:t,devicePixelRatio:r,testMetadata:o,orgId:i,sessionId:a,logger:s,analytics:l,storage:c,uploadedFileStorage:d,visualDiffScreenshotStorage:p,serviceMocker:m,localCodeEvalTools:u,generator:h,environmentVariables:g,browserConfig:f,clientIp:S,enricher:b,flagStore:w}){let v={viewport:o.advanced?.viewport??Gt,locale:o.advanced?.locale??xo,timezoneId:o.advanced?.timezone??Eo,colorScheme:o.advanced?.colorScheme};r&&(v.deviceScaleFactor=r);let x=o.id,C=await m?.initializeServicesForTest(i,x),A=await ul({settings:f,orgId:i,baseUrl:e,envName:t,localTools:u,envVariables:g,logger:s,customHeaders:void 0,flagStore:w});s=s.child({orgId:i,sessionId:a,testId:x});let N=!1,O=w.isBooleanFlagEnabled("icon_knowledge_base")?await c.fetchIconKnowledgeBase(i,s):null,H=await On.init({baseUrl:e,userBrowserSettings:A,enricher:b,storage:c,flagStore:w,mockedServices:C,logger:s,contextArgs:v,iconKnowledgeBase:O,callbacks:{onTabsChange:(K,U)=>{n.emit("tabs",{tabs:K,activeTab:U})},onScreencastFrame:(K,U)=>{let Y=n;N&&(Y=n.compress(!0)),Y.emit("screenshot",{buffer:K},()=>{U()})},onSvgsCollected:K=>{n.emit("newIconDetected",{numIcons:K.newSvgs.length}),c.saveNewIcons(i,K,s)}}});await H.navigate({url:e,initialNavigation:!0});let F=new pi({browser:H,generator:h,logger:s,analytics:l,flagStore:w,orgId:i,options:{scratchPadId:void 0,slowMoMs:A.slowMoMs,autoFollowNewTabs:A.autoFollowNewTabs},storage:c,localCodeEvalTools:u,uploadedFileStorage:d,visualDiffScreenshotStorage:p}),L=zS(n,a,s),B=async()=>{L.timers.forEach(K=>clearInterval(K))},P=new At({baseUrl:e,currentUrl:F.browser.url(),variablesFromEnvironment:g,envName:t});if(!n.connected)throw await H.cleanup(),new Error("Socket not connected anymore, not proceeding with session setup");n.emit("session",{url:e,userAgent:On.USER_AGENT,viewport:F.browser.getViewport(),sessionId:a}),Q.registerSession({controller:F,context:P,sessionId:a,cleanup:B,clientIp:S})}async function Qr({testId:n,orgId:e,logger:t,storage:r,authorization:o,flagStore:i,settings:a}){let s=await r.fetchTestMetadata(n,e,t);if(!s)throw new Error(`Test metadata could not found for test ${n}`);let l;o?.type==="API_KEY"&&(l=new dr({httpClient:new kt({...o,logger:t}),fakerSeed:void 0}));let c=s.envs?.find(g=>g.default),d;c&&(d=await r.fetchEnvironment(e,c.name,t));let p=d&&"browser"in d?d.browser:void 0,m={...a.browser,...p,...s.advanced},u=s.baseUrl||d?.variables?.[Ge];if(!u)throw new Error("Base URL is empty in both test options and the configured environment");let h={...d?.variables};return await Promise.all((s.parameters??[]).map(async g=>{let f=await Bt({orgId:e,s:g.defaultValue,context:At.dummyContext(d?.name,h),logger:t,flagStore:i,localTools:l});h[g.name]=f})),{localCodeEvalTools:l,baseUrl:u,envName:d?.name,browserConfig:m,environmentVariables:h,testMetadata:s}}var Lp=class{parentTracer=null;socket;step;constructor({step:e,socket:t,parentTracer:r}){this.socket=t,this.parentTracer=r,this.step=e}getParentStepIdChain(){return this.parentTracer?this.parentTracer?.getParentStepIdChain()??[]:[]}attachBeforeScreenshot(){}attachAfterScreenshot(){}attachBeforeHtmlSnapshot(){}attachAfterHtmlSnapshot(){}heal(){}async finish(e){switch(e.step.status){case"SUCCESS":this.socket.emit("success",{...e,parentStepIdChain:this.getParentStepIdChain()});return;case"FAILED":this.socket.emit("failure",{...e,parentStepIdChain:this.getParentStepIdChain()});return;case"CANCELLED":this.socket.emit("cancelled",{...e,parentStepIdChain:this.getParentStepIdChain()});return}}async startSubSteps(){return new Rl({parentStep:this.step,socket:this.socket,parentTracer:this})}},Rl=class{parentTracer;parentStep;socket;constructor({parentStep:e,socket:t,parentTracer:r}){this.parentTracer=r,this.parentStep=e,this.socket=t}getParentStepIdChain(){return this.parentStep?[...this.parentTracer?.getParentStepIdChain()??[],this.parentStep.id]:[]}async startStep(e){return this.socket.emit("started",{stepId:e.step.id,parentStepIdChain:this.getParentStepIdChain()}),new Lp({step:e.step,parentTracer:this,socket:this.socket})}},Al=class{constructor(e,t,r,o,i){this.socket=e;this.storage=t;this.orgId=r;this.testId=o;this.stepsBeforeRun=i}trackStatus(){}attachConsoleLogs(){}attachNetworkLogs(){}async finish(){this.socket.emit("finished")}async startStepList(){return new Rl({parentStep:null,parentTracer:null,socket:this.socket})}};var Op={currentlyExecutingRequests:{}},Ek=n=>async(e,t)=>{let{testId:r,orgId:o}=n.metadata,i=await n.flagStoreFactory(o),a=await n.settingsFactory(o,n.logger),s,l=await Qr({testId:r,orgId:o,logger:n.logger,storage:n.storage,authorization:n.authorization,flagStore:i,settings:a}),c=`${r}|${l.baseUrl}`;try{let d=Op.currentlyExecutingRequests[c]??0;Op.currentlyExecutingRequests[c]=d+1,s=await Ck({...n,...e,...l,done:t})}finally{n.logger.info({result:s,sessionId:n.metadata.sessionId},"Test execution complete"),Op.currentlyExecutingRequests[c]--}},Ck=async({socket:n,steps:e,baseUrl:t,testMetadata:r,reInitialize:o,toStep:i,fromStep:a,storage:s,metadata:l,logger:c,analytics:d,envName:p,environmentVariables:m,localCodeEvalTools:u,done:h,cacheStorageFactory:g})=>{let{testId:f,sessionId:S,orgId:b}=l,w=S,v=Q.getSession(S);if(!v)throw new Error("No active session found");let{controller:x,context:C}=v;x.setOpen(),c=c.child({testId:f,orgId:b,sessionId:S,runId:w}),c.info({steps:e.map(Z=>`${Z.type}${"command"in Z?` - ${Z.command.type}`:""}`),toStep:i,fromStep:a,reInitialize:o,envName:p,baseUrl:t,context:C,flags:x.flagStore.getAllFlags()},"Socket execution parameters");let A=m??{},N=async()=>{o&&(await x.browser.reset({newUrl:t}),C.reset({baseUrl:t,currentUrl:x.browser.url(),variablesFromEnvironment:A,envName:p}))},O=await g(b),H=async()=>{try{await O.resolveStepCacheEntries({schemaVersion:r.schemaVersion,organizationId:b,testId:f,steps:e,logger:c})}catch(Z){c.error({err:Z},"Failed to fetch step cache entries from Momentic server. This can drastically reduce test reliability and performance.")}};try{await ta({promiseGenerator:async()=>Promise.all([N(),H()]),signal:x.executeAbortController.signal,codePath:"resolveStepCacheAndInitBrowser"}),x.setOpen()}catch(Z){if(n.emit("finished"),Z.name!=="AbortError")throw new Error(`Failed to setup browser for execution: ${Z}`)}let F=xk(e),L={collectDebugData:!1,reinitializeBrowser:!1,disableHealing:!0},B={orgId:b,runId:w,testMetadata:r,steps:e,fromStep:a,toStep:i},P={controller:x,context:C,storage:s,debugDataStorage:new Or,codeEvalTools:u,billingReporter:new Po,logger:c,analytics:d},K={test:{},step:{onDynamicAIActionStatusUpdateEvent:Z=>{n.emit("dynamicCommandStatusUpdate",Z)},onDynamicAIActionEvaluatingEvent:Z=>{n.emit("dynamicCommandEvaluating",Z)},onDynamicCommandGenerated:Z=>{n.emit("dynamicCommandGenerated",Z)},onDynamicCommandExecuted:Z=>{n.emit("dynamicCommandExecuted",Z)}}},U=new Al(n,s,b,f,F),Y=await pl({fixtures:P,options:L,callbacks:K,inputs:B,testParams:{tracer:U}});return Y?.status==="PASSED"&&await Cs({logger:c,cacheStorage:O,orgId:b,testId:f,originalSteps:{steps:F},updatedSteps:{steps:e}}),await U.finish(),h?.(Y),Y.status};var tw={event:"execute",createHandler:Ek};import{cloneDeep as Rk}from"lodash-es";var Ak=n=>async({command:e},t)=>{let{logger:r,generatorFactory:o,metadata:i}=n,a=Rk(e),s=Wg(a);if(s.category!=="NO_DESCRIPTION_PROVIDED"){if(s.category!=="NONE"){t?.({result:s});return}"cache"in a&&(a.cache=void 0,a.id=void 0);try{let c=await(await o(i.orgId,r)).getLintStepResult({command:a},{logger:r});t?.({result:c})}catch(l){r.error({event:"lint",err:l},"Failed to lint step"),t?.({result:void 0})}}},nw={event:"lintStep",createHandler:Ak};var Ik=({metadata:n,logger:e,storage:t})=>{let{sessionId:r}=n;return async(o,i)=>{let{description:a,command:s,testMetadata:l,returnScreenshot:c}=o;e.info({params:o},`Locate handler called - ${a}`);let d=Q.getSession(r);if(!d)throw new Error("No active session found");let{controller:p,context:m}=d;p.setOpen();let u=Co.parse(l.advanced??{}),h={},g;if(a){if("useSelector"in s&&s.useSelector)try{let f=await p.locateElementWithSelector(a,"iframeUrl"in s?s.iframeUrl:void 0);g=f.resolution.locator,h={target:f.target,thoughts:f.thoughts}}catch(f){e.warn({err:f},"Failed resolving target with selector"),i({err:`Failed locating element: ${f.message}`,decisions:f instanceof nr?f.decisions:void 0});return}else try{let f=await p.locateElement({description:a,disableCache:u.disableAICaching??!1,iframeUrl:"iframeUrl"in s?s.iframeUrl:void 0,skipWait:!0,testContext:m,source:Rr(s)});h={target:f.target,thoughts:f.thoughts},g=f.resolution.locator}catch(f){(async()=>{try{let S=await p.browser.getCondensedHtml({skipWait:!0});e.warn({err:f,html:S.slice(0,1e5)},"Failed locating element with AI")}catch(S){e.warn({err:S},"Failed grabbing HTML after trying to locate element with AI")}})(),i({err:`Failed locating element with AI: ${f.message}`});return}if(s.type==="SELECT_OPTION"&&g)try{h.options=await p.browser.getSelectOptions(g)}catch(f){e.warn({err:f},"Failed getting select options"),i({err:`Failed getting select options: ${f.message}`});return}e.info({result:h},"Locate handler result")}if(c)try{let{buffer:f,width:S,height:b}=await p.screenshotWithDimensions({clearHighlights:!0,locator:g}),w=await t.uploadScreenshot(f);h.screenshot={data:w,width:S,height:b},e.info({width:S,height:b},"Captured screenshot during locate")}catch(f){e.error({err:f},"Error capturing screenshot during locate"),i({err:`Error taking screenshot: ${f.message}`});return}if(i({result:h}),g)try{await Promise.all([p.browser.scrollIntoView(g),p.browser.highlight(g)])}catch(f){e.warn({err:f},"Error highlighting element, continuing...")}}},rw={event:"locate",createHandler:Ik};var Pk=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({event:r,percentX:o,percentY:i})=>{let a=Q.getSession(t);if(!a)throw new Error("No active session found");let s=a.controller.browser;if(s.closed||s.getActivePage().isClosed()){e.warn("Ignoring mouse move because the browser is closed");return}try{await s.clickMouseFromPositionPercentages(r,o,i)}catch(l){e.error({err:l},"Error performing click during cloud recording in control mode")}}},ow={event:"mouseClickEvent",createHandler:Pk};var Lk=({metadata:n,generatorFactory:e,logger:t,socket:r})=>{let{sessionId:o,orgId:i,testId:a}=n;return async({stepId:s,parentStepIdChain:l,attribute:c})=>{let d=Q.getSession(o);if(!d)throw new Error("No active session found");let{controller:p}=d,m=await e(i,t);p.setOpen(),d.browserBehavior.showOverlay=!0;let u=new AbortController;u.signal.addEventListener("abort",async()=>{try{d.browserBehavior.showOverlay=!1,await p.stopRecordMode()}catch(f){t.warn({err:f},"Failed to stop record mode in target click socket handler")}});let h=!1,g=(f,S)=>{S.type!=="PRESET_ACTION"||S.command.type!=="CLICK"||(r.emit("targetRecordingUpdate",{type:f,stepId:s,parentStepIdChain:l,command:S.command,attribute:c}),u.abort(),h=!0)};setTimeout(()=>{h||(u.abort(),r.emit("targetRecordingUpdate",{type:"error",err:"Timed out waiting for click event",stepId:s,parentStepIdChain:l,attribute:c}))},1e4),await p.startRecordMode({params:{generator:m,logger:t,testId:a,orgId:i,callbacks:{onActionReceived:f=>g("clickReceived",f),onStepRecorded:f=>g("descriptionGenerated",f)}},abortController:u,isClickToRecord:!0}),r.emit("targetRecordingUpdate",{type:"listenersInitialized",stepId:s,parentStepIdChain:l,attribute:c})}},iw={event:"recordTargetClick",createHandler:Lk};var Ok=["Dead","Meta","AudioVolumeUp","AudioVolumeDown"],kk=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({key:r})=>{let o=Q.getSession(t);if(!o)throw new Error("No active session found");if(Ok.includes(r))return;let{controller:i}=o;if(i.browser.closed||i.browser.getActivePage().isClosed()){e.debug({sessionId:t},"Browser is closed, ignoring keyboard press socket event");return}try{i.setOpen(),r.length>1?await i.browser.press(r,{}):await i.browser.type(r,{clearContent:!1})}catch(a){if(a.message.includes("has been closed")){e.debug({sessionId:t,err:a},"Browser is closed, ignoring keyboard press socket event error");return}throw a}}},aw={event:"keyboardPressEvent",createHandler:kk};var Mk=({metadata:n,logger:e})=>{let{sessionId:t}=n,r,o=0,i=(l,c)=>{let d=async()=>{r=void 0};clearTimeout(r),r=setTimeout(d,Math.min(1e3,250*(o+1)))},a,s=0;return async l=>{let c=Q.getSession(t);if(!c)throw new Error("No active session found");let{controller:d,browserBehavior:p}=c,m=d.browser;if(m.closed||m.getActivePage().isClosed()){e.warn("Ignoring mouse move because the page is closed");return}if(l.event==="scroll"){let u=await m.scrollFromPositionPercentages(l.percentX,l.percentY,a?.x??0,a?.y??0),h=c.browserBehavior.recordingState?.transformer;h&&u&&h.recordScroll(u);return}p.showOverlay&&i(m,l);try{let u=await m.moveMouseFromPositionPercentages(l.percentX,l.percentY);s=0,a=u}catch(u){s++,s%5===0&&e.warn({err:u,mouseErrors:s},"Error in socket mouse move handler")}}},sw={event:"mouseMoveEvent",createHandler:Mk};var Nk=({metadata:n,generatorFactory:e,socket:t,logger:r})=>{let{sessionId:o,orgId:i,testId:a}=n;return async({stepId:s})=>{let l=Q.getSession(o);if(!l)throw new Error("No active session found");let{controller:c,browserBehavior:d}=l,p=await e(i,r);r.info("Starting cloud recording");let m=new AbortController,u=await c.startRecordMode({params:{generator:p,logger:r,testId:a,orgId:i,callbacks:{onActionReceived:(h,g)=>{t.emit("stepRecorded",{stepId:s,step:h,offset:g})},onStepRecorded:(h,g)=>{t.emit("stepRecorded",{stepId:s,step:h,offset:g})}}},abortController:m,isClickToRecord:!1});d.recordingState={transformer:u}}},lw={event:"recordingStart",createHandler:Nk};var _k=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async()=>{let r=Q.getSession(t);if(!r)throw new Error("No active session found");e.info("Stopping cloud recording"),await r.controller.stopRecordMode(),r.browserBehavior.recordingState=void 0,r.browserBehavior.showOverlay=!1}},cw={event:"recordingStop",createHandler:_k};var Dk=({socket:n,metadata:e,logger:t,storage:r,authorization:o,flagStoreFactory:i,settingsFactory:a})=>async(s,l)=>{let{testId:c,sessionId:d,orgId:p}=e;t.info({testId:c,sessionId:d},"Refresh event received");let m=await i(p),u=await a(p,t),{baseUrl:h}=await Qr({testId:c,orgId:p,logger:t,storage:r,authorization:o,flagStore:m,settings:u}),g=Q.getSession(d);if(!g){n.emit("error",{message:"No session to refresh"});return}let{controller:f}=g;f.setOpen(),await f.browser.refresh();let S=f.browser.getViewport();t.info({baseUrl:h,viewport:S},`Session refreshed for test ${c} at ${h}`),l()},dw={event:"refresh",createHandler:Dk};var Fk=({socket:n,metadata:e,logger:t,storage:r,authorization:o,flagStoreFactory:i,settingsFactory:a})=>async()=>{let{testId:s,sessionId:l,orgId:c}=e;t.info({testId:s,sessionId:l},"Reset event received");let d=await i(c),p=await a(c,t),{baseUrl:m,envName:u,environmentVariables:h}=await Qr({testId:s,orgId:c,logger:t,storage:r,authorization:o,flagStore:d,settings:p}),g=Q.getSession(l);if(!g){n.emit("error",{message:"No session to reset"});return}let{controller:f,context:S}=g;await f.browser.reset({newUrl:m});let b=f.browser.baseUrl;S.reset({baseUrl:b,currentUrl:f.browser.url(),variablesFromEnvironment:h,envName:u});let w=f.browser.getViewport(),v=On.USER_AGENT;t.info({baseUrl:m,viewport:w},`Session reset for test ${s} at ${b}`),n.emit("session",{url:b,userAgent:v,viewport:w,sessionId:l})},pw={event:"reset",createHandler:Fk};var Uk=({metadata:n})=>{let{sessionId:e}=n;return async({url:t})=>{let r=Q.getSession(e);if(!r)throw new Error("No active session found");await r.controller.browser.switchToPage({type:"SUBSTRING",substring:t})}},uw={event:"switchTab",createHandler:Uk};async function mw(n){let{socket:e}=n;return e.handshake.query.type==="api-test"?ZS(n):ew(n)}var hw=[ry,tw,rw,pw,dw,ey,uw,nw,iw,lw,cw,sw,ow,aw,QS,HS,ny,ty];var gw=n=>{let{logger:e}=n,t=new Bk(n.baseServer,{cors:{origin:"*",methods:["GET","POST"]},pingTimeout:15*60*1e3,pingInterval:15*60*1e3,maxHttpBufferSize:1e7,perMessageDeflate:!0});return t.on("connection",async r=>{let o;try{e.info({event:"connection",transport:r.conn.transport.name},"Websocket connection established"),o=await mw({...n,socket:r,logger:e}),e=e.child(o)}catch(i){e.error({event:"connection",type:"websocket",err:i},"Failed to setup connection"),r.emit("error",{message:i instanceof Error?i.message:`${i}`}),r.disconnect(!0);return}hw.forEach(i=>zk(i,{socket:r,metadata:o,...n,logger:e}))}),t},zk=(n,e)=>{let t=n.createHandler(e),r=(...o)=>{["mouseMoveEvent","keyboardPressEvent","mouseClickEvent","lintStep"].includes(n.event)||e.logger.debug({...e.metadata,event:n.event,args:o},`Websocket event (${n.event})`);let i=a=>{e.logger.error({event:n.event,type:"websocket",args:o,err:a instanceof Error?a:new Error(`${a}`)},"Unhandled exception in socket handler"),e.socket.emit("error",{message:a instanceof Error?a.message:`${a}`})};try{let a=t.apply(void 0,o);a&&typeof a.catch=="function"&&a.catch(i)}catch(a){i(a)}};e.socket.on(n.event,r)};import{Router as Kk}from"express";import _p from"fs";import Wk from"path";import Sw,{multistream as Hk}from"pino";import jk from"pino-pretty";var fw=["lastScreenshotBuffer"];var kp=new Map,$k=!0,Mp=class n{consoleLogger;ddClientToken;hostname;bindingAttributes;disableConsoleLogs;site="https://http-intake.logs.us5.datadoghq.com/api/v2/logs";constructor({bindings:e,clientToken:t,hostname:r,disableConsoleLogs:o}){this.ddClientToken=t,this.hostname=r,this.disableConsoleLogs=o,this.bindingAttributes={...e,env:"production"};let i={base:this.bindingAttributes,errorKey:"err",level:"debug"};this.consoleLogger=$k?Sw(i):Sw(i,Hk([{stream:jk({colorize:!0})}]))}child(e){return new n({clientToken:this.ddClientToken,bindings:{...this.bindingAttributes,...e},hostname:this.hostname,disableConsoleLogs:this.disableConsoleLogs})}flush(e){this.disableConsoleLogs||this.consoleLogger.flush(e)}log(e,t,r,...o){if(t&&r===void 0&&(r=`${t}`,t={}),this.disableConsoleLogs||this.consoleLogger[e](e==="error"?t:{testId:t.testId,runId:t.runId},r,...o),typeof t=="object"&&t&&"err"in t&&t.err instanceof Error){let a={};for(let s of Object.getOwnPropertyNames(t.err))fw.includes(s)||(a[s]=t.err[s]);a.name=t.err.name,t.err=a}let i=Object.assign({},this.bindingAttributes,t&&typeof t=="object"?t:{});o.length>0&&(i.args=o),(async()=>{try{let a=await fetch(this.site,{method:"POST",headers:{Accept:"application/json","Content-Type":"application/json","DD-API-KEY":this.ddClientToken},body:JSON.stringify([{ddsource:this.bindingAttributes.app,ddtags:["env:production"],hostname:this.hostname??"vercel",service:"momentic",message:{message:r||"",...i,level:e}}])});if(!a.ok)throw new Error(`Failed to log to Datadog: ${a.statusText})}`)}catch(a){this.disableConsoleLogs||this.consoleLogger.warn({obj:t,msg:r,args:o,err:a},"Failed to log to Datadog")}})()}debug(e,t,...r){this.log("debug",e,t,...r)}info(e,t,...r){this.log("info",e,t,...r)}warn(e,t,...r){this.log("warn",e,t,...r)}error(e,t,...r){this.log("error",e,t,...r)}bindings(){return this.bindingAttributes}addBinding(e,t){this.bindingAttributes[e]=t}setMinLevel(e){this.consoleLogger.level=e}enableConsoleLogs(){this.disableConsoleLogs=!1}},Il=({app:n,clientToken:e,hostname:t,disableConsoleLogs:r})=>{if(!process.env.DD_CLIENT_TOKEN&&!process.env.NEXT_PUBLIC_DD_CLIENT_TOKEN&&!e)throw new Error("Missing DD_CLIENT_TOKEN");return kp.has(n)||kp.set(n,new Mp({bindings:{app:n},hostname:t,clientToken:e||process.env.NEXT_PUBLIC_DD_CLIENT_TOKEN||process.env.DD_CLIENT_TOKEN,disableConsoleLogs:r})),kp.get(n)};import{hostname as Gk}from"os";var $e=Il({app:"desktop-server",clientToken:"pubcfd7516a5c0ba852b42675cd97bee027",hostname:Gk(),disableConsoleLogs:!0}),yw=n=>{$e.addBinding("version",n)};var Vk=new yl(30,60*1e3),Up="https://api.momentic.ai",Bp,Np,bw=n=>{Up=n},Pl=()=>Up,ww=(n,e)=>{Bp=n,Np?.abort(),Np=new AbortController;let t=Np.signal,r=[n.configFilePath];n.config.environments?.forEach(o=>{if(!o.envFile)return;let i=Wk.resolve(n.rootDir,o.envFile);try{if(_p.lstatSync(i).isSymbolicLink())return;_p.existsSync(i)&&r.push(i)}catch(a){$e.warn({err:a},`Failed to check if env file ${i} exists`)}});try{qk({filesToWatch:r,revalidator:e,signal:t,project:n})}catch(o){$e.error({err:o},"Failed to start config file watchers")}},me=()=>Bp,ui,Dp,Fp,vw=async n=>{if(ui)return ui;let e=new lt({baseUrl:Up,apiKey:n,logger:$e});try{let t=await e.getAuthInfo();return ui=t.orgId,Dp=t.userId,Fp=n,ui}catch(t){throw new Error(`Error checking API key against server: ${t}`)}},Sr=()=>{if(!ui)throw new Error("Your organization ID is invalid.");return ui},Ll=()=>{if(!Dp)throw new Error("Your user ID is invalid.");return Dp},Tw=()=>{if(!Fp)throw new Error("Your API key is invalid.");return Fp};function qk({filesToWatch:n,revalidator:e,signal:t,project:r}){n.forEach(o=>{_p.watch(o,{signal:t,persistent:!1,recursive:!1},(i,a)=>{a&&(Vk.increment("setLocalProject")&&y.warn(`A file change under the ${r.rootDir} directory has caused Momentic to reload its configuration more than 30 times in the last minute. Rapid changes to files may indicate your momentic.config.yaml 'include' glob is incorrect. Please ensure temporary, library, and auto-generated files are not included in Momentic's context.`),Bp=e(r.configFilePath))})})}function Ce(n){return function(...e){let t=e[e.length-1],r=n(...e);Promise.resolve(r).catch(t)}}var xw=Kk();xw.get("/",Ce((n,e)=>{let t=kf(me(),$e);e.status(200).json(t)}));var Ew=xw;import{Router as Yk}from"express";var Ol=class extends Qo{constructor(t,r){super(t,r);this.client=t;this.orgId=r}async getOrgId(t){return this.orgId}async fetchTestMetadata(t,r,o){let i=me(),s=Oe(i,o).tests[t];if(s)return _s(s.relativePath,i)}async fetchApiTestMetadata(t,r,o){throw new Error("API tests are not available in the desktop app")}async fetchEnvironment(t,r,o){let i=me();return oa(r,i,kr)}async fetchIconKnowledgeBase(t,r){try{return await this.client.fetchIconKnowledgeBase(t,r)}catch(o){return r.error({err:o},"Failed to fetch icon knowledge base"),null}}async fetchCloudOrgSettings(t,r){}};var Cw=Yk();Cw.get("/",Ce((n,e)=>{e.status(200).json({userId:Ll(),orgId:Sr()})}));var Rw=Cw;import{Router as Jk}from"express";var Aw=Jk();Aw.get("/",Ce((n,e)=>{let t=me(),r=Oe(t,y),o=new Set;r?.tests&&Object.values(r.tests).forEach(a=>{a.labels?.forEach(s=>o.add(s))});let i=Array.from(o).sort();e.status(200).json(i)}));var Iw=Aw;import{Router as Xk}from"express";import Pw from"fs";import Zk from"path";var Aa=Xk();Aa.get("/",Ce(async(n,e)=>{let t=me(),r=Oe(t,y),i=(await Ns(r,$e)).map(a=>{let s=r.modules[a.moduleId];if(!s){y.warn(`Found a dangling module with ID ${a.moduleId} that could not be found on disk.`);return}return{...s,content:a}}).filter(a=>a!==void 0);e.status(200).json(i)}));Aa.post("/",Ce(async(n,e)=>{let t;try{t=Ah.parse(n.body)}catch(s){e.status(400).json({error:`Invalid request body: ${s}`});return}try{Io(t.name)}catch(s){e.status(400).json({error:`Invalid module name: ${s}`});return}let r=me(),o=Oe(r,y).modules;if(Object.values(o).find(s=>s.name===t.name)){e.status(400).send(`A module with the name "${t.name}" already exists. Please choose a different name.`);return}let i=Zk.join(r.rootDir,t.folderPath??"");if(!Pw.existsSync(i)||!Pw.statSync(i).isDirectory()){e.status(400).json({error:`The folder configured for module creation '${i}' does not exist.`});return}let a=await Af({...t,folder:i,project:r});e.status(201).json(a)}));Aa.get("/:moduleId",Ce(async(n,e)=>{if(!n.params.moduleId){e.status(400).json({error:"Missing moduleId in url path."});return}let t=Oe(me(),y),r=t.modules[n.params.moduleId];if(!r){e.status(404).json({error:"Module not found."});return}try{let o=await cd(r,t,y);e.json(o)}catch(o){e.status(400).json({err:o})}}));Aa.patch("/:moduleId/metadata",Ce(async(n,e)=>{if(!n.params.moduleId){e.status(400).json({error:"Missing moduleId in url path."});return}let t;try{t=Ih.parse(n.body)}catch(i){e.status(400).json({error:`Invalid request body: ${i}`});return}let r=me(),o=Oe(r,y);Rf({moduleId:n.params.moduleId,content:t,momenticFiles:o,logger:y,project:r}),e.status(201).json({message:"ok"})}));var Lw=Aa;import{Router as Qk}from"express";var kl=Qk();kl.get("/",Ce((n,e)=>{let t=Fd().map(r=>({name:r.config.name,configFilePath:r.configFilePath}));e.status(200).json(t)}));kl.get("/current",Ce((n,e)=>{let t=me(),r={name:t.config.name,configFilePath:t.configFilePath};e.status(200).json(r)}));kl.post("/set",Ce((n,e)=>{let t;try{t=Lh.parse(n.body)}catch(r){e.status(400).json({error:`Invalid request body: ${r}`});return}try{let r=Qt({configFilePath:t.configFilePath});ww(r,o=>Qt({configFilePath:o}))}catch(r){e.status(400).json({error:`Error setting project: ${r}`});return}e.sendStatus(204)}));var Ow=kl;import{Router as eM}from"express";var kw=eM();kw.get("/",Ce((n,e)=>{let r={ai:me().config.ai};e.status(200).json(r)}));var Mw=kw;import{Router as rM}from"express";import Nw from"fs";import eo from"path";import{v4 as _w}from"uuid";import oM from"yaml";import{randomUUID as tM}from"node:crypto";import{PostHog as nM}from"posthog-node";var mi=class{identify(){return this}child(){return this}track(){return this}async shutdown(){}},hi=class n{bindings;client;options;constructor(e,t={}){this.bindings=e,this.options=t,this.client=new nM("phc_oy1FexHsc0S3axxOMXCm46yZsW35zROAoV4SOzpDSXH",{host:"https://us.i.posthog.com",...t})}async shutdown(){await this.client.shutdown()}identify(e){return this.bindings={...this.bindings,...e},this}child(e){return new n({...this.bindings,...e},this.options)}track(e,t){if(!th(this.bindings))return console.error(`Cannot track ${e.type} event without required bindings.`,this.bindings),this;let{type:r,...o}=e;return this.client.capture({distinctId:tM(),event:r,timestamp:t?.timestamp,properties:{...this.bindings,...o}}),this}};var gi=new hi({platform:"local_app"},{flushAt:1,flushInterval:0});var yr=rM();function Dw(n){let e=Oe(n,y);return Object.values(e.tests)}yr.get("/",Ce((n,e)=>{let t=Dw(me());e.status(200).json(t)}));yr.post("/",Ce(async(n,e)=>{let t;try{t=Ch.parse(n.body)}catch(d){e.status(400).json({error:`Invalid request body: ${d}`});return}try{Io(t.name)}catch(d){e.status(400).json({error:d.message});return}let o={id:_w(),name:t.name,description:t.description,baseUrl:t.baseUrl,schemaVersion:Fe,advanced:{disableAICaching:!1,browserType:t.browserType??"Chromium",viewport:t.viewport??Gt},retries:0,steps:[]};t.environment&&(o.envs=[{name:t.environment,default:!0}]);let i=me();if(Dw(i).find(d=>d.name===t.name)){e.status(400).send(`A test with the name "${t.name}" already exists. Please use a different name.`);return}let s=eo.join(i.rootDir,t.folderPath??""),l=await Pf({test:o,name:t.name,folder:s}),c={...o,relativeFilePath:eo.relative(i.rootDir,l)};gi.track({type:"test_editor:test_create"}),e.status(201).json(c)}));yr.get("/:testPath",Ce(async(n,e)=>{let{testPath:t}=n.params;if(!t){e.status(400).json({error:"Missing testPath in url path."});return}let r=me(),o=Oe(r,y),i;try{i=await ra(eo.join(r.rootDir,t),$e,o),e.status(200).json(i)}catch(a){e.status(400).send({error:a.message});return}(async()=>{try{let{stepsToSave:a,moduleUpdates:s}=await Yt({stepLists:{steps:i.steps,beforeSteps:i.beforeSteps,afterSteps:i.afterSteps}});s.forEach(l=>{jr({content:l,schemaVersion:Fe,momenticFiles:o,project:r})}),Bn({relativeTestPath:t,steps:a,schemaVersion:Fe,project:r})}catch(a){$e.error({err:a},"Failed to save migrated test to disk after initial fetch")}})()}));yr.patch("/:testPath/metadata",Ce(async(n,e)=>{if(!n.params.testPath){e.status(400).json({error:"Missing testPath in url path."});return}let t;try{t=Eh.parse(n.body)}catch(i){e.status(400).json({error:`Invalid request body: ${i}`});return}let o={message:"ok",newRelativeTestPath:dd(n.params.testPath,t,me()).newRelativeTestPath};e.status(200).json(o)}));yr.patch("/:testPath",Ce(async(n,e)=>{let{testPath:t}=n.params;if(!t){e.status(400).json({error:"Missing testPath in url path."});return}let r;try{r=xh.parse(n.body)}catch(u){e.status(400).json({error:`Invalid request body: ${u}`});return}let o=me(),i=Oe(o,y),a;try{a=_s(t,o)}catch(u){e.status(400).json({error:`Existing test file on disk is invalid: ${u}`});return}let{stepsToSave:s,moduleUpdates:l,cachesToSave:c}=await Yt({stepLists:r.stepLists,cacheCreationParams:{testId:a.id,orgId:Sr()}}),d=new lt({apiKey:Tw(),baseUrl:Pl(),logger:$e}),p=await Xo($e,d,o);await ri({client:d,gitMetadata:p}).saveStepCacheEntries(c,a.id,$e),l.forEach(u=>{jr({content:u,schemaVersion:r.schemaVersion,momenticFiles:i,project:o})}),Bn({relativeTestPath:t,steps:s,schemaVersion:r.schemaVersion,project:o}),e.status(201).json({message:"ok"})}));yr.patch("/:testPath/environments",Ce(async(n,e)=>{let{testPath:t}=n.params;if(!t){e.status(400).json({error:"Missing testPath in url path."});return}let r;try{r=Ph.parse(n.body)}catch(o){e.status(400).json({error:`Invalid request body: ${o}`});return}dd(t,{envs:r.defaultEnv?[{name:r.defaultEnv,default:!0}]:[]},me()),e.status(201).json({message:"ok"})}));yr.post("/:testPath/duplicate",Ce(async(n,e)=>{let{testPath:t}=n.params;if(!t){e.status(400).json({error:"Missing testPath in url path."});return}let r;try{r=Rh.parse(n.body)}catch(f){e.status(400).json({error:`Invalid request body: ${f}`});return}try{Io(r.name)}catch(f){e.status(400).json({error:f.message});return}let o=me(),i=eo.join(o.rootDir,t);if(!Nw.existsSync(i)){e.status(404).json({error:"Test not found."});return}let a=Oe(o,y),s;try{s=await ra(i,$e,a)}catch(f){e.status(400).send({error:f.message});return}let l=_w(),c=Kt.parse({...s,name:r.name,id:l}),{stepsToSave:d}=await Yt({stepLists:{steps:s.steps,beforeSteps:s.beforeSteps,afterSteps:s.afterSteps},createNewCacheIds:!0,cacheCreationParams:{testId:l,orgId:Sr()}}),p=Fn({fileType:Ee.TEST,...c,beforeSteps:d.beforeSteps??void 0,steps:d.steps,afterSteps:d.afterSteps??void 0}),m=eo.dirname(i),u=eo.join(m,`${r.name}.${Ot.TEST}`),h=oM.stringify(p);Nw.writeFileSync(u,h,"utf-8");let g={relativeFilePath:eo.relative(o.rootDir,u)};gi.track({type:"test_editor:test_create"}),e.status(201).json(g)}));var Fw=yr;var Ia=class{async prepareGoldenScreenshotForComparison(e,t,r){return await new Yo(me(),!1).prepareGoldenScreenshotForComparison(e,t,r)}};async function Hw(n){let{momenticServerUrl:e,apiKey:t,serverPort:r,staticDir:o,devicePixelRatio:i,version:a,logger:s=$e,alwaysSaveCache:l,noCache:c}=n;yw(a),e&&bw(e),await vw(t);let d=Sr(),p=Ll();gi.identify({user_id:p,org_id:d}),s.debug({params:n,orgId:d,userId:p},"Desktop server init and api key check done");let m=dM(o,r,s),u=`http://localhost:${r}`;y.info(`Desktop server is running at ${u}`),await new Promise(x=>{try{m.listen(r,()=>{s.info(`Desktop server is running at ${u}`),x()})}catch(C){C.message.includes("EADDRINUSE")?jw(r):y.error(`An unexpected error occurred while starting the server: ${C.message}`),process.exit(1)}});let g={type:"API_KEY",baseUrl:Pl(),apiKey:t,logger:s},f=async()=>{let x=me();return new ti(x.config.ai?.agentConfig,g)},S=async()=>new ni(g,await f()),b=new lt(g),w=new Ol(b,Sr()),v=new Ia;gw({baseServer:m,generatorFactory:f,enricherFactory:S,cacheStorageFactory:async()=>{let x=me(),C=await Xo(s,b,x);return ri({client:b,gitMetadata:C,alwaysSaveCache:l,noCache:c})},flagStoreFactory:async x=>{let C=me();return new Jo(C.config)},settingsFactory:async()=>{let x=me();return{ai:{},browser:{},...x.config}},storage:w,logger:s,devicePixelRatio:i,authorization:g,visualDiffScreenshotStorage:v,analytics:gi})}var zw="25mb";function dM(n,e,t){let r=Bw();r.use(iM()),r.use(Uw.json({limit:zw})),r.use(Uw.urlencoded({extended:!1,limit:zw}));let o=lM();if(o.use("/tests",Fw),o.use("/modules",Lw),o.use("/environments",Ew),o.use("/projects",Ow),o.use("/labels",Iw),o.use("/settings",Mw),o.use("/identify",Rw),r.use("/api",o),r.use((a,s,l)=>{a.path!=="/healthcheck"&&!a.path.startsWith("/assets")&&t.debug({url:a.url,path:a.path,query:a.query,method:a.method,body:a.body,headers:a.rawHeaders,client:a.ip},"Received desktop-server request"),s.on("close",()=>{s.statusCode>=400&&t.error({url:a.url,method:a.method,statusCode:s.statusCode},"Request completed in error")}),l()}),r.use((a,s,l,c)=>{if(a instanceof Error&&a.message.includes("BadRequestError: request aborted")){l.status(400).send("Client disconnected");return}t.error({stack:a.stack,msg:a.message,err:a,url:s.url,method:s.method},"Unhandled exception leading to 500 on desktop-server"),y.error(`Oh no! We seem to have hit an unexpected snag \u{1F61E}. Please contact Momentic Support with the following error: ${a.message}
3613
3613
  ${a.stack}`),l.status(500).send("Internal Server Error")}),n){let a=Bw.static(n,{setHeaders:s=>{s.setHeader("Cache-Control","no-cache")}});r.use("/",a),r.use("*",a)}let i=cM.createServer(r);return i.once("error",a=>{"code"in a&&a.code==="EADDRINUSE"?(jw(e),process.exit(1)):console.error("An unexpected server error occurred:",a.message)}),i}sM.setMaxListeners(50);process.on("warning",n=>{$e.warn({err:n},`Node warning received on desktop-server: ${n.message}`)});process.on("uncaughtException",n=>{$e.error({err:n},"Uncaught exception leading to exit on desktop-server"),y.error(`Oh no! The Momentic desktop app encountered a fatal error \u{1F61E}. Error logs: ${n.message}`)});process.on("unhandledRejection",(n,e)=>{$e.error({reason:`${n}`,promise:`${e}`,stack:n?.stack},"Uncaught exception leading to exit on desktop-server (promise rejection)"),y.error(`Oh no! The Momentic desktop app encountered an asynchronous error \u{1F61E}. Error logs: ${n}`)});function jw(n){y.error(aM`Port ${n} is already in use by another process. Please close the other process and try again.
3614
3614
  Using Bash on MacOS or Linux:
3615
3615
  lsof -t -i :58888 | xargs kill -9
@@ -3618,27 +3618,27 @@ ${a.stack}`),l.status(500).send("Internal Server Error")}),n){let a=Bw.static(n,
3618
3618
  for /f "tokens=5" %a in ('netstat -ano ^| findstr :58888') do taskkill /PID %a /F
3619
3619
  `)}import EN from"events";import Xl from"fs";import CN from"open";import Jl from"path";import{fileURLToPath as RN}from"url";import PM from"diff-lines";import{gt as LM}from"semver";import{execSync as pM}from"child_process";import{platform as uM}from"os";function zp(){return $w()?(y.dimmed("Setting device pixel ratio to 2 automatically since a Mac OS Retina screen was detected."),y.dimmed(`If you are using a low pixel-density monitor, you should manually set --pixel-ratio to 1 to avoid incorrect viewport calculations. Confirm your device's pixel-ratio at https://www.mydevice.io.
3620
3620
  `),2):(y.dimmed("Setting device pixel ratio to 1."),y.dimmed(`If you are using Momentic on a high-pixel density (HiDPI) monitor, relaunch with the --pixel-ratio option to avoid incorrect viewport calculations. Confirm your device's pixel-ratio at https://www.mydevice.io.
3621
- l.`),1)}function $w(){return uM()==="darwin"&&pM("system_profiler SPDisplaysDataType").toString().includes("Retina")}function Hp(n){$w()&&n===1&&(y.warn("If you are using Momentic on a Retina screen, relaunch with the --pixel-ratio option to avoid incorrect viewport calculations."),y.warn("Confirm your device's pixel-ratio at https://www.mydevice.io."))}import mM from"@actions/exec";import hM from"@actions/io";import gM from"quote";import fM from"string-argv";async function Gw(n,e=!0){let t=fM(n),r=await hM.which(t[0],!0),o=t.slice(1),i=mM.exec(gM(r),o,{delay:100});if(e)return i}import{existsSync as SM,statSync as yM}from"fs";var to=!!process.env.CI||!!process.env.GITHUB_ACTIONS||!!process.env.GITHUB_RUN_ID||!!process.env.GITLAB_CI||!!process.env.CI_COMMIT_SHA||!!process.env.JENKINS_URL||!!process.env.BUILD_NUMBER||!!process.env.JENKINS_HOME||!!process.env.CIRCLECI||!!process.env.CIRCLE_BUILD_NUM||!!process.env.TRAVIS||!!process.env.TRAVIS_BUILD_NUMBER||!!process.env.BITBUCKET_BUILD_NUMBER||!!process.env.BITBUCKET_COMMIT||!!process.env.CODEBUILD_BUILD_ID||!!process.env.TF_BUILD||!!process.env.BUILD_BUILDID||!!process.env.AGENT_ID||!!process.env.BUILDER_SA_EMAIL||!!process.env.HEROKU_TEST_RUN_ID||!!process.env.CI_NODE_INDEX||!!process.env.TEAMCITY_VERSION||!!process.env.BUILD_VCS_NUMBER||!!process.env.BUILDKITE||!!process.env.BUILDKITE_BUILD_NUMBER||!!process.env.APPVEYOR||!!process.env.APPVEYOR_BUILD_NUMBER||!!process.env.DRONE||!!process.env.DRONE_BUILD_NUMBER||!!process.env.SHIPPABLE||!!process.env.BUILD_URL||!!process.env.SEMAPHORE||!!process.env.SEMAPHORE_EXECUTABLE_UUID||!!process.env.WOODPECKER||!!process.env.CI_BUILD_NUMBER||!!process.env.WERCKER_MAIN_PIPELINE_STARTED||!!process.env.BUDDY_EXECUTION_ID;function Ww(n){try{return SM(n)&&yM(n).isDirectory()}catch(e){return y.error({err:e},`Error reading path ${n} during directory existence check`),!1}}import bM from"csv-parser";import{createReadStream as wM}from"fs";function jp(n){return new Promise((e,t)=>{let r=[];wM(n).pipe(bM()).on("data",o=>r.push(o)).on("end",()=>e(r)).on("error",o=>t(o))})}import Ml from"semver";import{z as Nl}from"zod";var fn="2.0.1",vM="https://registry.npmjs.org/momentic",TM=Nl.object({versions:Nl.record(Nl.string(),Nl.unknown()).optional()});async function Vw(n){try{await xM(n)}catch(e){y.warn({err:e},"Failed to check CLI version against NPM servers")}}async function xM(n){if(!fn){n.warn("Unable to check CLI version because CLI_VERSION is not set");return}let e;for(let r=0;r<2;r++)try{let o=await D(fetch(vM),{milliseconds:5e3});if(!o.ok)throw new Error(`Got error status code ${o.statusText}`);let i=await o.json();e=TM.parse(i).versions;break}catch(o){n.warn({err:o},"Failed to fetch npm registry data")}if(!e){n.warn("Failed to fetch npm registry data. Skipping version check.");return}let t;for(let r of Object.keys(e))Ml.valid(r)&&(!t||Ml.gt(r,t))&&Ml.gt(r,fn)&&Ml.lt(r,"2.0.0")&&!r.includes("alpha")&&(t=r);t&&(y.warn(`Update available: v${fn} -> v${t}`),y.warn("This version may be missing critical fixes, features, and security updates."),y.warn(`Run "npx momentic@${t} -V" to update`))}import{existsSync as CM,mkdirSync as RM,statSync as AM}from"fs";import{dirname as IM}from"path";import Kw from"readline/promises";import{hostname as EM}from"os";var ne=Il({app:"cli",clientToken:"pub7eb923f18fb3f1d42ac5eba8c5ea13a5",hostname:EM(),disableConsoleLogs:!0}).child({version:"2.0.1"});var $p=!1,Yw=(()=>{try{return AM("/.dockerenv"),!0}catch{return!1}})();async function gt(n,e){if(to||$p||Yw)return!0;ne.flush(),await new Promise(a=>setTimeout(a,500));let t=Kw.createInterface({input:process.stdin,output:process.stdout}),r=n.split("."),o;if(r.length===1)o=n;else{let a=`${r.slice(0,r.length-1).join(".").trim()}.`;e?y.warn(a):y.log(a),o=r[r.length-1].trim()}let i=await t.question(`${o} ('y' for yes / n for no / 'A' to accept all) `);return t.close(),i==="A"?($p=!0,setTimeout(()=>{$p=!1},3e3),!0):i.toLowerCase()==="y"}async function Gp(n){let e=IM(n);return Ww(e)?CM(n)?gt(`File '${qw(n)}' already exists. Overwrite existing content?`,!0):!0:await gt(`Directory '${qw(e)}' doesn't exist. Create it now?`,!0)?(RM(e,{recursive:!0}),!0):!1}function qw(n){return n.replace(/(\s+)/g,"\\$1")}async function Jw(n,e){if(to||Yw)return e;let t=Kw.createInterface({input:process.stdin,output:process.stdout}),r=await t.question(`${n} `);return t.close(),r.trim()||e}async function Xw({test:n,fragment:e,entities:t,client:r,logger:o,yes:i}){LM(e.schemaVersion,Fe)&&(y.error(`This version of the CLI does not support the schema version of the fragment (${e.schemaVersion}). Please update to the latest version of the CLI and retry this command.`),process.exit(1)),Dg(e.steps).forEach(g=>{t.modules[g]||(y.error(`The test patch contains a module with id ${g} that could not be found in the current project. This suggests that either this test patch or your local file system may be out of date.`),process.exit(1))}),e.createdAt.getTime()<Date.now()-7*24*60*60*1e3&&!i&&!await gt("The test patch you are applying is more than 7 days old. Are you sure you want to continue?",!0)&&process.exit(1);let s=n.lastModified.getTime();e.createdAt.getTime()+60*60*1e3<s&&!i&&!await gt("The test patch you are applying was created before the test was last updated. Are you sure you want to continue?",!0)&&process.exit(1);let l=Gr(n.fullFilePath,o,t),c=l.steps;if(!Array.isArray(c))throw new Error(`Test ${n.fullFilePath} is missing steps array`);let d,p;if(e.schemaVersion!==Fe){let{steps:g,newVersion:f}=await Qi({metadata:{id:e.id,schemaVersion:e.schemaVersion},steps:e.steps,logger:y});d=f,p=Ae.array().parse(g)}else p=Ae.array().parse(e.steps);let{stepsToSave:m,moduleUpdates:u}=await Yt({stepLists:{steps:p}});m.beforeSteps=l.beforeSteps??void 0,m.afterSteps=l.afterSteps??void 0;let h=PM(JSON.stringify(c,void 0,2),JSON.stringify(m,void 0,2),{n_surrounding:5});y.dimmed("=".repeat(30)),y.dimmed(h),y.dimmed("=".repeat(30)),y.dimmed(""),d&&y.warn(`If this patch is applied, your test will also be automatically upgraded to the latest schema version (${d}). Schema upgrades have no impact on functionality, although you may notice minor differences in the test YAML.`),!i&&!await gt("Do you want to apply this patch?")&&(y.dimmed("Cancelled."),process.exit(1)),Bn({relativeTestPath:n.relativePath,steps:m,schemaVersion:d??e.schemaVersion,project:t.project}),y.success("Patch applied successfully."),await r.patchTestFragment(e.id,{applied:!0,appliedAt:new Date})}import{randomUUID as nu}from"crypto";var zt=" ".repeat(6);import Sv from"chalk";import{Argument as no,Option as ke}from"@commander-js/extra-typings";import{validateHeaderValue as OM}from"http";import{cpus as Zw}from"os";import{parse as due}from"yaml";import{z as V}from"zod";var _l=58888,Wp=30*60*1e3,Gn=new ke("--api-key <key>","API key for authentication. If not supplied, attempts to read the MOMENTIC_API_KEY env var."),Wn=new ke("--server <server>","Momentic server to use. Leave unchanged unless using Momentic on-premise."),ro=new ke("-y, --yes","Skip all confirmation prompts."),Vp=new ke("-w, --wait","Wait for tests to finish running before exiting. Only applicable when running tests remotely").implies({remote:!0}),qp=new ke("--wait-timeout <waitTimeout>",`The maximum number of seconds to wait for tests to complete. Only applicable when the --wait option is specified. Defaults to ${Wp/1e3} seconds.`),Dl=new ke("--custom-headers <customHeaders...>","Specify custom headers in the form HEADER=VALUE to be sent with each request during the test. Multiple entries can be provided."),ev=new ke("--reporter <reporter>","Output report files in a standardized format to a local directory. See the --reporter-dir flag for information on the output directory.").choices(Object.values(Gi)),tv=new ke("--reporter-dir <reporterDir>","Output directory to store report files. Relative paths are resolved relative to the project root, which is defined by the detected momentic.config.yaml. Defaults to 'reports' if unset."),Kp=new ke("--output-dir <outputDir>","[Alpha] Output directory to store run artifacts such as screenshots, results, and logs. Relative paths are resolved relative to the project root, which is defined by the detected momentic.config.yaml. This directory will be cleared at the start of execution."),nv=new ke("--upload-results","Upload test results to Momentic Cloud. By default, this option is disabled."),rv=new ke("--include <includePatterns...>","Only include tests that match the provided regex patterns. Multiple patterns can be provided. The patterns will be matched against the test file paths and the pattern only needs to match a part of the path for the test to be included."),ov=new ke("--exclude <excludePatterns...>","The inverted version of --include: a test that matches any of the provided exclusion patterns will be excluded from running."),Yp=new ke("--pixel-ratio <pixelRatio>","Device pixel ratio of your screen or monitor. Mac OS Retina displays and machines marketed as 'HiDPI' should set this to 2. Visit https://www.mydevice.io/ to find your device's pixel ratio."),iv=new ke("--port <port>",`Port to run the app on. Defaults to ${_l}.`),Jp=new ke("--input-csv <inputCsv>","Path to a CSV file on disk where each row represents a set of inputs that will be made available to all tests that are ran. The first line of the CSV must be the input names."),Fl=new ke("--env <env>","Name of the environment to use when running tests."),Ul=new ke("--url-override <urlOverride>","Fully qualified url (e.g. https://www.google.com) to start all tests from. Overrides any default starting url set from the test or environment."),av=new ke("--shard-index <shardIndex>","The index of the shard to run tests for. Defaults to 1.").default(1).argParser(n=>parseInt(n,10)),kn=new ke("-c, --config <configPath>","Absolute or relative path to a Momentic configuration file (*.momentic.config.yaml)"),Xp=new ke("-f, --filter <filter>","Run tests within the project that has a name equal to the filter provided. This option cannot be used together with file path or directory arguments, but substring matches are allowed."),sv=new ke("--shard-count <shardCount>","The number of shards that tests are being run on. Defaults to 1.").default(1).argParser(n=>parseInt(n,10)),lv=new ke("--fix","Attempt to fix any issues found. This option will write changes to your local file system."),Zp=new ke("--save-cache","Always save updated step caches after successful test runs. By default, caches are not saved when running on the protected branches configured in the momentic.config.yaml."),Qp=new ke("--disable-cache","Disable caching of test results. This will cause all tests to be re-run every time."),cv=new no("<tests...>",`One or more test paths to queue on Momentic Cloud.
3621
+ l.`),1)}function $w(){return uM()==="darwin"&&pM("system_profiler SPDisplaysDataType").toString().includes("Retina")}function Hp(n){$w()&&n===1&&(y.warn("If you are using Momentic on a Retina screen, relaunch with the --pixel-ratio option to avoid incorrect viewport calculations."),y.warn("Confirm your device's pixel-ratio at https://www.mydevice.io."))}import mM from"@actions/exec";import hM from"@actions/io";import gM from"quote";import fM from"string-argv";async function Gw(n,e=!0){let t=fM(n),r=await hM.which(t[0],!0),o=t.slice(1),i=mM.exec(gM(r),o,{delay:100});if(e)return i}import{existsSync as SM,statSync as yM}from"fs";var fi=!!process.env.CI||!!process.env.GITHUB_ACTIONS||!!process.env.GITHUB_RUN_ID||!!process.env.GITLAB_CI||!!process.env.CI_COMMIT_SHA||!!process.env.JENKINS_URL||!!process.env.BUILD_NUMBER||!!process.env.JENKINS_HOME||!!process.env.CIRCLECI||!!process.env.CIRCLE_BUILD_NUM||!!process.env.TRAVIS||!!process.env.TRAVIS_BUILD_NUMBER||!!process.env.BITBUCKET_BUILD_NUMBER||!!process.env.BITBUCKET_COMMIT||!!process.env.CODEBUILD_BUILD_ID||!!process.env.TF_BUILD||!!process.env.BUILD_BUILDID||!!process.env.AGENT_ID||!!process.env.BUILDER_SA_EMAIL||!!process.env.HEROKU_TEST_RUN_ID||!!process.env.CI_NODE_INDEX||!!process.env.TEAMCITY_VERSION||!!process.env.BUILD_VCS_NUMBER||!!process.env.BUILDKITE||!!process.env.BUILDKITE_BUILD_NUMBER||!!process.env.APPVEYOR||!!process.env.APPVEYOR_BUILD_NUMBER||!!process.env.DRONE||!!process.env.DRONE_BUILD_NUMBER||!!process.env.SHIPPABLE||!!process.env.BUILD_URL||!!process.env.SEMAPHORE||!!process.env.SEMAPHORE_EXECUTABLE_UUID||!!process.env.WOODPECKER||!!process.env.CI_BUILD_NUMBER||!!process.env.WERCKER_MAIN_PIPELINE_STARTED||!!process.env.BUDDY_EXECUTION_ID;function Ww(n){try{return SM(n)&&yM(n).isDirectory()}catch(e){return y.error({err:e},`Error reading path ${n} during directory existence check`),!1}}import bM from"csv-parser";import{createReadStream as wM}from"fs";function jp(n){return new Promise((e,t)=>{let r=[];wM(n).pipe(bM()).on("data",o=>r.push(o)).on("end",()=>e(r)).on("error",o=>t(o))})}import Ml from"semver";import{z as Nl}from"zod";var fn="2.0.2",vM="https://registry.npmjs.org/momentic",TM=Nl.object({versions:Nl.record(Nl.string(),Nl.unknown()).optional()});async function Vw(n){try{await xM(n)}catch(e){y.warn({err:e},"Failed to check CLI version against NPM servers")}}async function xM(n){if(!fn){n.warn("Unable to check CLI version because CLI_VERSION is not set");return}let e;for(let r=0;r<2;r++)try{let o=await D(fetch(vM),{milliseconds:5e3});if(!o.ok)throw new Error(`Got error status code ${o.statusText}`);let i=await o.json();e=TM.parse(i).versions;break}catch(o){n.warn({err:o},"Failed to fetch npm registry data")}if(!e){n.warn("Failed to fetch npm registry data. Skipping version check.");return}let t;for(let r of Object.keys(e))Ml.valid(r)&&(!t||Ml.gt(r,t))&&Ml.gt(r,fn)&&Ml.lt(r,"2.0.0")&&!r.includes("alpha")&&(t=r);t&&(y.warn(`Update available: v${fn} -> v${t}`),y.warn("This version may be missing critical fixes, features, and security updates."),y.warn(`Run "npx momentic@${t} -V" to update`))}import{existsSync as CM,mkdirSync as RM,statSync as AM}from"fs";import{dirname as IM}from"path";import Kw from"readline/promises";import{hostname as EM}from"os";var ne=Il({app:"cli",clientToken:"pub7eb923f18fb3f1d42ac5eba8c5ea13a5",hostname:EM(),disableConsoleLogs:!0}).child({version:"2.0.2"});var $p=!1,Yw=(()=>{try{return AM("/.dockerenv"),!0}catch{return!1}})();async function gt(n,e){if(fi||$p||Yw)return!0;ne.flush(),await new Promise(a=>setTimeout(a,500));let t=Kw.createInterface({input:process.stdin,output:process.stdout}),r=n.split("."),o;if(r.length===1)o=n;else{let a=`${r.slice(0,r.length-1).join(".").trim()}.`;e?y.warn(a):y.log(a),o=r[r.length-1].trim()}let i=await t.question(`${o} ('y' for yes / n for no / 'A' to accept all) `);return t.close(),i==="A"?($p=!0,setTimeout(()=>{$p=!1},3e3),!0):i.toLowerCase()==="y"}async function Gp(n){let e=IM(n);return Ww(e)?CM(n)?gt(`File '${qw(n)}' already exists. Overwrite existing content?`,!0):!0:await gt(`Directory '${qw(e)}' doesn't exist. Create it now?`,!0)?(RM(e,{recursive:!0}),!0):!1}function qw(n){return n.replace(/(\s+)/g,"\\$1")}async function Jw(n,e){if(fi||Yw)return e;let t=Kw.createInterface({input:process.stdin,output:process.stdout}),r=await t.question(`${n} `);return t.close(),r.trim()||e}async function Xw({test:n,fragment:e,entities:t,client:r,logger:o,yes:i}){LM(e.schemaVersion,Fe)&&(y.error(`This version of the CLI does not support the schema version of the fragment (${e.schemaVersion}). Please update to the latest version of the CLI and retry this command.`),process.exit(1)),Dg(e.steps).forEach(g=>{t.modules[g]||(y.error(`The test patch contains a module with id ${g} that could not be found in the current project. This suggests that either this test patch or your local file system may be out of date.`),process.exit(1))}),e.createdAt.getTime()<Date.now()-7*24*60*60*1e3&&!i&&!await gt("The test patch you are applying is more than 7 days old. Are you sure you want to continue?",!0)&&process.exit(1);let s=n.lastModified.getTime();e.createdAt.getTime()+60*60*1e3<s&&!i&&!await gt("The test patch you are applying was created before the test was last updated. Are you sure you want to continue?",!0)&&process.exit(1);let l=Gr(n.fullFilePath,o,t),c=l.steps;if(!Array.isArray(c))throw new Error(`Test ${n.fullFilePath} is missing steps array`);let d,p;if(e.schemaVersion!==Fe){let{steps:g,newVersion:f}=await Qi({metadata:{id:e.id,schemaVersion:e.schemaVersion},steps:e.steps,logger:y});d=f,p=Ae.array().parse(g)}else p=Ae.array().parse(e.steps);let{stepsToSave:m,moduleUpdates:u}=await Yt({stepLists:{steps:p}});m.beforeSteps=l.beforeSteps??void 0,m.afterSteps=l.afterSteps??void 0;let h=PM(JSON.stringify(c,void 0,2),JSON.stringify(m,void 0,2),{n_surrounding:5});y.dimmed("=".repeat(30)),y.dimmed(h),y.dimmed("=".repeat(30)),y.dimmed(""),d&&y.warn(`If this patch is applied, your test will also be automatically upgraded to the latest schema version (${d}). Schema upgrades have no impact on functionality, although you may notice minor differences in the test YAML.`),!i&&!await gt("Do you want to apply this patch?")&&(y.dimmed("Cancelled."),process.exit(1)),Bn({relativeTestPath:n.relativePath,steps:m,schemaVersion:d??e.schemaVersion,project:t.project}),y.success("Patch applied successfully."),await r.patchTestFragment(e.id,{applied:!0,appliedAt:new Date})}import{randomUUID as nu}from"crypto";var zt=" ".repeat(6);import Sv from"chalk";import{Argument as to,Option as ke}from"@commander-js/extra-typings";import{validateHeaderValue as OM}from"http";import{cpus as Zw}from"os";import{parse as due}from"yaml";import{z as q}from"zod";var _l=58888,Wp=30*60*1e3,Gn=new ke("--api-key <key>","API key for authentication. If not supplied, attempts to read the MOMENTIC_API_KEY env var."),Wn=new ke("--server <server>","Momentic server to use. Leave unchanged unless using Momentic on-premise."),no=new ke("-y, --yes","Skip all confirmation prompts.").env("CI"),Vp=new ke("-w, --wait","Wait for tests to finish running before exiting. Only applicable when running tests remotely").implies({remote:!0}),qp=new ke("--wait-timeout <waitTimeout>",`The maximum number of seconds to wait for tests to complete. Only applicable when the --wait option is specified. Defaults to ${Wp/1e3} seconds.`),Dl=new ke("--custom-headers <customHeaders...>","Specify custom headers in the form HEADER=VALUE to be sent with each request during the test. Multiple entries can be provided."),ev=new ke("--reporter <reporter>","Output report files in a standardized format to a local directory. See the --reporter-dir flag for information on the output directory.").choices(Object.values(Gi)),tv=new ke("--reporter-dir <reporterDir>","Output directory to store report files. Relative paths are resolved relative to the project root, which is defined by the detected momentic.config.yaml. Defaults to 'reports' if unset."),Kp=new ke("--output-dir <outputDir>","[Alpha] Output directory to store run artifacts such as screenshots, results, and logs. Relative paths are resolved relative to the project root, which is defined by the detected momentic.config.yaml. This directory will be cleared at the start of execution."),nv=new ke("--upload-results","Upload test results to Momentic Cloud. By default, this option is disabled."),rv=new ke("--include <includePatterns...>","Only include tests that match the provided regex patterns. Multiple patterns can be provided. The patterns will be matched against the test file paths and the pattern only needs to match a part of the path for the test to be included."),ov=new ke("--exclude <excludePatterns...>","The inverted version of --include: a test that matches any of the provided exclusion patterns will be excluded from running."),Yp=new ke("--pixel-ratio <pixelRatio>","Device pixel ratio of your screen or monitor. Mac OS Retina displays and machines marketed as 'HiDPI' should set this to 2. Visit https://www.mydevice.io/ to find your device's pixel ratio."),iv=new ke("--port <port>",`Port to run the app on. Defaults to ${_l}.`),Jp=new ke("--input-csv <inputCsv>","Path to a CSV file on disk where each row represents a set of inputs that will be made available to all tests that are ran. The first line of the CSV must be the input names."),Fl=new ke("--env <env>","Name of the environment to use when running tests."),Ul=new ke("--url-override <urlOverride>","Fully qualified url (e.g. https://www.google.com) to start all tests from. Overrides any default starting url set from the test or environment."),av=new ke("--shard-index <shardIndex>","The index of the shard to run tests for. Defaults to 1.").default(1).argParser(n=>parseInt(n,10)),kn=new ke("-c, --config <configPath>","Absolute or relative path to a Momentic configuration file (*.momentic.config.yaml)"),Xp=new ke("-f, --filter <filter>","Run tests within the project that has a name equal to the filter provided. This option cannot be used together with file path or directory arguments, but substring matches are allowed."),sv=new ke("--shard-count <shardCount>","The number of shards that tests are being run on. Defaults to 1.").default(1).argParser(n=>parseInt(n,10)),lv=new ke("--fix","Attempt to fix any issues found. This option will write changes to your local file system."),Zp=new ke("--save-cache","Always save updated step caches after successful test runs. By default, caches are not saved when running on the protected branches configured in the momentic.config.yaml.").env("CI"),Qp=new ke("--disable-cache","Disable caching of test results. This will cause all tests to be re-run every time."),cv=new to("<tests...>",`One or more test paths to queue on Momentic Cloud.
3622
3622
 
3623
- A test path is a lowercased version of your test name where spaces are replaced with dashes: 'npx momentic pull hello-world'.`),dv=new no("<tests...>",`One or more test paths to import from Momentic Cloud.
3623
+ A test path is a lowercased version of your test name where spaces are replaced with dashes: 'npx momentic pull hello-world'.`),dv=new to("<tests...>",`One or more test paths to import from Momentic Cloud.
3624
3624
 
3625
- A test path is a lowercased version of your test name where spaces are replaced with dashes: 'npx momentic import hello-world'.`).argOptional(),pv=new no("<tests...>","One or more test file path or folders that exist on the local machine: 'npx momentic run hello-world.test.yaml'.").argOptional(),uv=new no("<suites...>",`One or more suite paths that exist on Momentic Cloud.
3625
+ A test path is a lowercased version of your test name where spaces are replaced with dashes: 'npx momentic import hello-world'.`).argOptional(),pv=new to("<tests...>","One or more test file path or folders that exist on the local machine: 'npx momentic run hello-world.test.yaml'.").argOptional(),uv=new to("<suites...>",`One or more suite paths that exist on Momentic Cloud.
3626
3626
 
3627
- The suite path is a lowercased version of your suite name where spaces and special characters are replaced with dashes, such as 'production-tests'.`),hue=new no("<envs...>","One or more environment names to push").argOptional(),mv=new no("<resultsPath>","Path to a directory that contains on or more test results archives.").argRequired(),hv=new no("<results>","Path to the results archive.").argRequired(),Qw=V.object({apiKey:V.preprocess(n=>n!==void 0?n:process.env.MOMENTIC_API_KEY,V.string()),server:V.string().default("https://api.momentic.ai"),config:V.string().optional(),filter:V.string().optional(),yes:V.preprocess(n=>to?!0:n,V.boolean().optional()),fix:V.boolean().optional(),pixelRatio:V.coerce.number().optional(),port:V.coerce.number().default(_l).optional(),wait:V.preprocess(n=>!!n,V.boolean()).optional(),waitTimeout:V.coerce.number().optional(),start:V.string().optional(),waitOn:V.string().optional(),waitOnTimeout:V.coerce.number().default(60).optional(),customHeaders:V.string().array().optional(),env:V.string().optional(),urlOverride:V.string().url().optional(),all:V.boolean().optional(),parallel:V.coerce.number().optional(),retries:V.coerce.number().optional(),shardIndex:V.coerce.number().optional(),shardCount:V.coerce.number().optional(),inputCsv:V.string().optional(),updateGoldenFiles:V.boolean().optional().default(!1),tests:V.array(V.string()).optional(),suites:V.array(V.string()).optional(),paths:V.array(V.string()).optional(),envs:V.array(V.string()).optional(),include:V.array(V.string()).optional(),exclude:V.array(V.string()).optional(),labels:V.array(V.string()).optional(),reporter:V.nativeEnum(Gi).optional(),reporterDir:V.string().optional(),outputDir:V.string().optional(),uploadResults:V.boolean().optional(),saveCache:V.boolean().optional(),disableCache:V.boolean().optional()}),Sn=async n=>{let e={},t;try{let r=Object.assign(e,Qw.partial().parse(n));t=Qw.parse(r)}catch(r){y.error(`Error parsing command line arguments: ${r.message}`),process.exit(1)}try{kM(t)}catch(r){y.error(`Invalid command line arguments: ${r.message}`),process.exit(1)}return t};var kM=n=>{for(let[e,t]of Object.entries(n))switch(e){case"shardIndex":if(!n.shardCount)throw new Error("The --shard-count flag must be provided alongside --shard-index");if(n.shardCount&&n.shardIndex&&n.shardIndex>n.shardCount)throw new Error("Shard index cannot be greater than shard count");if(n.shardIndex!==void 0&&n.shardIndex<1)throw new Error("Shard index must be greater than 0");break;case"waitTimeout":case"pixelRatio":try{n[e]=V.number().int().optional().parse(t)}catch{throw new Error(`Invalid ${e} provided does not parse a number: ${t}`)}break;case"urlOverride":if(t===void 0)break;try{V.string().url().parse(t)}catch(r){throw new Error(`Invalid URL provided for ${e}`,{cause:r})}break;case"server":if(typeof t!="string")throw new Error(`Expected a string for ${e}`);if(!t.startsWith("http"))throw new Error("--server option must be a fully qualified URL beginning with http");break;case"parallel":if(t===void 0)break;if(typeof t!="number"||isNaN(t))throw new Error(`Expected a number for ${e}`);Zw().length<t*2&&y.warn(`You requested to run tests in parallel ${t} at a time on a machine with ${Zw().length} cores. This may cause performance issues and test failures as Chrome requires at least 2 cores per browser instance.`);break;default:break}};function Bl(n){if(n===void 0)return;let e={};for(let t of n){let r=t.indexOf("=");if(r===-1)throw new Error(`Header value pair does not contain '=': ${t}`);let o=t.slice(0,r),i=t.slice(r+1);OM(o,i),e[o]=i}return e}async function eu(n){let e=process.versions.node,t=parseInt(e.split(".")[0]);(isNaN(t)||t<18)&&(y.error(`Node.js version 18 or higher is required to run the CLI. Detected: ${process.versions.node}.`),process.exit(1)),y.debug(`Identified node version ${e}`);let r=await n.client.getAuthInfo();return y.debug("Got auth info from API"),r}import{Console as gv}from"console";import{format as Pa}from"util";var tu=class extends Error{constructor(e,t,r){let o=Error.stackTraceLimit;r&&(Error.stackTraceLimit=Math.max(r,o||10)),super(e),Error.captureStackTrace&&Error.captureStackTrace(this,t),Error.stackTraceLimit=o}},zl=class n extends gv{_buffer=[];_groupDepth=0;Console=gv;constructor(){super({write:e=>(n.write(this._buffer,"log",e),!0)})}static write(e,t,r,o=2){let i=new tu(void 0,n.write).stack;if(!i)return e;let a=i.split(`
3627
+ The suite path is a lowercased version of your suite name where spaces and special characters are replaced with dashes, such as 'production-tests'.`),hue=new to("<envs...>","One or more environment names to push").argOptional(),mv=new to("<resultsPath>","Path to a directory that contains on or more test results archives.").argRequired(),hv=new to("<results>","Path to the results archive.").argRequired(),Qw=q.object({apiKey:q.preprocess(n=>n!==void 0?n:process.env.MOMENTIC_API_KEY,q.string()),server:q.string().default("https://api.momentic.ai"),config:q.string().optional(),filter:q.string().optional(),yes:q.boolean().optional(),fix:q.boolean().optional(),pixelRatio:q.coerce.number().optional(),port:q.coerce.number().default(_l).optional(),wait:q.preprocess(n=>!!n,q.boolean()).optional(),waitTimeout:q.coerce.number().optional(),start:q.string().optional(),waitOn:q.string().optional(),waitOnTimeout:q.coerce.number().default(60).optional(),customHeaders:q.string().array().optional(),env:q.string().optional(),urlOverride:q.string().url().optional(),all:q.boolean().optional(),parallel:q.coerce.number().optional(),retries:q.coerce.number().optional(),shardIndex:q.coerce.number().optional(),shardCount:q.coerce.number().optional(),inputCsv:q.string().optional(),updateGoldenFiles:q.boolean().optional().default(!1),tests:q.array(q.string()).optional(),suites:q.array(q.string()).optional(),paths:q.array(q.string()).optional(),envs:q.array(q.string()).optional(),include:q.array(q.string()).optional(),exclude:q.array(q.string()).optional(),labels:q.array(q.string()).optional(),reporter:q.nativeEnum(Gi).optional(),reporterDir:q.string().optional(),outputDir:q.string().optional(),uploadResults:q.boolean().optional(),saveCache:q.boolean().optional(),disableCache:q.boolean().optional()}),Sn=async n=>{let e={},t;try{let r=Object.assign(e,Qw.partial().parse(n));t=Qw.parse(r)}catch(r){y.error(`Error parsing command line arguments: ${r.message}`),process.exit(1)}try{kM(t)}catch(r){y.error(`Invalid command line arguments: ${r.message}`),process.exit(1)}return t};var kM=n=>{for(let[e,t]of Object.entries(n))switch(e){case"shardIndex":if(!n.shardCount)throw new Error("The --shard-count flag must be provided alongside --shard-index");if(n.shardCount&&n.shardIndex&&n.shardIndex>n.shardCount)throw new Error("Shard index cannot be greater than shard count");if(n.shardIndex!==void 0&&n.shardIndex<1)throw new Error("Shard index must be greater than 0");break;case"waitTimeout":case"pixelRatio":try{n[e]=q.number().int().optional().parse(t)}catch{throw new Error(`Invalid ${e} provided does not parse a number: ${t}`)}break;case"urlOverride":if(t===void 0)break;try{q.string().url().parse(t)}catch(r){throw new Error(`Invalid URL provided for ${e}`,{cause:r})}break;case"server":if(typeof t!="string")throw new Error(`Expected a string for ${e}`);if(!t.startsWith("http"))throw new Error("--server option must be a fully qualified URL beginning with http");break;case"parallel":if(t===void 0)break;if(typeof t!="number"||isNaN(t))throw new Error(`Expected a number for ${e}`);Zw().length<t*2&&y.warn(`You requested to run tests in parallel ${t} at a time on a machine with ${Zw().length} cores. This may cause performance issues and test failures as Chrome requires at least 2 cores per browser instance.`);break;default:break}};function Bl(n){if(n===void 0)return;let e={};for(let t of n){let r=t.indexOf("=");if(r===-1)throw new Error(`Header value pair does not contain '=': ${t}`);let o=t.slice(0,r),i=t.slice(r+1);OM(o,i),e[o]=i}return e}async function eu(n){let e=process.versions.node,t=parseInt(e.split(".")[0]);(isNaN(t)||t<18)&&(y.error(`Node.js version 18 or higher is required to run the CLI. Detected: ${process.versions.node}.`),process.exit(1)),y.debug(`Identified node version ${e}`);let r=await n.client.getAuthInfo();return y.debug("Got auth info from API"),r}import{Console as gv}from"console";import{format as Pa}from"util";var tu=class extends Error{constructor(e,t,r){let o=Error.stackTraceLimit;r&&(Error.stackTraceLimit=Math.max(r,o||10)),super(e),Error.captureStackTrace&&Error.captureStackTrace(this,t),Error.stackTraceLimit=o}},zl=class n extends gv{_buffer=[];_groupDepth=0;Console=gv;constructor(){super({write:e=>(n.write(this._buffer,"log",e),!0)})}static write(e,t,r,o=2){let i=new tu(void 0,n.write).stack;if(!i)return e;let a=i.split(`
3628
3628
  `).slice(o).filter(Boolean).join(`
3629
3629
  `);return e.push({message:r,origin:a,type:t}),e}_log(e,t){n.write(this._buffer,e," ".repeat(this._groupDepth)+t,3)}debug(e,...t){this._log("debug",Pa(e,...t))}error(e,...t){this._log("error",Pa(e,...t))}info(e,...t){this._log("info",Pa(e,...t))}log(e,...t){this._log("log",Pa(e,...t))}warn(e,...t){this._log("warn",Pa(e,...t))}getBuffer(){return this._buffer.length>0?this._buffer:void 0}};function fv(n){let e=globalThis.console,t=new zl;globalThis.console=t;try{n()}finally{let o=t.getBuffer()?.map(i=>i.message).join(`
3630
3630
  `);process.stderr.write(`${o}
3631
- `),globalThis.console=e}}var NM=5;async function Hl({getResults:n,checkDone:e,name:t,timeoutMs:r=Wp}){let o=Date.now(),i=0;for(;Date.now()-o<r;){let a;i>NM&&(y.error(`Failed to fetch ${t} status too many times.`),process.exit(1));try{a=await n(),i=0}catch(c){i++,ne.warn({err:c},"Failed to fetch run status, retrying..."),y.warn({err:c},"Failed to fetch run status, retrying..."),await new Promise(d=>setTimeout(d,1500*i));continue}if(e(a))return a;let l=Math.max(1e4,Math.floor(r/100));await new Promise(c=>setTimeout(c,l))}y.error(`Timeout elapsed waiting for ${t} to complete (${Math.floor(r/1e3)}s).`),process.exit(1)}function Si({results:n,startTime:e,entity:t,getDisplayLine:r,onFailed:o}){let i=n.filter(l=>l.status==="PASSED"),a=n.filter(l=>l.status==="FAILED"),s=n.filter(l=>l.status==="CANCELLED");return fv(()=>{a.forEach(l=>{y.log(""),o(l)}),a.length&&(y.log(""),y.error(`${a.length} ${t}s failed:`),a.forEach(l=>{y.dimmed(r(l))})),s.length&&(y.log(""),y.warn(`${s.length} ${t}s cancelled:`),s.forEach(l=>{y.dimmed(r(l))})),i.length&&(y.log(""),y.success(`${i.length} ${t}s passed:`),i.forEach(l=>{y.dimmed(r(l))})),y.log(""),y.dimmed(`Total time: ${Math.round((Date.now()-e)/1e3)}s`)}),{passed:i.length,failed:a.length,cancelled:s.length}}var jl=(n,e)=>{if(!n.failureDetails||!n.failureReason)return;let t=Za[n.failureDetails?.classification?.reason||n.failureReason],r=n.failureDetails?.classification?.summary||xo[n.failureReason];y.error(e),y.log(`${zt}Reason: ${Sv.red(t)}`),y.log(`${zt}Description: ${Sv.red(r)}`)};async function ru({fix:n,project:e}){let t=Oe(e,y),r=Object.values(t.tests),o={},i={},a=new Set,s={},l=new Set,c=0;for(let p of r)try{let m=Gr(p.fullFilePath,ne,t),u=m.steps;if(!u||u.length===0||!Array.isArray(u)){y.debug(`Test ${p.name} (${p.relativePath}) has no steps, skipping...`);continue}let h=bt.parse(m),g=await Ur(h,u,y),f=!1,S=!1;g.steps=g.steps.map((b,w)=>{if(!b.id)return y.error(`Step ${w} in test '${p.name}' (${p.relativePath}) does not have an ID`),S=!0,b;let v=o[b.id]?.testId,x=o[b.id]?.testRelativePath;if(v){if(c++,S=!0,v===p.id?y.error(`Multiple steps in the test '${p.name}' (${p.relativePath}) have the same ID '${b.id}'`):y.error(`Step ${w} in test '${p.name}' (${p.relativePath}) has the ID ${b.id} which is duplicated in test ${x}`),n)return f=!0,Se.parse({...b,id:nu()})}else o[b.id]={testId:p.id,testRelativePath:p.relativePath};if(b.type!=="PRESET_ACTION")return b;let C=b.command.id,A=i[C]?.testId,N=i[C]?.testRelativePath;if(A){if(c++,S=!0,A===p.id?y.error(`Multiple commands in the test '${p.name}' (${p.relativePath}) have the same ID '${C}'`):y.error(`Command ${w} in test '${p.name}' (${p.relativePath}) has the ID ${C} which is duplicated in test ${N}`),n)return f=!0,Se.parse({...b,command:{...b.command,id:nu()}})}else i[C]={testId:p.id,testRelativePath:p.relativePath};return b}),S&&y.dimmed("=".repeat(80)),f&&n&&(Bn({relativeTestPath:p.relativePath,steps:{beforeSteps:m.beforeSteps,steps:g.steps,afterSteps:m.afterSteps},schemaVersion:Fe,project:e}),a.add(p.fullFilePath))}catch(m){y.error({err:m},`Failed to parse test ${p.name} (${p.relativePath})`);continue}let d=Object.values(t.modules);for(let p of d)try{let m=Un(p.fullFilePath,y),u=m.steps;if(!u||u.length===0||!Array.isArray(u)){y.debug(`Module ${p.name} (${p.relativePath}) has no steps, skipping...`);continue}let h,g;try{let w=await Ur({id:m.moduleId,schemaVersion:m.schemaVersion},m.steps,y);h=w.steps,g=w.newVersion}catch(w){y.error({err:w},`Failed to migrate module ${p.name} (${p.relativePath})`);continue}let f=!1,S=!1,b=h.map((w,v)=>{if(w.type!=="PRESET_ACTION")return w;let x=w.command.id,C=i[x],A=s[x];if(C||A){if(c++,S=!0,A?.moduleId===p.id?y.error(`Multiple commands in module '${p.name}' (${p.relativePath}) have the same ID '${x}'`):C?y.error(`Command in module '${p.name}' (${p.relativePath}) has the ID ${x} which is duplicated in test ${C.testRelativePath}`):y.error(`Command ${v} in module '${p.name}' (${p.relativePath}) has the ID ${x} which is duplicated in module ${A.moduleRelativePath}`),n)return f=!0,{...w,command:{...w.command,id:nu()}}}else s[x]={moduleId:p.id,moduleRelativePath:p.relativePath};return w});S&&y.dimmed("=".repeat(80)),f&&n&&(jr({content:{...m,steps:b},schemaVersion:g,momenticFiles:t,project:e,forceSaveOnNoDiffs:!0}),l.add(p.fullFilePath))}catch(m){y.error({err:m},`Failed to parse module ${p.name} (${p.relativePath})`);continue}return{errors:c,modifiedTestFilePaths:a,modifiedModuleFilePaths:l}}async function yv({fix:n,project:e}){let{errors:t,modifiedTestFilePaths:r,modifiedModuleFilePaths:o}=await ru({fix:n,project:e});t>0?(y.error(`Found errors in ${t} steps`),n?(y.warn(`Modified the following files:
3631
+ `),globalThis.console=e}}var NM=5;async function Hl({getResults:n,checkDone:e,name:t,timeoutMs:r=Wp}){let o=Date.now(),i=0;for(;Date.now()-o<r;){let a;i>NM&&(y.error(`Failed to fetch ${t} status too many times.`),process.exit(1));try{a=await n(),i=0}catch(c){i++,ne.warn({err:c},"Failed to fetch run status, retrying..."),y.warn({err:c},"Failed to fetch run status, retrying..."),await new Promise(d=>setTimeout(d,1500*i));continue}if(e(a))return a;let l=Math.max(1e4,Math.floor(r/100));await new Promise(c=>setTimeout(c,l))}y.error(`Timeout elapsed waiting for ${t} to complete (${Math.floor(r/1e3)}s).`),process.exit(1)}function Si({results:n,startTime:e,entity:t,getDisplayLine:r,onFailed:o}){let i=n.filter(l=>l.status==="PASSED"),a=n.filter(l=>l.status==="FAILED"),s=n.filter(l=>l.status==="CANCELLED");return fv(()=>{a.forEach(l=>{y.log(""),o(l)}),a.length&&(y.log(""),y.error(`${a.length} ${t}s failed:`),a.forEach(l=>{y.dimmed(r(l))})),s.length&&(y.log(""),y.warn(`${s.length} ${t}s cancelled:`),s.forEach(l=>{y.dimmed(r(l))})),i.length&&(y.log(""),y.success(`${i.length} ${t}s passed:`),i.forEach(l=>{y.dimmed(r(l))})),y.log(""),y.dimmed(`Total time: ${Math.round((Date.now()-e)/1e3)}s`)}),{passed:i.length,failed:a.length,cancelled:s.length}}var jl=(n,e)=>{if(!n.failureDetails||!n.failureReason)return;let t=Za[n.failureDetails?.classification?.reason||n.failureReason],r=n.failureDetails?.classification?.summary||To[n.failureReason];y.error(e),y.log(`${zt}Reason: ${Sv.red(t)}`),y.log(`${zt}Description: ${Sv.red(r)}`)};async function ru({fix:n,project:e}){let t=Oe(e,y),r=Object.values(t.tests),o={},i={},a=new Set,s={},l=new Set,c=0;for(let p of r)try{let m=Gr(p.fullFilePath,ne,t),u=m.steps;if(!u||u.length===0||!Array.isArray(u)){y.debug(`Test ${p.name} (${p.relativePath}) has no steps, skipping...`);continue}let h=bt.parse(m),g=await Ur(h,u,y),f=!1,S=!1;g.steps=g.steps.map((b,w)=>{if(!b.id)return y.error(`Step ${w} in test '${p.name}' (${p.relativePath}) does not have an ID`),S=!0,b;let v=o[b.id]?.testId,x=o[b.id]?.testRelativePath;if(v){if(c++,S=!0,v===p.id?y.error(`Multiple steps in the test '${p.name}' (${p.relativePath}) have the same ID '${b.id}'`):y.error(`Step ${w} in test '${p.name}' (${p.relativePath}) has the ID ${b.id} which is duplicated in test ${x}`),n)return f=!0,Se.parse({...b,id:nu()})}else o[b.id]={testId:p.id,testRelativePath:p.relativePath};if(b.type!=="PRESET_ACTION")return b;let C=b.command.id,A=i[C]?.testId,N=i[C]?.testRelativePath;if(A){if(c++,S=!0,A===p.id?y.error(`Multiple commands in the test '${p.name}' (${p.relativePath}) have the same ID '${C}'`):y.error(`Command ${w} in test '${p.name}' (${p.relativePath}) has the ID ${C} which is duplicated in test ${N}`),n)return f=!0,Se.parse({...b,command:{...b.command,id:nu()}})}else i[C]={testId:p.id,testRelativePath:p.relativePath};return b}),S&&y.dimmed("=".repeat(80)),f&&n&&(Bn({relativeTestPath:p.relativePath,steps:{beforeSteps:m.beforeSteps,steps:g.steps,afterSteps:m.afterSteps},schemaVersion:Fe,project:e}),a.add(p.fullFilePath))}catch(m){y.error({err:m},`Failed to parse test ${p.name} (${p.relativePath})`);continue}let d=Object.values(t.modules);for(let p of d)try{let m=Un(p.fullFilePath,y),u=m.steps;if(!u||u.length===0||!Array.isArray(u)){y.debug(`Module ${p.name} (${p.relativePath}) has no steps, skipping...`);continue}let h,g;try{let w=await Ur({id:m.moduleId,schemaVersion:m.schemaVersion},m.steps,y);h=w.steps,g=w.newVersion}catch(w){y.error({err:w},`Failed to migrate module ${p.name} (${p.relativePath})`);continue}let f=!1,S=!1,b=h.map((w,v)=>{if(w.type!=="PRESET_ACTION")return w;let x=w.command.id,C=i[x],A=s[x];if(C||A){if(c++,S=!0,A?.moduleId===p.id?y.error(`Multiple commands in module '${p.name}' (${p.relativePath}) have the same ID '${x}'`):C?y.error(`Command in module '${p.name}' (${p.relativePath}) has the ID ${x} which is duplicated in test ${C.testRelativePath}`):y.error(`Command ${v} in module '${p.name}' (${p.relativePath}) has the ID ${x} which is duplicated in module ${A.moduleRelativePath}`),n)return f=!0,{...w,command:{...w.command,id:nu()}}}else s[x]={moduleId:p.id,moduleRelativePath:p.relativePath};return w});S&&y.dimmed("=".repeat(80)),f&&n&&(jr({content:{...m,steps:b},schemaVersion:g,momenticFiles:t,project:e,forceSaveOnNoDiffs:!0}),l.add(p.fullFilePath))}catch(m){y.error({err:m},`Failed to parse module ${p.name} (${p.relativePath})`);continue}return{errors:c,modifiedTestFilePaths:a,modifiedModuleFilePaths:l}}async function yv({fix:n,project:e}){let{errors:t,modifiedTestFilePaths:r,modifiedModuleFilePaths:o}=await ru({fix:n,project:e});t>0?(y.error(`Found errors in ${t} steps`),n?(y.warn(`Modified the following files:
3632
3632
  ${[...r].map(i=>`${zt}- ${i}`).join(`
3633
3633
  `)}`),o.size>0&&y.warn(`Modified the following module files:
3634
3634
  ${[...o].map(i=>`${zt}- ${i}`).join(`
3635
- `)}`)):y.warn("To fix these errors automatically, re-run this check with the --fix flag and then commit the resulting changes"),process.exit(1)):(y.success("No step ID errors found!"),process.exit(0))}async function bv({project:n}){let e=Oe(n,y),t=Object.values(e.tests),r=await Ns(e,ne),o={},i={},a={},s={},l=new Set,c=new Set,d=new Set,p=new Set;for(let u of t)o[u.id]?a[u.id]?a[u.id].push(u.fullFilePath):a[u.id]=[o[u.id],u.fullFilePath]:o[u.id]=u.fullFilePath,i[u.name]?s[u.name]?s[u.name].push(u.fullFilePath):s[u.name]=[i[u.name],u.fullFilePath]:i[u.name]=u.fullFilePath;for(let u of r)p.has(u.moduleId)&&l.add(u.moduleId),d.has(u.name)&&c.add(u.name),p.add(u.moduleId),d.add(u.name);if(Object.entries(a).length>0||Object.entries(s).length>0||l.size>0||c.size>0){for(let[u,h]of Object.entries(a))for(let g of h)y.error(`Test ID ${u} is duplicated in ${g}`);for(let[u,h]of Object.entries(s))for(let g of h)y.error(`Test Name ${u} is duplicated in ${g}`);for(let u of l)y.error(`Module id ${u} is duplicated in your project`);for(let u of c)y.error(`Module name ${u} is duplicated in your project`);process.exit(1)}y.success("No duplicates detected. All test and module names and ids are unique."),process.exit(0)}import{cloneDeep as _M}from"lodash-es";async function wv({client:n,skipPrompts:e,project:t}){let r=await n.getAllEnvironments(),o=_M(t.config);o.environments||(o.environments=[]);for(let i of r){let a=o.environments?.find(s=>s.name===i.name);if(a)!e&&!await gt(`Environment ${i.name} already exists in the project configuration file. Would you like to overwrite its variables?`)&&process.exit(1),a.baseUrl=i.variables[Ge],delete i.variables[Ge],a.envVariables=i.variables;else{let s=i.variables[Ge];delete i.variables[Ge],o.environments.push({name:i.name,baseUrl:s,envVariables:i.variables})}}Ko(o,t.configFilePath),y.success(`Pulled ${r.length} environments successfully! Please make sure to commit any changes to your project configuration file.`)}import{createHash as vv}from"crypto";import Tv from"fs";async function ou({testsToFetch:n,client:e,all:t,yes:r}){let{tests:o,modules:i}=await e.getTestYAMLExport({paths:n,all:t}),a=0;for(let[l,c]of Object.entries(o)){let d=xv(l,Ee.TEST);!r&&!await Gp(d)||(a+=1,Tv.writeFileSync(d,c,"utf-8"),ne.info({checksum:vv("md5").update(c).digest("hex")},`Wrote '${d}'`))}let s=0;for(let[l,c]of Object.entries(i)){let d=xv(l,Ee.MODULE);!r&&!await Gp(d)||(s+=1,Tv.writeFileSync(d,c,"utf-8"),ne.info({checksum:vv("md5").update(c).digest("hex")},`Wrote '${d}'`))}a===0?y.success("Pulled 0 tests."):y.success(`Pulled ${a} test${a>1?"s":""}${s?` and ${s} module${s>1?"s":""}`:""}!`)}function xv(n,e){switch(e){case Ee.TEST:return`${Ne(n)}.${Ot.TEST}`;case Ee.MODULE:return`${Ne(n)}.${Ot.MODULE}`;default:throw new Error(`Unknown entity type ${e}`)}}async function Ev(n){let{project:e,client:t,skipPrompts:r}=n;y.info("Welcome to the Momentic Cloud importer wizard! \u{1F636}\u200D\u{1F32B}\uFE0F"),y.info("Importing environments from Momentic Cloud."),y.info(`This command will overwrite all local environment configuration in ${e.configFilePath} with environments from Momentic Cloud.`),await gt("Are you sure you want to proceed?",!0)||(y.info("Aborting..."),process.exit(1)),await wv({client:t,project:e,skipPrompts:r}),y.success(`Successfully imported environments from Momentic Cloud. We recommend pulling secrets out of ${e.configFilePath} into .env files or dynamically set environment variables for security.`),y.info("Importing tests and modules from Momentic Cloud."),await ou({testsToFetch:[],client:t,all:!0,yes:r}),y.success("Successfully imported tests and modules from Momentic Cloud. You can move them to the desired location in your project. We recommend committing these files to version control so you can share them with team members and run Momentic tests in CI.")}async function Cv(n){let{client:e,skipPrompts:t,paths:r}=n;await ou({testsToFetch:r,client:e,all:void 0,yes:t}),y.success("Successfully imported tests and modules from Momentic Cloud. You can move them to the desired location in your project. We recommend committing these files to version control so you can share them with team members and run Momentic tests in CI.")}import DM from"fs";import{tmpdir as FM}from"os";import UM from"path";import{registry as La}from"playwright-core/lib/server";import Rv from"proper-lockfile";var Av=UM.join(FM(),"momenticBrowserInstallation");var iu=["chrome","chromium","chrome-for-testing"],BM={Chromium:"chromium","Google Chrome":"chrome","Chrome for Testing":"chrome-for-testing"},Iv={chrome:"chrome",chromium:"chromium","chrome-for-testing":"chromium-headless-shell"};function Pv(n){let e=Iv[BM[n]??""]??"",t=La.findExecutable(e);return!t||t.installType==="none"?!1:au(t)}function au(n){let e=n.executablePath();return DM.existsSync(e)}function zM(n,e){let t=Iv[n];if(!t)throw new Error(`Requested install of unknown browser type ${n}`);let r=La.findExecutable(t);if(!r||r.installType==="none")throw new Error(`Requested install of unknown browser type ${n}`);if(!(!e&&au(r)))return r}async function HM({browser:n,force:e}){let t=zM(n,e);if(!t){y.info(`Browser '${n}' is already installed, skipping...`);return}y.info(`Installing browser '${n}'...`);try{await La.installDeps([t],!1),await La.install([t],!1)}catch(r){if(r.message.includes("Lock file is already being held")){y.warn("Another process is installing Playwright browsers. Waiting for completion before proceeding..");let o=La.findExecutable(n),i=5*60*1e3,a=Date.now();for(;Date.now()-a<i&&!au(o);)y.info("Waiting for browser to finish installing..."),await new Promise(s=>setTimeout(s,5e3))}else throw r}}async function Lv({rawBrowsers:n,force:e=!1,all:t=!1}){let r=t?iu:Array.from(new Set(n));try{await Rv.lock(Av,{stale:1e3*60*5,update:1e3*60,realpath:!1,retries:{retries:30,factor:2,maxTimeout:15e3,minTimeout:500}})}catch(o){y.warn(`Failed to acquire lock to install browsers. Please ensure that any other process installing browsers completes within 5 minutes: ${o}. Continuing without installation...`);return}try{for(let o of r)try{await HM({browser:o,force:e})}catch(i){y.error(`Failed to install the ${o} browser: ${i}`)}}finally{await Rv.unlock(Av,{realpath:!1})}}async function Ov(n){let e=Oe(n,y),t=Object.values(e.tests);for(let r of t)try{let o=Gr(r.fullFilePath,y,e),i=o.steps;if(!i||i.length===0||!Array.isArray(i)){y.debug(`Test ${r.name} (${r.relativePath}) has no steps, skipping...`);continue}let a=bt.parse(o),s=await Ur(a,i,y);y.dimmed(`Updating ${r.relativePath}`),Bn({relativeTestPath:r.relativePath,steps:{beforeSteps:o.beforeSteps,steps:s.steps,afterSteps:o.afterSteps},schemaVersion:Fe,project:n,forceSaveOnNoDiffs:!0})}catch(o){y.error({err:o},`Failed to read or migrate test ${r.name} (${r.relativePath}), continuing...`)}for(let r of Object.values(e.modules)){y.dimmed(`Updating ${r.relativePath}`);try{let o=Un(r.fullFilePath,y),i=o.steps;if(!i||i.length===0||!Array.isArray(i)){y.debug(`Module ${r.name} (${r.relativePath}) has no steps, skipping...`);continue}let a=await Ur({id:o.moduleId,schemaVersion:o.schemaVersion},i,y);jr({content:{...o,steps:a.steps},schemaVersion:Fe,momenticFiles:e,project:n,forceSaveOnNoDiffs:!0})}catch(o){y.error({err:o},`Failed to read or migrate module ${r.name} (${r.relativePath}), continuing...`)}}}import{execSync as $M}from"child_process";import{PostHog as jM}from"posthog-node";async function kv(n,e){let t,r=0,o=3,i,a;for(;r<o;)try{let s=await D(n.getAllFlagsAndPayloads(e),{milliseconds:5e3});i=s.featureFlags||{},a=s.featureFlagPayloads||{};break}catch(s){t=s,r++,await new Promise(l=>setTimeout(l,100*r))}if(i&&a)return{flags:i,payloads:a};throw t}var $l=class n extends Xi{constructor(t,r,o,i){super(o,i);this.client=t;this.orgId=r}static async init(t){let r=new jM("phc_WRWd8LYIv6rolgDsyCdrPpxtZhsu6qXAkEwPicl44bI",{host:"https://us.i.posthog.com"}),{flags:o,payloads:i}=await kv(r,t);return new n(r,t,o,i)}async refresh(){let{flags:t,payloads:r}=await kv(this.client,this.orgId);this.flags=t,this.payloads=r}};function GM(){try{let e=$M("git remote show origin",{encoding:"utf8"}).match(/HEAD branch: (.*)$/m);if(e&&e[1])return e[1].trim();y.warn("Could not determine your Git main branch. Please set it manually in your project configuration under the 'gitMainBranch' field.");return}catch(n){let e=n instanceof Error?n.message:String(n);y.warn(`Could not determine Git main branch. Please set it manually in your project configuration under the 'gitMainBranch' field. Error:
3636
- ${e}`)}}async function Mv({project:n,orgId:e,apiClient:t}){y.info("Pulling browser and AI configuration options from Cloud");let r=await $l.init(e);n.config.browser={autoExpandIframes:r.isBooleanFlagEnabled("auto_expand_iframes"),disableSecondaryCacheResolution:r.isBooleanFlagEnabled("disable_secondary_cache_resolution"),globalLocatorRedirect:r.isBooleanFlagEnabled("global_locator_redirect"),visualActions:r.isBooleanFlagEnabled("visual_actions"),...n.config.browser},n.config.advanced={fakerConstantSeed:r.isBooleanFlagEnabled("faker_constant_seed"),...n.config.advanced},n.config.ai={aiPageFiltering:r.isBooleanFlagEnabled("rag_v2"),agentConfig:await t.getAgentConfig(),...n.config.ai},y.info(`Updated ${n.configFilePath} to include V2 browser and AI configuration options`),y.info("Determining main Git branch"),n.config.gitMainBranch=GM(),Ko(n.config,n.configFilePath),y.success("Migration complete!")}function Nv(n){return n?Ne(n):"Unknown suite"}async function _v({client:n,orgId:e,suitePaths:t,wait:r,waitTimeout:o,...i}){let{suiteRunIds:a,runGroupIds:s}=await n.queueSuiteRuns({paths:t,...i});ne.info({orgId:e,suiteRunIds:a,runGroupIds:s,suitePaths:t},"Queued suites remotely"),y.dimmed(`Queued ${t.length} suites.`),r||process.exit(0);let l=Date.now();y.dimmed(`Waiting for ${t.length} suites to complete.`);let c=new Set,d=[],p=f=>(f.status==="FAILED"||f.status==="PASSED"||f.status==="CANCELLED")&&f.runs.every(b=>b.status==="FAILED"&&(b.failureReason||b.finishedAt&&Date.now()-b.finishedAt.getTime()>30*1e3)||b.status==="PASSED"||b.status==="CANCELLED"),m=await Hl({name:"suites",getResults:async()=>{let f=s.filter(w=>!d.some(v=>v.id===w)),S=await n.bulkGetRunGroupStatus(f),b=[];for(let w of S)p(w)?d.push(w):b.push(w);return[...d,...b]},timeoutMs:o?o*1e3:void 0,checkDone:f=>(f.forEach(S=>{S.status==="RUNNING"&&(c.has(S.id)||(c.add(S.id),y.log(`${c.size}/${s.length} ${Nv(S.suite?.name)}`)))}),f.every(p))}),u=n.getAppUrl(),g=Si({results:m,startTime:l,onFailed:f=>{let S=Nv(f.suite?.name),b=f.runs.filter(v=>v.status==="FAILED").length,w=f.runs.length;y.error(`${S} (${b}/${w} tests failed):`);for(let v of f.runs)if(v.status==="FAILED"){let x=v.testName||v.test?.name;y.error(` ${x?Ne(x):"Unknown test"} (${u}/runs/${v.id})`)}},entity:"suite",getDisplayLine:f=>` ${f.suite?.name?Ne(f.suite.name):"Unknown suite name"} (${u}/run-groups/${f.id})`});process.exit(g.failed>0?1:0)}async function Dv({tests:n,client:e,orgId:t,...r}){!r.yes&&!await gt(`This command will queue ${n.length} tests to run remotely on Momentic's infrastructure. Results will be available on ${e.getAppUrl()}. Continue?`)&&process.exit(1);let{queuedTests:o,runIds:i}=await e.queueTests({testPaths:n,...r});if(ne.info({queuedTests:o,runIds:i,orgId:t},"Queued tests remotely"),y.dimmed(`Queued ${o.length} tests. Processing time may depend on a variety of factors, including how many tests have already been queued from your organization.`),r.wait||process.exit(0),!i.length)return;y.dimmed(`Waiting for ${o.length} tests to complete.`);let a=new Set,s=[],l=u=>u.status==="FAILED"&&u.failureReason||u.status==="PASSED"||u.status==="CANCELLED",c=e.getAppUrl(),d=Date.now(),p=await Hl({name:"runs",getResults:async()=>{let u=i.filter(f=>!s.some(S=>S.id===f)),h=await e.bulkGetRunStatus(u),g=[];for(let f of h)l(f)?s.push(f):g.push(f);return[...s,...g]},timeoutMs:r.waitTimeout?r.waitTimeout*1e3:void 0,checkDone:u=>(u.forEach(h=>{if(h.status==="RUNNING"&&!a.has(h.id)){a.add(h.id);let g=h.testName||h.test?.name;g&&y.log(`${a.size}/${o.length} ${Ne(g)}`)}}),u.every(l))}),m=Si({results:p,startTime:d,onFailed:u=>{let h=u.testName||u.test?.name;jl(u,h?Ne(h):"Unknown test")},getDisplayLine:u=>{let h=u.testName||u.test?.name,g=` ${h?Ne(h):"Unknown test"}`;return u.id&&(g+=` (${c}/runs/${u.id})`),g},entity:"test"});process.exit(m.failed>0?1:0)}import bi,{supportsColor as SN}from"chalk";import yN from"fs";import{existsSync as rN,mkdirSync as oN,statSync as iN}from"fs";import{randomUUID as su}from"crypto";import Gl from"fs";import{hostname as WM}from"os";import Oa from"path";async function Wl(n,e,t,r,o){if(r){let i=Oa.extname(r),a=`${su()}-screenshot${i}`,s=Oa.join(t,a),c=await(await fetch(r)).arrayBuffer();return Gl.writeFileSync(s,Buffer.from(c)),a}if(o){let i=await e.getScreenshot(n,o);if(i){let a=`${o}-screenshot.jpeg`,s=Oa.join(t,a);return Gl.writeFileSync(s,i),a}}}async function VM(n,e,t,r){let o=r.runId??su(),i={uuid:o,historyId:o,testCaseId:r.test.id,fullName:r.test.name,name:Ne(r.test.name),status:r.status==="PASSED"?"passed":r.status==="CANCELLED"?"skipped":"failed",start:r.lastAttemptStartedAt.getTime(),stop:r.finishedAt.getTime(),parameters:[],labels:[{name:"suite",value:t.suiteName},{name:"host",value:WM()},{name:"platform",value:"momentic"},{name:"attempts",value:r.attempts.toString()}],steps:[]};r.runId&&i.labels?.push({name:"runUrl",value:`https://app.momentic.ai/runs/${r.runId}`});for(let[s,l]of Object.entries(r.parameters))l!=null&&i.parameters.push({name:s,value:JSON.stringify(l)});r.results&&await qM(n,e,t.folder,i.steps,r.results);let a=`${o}-result.json`;Gl.writeFileSync(Oa.join(t.folder,a),JSON.stringify(i,void 0,2))}async function yi(n,e,t,r){let o={name:ln(r),start:r.startedAt.getTime(),stop:r.finishedAt.getTime(),status:r.status==="SUCCESS"?"passed":r.status==="CANCELLED"?"skipped":"failed",labels:[],steps:[],attachments:[]};r.beforeUrl&&o.labels?.push({name:"URL before step",value:r.beforeUrl}),r.afterUrl&&o.labels?.push({name:"URL after step",value:r.afterUrl});let i=await Wl(n,e,t,r.beforeScreenshot,r.beforeSnapshot);i&&o.attachments.push({name:"Screenshot before step",source:i,type:"image/jpeg"});let a=await Wl(n,e,t,r.afterScreenshot,r.afterSnapshot);if(a&&o.attachments.push({name:"Screenshot after step",source:a,type:"image/jpeg"}),r.message&&(o.statusDetails={message:r.message}),r.data){let s=`${su()}-attachment.json`,l=Oa.join(t,s);Gl.writeFileSync(l,JSON.stringify(r.data,null,2)),o.attachments.push({name:"Step output data",source:s,type:"text/plain"})}return o}async function qM(n,e,t,r,o){for(let i of o)switch(i.type){case"PRESET_ACTION":{r.push(await yi(n,e,t,i));break}case"CONDITIONAL":{let a=await yi(n,e,t,i);a.steps=[],i.assertion&&a.steps.push(await yi(n,e,t,i.assertion)),a.steps.push(...await Promise.all(i.results.map(s=>yi(n,e,t,s)))),r.push(a);break}case"AI_ACTION":case"IFRAME":case"SECTION":case"MODULE":{let a=await yi(n,e,t,i);if(a.steps=await Promise.all(i.results.map(s=>yi(n,e,t,s))),i.type==="MODULE"&&i.inputs){a.parameters=[];for(let[s,l]of Object.entries(i.inputs))a.parameters.push({name:s,value:l})}r.push(a)}}}async function Fv(n,e,t,r){for(let o of r.runs)await VM(n,e,{folder:t,suiteName:r.suiteName},o)}import Uv from"junit-report-builder";import Bv from"path";function KM(n,e){let t=e??Uv.testCase();if(t.name(n.test.name).className(n.test.name).file(Bv.relative(".",n.filePath)).property("id",n.test.id),n.baseUrl&&t.property("baseUrl",n.baseUrl),n.runId&&t.property("runUrl",`https://app.momentic.ai/runs/${n.runId}`),n.status==="FAILED"){if(n.failureReason){let r=Za[n.failureDetails?.classification?.reason||n.failureReason],o=n.failureDetails?.classification?.summary||xo[n.failureReason];n.runId&&(o+=` See details: https://app.momentic.ai/runs/${n.runId}`),t.failure(o,r)}n.failureDetails?.errorStack&&t.stacktrace(n.failureDetails.errorStack)}else n.status==="CANCELLED"&&t.skipped();t.time((n.finishedAt.getTime()-n.lastAttemptStartedAt.getTime())/1e3).property("startedAt",n.lastAttemptStartedAt.toISOString()).property("finishedAt",n.finishedAt.toISOString()).property("attempts",n.attempts.toString());for(let r of["testInputs","customHeaders"]){let o=n.parameters[r];Object.keys(o??{}).length>0&&t.multilineProperty(r,JSON.stringify(o))}for(let r of["envName","urlOverride"])n.parameters[r]!==void 0&&t.property(r,n.parameters[r]);return Object.keys(n.outputs).length&&t.multilineProperty("testOutputs",JSON.stringify(n.outputs)),t}function YM(n,{suiteId:e,suiteName:t,startedAt:r,finishedAt:o,runs:i}){let a=n.testSuite().name(t);e&&a.property("id",e),a.timestamp(r).property("startedAt",r.toISOString()).property("finishedAt",o.toISOString()).time((o.getTime()-r.getTime())/1e3);for(let s of i){let l=a.testCase();KM(s,l)}return a}function zv(n,e){let t=Uv.newBuilder();YM(t,e),t.writeTo(Bv.join(n,`${e.suiteName}.xml`))}import JM from"fs";import XM from"path";function Hv(n){return{title:ln(n),duration:n.finishedAt.getTime()-n.startedAt.getTime(),error:n.status==="FAILED"?{value:n.failureReason}:void 0,steps:n.results&&n.type!=="PRESET_ACTION"?n.results.map(Hv):[]}}async function ZM(n,e,t,r){if(r.results?.length){let o=await Wl(n,e,t,r.results[r.results.length-1].afterScreenshot,r.results[r.results.length-1].afterSnapshot);return o?[{name:"Final state screenshot",path:o,contentType:"image/jpeg"}]:[]}return[]}async function QM(n,e,t,r){return{status:r.status==="PASSED"?"passed":r.status==="CANCELLED"?"interrupted":"failed",duration:r.finishedAt.getTime()-r.lastAttemptStartedAt.getTime(),error:r.status==="FAILED"&&r.failureReason?{value:r.failureDetails?.classification?.reason||r.failureReason,message:r.failureDetails?.classification?.summary||xo[r.failureReason]}:void 0,retry:r.attempts-1,steps:r.results?.map(Hv)||[],startTime:r.lastAttemptStartedAt.toISOString(),attachments:await ZM(n,e,t,r)}}async function eN(n,e,t,r){return{expectedStatus:"passed",status:r.status==="PASSED"?"expected":"unexpected",results:[await QM(n,e,t,r)]}}async function tN(n,e,t,r){return{tags:[],title:r.test.name,ok:r.status==="PASSED",tests:[await eN(n,e,t,r)],id:r.runId,file:r.filePath}}function lu(n,e){return n.reduce((t,r)=>e(r)?t+1:t,0)}async function nN(n,e,t,r){return{suites:[{title:r.suiteName,file:r.projectConfigPath,specs:await Promise.all(r.runs.map(o=>tN(n,e,t,o)))}],errors:[],stats:{startTime:r.startedAt.toISOString(),duration:r.finishedAt.getTime()-r.startedAt.getTime(),expected:lu(r.runs,o=>o.status==="PASSED"),unexpected:lu(r.runs,o=>o.status!=="PASSED"),flaky:lu(r.runs,o=>!!o.isFlake),skipped:0}}}async function jv(n,e,t,r){let o=await nN(n,e,t,r);JM.writeFileSync(XM.join(t,`${r.suiteName}.json`),JSON.stringify(o,null,2))}async function $v(n,e,t,r,o){switch(rN(o)?iN(o).isDirectory()||(y.error(`The specified reporter output directory '${o}' exists on disk but is not a folder. Please move or delete the existing object or specify a different reporter path.`),process.exit(1)):(y.info(`Reporter output directory '${o}' does not exist on disk, creating it now...`),oN(o,{recursive:!0})),t){case"junit":zv(o,r);return;case"allure":case"allure-json":await Fv(n,e,o,r);return;case"playwright-json":await jv(n,e,o,r);return;default:throw new Error(`Unknown reporter format requested: '${t}'`)}}import bN from"wait-on";import cu from"fs";import{compact as aN}from"lodash-es";import du from"path";import{cwd as sN}from"process";import lN from"semver";async function Gv({tests:n,momenticFiles:e,project:t,yes:r,include:o,exclude:i,labels:a}){let s=new Set;if(n&&n.length>0){let c=n.some(p=>cu.existsSync(p)),d=sN();c?(d!==t.rootDir&&y.warn(`The current working directory ('${d}') is different from the project root directory ('${t.rootDir}'). All test path arguments will be resolved relative to the current working directory and only those tests matched by the project inclusion configuration will be ran. To avoid confusion, Momentic strongly recommends running the CLI from the project root directory or using substring filters rather than file paths.`),y.info(`Reading tests from the following local file paths:
3635
+ `)}`)):y.warn("To fix these errors automatically, re-run this check with the --fix flag and then commit the resulting changes"),process.exit(1)):(y.success("No step ID errors found!"),process.exit(0))}async function bv({project:n}){let e=Oe(n,y),t=Object.values(e.tests),r=await Ns(e,ne),o={},i={},a={},s={},l=new Set,c=new Set,d=new Set,p=new Set;for(let u of t)o[u.id]?a[u.id]?a[u.id].push(u.fullFilePath):a[u.id]=[o[u.id],u.fullFilePath]:o[u.id]=u.fullFilePath,i[u.name]?s[u.name]?s[u.name].push(u.fullFilePath):s[u.name]=[i[u.name],u.fullFilePath]:i[u.name]=u.fullFilePath;for(let u of r)p.has(u.moduleId)&&l.add(u.moduleId),d.has(u.name)&&c.add(u.name),p.add(u.moduleId),d.add(u.name);if(Object.entries(a).length>0||Object.entries(s).length>0||l.size>0||c.size>0){for(let[u,h]of Object.entries(a))for(let g of h)y.error(`Test ID ${u} is duplicated in ${g}`);for(let[u,h]of Object.entries(s))for(let g of h)y.error(`Test Name ${u} is duplicated in ${g}`);for(let u of l)y.error(`Module id ${u} is duplicated in your project`);for(let u of c)y.error(`Module name ${u} is duplicated in your project`);process.exit(1)}y.success("No duplicates detected. All test and module names and ids are unique."),process.exit(0)}import{cloneDeep as _M}from"lodash-es";async function wv({client:n,skipPrompts:e,project:t}){let r=await n.getAllEnvironments(),o=_M(t.config);o.environments||(o.environments=[]);for(let i of r){let a=o.environments?.find(s=>s.name===i.name);if(a)!e&&!await gt(`Environment ${i.name} already exists in the project configuration file. Would you like to overwrite its variables?`)&&process.exit(1),a.baseUrl=i.variables[Ge],delete i.variables[Ge],a.envVariables=i.variables;else{let s=i.variables[Ge];delete i.variables[Ge],o.environments.push({name:i.name,baseUrl:s,envVariables:i.variables})}}qo(o,t.configFilePath),y.success(`Pulled ${r.length} environments successfully! Please make sure to commit any changes to your project configuration file.`)}import{createHash as vv}from"crypto";import Tv from"fs";async function ou({testsToFetch:n,client:e,all:t,yes:r}){let{tests:o,modules:i}=await e.getTestYAMLExport({paths:n,all:t}),a=0;for(let[l,c]of Object.entries(o)){let d=xv(l,Ee.TEST);!r&&!await Gp(d)||(a+=1,Tv.writeFileSync(d,c,"utf-8"),ne.info({checksum:vv("md5").update(c).digest("hex")},`Wrote '${d}'`))}let s=0;for(let[l,c]of Object.entries(i)){let d=xv(l,Ee.MODULE);!r&&!await Gp(d)||(s+=1,Tv.writeFileSync(d,c,"utf-8"),ne.info({checksum:vv("md5").update(c).digest("hex")},`Wrote '${d}'`))}a===0?y.success("Pulled 0 tests."):y.success(`Pulled ${a} test${a>1?"s":""}${s?` and ${s} module${s>1?"s":""}`:""}!`)}function xv(n,e){switch(e){case Ee.TEST:return`${Ne(n)}.${Ot.TEST}`;case Ee.MODULE:return`${Ne(n)}.${Ot.MODULE}`;default:throw new Error(`Unknown entity type ${e}`)}}async function Ev(n){let{project:e,client:t,skipPrompts:r}=n;y.info("Welcome to the Momentic Cloud importer wizard! \u{1F636}\u200D\u{1F32B}\uFE0F"),y.info("Importing environments from Momentic Cloud."),y.info(`This command will overwrite all local environment configuration in ${e.configFilePath} with environments from Momentic Cloud.`),await gt("Are you sure you want to proceed?",!0)||(y.info("Aborting..."),process.exit(1)),await wv({client:t,project:e,skipPrompts:r}),y.success(`Successfully imported environments from Momentic Cloud. We recommend pulling secrets out of ${e.configFilePath} into .env files or dynamically set environment variables for security.`),y.info("Importing tests and modules from Momentic Cloud."),await ou({testsToFetch:[],client:t,all:!0,yes:r}),y.success("Successfully imported tests and modules from Momentic Cloud. You can move them to the desired location in your project. We recommend committing these files to version control so you can share them with team members and run Momentic tests in CI.")}async function Cv(n){let{client:e,skipPrompts:t,paths:r}=n;await ou({testsToFetch:r,client:e,all:void 0,yes:t}),y.success("Successfully imported tests and modules from Momentic Cloud. You can move them to the desired location in your project. We recommend committing these files to version control so you can share them with team members and run Momentic tests in CI.")}import DM from"fs";import{tmpdir as FM}from"os";import UM from"path";import{registry as La}from"playwright-core/lib/server";import Rv from"proper-lockfile";var Av=UM.join(FM(),"momenticBrowserInstallation");var iu=["chrome","chromium","chrome-for-testing"],BM={Chromium:"chromium","Google Chrome":"chrome","Chrome for Testing":"chrome-for-testing"},Iv={chrome:"chrome",chromium:"chromium","chrome-for-testing":"chromium-headless-shell"};function Pv(n){let e=Iv[BM[n]??""]??"",t=La.findExecutable(e);return!t||t.installType==="none"?!1:au(t)}function au(n){let e=n.executablePath();return DM.existsSync(e)}function zM(n,e){let t=Iv[n];if(!t)throw new Error(`Requested install of unknown browser type ${n}`);let r=La.findExecutable(t);if(!r||r.installType==="none")throw new Error(`Requested install of unknown browser type ${n}`);if(!(!e&&au(r)))return r}async function HM({browser:n,force:e}){let t=zM(n,e);if(!t){y.info(`Browser '${n}' is already installed, skipping...`);return}y.info(`Installing browser '${n}'...`);try{await La.installDeps([t],!1),await La.install([t],!1)}catch(r){if(r.message.includes("Lock file is already being held")){y.warn("Another process is installing Playwright browsers. Waiting for completion before proceeding..");let o=La.findExecutable(n),i=5*60*1e3,a=Date.now();for(;Date.now()-a<i&&!au(o);)y.info("Waiting for browser to finish installing..."),await new Promise(s=>setTimeout(s,5e3))}else throw r}}async function Lv({rawBrowsers:n,force:e=!1,all:t=!1}){let r=t?iu:Array.from(new Set(n));try{await Rv.lock(Av,{stale:1e3*60*5,update:1e3*60,realpath:!1,retries:{retries:30,factor:2,maxTimeout:15e3,minTimeout:500}})}catch(o){y.warn(`Failed to acquire lock to install browsers. Please ensure that any other process installing browsers completes within 5 minutes: ${o}. Continuing without installation...`);return}try{for(let o of r)try{await HM({browser:o,force:e})}catch(i){y.error(`Failed to install the ${o} browser: ${i}`)}}finally{await Rv.unlock(Av,{realpath:!1})}}async function Ov(n){let e=Oe(n,y),t=Object.values(e.tests);for(let r of t)try{let o=Gr(r.fullFilePath,y,e),i=o.steps;if(!i||i.length===0||!Array.isArray(i)){y.debug(`Test ${r.name} (${r.relativePath}) has no steps, skipping...`);continue}let a=bt.parse(o),s=await Ur(a,i,y);y.dimmed(`Updating ${r.relativePath}`),Bn({relativeTestPath:r.relativePath,steps:{beforeSteps:o.beforeSteps,steps:s.steps,afterSteps:o.afterSteps},schemaVersion:Fe,project:n,forceSaveOnNoDiffs:!0})}catch(o){y.error({err:o},`Failed to read or migrate test ${r.name} (${r.relativePath}), continuing...`)}for(let r of Object.values(e.modules)){y.dimmed(`Updating ${r.relativePath}`);try{let o=Un(r.fullFilePath,y),i=o.steps;if(!i||i.length===0||!Array.isArray(i)){y.debug(`Module ${r.name} (${r.relativePath}) has no steps, skipping...`);continue}let a=await Ur({id:o.moduleId,schemaVersion:o.schemaVersion},i,y);jr({content:{...o,steps:a.steps},schemaVersion:Fe,momenticFiles:e,project:n,forceSaveOnNoDiffs:!0})}catch(o){y.error({err:o},`Failed to read or migrate module ${r.name} (${r.relativePath}), continuing...`)}}}import{execSync as $M}from"child_process";import{PostHog as jM}from"posthog-node";async function kv(n,e){let t,r=0,o=3,i,a;for(;r<o;)try{let s=await D(n.getAllFlagsAndPayloads(e),{milliseconds:5e3});i=s.featureFlags||{},a=s.featureFlagPayloads||{};break}catch(s){t=s,r++,await new Promise(l=>setTimeout(l,100*r))}if(i&&a)return{flags:i,payloads:a};throw t}var $l=class n extends Xi{constructor(t,r,o,i){super(o,i);this.client=t;this.orgId=r}static async init(t){let r=new jM("phc_WRWd8LYIv6rolgDsyCdrPpxtZhsu6qXAkEwPicl44bI",{host:"https://us.i.posthog.com"}),{flags:o,payloads:i}=await kv(r,t);return new n(r,t,o,i)}async refresh(){let{flags:t,payloads:r}=await kv(this.client,this.orgId);this.flags=t,this.payloads=r}};function GM(){try{let e=$M("git remote show origin",{encoding:"utf8"}).match(/HEAD branch: (.*)$/m);if(e&&e[1])return e[1].trim();y.warn("Could not determine your Git main branch. Please set it manually in your project configuration under the 'gitMainBranch' field.");return}catch(n){let e=n instanceof Error?n.message:String(n);y.warn(`Could not determine Git main branch. Please set it manually in your project configuration under the 'gitMainBranch' field. Error:
3636
+ ${e}`)}}async function Mv({project:n,orgId:e,apiClient:t}){y.info("Pulling browser and AI configuration options from Cloud");let r=await $l.init(e);n.config.browser={autoExpandIframes:r.isBooleanFlagEnabled("auto_expand_iframes"),disableSecondaryCacheResolution:r.isBooleanFlagEnabled("disable_secondary_cache_resolution"),globalLocatorRedirect:r.isBooleanFlagEnabled("global_locator_redirect"),visualActions:r.isBooleanFlagEnabled("visual_actions"),...n.config.browser},n.config.advanced={fakerConstantSeed:r.isBooleanFlagEnabled("faker_constant_seed"),...n.config.advanced},n.config.ai={aiPageFiltering:r.isBooleanFlagEnabled("rag_v2"),agentConfig:await t.getAgentConfig(),...n.config.ai},y.info(`Updated ${n.configFilePath} to include V2 browser and AI configuration options`),y.info("Determining main Git branch"),n.config.gitMainBranch=GM(),qo(n.config,n.configFilePath),y.success("Migration complete!")}function Nv(n){return n?Ne(n):"Unknown suite"}async function _v({client:n,orgId:e,suitePaths:t,wait:r,waitTimeout:o,...i}){let{suiteRunIds:a,runGroupIds:s}=await n.queueSuiteRuns({paths:t,...i});ne.info({orgId:e,suiteRunIds:a,runGroupIds:s,suitePaths:t},"Queued suites remotely"),y.dimmed(`Queued ${t.length} suites.`),r||process.exit(0);let l=Date.now();y.dimmed(`Waiting for ${t.length} suites to complete.`);let c=new Set,d=[],p=f=>(f.status==="FAILED"||f.status==="PASSED"||f.status==="CANCELLED")&&f.runs.every(b=>b.status==="FAILED"&&(b.failureReason||b.finishedAt&&Date.now()-b.finishedAt.getTime()>30*1e3)||b.status==="PASSED"||b.status==="CANCELLED"),m=await Hl({name:"suites",getResults:async()=>{let f=s.filter(w=>!d.some(v=>v.id===w)),S=await n.bulkGetRunGroupStatus(f),b=[];for(let w of S)p(w)?d.push(w):b.push(w);return[...d,...b]},timeoutMs:o?o*1e3:void 0,checkDone:f=>(f.forEach(S=>{S.status==="RUNNING"&&(c.has(S.id)||(c.add(S.id),y.log(`${c.size}/${s.length} ${Nv(S.suite?.name)}`)))}),f.every(p))}),u=n.getAppUrl(),g=Si({results:m,startTime:l,onFailed:f=>{let S=Nv(f.suite?.name),b=f.runs.filter(v=>v.status==="FAILED").length,w=f.runs.length;y.error(`${S} (${b}/${w} tests failed):`);for(let v of f.runs)if(v.status==="FAILED"){let x=v.testName||v.test?.name;y.error(` ${x?Ne(x):"Unknown test"} (${u}/runs/${v.id})`)}},entity:"suite",getDisplayLine:f=>` ${f.suite?.name?Ne(f.suite.name):"Unknown suite name"} (${u}/run-groups/${f.id})`});process.exit(g.failed>0?1:0)}async function Dv({tests:n,client:e,orgId:t,...r}){!r.yes&&!await gt(`This command will queue ${n.length} tests to run remotely on Momentic's infrastructure. Results will be available on ${e.getAppUrl()}. Continue?`)&&process.exit(1);let{queuedTests:o,runIds:i}=await e.queueTests({testPaths:n,...r});if(ne.info({queuedTests:o,runIds:i,orgId:t},"Queued tests remotely"),y.dimmed(`Queued ${o.length} tests. Processing time may depend on a variety of factors, including how many tests have already been queued from your organization.`),r.wait||process.exit(0),!i.length)return;y.dimmed(`Waiting for ${o.length} tests to complete.`);let a=new Set,s=[],l=u=>u.status==="FAILED"&&u.failureReason||u.status==="PASSED"||u.status==="CANCELLED",c=e.getAppUrl(),d=Date.now(),p=await Hl({name:"runs",getResults:async()=>{let u=i.filter(f=>!s.some(S=>S.id===f)),h=await e.bulkGetRunStatus(u),g=[];for(let f of h)l(f)?s.push(f):g.push(f);return[...s,...g]},timeoutMs:r.waitTimeout?r.waitTimeout*1e3:void 0,checkDone:u=>(u.forEach(h=>{if(h.status==="RUNNING"&&!a.has(h.id)){a.add(h.id);let g=h.testName||h.test?.name;g&&y.log(`${a.size}/${o.length} ${Ne(g)}`)}}),u.every(l))}),m=Si({results:p,startTime:d,onFailed:u=>{let h=u.testName||u.test?.name;jl(u,h?Ne(h):"Unknown test")},getDisplayLine:u=>{let h=u.testName||u.test?.name,g=` ${h?Ne(h):"Unknown test"}`;return u.id&&(g+=` (${c}/runs/${u.id})`),g},entity:"test"});process.exit(m.failed>0?1:0)}import bi,{supportsColor as SN}from"chalk";import yN from"fs";import{existsSync as rN,mkdirSync as oN,statSync as iN}from"fs";import{randomUUID as su}from"crypto";import Gl from"fs";import{hostname as WM}from"os";import Oa from"path";async function Wl(n,e,t,r,o){if(r){let i=Oa.extname(r),a=`${su()}-screenshot${i}`,s=Oa.join(t,a),c=await(await fetch(r)).arrayBuffer();return Gl.writeFileSync(s,Buffer.from(c)),a}if(o){let i=await e.getScreenshot(n,o);if(i){let a=`${o}-screenshot.jpeg`,s=Oa.join(t,a);return Gl.writeFileSync(s,i),a}}}async function VM(n,e,t,r){let o=r.runId??su(),i={uuid:o,historyId:o,testCaseId:r.test.id,fullName:r.test.name,name:Ne(r.test.name),status:r.status==="PASSED"?"passed":r.status==="CANCELLED"?"skipped":"failed",start:r.lastAttemptStartedAt.getTime(),stop:r.finishedAt.getTime(),parameters:[],labels:[{name:"suite",value:t.suiteName},{name:"host",value:WM()},{name:"platform",value:"momentic"},{name:"attempts",value:r.attempts.toString()}],steps:[]};r.runId&&i.labels?.push({name:"runUrl",value:`https://app.momentic.ai/runs/${r.runId}`});for(let[s,l]of Object.entries(r.parameters))l!=null&&i.parameters.push({name:s,value:JSON.stringify(l)});r.results&&await qM(n,e,t.folder,i.steps,r.results);let a=`${o}-result.json`;Gl.writeFileSync(Oa.join(t.folder,a),JSON.stringify(i,void 0,2))}async function yi(n,e,t,r){let o={name:ln(r),start:r.startedAt.getTime(),stop:r.finishedAt.getTime(),status:r.status==="SUCCESS"?"passed":r.status==="CANCELLED"?"skipped":"failed",labels:[],steps:[],attachments:[]};r.beforeUrl&&o.labels?.push({name:"URL before step",value:r.beforeUrl}),r.afterUrl&&o.labels?.push({name:"URL after step",value:r.afterUrl});let i=await Wl(n,e,t,r.beforeScreenshot,r.beforeSnapshot);i&&o.attachments.push({name:"Screenshot before step",source:i,type:"image/jpeg"});let a=await Wl(n,e,t,r.afterScreenshot,r.afterSnapshot);if(a&&o.attachments.push({name:"Screenshot after step",source:a,type:"image/jpeg"}),r.message&&(o.statusDetails={message:r.message}),r.data){let s=`${su()}-attachment.json`,l=Oa.join(t,s);Gl.writeFileSync(l,JSON.stringify(r.data,null,2)),o.attachments.push({name:"Step output data",source:s,type:"text/plain"})}return o}async function qM(n,e,t,r,o){for(let i of o)switch(i.type){case"PRESET_ACTION":{r.push(await yi(n,e,t,i));break}case"CONDITIONAL":{let a=await yi(n,e,t,i);a.steps=[],i.assertion&&a.steps.push(await yi(n,e,t,i.assertion)),a.steps.push(...await Promise.all(i.results.map(s=>yi(n,e,t,s)))),r.push(a);break}case"AI_ACTION":case"IFRAME":case"SECTION":case"MODULE":{let a=await yi(n,e,t,i);if(a.steps=await Promise.all(i.results.map(s=>yi(n,e,t,s))),i.type==="MODULE"&&i.inputs){a.parameters=[];for(let[s,l]of Object.entries(i.inputs))a.parameters.push({name:s,value:l})}r.push(a)}}}async function Fv(n,e,t,r){for(let o of r.runs)await VM(n,e,{folder:t,suiteName:r.suiteName},o)}import Uv from"junit-report-builder";import Bv from"path";function KM(n,e){let t=e??Uv.testCase();if(t.name(n.test.name).className(n.test.name).file(Bv.relative(".",n.filePath)).property("id",n.test.id),n.baseUrl&&t.property("baseUrl",n.baseUrl),n.runId&&t.property("runUrl",`https://app.momentic.ai/runs/${n.runId}`),n.status==="FAILED"){if(n.failureReason){let r=Za[n.failureDetails?.classification?.reason||n.failureReason],o=n.failureDetails?.classification?.summary||To[n.failureReason];n.runId&&(o+=` See details: https://app.momentic.ai/runs/${n.runId}`),t.failure(o,r)}n.failureDetails?.errorStack&&t.stacktrace(n.failureDetails.errorStack)}else n.status==="CANCELLED"&&t.skipped();t.time((n.finishedAt.getTime()-n.lastAttemptStartedAt.getTime())/1e3).property("startedAt",n.lastAttemptStartedAt.toISOString()).property("finishedAt",n.finishedAt.toISOString()).property("attempts",n.attempts.toString());for(let r of["testInputs","customHeaders"]){let o=n.parameters[r];Object.keys(o??{}).length>0&&t.multilineProperty(r,JSON.stringify(o))}for(let r of["envName","urlOverride"])n.parameters[r]!==void 0&&t.property(r,n.parameters[r]);return Object.keys(n.outputs).length&&t.multilineProperty("testOutputs",JSON.stringify(n.outputs)),t}function YM(n,{suiteId:e,suiteName:t,startedAt:r,finishedAt:o,runs:i}){let a=n.testSuite().name(t);e&&a.property("id",e),a.timestamp(r).property("startedAt",r.toISOString()).property("finishedAt",o.toISOString()).time((o.getTime()-r.getTime())/1e3);for(let s of i){let l=a.testCase();KM(s,l)}return a}function zv(n,e){let t=Uv.newBuilder();YM(t,e),t.writeTo(Bv.join(n,`${e.suiteName}.xml`))}import JM from"fs";import XM from"path";function Hv(n){return{title:ln(n),duration:n.finishedAt.getTime()-n.startedAt.getTime(),error:n.status==="FAILED"?{value:n.failureReason}:void 0,steps:n.results&&n.type!=="PRESET_ACTION"?n.results.map(Hv):[]}}async function ZM(n,e,t,r){if(r.results?.length){let o=await Wl(n,e,t,r.results[r.results.length-1].afterScreenshot,r.results[r.results.length-1].afterSnapshot);return o?[{name:"Final state screenshot",path:o,contentType:"image/jpeg"}]:[]}return[]}async function QM(n,e,t,r){return{status:r.status==="PASSED"?"passed":r.status==="CANCELLED"?"interrupted":"failed",duration:r.finishedAt.getTime()-r.lastAttemptStartedAt.getTime(),error:r.status==="FAILED"&&r.failureReason?{value:r.failureDetails?.classification?.reason||r.failureReason,message:r.failureDetails?.classification?.summary||To[r.failureReason]}:void 0,retry:r.attempts-1,steps:r.results?.map(Hv)||[],startTime:r.lastAttemptStartedAt.toISOString(),attachments:await ZM(n,e,t,r)}}async function eN(n,e,t,r){return{expectedStatus:"passed",status:r.status==="PASSED"?"expected":"unexpected",results:[await QM(n,e,t,r)]}}async function tN(n,e,t,r){return{tags:[],title:r.test.name,ok:r.status==="PASSED",tests:[await eN(n,e,t,r)],id:r.runId,file:r.filePath}}function lu(n,e){return n.reduce((t,r)=>e(r)?t+1:t,0)}async function nN(n,e,t,r){return{suites:[{title:r.suiteName,file:r.projectConfigPath,specs:await Promise.all(r.runs.map(o=>tN(n,e,t,o)))}],errors:[],stats:{startTime:r.startedAt.toISOString(),duration:r.finishedAt.getTime()-r.startedAt.getTime(),expected:lu(r.runs,o=>o.status==="PASSED"),unexpected:lu(r.runs,o=>o.status!=="PASSED"),flaky:lu(r.runs,o=>!!o.isFlake),skipped:0}}}async function jv(n,e,t,r){let o=await nN(n,e,t,r);JM.writeFileSync(XM.join(t,`${r.suiteName}.json`),JSON.stringify(o,null,2))}async function $v(n,e,t,r,o){switch(rN(o)?iN(o).isDirectory()||(y.error(`The specified reporter output directory '${o}' exists on disk but is not a folder. Please move or delete the existing object or specify a different reporter path.`),process.exit(1)):(y.info(`Reporter output directory '${o}' does not exist on disk, creating it now...`),oN(o,{recursive:!0})),t){case"junit":zv(o,r);return;case"allure":case"allure-json":await Fv(n,e,o,r);return;case"playwright-json":await jv(n,e,o,r);return;default:throw new Error(`Unknown reporter format requested: '${t}'`)}}import bN from"wait-on";import cu from"fs";import{compact as aN}from"lodash-es";import du from"path";import{cwd as sN}from"process";import lN from"semver";async function Gv({tests:n,momenticFiles:e,project:t,yes:r,include:o,exclude:i,labels:a}){let s=new Set;if(n&&n.length>0){let c=n.some(p=>cu.existsSync(p)),d=sN();c?(d!==t.rootDir&&y.warn(`The current working directory ('${d}') is different from the project root directory ('${t.rootDir}'). All test path arguments will be resolved relative to the current working directory and only those tests matched by the project inclusion configuration will be ran. To avoid confusion, Momentic strongly recommends running the CLI from the project root directory or using substring filters rather than file paths.`),y.info(`Reading tests from the following local file paths:
3637
3637
  ${n.map(p=>`${zt}- ${p}`).join(`
3638
3638
  `)}
3639
3639
  `),n.forEach(p=>{if(!cu.existsSync(p))throw new Error(`Path '${p}' does not exist.`);let m,u;try{m=cu.statSync(p),u=m.isDirectory()}catch(g){y.warn({err:g},`Skipping path ${p} because it cannot be read`);return}let h=du.resolve(p);Object.values(e.tests).filter(g=>u?g.fullFilePath.startsWith(h):g.fullFilePath===h).forEach(g=>{s.add(g.fullFilePath)})})):(y.info(`Reading all tests from the project and running those matching the following substring filters:
3640
3640
  ${n.map(p=>`${zt}- ${p}`).join(`
3641
- `)}`),Object.values(e.tests).forEach(p=>{n.some(m=>p.relativePath.includes(m))&&s.add(p.fullFilePath)}))}else{!r&&!await gt("No test paths or substrings were provided. Do you want to run all tests?")&&(y.error("Cancelled by user."),process.exit(1));let c=Object.values(e.tests);y.info(`Reading all ${c.length} tests in the project from local disk.`),c.forEach(d=>{s.add(d.fullFilePath)})}for(let c of s){let d=du.relative(t.rootDir,c);o&&!o.some(p=>new RegExp(p).test(d))&&s.delete(c),i&&i.some(p=>new RegExp(p).test(d))&&s.delete(c)}let l=Array.from(s).map(async c=>{try{let d=await ra(c,ne,e);if(lN.gt(d.schemaVersion,Fe)&&y.warn(`Test ${c} has schema version ${d.schemaVersion}, which is greater than what is currently supported by this SDK. Please update your momentic package version to avoid unexpected behavior.`),d.disabled)return null;if(a&&a.length>0){let p=d.labels||[];if(!a.some(u=>p.includes(u)))return null}return{...d,fullFilePath:c,relativeFilePath:du.relative(t.rootDir,c)}}catch(d){y.error(`Failed to read and resolve test at '${c}': ${d}`),process.exit(1)}});return Promise.all(l).then(aN)}import{cloneDeep as Yv}from"lodash-es";async function Wv({orgId:n,codeEvalTools:e,logger:t,outputDefinitions:r,testContext:o,flagStore:i}){let a={};for(let s of r){let{name:l,value:c}=s;a[l]=await Bt({orgId:n,s:c,localTools:e,logger:t,context:o,flagStore:i})}return a}async function Vv({baseUrl:n,envName:e,devicePixelRatio:t,apiClient:r,test:o,storageClient:i,codeEvalTools:a,generator:s,orgId:l,variables:c,logger:d,customHeaders:p,testInputs:m,localBrowserConfig:u,visualDiffScreenshotStorage:h,flagStore:g}){let f=await ul({settings:u,customHeaders:p,envVariables:c,envName:e,baseUrl:n,logger:d,localTools:a,orgId:l,flagStore:g}),S={baseUrl:r.baseUrl,apiKey:r.apiKey,logger:ne},b=g.isBooleanFlagEnabled("icon_knowledge_base")?await i.fetchIconKnowledgeBase(l,d):null,w=f.browserType??"Chromium";if(!Pv(w)){let A=`Browser ${w} is required by the test named ${o.name} but does not appear to be installed on this machine. Please install it using 'momentic install-browser' before running tests. Attempting to continue...`;y.warn(A),ne.warn(A)}let v=await On.init({baseUrl:n,logger:d,userBrowserSettings:f,storage:i,flagStore:g,enricher:new ri(S,s),contextArgs:{viewport:o.advanced.viewport??Gt,locale:o.advanced.locale??Eo,timezoneId:o.advanced.timezone??Co,colorScheme:o.advanced.colorScheme,deviceScaleFactor:t},iconKnowledgeBase:b}),x=new ui({browser:v,generator:s,logger:d,orgId:l,options:{scratchPadId:void 0,slowMoMs:f.slowMoMs,autoFollowNewTabs:f.autoFollowNewTabs},storage:i,flagStore:g,localCodeEvalTools:a,visualDiffScreenshotStorage:h,analytics:new hi}),C=new At({baseUrl:n,currentUrl:x.browser.url(),variablesFromEnvironment:c,envName:e});return o.parameters&&await Promise.all(o.parameters.map(async A=>{let{name:N,defaultValue:O,required:H}=A,F=m?.[N];H&&F===void 0&&(y.error(`Required parameter '${N}' is required by test '${o.name}' but not provided`),process.exit(1));let L=await Bt({orgId:l,s:F??O,localTools:a,logger:d,context:At.dummyContext(C.getEnvName()),flagStore:g});C.setMomenticSystemVariable(N,L)})),{controller:x,context:C}}import{randomUUID as cN}from"crypto";async function qv({testId:n,apiClient:e,testAdvancedSettings:t,aiSettingsFromEnv:r,logger:o}){if(t.failureRecovery===!1||t.failureRecovery===void 0&&!r?.failureRecovery)return!1;let i;try{i=await e.getPastTestResults(n,{afterTime:Date.now()-7*24*60*60*1e3})}catch(s){return o.error({err:s},"Test is not eligible for recovery since we failed to fetch the recent test results"),!1}return i.some(s=>s.status==="PASSED")?to?!0:(o.warn("The CLI is not running in a CI environment and therefore ineligible for failure recovery"),y.warn("Test failed but is not eligible for failure recovery since this does not appear to be a CI environment"),!1):(o.debug({recentRuns:i},"Test is not eligible for recovery because there are only failures in the past 7 days"),!1)}async function Kv({attemptInputs:n,attemptFixtures:e,attemptMetadata:t}){let{attemptNumber:r,orgId:o,runId:i,runAttemptId:a}=t,{controller:s,context:l,flagStore:c,analytics:d,codeEvalTools:p,storageClient:m,debugDataStorage:u,logger:h,apiClient:g,billingReporter:f,tracer:S}=e,{test:b,orgSettings:w}=n;h.info(`Running test '${b.name}' locally (run link: https://app.momentic.ai/runs/${i})`);let v={controller:s,storage:m,debugDataStorage:u,billingReporter:f,analytics:d,context:l,logger:h,codeEvalTools:p},x={orgId:o,runId:i||cN(),runAttemptId:a,testMetadata:b,steps:b.steps,beforeSteps:b.beforeSteps,afterSteps:b.afterSteps},C={collectDebugData:!0,reinitializeBrowser:!0,disableHealing:!await qv({currentAttempt:r,testId:b.id,flagStore:c,apiClient:g,testAdvancedSettings:b.advanced,aiSettingsFromEnv:w.ai,logger:h})};return await pl({fixtures:v,inputs:x,options:C,callbacks:{step:{},test:{onTestComplete:async()=>{await s.browser.cleanup()},onProposedTestSteps:async O=>g.uploadProposedSteps(O,h)}},testParams:{tracer:S}})}async function Jv(n){let{testDefinition:e,logger:t}=n,r=new Date;try{return await dN(n)}catch(o){let i="Fatal error running test";return y.error(`${i}: ${o.message}`),t.error({err:o},i),{parameters:n,failureReason:"UnknownError",failureDetails:{errorMessage:o.message,errorStack:o.stack},status:"FAILED",attempts:0,test:e,filePath:e.relativeFilePath,startedAt:r,lastAttemptStartedAt:r,finishedAt:new Date,outputs:{}}}}async function dN(n){let{testDefinition:e,project:t,apiClient:r,orgId:o,urlOverride:i,runSigIntHandlers:a,runGroupTracer:s,logger:l,gitMetadata:c,alwaysSaveCache:d,noCache:p}=n,m=new ei(r,o),u=oi({client:r,gitMetadata:c,alwaysSaveCache:d,noCache:p}),h=Yv(e.steps);try{await u.resolveStepCacheEntries({organizationId:o,testId:e.id,steps:h,schemaVersion:e.schemaVersion,logger:l})}catch(x){throw l.error({err:x},"Failed to resolve step cache entries"),new Error(`Failed to resolve step cache entries. Please ensure you are running using a supported version of Momentic. If you believe this is a Momentic issue, please contact Support with the following error: ${x}`)}let g=n.envName??uN(e),f,S={};if(g){try{f=oa(g,t,l)}catch(x){let C=`Failed to resolve environment ${g} for test ${e.name}: ${x}`;throw new Error(C)}S=f.variables}let b=e.baseUrl;if(i)b=i;else if(!b){let x=S[Ge];typeof x=="string"&&(b=x)}if(!b){let x=`Cannot run test with no base URL and no ${Ge} variable defined in its environment`;throw new Error(x)}let w=await s.startRun({logger:l,originalSteps:{beforeSteps:e.beforeSteps,steps:e.steps,afterSteps:e.afterSteps},testId:e.id,testName:e.name,testLabels:e.labels,baseUrl:b,environmentName:g,schemaVersion:e.schemaVersion}),v=l.child(w.loggerBindings||{});Object.entries(w.envVarBindings||{}).forEach(([x,C])=>{S[x]=C});try{let x=await pN({...n,variables:S,envName:g,stepsWithCaches:h,resolvedEnv:f,baseUrl:b,storageClient:m,tracer:w,logger:v,cacheStorage:u});return await w.finish({logger:l,status:x.status,finishedAt:x.finishedAt,failureDetails:x.failureDetails,failureReason:x.failureReason,isFlake:x.isFlake}),{runId:w.runId,...x}}finally{a?.pop()}}async function pN(n){let{testDefinition:e,stepsWithCaches:t,project:r,regenerateGoldenFiles:o,apiClient:i,generator:a,baseUrl:s,storageClient:l,orgId:c,envName:d,urlOverride:p,customHeaders:m,testInputs:u,variables:h,resolvedEnv:g,retriesOverride:f,devicePixelRatio:S,logUpdate:b,tracer:w,logger:v,flagStore:x,cacheStorage:C}=n,A=new Date,N=new Jo(r,o),O={ai:r.config.ai},H={envName:d,urlOverride:p,customHeaders:m,testInputs:u},F,L=Math.abs(f??r.config.retries??e.retries??0),B=[];v.info({labels:e.labels,name:e.name},"Starting test run using CLI");for(let P=0;P<=L;P++){let K=await w.startAttempt(),U=v.child(K.loggerBindings||{}),Y={...e,steps:Yv(t)};P!==0&&b("RETRY",`attempt ${P+1}/${L+1}`);let Z=new Date,ft=new dr({httpClient:new kt({baseUrl:i.baseUrl,apiKey:i.apiKey,logger:U}),fakerSeed:x.isBooleanFlagEnabled("faker_constant_seed")?sh:void 0});try{let{controller:re,context:we}=await Vv({baseUrl:s,envName:d,apiClient:i,devicePixelRatio:S,logger:U,storageClient:l,codeEvalTools:ft,test:Y,generator:a,orgId:c,variables:h,customHeaders:m,testInputs:u,localBrowserConfig:{...r.config.browser||{},...g?.browser||{},...Y.advanced},visualDiffScreenshotStorage:N,flagStore:x});F=await Kv({attemptMetadata:{attemptNumber:P+1,orgId:c,runId:w.runId},attemptFixtures:{logger:U,storageClient:l,billingReporter:new Lo,analytics:new hi,debugDataStorage:new Or,codeEvalTools:ft,flagStore:x,apiClient:i,context:we,controller:re,tracer:K},attemptInputs:{test:Y,orgSettings:O}});let Me=new Date;F?.status==="PASSED"&&await Cs({logger:v,cacheStorage:C,orgId:c,testId:e.id,originalSteps:{steps:e.steps,beforeSteps:e.beforeSteps,afterSteps:e.afterSteps},updatedSteps:{steps:Y.steps,beforeSteps:Y.beforeSteps,afterSteps:Y.afterSteps}}),await K.finish({logger:U,result:F}),B.unshift(F.status);let _t=await Wv({orgId:c,codeEvalTools:ft,logger:U,outputDefinitions:e.outputs??[],testContext:we,flagStore:x}),on=Um(B),j=P+1;if(F.status!=="FAILED")return{...F,parameters:H,test:Y,filePath:Y.relativeFilePath,startedAt:A,lastAttemptStartedAt:Z,finishedAt:Me,attempts:j,baseUrl:s,outputs:_t,isFlake:on};let Kn=F.failedStepResult,an=Kn?.message||"Unknown failure",wi=Kn?.failureReason??Sh(an)??"UnknownError",vi=U.child({errResult:Kn,failureReason:wi,errorMessage:an,numAttempts:L+1,name:Y.name});if(P<L){vi.warn(`Retrying failed execution attempt for run: ${an}`);continue}return vi.error(`Test failed after all exhausting attempts: ${an}`),{...F,parameters:H,failureDetails:{errorMessage:an},failureReason:wi,test:Y,filePath:Y.relativeFilePath,startedAt:A,lastAttemptStartedAt:Z,finishedAt:Me,attempts:P+1,baseUrl:s,outputs:_t}}catch(re){xi(re);let we=`Encountered fatal platform error while running test '${Y.name}': ${re}`,Me=new Date,_t=P+1;U.error({err:re},we),y.error(we);let on={errorMessage:re.message,errStack:re.stack},j={status:"FAILED",failureDetails:on,failureReason:"InternalPlatformError",finishedAt:Me};return await K.finish({logger:U,result:{status:"FAILED",results:[]}}),{...j,parameters:H,test:Y,filePath:Y.relativeFilePath,startedAt:A,lastAttemptStartedAt:Z,finishedAt:new Date,attempts:_t,baseUrl:s,outputs:{}}}}throw new Error("This code should not be reachable")}function uN(n){for(let e of n.envs??[])if(e.default)return e.name}import{randomUUID as Zv}from"crypto";import mN from"adm-zip";import Vn from"fs";import oo from"path";var ka=class n{constructor(e){this.filePath=e;Vn.rmSync(this.filePath,{recursive:!0,force:!0}),Vn.mkdirSync(this.filePath,{recursive:!0})}cd(e){return new n(oo.join(this.filePath,e))}storeFile(e){let{name:t,contents:r}=e,o=oo.join(this.filePath,t);Vn.writeFileSync(o,r)}createRunArchive(e){return new pu(oo.join(this.filePath,"runs"),e)}},pu=class{constructor(e,t){this.filePath=e;this.tempPath=oo.join(e,`.${t}`),this.finalPath=oo.join(e,`${t}.zip`),Vn.rmSync(this.tempPath,{recursive:!0,force:!0}),Vn.rmSync(this.finalPath,{recursive:!0,force:!0}),Vn.mkdirSync(this.tempPath,{recursive:!0})}tempPath;finalPath;cd(e){return new ka(oo.join(this.tempPath,e))}storeFile(e){let{name:t,contents:r}=e,o=oo.join(this.tempPath,t);Vn.writeFileSync(o,r)}close(){let e=new mN;e.addLocalFolder(this.tempPath,void 0,r=>r!==".DS_Store");let t=e.toBuffer();Vn.writeFileSync(this.finalPath,t),Vn.rmSync(this.tempPath,{recursive:!0,force:!0})}};async function Xv(n,e,t,r,o){let i=qi(o.type);if(i&&await e.reportCreditsUsed(n,o.type,i,{testId:t,testName:r}),"command"in o){let a=Ki(o.command);a&&await e.reportCreditsUsed(n,o.command.type,a,{testId:t,testName:r})}}function hN(n){switch(n){case"PASSED":return"SUCCESS";case"FAILED":return"FAILED";case"CANCELLED":return"CANCELLED";case"RUNNING":case"PENDING":case"RETRYING":case"WAITING_FOR_USER":return"RUNNING"}}function gN(n){switch(n){case"SUCCESS":return"PASSED";case"FAILED":return"FAILED";case"CANCELLED":return"CANCELLED";case"RUNNING":return"RUNNING";case"IDLE":return"PENDING"}}var uu=class{constructor(e,t,r,o,i,a){this.testId=e;this.testName=t;this.metadata=r;this.diskStorage=o;this.billingReporter=i;this.asyncWork=a}children=[];finished=!1;getParentStepIdChain(){return[]}attachBeforeScreenshot(e){let{snapshotId:t,screenshot:r}=e;this.metadata.beforeSnapshotId=t,this.diskStorage.storeFile({name:"before.jpeg",contents:r})}attachAfterScreenshot(e){let{snapshotId:t,screenshot:r}=e;this.metadata.afterSnapshotId=t,this.diskStorage.storeFile({name:"after.jpeg",contents:r})}attachBeforeHtmlSnapshot(e){let{snapshotId:t,html:r}=e;this.metadata.beforeSnapshotId=t,this.diskStorage.storeFile({name:"before.html",contents:r})}attachAfterHtmlSnapshot(e){let{snapshotId:t,html:r}=e;this.metadata.afterSnapshotId=t,this.diskStorage.storeFile({name:"after.html",contents:r})}heal(e){let{healType:t}=e;this.metadata.healMetadata={healType:t,healedAt:new Date}}async finishInternal(e){if(this.finished)return;this.finished=!0,await Promise.all(this.children.map(r=>r.finish({status:gN(e.status),finishedAt:e.finishedAt})));let t={...this.metadata,status:e.status,finishedAt:e.finishedAt,message:e.message};this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(t,null,2)})}async finish(e){await this.finishInternal(e.step)}async startSubSteps(){let e=this.diskStorage.cd("substeps"),t=new Vl(this.testId,this.testName,e,this.billingReporter,this.asyncWork);return this.children.push(t),t}},Vl=class{constructor(e,t,r,o,i){this.testId=e;this.testName=t;this.diskStorage=r;this.billingReporter=o;this.asyncWork=i}children=[];finished=!1;getParentStepIdChain(){return[]}async startStep(e){let{logger:t,step:r}=e;this.asyncWork.push(Xv(t,this.billingReporter,this.testId,this.testName,r));let o=this.diskStorage.cd(r.id),i={step:r,status:"RUNNING",startedAt:new Date};o.storeFile({name:"metadata.json",contents:JSON.stringify(i,null,2)});let a=new uu(this.testId,this.testName,i,o,this.billingReporter,this.asyncWork);return this.children.push(a),a}async finish(e){this.finished||(this.finished=!0,await Promise.all(this.children.map(t=>t.finishInternal({status:hN(e.status),finishedAt:e.finishedAt}))))}},mu=class{constructor(e,t,r,o,i,a,s,l,c){this.orgId=e;this.testId=t;this.testName=r;this.originalSteps=o;this.metadata=i;this.client=a;this.diskStorage=s;this.billingReporter=l;this.asyncWork=c}finished=!1;children=[];trackStatus(){}attachNetworkLogs(e){let{logs:t}=e;this.diskStorage.storeFile({name:"network.har",contents:JSON.stringify(t,null,2)})}attachConsoleLogs(e){let{logs:t}=e;this.diskStorage.storeFile({name:"console.json",contents:JSON.stringify(t,null,2)})}async finish(e){if(this.finished)return;this.finished=!0;let{logger:t,result:r}=e,o={...this.metadata,status:r.status,finishedAt:new Date,results:As(r.results,t),beforeResults:r.beforeResults?As(r.beforeResults,t):void 0,afterResults:r.afterResults?As(r.afterResults,t):void 0};await Promise.all(this.children.map(i=>i.finish({status:o.status,finishedAt:o.finishedAt}))),this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(o,null,2)})}async startStepList(){let e=this.diskStorage.cd("steps"),t=new Vl(this.testId,this.testName,e,this.billingReporter,this.asyncWork);return this.children.push(t),t}},hu=class{constructor(e,t,r,o,i,a,s,l,c,d){this.orgId=e;this.testId=t;this.testName=r;this.runId=o;this.originalSteps=i;this.metadata=a;this.client=s;this.diskStorage=l;this.billingReporter=c;this.asyncWork=d}children=[];finished=!1;get loggerBindings(){return{runId:this.runId}}get envVarBindings(){return{[Sy]:this.runId}}async finish(e){if(this.finished)return;this.finished=!0;let t={...this.metadata,finishedAt:e.finishedAt||new Date,status:e.status,failureDetails:e.failureDetails,failureReason:e.failureReason,flake:e.isFlake||!1};await Promise.all(this.children.map(r=>r.finish({logger:e.logger,result:{status:t.status,results:[],beforeResults:[],afterResults:[]}}))),this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(t,null,2)}),this.diskStorage.close()}trackStatus(){}async startAttempt(){this.metadata.attempts=this.metadata.attempts+1,this.metadata.status="RUNNING",this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(this.metadata,null,2)});let e=this.diskStorage.cd(`attempts/${this.metadata.attempts}`),t={schemaVersion:Fe,startedAt:new Date,status:"RUNNING"};e.storeFile({name:"metadata.json",contents:JSON.stringify(t,null,2)});let r=new mu(this.orgId,this.testId,this.testName,this.originalSteps,t,this.client,e,this.billingReporter,this.asyncWork);return this.children.push(r),r}},ql=class n{constructor(e,t,r,o,i,a){this.orgId=e;this.runGroupId=t;this.metadata=r;this.client=o;this.diskStorage=i;this.billingReporter=a;this.asyncWork=[]}children=[];finished=!1;asyncWork;get loggerBindings(){return{orgId:this.orgId,runGroupId:this.runGroupId,branch:this.metadata.gitBranchName}}static async start(e,t,r,o,i,a){let s=Zv(),l={...a,trigger:Wt.CLI,startedAt:new Date,status:"RUNNING",cliVersion:fn},c=new ka(r);return c.storeFile({name:"metadata.json",contents:JSON.stringify(l,null,2)}),new n(t,s,l,o,c,i)}async finish(e){if(this.finished)return;this.finished=!0;let{status:t}=e,r={...this.metadata,status:t,updatedAt:new Date,finishedAt:new Date};await Promise.all(this.children.map(o=>o.finish({logger:e.logger,status:r.status,finishedAt:r.finishedAt}))),this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(r,null,2)}),await Promise.allSettled(this.asyncWork)}trackStatus(){}async startRun(e){let t=Zv(),r=this.diskStorage.createRunArchive(t),o={stepsSnapshot:e.originalSteps.steps,runGroupId:this.runGroupId,testId:e.testId,testName:e.testName,labels:e.testLabels,trigger:"CLI",status:"RUNNING",resolvedBaseUrl:e.baseUrl,environmentName:e.environmentName,cliVersion:fn,schemaVersion:e.schemaVersion,startedAt:new Date,attempts:0};r.storeFile({name:"metadata.json",contents:JSON.stringify(o,null,2)}),this.asyncWork.push(this.billingReporter.reportBillableEvent(e.logger,"test-run",{eventId:t,testId:e.testId,testName:e.testName}));let i=new hu(this.orgId,e.testId,e.testName,t,e.originalSteps,o,this.client,r,this.billingReporter,this.asyncWork);return this.children.push(i),i}};import Qv from"adm-zip";import eT from"fs";import Kl from"path";function fN(n){let e=new Qv;e.addLocalFile(Kl.join(n,"metadata.json"));for(let t of eT.readdirSync(Kl.join(n,"runs"))){if(!t.endsWith(".zip"))continue;let r=t.replace(/\.zip$/,""),o=new Qv(Kl.join(n,"runs",t));for(let i of o.getEntries())i.isDirectory||e.addFile(Kl.join("runs",r,i.entryName),i.getData())}return e.toBuffer()}async function Yl(n){let{client:e,consoleLogger:t,resultsPath:r}=n;if(!eT.existsSync(r)){t.warn("Results path does not exist, skipping upload.");return}let o=new ol(e);try{let i=fN(r),a=await o.uploadResultsArchive(i),s=`${e.getAppUrl()}/run-groups/${a}`;t.success(`Successfully uploaded test results. Once processed, your results can be found at ${s}`);return}catch(i){let a;i instanceof Error?a=i.message:typeof i=="string"?a=i:a="Unknown error",t.error(`Failed to upload test results: ${a}.`);return}}async function tT(n){let{logger:e,tests:t,yes:r,start:o,waitOn:i,client:a,debugDataStorage:s,billingReporter:l,flagStore:c,project:d,retriesOverride:p,urlOverride:m,envName:u,orgId:h,devicePixelRatio:g,customHeaders:f,testInputMatrix:S,reporter:b,include:w,exclude:v,labels:x,reporterDir:C=FS,outputDir:A=US,uploadResults:N=!1,waitOnTimeout:O=60,parallel:H=d.config.parallel??1,shardIndex:F=1,shardCount:L=1,regenerateGoldenFiles:B,gitMetadata:P,alwaysSaveCache:K,noCache:U}=n;o&&(e.info({orgId:h},`Executing start command: ${o}`),await Gw(o,!1)),i&&(e.info({orgId:h},`Waiting for url: ${i} with timeout: ${O} seconds.`),await bN({resources:[i],interval:2500,timeout:O*1e3,headers:{Accept:"*/*"},followRedirect:!0,verbose:!1,log:!0,strictSSL:!1}));let Y=new ni(d.config.ai?.agentConfig,{baseUrl:a.baseUrl,apiKey:a.apiKey,logger:e}),Z=Oe(d,y),ft=await Gv({tests:t,momenticFiles:Z,yes:r,project:d,include:w,exclude:v,labels:x}),re=[];ft.forEach((ot,br)=>{S?S.forEach((so,St)=>{re.push({testIndex:br,inputs:so,inputIndex:St})}):re.push({testIndex:br,inputs:void 0,inputIndex:void 0})}),L&&L>1&&(re=wN(re,F,L));let we=`Running ${re.length} tests with ${H} workers:`;e.info({allTestsToRunWithInputs:re,shardCount:L,shardIndex:F,orgId:h},we),y.info(we),re.forEach(ot=>{y.info(`${zt}- ${[ft[ot.testIndex].relativeFilePath]}${typeof ot.inputIndex=="number"?` with input set ${ot.inputIndex}`:""}`)}),y.log("");let Me=[],_t=new Date,on=new Set,j=async()=>{let ot=a.getAppUrl(),br=Si({results:Me,startTime:_t.getTime(),onFailed:St=>{jl(St,St.filePath)},getDisplayLine:St=>{let wr=`${zt}- ${St.filePath}${St.proposedTest?" [AUTO-HEALED] ":""}`;return St.runId&&(wr+=` (link when uploaded: ${ot}/runs/${St.runId})`),wr},entity:"test"}),so=Me.filter(St=>!!St.proposedTest);return so.length>0&&y.warn(`${so.length} tests passed with auto-healing. Please use the run links printed above to review proposed changes and apply them locally.`),y.log(""),N?(y.success(`Test results have been saved to the folder ${A}. Uploading to Momentic cloud.`),await Yl({client:a,consoleLogger:y,resultsPath:A})):y.success(`Test results have been saved to the folder ${A}. Upload them to Momentic cloud by running 'npx momentic results upload ${A}'.`),br};yN.existsSync(A)&&y.warn(`Output directory ${A} already exists, removing before test execution...`);let Kn=await ql.start(e,h,A,a,l,P),an=e.child(Kn.loggerBindings||{}),wi=[],vi=async()=>{y.warn("SIGINT received. Stopping tests and printing latest results..."),await Kn.finish({logger:an,status:"CANCELLED"}),await j(),await Promise.allSettled(wi.map(ot=>ot())),process.exit(1)};process.once("SIGINT",vi);let ao={};for(let ot=0;ot<re.length;ot++){let br=Object.values(ao);br.length===H&&await Promise.race(br.map(wr=>wr.promise));let so=re[ot],St=`test-${ot}`;ao[St]={done:!1,promise:(async({testIndex:wr,inputs:yu})=>{let lo=ft[wr];on.add({testIndex:wr,inputs:yu});let dT=lo.relativeFilePath.includes("..")?lo.fullFilePath:lo.relativeFilePath,Ma=(ct,Ti)=>{ct=ct.toUpperCase();let Mn=ct,Yn;ct.includes("FAIL")?(Mn=bi.bgRed.white("FAIL"),Yn=3):ct.includes("PASS")?(Mn=bi.bgGreen.white("PASS"),Yn=3):ct.includes("START")?(Mn=bi.bgBlue.white("START"),Yn=2):ct.includes("CANCEL")?(Mn=bi.bgRgb(191,68,11).white("CANCEL"),Yn=1):ct.includes("RETRY")?(Mn=bi.bgRgb(191,68,11).white("RETRY"),Yn=2):ct.includes("RUN")||ct.includes("PROG")?(Mn=bi.bgMagenta.white("RUNNING"),Yn=0):(an.warn(`Unknown status tried to be logged in run test locally: ${ct}`),Yn=0),SN||(Mn=`${Mn}`),y.log(`${Mn}${" ".repeat(Yn)} ${dT} ${Ti?`${Ti} `:""}(${on.size}/${re.length})`)};Ma("START");let pT=setInterval(()=>Ma("RUN"),5*60*1e3),bu=an.child({testId:lo.id});try{let ct=await Jv({testDefinition:lo,project:d,testInputs:yu,orgId:h,devicePixelRatio:g,apiClient:a,runGroupTracer:Kn,generator:Y,retriesOverride:p,urlOverride:m,envName:u,customHeaders:f,regenerateGoldenFiles:B,logUpdate:Ma,runSigIntHandlers:wi,logger:bu,flagStore:c,gitMetadata:P,alwaysSaveCache:K,noCache:U});Ma(ct.status),Me.push(ct)}catch(ct){let Ti=`Encountered unexpected fatal error when running test '${lo.name}': ${ct.message}`;y.error(Ti),bu.error(Ti)}finally{clearInterval(pT),ao[St].done=!0,delete ao[St]}})(so)}}await Promise.allSettled(Object.values(ao).map(ot=>ot.promise));let Su="PASSED";return Me.some(ot=>ot.status==="FAILED")&&(Su="FAILED"),await Kn.finish({logger:an,status:Su}),process.off("SIGINT",vi),b&&await $v(an,s,b,{projectConfigPath:d.configFilePath,suiteName:d.config.name,startedAt:_t,finishedAt:new Date,runs:Me},C),j()}function wN(n,e,t){if(t>n.length&&(y.warn(`Shard count ${t} is greater than the number of tests ${n.length}! Some workers won't have any tests to run.`),t=Math.max(t,n.length),e>t))return[];let r=Math.floor((e-1)*(n.length/t)),o=Math.floor(e*(n.length/t));return n.sort().filter((a,s)=>s>=r&&s<o)}import qn from"fs";import io from"path";var nT={status:(n,e)=>{if(n.status===e.status)return n.status;if(n.status==="FAILED"||e.status==="FAILED")return"FAILED";if(n.status==="CANCELLED"||e.status==="CANCELLED")return"CANCELLED";if(n.status==="RETRYING"||e.status==="RETRYING")return"RETRYING";if(n.status==="RUNNING"||e.status==="RUNNING")return"RUNNING";if(n.status==="PENDING"||e.status==="PENDING")return"PENDING";throw new Error(`Invalid run status merge: ${n.status} and ${e.status}`)},startedAt:(n,e)=>n.startedAt<e.startedAt?n.startedAt:e.startedAt,updatedAt:(n,e)=>n.updatedAt>e.updatedAt?n.updatedAt:e.updatedAt,finishedAt:(n,e)=>!n.finishedAt||!e.finishedAt?new Date:n.finishedAt>e.finishedAt?n.finishedAt:e.finishedAt,gitCommitTimestamp:(n,e)=>{if(!(!n&&!e)){if(!n.gitCommitTimestamp||!e.gitCommitTimestamp||n.gitCommitTimestamp.getTime()!==e.gitCommitTimestamp.getTime())throw new Error(`Git commit timestamps must match to be merged: ${n.gitCommitTimestamp} and ${e.gitCommitTimestamp}`);return n.gitCommitTimestamp}},pipelineId:(n,e)=>n.pipelineId===e.pipelineId?n.pipelineId:!n.pipelineId&&e.pipelineId?e.pipelineId:!e.pipelineId&&n.pipelineId?n.pipelineId:n.startedAt<e.startedAt?e.pipelineId:n.pipelineId};function rT(n,e){let t=n[e];if(!t)throw new Error(`No metadata value found for key: ${e}`);return t}function vN(n,e,t){if(nT[t]){let i=nT[t];return i(n,e)}let r=rT(n,t),o=rT(e,t);if(r!==o)throw new Error(`Metadata values for key "${t}" do not match: "${r}" vs "${o}"`);return r}var oT=new Set([".DS_Store","__MACOSX"]);function iT(n,e){qn.rmSync(n,{recursive:!0,force:!0});let t=qn.readdirSync(e).filter(a=>!oT.has(a)).map(a=>io.join(e,a));qn.mkdirSync(n,{recursive:!0});let r=io.join(t[0],"metadata.json"),o=td.parse(JSON.parse(qn.readFileSync(r,"utf-8")));for(let a of t){let s=io.join(a,"runs");if(!qn.existsSync(s))continue;let l=qn.readdirSync(s);for(let p of l){if(oT.has(p))continue;let m=io.join(s,p),u=io.join(n,"runs",p);qn.cpSync(m,u,{recursive:!0})}let c=io.join(a,"metadata.json"),d=td.parse(JSON.parse(qn.readFileSync(c,"utf-8")));for(let p in d){let m=p;o[m]=vN(o,d,m)}}let i=io.join(n,"metadata.json");qn.writeFileSync(i,JSON.stringify(o,null,2))}var aT=new gi({platform:"cli"},{flushAt:1,flushInterval:0});Zl||ne.warn("Sentry is not enabled in this environment due to unsupported node version");var AN=process.argv.some(n=>n.includes("--log-level"))&&process.argv.some(n=>n.includes("debug")),gu=n=>{AN&&y.dimmed(n)},Nt=new TN;Nt.name("momentic").description("CLI").version(fn);Nt.command("install-browsers").description("Install browser executables onto the local machine.").option("-f, --force","Force reinstallation even if the browser executables already exist on disk.").option("-a, --all","Install all browsers types.").argument("[browsers...]",`Browsers to install. Available choices: ${iu.join(", ")}.`).action(async(n,e)=>{!e.all&&n.length===0&&(y.error("No browsers specified"),process.exit(1)),await Lv({rawBrowsers:n,force:e.force,all:e.all})});Nt.addOption(new rn("--log-level <level>").choices(["debug","info","warn","error"]).default("info")).on("option:log-level",n=>{n==="debug"&&y.info("Enabling debug logging"),y.setMinLevel(n.toLowerCase())});Nt.addOption(new rn("--verbose","enable verbose logging")).on("option:verbose",()=>{ne.enableConsoleLogs(),y.setMinLevel(0)});var fu=Nt.command("checks").alias("check").description("Perform various project checks");fu.command("config").addOption(kn).action(async n=>{Qt({configFilePath:n.config})});fu.command("duplicate-ids").description("Checks if any steps in your entire Momentic test repository share the same ID.").addOption(kn).addOption(lv).action(async n=>{let e=await Sn(n),t=Qt({configFilePath:n.config});await yv({project:t,fix:e.fix})});fu.command("duplicate-names").description("Checks if tests or modules with duplicate names or ids exist").addOption(kn).action(async n=>{let e=Qt({configFilePath:n.config});await bv({project:e})});var sT=Nt.command("migrate").description("Migrate and upgrade tooling");sT.command("steps").description("Migrate steps in all tests and modules to the latest schema version. Note that this is always done when a test is loaded through the interactive editor, so is generally not needed.").addOption(kn).action(async n=>{let e=Qt({configFilePath:n.config});await Ov(e)});sT.command("v1-v2").description("Migrate from v1 of the Momentic CLI to v2").addOption(Wn).addOption(kn).addOption(Gn).action(async n=>{let e=await Sn(n);!e.yes&&!await gt("This command will modify your existing Momentic configuration. Please backup your local directory using Git or another version control system before proceeding. Continue?",!0)&&process.exit(1);let t=Qt({configFilePath:n.config}),r=new lt({baseUrl:e.server,apiKey:e.apiKey,logger:ne}),{orgId:o}=await r.getAuthInfo();await Mv({project:t,orgId:o,apiClient:r}),process.exit(0)});Nt.command("import").addOption(Gn).addOption(Wn).addOption(kn).addOption(ro).addArgument(dv).action(async(n,e)=>{let t=await Sn(e),{apiKey:r,server:o,config:i,yes:a}=t,s=Qt({configFilePath:i}),l=new lt({baseUrl:o,apiKey:r,logger:ne});!n||n.length===0?await Ev({client:l,project:s,skipPrompts:a}):await Cv({client:l,project:s,paths:n,skipPrompts:a}),process.exit(0)});Nt.command("init").description("Initialize an empty Momentic project in the current working directory").addOption(new rn("--name <name>","Name of the project")).action(async n=>{y.info(`Welcome to the Momentic project setup wizard! \u{1F680}
3642
- `),y.info("This wizard will help you bootstrap a new Momentic project. If you need to import existing assets from Momentic Cloud, you can call the 'import' command after initialization."),Xl.existsSync(qo)&&(y.error("A momentic.config.yaml file already exists in this directory. Please rename or remove it to initialize a new project."),process.exit(1));let t={name:n.name??await Jw("Choose an identifier for your project, such as a service, product, or team name (default: 'app'):","app"),include:kd};Ko(t,qo),y.success(`Initialized Momentic project file at ${Jl.resolve(qo)}`)});Nt.command("app").addOption(Gn).addOption(Wn).addOption(ro).addOption(Yp).addOption(iv).addOption(kn).addOption(Zp).addOption(Qp).action(async n=>{let e=await Sn(n),{apiKey:t,port:r=_l,yes:o,server:i,pixelRatio:a,disableCache:s,saveCache:l}=e,c=new lt({baseUrl:i,apiKey:t,logger:ne});await eu({client:c,skipPrompts:o});let d=RN(import.meta.url),p=Jl.dirname(d),m=Jl.resolve(p,"..","static"),u=Jl.resolve(p,"..","assets"),h=a??zp();Hp(h),await Hw({momenticServerUrl:i,apiKey:t,serverPort:r,appPort:r,staticDir:m,assetsDir:u,devicePixelRatio:h,version:fn,noCache:s,alwaysSaveCache:l});let g=`http://localhost:${r}`;await CN(g)});var lT=Nt.command("queue").description("Queue tests or suites to run on Momentic Cloud");lT.command("suites").description("Run one or more suites on Momentic Cloud").addOption(Gn).addOption(Wn).addOption(Vp).addOption(qp).addOption(ro).addArgument(uv).addOption(Ul).addOption(Fl).addOption(Dl).action(async(n,e)=>{let{apiKey:t,server:r,wait:o,waitTimeout:i,env:a,urlOverride:s,customHeaders:l}=await Sn(e),c=new lt({baseUrl:r,apiKey:t,logger:ne});(!n||!Array.isArray(n)||!n.length)&&(y.error("Must pass at least one suite to run."),process.exit(1));let{orgId:d}=await c.getAuthInfo();await _v({client:c,orgId:d,wait:o,suitePaths:n,waitTimeout:i,env:a,urlOverride:s,customHeaders:Bl(l)})});lT.command("tests").description("Run one or more tests on Momentic Cloud").addOption(Gn).addOption(Wn).addOption(ro).addOption(Dl).addOption(Jp).addOption(Ul).addOption(Fl).addOption(Vp).addOption(qp).addArgument(cv).action(async(n,e)=>{let t=await Sn(e),{all:r,apiKey:o,customHeaders:i,env:a,server:s,inputCsv:l,urlOverride:c,wait:d,waitTimeout:p,yes:m}=t,u=Bl(i);for(let S of n)(S.endsWith(".yaml")||Xl.existsSync(S))&&y.warn("Are you trying to run a test on your local machine? If so, please use the 'run' command instead of the 'queue' command");let h=new lt({baseUrl:s,apiKey:o,logger:ne}),{orgId:g}=await h.getAuthInfo(),f;l&&(f=await jp(l)),await Dv({client:h,orgId:g,tests:n,all:r,customHeaders:u,env:a,urlOverride:c,wait:d,waitTimeout:p,testInputMatrix:f,yes:m}),process.exit(0)});var IN=Nt.command("run").alias("test").description("Run tests on the local machine");IN.addOption(Gn).addOption(Wn).addOption(kn).addOption(Xp).addOption(ro).addOption(Dl).addOption(Jp).addOption(Zp).addOption(Qp).addOption(Fl).addOption(Ul).addOption(Yp).addOption(new rn("--start <start>","Arbitrary setup command that will run before Momentic steps begin.")).addOption(new rn("--wait-on <waitOn>","URL to wait to become accessible before Momentic tests begin.")).addOption(new rn("--wait-on-timeout <waitOnTimeout>","Max time in seconds to wait for the --wait-on URL to become accessible.")).addOption(new rn("--retries <retries>","Number of retries to attempt when running tests locally. Defaults to each test's own retry configuration.")).addOption(new rn("-p, --parallel <parallel>","When running with the --local flag, the number of tests to run in parallel. Defaults to 1.")).addOption(new rn("--labels <labels...>","Only run tests with the specified label(s).")).addOption(new rn("--update-golden-files","Update locally stored golden files for steps that this is enabled for.")).addOption(ev).addOption(tv).addOption(Kp).addOption(nv).addOption(av).addOption(sv).addOption(rv).addOption(ov).addArgument(pv).action(async(n,e)=>{y.debug("Run tests invoked");let t=await Sn(e);y.debug(t,"Parsed CLI options");let r=Bl(t.customHeaders),o=Qt({configFilePath:t.config,nameFilter:t.filter});y.debug({projectName:o.config.name},"Identified project config");let{errors:i}=await ru({project:o,fix:!1});i>0&&(y.error(`Found errors in ${i} steps`),y.warn("To fix these errors automatically, run the duplicate-ids check with the --fix flag and then commit the resulting changes"),process.exit(1));let a=new lt({baseUrl:t.server,apiKey:t.apiKey,logger:ne});y.debug("Checking API key and dependencies");let{orgId:s,userId:l}=await eu({client:a,skipPrompts:t.yes});y.debug("API key check and browser installation complete");let c=new nl(a),d=new rl(a),p=t.outputDir??o.config.outputDir,m=t.reporterDir??o.config.reporterDir,u=ne.child({orgId:s,userId:l,cliVersion:fn,trigger:"CLI"}),h=await Zo(ne,a,o);u.debug(h,"Got local git metadata");let g=new Xo(o.config),f=aT.child({org_id:s,user_id:l,cli_version:fn,trigger:"CLI"}),S;t.inputCsv&&(S=await jp(t.inputCsv));let b=t.pixelRatio??zp();Hp(b);try{(await tT({...t,retriesOverride:t.retries,devicePixelRatio:b,tests:n,project:o,client:a,debugDataStorage:d,billingReporter:c,analytics:f,flagStore:g,outputDir:p,uploadResults:t.uploadResults,reporterDir:m,customHeaders:r,envName:t.env,orgId:s,testInputMatrix:S,logger:u,regenerateGoldenFiles:t.updateGoldenFiles,gitMetadata:h,alwaysSaveCache:t.saveCache,noCache:t.disableCache})).failed>0?process.exit(1):process.exit(0)}catch(w){y.error("Failed to run tests locally. Please check the error message below or run with the --verbose flag."),y.error(w),process.exit(1)}});var PN=Nt.command("apply").description("Apply an operation to local resources");PN.command("patch").addOption(Gn).addOption(Wn).addOption(kn).addOption(Xp).addOption(ro).addOption(new rn("--from <from>","Name or ID of the patch to apply").makeOptionMandatory()).addOption(new rn("--to <to>","Name or ID of the test to apply the patch to").makeOptionMandatory()).action(async n=>{let e=await Sn(n),{apiKey:t,server:r,config:o,yes:i}=e,a=Qt({configFilePath:o}),s=ne,l=new lt({baseUrl:r,apiKey:t,logger:s}),c=Oe(a,y),d=c.tests[n.to]??Object.values(c.tests).find(m=>Ne(m.name)===n.to.trim());d||(y.error(`No test matching '${n.to}' could be found in the current project.`),process.exit(1));let p=await l.fetchTestFragment(n.from);await Xw({client:l,test:d,fragment:p,yes:i,entities:c,logger:ne}),process.exit(0)});var cT=Nt.command("results").description("Merge and upload test results.");cT.command("merge").description("Merge test results files.").addOption(Kp).addArgument(mv).action(async(n,e)=>{let t=await Sn(e),{outputDir:r}=t;r||(y.error("Output directory is required."),process.exit(1)),Xl.existsSync(n)||(y.warn("Results path does not exist, skipping merge."),process.exit(0)),Xl.existsSync(r)&&y.warn(`Output directory ${r} already exists, removing before merging...`),iT(r,n)});cT.command("upload").description("Upload test results to Momentic cloud.").addOption(Gn).addOption(Wn).addArgument(hv).action(async(n,e)=>{let t=await Sn(e),{apiKey:r,server:o}=t,i=ne,a=new lt({baseUrl:o,apiKey:r,logger:i});await Yl({consoleLogger:y,resultsPath:n,client:a}),process.exit(0)});async function LN(){gu("Main program started"),await Vw(ne),gu("CLI version check complete");try{await Nt.parseAsync(process.argv)}catch(n){let e={};try{e.playwrightVersion=xN("npx playwright --version").toString()}catch(t){ne.error({err:t},"Error fetching debug information")}ne.error({err:n,debugInfo:e},"Uncaught error in CLI"),ne.flush(),xi(n,e),y.error(n),process.exit(1)}}EN.setMaxListeners(50);process.on("warning",n=>{ne.warn({err:n},`Node warning received on CLI: ${n.message}`)});gu("CLI parsing setup complete");LN();
3641
+ `)}`),Object.values(e.tests).forEach(p=>{n.some(m=>p.relativePath.includes(m))&&s.add(p.fullFilePath)}))}else{!r&&!await gt("No test paths or substrings were provided. Do you want to run all tests?")&&(y.error("Cancelled by user."),process.exit(1));let c=Object.values(e.tests);y.info(`Reading all ${c.length} tests in the project from local disk.`),c.forEach(d=>{s.add(d.fullFilePath)})}for(let c of s){let d=du.relative(t.rootDir,c);o&&!o.some(p=>new RegExp(p).test(d))&&s.delete(c),i&&i.some(p=>new RegExp(p).test(d))&&s.delete(c)}let l=Array.from(s).map(async c=>{try{let d=await ra(c,ne,e);if(lN.gt(d.schemaVersion,Fe)&&y.warn(`Test ${c} has schema version ${d.schemaVersion}, which is greater than what is currently supported by this SDK. Please update your momentic package version to avoid unexpected behavior.`),d.disabled)return null;if(a&&a.length>0){let p=d.labels||[];if(!a.some(u=>p.includes(u)))return null}return{...d,fullFilePath:c,relativeFilePath:du.relative(t.rootDir,c)}}catch(d){y.error(`Failed to read and resolve test at '${c}': ${d}`),process.exit(1)}});return Promise.all(l).then(aN)}import{cloneDeep as Yv}from"lodash-es";async function Wv({orgId:n,codeEvalTools:e,logger:t,outputDefinitions:r,testContext:o,flagStore:i}){let a={};for(let s of r){let{name:l,value:c}=s;a[l]=await Bt({orgId:n,s:c,localTools:e,logger:t,context:o,flagStore:i})}return a}async function Vv({baseUrl:n,envName:e,devicePixelRatio:t,apiClient:r,test:o,storageClient:i,codeEvalTools:a,generator:s,orgId:l,variables:c,logger:d,customHeaders:p,testInputs:m,localBrowserConfig:u,visualDiffScreenshotStorage:h,flagStore:g}){let f=await ul({settings:u,customHeaders:p,envVariables:c,envName:e,baseUrl:n,logger:d,localTools:a,orgId:l,flagStore:g}),S={baseUrl:r.baseUrl,apiKey:r.apiKey,logger:ne},b=g.isBooleanFlagEnabled("icon_knowledge_base")?await i.fetchIconKnowledgeBase(l,d):null,w=f.browserType??"Chromium";if(!Pv(w)){let A=`Browser ${w} is required by the test named ${o.name} but does not appear to be installed on this machine. Please install it using 'momentic install-browser' before running tests. Attempting to continue...`;y.warn(A),ne.warn(A)}let v=await On.init({baseUrl:n,logger:d,userBrowserSettings:f,storage:i,flagStore:g,enricher:new ni(S,s),contextArgs:{viewport:o.advanced.viewport??Gt,locale:o.advanced.locale??xo,timezoneId:o.advanced.timezone??Eo,colorScheme:o.advanced.colorScheme,deviceScaleFactor:t},iconKnowledgeBase:b}),x=new pi({browser:v,generator:s,logger:d,orgId:l,options:{scratchPadId:void 0,slowMoMs:f.slowMoMs,autoFollowNewTabs:f.autoFollowNewTabs},storage:i,flagStore:g,localCodeEvalTools:a,visualDiffScreenshotStorage:h,analytics:new mi}),C=new At({baseUrl:n,currentUrl:x.browser.url(),variablesFromEnvironment:c,envName:e});return o.parameters&&await Promise.all(o.parameters.map(async A=>{let{name:N,defaultValue:O,required:H}=A,F=m?.[N];H&&F===void 0&&(y.error(`Required parameter '${N}' is required by test '${o.name}' but not provided`),process.exit(1));let L=await Bt({orgId:l,s:F??O,localTools:a,logger:d,context:At.dummyContext(C.getEnvName()),flagStore:g});C.setMomenticSystemVariable(N,L)})),{controller:x,context:C}}import{randomUUID as cN}from"crypto";async function qv({testId:n,apiClient:e,testAdvancedSettings:t,aiSettingsFromEnv:r,logger:o}){if(t.failureRecovery===!1||t.failureRecovery===void 0&&!r?.failureRecovery)return!1;let i;try{i=await e.getPastTestResults(n,{afterTime:Date.now()-7*24*60*60*1e3})}catch(s){return o.error({err:s},"Test is not eligible for recovery since we failed to fetch the recent test results"),!1}return i.some(s=>s.status==="PASSED")?fi?!0:(o.warn("The CLI is not running in a CI environment and therefore ineligible for failure recovery"),y.warn("Test failed but is not eligible for failure recovery since this does not appear to be a CI environment"),!1):(o.debug({recentRuns:i},"Test is not eligible for recovery because there are only failures in the past 7 days"),!1)}async function Kv({attemptInputs:n,attemptFixtures:e,attemptMetadata:t}){let{attemptNumber:r,orgId:o,runId:i,runAttemptId:a}=t,{controller:s,context:l,flagStore:c,analytics:d,codeEvalTools:p,storageClient:m,debugDataStorage:u,logger:h,apiClient:g,billingReporter:f,tracer:S}=e,{test:b,orgSettings:w}=n;h.info(`Running test '${b.name}' locally (run link: https://app.momentic.ai/runs/${i})`);let v={controller:s,storage:m,debugDataStorage:u,billingReporter:f,analytics:d,context:l,logger:h,codeEvalTools:p},x={orgId:o,runId:i||cN(),runAttemptId:a,testMetadata:b,steps:b.steps,beforeSteps:b.beforeSteps,afterSteps:b.afterSteps},C={collectDebugData:!0,reinitializeBrowser:!0,disableHealing:!await qv({currentAttempt:r,testId:b.id,flagStore:c,apiClient:g,testAdvancedSettings:b.advanced,aiSettingsFromEnv:w.ai,logger:h})};return await pl({fixtures:v,inputs:x,options:C,callbacks:{step:{},test:{onTestComplete:async()=>{await s.browser.cleanup()},onProposedTestSteps:async O=>g.uploadProposedSteps(O,h)}},testParams:{tracer:S}})}async function Jv(n){let{testDefinition:e,logger:t}=n,r=new Date;try{return await dN(n)}catch(o){let i="Fatal error running test";return y.error(`${i}: ${o.message}`),t.error({err:o},i),{parameters:n,failureReason:"UnknownError",failureDetails:{errorMessage:o.message,errorStack:o.stack},status:"FAILED",attempts:0,test:e,filePath:e.relativeFilePath,startedAt:r,lastAttemptStartedAt:r,finishedAt:new Date,outputs:{}}}}async function dN(n){let{testDefinition:e,project:t,apiClient:r,orgId:o,urlOverride:i,runSigIntHandlers:a,runGroupTracer:s,logger:l,gitMetadata:c,alwaysSaveCache:d,noCache:p}=n,m=new Qo(r,o),u=ri({client:r,gitMetadata:c,alwaysSaveCache:d,noCache:p}),h=Yv(e.steps);try{await u.resolveStepCacheEntries({organizationId:o,testId:e.id,steps:h,schemaVersion:e.schemaVersion,logger:l})}catch(x){throw l.error({err:x},"Failed to resolve step cache entries"),new Error(`Failed to resolve step cache entries. Please ensure you are running using a supported version of Momentic. If you believe this is a Momentic issue, please contact Support with the following error: ${x}`)}let g=n.envName??uN(e),f,S={};if(g){try{f=oa(g,t,l)}catch(x){let C=`Failed to resolve environment ${g} for test ${e.name}: ${x}`;throw new Error(C)}S=f.variables}let b=e.baseUrl;if(i)b=i;else if(!b){let x=S[Ge];typeof x=="string"&&(b=x)}if(!b){let x=`Cannot run test with no base URL and no ${Ge} variable defined in its environment`;throw new Error(x)}let w=await s.startRun({logger:l,originalSteps:{beforeSteps:e.beforeSteps,steps:e.steps,afterSteps:e.afterSteps},testId:e.id,testName:e.name,testLabels:e.labels,baseUrl:b,environmentName:g,schemaVersion:e.schemaVersion}),v=l.child(w.loggerBindings||{});Object.entries(w.envVarBindings||{}).forEach(([x,C])=>{S[x]=C});try{let x=await pN({...n,variables:S,envName:g,stepsWithCaches:h,resolvedEnv:f,baseUrl:b,storageClient:m,tracer:w,logger:v,cacheStorage:u});return await w.finish({logger:l,status:x.status,finishedAt:x.finishedAt,failureDetails:x.failureDetails,failureReason:x.failureReason,isFlake:x.isFlake}),{runId:w.runId,...x}}finally{a?.pop()}}async function pN(n){let{testDefinition:e,stepsWithCaches:t,project:r,regenerateGoldenFiles:o,apiClient:i,generator:a,baseUrl:s,storageClient:l,orgId:c,envName:d,urlOverride:p,customHeaders:m,testInputs:u,variables:h,resolvedEnv:g,retriesOverride:f,devicePixelRatio:S,logUpdate:b,tracer:w,logger:v,flagStore:x,cacheStorage:C}=n,A=new Date,N=new Yo(r,o),O={ai:r.config.ai},H={envName:d,urlOverride:p,customHeaders:m,testInputs:u},F,L=Math.abs(f??r.config.retries??e.retries??0),B=[];v.info({labels:e.labels,name:e.name},"Starting test run using CLI");for(let P=0;P<=L;P++){let K=await w.startAttempt(),U=v.child(K.loggerBindings||{}),Y={...e,steps:Yv(t)};P!==0&&b("RETRY",`attempt ${P+1}/${L+1}`);let Z=new Date,ft=new dr({httpClient:new kt({baseUrl:i.baseUrl,apiKey:i.apiKey,logger:U}),fakerSeed:x.isBooleanFlagEnabled("faker_constant_seed")?sh:void 0});try{let{controller:re,context:we}=await Vv({baseUrl:s,envName:d,apiClient:i,devicePixelRatio:S,logger:U,storageClient:l,codeEvalTools:ft,test:Y,generator:a,orgId:c,variables:h,customHeaders:m,testInputs:u,localBrowserConfig:{...r.config.browser||{},...g?.browser||{},...Y.advanced},visualDiffScreenshotStorage:N,flagStore:x});F=await Kv({attemptMetadata:{attemptNumber:P+1,orgId:c,runId:w.runId},attemptFixtures:{logger:U,storageClient:l,billingReporter:new Po,analytics:new mi,debugDataStorage:new Or,codeEvalTools:ft,flagStore:x,apiClient:i,context:we,controller:re,tracer:K},attemptInputs:{test:Y,orgSettings:O}});let Me=new Date;F?.status==="PASSED"&&await Cs({logger:v,cacheStorage:C,orgId:c,testId:e.id,originalSteps:{steps:e.steps,beforeSteps:e.beforeSteps,afterSteps:e.afterSteps},updatedSteps:{steps:Y.steps,beforeSteps:Y.beforeSteps,afterSteps:Y.afterSteps}}),await K.finish({logger:U,result:F}),B.unshift(F.status);let _t=await Wv({orgId:c,codeEvalTools:ft,logger:U,outputDefinitions:e.outputs??[],testContext:we,flagStore:x}),on=Um(B),j=P+1;if(F.status!=="FAILED")return{...F,parameters:H,test:Y,filePath:Y.relativeFilePath,startedAt:A,lastAttemptStartedAt:Z,finishedAt:Me,attempts:j,baseUrl:s,outputs:_t,isFlake:on};let Kn=F.failedStepResult,an=Kn?.message||"Unknown failure",wi=Kn?.failureReason??Sh(an)??"UnknownError",vi=U.child({errResult:Kn,failureReason:wi,errorMessage:an,numAttempts:L+1,name:Y.name});if(P<L){vi.warn(`Retrying failed execution attempt for run: ${an}`);continue}return vi.error(`Test failed after all exhausting attempts: ${an}`),{...F,parameters:H,failureDetails:{errorMessage:an},failureReason:wi,test:Y,filePath:Y.relativeFilePath,startedAt:A,lastAttemptStartedAt:Z,finishedAt:Me,attempts:P+1,baseUrl:s,outputs:_t}}catch(re){xi(re);let we=`Encountered fatal platform error while running test '${Y.name}': ${re}`,Me=new Date,_t=P+1;U.error({err:re},we),y.error(we);let on={errorMessage:re.message,errStack:re.stack},j={status:"FAILED",failureDetails:on,failureReason:"InternalPlatformError",finishedAt:Me};return await K.finish({logger:U,result:{status:"FAILED",results:[]}}),{...j,parameters:H,test:Y,filePath:Y.relativeFilePath,startedAt:A,lastAttemptStartedAt:Z,finishedAt:new Date,attempts:_t,baseUrl:s,outputs:{}}}}throw new Error("This code should not be reachable")}function uN(n){for(let e of n.envs??[])if(e.default)return e.name}import{randomUUID as Zv}from"crypto";import mN from"adm-zip";import Vn from"fs";import ro from"path";var ka=class n{constructor(e){this.filePath=e;Vn.rmSync(this.filePath,{recursive:!0,force:!0}),Vn.mkdirSync(this.filePath,{recursive:!0})}cd(e){return new n(ro.join(this.filePath,e))}storeFile(e){let{name:t,contents:r}=e,o=ro.join(this.filePath,t);Vn.writeFileSync(o,r)}createRunArchive(e){return new pu(ro.join(this.filePath,"runs"),e)}},pu=class{constructor(e,t){this.filePath=e;this.tempPath=ro.join(e,`.${t}`),this.finalPath=ro.join(e,`${t}.zip`),Vn.rmSync(this.tempPath,{recursive:!0,force:!0}),Vn.rmSync(this.finalPath,{recursive:!0,force:!0}),Vn.mkdirSync(this.tempPath,{recursive:!0})}tempPath;finalPath;cd(e){return new ka(ro.join(this.tempPath,e))}storeFile(e){let{name:t,contents:r}=e,o=ro.join(this.tempPath,t);Vn.writeFileSync(o,r)}close(){let e=new mN;e.addLocalFolder(this.tempPath,void 0,r=>r!==".DS_Store");let t=e.toBuffer();Vn.writeFileSync(this.finalPath,t),Vn.rmSync(this.tempPath,{recursive:!0,force:!0})}};async function Xv(n,e,t,r,o){let i=qi(o.type);if(i&&await e.reportCreditsUsed(n,o.type,i,{testId:t,testName:r}),"command"in o){let a=Ki(o.command);a&&await e.reportCreditsUsed(n,o.command.type,a,{testId:t,testName:r})}}function hN(n){switch(n){case"PASSED":return"SUCCESS";case"FAILED":return"FAILED";case"CANCELLED":return"CANCELLED";case"RUNNING":case"PENDING":case"RETRYING":case"WAITING_FOR_USER":return"RUNNING"}}function gN(n){switch(n){case"SUCCESS":return"PASSED";case"FAILED":return"FAILED";case"CANCELLED":return"CANCELLED";case"RUNNING":return"RUNNING";case"IDLE":return"PENDING"}}var uu=class{constructor(e,t,r,o,i,a){this.testId=e;this.testName=t;this.metadata=r;this.diskStorage=o;this.billingReporter=i;this.asyncWork=a}children=[];finished=!1;getParentStepIdChain(){return[]}attachBeforeScreenshot(e){let{snapshotId:t,screenshot:r}=e;this.metadata.beforeSnapshotId=t,this.diskStorage.storeFile({name:"before.jpeg",contents:r})}attachAfterScreenshot(e){let{snapshotId:t,screenshot:r}=e;this.metadata.afterSnapshotId=t,this.diskStorage.storeFile({name:"after.jpeg",contents:r})}attachBeforeHtmlSnapshot(e){let{snapshotId:t,html:r}=e;this.metadata.beforeSnapshotId=t,this.diskStorage.storeFile({name:"before.html",contents:r})}attachAfterHtmlSnapshot(e){let{snapshotId:t,html:r}=e;this.metadata.afterSnapshotId=t,this.diskStorage.storeFile({name:"after.html",contents:r})}heal(e){let{healType:t}=e;this.metadata.healMetadata={healType:t,healedAt:new Date}}async finishInternal(e){if(this.finished)return;this.finished=!0,await Promise.all(this.children.map(r=>r.finish({status:gN(e.status),finishedAt:e.finishedAt})));let t={...this.metadata,status:e.status,finishedAt:e.finishedAt,message:e.message};this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(t,null,2)})}async finish(e){await this.finishInternal(e.step)}async startSubSteps(){let e=this.diskStorage.cd("substeps"),t=new Vl(this.testId,this.testName,e,this.billingReporter,this.asyncWork);return this.children.push(t),t}},Vl=class{constructor(e,t,r,o,i){this.testId=e;this.testName=t;this.diskStorage=r;this.billingReporter=o;this.asyncWork=i}children=[];finished=!1;getParentStepIdChain(){return[]}async startStep(e){let{logger:t,step:r}=e;this.asyncWork.push(Xv(t,this.billingReporter,this.testId,this.testName,r));let o=this.diskStorage.cd(r.id),i={step:r,status:"RUNNING",startedAt:new Date};o.storeFile({name:"metadata.json",contents:JSON.stringify(i,null,2)});let a=new uu(this.testId,this.testName,i,o,this.billingReporter,this.asyncWork);return this.children.push(a),a}async finish(e){this.finished||(this.finished=!0,await Promise.all(this.children.map(t=>t.finishInternal({status:hN(e.status),finishedAt:e.finishedAt}))))}},mu=class{constructor(e,t,r,o,i,a,s,l,c){this.orgId=e;this.testId=t;this.testName=r;this.originalSteps=o;this.metadata=i;this.client=a;this.diskStorage=s;this.billingReporter=l;this.asyncWork=c}finished=!1;children=[];trackStatus(){}attachNetworkLogs(e){let{logs:t}=e;this.diskStorage.storeFile({name:"network.har",contents:JSON.stringify(t,null,2)})}attachConsoleLogs(e){let{logs:t}=e;this.diskStorage.storeFile({name:"console.json",contents:JSON.stringify(t,null,2)})}async finish(e){if(this.finished)return;this.finished=!0;let{logger:t,result:r}=e,o={...this.metadata,status:r.status,finishedAt:new Date,results:As(r.results,t),beforeResults:r.beforeResults?As(r.beforeResults,t):void 0,afterResults:r.afterResults?As(r.afterResults,t):void 0};await Promise.all(this.children.map(i=>i.finish({status:o.status,finishedAt:o.finishedAt}))),this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(o,null,2)})}async startStepList(){let e=this.diskStorage.cd("steps"),t=new Vl(this.testId,this.testName,e,this.billingReporter,this.asyncWork);return this.children.push(t),t}},hu=class{constructor(e,t,r,o,i,a,s,l,c,d){this.orgId=e;this.testId=t;this.testName=r;this.runId=o;this.originalSteps=i;this.metadata=a;this.client=s;this.diskStorage=l;this.billingReporter=c;this.asyncWork=d}children=[];finished=!1;get loggerBindings(){return{runId:this.runId}}get envVarBindings(){return{[Sy]:this.runId}}async finish(e){if(this.finished)return;this.finished=!0;let t={...this.metadata,finishedAt:e.finishedAt||new Date,status:e.status,failureDetails:e.failureDetails,failureReason:e.failureReason,flake:e.isFlake||!1};await Promise.all(this.children.map(r=>r.finish({logger:e.logger,result:{status:t.status,results:[],beforeResults:[],afterResults:[]}}))),this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(t,null,2)}),this.diskStorage.close()}trackStatus(){}async startAttempt(){this.metadata.attempts=this.metadata.attempts+1,this.metadata.status="RUNNING",this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(this.metadata,null,2)});let e=this.diskStorage.cd(`attempts/${this.metadata.attempts}`),t={schemaVersion:Fe,startedAt:new Date,status:"RUNNING"};e.storeFile({name:"metadata.json",contents:JSON.stringify(t,null,2)});let r=new mu(this.orgId,this.testId,this.testName,this.originalSteps,t,this.client,e,this.billingReporter,this.asyncWork);return this.children.push(r),r}},ql=class n{constructor(e,t,r,o,i,a){this.orgId=e;this.runGroupId=t;this.metadata=r;this.client=o;this.diskStorage=i;this.billingReporter=a;this.asyncWork=[]}children=[];finished=!1;asyncWork;get loggerBindings(){return{orgId:this.orgId,runGroupId:this.runGroupId,branch:this.metadata.gitBranchName}}static async start(e,t,r,o,i,a){let s=Zv(),l={...a,trigger:Wt.CLI,startedAt:new Date,status:"RUNNING",cliVersion:fn},c=new ka(r);return c.storeFile({name:"metadata.json",contents:JSON.stringify(l,null,2)}),new n(t,s,l,o,c,i)}async finish(e){if(this.finished)return;this.finished=!0;let{status:t}=e,r={...this.metadata,status:t,updatedAt:new Date,finishedAt:new Date};await Promise.all(this.children.map(o=>o.finish({logger:e.logger,status:r.status,finishedAt:r.finishedAt}))),this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(r,null,2)}),await Promise.allSettled(this.asyncWork)}trackStatus(){}async startRun(e){let t=Zv(),r=this.diskStorage.createRunArchive(t),o={stepsSnapshot:e.originalSteps.steps,runGroupId:this.runGroupId,testId:e.testId,testName:e.testName,labels:e.testLabels,trigger:"CLI",status:"RUNNING",resolvedBaseUrl:e.baseUrl,environmentName:e.environmentName,cliVersion:fn,schemaVersion:e.schemaVersion,startedAt:new Date,attempts:0};r.storeFile({name:"metadata.json",contents:JSON.stringify(o,null,2)}),this.asyncWork.push(this.billingReporter.reportBillableEvent(e.logger,"test-run",{eventId:t,testId:e.testId,testName:e.testName}));let i=new hu(this.orgId,e.testId,e.testName,t,e.originalSteps,o,this.client,r,this.billingReporter,this.asyncWork);return this.children.push(i),i}};import Qv from"adm-zip";import eT from"fs";import Kl from"path";function fN(n){let e=new Qv;e.addLocalFile(Kl.join(n,"metadata.json"));for(let t of eT.readdirSync(Kl.join(n,"runs"))){if(!t.endsWith(".zip"))continue;let r=t.replace(/\.zip$/,""),o=new Qv(Kl.join(n,"runs",t));for(let i of o.getEntries())i.isDirectory||e.addFile(Kl.join("runs",r,i.entryName),i.getData())}return e.toBuffer()}async function Yl(n){let{client:e,consoleLogger:t,resultsPath:r}=n;if(!eT.existsSync(r)){t.warn("Results path does not exist, skipping upload.");return}let o=new ol(e);try{let i=fN(r),a=await o.uploadResultsArchive(i),s=`${e.getAppUrl()}/run-groups/${a}`;t.success(`Successfully uploaded test results. Once processed, your results can be found at ${s}`);return}catch(i){let a;i instanceof Error?a=i.message:typeof i=="string"?a=i:a="Unknown error",t.error(`Failed to upload test results: ${a}.`);return}}async function tT(n){let{logger:e,tests:t,yes:r,start:o,waitOn:i,client:a,debugDataStorage:s,billingReporter:l,flagStore:c,project:d,retriesOverride:p,urlOverride:m,envName:u,orgId:h,devicePixelRatio:g,customHeaders:f,testInputMatrix:S,reporter:b,include:w,exclude:v,labels:x,reporterDir:C=FS,outputDir:A=US,uploadResults:N=!1,waitOnTimeout:O=60,parallel:H=d.config.parallel??1,shardIndex:F=1,shardCount:L=1,regenerateGoldenFiles:B,gitMetadata:P,alwaysSaveCache:K,noCache:U}=n;o&&(e.info({orgId:h},`Executing start command: ${o}`),await Gw(o,!1)),i&&(e.info({orgId:h},`Waiting for url: ${i} with timeout: ${O} seconds.`),await bN({resources:[i],interval:2500,timeout:O*1e3,headers:{Accept:"*/*"},followRedirect:!0,verbose:!1,log:!0,strictSSL:!1}));let Y=new ti(d.config.ai?.agentConfig,{baseUrl:a.baseUrl,apiKey:a.apiKey,logger:e}),Z=Oe(d,y),ft=await Gv({tests:t,momenticFiles:Z,yes:r,project:d,include:w,exclude:v,labels:x}),re=[];ft.forEach((ot,br)=>{S?S.forEach((ao,St)=>{re.push({testIndex:br,inputs:ao,inputIndex:St})}):re.push({testIndex:br,inputs:void 0,inputIndex:void 0})}),L&&L>1&&(re=wN(re,F,L));let we=`Running ${re.length} tests with ${H} workers:`;e.info({allTestsToRunWithInputs:re,shardCount:L,shardIndex:F,orgId:h},we),y.info(we),re.forEach(ot=>{y.info(`${zt}- ${[ft[ot.testIndex].relativeFilePath]}${typeof ot.inputIndex=="number"?` with input set ${ot.inputIndex}`:""}`)}),y.log("");let Me=[],_t=new Date,on=new Set,j=async()=>{let ot=a.getAppUrl(),br=Si({results:Me,startTime:_t.getTime(),onFailed:St=>{jl(St,St.filePath)},getDisplayLine:St=>{let wr=`${zt}- ${St.filePath}${St.proposedTest?" [AUTO-HEALED] ":""}`;return St.runId&&(wr+=` (link when uploaded: ${ot}/runs/${St.runId})`),wr},entity:"test"}),ao=Me.filter(St=>!!St.proposedTest);return ao.length>0&&y.warn(`${ao.length} tests passed with auto-healing. Please use the run links printed above to review proposed changes and apply them locally.`),y.log(""),N?(y.success(`Test results have been saved to the folder ${A}. Uploading to Momentic cloud.`),await Yl({client:a,consoleLogger:y,resultsPath:A})):y.success(`Test results have been saved to the folder ${A}. Upload them to Momentic cloud by running 'npx momentic results upload ${A}'.`),br};yN.existsSync(A)&&y.warn(`Output directory ${A} already exists, removing before test execution...`);let Kn=await ql.start(e,h,A,a,l,P),an=e.child(Kn.loggerBindings||{}),wi=[],vi=async()=>{y.warn("SIGINT received. Stopping tests and printing latest results..."),await Kn.finish({logger:an,status:"CANCELLED"}),await j(),await Promise.allSettled(wi.map(ot=>ot())),process.exit(1)};process.once("SIGINT",vi);let io={};for(let ot=0;ot<re.length;ot++){let br=Object.values(io);br.length===H&&await Promise.race(br.map(wr=>wr.promise));let ao=re[ot],St=`test-${ot}`;io[St]={done:!1,promise:(async({testIndex:wr,inputs:yu})=>{let so=ft[wr];on.add({testIndex:wr,inputs:yu});let dT=so.relativeFilePath.includes("..")?so.fullFilePath:so.relativeFilePath,Ma=(ct,Ti)=>{ct=ct.toUpperCase();let Mn=ct,Yn;ct.includes("FAIL")?(Mn=bi.bgRed.white("FAIL"),Yn=3):ct.includes("PASS")?(Mn=bi.bgGreen.white("PASS"),Yn=3):ct.includes("START")?(Mn=bi.bgBlue.white("START"),Yn=2):ct.includes("CANCEL")?(Mn=bi.bgRgb(191,68,11).white("CANCEL"),Yn=1):ct.includes("RETRY")?(Mn=bi.bgRgb(191,68,11).white("RETRY"),Yn=2):ct.includes("RUN")||ct.includes("PROG")?(Mn=bi.bgMagenta.white("RUNNING"),Yn=0):(an.warn(`Unknown status tried to be logged in run test locally: ${ct}`),Yn=0),SN||(Mn=`${Mn}`),y.log(`${Mn}${" ".repeat(Yn)} ${dT} ${Ti?`${Ti} `:""}(${on.size}/${re.length})`)};Ma("START");let pT=setInterval(()=>Ma("RUN"),5*60*1e3),bu=an.child({testId:so.id});try{let ct=await Jv({testDefinition:so,project:d,testInputs:yu,orgId:h,devicePixelRatio:g,apiClient:a,runGroupTracer:Kn,generator:Y,retriesOverride:p,urlOverride:m,envName:u,customHeaders:f,regenerateGoldenFiles:B,logUpdate:Ma,runSigIntHandlers:wi,logger:bu,flagStore:c,gitMetadata:P,alwaysSaveCache:K,noCache:U});Ma(ct.status),Me.push(ct)}catch(ct){let Ti=`Encountered unexpected fatal error when running test '${so.name}': ${ct.message}`;y.error(Ti),bu.error(Ti)}finally{clearInterval(pT),io[St].done=!0,delete io[St]}})(ao)}}await Promise.allSettled(Object.values(io).map(ot=>ot.promise));let Su="PASSED";return Me.some(ot=>ot.status==="FAILED")&&(Su="FAILED"),await Kn.finish({logger:an,status:Su}),process.off("SIGINT",vi),b&&await $v(an,s,b,{projectConfigPath:d.configFilePath,suiteName:d.config.name,startedAt:_t,finishedAt:new Date,runs:Me},C),j()}function wN(n,e,t){if(t>n.length&&(y.warn(`Shard count ${t} is greater than the number of tests ${n.length}! Some workers won't have any tests to run.`),t=Math.max(t,n.length),e>t))return[];let r=Math.floor((e-1)*(n.length/t)),o=Math.floor(e*(n.length/t));return n.sort().filter((a,s)=>s>=r&&s<o)}import qn from"fs";import oo from"path";var nT={status:(n,e)=>{if(n.status===e.status)return n.status;if(n.status==="FAILED"||e.status==="FAILED")return"FAILED";if(n.status==="CANCELLED"||e.status==="CANCELLED")return"CANCELLED";if(n.status==="RETRYING"||e.status==="RETRYING")return"RETRYING";if(n.status==="RUNNING"||e.status==="RUNNING")return"RUNNING";if(n.status==="PENDING"||e.status==="PENDING")return"PENDING";throw new Error(`Invalid run status merge: ${n.status} and ${e.status}`)},startedAt:(n,e)=>n.startedAt<e.startedAt?n.startedAt:e.startedAt,updatedAt:(n,e)=>n.updatedAt>e.updatedAt?n.updatedAt:e.updatedAt,finishedAt:(n,e)=>!n.finishedAt||!e.finishedAt?new Date:n.finishedAt>e.finishedAt?n.finishedAt:e.finishedAt,gitCommitTimestamp:(n,e)=>{if(!(!n&&!e)){if(!n.gitCommitTimestamp||!e.gitCommitTimestamp||n.gitCommitTimestamp.getTime()!==e.gitCommitTimestamp.getTime())throw new Error(`Git commit timestamps must match to be merged: ${n.gitCommitTimestamp} and ${e.gitCommitTimestamp}`);return n.gitCommitTimestamp}},pipelineId:(n,e)=>n.pipelineId===e.pipelineId?n.pipelineId:!n.pipelineId&&e.pipelineId?e.pipelineId:!e.pipelineId&&n.pipelineId?n.pipelineId:n.startedAt<e.startedAt?e.pipelineId:n.pipelineId};function rT(n,e){let t=n[e];if(!t)throw new Error(`No metadata value found for key: ${e}`);return t}function vN(n,e,t){if(nT[t]){let i=nT[t];return i(n,e)}let r=rT(n,t),o=rT(e,t);if(r!==o)throw new Error(`Metadata values for key "${t}" do not match: "${r}" vs "${o}"`);return r}var oT=new Set([".DS_Store","__MACOSX"]);function iT(n,e){qn.rmSync(n,{recursive:!0,force:!0});let t=qn.readdirSync(e).filter(a=>!oT.has(a)).map(a=>oo.join(e,a));qn.mkdirSync(n,{recursive:!0});let r=oo.join(t[0],"metadata.json"),o=td.parse(JSON.parse(qn.readFileSync(r,"utf-8")));for(let a of t){let s=oo.join(a,"runs");if(!qn.existsSync(s))continue;let l=qn.readdirSync(s);for(let p of l){if(oT.has(p))continue;let m=oo.join(s,p),u=oo.join(n,"runs",p);qn.cpSync(m,u,{recursive:!0})}let c=oo.join(a,"metadata.json"),d=td.parse(JSON.parse(qn.readFileSync(c,"utf-8")));for(let p in d){let m=p;o[m]=vN(o,d,m)}}let i=oo.join(n,"metadata.json");qn.writeFileSync(i,JSON.stringify(o,null,2))}var aT=new hi({platform:"cli"},{flushAt:1,flushInterval:0});Zl||ne.warn("Sentry is not enabled in this environment due to unsupported node version");var AN=process.argv.some(n=>n.includes("--log-level"))&&process.argv.some(n=>n.includes("debug")),gu=n=>{AN&&y.dimmed(n)},Nt=new TN;Nt.name("momentic").description("CLI").version(fn);Nt.command("install-browsers").description("Install browser executables onto the local machine.").option("-f, --force","Force reinstallation even if the browser executables already exist on disk.").option("-a, --all","Install all browsers types.").argument("[browsers...]",`Browsers to install. Available choices: ${iu.join(", ")}.`).action(async(n,e)=>{!e.all&&n.length===0&&(y.error("No browsers specified"),process.exit(1)),await Lv({rawBrowsers:n,force:e.force,all:e.all})});Nt.addOption(new rn("--log-level <level>").choices(["debug","info","warn","error"]).default("info")).on("option:log-level",n=>{n==="debug"&&y.info("Enabling debug logging"),y.setMinLevel(n.toLowerCase())});Nt.addOption(new rn("--verbose","enable verbose logging")).on("option:verbose",()=>{ne.enableConsoleLogs(),y.setMinLevel(0)});var fu=Nt.command("checks").alias("check").description("Perform various project checks");fu.command("config").addOption(kn).action(async n=>{Qt({configFilePath:n.config})});fu.command("duplicate-ids").description("Checks if any steps in your entire Momentic test repository share the same ID.").addOption(kn).addOption(lv).action(async n=>{let e=await Sn(n),t=Qt({configFilePath:n.config});await yv({project:t,fix:e.fix})});fu.command("duplicate-names").description("Checks if tests or modules with duplicate names or ids exist").addOption(kn).action(async n=>{let e=Qt({configFilePath:n.config});await bv({project:e})});var sT=Nt.command("migrate").description("Migrate and upgrade tooling");sT.command("steps").description("Migrate steps in all tests and modules to the latest schema version. Note that this is always done when a test is loaded through the interactive editor, so is generally not needed.").addOption(kn).action(async n=>{let e=Qt({configFilePath:n.config});await Ov(e)});sT.command("v1-v2").description("Migrate from v1 of the Momentic CLI to v2").addOption(Wn).addOption(kn).addOption(Gn).action(async n=>{let e=await Sn(n);!e.yes&&!await gt("This command will modify your existing Momentic configuration. Please backup your local directory using Git or another version control system before proceeding. Continue?",!0)&&process.exit(1);let t=Qt({configFilePath:n.config}),r=new lt({baseUrl:e.server,apiKey:e.apiKey,logger:ne}),{orgId:o}=await r.getAuthInfo();await Mv({project:t,orgId:o,apiClient:r}),process.exit(0)});Nt.command("import").addOption(Gn).addOption(Wn).addOption(kn).addOption(no).addArgument(dv).action(async(n,e)=>{let t=await Sn(e),{apiKey:r,server:o,config:i,yes:a}=t,s=Qt({configFilePath:i}),l=new lt({baseUrl:o,apiKey:r,logger:ne});!n||n.length===0?await Ev({client:l,project:s,skipPrompts:a}):await Cv({client:l,project:s,paths:n,skipPrompts:a}),process.exit(0)});Nt.command("init").description("Initialize an empty Momentic project in the current working directory").addOption(new rn("--name <name>","Name of the project")).action(async n=>{y.info(`Welcome to the Momentic project setup wizard! \u{1F680}
3642
+ `),y.info("This wizard will help you bootstrap a new Momentic project. If you need to import existing assets from Momentic Cloud, you can call the 'import' command after initialization."),Xl.existsSync(Vo)&&(y.error("A momentic.config.yaml file already exists in this directory. Please rename or remove it to initialize a new project."),process.exit(1));let t={name:n.name??await Jw("Choose an identifier for your project, such as a service, product, or team name (default: 'app'):","app"),include:kd};qo(t,Vo),y.success(`Initialized Momentic project file at ${Jl.resolve(Vo)}`)});Nt.command("app").addOption(Gn).addOption(Wn).addOption(no).addOption(Yp).addOption(iv).addOption(kn).addOption(Zp).addOption(Qp).action(async n=>{let e=await Sn(n),{apiKey:t,port:r=_l,yes:o,server:i,pixelRatio:a,disableCache:s,saveCache:l}=e,c=new lt({baseUrl:i,apiKey:t,logger:ne});await eu({client:c,skipPrompts:o});let d=RN(import.meta.url),p=Jl.dirname(d),m=Jl.resolve(p,"..","static"),u=Jl.resolve(p,"..","assets"),h=a??zp();Hp(h),await Hw({momenticServerUrl:i,apiKey:t,serverPort:r,appPort:r,staticDir:m,assetsDir:u,devicePixelRatio:h,version:fn,noCache:s,alwaysSaveCache:l});let g=`http://localhost:${r}`;await CN(g)});var lT=Nt.command("queue").description("Queue tests or suites to run on Momentic Cloud");lT.command("suites").description("Run one or more suites on Momentic Cloud").addOption(Gn).addOption(Wn).addOption(Vp).addOption(qp).addOption(no).addArgument(uv).addOption(Ul).addOption(Fl).addOption(Dl).action(async(n,e)=>{let{apiKey:t,server:r,wait:o,waitTimeout:i,env:a,urlOverride:s,customHeaders:l}=await Sn(e),c=new lt({baseUrl:r,apiKey:t,logger:ne});(!n||!Array.isArray(n)||!n.length)&&(y.error("Must pass at least one suite to run."),process.exit(1));let{orgId:d}=await c.getAuthInfo();await _v({client:c,orgId:d,wait:o,suitePaths:n,waitTimeout:i,env:a,urlOverride:s,customHeaders:Bl(l)})});lT.command("tests").description("Run one or more tests on Momentic Cloud").addOption(Gn).addOption(Wn).addOption(no).addOption(Dl).addOption(Jp).addOption(Ul).addOption(Fl).addOption(Vp).addOption(qp).addArgument(cv).action(async(n,e)=>{let t=await Sn(e),{all:r,apiKey:o,customHeaders:i,env:a,server:s,inputCsv:l,urlOverride:c,wait:d,waitTimeout:p,yes:m}=t,u=Bl(i);for(let S of n)(S.endsWith(".yaml")||Xl.existsSync(S))&&y.warn("Are you trying to run a test on your local machine? If so, please use the 'run' command instead of the 'queue' command");let h=new lt({baseUrl:s,apiKey:o,logger:ne}),{orgId:g}=await h.getAuthInfo(),f;l&&(f=await jp(l)),await Dv({client:h,orgId:g,tests:n,all:r,customHeaders:u,env:a,urlOverride:c,wait:d,waitTimeout:p,testInputMatrix:f,yes:m}),process.exit(0)});var IN=Nt.command("run").alias("test").description("Run tests on the local machine");IN.addOption(Gn).addOption(Wn).addOption(kn).addOption(Xp).addOption(no).addOption(Dl).addOption(Jp).addOption(Zp).addOption(Qp).addOption(Fl).addOption(Ul).addOption(Yp).addOption(new rn("--start <start>","Arbitrary setup command that will run before Momentic steps begin.")).addOption(new rn("--wait-on <waitOn>","URL to wait to become accessible before Momentic tests begin.")).addOption(new rn("--wait-on-timeout <waitOnTimeout>","Max time in seconds to wait for the --wait-on URL to become accessible.")).addOption(new rn("--retries <retries>","Number of retries to attempt when running tests locally. Defaults to each test's own retry configuration.")).addOption(new rn("-p, --parallel <parallel>","When running with the --local flag, the number of tests to run in parallel. Defaults to 1.")).addOption(new rn("--labels <labels...>","Only run tests with the specified label(s).")).addOption(new rn("--update-golden-files","Update locally stored golden files for steps that this is enabled for.")).addOption(ev).addOption(tv).addOption(Kp).addOption(nv).addOption(av).addOption(sv).addOption(rv).addOption(ov).addArgument(pv).action(async(n,e)=>{y.debug("Run tests invoked");let t=await Sn(e);y.debug(t,"Parsed CLI options");let r=Bl(t.customHeaders),o=Qt({configFilePath:t.config,nameFilter:t.filter});y.debug({projectName:o.config.name},"Identified project config");let{errors:i}=await ru({project:o,fix:!1});i>0&&(y.error(`Found errors in ${i} steps`),y.warn("To fix these errors automatically, run the duplicate-ids check with the --fix flag and then commit the resulting changes"),process.exit(1));let a=new lt({baseUrl:t.server,apiKey:t.apiKey,logger:ne});y.debug("Checking API key and dependencies");let{orgId:s,userId:l}=await eu({client:a,skipPrompts:t.yes});y.debug("API key check and browser installation complete");let c=new nl(a),d=new rl(a),p=t.outputDir??o.config.outputDir,m=t.reporterDir??o.config.reporterDir,u=ne.child({orgId:s,userId:l,cliVersion:fn,trigger:"CLI"}),h=await Xo(ne,a,o);u.debug(h,"Got local git metadata");let g=new Jo(o.config),f=aT.child({org_id:s,user_id:l,cli_version:fn,trigger:"CLI"}),S;t.inputCsv&&(S=await jp(t.inputCsv));let b=t.pixelRatio??zp();Hp(b);try{(await tT({...t,retriesOverride:t.retries,devicePixelRatio:b,tests:n,project:o,client:a,debugDataStorage:d,billingReporter:c,analytics:f,flagStore:g,outputDir:p,uploadResults:t.uploadResults,reporterDir:m,customHeaders:r,envName:t.env,orgId:s,testInputMatrix:S,logger:u,regenerateGoldenFiles:t.updateGoldenFiles,gitMetadata:h,alwaysSaveCache:t.saveCache,noCache:t.disableCache})).failed>0?process.exit(1):process.exit(0)}catch(w){y.error("Failed to run tests locally. Please check the error message below or run with the --verbose flag."),y.error(w),process.exit(1)}});var PN=Nt.command("apply").description("Apply an operation to local resources");PN.command("patch").addOption(Gn).addOption(Wn).addOption(kn).addOption(Xp).addOption(no).addOption(new rn("--from <from>","Name or ID of the patch to apply").makeOptionMandatory()).addOption(new rn("--to <to>","Name or ID of the test to apply the patch to").makeOptionMandatory()).action(async n=>{let e=await Sn(n),{apiKey:t,server:r,config:o,yes:i}=e,a=Qt({configFilePath:o}),s=ne,l=new lt({baseUrl:r,apiKey:t,logger:s}),c=Oe(a,y),d=c.tests[n.to]??Object.values(c.tests).find(m=>Ne(m.name)===n.to.trim());d||(y.error(`No test matching '${n.to}' could be found in the current project.`),process.exit(1));let p=await l.fetchTestFragment(n.from);await Xw({client:l,test:d,fragment:p,yes:i,entities:c,logger:ne}),process.exit(0)});var cT=Nt.command("results").description("Merge and upload test results.");cT.command("merge").description("Merge test results files.").addOption(Kp).addArgument(mv).action(async(n,e)=>{let t=await Sn(e),{outputDir:r}=t;r||(y.error("Output directory is required."),process.exit(1)),Xl.existsSync(n)||(y.warn("Results path does not exist, skipping merge."),process.exit(0)),Xl.existsSync(r)&&y.warn(`Output directory ${r} already exists, removing before merging...`),iT(r,n)});cT.command("upload").description("Upload test results to Momentic cloud.").addOption(Gn).addOption(Wn).addArgument(hv).action(async(n,e)=>{let t=await Sn(e),{apiKey:r,server:o}=t,i=ne,a=new lt({baseUrl:o,apiKey:r,logger:i});await Yl({consoleLogger:y,resultsPath:n,client:a}),process.exit(0)});async function LN(){gu("Main program started"),await Vw(ne),gu("CLI version check complete");try{await Nt.parseAsync(process.argv)}catch(n){let e={};try{e.playwrightVersion=xN("npx playwright --version").toString()}catch(t){ne.error({err:t},"Error fetching debug information")}ne.error({err:n,debugInfo:e},"Uncaught error in CLI"),ne.flush(),xi(n,e),y.error(n),process.exit(1)}}EN.setMaxListeners(50);process.on("warning",n=>{ne.warn({err:n},`Node warning received on CLI: ${n.message}`)});gu("CLI parsing setup complete");LN();
3643
3643
  //# sourceMappingURL=cli.js.map
3644
- //# debugId=a81c6a16-1a30-5cf3-be42-b81beeac317a
3644
+ //# debugId=cecd290f-b551-50e0-af2b-e744c94386d1