momentic 2.7.1 → 2.7.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,60 +1,60 @@
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]="0ba158ab-7de7-5b11-865d-75f20a411592")}catch(e){}}();
4
- var JT=Object.create;var Zu=Object.defineProperty;var XT=Object.getOwnPropertyDescriptor;var QT=Object.getOwnPropertyNames;var ZT=Object.getPrototypeOf,eE=Object.prototype.hasOwnProperty;var em=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports);var tE=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of QT(e))!eE.call(n,o)&&o!==t&&Zu(n,o,{get:()=>e[o],enumerable:!(r=XT(e,o))||r.enumerable});return n};var nE=(n,e,t)=>(t=n!=null?JT(ZT(n)):{},tE(e||!n||!n.__esModule?Zu(t,"default",{value:n,enumerable:!0}):t,n));var hS=em((z3,mS)=>{"use strict";mS.exports=pS;function pS(n,e,t){n instanceof RegExp&&(n=dS(n,t)),e instanceof RegExp&&(e=dS(e,t));var r=uS(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 dS(n,e){var t=e.match(n);return t?t[0]:null}pS.range=uS;function uS(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 TS=em((H3,vS)=>{"use strict";var gS=hS();vS.exports=ZA;var fS="\0SLASH"+Math.random()+"\0",SS="\0OPEN"+Math.random()+"\0",Hd="\0CLOSE"+Math.random()+"\0",yS="\0COMMA"+Math.random()+"\0",bS="\0PERIOD"+Math.random()+"\0";function zd(n){return parseInt(n,10)==n?parseInt(n,10):n.charCodeAt(0)}function XA(n){return n.split("\\\\").join(fS).split("\\{").join(SS).split("\\}").join(Hd).split("\\,").join(yS).split("\\.").join(bS)}function QA(n){return n.split(fS).join("\\").split(SS).join("{").split(Hd).join("}").split(yS).join(",").split(bS).join(".")}function wS(n){if(!n)return[""];var e=[],t=gS("{","}",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=wS(i);return i.length&&(a[a.length-1]+=s.shift(),a.push.apply(a,s)),e.push.apply(e,a),e}function ZA(n){return n?(n.substr(0,2)==="{}"&&(n="\\{\\}"+n.substr(2)),fa(XA(n),!0).map(QA)):[]}function eI(n){return"{"+n+"}"}function tI(n){return/^-?0\d/.test(n)}function nI(n,e){return n<=e}function rI(n,e){return n>=e}function fa(n,e){var t=[],r=gS("{","}",n);if(!r)return[n];var o=r.pre,i=r.post.length?fa(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+Hd+r.post,fa(n)):[n];var u;if(d)u=r.body.split(/\.\./);else if(u=wS(r.body),u.length===1&&(u=fa(u[0],!1).map(eI),u.length===1))return i.map(function(W){return r.pre+u[0]+W});var m;if(d){var h=zd(u[0]),g=zd(u[1]),f=Math.max(u[0].length,u[1].length),S=u.length==3?Math.abs(zd(u[2])):1,w=nI,T=g<h;T&&(S*=-1,w=rI);var y=u.some(tI);m=[];for(var E=h;w(E,g);E+=S){var x;if(c)x=String.fromCharCode(E),x==="\\"&&(x="");else if(x=String(E),y){var A=f-x.length;if(A>0){var k=new Array(A+1).join("0");E<0?x="-"+k+x.slice(1):x=k+x}}m.push(x)}}else{m=[];for(var L=0;L<u.length;L++)m.push.apply(m,fa(u[L],!1))}for(var L=0;L<m.length;L++)for(var a=0;a<i.length;a++){var s=o+m[L]+i[a];(!e||d||s)&&t.push(s)}}return t}});var Mi=(n,e)=>{},Tc=!1;try{let n=await import("@sentry/node");Mi=n.captureException,n.init({dsn:"https://89e980855f7b9c6e56fc6c7e7143888b@o4506426201800704.ingest.us.sentry.io/4508343221354497",environment:"production",release:process.env.SENTRY_RELEASE_NAME,tracesSampleRate:0}),Tc=!0}catch{}import{Command as A_,Option as Bt}from"@commander-js/extra-typings";import{execSync as I_}from"child_process";import Iv from"body-parser";import ck from"cors";import dk from"dedent";import pk from"events";import Pv,{Router as uk}from"express";import{diff as KA}from"deep-object-diff";import un from"fs";import Zr from"path";import{diff as wA}from"deep-object-diff";import{z as tm}from"zod";var z_=tm.object({input:tm.string()});import{z as Ye}from"zod";var $_=Ye.object({srcs:Ye.array(Ye.string()),urls:Ye.array(Ye.string()),desiredSrc:Ye.string().optional(),desiredUrl:Ye.string().optional()}),nm=Ye.object({srcRegex:Ye.string().optional(),urlRegex:Ye.string().optional()}),rm=Ye.object({x:Ye.number(),y:Ye.number(),correlation:Ye.number()}),G_=Ye.object({searchImageBase64String:Ye.string(),pageImageBase64String:Ye.string(),id:Ye.string().uuid(),timeoutMs:Ye.number().max(1e4).min(0).optional()});import{z as _}from"zod";import*as F from"zod";function Ce(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}}Ce(F);var rr=(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))(rr||{}),rE=F.object({mPathSelectorTokens:F.string().array(),frameSrcRegex:F.string().optional(),frameUrlRegex:F.string().optional(),indices:F.number().array()}),Ec=F.object({result:F.number(),traceId:F.string()}).array(),Ni=F.object({type:F.literal("GCS_TRACES"),traces:Ec}),Ir=F.object({id:F.number().int(),dataMomenticId:F.number().int().optional(),selector:F.string().optional(),hybridSelector:F.object({textContent:F.string().nullish(),attributes:F.record(F.string(),F.string()),tagName:F.string(),expandShadowRoot:F.boolean().optional(),classNames:F.string().array(),nthChild:F.number()}).array().optional(),generatedSelectors:F.string().array().optional(),role:F.string().optional(),name:F.string().optional(),numChildren:F.number().optional(),content:F.string().optional(),pathFromRoot:F.string().optional(),serializedForm:F.string().optional(),nodeOnlySerializedForm:F.string().optional(),serializedHtml:F.string().optional().describe("pruned html including 1 neighbor and 1 layer of children. value for text inputs pruned."),nodeOnlySerializedHtml:F.string().optional().describe("outerHtml of the element without any children. value for text inputs pruned."),screenshotUrl:F.string().url().optional(),boundingBox:F.object({x:F.number().optional(),y:F.number().optional(),width:F.number(),height:F.number()}).describe("css pixel bounding box").optional(),frameCache:rE.optional(),inputDescription:F.string().optional().describe("the description that generated this cache"),targetSource:F.nativeEnum(rr).optional(),targetUpdateTime:F.string().optional(),targetUpdateLoggerTags:F.record(F.string(),F.string()).optional(),memory:Ni.optional()}).openapi({ref:"ElementTargetCache"});function om(n){return!!(n.name||n.role||n.content||n.serializedForm||n.serializedHtml||n.screenshotUrl)}var oE=F.object({type:F.literal("description"),elementDescriptor:F.string(),a11yData:Ir.optional().describe("DEPRECATED: new a11y cache is stored in DB and resolved into the 'cache' field")}).openapi({ref:"DescriptionTarget"}),iE=F.object({x:F.number(),y:F.number()}),aE=F.object({type:F.literal("coordinates"),pixels:iE}).openapi({ref:"CoordinatesTarget"});function or(n){return n.type==="description"}function En(n){return n.type==="coordinates"}var pt=F.discriminatedUnion("type",[oE,aE]).openapi({ref:"ElementTarget"});function xc(n){if(!n)return!1;switch(n.type){case"description":return!!n.elementDescriptor}return!0}function ut(n){if(!n)return"";switch(n.type){case"description":return n.elementDescriptor;case"coordinates":return`x: ${n.pixels.x}, y: ${n.pixels.y}`}}import{v4 as be}from"uuid";import*as v from"zod";import{z as fe}from"zod";import{z as wo}from"zod";var Cc=wo.object({result:wo.boolean(),traceId:wo.string()}).array(),Rc=wo.object({type:wo.literal("GCS_TRACES"),traces:Cc}),im=wo.object({memory:Rc.optional()});var Xa=class{async resolveStepCacheEntries(){}async saveStepCacheEntries(){}};Ce(fe);var am=fe.object({plan:fe.string().optional(),evidence:fe.string().optional(),thoughts:fe.string(),result:fe.boolean(),relevantElements:fe.array(fe.number()).optional(),updatedMemory:Cc.optional()}),vo=(o=>(o.CONTAINS="CONTAINS",o.STARTS_WITH="STARTS_WITH",o.EQUALS="EQUALS",o.EXISTS="EXISTS",o))(vo||{});var sE=fe.object({type:fe.literal("ELEMENT_CONTENT"),negated:fe.boolean().optional(),operation:fe.nativeEnum(vo),value:fe.string()}).openapi({ref:"ElementContentAssertion"}),lE=fe.object({type:fe.literal("ELEMENT_ATTRIBUTE"),negated:fe.boolean().optional(),operation:fe.nativeEnum(vo),attr:fe.string(),value:fe.string()}).openapi({ref:"ElementAttributeValueAssertion"}),To=(o=>(o.EXISTS="EXISTS",o.VISIBLE="VISIBLE",o.ENABLED="ENABLED",o.EDITABLE="EDITABLE",o))(To||{}),cE=fe.object({type:fe.literal("ELEMENT_EXISTENCE"),negated:fe.boolean().optional(),condition:fe.nativeEnum(To).describe("Treated as the element exists AND is also ...")}).openapi({ref:"ElementExistenceAssertion"}),sm=fe.discriminatedUnion("type",[sE,lE,cE]).openapi({ref:"ManualElementAssertion"});var dE=fe.object({type:fe.literal("CONTENT"),negated:fe.boolean().optional(),value:fe.string()}).openapi({ref:"PageContentAssertion"}),lm=fe.discriminatedUnion("type",[dE]).openapi({ref:"ManualPageAssertion"});import{z as le}from"zod";var Qa=le.object({url:le.string(),method:le.union([le.literal("GET"),le.literal("POST"),le.literal("PUT"),le.literal("DELETE"),le.literal("PATCH")]),headers:le.record(le.string(),le.string()).optional(),params:le.record(le.string(),le.string()).optional(),body:le.string().optional(),timeout:le.number().int().optional().describe("Max seconds to wait for the request to complete")}),cm=le.object({url:le.string(),headers:le.record(le.string(),le.string()).optional(),query:le.string(),variables:le.record(le.string(),le.string()).optional(),timeout:le.number().int().optional().describe("Max seconds to wait for the request to complete")}),Za=le.object({code:le.string(),fragment:le.boolean().optional(),environment:le.union([le.literal("NODE"),le.literal("BROWSER")]).optional().describe("default NODE"),timeout:le.number().int().max(60).optional().describe("Max seconds for the code to complete")});var Ue=(H=>(H.AI_EXTRACT="AI_EXTRACT",H.AI_ASSERTION="AI_ASSERTION",H.AUTH_LOAD="AUTH_LOAD",H.AUTH_SAVE="AUTH_SAVE",H.BLUR="BLUR",H.CAPTCHA="CAPTCHA",H.CLICK="CLICK",H.COOKIE="COOKIE",H.COPY="COPY",H.DIALOG="DIALOG",H.DRAG="DRAG",H.ELEMENT_CHECK="ELEMENT_CHECK",H.FILE_UPLOAD="FILE_UPLOAD",H.FOCUS="FOCUS",H.GO_BACK="GO_BACK",H.GO_FORWARD="GO_FORWARD",H.HOVER="HOVER",H.JAVASCRIPT="JAVASCRIPT",H.LOCAL_STORAGE="LOCAL_STORAGE",H.MOUSE_DRAG="MOUSE_DRAG",H.NAVIGATE="NAVIGATE",H.NEW_TAB="NEW_TAB",H.PAGE_CHECK="PAGE_CHECK",H.PASTE="PASTE",H.PRESS="PRESS",H.KEY_DOWN="KEY_DOWN",H.KEY_UP="KEY_UP",H.REFRESH="REFRESH",H.REQUEST="REQUEST",H.GRAPHQL_REQUEST="GRAPHQL_REQUEST",H.SCROLL_DOWN="SCROLL_DOWN",H.SCROLL_UP="SCROLL_UP",H.SCROLL_LEFT="SCROLL_LEFT",H.SCROLL_RIGHT="SCROLL_RIGHT",H.SELECT_OPTION="SELECT_OPTION",H.SWITCH_TAB="TAB",H.TYPE="TYPE",H.VISUAL_DIFF="VISUAL_DIFF",H.WAIT="WAIT",H.WAIT_FOR_URL="WAIT_FOR_URL",H.REGISTER_REQUEST_LISTENER="REGISTER_REQUEST_LISTENER",H.AWAIT_LISTENER="AWAIT_LISTENER",H.RECORD_REQUESTS="RECORD_REQUESTS",H.GET_RECORDED_REQUESTS="GET_RECORDED_REQUESTS",H.SET_HEADER="SET_HEADER",H.SUCCESS="SUCCESS",H))(Ue||{});Ce(v);var V=v.object({thoughts:v.string().optional(),id:v.string().uuid().describe("unique identifier to this step, used for step cache")}),Gt=v.object({useSelector:v.boolean().optional(),force:v.boolean().optional(),disableCache:v.boolean().optional().describe("disable element caching for this step"),iframeUrl:v.string().optional().describe("url or url regex for the iframe")}).openapi({ref:"CommonTargetingOptions"}),xn=v.object({target:Ir}).optional().openapi({ref:"SingleTargetCache"}),es=v.object({loadTimeout:v.number().int().max(60).optional().describe("Max seconds for the page to load")}),pE=V.merge(es).merge(v.object({type:v.literal("NAVIGATE"),url:v.string()})).openapi({ref:"NavigateCommand"}),ts=Gt.merge(v.object({cache:xn})),Eo=V.merge(ts.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_UP"),deltaY:v.number().optional()}))).openapi({ref:"ScrollUpCommand"}),xo=V.merge(ts.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_DOWN"),deltaY:v.number().optional()}))).openapi({ref:"ScrollDownCommand"}),Co=V.merge(ts.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_LEFT"),deltaX:v.number().optional()}))).openapi({ref:"ScrollLeftCommand"}),Ro=V.merge(ts.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_RIGHT"),deltaX:v.number().optional()}))).openapi({ref:"ScrollRightCommand"}),SD=v.discriminatedUnion("type",[Eo,xo,Co,Ro]).openapi({ref:"AllScrollCommands"}),uE=V.merge(v.object({type:v.literal("DIALOG"),action:v.union([v.literal("ACCEPT"),v.literal("DISMISS")])})).openapi({ref:"DialogCommand"}),mE=V.merge(v.object({type:v.literal("WAIT"),delay:v.number()})).openapi({ref:"WaitCommand"}),hE=v.discriminatedUnion("type",[v.object({type:v.literal("SUBSTRING"),url:v.string()}),v.object({type:v.literal("GLOB"),glob:v.string()}),v.object({type:v.literal("REGEX"),regex:v.string()})]),gE=v.object({caseInsensitive:v.boolean().optional().describe("Whether to ignore case when matching the URL"),negated:v.boolean().optional().describe("Wait for the URL to NOT match the provided matcher instead."),timeout:v.number().int().optional().describe("Max seconds to wait for the URL to match")}),fE=V.extend({type:v.literal("WAIT_FOR_URL"),matcher:hE}).merge(gE).openapi({ref:"WaitUrlCommand"}),SE=V.merge(es).merge(v.object({type:v.literal("REFRESH")})).openapi({ref:"RefreshCommand"}),yE=V.merge(v.object({type:v.literal("GO_BACK")})).openapi({ref:"GoBackCommand"}),bE=V.merge(v.object({type:v.literal("GO_FORWARD")})).openapi({ref:"GoForwardCommand"}),wE=V.extend({type:v.literal("AUTH_SAVE")}).openapi({ref:"AuthSaveCommand"}),vE=V.extend({type:v.literal("AUTH_LOAD"),storageState:v.string().describe("JSON string auth state. Leave blank or set to the empty string to clear all existing authentication.")}).openapi({ref:"AuthLoadCommand"}),Ic=V.merge(Gt).extend({type:v.literal("CAPTCHA")}).openapi({ref:"CaptchaCommand"}),TE=V.extend({type:v.literal("COPY"),value:v.string()}).openapi({ref:"CopyCommand"}),EE=V.extend({type:v.literal("PASTE")}).openapi({ref:"PasteCommand"}),xE=V.merge(Za).extend({type:v.literal("JAVASCRIPT")}).openapi({ref:"JavaScriptCommand"}),_i=V.merge(Gt).extend({type:v.literal("CLICK"),target:pt,doubleClick:v.boolean().optional(),rightClick:v.boolean().optional(),waitForDownload:v.boolean().optional().describe("Wait for the click to trigger a file download and for the file download to complete."),delayMs:v.number().optional(),downloadTimeoutMs:v.number().optional(),cache:xn,relativePosition:v.object({x:v.number(),y:v.number()}).optional()}).openapi({ref:"ClickCommand"}),Di=V.merge(Gt).merge(v.object({type:v.literal("DRAG"),fromTarget:pt,toTarget:pt,steps:v.number().optional(),hoverSeconds:v.number().optional().describe("Seconds to hover the object before dropping"),cache:v.object({fromTarget:Ir.optional(),toTarget:Ir.optional()}).optional()})).openapi({ref:"DragCommand"}),Fi=V.merge(Gt).merge(v.object({type:v.literal("MOUSE_DRAG"),target:pt.optional(),deltaX:v.string().describe("pixels to move horizontally, can be template"),deltaY:v.string().describe("pixels to move vertically, can be template"),steps:v.number().optional(),cache:xn})).openapi({ref:"MouseDragCommand"}),Ui=V.merge(Gt).merge(v.object({type:v.literal("HOVER"),target:pt,cache:xn})).openapi({ref:"HoverCommand"}),Bi=V.merge(Gt).merge(v.object({type:v.literal("FOCUS"),target:pt,cache:xn})).openapi({ref:"FocusCommand"}),zi=V.merge(Gt).extend({type:v.literal("BLUR"),target:pt.optional(),cache:xn}).openapi({ref:"BlurCommand"}),CE=v.object({type:v.literal("URL"),url:v.string()}).describe("Accessible link to the file, either public http or local file://").openapi({ref:"UrlSource"}),RE=v.object({type:v.literal("USER_FILE"),name:v.string()}).describe("Accessible link to the file, references the google cloud file").openapi({ref:"UploadedFileSource"}),AE=V.extend({type:v.literal("FILE_UPLOAD"),fileSource:v.discriminatedUnion("type",[CE,RE]),filename:v.string().optional()}).openapi({ref:"FileUploadCommand"}),IE=v.discriminatedUnion("type",[v.object({type:v.literal("VALUE"),value:v.string()}),v.object({type:v.literal("LABEL"),label:v.string()}),v.object({type:v.literal("INDEX"),index:v.coerce.string()})]),Hi=V.merge(Gt).extend({type:v.literal("SELECT_OPTION"),target:pt,cache:xn,choice:IE.describe("new field for selecting options, optional for backcompat")}).openapi({ref:"SelectOptionCommand"}),Pc=v.union([v.literal("MULTIMODAL"),v.literal("VISION_ONLY")]),ns=V.merge(v.object({type:v.literal("AI_ASSERTION"),assertion:v.string(),disableCache:v.boolean().optional(),iframeUrl:v.string().optional(),contextChoice:Pc.optional(),timeout:v.number().int().optional().describe("Max seconds to wait for assertion to be true"),cache:im.optional()})).openapi({ref:"AIAssertionCommand"}),Cn=5,Lc=600,ji=V.merge(Gt).extend({type:v.literal("ELEMENT_CHECK"),target:pt,assertion:sm,cache:xn,timeout:v.number().int().min(0).max(Lc).optional().describe("max seconds to wait for the assertion to be true")}).openapi({ref:"ElementAssertionCommand"}),PE=V.extend({type:v.literal("PAGE_CHECK"),assertion:lm,iframeUrl:v.string().optional().describe("url or url regex for the iframe"),timeout:v.number().int().min(0).max(Lc).optional().describe("max seconds to wait for the assertion to be true")}).openapi({ref:"PageAssertionCommand"}),LE=V.merge(v.object({type:v.literal("AI_EXTRACT"),goal:v.string(),schema:v.string().optional(),envKey:v.string().optional(),disableCache:v.boolean().optional(),iframeUrl:v.string().optional()})).openapi({ref:"AIExtractCommand"}),OE=v.object({clearContent:v.boolean().optional(),forceClearContent:v.boolean().optional(),delay:v.number().min(0).max(1e3).optional().describe("Delay between each press in milliseconds."),force:v.boolean().optional(),pressEnter:v.boolean().optional()}),dm=25,$i=V.merge(Gt).merge(OE).extend({type:v.literal("TYPE"),target:pt.optional(),value:v.string(),cache:xn}).openapi({ref:"TypeCommand"}),ME=V.merge(v.object({type:v.literal("PRESS"),value:v.string(),repeat:v.number().optional(),convertMeta:v.boolean().optional(),delayMs:v.number().optional()})).openapi({ref:"PressCommand"}),NE=V.merge(v.object({type:v.literal("KEY_DOWN"),value:v.string(),convertMeta:v.boolean().optional()})).openapi({ref:"KeyDownCommand"}),kE=V.merge(v.object({type:v.literal("KEY_UP"),value:v.string(),convertMeta:v.boolean().optional()})).openapi({ref:"KeyUpCommand"}),_E=v.object({type:v.literal("SUBSTRING"),substring:v.string()}),DE=v.object({type:v.literal("REGEX"),pattern:v.string()}),FE=v.object({type:v.literal("INDEX"),index:v.coerce.string()}),UE=v.discriminatedUnion("type",[_E,DE,FE]),BE=V.merge(es).merge(v.object({type:v.literal("TAB"),action:UE})).openapi({ref:"TabCommand"}),zE=V.merge(es).merge(v.object({type:v.literal("NEW_TAB"),url:v.string()})).openapi({ref:"NewTabCommand"}),HE=V.merge(v.object({type:v.literal("COOKIE"),value:v.string()})).openapi({ref:"CookieCommand"}),jE=V.merge(v.object({type:v.literal("LOCAL_STORAGE"),key:v.string(),value:v.string()})).openapi({ref:"LocalStorageCommand"}),$E=V.extend({type:v.literal("REQUEST")}).merge(Qa).openapi({ref:"RequestCommand"}),GE=V.extend({type:v.literal("GRAPHQL_REQUEST")}).merge(cm).openapi({ref:"GraphQLRequestCommand"}),WE=V.merge(v.object({type:v.literal("SUCCESS"),condition:ns.optional()})).openapi({ref:"SuccessCommand"}),VE=V.merge(v.object({type:v.literal("FAILURE")})).openapi({ref:"FailureCommand"}),qE=v.object({data:v.string().describe("location at which to find a jpg"),width:v.number(),height:v.number()}),Gi=V.merge(Gt).merge(v.object({type:v.literal("VISUAL_DIFF"),threshold:v.number().optional().describe("default 0.1"),target:pt.optional(),screenshot:qE.optional(),cache:xn})).openapi({ref:"VisualDiffCommand"}),KE=V.merge(v.object({type:v.literal("REGISTER_REQUEST_LISTENER"),pattern:v.string(),key:v.string()})).openapi({ref:"RegisterRequestListenerCommand"}),YE=V.merge(v.object({type:v.literal("AWAIT_LISTENER"),key:v.string(),timeout:v.number().optional().describe("timeout")})).openapi({ref:"WaitForListenerCommand"}),JE=V.merge(v.object({type:v.literal("RECORD_REQUESTS"),pattern:v.string(),key:v.string()})).openapi({ref:"RecordRequestsCommand"}),XE=V.merge(v.object({type:v.literal("GET_RECORDED_REQUESTS"),key:v.string()})).openapi({ref:"GetRecordedRequestsCommand"}),QE=V.merge(v.object({type:v.literal("SET_HEADER"),name:v.string(),value:v.string(),urlPattern:v.string().optional().describe("URL pattern to match")})).openapi({ref:"SetHeaderCommand"}),pm=v.discriminatedUnion("type",[_i,$i,ME,NE,kE,Hi,pE,xo,Eo,ns,Ui,mE,WE]),ZE=v.discriminatedUnion("type",[LE,vE,wE,Ic,HE,TE,uE,Di,ji,AE,yE,bE,xE,jE,Fi,zE,PE,EE,SE,$E,GE,Co,Ro,BE,Gi,Bi,zi,fE,KE,YE,JE,XE,QE]),Ao=v.discriminatedUnion("type",[...pm.options,...ZE.options]).openapi({ref:"Command"}),rs=v.discriminatedUnion("type",[...pm.options,VE]);function Un(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:be(),type:n};break;case"AUTH_LOAD":{e={id:be(),type:n,storageState:""};break}case"AI_EXTRACT":e={id:be(),type:n,goal:""};break;case"DIALOG":e={id:be(),type:n,action:"DISMISS"};break;case"DRAG":e={id:be(),type:n,fromTarget:{type:"description",elementDescriptor:""},toTarget:{type:"description",elementDescriptor:""}};break;case"MOUSE_DRAG":e={id:be(),type:n,deltaX:"0",deltaY:"0",steps:1};break;case"WAIT_FOR_URL":e={id:be(),type:n,matcher:{type:"SUBSTRING",url:""}};break;case"WAIT":e={id:be(),type:n,delay:1};break;case"BLUR":e={id:be(),type:n};break;case"HOVER":case"FOCUS":case"CLICK":e={id:be(),type:n,target:{type:"description",elementDescriptor:""}};break;case"COOKIE":case"PRESS":case"COPY":case"TYPE":e={id:be(),type:n,value:"",clearContent:!0};break;case"KEY_DOWN":case"KEY_UP":e={id:be(),type:n,value:""};break;case"SELECT_OPTION":e={id:be(),type:n,target:{type:"description",elementDescriptor:""},choice:{type:"VALUE",value:""}};break;case"NAVIGATE":case"NEW_TAB":return{id:be(),type:n,url:""};case"TAB":e={id:be(),type:n,action:{type:"SUBSTRING",substring:""}};break;case"REQUEST":e={id:be(),type:n,url:"",method:"GET"};break;case"GRAPHQL_REQUEST":e={id:be(),type:n,url:"",query:""};break;case"LOCAL_STORAGE":e={id:be(),type:n,key:"",value:""};break;case"JAVASCRIPT":e={id:be(),type:n,code:""};break;case"AI_ASSERTION":e={id:be(),type:n,assertion:""};break;case"FILE_UPLOAD":{e={id:be(),type:n,fileSource:{type:"URL",url:""}};break}case"ELEMENT_CHECK":{e={id:be(),type:n,target:{type:"description",elementDescriptor:""},assertion:{type:"ELEMENT_EXISTENCE",condition:"EXISTS"}};break}case"PAGE_CHECK":{e={id:be(),type:n,assertion:{type:"CONTENT",value:""}};break}case"REGISTER_REQUEST_LISTENER":{e={id:be(),type:n,pattern:"",key:""};break}case"AWAIT_LISTENER":{e={id:be(),type:n,key:""};break}case"RECORD_REQUESTS":{e={id:be(),type:n,pattern:"",key:""};break}case"GET_RECORDED_REQUESTS":{e={id:be(),type:n,key:""};break}case"SET_HEADER":{e={id:be(),type:n,name:"",value:""};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 um(n){switch(n.type){case"BLUR":case"CLICK":case"DRAG":case"FOCUS":case"HOVER":case"MOUSE_DRAG":case"PRESS":case"KEY_DOWN":case"KEY_UP":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"GET_RECORDED_REQUESTS":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"RECORD_REQUESTS":case"REGISTER_REQUEST_LISTENER":case"REFRESH":case"REQUEST":case"SELECT_OPTION":case"SET_HEADER":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 ex}from"zod";var TD=ex.discriminatedUnion("type",[zi,Ic,_i,Di,Bi,Ui,Fi,Eo,xo,Co,Ro,Hi,$i,Gi,ji]);function mm(n){return["AI_ASSERTION","ELEMENT_CHECK","PAGE_CHECK"].includes(n)}import{z as tx}from"zod";var Tt={type:!0,cache:!0},Pr=tx.discriminatedUnion("type",[ns.pick(Tt),zi.pick(Tt),_i.pick(Tt),Di.pick(Tt),ji.pick(Tt),Bi.pick(Tt),Ui.pick(Tt),Fi.pick(Tt),Eo.pick(Tt),xo.pick(Tt),Co.pick(Tt),Ro.pick(Tt),Hi.pick(Tt),$i.pick(Tt),Gi.pick(Tt)]),Oc=Object.values(Ue).filter(n=>Pr.options.some(e=>e.shape.type.safeParse(n).success));Ao.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 Nc}from"zod";import{z as Mc}from"zod";import{z as Io}from"zod";var It=Io.object({index:Io.number().optional().describe("global index within a test (in-order traversal)"),id:Io.string(),skipped:Io.boolean().optional(),envKey:Io.string().optional().describe("key in the environment to save the result of this step to"),aiSuggested:Io.boolean().optional()});Ce(Mc);var Pt=It.extend({type:Mc.literal("PRESET_ACTION"),command:Ao,skipped:Mc.boolean().optional()}).openapi({ref:"PresetAction"});Ce(Nc);var Lr=It.extend({type:Nc.literal("AI_ACTION"),text:Nc.string(),steps:Pt.array().optional()}).openapi({ref:"AIAction"});import{z as ie}from"zod";var nx=ie.object({cacheKey:ie.string(),cacheExpiryMs:ie.number()}),kc=It.extend({id:ie.string().uuid().describe("ID of the module step itself. Used to 'namespace' step cache entries."),inputs:ie.record(ie.string()).optional(),cacheConfig:nx.optional()}),Bn=kc.extend({type:ie.literal("MODULE"),moduleId:ie.string().uuid()}),rx=ie.union([Bn.pick({type:!0,moduleId:!0}),ie.record(ie.unknown())]),ox=ie.object({type:ie.literal("URL_REGEX"),regex:ie.string()}),ix=ie.object({type:ie.literal("PAGE_CHECK"),substring:ie.string()}),_c=ie.object({cacheInvalidation:ie.discriminatedUnion("type",[ix,ox]).optional()}),Lt=ie.object({moduleId:ie.string().uuid(),name:ie.string(),description:ie.string().nullish(),enabled:ie.boolean().nullish(),parameters:ie.string().array().nullish(),defaultParameters:ie.record(ie.string(),ie.string()).nullish(),parameterEnums:ie.record(ie.string(),ie.string().array()).nullish(),defaultCacheKey:ie.string().nullish(),defaultCacheTtl:ie.number().nullish(),defaultCacheAllInvocations:ie.boolean().nullish(),autoAuth:ie.boolean().nullish(),advanced:_c.nullish()});import{z as at}from"zod";import{z as Dc}from"zod";Ce(Dc);var Po=It.extend({type:Dc.literal("AI_ACTION_DYNAMIC"),text:Dc.string()}).openapi({ref:"AIActionDynamic"});import{z as hm}from"zod";var Fc=It.extend({type:hm.literal("CONDITIONAL"),skipped:hm.boolean().optional()});import{z as os}from"zod";var ax=os.object({type:os.literal("url"),url:os.string()}),Wi=It.extend({type:os.literal("IFRAME"),identifier:ax});import{z as Wt}from"zod";var Uc=(r=>(r.ALWAYS="ALWAYS",r.ON_FAILURE="ON_FAILURE",r.ON_ACTION_FAILURE="ON_ACTION_FAILURE",r))(Uc||{});var sx=Wt.discriminatedUnion("type",[Wt.object({type:Wt.literal("NAVIGATE_URL"),url:Wt.string().url()}),Wt.object({type:Wt.literal("GO_TO_SECTION_START")})]),lx=Wt.object({trigger:Wt.nativeEnum(Uc).optional(),attempts:Wt.number().int().optional(),restartBehavior:sx}),Vi=It.extend({type:Wt.literal("SECTION"),description:Wt.string().describe("user provided goal of what the section should accomplish"),plan:Wt.string().array().optional(),autohealingConfig:lx.optional()});var gm=Lt.merge(kc).extend({type:at.literal("RESOLVED_MODULE"),steps:at.lazy(()=>Le.array())}),Bc=Lt.extend({steps:at.lazy(()=>Le.array())}),zc=Wi.extend({steps:at.lazy(()=>we.array())}),cx=Wi.extend({steps:at.lazy(()=>Le.array())}),Hc=Vi.extend({steps:at.lazy(()=>we.array())}),dx=Vi.extend({steps:at.lazy(()=>Le.array())}),Or=Fc.extend({blocks:at.object({assertion:at.lazy(()=>Pt),steps:at.lazy(()=>we.array())}).array(),elseSteps:at.lazy(()=>we.array().optional())}),px=Fc.extend({blocks:at.object({assertion:at.lazy(()=>Pt),steps:at.lazy(()=>Le.array())}).array(),elseSteps:at.lazy(()=>Le.array().optional())}),we=at.discriminatedUnion("type",[Pt,Lr,Po,Bn,Or,zc,Hc]),Le=at.discriminatedUnion("type",[Pt,Lr,Po,gm,px,cx,dx]);import{z as Vt}from"zod";var ux=Vt.object({steps:we.array(),beforeSteps:we.array().nullish(),afterSteps:we.array().nullish()}),Lo=Vt.object({steps:Le.array(),beforeSteps:Le.array().nullish(),afterSteps:Le.array().nullish()}),Mr=Vt.object({steps:Vt.record(Vt.string(),Vt.unknown()).array(),beforeSteps:Vt.record(Vt.string(),Vt.unknown()).array().nullish(),afterSteps:Vt.record(Vt.string(),Vt.unknown()).array().nullish()});var Oe="1.0.20";import{z as ir}from"zod";var jc=ir.object({key:ir.string(),testId:ir.string().optional(),moduleId:ir.string().optional(),organizationId:ir.string(),value:Pr}),$c=jc.extend({uniqueKey:ir.string()}),HF=ir.record(ir.string(),$c);var fm=_.object({phrase:_.string()}),Gc=_.object({thoughts:_.string().optional(),result:_.union([_.literal("NOT_FOUND"),_.string(),_.number(),_.array(_.unknown()),_.record(_.unknown(),_.unknown()),_.unknown()])}),E0=_.object({text:_.string()}),Sm=_.object({thoughts:_.string(),review:_.string().optional(),id:_.number().int(),updatedMemory:Ec.optional()}),is=(u=>(u.NO_DESCRIPTION_PROVIDED="NO_DESCRIPTION_PROVIDED",u.FEW_WORDS="FEW_WORDS",u.STYLE_TAG="STYLE_TAG",u.TYPE_IN_DESCRIPTION="TYPE_IN_DESCRIPTION",u.HARDCODED_ATTRIBUTE="HARDCODED_ATTRIBUTE",u.NONE="NONE",u.AMBIGUOUS_DESCRIPTION="AMBIGUOUS_DESCRIPTION",u.AMBIGUOUS_ASSERTION="AMBIGUOUS_ASSERTION",u.PREFER_PAGE_CHECK="PREFER_PAGE_CHECK",u.PREFER_ASSERTION="PREFER_ASSERTION",u.HTML_ELEMENTS="HTML_ELEMENTS",u.MULTIPLE_ELEMENTS_DESCRIPTION="MULTIPLE_ELEMENTS_DESCRIPTION",u))(is||{});var ym=_.object({thoughts:_.string(),category:_.nativeEnum(is)}),mx=_.discriminatedUnion("op",[_.object({op:_.literal("replace"),path:_.string(),value:_.string()}),_.object({op:_.literal("add"),path:_.string(),value:_.string()}),_.object({op:_.literal("remove"),path:_.string()})]),x0=_.object({thoughts:_.string(),patches:mx.array()}),bm=[_.literal("add"),_.literal("replace"),_.literal("remove")],hx=_.object({op:_.union(bm),path:_.string(),value:Le.optional()}),wm=_.object({patches:hx.array(),thoughts:_.string()});var gx=_.object({thoughts:_.string(),op:_.union(bm),value:_.union([_.null(),Le])}),vm=_.object({reasoning:_.string(),scenario:_.string(),patch:gx.or(_.null())}),C0=_.object({thoughts:_.string(),evaluation:_.number().min(1).max(10)}),R0=_.object({observations:_.string(),reasoning:_.string(),command:rs});var Wc=_.object({summary:_.string(),reasoning:_.string(),evaluation:_.discriminatedUnion("type",[_.object({type:_.literal("DONE")}),_.object({type:_.literal("RIGHT_TRACK")}),_.object({type:_.literal("WRONG_TRACK"),feedback:_.string()}),_.object({type:_.literal("IMPOSSIBLE")})])});import{z as N}from"zod";import*as Q from"zod";var M0=Q.object({thoughts:Q.string().optional().describe("only provided if a description was provided"),target:Ir.optional().describe("only provided if a description was provided"),pageState:Q.string().optional().describe("serialized a11y tree, only provided if a description was provided"),options:Q.object({label:Q.string(),value:Q.string()}).array().optional().describe("list of options, provided for <select> elements only"),screenshot:Q.object({data:Q.string(),height:Q.number().int(),width:Q.number().int()}).optional().describe("only provided if returnScreenshot is true")}),as=Q.union([Q.literal("ELEMENT_CHECK"),Q.literal("NEGATED_CHECK"),Q.literal("NEGATED_ELEMENT_VISIBLE_CHECK"),Q.literal("SELECT_OPTION"),Q.literal("TYPE")]);function Nr(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.condition==="EXISTS"&&n.assertion.negated)return"NEGATED_CHECK";if(n.type==="ELEMENT_CHECK"&&n.assertion.type==="ELEMENT_EXISTENCE"&&n.assertion.condition==="VISIBLE"&&n.assertion.negated)return"NEGATED_ELEMENT_VISIBLE_CHECK";if(n.type==="ELEMENT_CHECK")return"ELEMENT_CHECK"}}var qi=(a=>(a.USER_SELECTOR="USER_SELECTOR",a.CSS_SELECTOR="CSS_SELECTOR",a.HYBRID_SELECTOR="HYBRID_SELECTOR",a.HTML_DISTANCE="HTML_DISTANCE",a.TEMPLATE_MATCHING="TEMPLATE_MATCHING",a.AUTO_FRAME="AUTO_FRAME",a))(qi||{}),Oo=Q.object({matched:Q.boolean(),reason:Q.string().optional().describe("Human understandable description"),logs:Q.string().array().optional().describe("Logs for debugging")}),fx=Oo.extend({type:Q.literal("USER_SELECTOR")}),Sx=Oo.extend({type:Q.literal("CSS_SELECTOR"),selectors:Q.string().array()}),yx=Oo.extend({type:Q.literal("HYBRID_SELECTOR")}),bx=Oo.extend({type:Q.literal("HTML_DISTANCE"),distance:Q.number().optional(),closestElement:Q.string().optional(),savedElement:Q.string().optional()}),wx=Oo.extend({type:Q.literal("TEMPLATE_MATCHING"),elementImageUrl:Q.string().url()}),vx=Oo.extend({type:Q.literal("AUTO_FRAME"),logs:Q.string().array().optional()}),Tm=Q.discriminatedUnion("type",[fx,Sx,yx,bx,wx,vx]);import{z as Zi}from"zod";import{z as $C}from"zod";import*as J from"zod";import{cloneDeep as Ji}from"lodash-es";var Tx=n=>{let e=Em(n,0);if(e===void 0||!xx(n[e]))return;let t=Em(n,e+1);if(t!==void 0)return Cx(n,e,t)},xm=Tx,Em=(n,e)=>{for(let t=e;t<n.length;t+=1){let r=n[t];if(!Ex(r))return t}},Ex=n=>n===" "||n===" "||n===`
5
- `||n==="\r",xx=n=>n==="{"||n==="[",Cx=(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 Rx(r);if(r===void 0)r=i;else if(r[0]===i)r+=i;else return}},Rx=n=>n===void 0?0:n[0]===" "?n.length:n;var Cm=(n,e)=>{let t=Vc(n,"toPrecision",e,e);return t===void 0?Vc(n,"toExponential",e,e):t},Vc=(n,e,t,r)=>{let i=n[e](r).replace(Ax,"$1").replace(Ix,"$1");return i.length<=t?i:r===1?void 0:Vc(n,e,t,r-1)},Ax=/(e)\+/iu,Ix=/\.?0*($|e)/iu;var Am=(n,e)=>{if(typeof n!="string")throw new TypeError(`Input must be a JSON string: ${n}`);Px(e)},Px=n=>{if(Lx(n),n<0)throw new TypeError(`"maxSize" argument must be positive: ${n}`);if(n<Rm)throw new TypeError(`"maxSize" argument must be at least ${Rm}: ${n}`)},Lx=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}`)},Rm=7;var ss=(n,e,t)=>{let r=Pm(e,t);return Im(n,e,r)},Im=(n,e,t)=>{if(t>=e)return t;let r=n[t];return r>=Bx&&r<=zx?Im(n,e,t+1):t},ls=(n,e,t)=>{if(t===void 0)return t;let r=Pm(e,t);return Ox(n,r)},Ox=(n,e)=>Mx(n,e)?e-3:Nx(n,e)?e-2:kx(n,e)?e-1:e,Mx=(n,e)=>e>=3&&n[e-3]>=_x&&n[e-3]<=Dx,Nx=(n,e)=>e>=2&&n[e-2]>=Fx,kx=(n,e)=>e>=1&&n[e-1]>=Ux,Pm=(n,e)=>e<0||Object.is(e,-0)?Math.max(n+e,0):e,_x=240,Dx=244,Fx=224,Ux=194,Bx=128,zx=191;var Lm=(n,e,t)=>{let r=globalThis.Buffer.from(n),o=ss(r,r.length,e),i=ls(r,r.length,t);return o===0&&i>=r.length?r.toString():r.toString("utf8",o,i)};var Om=/[\uD800-\uDFFF]/gu,Mm="\uFFFD";var cs=n=>Hx(n)?n.replace(Om,Mm):n,Hx=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 Yc=({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,u=0;for(;u<e;d+=a){p=d;let h=n.charCodeAt(d);if(Number.isNaN(h))break;if(h<=127){u+=1;continue}if(h<=2047){u+=2;continue}if(u+=3,h<t||h>r)continue;let g=n.charCodeAt(d+a);Number.isNaN(g)||g<o||g>i||(u+=1,d+=a)}return(s&&u>e?p:d)+l};var Jc=(n,e,t)=>e<0||Object.is(e,-0)?qx(n,e,t):Vx(n,e,t),Vx=(n,e,t)=>Yc({input:n,targetByteCount:e,firstStartSurrogate:55296,lastStartSurrogate:56319,firstEndSurrogate:56320,lastEndSurrogate:57343,increment:1,canBacktrack:t,shift:0,charIndexInit:0}),qx=(n,e,t)=>Yc({input:n,targetByteCount:-e,firstStartSurrogate:56320,lastStartSurrogate:57343,firstEndSurrogate:55296,lastEndSurrogate:56319,increment:-1,canBacktrack:!t,shift:1,charIndexInit:n.length-1});var ds=(n,e,t)=>{let r=Jc(n,e,!1),o=Kx(n,t),i=r===0&&o===void 0?n:n.slice(r,o);return cs(i)},Kx=(n,e)=>{if(e===void 0)return e;let t=Jc(n,e,!0);return t===n.length?void 0:t};var km=(n,e,t)=>{let{textEncoder:r,textDecoder:o}=Yx(),i=Jx(n),{written:a}=r.encodeInto(n,i),s=ss(i,a,e),l=ls(i,a,t),c=l===void 0?a:Math.min(l,a),d=i.subarray(s,c);return o.decode(d)},Yx=()=>(Xc===void 0&&(Xc=new globalThis.TextEncoder,Nm=new globalThis.TextDecoder("utf8",{fatal:!1})),{textEncoder:Xc,textDecoder:Nm}),Xc,Nm,Jx=n=>{let e=n.length*3;return e>Xx?new Uint8Array(e):((ps===void 0||ps.length<e)&&(ps=new Uint8Array(e)),ps)},Xx=1e5,ps;var _m=(n,e)=>{if(e===void 0)return e;let t=Qc(n,e);return t>=n.length*Dm?void 0:t},Qc=(n,e)=>e<=n.length*-Dm?0:e,Dm=4;var Fm=(n,e,t)=>{if(typeof n!="string")throw new TypeError(`First argument must be a string: ${n}`);Qx(e),Zx(t)},Qx=n=>{if(n===void 0)throw new TypeError("Second argument is required.");Um("Second",n)},Zx=n=>{n!==void 0&&Um("Third",n)},Um=(n,e)=>{if(!Number.isInteger(e))throw new TypeError(`${n} argument must be an integer: ${e}`)};var Bm=n=>{let e=!0,t=0;for(let r=0;r<Zc;r+=1){let o=eC(n,r);o<=127||(e&&(e=!1),o>2047&&(t+=1))}return{asciiOnly:e,longCharsPercentage:t/Zc}},eC=(n,e)=>{let t=Zc-1,r=1-(t-e)/t,o=Math.round(r*(n.length-1));return n.charCodeAt(o)},Zc=50;var tC=(n,e,t)=>{if(Fm(n,e,t),n==="")return n;let r=Qc(n,e),o=_m(n,t);return o===void 0&&Object.is(r,0)?cs(n):nC(n,r,o)},zm=tC,nC=(n,e,t)=>{if(n.length<=rC)return ds(n,e,t);let{asciiOnly:r,longCharsPercentage:o}=Bm(n);return r?iC(n,e,t):o>=oC?ds(n,e,t):Hm(n,e,t)},rC=200,oC=.4,iC=(n,e,t)=>"Buffer"in globalThis&&"from"in globalThis.Buffer?Lm(n,e,t):Hm(n,e,t),Hm=(n,e,t)=>"TextEncoder"in globalThis?km(n,e,t):ds(n,e,t);var $m=(n,e)=>{let t=JSON.stringify(n),r=lC(t),o=zm(r,0,e-jm.length-Ki.length*2),a=`${aC(o)}${jm}`;return cC(a)},aC=n=>n.replace(sC,""),sC=/(\\|\\u[0-9a-fA-F]{0,3})$/u,lC=n=>n.slice(Ki.length,-Ki.length),cC=n=>`${Ki}${n}${Ki}`,Ki='"',jm="...";var Gm=n=>globalThis.Buffer.byteLength(n);var ed=n=>{let e=n.length,t=e;for(let r=0;r<e;r+=1){let o=n.charCodeAt(r);if(o<=dC)continue;if(o<=pC){t+=1;continue}if(t+=2,o<uC||o>mC)continue;let i=n.charCodeAt(r+1);i<hC||i>gC||(r+=1)}return t},dC=127,pC=2047,uC=55296,mC=56319,hC=56320,gC=57343;var Wm=()=>fC.bind(void 0,new TextEncoder),fC=(n,e)=>{let t=SC(e);return n.encodeInto(e,t).written},SC=n=>{let e=n.length*3;return e>yC?new Uint8Array(e):((us===void 0||us.length<e)&&(us=new Uint8Array(e)),us)},yC=1e5,us;var wC=()=>"Buffer"in globalThis&&"byteLength"in globalThis.Buffer?Gm:"TextEncoder"in globalThis?vC.bind(void 0,Wm()):ed,vC=(n,e)=>e.length<100?ed(e):n(e),Vm=wC();var qm=n=>{if(n===null)return TC;if(n===!0)return EC;if(n===!1)return xC;let e=typeof n;return e==="object"?CC:e==="number"?JSON.stringify(n).length:td(n)},TC=4,EC=4,xC=5,CC=2,td=n=>Vm(JSON.stringify(n));var ms=({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=>qm(n),Jm=(n,e,t)=>{let r=Qm({empty:n,indent:e,depth:t,keySpaceSize:0}),o=Zm(n);return r+o},Xm=({key:n,empty:e,indent:t,depth:r})=>{let o=Qm({empty:e,indent:t,depth:r,keySpaceSize:1}),i=td(n),a=Zm(e);return o+i+RC+a},RC=1,Qm=({empty:n,indent:e,depth:t,keySpaceSize:r})=>{if(e===void 0)return 0;let o=Km+e*(t+1),i=n?Km+e*t:0;return r+o+i},Km=1,Zm=n=>n?0:AC,AC=1;var hs=({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],u=[...t,i],{size:m,stop:h,truncatedProps:g}=ms({size:s,increment:r,maxSize:o,truncatedProps:e,path:u,value:p});return h?{empty:a,size:m,truncatedProps:g}:IC({value:p,truncatedProps:e,path:u,maxSize:o,empty:a,size:s,newSize:m,truncateValue:l,indent:c,depth:d})},IC=({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:u}=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:u}:{empty:!1,size:p,value:d,truncatedProps:u}};var eh=({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=Jm(c.empty,a,s);c=hs({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 th=({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=Xm({key:d,empty:c.empty,indent:a,depth:s});c=hs({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 gs=({value:n,truncatedProps:e,path:t,size:r,maxSize:o,indent:i,depth:a})=>{let s=Ym(n),{size:l,stop:c,truncatedProps:d}=ms({size:r,increment:s,maxSize:o,truncatedProps:e,path:t,value:n});return c?{value:void 0,size:l,truncatedProps:d}:PC({value:n,truncatedProps:d,path:t,size:l,maxSize:o,indent:i,depth:a})},PC=({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)?eh({array:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:gs,indent:i,depth:a}):th({object:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:gs,indent:i,depth:a});var LC=(n,e)=>{Am(n,e);let t=OC(n),r=MC(n),{value:o,truncatedProps:i}=gs({value:r,truncatedProps:[],path:[],size:0,maxSize:e,indent:t,depth:0});return{jsonString:NC({newValue:o,value:r,maxSize:e,indent:t}),truncatedProps:i}},Mo=LC,OC=n=>{let e=xm(n);return typeof e=="string"?e.length:e},MC=n=>{try{return JSON.parse(n)}catch(e){throw new TypeError(`Invalid JSON string: "${n}"
7
- ${e.message}`)}},NC=({newValue:n,value:e,maxSize:t,indent:r})=>n!==void 0?JSON.stringify(n,void 0,r):typeof e=="number"?Cm(e,t):$m(e,t);import*as _r from"zod";import{z as cn}from"zod";import{z as et}from"zod";var nd=et.object({autoFollowNewTabs:et.boolean().optional().describe("Deprecated: Auto-follow new tabs that are opened."),showZeroOpacityElements:et.boolean().optional(),ignoreHrefForCaching:et.boolean().optional(),hybridSelectorMode:et.enum(["test","prefer"]).optional(),globalLocatorRedirect:et.boolean().optional(),visualActions:et.boolean().optional(),autoExpandIframes:et.boolean().optional()});var nh=1e4,rh=6e4,kr=nd.extend({pageLoadTimeoutMs:et.number().optional().refine(n=>n===void 0||n<=rh&&n>=-1,{message:`Page load timeout must be between 0 and ${rh/1e3} seconds`}).describe("global page load timeout default for all tests in ms, can still be overridden by individual tests"),smartWaitingTimeoutMs:et.number().optional().refine(n=>n===void 0||n<=nh&&n>=-1,{message:`Smart waiting timeout must be between 0 and ${nh/1e3} seconds`}),localChromeExtensionPaths:et.string().array().optional(),extraHeaders:et.record(et.string(),et.string()).optional().describe("HTTP headers to be sent on every request"),userAgent:et.string().optional(),disableGpu:et.boolean().optional(),bustCacheOnBoundingBoxChange:et.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:et.boolean().optional().describe("Allow fetching the partial accessibility tree if the full tree takes too long.")});var We="BASE_URL",fs="CURRENT_URL",No="ENV_NAME",Yi="TEST_NAME",$U={[We]:"https://www.google.com"},oh=cn.string().describe("Name of the fixture (must be available locally in the fixtures directory)."),ih=cn.object({name:cn.string(),variables:cn.record(cn.string().describe("variable name"),cn.string().describe("variable value"))}),ah=cn.object({name:cn.string(),variables:cn.record(cn.string().describe("variable name"),cn.unknown().describe("variable value")),browser:kr.optional()});Ce(_r);var Xi=_r.object({env:_r.record(_r.unknown())}).openapi({ref:"TestContextSnapshot"}),kC="\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022",_C=[We,No,Yi],sh=[fs,We,No,Yi],Ot=class n{env={};varsFromMomenticEnvironment={};constructor(e){this.reset(e)}static dummyContext(e=void 0,t=void 0,r={}){return new n({baseUrl:"about:blank",currentUrl:"about:blank",testName:e,envName:t,variablesFromEnvironment:r})}static fromSnapshot({snapshot:e,environmentVariables:t}){let r=e.env[We]??"about:blank",o=e.env[fs]??"about:blank",i=e.env[No],a=e.env[Yi],s={};for(let[c,d]of Object.entries(e.env))sh.includes(c)||(t??{})[c]===void 0&&(s[c]=d);return new n({baseUrl:r,currentUrl:o,dynamicVariables:s,envName:i,testName:a,variablesFromEnvironment:t??{}})}setEnvVariables(e){let t=Ji(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){_C.includes(e)||(this.env[e]=t)}getEnvName(){return this.env[No]}toObjectCopy(){let e={env:Object.assign({},this.env,this.varsFromMomenticEnvironment)};return Ji(e)}toEditorDisplayCopy(){return this.toObjectCopy()}toRedactedDisplayCopy(){let e=this.toObjectCopy();e.env=Object.fromEntries(Object.entries(e.env).map(([r,o])=>sh.includes(r)||this.varsFromMomenticEnvironment[r]===void 0?[r,o]:[r,kC]));for(let[r,o]of Object.entries(e.env)){if(!o){e.env[r]=o;continue}let{jsonString:i}=Mo(JSON.stringify(o),1e3);try{e.env[r]=JSON.parse(i)}catch{e.env[r]=void 0}}let{jsonString:t}=Mo(JSON.stringify(e.env),5e3);try{e.env=JSON.parse(t)}catch{e.env={}}return e}setCurrentUrl(e){this.env[fs]=e}reset(e){this.env={},this.varsFromMomenticEnvironment={},this.setEnvVariables(e.dynamicVariables??{}),this.setCurrentUrl(e.currentUrl),this.varsFromMomenticEnvironment=Ji(e.variablesFromEnvironment),this.setMomenticSystemVariable(We,e.baseUrl),e.envName&&this.setMomenticSystemVariable(No,e.envName),e.testName&&this.setMomenticSystemVariable(Yi,e.testName)}getDynamicVariablesCopy(){return Ji(this.env)}getVariablesFromEnvironmentCopy(){return Ji(this.varsFromMomenticEnvironment)}};import{z as Dr}from"zod";Ce(Dr);var ce=(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))(ce||{});var lh=["JobTimeoutError","UserConfigurationError","UserInfrastructureError"],Ss={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"},ko={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 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."},rd=Dr.object({reason:Dr.nativeEnum(ce),summary:Dr.string()}).openapi({ref:"TestResultClassification"}),ys=Dr.object({errorMessage:Dr.string(),errorStack:Dr.string().optional(),classification:rd.optional()}).openapi({ref:"TestFailureDetails"});Ce(J);var Re=(i=>(i.SUCCESS="SUCCESS",i.FAILED="FAILED",i.RUNNING="RUNNING",i.IDLE="IDLE",i.CANCELLED="CANCELLED",i))(Re||{}),od=(r=>(r.SUCCESS="SUCCESS",r.FAILED="FAILED",r.CANCELLED="CANCELLED",r))(od||{}),id=J.object({beforeUrl:J.string().optional(),afterUrl:J.string().optional(),message:J.string().optional(),beforeScreenshot:J.string().optional(),afterScreenshot:J.string().optional(),beforeSnapshot:J.string().optional(),afterSnapshot:J.string().optional(),startedAt:J.coerce.date(),finishedAt:J.coerce.date()}),DC=id.extend({viewport:J.object({height:J.number(),width:J.number()}),status:J.nativeEnum(od),message:J.string().optional(),elementInteracted:J.string().optional()}),ar=id.extend({status:J.nativeEnum(Re),message:J.string().optional(),data:J.unknown().optional(),beforeTestContext:Xi.optional(),afterTestContext:Xi.optional(),failureReason:J.nativeEnum(ce).optional(),details:J.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"}),bs=ar.merge(Pt).extend({results:DC.array(),proposedStep:Pt.optional()}),FC=ar.merge(Lr).extend({results:J.lazy(()=>bs.array())}),UC=ar.merge(Po).extend({results:J.lazy(()=>bs.array())}),BC=ar.merge(Bn).extend({moduleName:J.string().optional(),results:J.lazy(()=>Mt.array())}),zC=ar.merge(Or).extend({assertion:bs.optional(),results:J.lazy(()=>Mt.array()).describe("results for the block actually executed")}),HC=ar.merge(Wi).extend({results:J.lazy(()=>Mt.array())}),jC=ar.merge(Vi).extend({results:J.lazy(()=>Mt.array()),healingAttempts:J.lazy(()=>Mt.array().array()).optional()}),Mt=J.discriminatedUnion("type",[FC,UC,bs,BC,zC,HC,jC]),ws=ar.pick({startedAt:!0,finishedAt:!0,status:!0,message:!0,data:!0}),vs=id.extend({index:J.number().optional(),description:J.string(),pageState:J.string().optional()});var ad=$C.object({results:Mt.array().describe("main results"),beforeResults:Mt.array().optional(),afterResults:Mt.array().optional()}),Ts=ad.partial();import{z as $}from"zod";import{z as Ae}from"zod";var GC=Ae.object({type:Ae.literal("FAILURE_RECOVERY"),thoughts:Ae.string()}),WC=Ae.object({type:Ae.literal("DESCRIPTION_UPDATE"),thoughts:Ae.string()}),Es=Ae.discriminatedUnion("type",[WC,GC]),xs=(e=>(e.AUTO_HEALING="AUTO_HEALING",e))(xs||{}),VC=Ae.object({testId:Ae.string(),name:Ae.string(),orgId:Ae.string(),runId:Ae.string(),purpose:Ae.nativeEnum(xs).catch("AUTO_HEALING"),steps:Le.array(),details:Es.or(Es.array()).optional()}),gB=VC.pick({name:!0,orgId:!0}),sd=Ae.object({id:Ae.string(),name:Ae.string().nullish(),createdAt:Ae.string().pipe(Ae.coerce.date()).or(Ae.date()),organizationId:Ae.string(),schemaVersion:Ae.string(),purpose:Ae.nativeEnum(xs).catch("AUTO_HEALING"),runId:Ae.string().nullish(),details:Es.or(Es.array()).nullish(),applied:Ae.boolean().nullish(),appliedAt:Ae.coerce.date().nullish()}),ch=sd.extend({steps:Le.array()});import{isValidCron as qC}from"cron-validator";import{z as te}from"zod";import{z as ld}from"zod";var zn=(r=>(r.CHROMIUM="Chromium",r.GOOGLE_CHROME="Google Chrome",r.CHROME_FOR_TESTING="Chrome for Testing",r))(zn||{});var Cs=ld.object({width:ld.number().min(200).max(1e4),height:ld.number().min(200).max(1e4)}),dh={"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}},yB=Object.keys(dh);var qt=dh["Desktop Large"],_o="en-us",Do="America/Los_Angeles";var Fo={latitude:37.7749,longitude:-122.4194};var ph=["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 uh=2e3,Rs=kr.extend({browserType:te.nativeEnum(zn).optional(),slowMoMs:te.number().optional().refine(n=>n===void 0||n<=uh&&n>=-1,{message:`Slow motion must be between 0 and ${uh} milliseconds`}),basicAuthorization:te.object({username:te.string().optional(),password:te.string().optional()}).optional(),geolocation:te.object({latitude:te.coerce.number().refine(n=>n>=-90&&n<=90,{message:"Latitude must be between -90 and 90 degrees"}),longitude:te.coerce.number().refine(n=>n>=-180&&n<=180,{message:"Longitude must be between -180 and 180 degrees"})}).optional(),disableJavaScript:te.boolean().optional(),locale:te.string().optional(),timezone:te.enum(ph).optional(),colorScheme:te.enum(["light","dark"]).optional()}),mh=["extraHeaders","basicAuthorization","localChromeExtensionPaths"],cd=te.object({useMemory:te.boolean().optional(),failureRecovery:te.boolean().optional().describe("undefined means inherit org settings")}),KC=cd.extend({disableAICaching:te.boolean().optional()}),YC=te.object({viewport:Cs.optional()}),Fr=YC.merge(KC).merge(Rs),Uo=te.object({cron:te.string().refine(n=>qC(n),{message:"Invalid cron expression."}).default("0 0 */1 * *"),enabled:te.boolean().default(!1),env:te.string().optional(),timeZone:te.string().default("America/Los_Angeles"),jobKey:te.string().optional()}),Bo=te.object({onSuccess:te.boolean().default(!1),failureMessage:te.string().optional(),onFailure:te.boolean().default(!0),successMessage:te.string().optional()}),JC=te.object({name:te.string(),required:te.boolean().optional(),defaultValue:te.string().describe("this is not optional because we need a value when the editor is first loaded")}),As=JC.array(),XC=te.object({name:te.string(),value:te.string()}),hh=XC.array(),Is=te.object({name:te.string(),default:te.boolean().optional(),fixtures:oh.array().optional()});Ce($);var Kt={WEBHOOK:"WEBHOOK",CRON:"CRON",MANUAL:"MANUAL",CLI:"CLI"},ae=(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))(ae||{}),Ps=(t=>(t.BEFORE_ALL="BEFORE_ALL",t.AFTER_ALL="AFTER_ALL",t))(Ps||{});var Ve=$.string().pipe($.coerce.date()).or($.date()),Qi=$.object({id:$.string(),runKey:$.string(),organizationId:$.string(),createdAt:Ve,createdBy:$.string(),flake:$.boolean().nullish(),scheduledAt:Ve.or($.null()),startedAt:Ve.or($.null()),updatedAt:Ve.nullish(),finishedAt:Ve.or($.null()),resolvedBaseUrl:$.string().nullish(),environmentName:$.string().nullish(),labels:$.array($.string()).optional(),cliVersion:$.string().nullish(),section:$.nativeEnum(Ps).nullish(),status:$.nativeEnum(ae),trigger:$.nativeEnum(Kt),attempts:$.number(),runAttempts:$.array($.object({id:$.string(),status:$.nativeEnum(ae),startedAt:Ve.or($.null()),finishedAt:Ve.or($.null())})).optional(),videos:$.array($.string()).optional(),failureReason:$.nativeEnum(ce).nullish(),failureDetails:ys.nullish(),testFragments:$.array(sd).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"}),QC={id:!0,status:!0,testName:!0,localTestId:!0,testId:!0,test:{select:{name:!0,id:!0}},finishedAt:!0,failureReason:!0,failureDetails:!0},Ls=Qi.pick({...QC,test:!0}),gh=Qi.omit({failureReason:!0,failureDetails:!0,test:!0}),dd=Qi.extend({stepsSnapshot:$.array($.record($.unknown())).nullish(),resolvedInputs:$.record($.string(),$.string()).nullish(),test:$.object({name:$.string(),id:$.string(),description:$.string().nullish(),baseUrl:$.string().nullish(),advanced:Fr.nullish()}).nullish()}).merge(ad),fh=n=>n.includes("PASSED")&&n.includes("FAILED");var ZC=Zi.object({id:Zi.string().uuid(),startedAt:Ve.or(Zi.null()),finishedAt:Ve.or(Zi.null()),status:Zi.nativeEnum(ae)}).merge(Ts),zB=ZC.array();var Os=(o=>(o.JUNIT="junit",o.ALLURE="allure",o.ALLURE_JSON="allure-json",o.PLAYWRIGHT_JSON="playwright-json",o))(Os||{});import{z as Je}from"zod";var eR=Je.object({id:Je.string(),status:Je.nativeEnum(ae),trigger:Je.nativeEnum(Kt),createdAt:Ve,startedAt:Ve.nullish(),finishedAt:Ve.nullish(),gitCommitSha:Je.string().nullish(),gitCommitShaShort:Je.string().nullish(),gitCommitTimestamp:Ve.nullish(),gitBranchName:Je.string().nullish(),gitOriginUrl:Je.string().nullish(),gitCommitMessage:Je.string().nullish(),gitCommitAuthorName:Je.string().nullish(),githubRepository:Je.string().nullish(),gitlabProjectPath:Je.string().nullish(),pipelineId:Je.string().nullish(),cliVersion:Je.string().nullish(),suite:Je.object({id:Je.string(),name:Je.string()}).nullish(),runs:Je.object({status:Je.nativeEnum(ae)}).array()}).openapi({ref:"RunGroup"}),Sh=eR.pick({id:!0,createdAt:!0,startedAt:!0,finishedAt:!0,status:!0,trigger:!0,suite:!0}).extend({runs:Ls.array()});import{z as tt}from"zod";var tR=tt.object({type:tt.literal("TARGETING"),name:tt.string().optional().describe("Target name to disambiguate for steps with multiple targets"),elementLocationDecisions:Tm.array(),pageState:tt.string().optional(),targetSource:tt.nativeEnum(rr).optional(),targetUpdateTime:tt.string().optional()}),nR=tt.object({type:tt.literal("AI_LOCATION"),matched:tt.boolean(),pageState:tt.string().optional(),ragUsed:tt.boolean().optional(),thoughts:tt.string().optional()}),rR=tt.object({type:tt.literal("ASSERTION"),relevantElementsSerialized:tt.string().array().optional(),pageState:tt.string().optional(),ragUsed:tt.boolean().optional()}),yh=tt.discriminatedUnion("type",[tR,nR,rR]);function Ms(){return{details:[]}}import{z as Be}from"zod";var oR=Be.object({id:Be.string(),name:Be.string()}),e1=oR.merge(Be.object({createdAt:Ve,createdBy:Be.string(),schedule:Uo,notification:Bo,environment:Be.object({name:Be.string()}).nullish(),beforeTests:Be.object({id:Be.string()}).array().nullish(),afterTests:Be.object({id:Be.string()}).array().nullish()})),bh=Be.object({id:Be.string().uuid(),orgId:Be.string(),createdAt:Ve,startedAt:Ve.or(Be.null()),finishedAt:Ve.or(Be.null()),status:Be.nativeEnum(ae),trigger:Be.nativeEnum(Kt),suite:Be.object({id:Be.string(),name:Be.string()}).nullish(),runs:Qi.array()}),t1=bh.pick({id:!0,createdAt:!0,startedAt:!0,finishedAt:!0,status:!0,trigger:!0,suite:!0}),wh=bh.extend({runs:Ls.array()});import{z as Yt}from"zod";import{cloneDeep as i1}from"lodash-es";import{z as ue}from"zod";var d1=ue.object({thoughts:ue.string(),subGoals:ue.object({instruction:ue.string()}).array()}),p1=ue.object({thoughts:ue.string(),newPlanMarkdown:ue.string()}),u1=ue.object({thoughts:ue.string(),correct:ue.boolean(),failedActionIndex:ue.number().optional()}),iR=ue.object({type:ue.literal("PLANNING"),beforePlan:ue.string(),goalDecision:ue.string(),thoughts:ue.string()}),aR=ue.object({type:ue.literal("RUNNING"),stepDisplayName:ue.string(),status:ue.nativeEnum(Re),results:Mt.array()}),sR=ue.object({type:ue.literal("REVISING"),beforePlan:ue.string(),afterPlan:ue.string(),errString:ue.string(),diffs:ue.string(),thoughts:ue.string()}),lR=ue.object({type:ue.literal("SYSTEM"),message:ue.string()}),cR=ue.discriminatedUnion("type",[iR,aR,sR,lR]),vh=cR.array();var S1=Yt.object({id:Yt.string(),scheduledAt:Yt.coerce.date().nullable(),startedAt:Yt.coerce.date().nullable(),finishedAt:Yt.coerce.date().nullable(),status:Yt.nativeEnum(ae),history:vh.nullable(),testPlan:Yt.object({id:Yt.string(),name:Yt.string()}).nullable(),test:Yt.object({id:Yt.string(),name:Yt.string()}).nullable()});import{z as Et}from"zod";var pd=Et.object({content:Et.string(),ids:Et.string().array(),tokenLength:Et.number()}),dR=Et.object({chunks:pd.array()}),k1=Et.object({ids:Et.string().array(),score:Et.number(),tokenLength:Et.number()}),_1=dR.extend({description:Et.string().describe("Input to pass to RAG engine"),tokenLimit:Et.number()}),Th=Et.object({ids:Et.number().array()}),Eh=Et.object({indices:Et.number().array()});var Jt=N.object({disableCache:N.boolean().optional(),useMemory:N.boolean().optional(),loggerTags:N.record(N.string(),N.string()).optional(),langfuseSessionId:N.string().optional(),agentConfigVersion:N.string().optional()}),$1=Jt.extend({chunks:pd.array(),description:N.string().describe("Input to pass to AI"),type:N.union([N.literal("locator"),N.literal("assertion"),N.literal("ai-action")]),softTokenLimit:N.number(),hardTokenLimit:N.number()}),pR=N.object({screenshotBase64AfterCommand:N.string(),urlAfterCommand:N.string(),serializedCommand:N.string(),elementInteracted:N.string().optional(),thoughts:N.string().optional()}),xh=N.object({goal:N.string(),browserState:N.string(),screenshot:N.string(),source:as.optional().catch(void 0),memory:N.discriminatedUnion("type",[Ni,N.object({type:N.literal("RESOLVED_TRACES"),traces:N.unknown().array()})]).optional()}),Ch=N.object({target:N.string().or(N.number()),browserState:N.string().optional(),screenshot:N.string().optional(),boundingBox:N.object({x:N.number(),y:N.number(),height:N.number(),width:N.number()}).optional()}),Rh=N.object({goal:N.string(),browserState:N.string(),screenshot:N.string().optional(),returnSchema:N.string().optional()}),Ah=N.object({goal:N.string(),browserState:N.string(),screenshot:N.string(),url:N.string(),contextChoice:Pc.optional(),memory:N.discriminatedUnion("type",[Rc,N.object({type:N.literal("RESOLVED_TRACES"),traces:N.unknown().array()})]).optional()}),Ih=N.object({command:Ao}),ud=N.object({goal:N.string(),browserState:N.string(),startingScreenshot:N.string().optional(),screenshot:N.string(),url:N.string(),history:pR.array(),actionHint:N.string().optional(),lastError:N.string().optional()}),Ph=N.object({results:vs.array(),errorMessage:N.string(),errorStack:N.string().optional()}),Lh=N.object({results:vs.array(),goal:N.string(),errorMessage:N.string()}),Oh=N.object({failedResults:vs.array(),nextStepsSerialized:N.string().array(),currentUrl:N.string(),currentPageState:N.string(),currentScreenshot:N.string()}),G1=N.object({description:N.string(),type:N.union([N.literal("locator"),N.literal("assertion"),N.literal("ai-action")]),excerpt:N.string()});import{z as ea}from"zod";var q1=ea.object({goal:ea.string()}),Mh=ea.object({keywords:ea.array(ea.string())});import{z as md}from"zod";var hd=(t=>(t.LOCATOR="locator",t.ASSERTION="assertion",t))(hd||{}),J1=md.nativeEnum(hd),uR=md.enum(["v1","v2"]),X1=uR.or(md.string().describe("for people with special configurations"));var Nh=n=>!(!n.org_id||!n.user_id||!n.platform);import{z as Ur}from"zod";var kh=Ur.object({id:Ur.string().uuid(),skipped:Ur.boolean().optional(),envKey:Ur.string().optional().describe("key in the environment to save the result of this step to")}),gd=kh.merge(Qa).extend({type:Ur.literal("REQUEST")}),fd=kh.merge(Za).extend({type:Ur.literal("JAVASCRIPT")}),Sd=Ur.discriminatedUnion("type",[fd,gd]);import{z as Xt}from"zod";import{z as Br}from"zod";var mR=/^[a-f0-9]{8}-[a-f0-9]{4}-[1-5][a-f0-9]{3}-[89ab][a-f0-9]{3}-[a-f0-9]{12}$/,Ie=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 Ns=Br.string().min(1).max(255).superRefine((n,e)=>{try{zr(n)}catch(t){return e.addIssue({code:Br.ZodIssueCode.custom,message:t.message,fatal:!0}),Br.NEVER}});function zr(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(mR))throw new Error("Name cannot be a UUID. Please choose a different name.")}var ks=Br.preprocess(n=>n===null?"":n,Br.union([Br.string().url(),Br.literal("")])).optional();var _h=Xt.object({id:Xt.string(),name:Ns,description:Xt.string().optional().nullish(),baseUrl:ks.nullish(),schemaVersion:Xt.string(),advanced:Xt.unknown().optional(),retries:Xt.number(),envs:Xt.array(Is).nullish(),parameters:As.nullish()}),hR=Xt.object({createdAt:Xt.coerce.date(),updatedAt:Xt.coerce.date(),schedule:Uo.nullish(),notification:Bo.nullish(),createdBy:Xt.string(),organizationId:Xt.string()}),gR=_h.merge(hR),wz=gR.extend({steps:Sd.array()}),vz=_h.extend({steps:Sd.array()});import{z as Nt}from"zod";var Dh=Nt.object({startedAt:Nt.coerce.date(),finishedAt:Nt.coerce.date(),status:Nt.nativeEnum(Re),message:Nt.string().optional(),data:Nt.unknown().optional()}),SR=Dh.merge(fd).extend({type:Nt.literal("JAVASCRIPT")}),yR=Dh.merge(gd).extend({type:Nt.literal("REQUEST")}),bR=Nt.discriminatedUnion("type",[SR,yR]),Fh=Nt.object({startedAt:Nt.coerce.date(),finishedAt:Nt.coerce.date().nullish(),status:Nt.nativeEnum(ae),results:bR.array(),failureReason:Nt.string().nullish(),failureDetails:ys.nullish()});import{z as kt}from"zod";var wR=kt.object({id:kt.string(),organizationId:kt.string(),createdAt:kt.coerce.date(),updatedAt:kt.coerce.date(),createdBy:kt.string(),scheduledAt:kt.coerce.date().nullish(),startedAt:kt.coerce.date().nullish(),finishedAt:kt.coerce.date().nullish(),status:kt.nativeEnum(ae),trigger:kt.nativeEnum(Kt),results:Fh.array().nullish(),apiTestName:kt.string().nullish(),apiTestPath:kt.string().nullish(),apiTestId:kt.string().nullish()}),Lz=wR.pick({status:!0,startedAt:!0,finishedAt:!0});var ta=(t=>(t.TestRun="test-run",t.CreditsUsed="credits-used",t))(ta||{}),Uh=3;function vR(n){return n==="MODULE"||n==="IFRAME"||n==="CONDITIONAL"||n==="SECTION"||n==="RESOLVED_MODULE"}function na(n){if(!vR(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 ra(n){switch(n.type){case"AI_EXTRACT":case"AI_ASSERTION":return Uh;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"KEY_DOWN":case"KEY_UP":case"COPY":case"PASTE":case"REFRESH":case"REQUEST":case"GRAPHQL_REQUEST":case"WAIT_FOR_URL":case"REGISTER_REQUEST_LISTENER":case"AWAIT_LISTENER":case"RECORD_REQUESTS":case"GET_RECORDED_REQUESTS":case"SET_HEADER":return 0;default:(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}var zo=class{async reportBillableEvent(e,t,r){}async reportCreditsUsed(e,t,r,o){}};function yd(n,e){return{...n,testId:e?.testId??"",testName:e?.testName??"",suiteId:e?.suiteId??"",suiteName:e?.suiteName??""}}import{parseString as TR,splitCookiesString as ER}from"set-cookie-parser";import{z as ge}from"zod";var bd=ge.object({name:ge.string(),value:ge.string(),url:ge.string().optional(),domain:ge.string().optional(),path:ge.string().optional(),expires:ge.number().default(Date.now()/1e3+60*60*24*365),httpOnly:ge.boolean().optional(),secure:ge.boolean().default(!0),sameSite:ge.union([ge.literal("Strict"),ge.literal("Lax"),ge.literal("None")]).default("None")});function _s(n,e){let t=[],r=ER(n);for(let o of r){let i=TR(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=bd.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,u]=d.split("=");if(!p||!u)throw new Error(`Invalid key-value pair in cookie: ${d}`);l.includes(p.toLowerCase())||t.push({...s,name:p,value:u})}}return t}var xR=ge.object({origin:ge.string(),localStorage:ge.array(ge.object({name:ge.string(),value:ge.string()}))}),CR=ge.object({entries:ge.record(ge.string(),ge.array(ge.tuple([ge.unknown(),ge.unknown()]))),version:ge.number().optional()}),Ds=ge.object({cookies:bd.array().optional(),origins:xR.array().optional(),idb:ge.record(ge.string(),CR).optional().describe("key is db name")});function Fs(n,e){let t=[];return n.cloneSync()?.serializeSync()?.cookies.forEach(r=>{let o=bd.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 Qz=new Set(Object.values(Ue));var RR={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",KEY_DOWN:"Key down",KEY_UP:"Key up",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:"localStorage",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",RECORD_REQUESTS:"Record requests",GET_RECORDED_REQUESTS:"Get recorded requests",SET_HEADER:"Set header",SUCCESS:"Done"},Zz={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"],KEY_DOWN:["keyboard","type","key","down","press"],KEY_UP:["keyboard","type","key","up","press"],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:[],RECORD_REQUESTS:[],GET_RECORDED_REQUESTS:[],SET_HEADER:[],SUCCESS:[]},eH={AI_ACTION:"Ask AI achieve a specific goal. Saves the steps for reuse. Please use Dynamic AI action instead.",AI_ACTION_DYNAMIC:"Ask AI achieve a specific goal. Fully dynamic and does not save the steps for reuse. Our most capable AI agent.",RESOLVED_MODULE:"A list of steps that can be reused in multiple tests.",AI_ASSERTION:"Ask AI to verify whether something is true on the page.",CLICK:"Click on an element on the page.",DIALOG:"Specify how native browser dialogs should be handled.",AI_EXTRACT:"Ask AI to extract data from the page.",HOVER:"Hover over an element on the page.",FILE_UPLOAD:"Automatically upload a file when the native file upload dialog is activated.",FOCUS:"Focus an element on the page.",BLUR:"Remove focus from an element on the page.",SELECT_OPTION:"Select an option from an HTML Select <select> element.",TYPE:"Type the specified text into an element.",PRESS:"Press the specified keys using the keyboard. (e.g. Control+A)",KEY_DOWN:"Hold down the specified keys on the keyboard. (e.g. Control+A)",KEY_UP:"Release the specified keys on 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 localStorage 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 in the browser or a Node.js environment.",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 JavaScript object including cookies, localStorage, and IndexDB entries.",AUTH_SAVE:"Save authentication state (cookies, localStorage) into a JavaScript object.",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 contents using pre-built conditions.",WAIT_FOR_URL:"Wait for the active page's URL to match a target value or pattern.",COPY:"Copy the specified value to the browser clipboard.",PASTE:"Paste the browser clipboard contents.",REGISTER_REQUEST_LISTENER:"Register a listener for network requests.",AWAIT_LISTENER:"Wait for a listener to fire, and return the response data.",RECORD_REQUESTS:"Record network requests that match a given pattern.",GET_RECORDED_REQUESTS:"Get recorded requests that matched the pattern.",SET_HEADER:"Set a header.",SUCCESS:"Indicate the entire AI action has succeeded, optionally based on a condition."};import{Faker as rH,en as oH}from"@faker-js/faker";import{z as G}from"zod";var Bh=55555,lH=G.object({body:G.string(),to:G.string(),from:G.string()}),cH=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()}),dH=G.object({to:G.string(),from:G.string(),subject:G.string(),body:G.string()}),pH=G.object({inbox:G.string(),afterDate:G.string().pipe(G.coerce.date()).or(G.date()).optional(),timeout:G.number().optional(),trimWhitespace:G.boolean().optional()}),uH=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 zh=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()}),mH=G.object({id:G.string().optional(),orgId:G.string(),momenticLambdaAuthHash:G.string(),code:G.string(),fragment:G.boolean(),state:Xi,timeoutMs:G.number().optional()}),sr=15e3;import*as mt from"zod";Ce(mt);var AR=mt.object({url:mt.string(),lineNumber:mt.number(),columnNumber:mt.number()}).openapi({ref:"CodeLocation"}),Us=mt.object({timestamp:mt.number(),text:mt.string(),type:mt.string(),tabIndex:mt.number(),args:mt.unknown().array().optional(),url:mt.string().optional(),location:AR.optional()}).openapi({ref:"ConsoleLog"}),Hh=Us.array(),IR=Hh.array();import*as vd from"zod";import{z as I}from"zod";var PR=I.object({name:I.string(),version:I.string(),comment:I.string().optional()}),LR=I.object({name:I.string(),version:I.string(),comment:I.string().optional()}),OR=I.object({onContentLoad:I.number().optional(),onLoad:I.number().optional(),comment:I.string().optional()}),$h=I.object({startedDateTime:I.string(),id:I.string(),title:I.string().optional(),pageTimings:OR,comment:I.string().optional()}),MR=I.array($h),NR=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()}),Gh=I.array(NR),kR=I.object({name:I.string(),value:I.string(),comment:I.string().optional()}),Wh=I.array(kR),_R=I.object({name:I.string(),value:I.string(),comment:I.string().optional()}),DR=I.array(_R),FR=I.object({name:I.string(),value:I.string().optional(),fileName:I.string().optional(),contentType:I.string().optional(),comment:I.string().optional()}),UR=I.array(FR),BR=I.object({mimeType:I.string(),params:UR,text:I.string(),comment:I.string().optional()}),zR=I.object({method:I.string(),url:I.string(),httpVersion:I.string().optional(),cookies:Gh,headers:Wh,queryString:DR,postData:BR.optional(),headersSize:I.number().optional(),bodySize:I.number().optional(),comment:I.string().optional()}),HR=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()}),jR=I.object({status:I.number(),statusText:I.string(),httpVersion:I.string().optional(),cookies:Gh,headers:Wh,content:HR,redirectURL:I.string().optional(),headersSize:I.number().optional(),bodySize:I.number().optional(),comment:I.string().optional()}),jh=I.object({expires:I.string().optional(),lastAccess:I.string(),eTag:I.string(),hitCount:I.number(),comment:I.string().optional()}),$R=I.object({beforeRequest:jh.optional(),afterRequest:jh.optional(),comment:I.string().optional()}),GR=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()}),Vh=I.object({pageref:I.string().optional(),startedDateTime:I.string(),time:I.number().optional(),request:zR,response:jR.optional(),cache:$R.optional(),timings:GR,serverIPAddress:I.string().optional(),connection:I.string().optional(),comment:I.string().optional(),_resourceType:I.string().optional()}),WR=I.array(Vh),VR=I.object({version:I.string().default("1.1"),creator:PR.optional(),browser:LR.optional(),pages:MR.optional(),entries:WR,comment:I.string().optional()}),qR=I.object({log:VR}),qh=I.record(I.string(),$h),Kh=I.record(I.string(),Vh);function wd(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())}}}Ce(vd);var KR=vd.object({logsPerPage:Us.array().array(),harPages:qh.optional(),harEntries:Kh.optional()}).openapi({ref:"DebugData"});var Hr=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 Yh(n){for(let e of Object.values(ce))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(ce))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}}},Hn=class extends Error{decisions;constructor(e,t,r={}){super(e,r),this.decisions=t,this.name="NoElementsFoundError"}toString(){return`${this.message}
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]="79926f15-e6af-58e9-89ff-23dbe00e65ff")}catch(e){}}();
4
+ var QE=Object.create;var em=Object.defineProperty;var eT=Object.getOwnPropertyDescriptor;var tT=Object.getOwnPropertyNames;var nT=Object.getPrototypeOf,rT=Object.prototype.hasOwnProperty;var tm=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports);var oT=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of tT(e))!rT.call(n,o)&&o!==t&&em(n,o,{get:()=>e[o],enumerable:!(r=eT(e,o))||r.enumerable});return n};var iT=(n,e,t)=>(t=n!=null?QE(nT(n)):{},oT(e||!n||!n.__esModule?em(t,"default",{value:n,enumerable:!0}):t,n));var gS=tm(($3,hS)=>{"use strict";hS.exports=uS;function uS(n,e,t){n instanceof RegExp&&(n=pS(n,t)),e instanceof RegExp&&(e=pS(e,t));var r=mS(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 pS(n,e){var t=e.match(n);return t?t[0]:null}uS.range=mS;function mS(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 TS=tm((G3,ES)=>{"use strict";var fS=gS();ES.exports=nI;var SS="\0SLASH"+Math.random()+"\0",yS="\0OPEN"+Math.random()+"\0",$d="\0CLOSE"+Math.random()+"\0",bS="\0COMMA"+Math.random()+"\0",wS="\0PERIOD"+Math.random()+"\0";function jd(n){return parseInt(n,10)==n?parseInt(n,10):n.charCodeAt(0)}function eI(n){return n.split("\\\\").join(SS).split("\\{").join(yS).split("\\}").join($d).split("\\,").join(bS).split("\\.").join(wS)}function tI(n){return n.split(SS).join("\\").split(yS).join("{").split($d).join("}").split(bS).join(",").split(wS).join(".")}function vS(n){if(!n)return[""];var e=[],t=fS("{","}",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=vS(i);return i.length&&(a[a.length-1]+=s.shift(),a.push.apply(a,s)),e.push.apply(e,a),e}function nI(n){return n?(n.substr(0,2)==="{}"&&(n="\\{\\}"+n.substr(2)),fa(eI(n),!0).map(tI)):[]}function rI(n){return"{"+n+"}"}function oI(n){return/^-?0\d/.test(n)}function iI(n,e){return n<=e}function aI(n,e){return n>=e}function fa(n,e){var t=[],r=fS("{","}",n);if(!r)return[n];var o=r.pre,i=r.post.length?fa(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+$d+r.post,fa(n)):[n];var u;if(d)u=r.body.split(/\.\./);else if(u=vS(r.body),u.length===1&&(u=fa(u[0],!1).map(rI),u.length===1))return i.map(function(j){return r.pre+u[0]+j});var m;if(d){var h=jd(u[0]),g=jd(u[1]),f=Math.max(u[0].length,u[1].length),S=u.length==3?Math.abs(jd(u[2])):1,w=iI,E=g<h;E&&(S*=-1,w=aI);var y=u.some(oI);m=[];for(var x=h;w(x,g);x+=S){var T;if(c)T=String.fromCharCode(x),T==="\\"&&(T="");else if(T=String(x),y){var A=f-T.length;if(A>0){var D=new Array(A+1).join("0");x<0?T="-"+D+T.slice(1):T=D+T}}m.push(T)}}else{m=[];for(var L=0;L<u.length;L++)m.push.apply(m,fa(u[L],!1))}for(var L=0;L<m.length;L++)for(var a=0;a<i.length;a++){var s=o+m[L]+i[a];(!e||d||s)&&t.push(s)}}return t}});var Mi=(n,e)=>{},xc=!1;try{let n=await import("@sentry/node");Mi=n.captureException,n.init({dsn:"https://89e980855f7b9c6e56fc6c7e7143888b@o4506426201800704.ingest.us.sentry.io/4508343221354497",environment:"production",release:process.env.SENTRY_RELEASE_NAME,tracesSampleRate:0}),xc=!0}catch{}import{Command as L_,Option as Bt}from"@commander-js/extra-typings";import{execSync as O_}from"child_process";import Ov from"body-parser";import uk from"cors";import mk from"dedent";import hk from"events";import Mv,{Router as gk}from"express";import{diff as XA}from"deep-object-diff";import un from"fs";import Qr from"path";import{diff as TA}from"deep-object-diff";import{z as nm}from"zod";var $_=nm.object({input:nm.string()});import{z as Ye}from"zod";var V_=Ye.object({srcs:Ye.array(Ye.string()),urls:Ye.array(Ye.string()),desiredSrc:Ye.string().optional(),desiredUrl:Ye.string().optional()}),rm=Ye.object({srcRegex:Ye.string().optional(),urlRegex:Ye.string().optional()}),om=Ye.object({x:Ye.number(),y:Ye.number(),correlation:Ye.number()}),q_=Ye.object({searchImageBase64String:Ye.string(),pageImageBase64String:Ye.string(),id:Ye.string().uuid(),timeoutMs:Ye.number().max(1e4).min(0).optional()});import{z as _}from"zod";import*as U from"zod";function Ce(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}}Ce(U);var or=(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))(or||{}),aT=U.object({mPathSelectorTokens:U.string().array(),frameSrcRegex:U.string().optional(),frameUrlRegex:U.string().optional(),indices:U.number().array()}),Cc=U.object({result:U.number(),traceId:U.string()}).array(),Ni=U.object({type:U.literal("GCS_TRACES"),traces:Cc}),Ir=U.object({id:U.number().int(),dataMomenticId:U.number().int().optional(),selector:U.string().optional(),hybridSelector:U.object({textContent:U.string().nullish(),attributes:U.record(U.string(),U.string()),tagName:U.string(),expandShadowRoot:U.boolean().optional(),classNames:U.string().array(),nthChild:U.number()}).array().optional(),generatedSelectors:U.string().array().optional(),role:U.string().optional(),name:U.string().optional(),numChildren:U.number().optional(),content:U.string().optional(),pathFromRoot:U.string().optional(),serializedForm:U.string().optional(),nodeOnlySerializedForm:U.string().optional(),serializedHtml:U.string().optional().describe("pruned html including 1 neighbor and 1 layer of children. value for text inputs pruned."),nodeOnlySerializedHtml:U.string().optional().describe("outerHtml of the element without any children. value for text inputs pruned."),screenshotUrl:U.string().url().optional(),boundingBox:U.object({x:U.number().optional(),y:U.number().optional(),width:U.number(),height:U.number()}).describe("css pixel bounding box").optional(),frameCache:aT.optional(),inputDescription:U.string().optional().describe("the description that generated this cache"),targetSource:U.nativeEnum(or).optional(),targetUpdateTime:U.string().optional(),targetUpdateLoggerTags:U.record(U.string(),U.string()).optional(),memory:Ni.optional()}).openapi({ref:"ElementTargetCache"});function im(n){return!!(n.name||n.role||n.content||n.serializedForm||n.serializedHtml||n.screenshotUrl)}var sT=U.object({type:U.literal("description"),elementDescriptor:U.string(),a11yData:Ir.optional().describe("DEPRECATED: new a11y cache is stored in DB and resolved into the 'cache' field")}).openapi({ref:"DescriptionTarget"}),lT=U.object({x:U.number(),y:U.number()}),cT=U.object({type:U.literal("coordinates"),pixels:lT}).openapi({ref:"CoordinatesTarget"});function ir(n){return n.type==="description"}function Tn(n){return n.type==="coordinates"}var pt=U.discriminatedUnion("type",[sT,cT]).openapi({ref:"ElementTarget"});function Rc(n){if(!n)return!1;switch(n.type){case"description":return!!n.elementDescriptor}return!0}function ut(n){if(!n)return"";switch(n.type){case"description":return n.elementDescriptor;case"coordinates":return`x: ${n.pixels.x}, y: ${n.pixels.y}`}}import{v4 as be}from"uuid";import*as v from"zod";import{z as Se}from"zod";import{z as wo}from"zod";var Ac=wo.object({result:wo.boolean(),traceId:wo.string()}).array(),Ic=wo.object({type:wo.literal("GCS_TRACES"),traces:Ac}),am=wo.object({memory:Ic.optional()});var Xa=class{async resolveStepCacheEntries(){}async saveStepCacheEntries(){}};Ce(Se);var sm=Se.object({plan:Se.string().optional(),evidence:Se.string().optional(),thoughts:Se.string(),result:Se.boolean(),relevantElements:Se.array(Se.number()).optional(),updatedMemory:Ac.optional()}),vo=(o=>(o.CONTAINS="CONTAINS",o.STARTS_WITH="STARTS_WITH",o.EQUALS="EQUALS",o.EXISTS="EXISTS",o))(vo||{});var dT=Se.object({type:Se.literal("ELEMENT_CONTENT"),negated:Se.boolean().optional(),operation:Se.nativeEnum(vo),value:Se.string()}).openapi({ref:"ElementContentAssertion"}),pT=Se.object({type:Se.literal("ELEMENT_ATTRIBUTE"),negated:Se.boolean().optional(),operation:Se.nativeEnum(vo),attr:Se.string(),value:Se.string()}).openapi({ref:"ElementAttributeValueAssertion"}),Eo=(o=>(o.EXISTS="EXISTS",o.VISIBLE="VISIBLE",o.ENABLED="ENABLED",o.EDITABLE="EDITABLE",o))(Eo||{}),uT=Se.object({type:Se.literal("ELEMENT_EXISTENCE"),negated:Se.boolean().optional(),condition:Se.nativeEnum(Eo).describe("Treated as the element exists AND is also ...")}).openapi({ref:"ElementExistenceAssertion"}),lm=Se.discriminatedUnion("type",[dT,pT,uT]).openapi({ref:"ManualElementAssertion"});var mT=Se.object({type:Se.literal("CONTENT"),negated:Se.boolean().optional(),value:Se.string()}).openapi({ref:"PageContentAssertion"}),cm=Se.discriminatedUnion("type",[mT]).openapi({ref:"ManualPageAssertion"});import{z as ce}from"zod";var Za=ce.object({url:ce.string(),method:ce.union([ce.literal("GET"),ce.literal("POST"),ce.literal("PUT"),ce.literal("DELETE"),ce.literal("PATCH")]),headers:ce.record(ce.string(),ce.string()).optional(),params:ce.record(ce.string(),ce.string()).optional(),body:ce.string().optional(),timeout:ce.number().int().optional().describe("Max seconds to wait for the request to complete")}),dm=ce.object({url:ce.string(),headers:ce.record(ce.string(),ce.string()).optional(),query:ce.string(),variables:ce.record(ce.string(),ce.string()).optional(),timeout:ce.number().int().optional().describe("Max seconds to wait for the request to complete")}),Qa=ce.object({code:ce.string(),fragment:ce.boolean().optional(),environment:ce.union([ce.literal("NODE"),ce.literal("BROWSER")]).optional().describe("default NODE"),timeout:ce.number().int().max(60).optional().describe("Max seconds for the code to complete")});var Ue=(H=>(H.AI_EXTRACT="AI_EXTRACT",H.AI_ASSERTION="AI_ASSERTION",H.AUTH_LOAD="AUTH_LOAD",H.AUTH_SAVE="AUTH_SAVE",H.BLUR="BLUR",H.CAPTCHA="CAPTCHA",H.CLICK="CLICK",H.COOKIE="COOKIE",H.COPY="COPY",H.DIALOG="DIALOG",H.DRAG="DRAG",H.ELEMENT_CHECK="ELEMENT_CHECK",H.FILE_UPLOAD="FILE_UPLOAD",H.FOCUS="FOCUS",H.GO_BACK="GO_BACK",H.GO_FORWARD="GO_FORWARD",H.HOVER="HOVER",H.JAVASCRIPT="JAVASCRIPT",H.LOCAL_STORAGE="LOCAL_STORAGE",H.MOUSE_DRAG="MOUSE_DRAG",H.NAVIGATE="NAVIGATE",H.NEW_TAB="NEW_TAB",H.PAGE_CHECK="PAGE_CHECK",H.PASTE="PASTE",H.PRESS="PRESS",H.KEY_DOWN="KEY_DOWN",H.KEY_UP="KEY_UP",H.REFRESH="REFRESH",H.REQUEST="REQUEST",H.GRAPHQL_REQUEST="GRAPHQL_REQUEST",H.SCROLL_DOWN="SCROLL_DOWN",H.SCROLL_UP="SCROLL_UP",H.SCROLL_LEFT="SCROLL_LEFT",H.SCROLL_RIGHT="SCROLL_RIGHT",H.SELECT_OPTION="SELECT_OPTION",H.SWITCH_TAB="TAB",H.TYPE="TYPE",H.VISUAL_DIFF="VISUAL_DIFF",H.WAIT="WAIT",H.WAIT_FOR_URL="WAIT_FOR_URL",H.REGISTER_REQUEST_LISTENER="REGISTER_REQUEST_LISTENER",H.AWAIT_LISTENER="AWAIT_LISTENER",H.RECORD_REQUESTS="RECORD_REQUESTS",H.GET_RECORDED_REQUESTS="GET_RECORDED_REQUESTS",H.SET_HEADER="SET_HEADER",H.SUCCESS="SUCCESS",H))(Ue||{});Ce(v);var W=v.object({thoughts:v.string().optional(),id:v.string().uuid().describe("unique identifier to this step, used for step cache")}),Gt=v.object({useSelector:v.boolean().optional(),force:v.boolean().optional(),disableCache:v.boolean().optional().describe("disable element caching for this step"),iframeUrl:v.string().optional().describe("url or url regex for the iframe")}).openapi({ref:"CommonTargetingOptions"}),xn=v.object({target:Ir}).optional().openapi({ref:"SingleTargetCache"}),es=v.object({loadTimeout:v.number().int().max(60).optional().describe("Max seconds for the page to load")}),hT=W.merge(es).merge(v.object({type:v.literal("NAVIGATE"),url:v.string()})).openapi({ref:"NavigateCommand"}),ts=Gt.merge(v.object({cache:xn})),To=W.merge(ts.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_UP"),deltaY:v.number().optional()}))).openapi({ref:"ScrollUpCommand"}),xo=W.merge(ts.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_DOWN"),deltaY:v.number().optional()}))).openapi({ref:"ScrollDownCommand"}),Co=W.merge(ts.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_LEFT"),deltaX:v.number().optional()}))).openapi({ref:"ScrollLeftCommand"}),Ro=W.merge(ts.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_RIGHT"),deltaX:v.number().optional()}))).openapi({ref:"ScrollRightCommand"}),wD=v.discriminatedUnion("type",[To,xo,Co,Ro]).openapi({ref:"AllScrollCommands"}),gT=W.merge(v.object({type:v.literal("DIALOG"),action:v.union([v.literal("ACCEPT"),v.literal("DISMISS")])})).openapi({ref:"DialogCommand"}),fT=W.merge(v.object({type:v.literal("WAIT"),delay:v.number()})).openapi({ref:"WaitCommand"}),ST=v.discriminatedUnion("type",[v.object({type:v.literal("SUBSTRING"),url:v.string()}),v.object({type:v.literal("GLOB"),glob:v.string()}),v.object({type:v.literal("REGEX"),regex:v.string()})]),yT=v.object({caseInsensitive:v.boolean().optional().describe("Whether to ignore case when matching the URL"),negated:v.boolean().optional().describe("Wait for the URL to NOT match the provided matcher instead."),timeout:v.number().int().optional().describe("Max seconds to wait for the URL to match")}),bT=W.extend({type:v.literal("WAIT_FOR_URL"),matcher:ST}).merge(yT).openapi({ref:"WaitUrlCommand"}),wT=W.merge(es).merge(v.object({type:v.literal("REFRESH")})).openapi({ref:"RefreshCommand"}),vT=W.merge(v.object({type:v.literal("GO_BACK")})).openapi({ref:"GoBackCommand"}),ET=W.merge(v.object({type:v.literal("GO_FORWARD")})).openapi({ref:"GoForwardCommand"}),TT=W.extend({type:v.literal("AUTH_SAVE")}).openapi({ref:"AuthSaveCommand"}),xT=W.extend({type:v.literal("AUTH_LOAD"),storageState:v.string().describe("JSON string auth state. Leave blank or set to the empty string to clear all existing authentication.")}).openapi({ref:"AuthLoadCommand"}),Lc=W.merge(Gt).extend({type:v.literal("CAPTCHA")}).openapi({ref:"CaptchaCommand"}),CT=W.extend({type:v.literal("COPY"),value:v.string()}).openapi({ref:"CopyCommand"}),RT=W.extend({type:v.literal("PASTE")}).openapi({ref:"PasteCommand"}),AT=W.merge(Qa).extend({type:v.literal("JAVASCRIPT")}).openapi({ref:"JavaScriptCommand"}),_i=W.merge(Gt).extend({type:v.literal("CLICK"),target:pt,doubleClick:v.boolean().optional(),rightClick:v.boolean().optional(),waitForDownload:v.boolean().optional().describe("Wait for the click to trigger a file download and for the file download to complete."),delayMs:v.number().optional(),downloadTimeoutMs:v.number().optional(),cache:xn,relativePosition:v.object({x:v.number(),y:v.number()}).optional()}).openapi({ref:"ClickCommand"}),Di=W.merge(Gt).merge(v.object({type:v.literal("DRAG"),fromTarget:pt,toTarget:pt,steps:v.number().optional(),hoverSeconds:v.number().optional().describe("Seconds to hover the object before dropping"),cache:v.object({fromTarget:Ir.optional(),toTarget:Ir.optional()}).optional()})).openapi({ref:"DragCommand"}),Fi=W.merge(Gt).merge(v.object({type:v.literal("MOUSE_DRAG"),target:pt.optional(),deltaX:v.string().describe("pixels to move horizontally, can be template"),deltaY:v.string().describe("pixels to move vertically, can be template"),steps:v.number().optional(),cache:xn})).openapi({ref:"MouseDragCommand"}),Ui=W.merge(Gt).merge(v.object({type:v.literal("HOVER"),target:pt,cache:xn})).openapi({ref:"HoverCommand"}),Bi=W.merge(Gt).merge(v.object({type:v.literal("FOCUS"),target:pt,cache:xn})).openapi({ref:"FocusCommand"}),zi=W.merge(Gt).extend({type:v.literal("BLUR"),target:pt.optional(),cache:xn}).openapi({ref:"BlurCommand"}),IT=v.object({type:v.literal("URL"),url:v.string()}).describe("Accessible link to the file, either public http or local file://").openapi({ref:"UrlSource"}),PT=v.object({type:v.literal("USER_FILE"),name:v.string()}).describe("Accessible link to the file, references the google cloud file").openapi({ref:"UploadedFileSource"}),LT=W.extend({type:v.literal("FILE_UPLOAD"),fileSource:v.discriminatedUnion("type",[IT,PT]),filename:v.string().optional()}).openapi({ref:"FileUploadCommand"}),OT=v.discriminatedUnion("type",[v.object({type:v.literal("VALUE"),value:v.string()}),v.object({type:v.literal("LABEL"),label:v.string()}),v.object({type:v.literal("INDEX"),index:v.coerce.string()})]),Hi=W.merge(Gt).extend({type:v.literal("SELECT_OPTION"),target:pt,cache:xn,choice:OT.describe("new field for selecting options, optional for backcompat")}).openapi({ref:"SelectOptionCommand"}),Oc=v.union([v.literal("MULTIMODAL"),v.literal("VISION_ONLY")]),ns=W.merge(v.object({type:v.literal("AI_ASSERTION"),assertion:v.string(),disableCache:v.boolean().optional(),iframeUrl:v.string().optional(),contextChoice:Oc.optional(),timeout:v.number().int().optional().describe("Max seconds to wait for assertion to be true"),cache:am.optional()})).openapi({ref:"AIAssertionCommand"}),Cn=5,Mc=600,ji=W.merge(Gt).extend({type:v.literal("ELEMENT_CHECK"),target:pt,assertion:lm,cache:xn,timeout:v.number().int().min(0).max(Mc).optional().describe("max seconds to wait for the assertion to be true")}).openapi({ref:"ElementAssertionCommand"}),MT=W.extend({type:v.literal("PAGE_CHECK"),assertion:cm,iframeUrl:v.string().optional().describe("url or url regex for the iframe"),timeout:v.number().int().min(0).max(Mc).optional().describe("max seconds to wait for the assertion to be true")}).openapi({ref:"PageAssertionCommand"}),NT=W.merge(v.object({type:v.literal("AI_EXTRACT"),goal:v.string(),schema:v.string().optional(),envKey:v.string().optional(),disableCache:v.boolean().optional(),iframeUrl:v.string().optional()})).openapi({ref:"AIExtractCommand"}),kT=v.object({clearContent:v.boolean().optional(),forceClearContent:v.boolean().optional(),delay:v.number().min(0).max(1e3).optional().describe("Delay between each press in milliseconds."),force:v.boolean().optional(),pressEnter:v.boolean().optional()}),pm=25,$i=W.merge(Gt).merge(kT).extend({type:v.literal("TYPE"),target:pt.optional(),value:v.string(),cache:xn}).openapi({ref:"TypeCommand"}),_T=W.merge(v.object({type:v.literal("PRESS"),value:v.string(),repeat:v.number().optional(),convertMeta:v.boolean().optional(),delayMs:v.number().optional()})).openapi({ref:"PressCommand"}),DT=W.merge(v.object({type:v.literal("KEY_DOWN"),value:v.string(),convertMeta:v.boolean().optional()})).openapi({ref:"KeyDownCommand"}),FT=W.merge(v.object({type:v.literal("KEY_UP"),value:v.string(),convertMeta:v.boolean().optional()})).openapi({ref:"KeyUpCommand"}),UT=v.object({type:v.literal("SUBSTRING"),substring:v.string()}),BT=v.object({type:v.literal("REGEX"),pattern:v.string()}),zT=v.object({type:v.literal("INDEX"),index:v.coerce.string()}),HT=v.discriminatedUnion("type",[UT,BT,zT]),jT=W.merge(es).merge(v.object({type:v.literal("TAB"),action:HT})).openapi({ref:"TabCommand"}),$T=W.merge(es).merge(v.object({type:v.literal("NEW_TAB"),url:v.string()})).openapi({ref:"NewTabCommand"}),GT=W.merge(v.object({type:v.literal("COOKIE"),value:v.string()})).openapi({ref:"CookieCommand"}),WT=W.merge(v.object({type:v.literal("LOCAL_STORAGE"),key:v.string(),value:v.string()})).openapi({ref:"LocalStorageCommand"}),VT=W.extend({type:v.literal("REQUEST")}).merge(Za).openapi({ref:"RequestCommand"}),qT=W.extend({type:v.literal("GRAPHQL_REQUEST")}).merge(dm).openapi({ref:"GraphQLRequestCommand"}),KT=W.merge(v.object({type:v.literal("SUCCESS"),condition:ns.optional()})).openapi({ref:"SuccessCommand"}),YT=W.merge(v.object({type:v.literal("FAILURE")})).openapi({ref:"FailureCommand"}),JT=v.object({data:v.string().describe("location at which to find a jpg"),width:v.number(),height:v.number()}),Gi=W.merge(Gt).merge(v.object({type:v.literal("VISUAL_DIFF"),threshold:v.number().optional().describe("default 0.1"),target:pt.optional(),screenshot:JT.optional(),cache:xn})).openapi({ref:"VisualDiffCommand"}),XT=W.merge(v.object({type:v.literal("REGISTER_REQUEST_LISTENER"),pattern:v.string(),key:v.string()})).openapi({ref:"RegisterRequestListenerCommand"}),ZT=W.merge(v.object({type:v.literal("AWAIT_LISTENER"),key:v.string(),timeout:v.number().optional().describe("timeout")})).openapi({ref:"WaitForListenerCommand"}),QT=W.merge(v.object({type:v.literal("RECORD_REQUESTS"),pattern:v.string(),key:v.string()})).openapi({ref:"RecordRequestsCommand"}),ex=W.merge(v.object({type:v.literal("GET_RECORDED_REQUESTS"),key:v.string()})).openapi({ref:"GetRecordedRequestsCommand"}),tx=W.merge(v.object({type:v.literal("SET_HEADER"),name:v.string(),value:v.string(),urlPattern:v.string().optional().describe("URL pattern to match")})).openapi({ref:"SetHeaderCommand"}),um=v.discriminatedUnion("type",[_i,$i,_T,DT,FT,Hi,hT,xo,To,ns,Ui,fT,KT]),nx=v.discriminatedUnion("type",[NT,xT,TT,Lc,GT,CT,gT,Di,ji,LT,vT,ET,AT,WT,Fi,$T,MT,RT,wT,VT,qT,Co,Ro,jT,Gi,Bi,zi,bT,XT,ZT,QT,ex,tx]),Ao=v.discriminatedUnion("type",[...um.options,...nx.options]).openapi({ref:"Command"}),rs=v.discriminatedUnion("type",[...um.options,YT]);function Bn(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:be(),type:n};break;case"AUTH_LOAD":{e={id:be(),type:n,storageState:""};break}case"AI_EXTRACT":e={id:be(),type:n,goal:""};break;case"DIALOG":e={id:be(),type:n,action:"DISMISS"};break;case"DRAG":e={id:be(),type:n,fromTarget:{type:"description",elementDescriptor:""},toTarget:{type:"description",elementDescriptor:""}};break;case"MOUSE_DRAG":e={id:be(),type:n,deltaX:"0",deltaY:"0",steps:1};break;case"WAIT_FOR_URL":e={id:be(),type:n,matcher:{type:"SUBSTRING",url:""}};break;case"WAIT":e={id:be(),type:n,delay:1};break;case"BLUR":e={id:be(),type:n};break;case"HOVER":case"FOCUS":case"CLICK":e={id:be(),type:n,target:{type:"description",elementDescriptor:""}};break;case"COOKIE":case"PRESS":case"COPY":case"TYPE":e={id:be(),type:n,value:"",clearContent:!0};break;case"KEY_DOWN":case"KEY_UP":e={id:be(),type:n,value:""};break;case"SELECT_OPTION":e={id:be(),type:n,target:{type:"description",elementDescriptor:""},choice:{type:"VALUE",value:""}};break;case"NAVIGATE":case"NEW_TAB":return{id:be(),type:n,url:""};case"TAB":e={id:be(),type:n,action:{type:"SUBSTRING",substring:""}};break;case"REQUEST":e={id:be(),type:n,url:"",method:"GET"};break;case"GRAPHQL_REQUEST":e={id:be(),type:n,url:"",query:""};break;case"LOCAL_STORAGE":e={id:be(),type:n,key:"",value:""};break;case"JAVASCRIPT":e={id:be(),type:n,code:""};break;case"AI_ASSERTION":e={id:be(),type:n,assertion:""};break;case"FILE_UPLOAD":{e={id:be(),type:n,fileSource:{type:"URL",url:""}};break}case"ELEMENT_CHECK":{e={id:be(),type:n,target:{type:"description",elementDescriptor:""},assertion:{type:"ELEMENT_EXISTENCE",condition:"EXISTS"}};break}case"PAGE_CHECK":{e={id:be(),type:n,assertion:{type:"CONTENT",value:""}};break}case"REGISTER_REQUEST_LISTENER":{e={id:be(),type:n,pattern:"",key:""};break}case"AWAIT_LISTENER":{e={id:be(),type:n,key:""};break}case"RECORD_REQUESTS":{e={id:be(),type:n,pattern:"",key:""};break}case"GET_RECORDED_REQUESTS":{e={id:be(),type:n,key:""};break}case"SET_HEADER":{e={id:be(),type:n,name:"",value:""};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 mm(n){switch(n.type){case"BLUR":case"CLICK":case"DRAG":case"FOCUS":case"HOVER":case"MOUSE_DRAG":case"PRESS":case"KEY_DOWN":case"KEY_UP":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"GET_RECORDED_REQUESTS":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"RECORD_REQUESTS":case"REGISTER_REQUEST_LISTENER":case"REFRESH":case"REQUEST":case"SELECT_OPTION":case"SET_HEADER":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 rx}from"zod";var CD=rx.discriminatedUnion("type",[zi,Lc,_i,Di,Bi,Ui,Fi,To,xo,Co,Ro,Hi,$i,Gi,ji]);function hm(n){return["AI_ASSERTION","ELEMENT_CHECK","PAGE_CHECK"].includes(n)}import{z as ox}from"zod";var Et={type:!0,cache:!0},Pr=ox.discriminatedUnion("type",[ns.pick(Et),zi.pick(Et),_i.pick(Et),Di.pick(Et),ji.pick(Et),Bi.pick(Et),Ui.pick(Et),Fi.pick(Et),To.pick(Et),xo.pick(Et),Co.pick(Et),Ro.pick(Et),Hi.pick(Et),$i.pick(Et),Gi.pick(Et)]),Nc=Object.values(Ue).filter(n=>Pr.options.some(e=>e.shape.type.safeParse(n).success));Ao.options.forEach(n=>{if("target"in n.shape&&!Nc.includes(n.shape.type.value))throw new Error(`Command ${n.shape.type.value} has a target but no cache`)});import{z as _c}from"zod";import{z as kc}from"zod";import{z as Io}from"zod";var It=Io.object({index:Io.number().optional().describe("global index within a test (in-order traversal)"),id:Io.string(),skipped:Io.boolean().optional(),envKey:Io.string().optional().describe("key in the environment to save the result of this step to"),aiSuggested:Io.boolean().optional()});Ce(kc);var Pt=It.extend({type:kc.literal("PRESET_ACTION"),command:Ao,skipped:kc.boolean().optional()}).openapi({ref:"PresetAction"});Ce(_c);var Lr=It.extend({type:_c.literal("AI_ACTION"),text:_c.string(),steps:Pt.array().optional()}).openapi({ref:"AIAction"});import{z as ae}from"zod";var ix=ae.object({cacheKey:ae.string(),cacheExpiryMs:ae.number()}),Dc=It.extend({id:ae.string().uuid().describe("ID of the module step itself. Used to 'namespace' step cache entries."),inputs:ae.record(ae.string()).optional(),cacheConfig:ix.optional()}),zn=Dc.extend({type:ae.literal("MODULE"),moduleId:ae.string().uuid()}),ax=ae.union([zn.pick({type:!0,moduleId:!0}),ae.record(ae.unknown())]),sx=ae.object({type:ae.literal("URL_REGEX"),regex:ae.string()}),lx=ae.object({type:ae.literal("PAGE_CHECK"),substring:ae.string()}),Fc=ae.object({cacheInvalidation:ae.discriminatedUnion("type",[lx,sx]).optional()}),Lt=ae.object({moduleId:ae.string().uuid(),name:ae.string(),description:ae.string().nullish(),enabled:ae.boolean().nullish(),parameters:ae.string().array().nullish(),defaultParameters:ae.record(ae.string(),ae.string()).nullish(),parameterEnums:ae.record(ae.string(),ae.string().array()).nullish(),defaultCacheKey:ae.string().nullish(),defaultCacheTtl:ae.number().nullish(),defaultCacheAllInvocations:ae.boolean().nullish(),autoAuth:ae.boolean().nullish(),advanced:Fc.nullish()});import{z as at}from"zod";import{z as Uc}from"zod";Ce(Uc);var Po=It.extend({type:Uc.literal("AI_ACTION_DYNAMIC"),text:Uc.string()}).openapi({ref:"AIActionDynamic"});import{z as gm}from"zod";var Bc=It.extend({type:gm.literal("CONDITIONAL"),skipped:gm.boolean().optional()});import{z as os}from"zod";var cx=os.object({type:os.literal("url"),url:os.string()}),Wi=It.extend({type:os.literal("IFRAME"),identifier:cx});import{z as Wt}from"zod";var zc=(r=>(r.ALWAYS="ALWAYS",r.ON_FAILURE="ON_FAILURE",r.ON_ACTION_FAILURE="ON_ACTION_FAILURE",r))(zc||{});var dx=Wt.discriminatedUnion("type",[Wt.object({type:Wt.literal("NAVIGATE_URL"),url:Wt.string().url()}),Wt.object({type:Wt.literal("GO_TO_SECTION_START")})]),px=Wt.object({trigger:Wt.nativeEnum(zc).optional(),attempts:Wt.number().int().optional(),restartBehavior:dx}),Vi=It.extend({type:Wt.literal("SECTION"),description:Wt.string().describe("user provided goal of what the section should accomplish"),plan:Wt.string().array().optional(),autohealingConfig:px.optional()});var fm=Lt.merge(Dc).extend({type:at.literal("RESOLVED_MODULE"),steps:at.lazy(()=>Le.array())}),Hc=Lt.extend({steps:at.lazy(()=>Le.array())}),jc=Wi.extend({steps:at.lazy(()=>we.array())}),ux=Wi.extend({steps:at.lazy(()=>Le.array())}),$c=Vi.extend({steps:at.lazy(()=>we.array())}),mx=Vi.extend({steps:at.lazy(()=>Le.array())}),Or=Bc.extend({blocks:at.object({assertion:at.lazy(()=>Pt),steps:at.lazy(()=>we.array())}).array(),elseSteps:at.lazy(()=>we.array().optional())}),hx=Bc.extend({blocks:at.object({assertion:at.lazy(()=>Pt),steps:at.lazy(()=>Le.array())}).array(),elseSteps:at.lazy(()=>Le.array().optional())}),we=at.discriminatedUnion("type",[Pt,Lr,Po,zn,Or,jc,$c]),Le=at.discriminatedUnion("type",[Pt,Lr,Po,fm,hx,ux,mx]);import{z as Vt}from"zod";var gx=Vt.object({steps:we.array(),beforeSteps:we.array().nullish(),afterSteps:we.array().nullish()}),Lo=Vt.object({steps:Le.array(),beforeSteps:Le.array().nullish(),afterSteps:Le.array().nullish()}),Mr=Vt.object({steps:Vt.record(Vt.string(),Vt.unknown()).array(),beforeSteps:Vt.record(Vt.string(),Vt.unknown()).array().nullish(),afterSteps:Vt.record(Vt.string(),Vt.unknown()).array().nullish()});var Oe="1.0.20";import{z as ar}from"zod";var Gc=ar.object({key:ar.string(),testId:ar.string().optional(),moduleId:ar.string().optional(),organizationId:ar.string(),value:Pr}),Wc=Gc.extend({uniqueKey:ar.string()}),GF=ar.record(ar.string(),Wc);var Sm=_.object({phrase:_.string()}),Vc=_.object({thoughts:_.string().optional(),result:_.union([_.literal("NOT_FOUND"),_.string(),_.number(),_.array(_.unknown()),_.record(_.unknown(),_.unknown()),_.unknown()])}),R0=_.object({text:_.string()}),ym=_.object({thoughts:_.string(),review:_.string().optional(),id:_.number().int(),updatedMemory:Cc.optional()}),is=(u=>(u.NO_DESCRIPTION_PROVIDED="NO_DESCRIPTION_PROVIDED",u.FEW_WORDS="FEW_WORDS",u.STYLE_TAG="STYLE_TAG",u.TYPE_IN_DESCRIPTION="TYPE_IN_DESCRIPTION",u.HARDCODED_ATTRIBUTE="HARDCODED_ATTRIBUTE",u.NONE="NONE",u.AMBIGUOUS_DESCRIPTION="AMBIGUOUS_DESCRIPTION",u.AMBIGUOUS_ASSERTION="AMBIGUOUS_ASSERTION",u.PREFER_PAGE_CHECK="PREFER_PAGE_CHECK",u.PREFER_ASSERTION="PREFER_ASSERTION",u.HTML_ELEMENTS="HTML_ELEMENTS",u.MULTIPLE_ELEMENTS_DESCRIPTION="MULTIPLE_ELEMENTS_DESCRIPTION",u))(is||{});var bm=_.object({thoughts:_.string(),category:_.nativeEnum(is)}),fx=_.discriminatedUnion("op",[_.object({op:_.literal("replace"),path:_.string(),value:_.string()}),_.object({op:_.literal("add"),path:_.string(),value:_.string()}),_.object({op:_.literal("remove"),path:_.string()})]),A0=_.object({thoughts:_.string(),patches:fx.array()}),wm=[_.literal("add"),_.literal("replace"),_.literal("remove")],Sx=_.object({op:_.union(wm),path:_.string(),value:Le.optional()}),vm=_.object({patches:Sx.array(),thoughts:_.string()});var yx=_.object({thoughts:_.string(),op:_.union(wm),value:_.union([_.null(),Le])}),Em=_.object({reasoning:_.string(),scenario:_.string(),patch:yx.or(_.null())}),I0=_.object({thoughts:_.string(),evaluation:_.number().min(1).max(10)}),P0=_.object({observations:_.string(),reasoning:_.string(),command:rs});var qc=_.object({summary:_.string(),reasoning:_.string(),evaluation:_.discriminatedUnion("type",[_.object({type:_.literal("DONE")}),_.object({type:_.literal("RIGHT_TRACK")}),_.object({type:_.literal("WRONG_TRACK"),feedback:_.string()}),_.object({type:_.literal("IMPOSSIBLE")})])});import{z as M}from"zod";import*as Z from"zod";var _0=Z.object({thoughts:Z.string().optional().describe("only provided if a description was provided"),target:Ir.optional().describe("only provided if a description was provided"),pageState:Z.string().optional().describe("serialized a11y tree, only provided if a description was provided"),options:Z.object({label:Z.string(),value:Z.string()}).array().optional().describe("list of options, provided for <select> elements only"),screenshot:Z.object({data:Z.string(),height:Z.number().int(),width:Z.number().int()}).optional().describe("only provided if returnScreenshot is true")}),as=Z.union([Z.literal("ELEMENT_CHECK"),Z.literal("NEGATED_CHECK"),Z.literal("NEGATED_ELEMENT_VISIBLE_CHECK"),Z.literal("SELECT_OPTION"),Z.literal("TYPE")]);function Nr(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.condition==="EXISTS"&&n.assertion.negated)return"NEGATED_CHECK";if(n.type==="ELEMENT_CHECK"&&n.assertion.type==="ELEMENT_EXISTENCE"&&n.assertion.condition==="VISIBLE"&&n.assertion.negated)return"NEGATED_ELEMENT_VISIBLE_CHECK";if(n.type==="ELEMENT_CHECK")return"ELEMENT_CHECK"}}var qi=(a=>(a.USER_SELECTOR="USER_SELECTOR",a.CSS_SELECTOR="CSS_SELECTOR",a.HYBRID_SELECTOR="HYBRID_SELECTOR",a.HTML_DISTANCE="HTML_DISTANCE",a.TEMPLATE_MATCHING="TEMPLATE_MATCHING",a.AUTO_FRAME="AUTO_FRAME",a))(qi||{}),Oo=Z.object({matched:Z.boolean(),reason:Z.string().optional().describe("Human understandable description"),logs:Z.string().array().optional().describe("Logs for debugging")}),bx=Oo.extend({type:Z.literal("USER_SELECTOR")}),wx=Oo.extend({type:Z.literal("CSS_SELECTOR"),selectors:Z.string().array()}),vx=Oo.extend({type:Z.literal("HYBRID_SELECTOR")}),Ex=Oo.extend({type:Z.literal("HTML_DISTANCE"),distance:Z.number().optional(),closestElement:Z.string().optional(),savedElement:Z.string().optional()}),Tx=Oo.extend({type:Z.literal("TEMPLATE_MATCHING"),elementImageUrl:Z.string().url()}),xx=Oo.extend({type:Z.literal("AUTO_FRAME"),logs:Z.string().array().optional()}),Tm=Z.discriminatedUnion("type",[bx,wx,vx,Ex,Tx,xx]);import{z as Qi}from"zod";import{z as VC}from"zod";import*as Y from"zod";import{cloneDeep as Ji}from"lodash-es";var Cx=n=>{let e=xm(n,0);if(e===void 0||!Ax(n[e]))return;let t=xm(n,e+1);if(t!==void 0)return Ix(n,e,t)},Cm=Cx,xm=(n,e)=>{for(let t=e;t<n.length;t+=1){let r=n[t];if(!Rx(r))return t}},Rx=n=>n===" "||n===" "||n===`
5
+ `||n==="\r",Ax=n=>n==="{"||n==="[",Ix=(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 Px(r);if(r===void 0)r=i;else if(r[0]===i)r+=i;else return}},Px=n=>n===void 0?0:n[0]===" "?n.length:n;var Rm=(n,e)=>{let t=Kc(n,"toPrecision",e,e);return t===void 0?Kc(n,"toExponential",e,e):t},Kc=(n,e,t,r)=>{let i=n[e](r).replace(Lx,"$1").replace(Ox,"$1");return i.length<=t?i:r===1?void 0:Kc(n,e,t,r-1)},Lx=/(e)\+/iu,Ox=/\.?0*($|e)/iu;var Im=(n,e)=>{if(typeof n!="string")throw new TypeError(`Input must be a JSON string: ${n}`);Mx(e)},Mx=n=>{if(Nx(n),n<0)throw new TypeError(`"maxSize" argument must be positive: ${n}`);if(n<Am)throw new TypeError(`"maxSize" argument must be at least ${Am}: ${n}`)},Nx=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}`)},Am=7;var ss=(n,e,t)=>{let r=Lm(e,t);return Pm(n,e,r)},Pm=(n,e,t)=>{if(t>=e)return t;let r=n[t];return r>=jx&&r<=$x?Pm(n,e,t+1):t},ls=(n,e,t)=>{if(t===void 0)return t;let r=Lm(e,t);return kx(n,r)},kx=(n,e)=>_x(n,e)?e-3:Dx(n,e)?e-2:Fx(n,e)?e-1:e,_x=(n,e)=>e>=3&&n[e-3]>=Ux&&n[e-3]<=Bx,Dx=(n,e)=>e>=2&&n[e-2]>=zx,Fx=(n,e)=>e>=1&&n[e-1]>=Hx,Lm=(n,e)=>e<0||Object.is(e,-0)?Math.max(n+e,0):e,Ux=240,Bx=244,zx=224,Hx=194,jx=128,$x=191;var Om=(n,e,t)=>{let r=globalThis.Buffer.from(n),o=ss(r,r.length,e),i=ls(r,r.length,t);return o===0&&i>=r.length?r.toString():r.toString("utf8",o,i)};var Mm=/[\uD800-\uDFFF]/gu,Nm="\uFFFD";var cs=n=>Gx(n)?n.replace(Mm,Nm):n,Gx=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 Xc=({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,u=0;for(;u<e;d+=a){p=d;let h=n.charCodeAt(d);if(Number.isNaN(h))break;if(h<=127){u+=1;continue}if(h<=2047){u+=2;continue}if(u+=3,h<t||h>r)continue;let g=n.charCodeAt(d+a);Number.isNaN(g)||g<o||g>i||(u+=1,d+=a)}return(s&&u>e?p:d)+l};var Zc=(n,e,t)=>e<0||Object.is(e,-0)?Jx(n,e,t):Yx(n,e,t),Yx=(n,e,t)=>Xc({input:n,targetByteCount:e,firstStartSurrogate:55296,lastStartSurrogate:56319,firstEndSurrogate:56320,lastEndSurrogate:57343,increment:1,canBacktrack:t,shift:0,charIndexInit:0}),Jx=(n,e,t)=>Xc({input:n,targetByteCount:-e,firstStartSurrogate:56320,lastStartSurrogate:57343,firstEndSurrogate:55296,lastEndSurrogate:56319,increment:-1,canBacktrack:!t,shift:1,charIndexInit:n.length-1});var ds=(n,e,t)=>{let r=Zc(n,e,!1),o=Xx(n,t),i=r===0&&o===void 0?n:n.slice(r,o);return cs(i)},Xx=(n,e)=>{if(e===void 0)return e;let t=Zc(n,e,!0);return t===n.length?void 0:t};var _m=(n,e,t)=>{let{textEncoder:r,textDecoder:o}=Zx(),i=Qx(n),{written:a}=r.encodeInto(n,i),s=ss(i,a,e),l=ls(i,a,t),c=l===void 0?a:Math.min(l,a),d=i.subarray(s,c);return o.decode(d)},Zx=()=>(Qc===void 0&&(Qc=new globalThis.TextEncoder,km=new globalThis.TextDecoder("utf8",{fatal:!1})),{textEncoder:Qc,textDecoder:km}),Qc,km,Qx=n=>{let e=n.length*3;return e>eC?new Uint8Array(e):((ps===void 0||ps.length<e)&&(ps=new Uint8Array(e)),ps)},eC=1e5,ps;var Dm=(n,e)=>{if(e===void 0)return e;let t=ed(n,e);return t>=n.length*Fm?void 0:t},ed=(n,e)=>e<=n.length*-Fm?0:e,Fm=4;var Um=(n,e,t)=>{if(typeof n!="string")throw new TypeError(`First argument must be a string: ${n}`);tC(e),nC(t)},tC=n=>{if(n===void 0)throw new TypeError("Second argument is required.");Bm("Second",n)},nC=n=>{n!==void 0&&Bm("Third",n)},Bm=(n,e)=>{if(!Number.isInteger(e))throw new TypeError(`${n} argument must be an integer: ${e}`)};var zm=n=>{let e=!0,t=0;for(let r=0;r<td;r+=1){let o=rC(n,r);o<=127||(e&&(e=!1),o>2047&&(t+=1))}return{asciiOnly:e,longCharsPercentage:t/td}},rC=(n,e)=>{let t=td-1,r=1-(t-e)/t,o=Math.round(r*(n.length-1));return n.charCodeAt(o)},td=50;var oC=(n,e,t)=>{if(Um(n,e,t),n==="")return n;let r=ed(n,e),o=Dm(n,t);return o===void 0&&Object.is(r,0)?cs(n):iC(n,r,o)},Hm=oC,iC=(n,e,t)=>{if(n.length<=aC)return ds(n,e,t);let{asciiOnly:r,longCharsPercentage:o}=zm(n);return r?lC(n,e,t):o>=sC?ds(n,e,t):jm(n,e,t)},aC=200,sC=.4,lC=(n,e,t)=>"Buffer"in globalThis&&"from"in globalThis.Buffer?Om(n,e,t):jm(n,e,t),jm=(n,e,t)=>"TextEncoder"in globalThis?_m(n,e,t):ds(n,e,t);var Gm=(n,e)=>{let t=JSON.stringify(n),r=pC(t),o=Hm(r,0,e-$m.length-Ki.length*2),a=`${cC(o)}${$m}`;return uC(a)},cC=n=>n.replace(dC,""),dC=/(\\|\\u[0-9a-fA-F]{0,3})$/u,pC=n=>n.slice(Ki.length,-Ki.length),uC=n=>`${Ki}${n}${Ki}`,Ki='"',$m="...";var Wm=n=>globalThis.Buffer.byteLength(n);var nd=n=>{let e=n.length,t=e;for(let r=0;r<e;r+=1){let o=n.charCodeAt(r);if(o<=mC)continue;if(o<=hC){t+=1;continue}if(t+=2,o<gC||o>fC)continue;let i=n.charCodeAt(r+1);i<SC||i>yC||(r+=1)}return t},mC=127,hC=2047,gC=55296,fC=56319,SC=56320,yC=57343;var Vm=()=>bC.bind(void 0,new TextEncoder),bC=(n,e)=>{let t=wC(e);return n.encodeInto(e,t).written},wC=n=>{let e=n.length*3;return e>vC?new Uint8Array(e):((us===void 0||us.length<e)&&(us=new Uint8Array(e)),us)},vC=1e5,us;var TC=()=>"Buffer"in globalThis&&"byteLength"in globalThis.Buffer?Wm:"TextEncoder"in globalThis?xC.bind(void 0,Vm()):nd,xC=(n,e)=>e.length<100?nd(e):n(e),qm=TC();var Km=n=>{if(n===null)return CC;if(n===!0)return RC;if(n===!1)return AC;let e=typeof n;return e==="object"?IC:e==="number"?JSON.stringify(n).length:rd(n)},CC=4,RC=4,AC=5,IC=2,rd=n=>qm(JSON.stringify(n));var ms=({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}},Jm=n=>Km(n),Xm=(n,e,t)=>{let r=Qm({empty:n,indent:e,depth:t,keySpaceSize:0}),o=eh(n);return r+o},Zm=({key:n,empty:e,indent:t,depth:r})=>{let o=Qm({empty:e,indent:t,depth:r,keySpaceSize:1}),i=rd(n),a=eh(e);return o+i+PC+a},PC=1,Qm=({empty:n,indent:e,depth:t,keySpaceSize:r})=>{if(e===void 0)return 0;let o=Ym+e*(t+1),i=n?Ym+e*t:0;return r+o+i},Ym=1,eh=n=>n?0:LC,LC=1;var hs=({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],u=[...t,i],{size:m,stop:h,truncatedProps:g}=ms({size:s,increment:r,maxSize:o,truncatedProps:e,path:u,value:p});return h?{empty:a,size:m,truncatedProps:g}:OC({value:p,truncatedProps:e,path:u,maxSize:o,empty:a,size:s,newSize:m,truncateValue:l,indent:c,depth:d})},OC=({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:u}=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:u}:{empty:!1,size:p,value:d,truncatedProps:u}};var th=({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=Xm(c.empty,a,s);c=hs({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 nh=({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=Zm({key:d,empty:c.empty,indent:a,depth:s});c=hs({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 gs=({value:n,truncatedProps:e,path:t,size:r,maxSize:o,indent:i,depth:a})=>{let s=Jm(n),{size:l,stop:c,truncatedProps:d}=ms({size:r,increment:s,maxSize:o,truncatedProps:e,path:t,value:n});return c?{value:void 0,size:l,truncatedProps:d}:MC({value:n,truncatedProps:d,path:t,size:l,maxSize:o,indent:i,depth:a})},MC=({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)?th({array:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:gs,indent:i,depth:a}):nh({object:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:gs,indent:i,depth:a});var NC=(n,e)=>{Im(n,e);let t=kC(n),r=_C(n),{value:o,truncatedProps:i}=gs({value:r,truncatedProps:[],path:[],size:0,maxSize:e,indent:t,depth:0});return{jsonString:DC({newValue:o,value:r,maxSize:e,indent:t}),truncatedProps:i}},Mo=NC,kC=n=>{let e=Cm(n);return typeof e=="string"?e.length:e},_C=n=>{try{return JSON.parse(n)}catch(e){throw new TypeError(`Invalid JSON string: "${n}"
7
+ ${e.message}`)}},DC=({newValue:n,value:e,maxSize:t,indent:r})=>n!==void 0?JSON.stringify(n,void 0,r):typeof e=="number"?Rm(e,t):Gm(e,t);import*as _r from"zod";import{z as cn}from"zod";import{z as et}from"zod";var od=et.object({autoFollowNewTabs:et.boolean().optional().describe("Deprecated: Auto-follow new tabs that are opened."),showZeroOpacityElements:et.boolean().optional(),ignoreHrefForCaching:et.boolean().optional(),hybridSelectorMode:et.enum(["test","prefer"]).optional(),globalLocatorRedirect:et.boolean().optional(),visualActions:et.boolean().optional(),autoExpandIframes:et.boolean().optional()});var rh=1e4,oh=6e4,kr=od.extend({pageLoadTimeoutMs:et.number().optional().refine(n=>n===void 0||n<=oh&&n>=-1,{message:`Page load timeout must be between 0 and ${oh/1e3} seconds`}).describe("global page load timeout default for all tests in ms, can still be overridden by individual tests"),smartWaitingTimeoutMs:et.number().optional().refine(n=>n===void 0||n<=rh&&n>=-1,{message:`Smart waiting timeout must be between 0 and ${rh/1e3} seconds`}),localChromeExtensionPaths:et.string().array().optional(),extraHeaders:et.record(et.string(),et.string()).optional().describe("HTTP headers to be sent on every request"),userAgent:et.string().optional(),disableGpu:et.boolean().optional(),bustCacheOnBoundingBoxChange:et.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:et.boolean().optional().describe("Allow fetching the partial accessibility tree if the full tree takes too long.")});var We="BASE_URL",fs="CURRENT_URL",No="ENV_NAME",Yi="TEST_NAME",VU={[We]:"https://www.google.com"},ih=cn.string().describe("Name of the fixture (must be available locally in the fixtures directory)."),ah=cn.object({name:cn.string(),variables:cn.record(cn.string().describe("variable name"),cn.string().describe("variable value"))}),sh=cn.object({name:cn.string(),variables:cn.record(cn.string().describe("variable name"),cn.unknown().describe("variable value")),browser:kr.optional()});Ce(_r);var Xi=_r.object({env:_r.record(_r.unknown())}).openapi({ref:"TestContextSnapshot"}),FC="\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022",UC=[We,No,Yi],lh=[fs,We,No,Yi],Ot=class n{env={};varsFromMomenticEnvironment={};constructor(e){this.reset(e)}static dummyContext(e=void 0,t=void 0,r={}){return new n({baseUrl:"about:blank",currentUrl:"about:blank",testName:e,envName:t,variablesFromEnvironment:r})}static fromSnapshot({snapshot:e,environmentVariables:t}){let r=e.env[We]??"about:blank",o=e.env[fs]??"about:blank",i=e.env[No],a=e.env[Yi],s={};for(let[c,d]of Object.entries(e.env))lh.includes(c)||(t??{})[c]===void 0&&(s[c]=d);return new n({baseUrl:r,currentUrl:o,dynamicVariables:s,envName:i,testName:a,variablesFromEnvironment:t??{}})}setEnvVariables(e){let t=Ji(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){UC.includes(e)||(this.env[e]=t)}getEnvName(){return this.env[No]}toObjectCopy(){let e={env:Object.assign({},this.env,this.varsFromMomenticEnvironment)};return Ji(e)}toEditorDisplayCopy(){return this.toObjectCopy()}toRedactedDisplayCopy(){let e=this.toObjectCopy();e.env=Object.fromEntries(Object.entries(e.env).map(([r,o])=>lh.includes(r)||this.varsFromMomenticEnvironment[r]===void 0?[r,o]:[r,FC]));for(let[r,o]of Object.entries(e.env)){if(!o){e.env[r]=o;continue}let{jsonString:i}=Mo(JSON.stringify(o),1e3);try{e.env[r]=JSON.parse(i)}catch{e.env[r]=void 0}}let{jsonString:t}=Mo(JSON.stringify(e.env),5e3);try{e.env=JSON.parse(t)}catch{e.env={}}return e}setCurrentUrl(e){this.env[fs]=e}reset(e){this.env={},this.varsFromMomenticEnvironment={},this.setEnvVariables(e.dynamicVariables??{}),this.setCurrentUrl(e.currentUrl),this.varsFromMomenticEnvironment=Ji(e.variablesFromEnvironment),this.setMomenticSystemVariable(We,e.baseUrl),e.envName&&this.setMomenticSystemVariable(No,e.envName),e.testName&&this.setMomenticSystemVariable(Yi,e.testName)}getDynamicVariablesCopy(){return Ji(this.env)}getVariablesFromEnvironmentCopy(){return Ji(this.varsFromMomenticEnvironment)}};import{z as Dr}from"zod";Ce(Dr);var de=(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))(de||{});var ch=["JobTimeoutError","UserConfigurationError","UserInfrastructureError"],Ss={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"},ko={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 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."},id=Dr.object({reason:Dr.nativeEnum(de),summary:Dr.string()}).openapi({ref:"TestResultClassification"}),ys=Dr.object({errorMessage:Dr.string(),errorStack:Dr.string().optional(),classification:id.optional()}).openapi({ref:"TestFailureDetails"});Ce(Y);var Re=(i=>(i.SUCCESS="SUCCESS",i.FAILED="FAILED",i.RUNNING="RUNNING",i.IDLE="IDLE",i.CANCELLED="CANCELLED",i))(Re||{}),ad=(r=>(r.SUCCESS="SUCCESS",r.FAILED="FAILED",r.CANCELLED="CANCELLED",r))(ad||{}),sd=Y.object({beforeUrl:Y.string().optional(),afterUrl:Y.string().optional(),message:Y.string().optional(),beforeScreenshot:Y.string().optional(),afterScreenshot:Y.string().optional(),beforeSnapshot:Y.string().optional(),afterSnapshot:Y.string().optional(),startedAt:Y.coerce.date(),finishedAt:Y.coerce.date()}),BC=sd.extend({viewport:Y.object({height:Y.number(),width:Y.number()}),status:Y.nativeEnum(ad),message:Y.string().optional(),elementInteracted:Y.string().optional()}),sr=sd.extend({status:Y.nativeEnum(Re),message:Y.string().optional(),data:Y.unknown().optional(),beforeTestContext:Xi.optional(),afterTestContext:Xi.optional(),failureReason:Y.nativeEnum(de).optional(),details:Y.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"}),bs=sr.merge(Pt).extend({results:BC.array(),proposedStep:Pt.optional()}),zC=sr.merge(Lr).extend({results:Y.lazy(()=>bs.array())}),HC=sr.merge(Po).extend({results:Y.lazy(()=>bs.array())}),jC=sr.merge(zn).extend({moduleName:Y.string().optional(),results:Y.lazy(()=>Mt.array())}),$C=sr.merge(Or).extend({assertion:bs.optional(),results:Y.lazy(()=>Mt.array()).describe("results for the block actually executed")}),GC=sr.merge(Wi).extend({results:Y.lazy(()=>Mt.array())}),WC=sr.merge(Vi).extend({results:Y.lazy(()=>Mt.array()),healingAttempts:Y.lazy(()=>Mt.array().array()).optional()}),Mt=Y.discriminatedUnion("type",[zC,HC,bs,jC,$C,GC,WC]),ws=sr.pick({startedAt:!0,finishedAt:!0,status:!0,message:!0,data:!0}),vs=sd.extend({index:Y.number().optional(),description:Y.string(),pageState:Y.string().optional()});var ld=VC.object({results:Mt.array().describe("main results"),beforeResults:Mt.array().optional(),afterResults:Mt.array().optional()}),Es=ld.partial();import{z as $}from"zod";import{z as Ae}from"zod";var qC=Ae.object({type:Ae.literal("FAILURE_RECOVERY"),thoughts:Ae.string()}),KC=Ae.object({type:Ae.literal("DESCRIPTION_UPDATE"),thoughts:Ae.string()}),Ts=Ae.discriminatedUnion("type",[KC,qC]),xs=(e=>(e.AUTO_HEALING="AUTO_HEALING",e))(xs||{}),YC=Ae.object({testId:Ae.string(),name:Ae.string(),orgId:Ae.string(),runId:Ae.string(),purpose:Ae.nativeEnum(xs).catch("AUTO_HEALING"),steps:Le.array(),details:Ts.or(Ts.array()).optional()}),yB=YC.pick({name:!0,orgId:!0}),cd=Ae.object({id:Ae.string(),name:Ae.string().nullish(),createdAt:Ae.string().pipe(Ae.coerce.date()).or(Ae.date()),organizationId:Ae.string(),schemaVersion:Ae.string(),purpose:Ae.nativeEnum(xs).catch("AUTO_HEALING"),runId:Ae.string().nullish(),details:Ts.or(Ts.array()).nullish(),applied:Ae.boolean().nullish(),appliedAt:Ae.coerce.date().nullish()}),dh=cd.extend({steps:Le.array()});import{isValidCron as JC}from"cron-validator";import{z as ne}from"zod";import{z as dd}from"zod";var Hn=(r=>(r.CHROMIUM="Chromium",r.GOOGLE_CHROME="Google Chrome",r.CHROME_FOR_TESTING="Chrome for Testing",r))(Hn||{});var Cs=dd.object({width:dd.number().min(200).max(1e4),height:dd.number().min(200).max(1e4)}),ph={"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}},vB=Object.keys(ph);var qt=ph["Desktop Large"],_o="en-us",Do="America/Los_Angeles";var Fo={latitude:37.7749,longitude:-122.4194};var uh=["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 mh=2e3,Rs=kr.extend({browserType:ne.nativeEnum(Hn).optional(),slowMoMs:ne.number().optional().refine(n=>n===void 0||n<=mh&&n>=-1,{message:`Slow motion must be between 0 and ${mh} milliseconds`}),basicAuthorization:ne.object({username:ne.string().optional(),password:ne.string().optional()}).optional(),geolocation:ne.object({latitude:ne.coerce.number().refine(n=>n>=-90&&n<=90,{message:"Latitude must be between -90 and 90 degrees"}),longitude:ne.coerce.number().refine(n=>n>=-180&&n<=180,{message:"Longitude must be between -180 and 180 degrees"})}).optional(),disableJavaScript:ne.boolean().optional(),locale:ne.string().optional(),timezone:ne.enum(uh).optional(),colorScheme:ne.enum(["light","dark"]).optional()}),hh=["extraHeaders","basicAuthorization","localChromeExtensionPaths"],pd=ne.object({useMemory:ne.boolean().optional(),failureRecovery:ne.boolean().optional().describe("undefined means inherit org settings")}),XC=pd.extend({disableAICaching:ne.boolean().optional()}),ZC=ne.object({viewport:Cs.optional()}),Fr=ZC.merge(XC).merge(Rs),Uo=ne.object({cron:ne.string().refine(n=>JC(n),{message:"Invalid cron expression."}).default("0 0 */1 * *"),enabled:ne.boolean().default(!1),env:ne.string().optional(),timeZone:ne.string().default("America/Los_Angeles"),jobKey:ne.string().optional()}),Bo=ne.object({onSuccess:ne.boolean().default(!1),failureMessage:ne.string().optional(),onFailure:ne.boolean().default(!0),successMessage:ne.string().optional()}),QC=ne.object({name:ne.string(),required:ne.boolean().optional(),defaultValue:ne.string().describe("this is not optional because we need a value when the editor is first loaded")}),As=QC.array(),eR=ne.object({name:ne.string(),value:ne.string()}),gh=eR.array(),Is=ne.object({name:ne.string(),default:ne.boolean().optional(),fixtures:ih.array().optional()});Ce($);var Kt={WEBHOOK:"WEBHOOK",CRON:"CRON",MANUAL:"MANUAL",CLI:"CLI"},se=(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))(se||{}),Ps=(t=>(t.BEFORE_ALL="BEFORE_ALL",t.AFTER_ALL="AFTER_ALL",t))(Ps||{});var Ve=$.string().pipe($.coerce.date()).or($.date()),Zi=$.object({id:$.string(),runKey:$.string(),organizationId:$.string(),createdAt:Ve,createdBy:$.string(),flake:$.boolean().nullish(),scheduledAt:Ve.or($.null()),startedAt:Ve.or($.null()),updatedAt:Ve.nullish(),finishedAt:Ve.or($.null()),resolvedBaseUrl:$.string().nullish(),environmentName:$.string().nullish(),labels:$.array($.string()).optional(),cliVersion:$.string().nullish(),section:$.nativeEnum(Ps).nullish(),status:$.nativeEnum(se),trigger:$.nativeEnum(Kt),attempts:$.number(),runAttempts:$.array($.object({id:$.string(),status:$.nativeEnum(se),startedAt:Ve.or($.null()),finishedAt:Ve.or($.null())})).optional(),videos:$.array($.string()).optional(),failureReason:$.nativeEnum(de).nullish(),failureDetails:ys.nullish(),testFragments:$.array(cd).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"}),tR={id:!0,status:!0,testName:!0,localTestId:!0,testId:!0,test:{select:{name:!0,id:!0}},finishedAt:!0,failureReason:!0,failureDetails:!0},Ls=Zi.pick({...tR,test:!0}),fh=Zi.omit({failureReason:!0,failureDetails:!0,test:!0}),ud=Zi.extend({stepsSnapshot:$.array($.record($.unknown())).nullish(),resolvedInputs:$.record($.string(),$.string()).nullish(),test:$.object({name:$.string(),id:$.string(),description:$.string().nullish(),baseUrl:$.string().nullish(),advanced:Fr.nullish()}).nullish()}).merge(ld),Sh=n=>n.includes("PASSED")&&n.includes("FAILED");var nR=Qi.object({id:Qi.string().uuid(),startedAt:Ve.or(Qi.null()),finishedAt:Ve.or(Qi.null()),status:Qi.nativeEnum(se)}).merge(Es),$B=nR.array();var Os=(o=>(o.JUNIT="junit",o.ALLURE="allure",o.ALLURE_JSON="allure-json",o.PLAYWRIGHT_JSON="playwright-json",o))(Os||{});import{z as Je}from"zod";var rR=Je.object({id:Je.string(),status:Je.nativeEnum(se),trigger:Je.nativeEnum(Kt),createdAt:Ve,startedAt:Ve.nullish(),finishedAt:Ve.nullish(),gitCommitSha:Je.string().nullish(),gitCommitShaShort:Je.string().nullish(),gitCommitTimestamp:Ve.nullish(),gitBranchName:Je.string().nullish(),gitOriginUrl:Je.string().nullish(),gitCommitMessage:Je.string().nullish(),gitCommitAuthorName:Je.string().nullish(),githubRepository:Je.string().nullish(),gitlabProjectPath:Je.string().nullish(),pipelineId:Je.string().nullish(),cliVersion:Je.string().nullish(),suite:Je.object({id:Je.string(),name:Je.string()}).nullish(),runs:Je.object({status:Je.nativeEnum(se)}).array()}).openapi({ref:"RunGroup"}),yh=rR.pick({id:!0,createdAt:!0,startedAt:!0,finishedAt:!0,status:!0,trigger:!0,suite:!0}).extend({runs:Ls.array()});import{z as tt}from"zod";var oR=tt.object({type:tt.literal("TARGETING"),name:tt.string().optional().describe("Target name to disambiguate for steps with multiple targets"),elementLocationDecisions:Tm.array(),pageState:tt.string().optional(),targetSource:tt.nativeEnum(or).optional(),targetUpdateTime:tt.string().optional()}),iR=tt.object({type:tt.literal("AI_LOCATION"),matched:tt.boolean(),pageState:tt.string().optional(),ragUsed:tt.boolean().optional(),thoughts:tt.string().optional()}),aR=tt.object({type:tt.literal("ASSERTION"),relevantElementsSerialized:tt.string().array().optional(),pageState:tt.string().optional(),ragUsed:tt.boolean().optional()}),bh=tt.discriminatedUnion("type",[oR,iR,aR]);function Ms(){return{details:[]}}import{z as Be}from"zod";var sR=Be.object({id:Be.string(),name:Be.string()}),r1=sR.merge(Be.object({createdAt:Ve,createdBy:Be.string(),schedule:Uo,notification:Bo,environment:Be.object({name:Be.string()}).nullish(),beforeTests:Be.object({id:Be.string()}).array().nullish(),afterTests:Be.object({id:Be.string()}).array().nullish()})),wh=Be.object({id:Be.string().uuid(),orgId:Be.string(),createdAt:Ve,startedAt:Ve.or(Be.null()),finishedAt:Ve.or(Be.null()),status:Be.nativeEnum(se),trigger:Be.nativeEnum(Kt),suite:Be.object({id:Be.string(),name:Be.string()}).nullish(),runs:Zi.array()}),o1=wh.pick({id:!0,createdAt:!0,startedAt:!0,finishedAt:!0,status:!0,trigger:!0,suite:!0}),vh=wh.extend({runs:Ls.array()});import{z as Yt}from"zod";import{cloneDeep as l1}from"lodash-es";import{z as me}from"zod";var m1=me.object({thoughts:me.string(),subGoals:me.object({instruction:me.string()}).array()}),h1=me.object({thoughts:me.string(),newPlanMarkdown:me.string()}),g1=me.object({thoughts:me.string(),correct:me.boolean(),failedActionIndex:me.number().optional()}),lR=me.object({type:me.literal("PLANNING"),beforePlan:me.string(),goalDecision:me.string(),thoughts:me.string()}),cR=me.object({type:me.literal("RUNNING"),stepDisplayName:me.string(),status:me.nativeEnum(Re),results:Mt.array()}),dR=me.object({type:me.literal("REVISING"),beforePlan:me.string(),afterPlan:me.string(),errString:me.string(),diffs:me.string(),thoughts:me.string()}),pR=me.object({type:me.literal("SYSTEM"),message:me.string()}),uR=me.discriminatedUnion("type",[lR,cR,dR,pR]),Eh=uR.array();var w1=Yt.object({id:Yt.string(),scheduledAt:Yt.coerce.date().nullable(),startedAt:Yt.coerce.date().nullable(),finishedAt:Yt.coerce.date().nullable(),status:Yt.nativeEnum(se),history:Eh.nullable(),testPlan:Yt.object({id:Yt.string(),name:Yt.string()}).nullable(),test:Yt.object({id:Yt.string(),name:Yt.string()}).nullable()});import{z as Tt}from"zod";var md=Tt.object({content:Tt.string(),ids:Tt.string().array(),tokenLength:Tt.number()}),mR=Tt.object({chunks:md.array()}),F1=Tt.object({ids:Tt.string().array(),score:Tt.number(),tokenLength:Tt.number()}),U1=mR.extend({description:Tt.string().describe("Input to pass to RAG engine"),tokenLimit:Tt.number()}),Th=Tt.object({ids:Tt.number().array()}),xh=Tt.object({indices:Tt.number().array()});var Jt=M.object({disableCache:M.boolean().optional(),useMemory:M.boolean().optional(),loggerTags:M.record(M.string(),M.string()).optional(),langfuseSessionId:M.string().optional(),agentConfigVersion:M.string().optional()}),V1=Jt.extend({chunks:md.array(),description:M.string().describe("Input to pass to AI"),type:M.union([M.literal("locator"),M.literal("assertion"),M.literal("ai-action")]),softTokenLimit:M.number(),hardTokenLimit:M.number()}),hR=M.object({screenshotBase64AfterCommand:M.string(),urlAfterCommand:M.string(),serializedCommand:M.string(),elementInteracted:M.string().optional(),thoughts:M.string().optional()}),Ch=M.object({goal:M.string(),browserState:M.string(),screenshot:M.string(),source:as.optional().catch(void 0),memory:M.discriminatedUnion("type",[Ni,M.object({type:M.literal("RESOLVED_TRACES"),traces:M.unknown().array()})]).optional()}),Rh=M.object({target:M.string().or(M.number()),browserState:M.string().optional(),screenshot:M.string().optional(),boundingBox:M.object({x:M.number(),y:M.number(),height:M.number(),width:M.number()}).optional()}),Ah=M.object({goal:M.string(),browserState:M.string(),screenshot:M.string().optional(),returnSchema:M.string().optional()}),Ih=M.object({goal:M.string(),browserState:M.string(),screenshot:M.string(),url:M.string(),contextChoice:Oc.optional(),memory:M.discriminatedUnion("type",[Ic,M.object({type:M.literal("RESOLVED_TRACES"),traces:M.unknown().array()})]).optional()}),Ph=M.object({command:Ao}),hd=M.object({goal:M.string(),browserState:M.string(),startingScreenshot:M.string().optional(),screenshot:M.string(),url:M.string(),history:hR.array(),actionHint:M.string().optional(),lastError:M.string().optional()}),Lh=M.object({results:vs.array(),errorMessage:M.string(),errorStack:M.string().optional()}),Oh=M.object({results:vs.array(),goal:M.string(),errorMessage:M.string()}),Mh=M.object({failedResults:vs.array(),nextStepsSerialized:M.string().array(),currentUrl:M.string(),currentPageState:M.string(),currentScreenshot:M.string()}),q1=M.object({description:M.string(),type:M.union([M.literal("locator"),M.literal("assertion"),M.literal("ai-action")]),excerpt:M.string()});import{z as ea}from"zod";var J1=ea.object({goal:ea.string()}),Nh=ea.object({keywords:ea.array(ea.string())});import{z as gd}from"zod";var fd=(t=>(t.LOCATOR="locator",t.ASSERTION="assertion",t))(fd||{}),Q1=gd.nativeEnum(fd),gR=gd.enum(["v1","v2"]),ez=gR.or(gd.string().describe("for people with special configurations"));var kh=n=>!(!n.org_id||!n.user_id||!n.platform);import{z as Ur}from"zod";var _h=Ur.object({id:Ur.string().uuid(),skipped:Ur.boolean().optional(),envKey:Ur.string().optional().describe("key in the environment to save the result of this step to")}),Sd=_h.merge(Za).extend({type:Ur.literal("REQUEST")}),yd=_h.merge(Qa).extend({type:Ur.literal("JAVASCRIPT")}),bd=Ur.discriminatedUnion("type",[yd,Sd]);import{z as Xt}from"zod";import{z as Br}from"zod";var fR=/^[a-f0-9]{8}-[a-f0-9]{4}-[1-5][a-f0-9]{3}-[89ab][a-f0-9]{3}-[a-f0-9]{12}$/,Ie=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 Ns=Br.string().min(1).max(255).superRefine((n,e)=>{try{zr(n)}catch(t){return e.addIssue({code:Br.ZodIssueCode.custom,message:t.message,fatal:!0}),Br.NEVER}});function zr(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(fR))throw new Error("Name cannot be a UUID. Please choose a different name.")}var ks=Br.preprocess(n=>n===null?"":n,Br.union([Br.string().url(),Br.literal("")])).optional();var Dh=Xt.object({id:Xt.string(),name:Ns,description:Xt.string().optional().nullish(),baseUrl:ks.nullish(),schemaVersion:Xt.string(),advanced:Xt.unknown().optional(),retries:Xt.number(),envs:Xt.array(Is).nullish(),parameters:As.nullish()}),SR=Xt.object({createdAt:Xt.coerce.date(),updatedAt:Xt.coerce.date(),schedule:Uo.nullish(),notification:Bo.nullish(),createdBy:Xt.string(),organizationId:Xt.string()}),yR=Dh.merge(SR),Tz=yR.extend({steps:bd.array()}),xz=Dh.extend({steps:bd.array()});import{z as Nt}from"zod";var Fh=Nt.object({startedAt:Nt.coerce.date(),finishedAt:Nt.coerce.date(),status:Nt.nativeEnum(Re),message:Nt.string().optional(),data:Nt.unknown().optional()}),wR=Fh.merge(yd).extend({type:Nt.literal("JAVASCRIPT")}),vR=Fh.merge(Sd).extend({type:Nt.literal("REQUEST")}),ER=Nt.discriminatedUnion("type",[wR,vR]),Uh=Nt.object({startedAt:Nt.coerce.date(),finishedAt:Nt.coerce.date().nullish(),status:Nt.nativeEnum(se),results:ER.array(),failureReason:Nt.string().nullish(),failureDetails:ys.nullish()});import{z as kt}from"zod";var TR=kt.object({id:kt.string(),organizationId:kt.string(),createdAt:kt.coerce.date(),updatedAt:kt.coerce.date(),createdBy:kt.string(),scheduledAt:kt.coerce.date().nullish(),startedAt:kt.coerce.date().nullish(),finishedAt:kt.coerce.date().nullish(),status:kt.nativeEnum(se),trigger:kt.nativeEnum(Kt),results:Uh.array().nullish(),apiTestName:kt.string().nullish(),apiTestPath:kt.string().nullish(),apiTestId:kt.string().nullish()}),Nz=TR.pick({status:!0,startedAt:!0,finishedAt:!0});var ta=(t=>(t.TestRun="test-run",t.CreditsUsed="credits-used",t))(ta||{}),Bh=3;function xR(n){return n==="MODULE"||n==="IFRAME"||n==="CONDITIONAL"||n==="SECTION"||n==="RESOLVED_MODULE"}function na(n){if(!xR(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 ra(n){switch(n.type){case"AI_EXTRACT":case"AI_ASSERTION":return Bh;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"KEY_DOWN":case"KEY_UP":case"COPY":case"PASTE":case"REFRESH":case"REQUEST":case"GRAPHQL_REQUEST":case"WAIT_FOR_URL":case"REGISTER_REQUEST_LISTENER":case"AWAIT_LISTENER":case"RECORD_REQUESTS":case"GET_RECORDED_REQUESTS":case"SET_HEADER":return 0;default:(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}var zo=class{async reportBillableEvent(e,t,r){}async reportCreditsUsed(e,t,r,o){}};function wd(n,e){return{...n,testId:e?.testId??"",testName:e?.testName??"",suiteId:e?.suiteId??"",suiteName:e?.suiteName??""}}import{parseString as CR,splitCookiesString as RR}from"set-cookie-parser";import{z as fe}from"zod";var vd=fe.object({name:fe.string(),value:fe.string(),url:fe.string().optional(),domain:fe.string().optional(),path:fe.string().optional(),expires:fe.number().default(Date.now()/1e3+60*60*24*365),httpOnly:fe.boolean().optional(),secure:fe.boolean().default(!0),sameSite:fe.union([fe.literal("Strict"),fe.literal("Lax"),fe.literal("None")]).default("None")});function _s(n,e){let t=[],r=RR(n);for(let o of r){let i=CR(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=vd.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,u]=d.split("=");if(!p||!u)throw new Error(`Invalid key-value pair in cookie: ${d}`);l.includes(p.toLowerCase())||t.push({...s,name:p,value:u})}}return t}var AR=fe.object({origin:fe.string(),localStorage:fe.array(fe.object({name:fe.string(),value:fe.string()}))}),IR=fe.object({entries:fe.record(fe.string(),fe.array(fe.tuple([fe.unknown(),fe.unknown()]))),version:fe.number().optional()}),Ds=fe.object({cookies:vd.array().optional(),origins:AR.array().optional(),idb:fe.record(fe.string(),IR).optional().describe("key is db name")});function Fs(n,e){let t=[];return n.cloneSync()?.serializeSync()?.cookies.forEach(r=>{let o=vd.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 tH=new Set(Object.values(Ue));var PR={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",KEY_DOWN:"Key down",KEY_UP:"Key up",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:"localStorage",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",RECORD_REQUESTS:"Record requests",GET_RECORDED_REQUESTS:"Get recorded requests",SET_HEADER:"Set header",SUCCESS:"Done"},nH={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"],KEY_DOWN:["keyboard","type","key","down","press"],KEY_UP:["keyboard","type","key","up","press"],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:[],RECORD_REQUESTS:[],GET_RECORDED_REQUESTS:[],SET_HEADER:[],SUCCESS:[]},rH={AI_ACTION:"Ask AI achieve a specific goal. Saves the steps for reuse. Please use Dynamic AI action instead.",AI_ACTION_DYNAMIC:"Ask AI achieve a specific goal. Fully dynamic and does not save the steps for reuse. Our most capable AI agent.",RESOLVED_MODULE:"A list of steps that can be reused in multiple tests.",AI_ASSERTION:"Ask AI to verify whether something is true on the page.",CLICK:"Click on an element on the page.",DIALOG:"Specify how native browser dialogs should be handled.",AI_EXTRACT:"Ask AI to extract data from the page.",HOVER:"Hover over an element on the page.",FILE_UPLOAD:"Automatically upload a file when the native file upload dialog is activated.",FOCUS:"Focus an element on the page.",BLUR:"Remove focus from an element on the page.",SELECT_OPTION:"Select an option from an HTML Select <select> element.",TYPE:"Type the specified text into an element.",PRESS:"Press the specified keys using the keyboard. (e.g. Control+A)",KEY_DOWN:"Hold down the specified keys on the keyboard. (e.g. Control+A)",KEY_UP:"Release the specified keys on 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 localStorage 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 in the browser or a Node.js environment.",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 JavaScript object including cookies, localStorage, and IndexDB entries.",AUTH_SAVE:"Save authentication state (cookies, localStorage) into a JavaScript object.",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 contents using pre-built conditions.",WAIT_FOR_URL:"Wait for the active page's URL to match a target value or pattern.",COPY:"Copy the specified value to the browser clipboard.",PASTE:"Paste the browser clipboard contents.",REGISTER_REQUEST_LISTENER:"Register a listener for network requests.",AWAIT_LISTENER:"Wait for a listener to fire, and return the response data.",RECORD_REQUESTS:"Record network requests that match a given pattern.",GET_RECORDED_REQUESTS:"Get recorded requests that matched the pattern.",SET_HEADER:"Set a header.",SUCCESS:"Indicate the entire AI action has succeeded, optionally based on a condition."};import{Faker as aH,en as sH}from"@faker-js/faker";import{z as G}from"zod";var zh=55555,pH=G.object({body:G.string(),to:G.string(),from:G.string()}),uH=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()}),mH=G.object({to:G.string(),from:G.string(),subject:G.string(),body:G.string()}),hH=G.object({inbox:G.string(),afterDate:G.string().pipe(G.coerce.date()).or(G.date()).optional(),timeout:G.number().optional(),trimWhitespace:G.boolean().optional()}),gH=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 Hh=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()}),fH=G.object({id:G.string().optional(),orgId:G.string(),momenticLambdaAuthHash:G.string(),code:G.string(),fragment:G.boolean(),state:Xi,timeoutMs:G.number().optional()}),lr=15e3;import*as mt from"zod";Ce(mt);var LR=mt.object({url:mt.string(),lineNumber:mt.number(),columnNumber:mt.number()}).openapi({ref:"CodeLocation"}),Us=mt.object({timestamp:mt.number(),text:mt.string(),type:mt.string(),tabIndex:mt.number(),args:mt.unknown().array().optional(),url:mt.string().optional(),location:LR.optional()}).openapi({ref:"ConsoleLog"}),jh=Us.array(),OR=jh.array();import*as Td from"zod";import{z as I}from"zod";var MR=I.object({name:I.string(),version:I.string(),comment:I.string().optional()}),NR=I.object({name:I.string(),version:I.string(),comment:I.string().optional()}),kR=I.object({onContentLoad:I.number().optional(),onLoad:I.number().optional(),comment:I.string().optional()}),Gh=I.object({startedDateTime:I.string(),id:I.string(),title:I.string().optional(),pageTimings:kR,comment:I.string().optional()}),_R=I.array(Gh),DR=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()}),Wh=I.array(DR),FR=I.object({name:I.string(),value:I.string(),comment:I.string().optional()}),Vh=I.array(FR),UR=I.object({name:I.string(),value:I.string(),comment:I.string().optional()}),BR=I.array(UR),zR=I.object({name:I.string(),value:I.string().optional(),fileName:I.string().optional(),contentType:I.string().optional(),comment:I.string().optional()}),HR=I.array(zR),jR=I.object({mimeType:I.string(),params:HR,text:I.string(),comment:I.string().optional()}),$R=I.object({method:I.string(),url:I.string(),httpVersion:I.string().optional(),cookies:Wh,headers:Vh,queryString:BR,postData:jR.optional(),headersSize:I.number().optional(),bodySize:I.number().optional(),comment:I.string().optional()}),GR=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()}),WR=I.object({status:I.number(),statusText:I.string(),httpVersion:I.string().optional(),cookies:Wh,headers:Vh,content:GR,redirectURL:I.string().optional(),headersSize:I.number().optional(),bodySize:I.number().optional(),comment:I.string().optional()}),$h=I.object({expires:I.string().optional(),lastAccess:I.string(),eTag:I.string(),hitCount:I.number(),comment:I.string().optional()}),VR=I.object({beforeRequest:$h.optional(),afterRequest:$h.optional(),comment:I.string().optional()}),qR=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()}),qh=I.object({pageref:I.string().optional(),startedDateTime:I.string(),time:I.number().optional(),request:$R,response:WR.optional(),cache:VR.optional(),timings:qR,serverIPAddress:I.string().optional(),connection:I.string().optional(),comment:I.string().optional(),_resourceType:I.string().optional()}),KR=I.array(qh),YR=I.object({version:I.string().default("1.1"),creator:MR.optional(),browser:NR.optional(),pages:_R.optional(),entries:KR,comment:I.string().optional()}),JR=I.object({log:YR}),Kh=I.record(I.string(),Gh),Yh=I.record(I.string(),qh);function Ed(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())}}}Ce(Td);var XR=Td.object({logsPerPage:Us.array().array(),harPages:Kh.optional(),harEntries:Yh.optional()}).openapi({ref:"DebugData"});var Hr=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 Jh(n){for(let e of Object.values(de))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(de))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}}},jn=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 Jh(n){return n instanceof Error?n.message.includes("Timeout")&&n.message.includes("exceeded")&&n.message.includes("waiting for locator"):!1}function Td(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"))}var jn=class extends Error{constructor(e,t={}){super(e,t),this.name="BoundingBoxMovedError"}};function ia(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 oa=class extends Error{constructor(e,t={}){super(e,t),this.name="InsufficientCacheDataError"}};import{cloneDeep as YR}from"lodash-es";import{z as Rn}from"zod";var Qt=(m=>(m.AutoExpandIframes="auto_expand_iframes",m.DisableSecondaryCacheResolution="disable_secondary_cache_resolution",m.DisableClickhouseCaches="disable_clickhouse_caches",m.DisableClickHouseLastUpdatedEndpoint="disable_clickhouse_last_updated_endpoint",m.FakerConstantSeed="faker_constant_seed",m.ShowZeroOpacityElements="show_zero_opacity_elements",m.GlobalLocatorRedirect="global_locator_redirect",m.IconKnowledgeBase="icon_knowledge_base",m.MiniModelInitialAssertion="mini_model_initial_assertion",m.MiniModelInitialLocator="mini_model_initial_locator",m.ShowTestPlans="show_test_plans",m.RagV2="rag_v2",m.VisualActions="visual_actions",m))(Qt||{});var Xh=Rn.union([Rn.string(),Rn.number(),Rn.boolean(),Rn.null(),Rn.record(Rn.string(),Rn.lazy(()=>Xh)),Rn.array(Rn.lazy(()=>Xh))]),aa=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=YR(this.flags);return Object.entries(e).forEach(([t,r])=>{typeof r=="boolean"&&Object.values(Qt).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")}},tj=new aa({},{});var Ed={".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"},Qh=[".sh",".exe",".app",".bat",".cmd",".msi",".apk",".jar",".py",".js",".cron",".php",".asp"],rj=Object.keys(Ed);import*as Zh from"zod";var ij=Zh.custom().refine(n=>n&&n.length>0).refine(n=>n&&n[0]instanceof File,{message:"Please upload a valid file."});import{z as lr}from"zod";var lj=lr.object({id:lr.string(),name:lr.string(),createdAt:lr.coerce.date(),createdBy:lr.string(),updatedAt:lr.coerce.date(),updatedBy:lr.string().nullable(),organizationId:lr.string()});import{z as P}from"zod";import{z as Me}from"zod";var ht=Me.object({id:Me.string(),name:Ns,baseUrl:ks,description:Me.string().optional().nullish(),schemaVersion:Me.string(),advanced:Fr,retries:Me.number(),envs:Me.array(Is).nullish(),parameters:As.nullish(),disabled:Me.boolean().optional(),labels:Me.array(Me.string()).optional().catch([])}),gj=Me.enum(["INHERIT","ENABLED","DISABLED"]);var JR=Fr.extend({failureRecovery:Me.boolean().or(Me.string()).optional().transform(n=>typeof n=="string"?n:n===void 0?"INHERIT":n?"ENABLED":"DISABLED"),useMemory:Me.boolean().or(Me.string()).optional().transform(n=>typeof n=="string"?n:n===void 0?"INHERIT":n?"ENABLED":"DISABLED")});var fj=ht.pick({name:!0,description:!0,baseUrl:!0,retries:!0,disabled:!0,parameters:!0}).extend({advanced:JR}),Sj=ht.pick({name:!0,description:!0,baseUrl:!0,retries:!0,disabled:!0,advanced:!0,parameters:!0}),XR=Me.object({labels:Me.array(Me.string()).optional(),outputs:hh.nullish()}),Zt=ht.merge(XR),QR=Me.object({createdAt:Me.coerce.date(),updatedAt:Me.coerce.date(),updatedBy:Me.string().nullable(),schedule:Uo,notification:Bo,createdBy:Me.string(),organizationId:Me.string(),folderId:Me.string().nullable().optional()}),ZR=ht.merge(QR),yj=ZR.merge(Lo),zs=ht.merge(Lo),bj=ht.merge(Mr);var eg=P.object({platformSep:P.string(),fullPathSegments:P.string().array(),relativePathSegments:P.string().array(),relativePath:P.string().describe("path relative to the root test directory, i.e. my-folder/my-test.yaml"),fileName:P.string().describe("base name of the file including the extension, e.g. my-module.module.yaml"),lastModified:P.coerce.date(),createdAt:P.coerce.date()}),eA=P.array(eg.extend({id:P.string(),name:P.string(),description:P.string().optional(),labels:P.string().array().optional()})),tA=P.array(eg.extend({id:P.string(),name:P.string(),description:P.string().optional(),content:Bc})),Aj=P.object({tests:eA,modules:tA,labels:P.string().array()}),Ij=zs.merge(Zt),tg=P.object({schemaVersion:P.string(),stepLists:Lo}),ng=Zt.partial().merge(ht.pick({id:!0})),rg=P.object({name:P.string(),description:P.string().optional(),baseUrl:P.string().url().optional(),environment:P.string().optional(),browserType:P.nativeEnum(zn).optional(),viewport:Cs.optional(),pathSegments:P.string().array().optional()}),Pj=zs.merge(P.object({relativeFilePath:P.string().describe("relative to project root")})),og=P.object({name:P.string()}),Lj=P.object({relativeFilePath:P.string()}),ig=P.object({name:P.string()}),Oj=P.object({relativeFilePath:P.string()}),ag=P.object({name:P.string(),description:P.string(),enabled:P.boolean(),steps:P.lazy(()=>Le.array()),testFilePath:P.string().describe("relative to the project root"),folderPath:P.string().optional().describe("user selected folder path")}),sg=P.object({description:P.string(),enabled:P.boolean()}).partial();var Mj=P.array(ah),lg=P.object({defaultEnv:P.string().optional().describe("name of the default env, or undefined to unset")}),cg=P.object({configFilePath:P.string().describe("full path on disk")}),Nj=P.string().array(),kj=P.object({message:P.string(),newRelativeTestPath:P.string().optional()}),xd=P.object({name:P.string(),absolutePath:P.string(),relativePath:P.string(),pathSegments:P.array(P.string()),isDirectory:P.boolean(),size:P.number(),createdAt:P.coerce.date(),modifiedAt:P.coerce.date(),accessedAt:P.coerce.date()}),dg=P.object({pathSegments:P.array(P.string())}),_j=P.object({absolutePath:P.string(),pathSegments:P.array(P.string()),contents:P.array(xd)}),pg=P.object({pathSegments:P.array(P.string())}),ug=P.object({pathSegments:P.array(P.string()),newPathSegments:P.array(P.string())}),mg=P.object({pathSegments:P.array(P.string()),recursive:P.boolean().optional()}),Dj=P.object({success:P.boolean(),message:P.string(),pathSegments:P.array(P.string()).optional()});var Hs=["node_modules","dist","bin",".git",".npm",".next","out",".yarn","__pycache__","build",".env",".venv","venv","env","wheels"],hg=Hs.map(n=>`**/${n}/**`);import An from"chalk";var nA=["app","version","env","namespace","host"];function ze(n){let e=n.bindings()??{},t={};for(let r of Object.keys(e)){let o=e[r];!nA.includes(r)&&typeof o=="string"&&(t[r]=o)}return t}var Cd=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 Xh(n){return n instanceof Error?n.message.includes("Timeout")&&n.message.includes("exceeded")&&n.message.includes("waiting for locator"):!1}function xd(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"))}var Rn=class extends Error{retryableWithAI;constructor(e,t,r={}){super(e,r),this.name="CacheAttributesDisqualifyElementError",this.retryableWithAI=t}},zs=class extends Rn{constructor(e,t={}){super(e,!0,t),this.name="BoundingBoxMovedError"}},Hs=class extends Rn{constructor(e,t={}){super(e,!1,t),this.name="ZeroOpacityError"}};function ia(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 oa=class extends Error{constructor(e,t={}){super(e,t),this.name="InsufficientCacheDataError"}};import{cloneDeep as ZR}from"lodash-es";import{z as An}from"zod";var Zt=(m=>(m.AutoExpandIframes="auto_expand_iframes",m.DisableSecondaryCacheResolution="disable_secondary_cache_resolution",m.DisableClickhouseCaches="disable_clickhouse_caches",m.DisableClickHouseLastUpdatedEndpoint="disable_clickhouse_last_updated_endpoint",m.FakerConstantSeed="faker_constant_seed",m.ShowZeroOpacityElements="show_zero_opacity_elements",m.GlobalLocatorRedirect="global_locator_redirect",m.IconKnowledgeBase="icon_knowledge_base",m.MiniModelInitialAssertion="mini_model_initial_assertion",m.MiniModelInitialLocator="mini_model_initial_locator",m.ShowTestPlans="show_test_plans",m.RagV2="rag_v2",m.VisualActions="visual_actions",m))(Zt||{});var Zh=An.union([An.string(),An.number(),An.boolean(),An.null(),An.record(An.string(),An.lazy(()=>Zh)),An.array(An.lazy(()=>Zh))]),aa=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=ZR(this.flags);return Object.entries(e).forEach(([t,r])=>{typeof r=="boolean"&&Object.values(Zt).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")}},oj=new aa({},{});var Cd={".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"},Qh=[".sh",".exe",".app",".bat",".cmd",".msi",".apk",".jar",".py",".js",".cron",".php",".asp"],aj=Object.keys(Cd);import*as eg from"zod";var lj=eg.custom().refine(n=>n&&n.length>0).refine(n=>n&&n[0]instanceof File,{message:"Please upload a valid file."});import{z as cr}from"zod";var pj=cr.object({id:cr.string(),name:cr.string(),createdAt:cr.coerce.date(),createdBy:cr.string(),updatedAt:cr.coerce.date(),updatedBy:cr.string().nullable(),organizationId:cr.string()});import{z as P}from"zod";import{z as Me}from"zod";var ht=Me.object({id:Me.string(),name:Ns,baseUrl:ks,description:Me.string().optional().nullish(),schemaVersion:Me.string(),advanced:Fr,retries:Me.number(),envs:Me.array(Is).nullish(),parameters:As.nullish(),disabled:Me.boolean().optional(),labels:Me.array(Me.string()).optional().catch([])}),yj=Me.enum(["INHERIT","ENABLED","DISABLED"]);var QR=Fr.extend({failureRecovery:Me.boolean().or(Me.string()).optional().transform(n=>typeof n=="string"?n:n===void 0?"INHERIT":n?"ENABLED":"DISABLED"),useMemory:Me.boolean().or(Me.string()).optional().transform(n=>typeof n=="string"?n:n===void 0?"INHERIT":n?"ENABLED":"DISABLED")});var bj=ht.pick({name:!0,description:!0,baseUrl:!0,retries:!0,disabled:!0,parameters:!0}).extend({advanced:QR}),wj=ht.pick({name:!0,description:!0,baseUrl:!0,retries:!0,disabled:!0,advanced:!0,parameters:!0}),eA=Me.object({labels:Me.array(Me.string()).optional(),outputs:gh.nullish()}),Qt=ht.merge(eA),tA=Me.object({createdAt:Me.coerce.date(),updatedAt:Me.coerce.date(),updatedBy:Me.string().nullable(),schedule:Uo,notification:Bo,createdBy:Me.string(),organizationId:Me.string(),folderId:Me.string().nullable().optional()}),nA=ht.merge(tA),vj=nA.merge(Lo),js=ht.merge(Lo),Ej=ht.merge(Mr);var tg=P.object({platformSep:P.string(),fullPathSegments:P.string().array(),relativePathSegments:P.string().array(),relativePath:P.string().describe("path relative to the root test directory, i.e. my-folder/my-test.yaml"),fileName:P.string().describe("base name of the file including the extension, e.g. my-module.module.yaml"),lastModified:P.coerce.date(),createdAt:P.coerce.date()}),rA=P.array(tg.extend({id:P.string(),name:P.string(),description:P.string().optional(),labels:P.string().array().optional()})),oA=P.array(tg.extend({id:P.string(),name:P.string(),description:P.string().optional(),content:Hc})),Lj=P.object({tests:rA,modules:oA,labels:P.string().array()}),Oj=js.merge(Qt),ng=P.object({schemaVersion:P.string(),stepLists:Lo}),rg=Qt.partial().merge(ht.pick({id:!0})),og=P.object({name:P.string(),description:P.string().optional(),baseUrl:P.string().url().optional(),environment:P.string().optional(),browserType:P.nativeEnum(Hn).optional(),viewport:Cs.optional(),pathSegments:P.string().array().optional()}),Mj=js.merge(P.object({relativeFilePath:P.string().describe("relative to project root")})),ig=P.object({name:P.string()}),Nj=P.object({relativeFilePath:P.string()}),ag=P.object({name:P.string()}),kj=P.object({relativeFilePath:P.string()}),sg=P.object({name:P.string(),description:P.string(),enabled:P.boolean(),steps:P.lazy(()=>Le.array()),testFilePath:P.string().describe("relative to the project root"),folderPath:P.string().optional().describe("user selected folder path")}),lg=P.object({description:P.string(),enabled:P.boolean()}).partial();var _j=P.array(sh),cg=P.object({defaultEnv:P.string().optional().describe("name of the default env, or undefined to unset")}),dg=P.object({configFilePath:P.string().describe("full path on disk")}),Dj=P.string().array(),Fj=P.object({message:P.string(),newRelativeTestPath:P.string().optional()}),Rd=P.object({name:P.string(),absolutePath:P.string(),relativePath:P.string(),pathSegments:P.array(P.string()),isDirectory:P.boolean(),size:P.number(),createdAt:P.coerce.date(),modifiedAt:P.coerce.date(),accessedAt:P.coerce.date()}),pg=P.object({pathSegments:P.array(P.string())}),Uj=P.object({absolutePath:P.string(),pathSegments:P.array(P.string()),contents:P.array(Rd)}),ug=P.object({pathSegments:P.array(P.string())}),mg=P.object({pathSegments:P.array(P.string()),newPathSegments:P.array(P.string())}),hg=P.object({pathSegments:P.array(P.string()),recursive:P.boolean().optional()}),Bj=P.object({success:P.boolean(),message:P.string(),pathSegments:P.array(P.string()).optional()});var $s=["node_modules","dist","bin",".git",".npm",".next","out",".yarn","__pycache__","build",".env",".venv","venv","env","wheels"],gg=$s.map(n=>`**/${n}/**`);import In from"chalk";var iA=["app","version","env","namespace","host"];function ze(n){let e=n.bindings()??{},t={};for(let r of Object.keys(e)){let o=e[r];!iA.includes(r)&&typeof o=="string"&&(t[r]=o)}return t}var Ad=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,An.reset,...e)}info(...e){this.logWithLevel(1,An.white,...e)}debug(...e){this.logWithLevel(0,An.dim,...e)}warn(...e){this.logWithLevel(2,An.yellow,...e)}error(...e){this.logWithLevel(3,An.red,...e)}success(...e){this.logWithLevel(4,An.green,...e)}dimmed(...e){this.logWithLevel(1,An.dim,...e)}underline(...e){this.logWithLevel(2,An.underline,...e)}bold(...e){this.logWithLevel(2,An.bold,...e)}grey(...e){this.logWithLevel(0,An.grey,...e)}child(e){return new n(this.minLogLevel,{...this.logBindings,...e})}flush(){}bindings(){return this.logBindings}},Rd=class{debug(){}info(){}warn(){}error(){}success(){}dimmed(){}underline(){}bold(){}grey(){}child(){return this}flush(){}bindings(){return{}}},gg=new Rd,b=new Cd(1,{}),jr={info:()=>{},error:()=>{},debug:()=>{},warn:()=>{},child:()=>jr,flush:()=>{},bindings:()=>({})},js={},$r=({logger:n,logKey:e,maxCount:t,intervalMs:r},o,i,...a)=>{let s=js[e];s?clearTimeout(s.timer):(s={count:0,totalCount:0},js[e]=s),s.totalCount++,s.count<t&&(s.count++,n.debug(o,i,...a)),s.timer=setTimeout(()=>{let l=js[e];l?.totalCount!==l?.count&&n.debug({logKey:e,totalCount:l?.totalCount,count:l?.count},`Debug logs were rate-limited for ${e}`),delete js[e]},r)};import{z as He}from"zod";var fg=He.object({id:He.string(),createdAt:He.coerce.date(),createdBy:He.string(),organizationId:He.string(),name:He.string(),description:He.string().nullish(),enabled:He.boolean(),schemaVersion:He.string().describe("Schema version for steps"),parameters:He.string().array().nullish().describe("Parameter list"),parameterEnums:He.record(He.string(),He.string().array()).nullish(),defaultParameters:He.record(He.string(),He.string()).nullish(),defaultCacheKey:He.string().nullish(),defaultCacheTtl:He.number().nullish(),defaultCacheAllInvocations:He.boolean().nullish(),autoAuth:He.boolean().nullish(),advanced:_c.nullish()}),Yj=fg.extend({steps:He.lazy(()=>we.array())}),Sg=5*60*1e3,Ad=Lt.merge(fg.omit({id:!0,createdAt:!0,createdBy:!0,organizationId:!0,enabled:!0}));import{formatInTimeZone as Qj}from"date-fns-tz";import{z as qe}from"zod";var Id=cd.extend({aiAction:qe.boolean().optional(),stepLintSuggestions:qe.boolean().optional(),agentConfig:qe.record(qe.string(),qe.string()).optional(),aiPageFiltering:qe.boolean().optional().describe("rag v2 feature flag")}),yg=qe.object({fakerConstantSeed:qe.boolean().optional()}),r$=qe.object({ai:Id.optional(),githubAppInstallationId:qe.number().nullish(),githubReleaseAppInstallationId:qe.number().nullish(),gitlabAppAccessToken:qe.string().nullish().optional(),gitlabAppBaseUrl:qe.string().nullish().optional(),qaseAccessToken:qe.string().nullish().optional(),browser:nd.optional()}),o$=qe.object({globalOverrides:qe.record(qe.string()).optional(),agentConfig:qe.record(qe.string(),qe.string()).optional()});import*as C from"zod";var bg="x-momentic-cli-version",wg="x-momentic-main-branch-name",vg="x-momentic-branch-name",Tg="x-momentic-commit-timestamp",Eg="x-momentic-last-commit-on-main",xg="x-momentic-last-commit-on-main-timestamp",b$=C.object({error:C.boolean(),reason:C.string(),message:C.string()}),w$=Jt.merge(ud),Cg=rs,v$=Jt.merge(ud);var T$=Jt.merge(Ah).extend({useConsensus:C.boolean().optional(),attemptNumber:C.number().optional()}),Pd=am,E$=Jt.merge(Ih),Rg=ym,x$=Jt.merge(xh),Ag=Sm,C$=Jt.merge(Ch),Ig=fm,R$=Jt.merge(Rh);var A$=C.object({testPaths:C.string().array().describe("can be either hyphenated, lowercase test names or UUIDs"),env:C.string().optional(),all:C.boolean().optional(),urlOverride:C.string().optional(),customHeaders:C.record(C.string(),C.string()).optional(),testInputMatrix:C.record(C.string(),C.string()).array().optional()}),Pg=C.object({queuedTests:C.unknown().array(),runIds:C.string().uuid().array(),runGroupId:C.string().optional()});var I$=C.string().array(),P$=C.union([C.object({paths:C.string().array().describe("run specific test paths (e.g. todo-test)"),all:C.boolean().describe("run all tests").optional()}),C.object({path:C.string().describe("deprecated; present for backcompat")})]),Lg=C.object({tests:C.record(C.string().describe("Test name"),C.string().describe("Test YAML")),modules:C.record(C.string().describe("Module name"),C.string().describe("Module YAML"))}),rA=C.object({test:C.string().describe("test YAML"),modules:C.record(C.string().describe("moduleId"),C.string().describe("module YAML"))}),L$=rA.array(),O$=C.object({testId:C.string(),schemaVersion:C.string()}).merge(Mr),M$=C.object({entries:C.array(jc),testId:C.string()}),N$=C.object({testId:C.string(),uniqueKeys:C.string().array()}),k$=C.object({steps:C.array(C.record(C.unknown())),testId:C.string(),schemaVersion:C.string()});function oA(n){return C.record(C.unknown()).transform(e=>{let t={};for(let[r,o]of Object.entries(e)){let i=n.safeParse(o);i.success&&(t[r]=i.data)}return t})}var Og=oA($c),Mg=C.object({trigger:C.nativeEnum(Kt),status:C.nativeEnum(ae),startedAt:C.coerce.date().optional(),gitCommitSha:C.string().optional(),gitCommitShaShort:C.string().optional(),gitCommitTimestamp:C.coerce.date().optional(),gitBranchName:C.string().optional(),gitOriginUrl:C.string().optional(),gitCommitMessage:C.string().optional(),gitCommitAuthorName:C.string().optional(),githubRepository:C.string().optional(),gitlabProjectPath:C.string().optional(),pipelineId:C.string().optional(),cliVersion:C.string().optional()}),_$=C.object({id:C.string()}),Ng=C.object({status:C.nativeEnum(ae),updatedAt:C.coerce.date().optional(),finishedAt:C.coerce.date().optional()}),kg=C.object({stepsSnapshot:C.array(C.record(C.unknown())).optional(),runGroupId:C.string().optional(),testId:C.string(),testName:C.string(),resolvedBaseUrl:C.string().optional(),environmentName:C.string().optional(),labels:C.array(C.string()).optional(),cliVersion:C.string().optional(),trigger:C.nativeEnum(Kt),schemaVersion:C.string().optional(),section:C.nativeEnum(Ps).optional()}),D$=C.object({id:C.string()}),iA=dd.pick({id:!0,status:!0,testName:!0,testId:!0,test:!0,failureReason:!0,failureDetails:!0}),_g=iA.array(),Dg=dd.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(),F$=C.object({id:C.string()}),Fg=C.object({status:C.nativeEnum(ae),finishedAt:C.coerce.date().optional(),schemaVersion:C.string().optional().default("1.0.19"),results:C.record(C.string(),C.unknown()).array().optional(),beforeResults:C.record(C.string(),C.unknown()).array().optional(),afterResults:C.record(C.string(),C.unknown()).array().optional()}),U$=C.object({screenshot:C.string()}),Ug=C.object({key:C.string()}),Bg=C.object({orgId:C.string(),userId:C.string()}),zg=C.array(ih),B$=C.record(C.string(),C.union([C.string(),C.boolean()])),z$=C.object({paths:C.string().array(),env:C.string().optional(),urlOverride:C.string().optional(),customHeaders:C.record(C.string(),C.string()).optional()}),Hg=C.object({suiteRunIds:C.string().array(),runGroupIds:C.string().array()}),H$=C.object({suiteRunIds:C.string().array()}),j$=wh.array(),$$=C.object({runGroupIds:C.string().array()}),sa=C.object({uploadUrl:C.string()}),G$=Jt.merge(Ph),W$=Jt.merge(Oh),V$=Jt.merge(Lh),aA=C.object({testId:C.string().optional().default(""),testName:C.string().optional().default(""),suiteId:C.string().optional().default(""),suiteName:C.string().optional().default(""),creditsUsed:C.number().optional(),usedBy:C.string().optional()}),sA=C.object({transactionId:C.string(),timestamp:C.string(),event:C.nativeEnum(ta),properties:aA}),q$=sA.array(),jg=ch.omit({steps:!0}).extend({steps:C.array(C.record(C.string(),C.unknown())).describe("unparsed ResolvedStep[]")}),K$=C.object({limit:C.number().max(10).optional(),afterTime:C.number().optional()}),$g=gh.array(),Y$=C.object({applied:C.boolean().optional(),appliedAt:C.coerce.date().optional()}),Gg=sa.extend({id:C.string()}),J$=C.object({runGroupId:C.string().uuid().optional()}),Wg=C.object({runGroupId:C.string().uuid()});import{z as Ne}from"zod";var Vg=Ne.object({orgId:Ne.string(),cacheKeys:Ne.string().array()}),Z$=Ne.object({keyParams:Vg,clientMetadata:Ne.string(),lockAcquisitionTimeoutMs:Ne.number().optional()}),qg=Ne.object({acquired:Ne.boolean(),acquiredByMetadata:Ne.string(),keyPrefix:Ne.string()}),eG=Ne.object({keyPrefix:Ne.string(),result:Ne.string(),ttlMs:Ne.number()}),tG=Ne.union([Ne.object({keyPrefix:Ne.string()}),Vg]),lA=Ne.object({remainingTtlMs:Ne.number(),value:Ne.string().nullish()}),nG=Ne.object({results:Ne.record(Ne.string(),lA),activeLocks:Ne.string().array()}),Kg=0,Yg=5*60*1e3;import{z as dn}from"zod";var Jg="test",Xg="module",_t=(t=>(t.TEST=`${Jg}.yaml`,t.MODULE=`${Xg}.yaml`,t))(_t||{}),ve=(t=>(t.TEST=`momentic/${Jg}`,t.MODULE=`momentic/${Xg}`,t))(ve||{}),cG=ht.merge(Mr),Ld=Lt.extend({steps:dn.array(dn.record(dn.string(),dn.unknown())),schemaVersion:dn.string()}),dG=Ld.extend({fileType:dn.literal(ve.MODULE)}),pG=dn.object({test:dn.string().describe("YAML for the test, including metadata and steps"),modules:dn.record(dn.string(),dn.string()).describe("Map of module name to YAML for the module")});import{z as st}from"zod";var cA=st.object({version:st.string(),json:st.record(st.unknown()),hash:st.string()}),Qg=st.record(st.unknown()),gG=st.object({newSvgs:st.array(cA),metadata:Qg.optional()}),dA=st.object({version:st.string(),json:st.record(st.unknown()).nullish(),hash:st.string(),description:st.string().nullish(),metadata:Qg.nullish()}),Zg=st.record(st.string().describe("icon hash"),dA);import{validator as wG}from"@exodus/schemasafe";var ef=n=>{n.extraHeaders&&(n.extraHeaders=Object.fromEntries(Object.entries(n.extraHeaders).filter(([e,t])=>e.trim()&&t.trim())))};import{z as MG}from"zod";import{z as Xe}from"zod";var _G=Xe.object({repositoriesIndexed:Xe.boolean(),indexingInProgress:Xe.boolean(),indexesOutdated:Xe.boolean()}),tf=(a=>(a.Queued="queued",a.InProgress="in_progress",a.Completed="completed",a.Waiting="waiting",a.Requested="requested",a.Pending="pending",a))(tf||{}),nf=(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))(nf||{}),DG=Xe.object({name:Xe.string(),status:Xe.nativeEnum(tf),conclusion:Xe.nativeEnum(nf).nullable()}),la=Xe.object({sha:Xe.string(),message:Xe.string(),author:Xe.object({name:Xe.string().optional(),email:Xe.string().optional(),date:Xe.coerce.date().optional()}),committer:Xe.object({name:Xe.string().optional(),email:Xe.string().optional(),date:Xe.coerce.date().optional()})});import{z as _e}from"zod";var Od=_e.object({assertion:_e.string().describe("A human readable assertion that evaluates to either true or false depending on the state of the system.")}),pA=_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:Od.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.")}),rf=pA.extend({subSteps:_e.lazy(()=>rf.array().optional()).describe("More granular steps to be take to achieve the current step's higher level objective.")}),of=_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")}),af=of.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)}),zG=af.extend({testGenRuns:_e.tuple([]).or(_e.tuple([_e.object({id:_e.string(),startedAt:_e.coerce.date(),status:_e.nativeEnum(ae)})]))}),sf=_e.object({preConditions:Od.array().nullish().transform(n=>n??[]),postConditions:Od.array().nullish().transform(n=>n??[]),steps:rf.array().nullish().transform(n=>n??[])}),HG=af.extend({plan:sf.nullish().transform(n=>n??{preConditions:[],postConditions:[],steps:[]})}),uA=of.extend({plan:sf.nullish().transform(n=>n??{preConditions:[],postConditions:[],steps:[]})}),jG=uA.array().nullish().transform(n=>n??[]);var qG=90*24*60*60*1e3,KG=14*24*60*60*1e3,YG=7*24*60*60*1e3;import{z as Pe}from"zod";var mA=Pe.object({step:Le,status:Pe.nativeEnum(Re),startedAt:Pe.coerce.date(),finishedAt:Pe.coerce.date().optional(),healMetadata:Pe.object({healType:Pe.nativeEnum(qi).or(Pe.literal("AI")),healedAt:Pe.coerce.date()}).optional(),beforeSnapshotId:Pe.string().uuid().optional(),afterSnapshotId:Pe.string().uuid().optional(),message:Pe.string().optional()}),nW=mA.extend({finishedAt:Pe.coerce.date().optional().transform(n=>n??new Date)}),hA=Pe.object({id:Pe.string().uuid().optional(),startedAt:Pe.coerce.date()}).merge(Fg).merge(Ts),rW=hA.extend({finishedAt:Pe.coerce.date().optional().transform(n=>n??new Date)}),gA=Dg.merge(kg).extend({status:Pe.nativeEnum(ae),startedAt:Pe.coerce.date(),attempts:Pe.number()}),oW=gA.extend({finishedAt:Pe.coerce.date().optional().transform(n=>n??new Date)}),fA=Mg.merge(Ng).extend({id:Pe.string().uuid().optional(),startedAt:Pe.coerce.date(),cliVersion:Pe.string()}),ca=fA.extend({updatedAt:Pe.coerce.date().optional().transform(n=>n??new Date),finishedAt:Pe.coerce.date().optional().transform(n=>n??new Date)});import SA from"semver";import{z as yA}from"zod";var lW=yA.string().refine(n=>SA.valid(n),{message:"must be a valid semver string"});function Md(n){let e={parentChain:[]};return $s(n,e),e}function $s(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||$s({...n,steps:l.steps},e)&&i)return!0;if($s({...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),$s({...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 lf(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!!bA([n],t,i).result}function bA(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 Md({steps:n,earlyStop:!0,onPresetAction:i,onConditional:i,onSimpleStepContainer:i}),{result:r,parentChain:o}}function cf(n,e){e(n);for(let t in n){let r=n[t];r&&(Array.isArray(r)?Gs(r,e):typeof r=="object"&&cf(r,e))}}function Gs(n,e){for(let t of n)t&&(Array.isArray(t)?Gs(t,e):typeof t=="object"&&cf(t,e))}import{cloneDeep as df}from"lodash-es";import{v4 as Nd}from"uuid";async function gt(n){let e=new Map,t=new Set,r=df(n.stepLists.steps),o=await Gr({...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=df(n.stepLists[a]);if(!s)continue;let l=await Gr({...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 Gr({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?Nd():d.id,d.type){case"PRESET_ACTION":{let u=d.command;u.id=l?Nd():u.id,uf(u),"cache"in u&&u.cache&&(r&&(c.cachesToSave=c.cachesToSave.concat(pf({id:u.id,orgId:r.orgId,testId:r.testId,value:Pr.parse(u),moduleIdParents:o,moduleStepParents:i,skipIntermediateEntries:e.skipCacheIntermediateEntries}))),delete u.cache),u.thoughts&&delete u.thoughts,c.stepsToSave.push({...d,command:u});break}case"RESOLVED_MODULE":{let u=l?Nd():d.id,m=d.moduleId;a.has(m)?m=a.get(m):s!==void 0&&(m=await s(d),a.set(d.moduleId,m));let{cachesToSave:h,stepsToSave:g,moduleUpdates:f}=await Gr({...e,steps:d.steps,cacheCreationParams:r?{...r}:void 0,createNewCacheIds:!1,moduleStepParents:[...i,u],moduleIdParents:[...o,m],skipCacheIntermediateEntries:l});c.moduleUpdates=c.moduleUpdates.concat(f),c.cachesToSave=c.cachesToSave.concat(h),t.has(m)||(t.add(m),c.moduleUpdates.push({...Lt.parse(d),steps:we.array().parse(g),moduleId:m}));let S={type:"MODULE",moduleId:m,inputs:d.inputs,id:u,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:u,cachesToSave:m}=await Gr({...e,steps:d.steps});try{d.steps=Pt.array().parse(u)}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(m);break}case"AI_ACTION_DYNAMIC":{c.stepsToSave.push(d);break}case"CONDITIONAL":{let u=[];for(let h of d.blocks){let{stepsToSave:g,cachesToSave:f,moduleUpdates:S}=await Gr({...e,steps:h.steps});u.push({...h,steps:g}),c.cachesToSave=c.cachesToSave.concat(f),c.moduleUpdates=c.moduleUpdates.concat(S)}let m={...d,elseSteps:void 0,blocks:u};if(d.elseSteps){let{stepsToSave:h,cachesToSave:g,moduleUpdates:f}=await Gr({...e,steps:d.elseSteps});m.elseSteps=h,c.cachesToSave=c.cachesToSave.concat(g),c.moduleUpdates=c.moduleUpdates.concat(f)}c.stepsToSave.push(m);break}case"IFRAME":case"SECTION":{let{stepsToSave:u,cachesToSave:m,moduleUpdates:h}=await Gr({...e,steps:d.steps}),g={...d,steps:u};c.moduleUpdates=c.moduleUpdates.concat(h),c.stepsToSave.push(g),c.cachesToSave=c.cachesToSave.concat(m);break}default:return(u=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(d)}return c}function Ho({steps:n,topLevel:e=!0,...t}){let{stepCacheEntries:r,logger:o,keyPrefix:i}=t,a=[],s=[],l=[],c=0,d=(u,m)=>{try{let h=Pr.parse(m.value);if(h.type!==u.type){o.warn({parsedCacheEntry:h,command:u},"Not using step cache due to type mismatch"),s.push(m.key);return}u.cache=h.cache,a.push(m.key),l.push(m.uniqueKey)}catch(h){s.push(m.key),o.error({err:h,cacheEntry:m},"Not using step cache due to parsing error")}},p=(u,m)=>{let h=vA(u.id,m),g=h.find(f=>!!r[f]);if(g)d(u,r[g]);else{if(u.type==="AI_ASSERTION")return;s.push(h[0])}};for(let u of n)switch(u.type){case"RESOLVED_MODULE":{c+=u.steps.length;let{cacheKeysHit:h,cacheKeysMissed:g,uniqueKeysHit:f}=Ho({...t,steps:u.steps,keyPrefix:i?`${i}:${u.id}`:u.id,topLevel:!1});a.push(...h),s.push(...g),l.push(...f);break}case"IFRAME":case"SECTION":case"AI_ACTION":{if(c+=u.steps?.length??0,!u.steps?.length)break;let{cacheKeysHit:h,cacheKeysMissed:g,uniqueKeysHit:f}=Ho({...t,steps:u.steps,topLevel:!1});a.push(...h),s.push(...g),l.push(...f);break}case"AI_ACTION_DYNAMIC":continue;case"PRESET_ACTION":{if(!Oc.includes(u.command.type)||(u.command.type==="TYPE"||u.command.type==="MOUSE_DRAG"||u.command.type==="VISUAL_DIFF"||u.command.type==="SCROLL_DOWN"||u.command.type==="SCROLL_UP"||u.command.type==="SCROLL_LEFT"||u.command.type==="SCROLL_RIGHT")&&!u.command.target||u.command.type==="ELEMENT_CHECK"&&u.command.assertion.type==="ELEMENT_EXISTENCE"&&u.command.assertion.negated||"cache"in u.command&&u.command.cache)continue;c++,p(u.command,i);break}case"CONDITIONAL":{for(let h of u.blocks){c++,p(h.assertion.command,i),c+=h.steps.length;let{cacheKeysHit:g,cacheKeysMissed:f,uniqueKeysHit:S}=Ho({...t,steps:h.steps,topLevel:!1});a.push(...g),s.push(...f),l.push(...S)}if(u.elseSteps){c+=u.elseSteps.length;let{cacheKeysHit:h,cacheKeysMissed:g,uniqueKeysHit:f}=Ho({...t,steps:u.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"})(u)}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 mf(n,e){return e?`${e}:${n}`:n}function vA(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 pf(n){let{moduleStepParents:e=[],moduleIdParents:t=[]}=n;if(e.length!==t.length)throw new Error(`Invalid cache entry parent length: ${JSON.stringify(e)}
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:mf(n.id,a),moduleId:i,organizationId:n.orgId,value:n.value})}return r.push({key:mf(n.id,e.join(":")),organizationId:n.orgId,value:n.value,testId:n.testId}),r}function uf(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 hf(n){let e=new Set;return Gs(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 gf(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 Ws({logger:n,cacheStorage:e,orgId:t,testId:r,originalSteps:o,updatedSteps:i}){let a=wA(o,i);if(Object.keys(a).length>0){n.info({changes:a},"Updating steps caches post-run success");try{let{cachesToSave:s}=await gt({stepLists:i,cacheCreationParams:{testId:r,orgId:t}});await e.saveStepCacheEntries({logger:n,testId:r,entries:s})}catch(s){n.error({err:s},"Failed to save step caches after successful execution. This is not critical, but can impact future performance.")}}}function je(n,e,t=!1){return n.length<e?n:n.slice(0,e-3)+(t?"...TRUNCATED...":"[...]")}var cr={EQUALS:"equals",CONTAINS:"contains",STARTS_WITH:"starts with",EXISTS:"exists"},dr={EQUALS:"does not equal",CONTAINS:"does not contain",STARTS_WITH:"does not start with",EXISTS:"does not exist"},kd={EXISTS:"exists",VISIBLE:"is visible",ENABLED:"is enabled",EDITABLE:"is editable"},_d={EXISTS:"does not exist",VISIBLE:"is not visible",ENABLED:"is disabled",EDITABLE:"is not editable"};function TA(n){switch(n.type){case"ELEMENT_CONTENT":return`${n.negated?dr[n.operation]:cr[n.operation]} '${n.value}'`;case"ELEMENT_ATTRIBUTE":{let t=n.negated?dr[n.operation]:cr[n.operation];return n.operation==="EXISTS"?`attribute '${n.attr}' ${t}`:`attribute '${n.attr}' ${t} '${n.value}'`}case"ELEMENT_EXISTENCE":return n.negated?_d[n.condition]:kd[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 cq={CONTENT:"The page"};function EA(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 Dd(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 xA(n){switch(n.type){case"CONTENT":return`${n.negated?dr.CONTAINS:cr.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 Wr(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: ${je(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: ${ut(n.target)}`:""}`;case"SCROLL_UP":return`Scroll up ${n.deltaY?`${n.deltaY}px`:"1 page height"}${n.target?` in the container of: ${ut(n.target)}`:""}`;case"SCROLL_LEFT":return`Scroll left ${n.deltaX?`${n.deltaX}px`:"1 page width"}${n.target?` in the container of: ${ut(n.target)}`:""}`;case"SCROLL_RIGHT":return`Scroll right ${n.deltaX?`${n.deltaX}px`:"1 page width"}${n.target?` in the container of: ${ut(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: ${ut(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 ${ut(n.target)}`;case"BLUR":return`Focus ${ut(n.target)}`;case"DRAG":return`Drag ${ut(n.fromTarget)} onto ${ut(n.toTarget)}`;case"MOUSE_DRAG":return n.target?.type==="description"&&n.target.elementDescriptor?`Click and drag ${ut(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: ${ut(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: ${ut(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"KEY_DOWN":return`Hold down ${n.value} on the keyboard`;case"KEY_UP":return`Release ${n.value} on the keyboard`;case"SELECT_OPTION":{let t="",r=EA(n.choice);return n.target.type==="coordinates"?t=` from element at coordinates: ${ut(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: ${je(n.code,30)}`;case"AI_ASSERTION":return`Assertion: '${n.assertion}'`;case"VISUAL_DIFF":return`Visual diff against baseline ${n.target?`for element: ${ut(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 ${ut(n.target)} ${TA(n.assertion)}`;case"PAGE_CHECK":return`Check the page ${xA(n.assertion)}`;case"WAIT_FOR_URL":return`Wait for page URL to ${Dd(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";case"RECORD_REQUESTS":return n.pattern?`Start recording requests that match ${n.pattern}`:"Start recording network requests";case"GET_RECORDED_REQUESTS":return n.key?`Get the requests that were recorded for ${n.key}`:"Get the requests that were recorded";case"SET_HEADER":return n.name?n.urlPattern?`Set a ${n.name} header for requests that match ${n.urlPattern}`:`Set a ${n.name} header for all requests`:"Set a header";default:return(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}function ff(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 CA}from"lodash-es";import{cloneDeep as mq,unset as hq}from"lodash-es";function pn(n){switch(n.type){case"AI_ACTION":return`AI action: ${je(n.text,100)}`;case"AI_ACTION_DYNAMIC":return`AI action: ${je(n.text,100)}`;case"PRESET_ACTION":return Wr(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: ${je(n.description,100)}`:""}`;default:return(t=>{throw new Error("You missed a case in the switch above")})(n)}}var Sf=1e3,yf=3e6,RA="[FAILED]";async function bf(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 Vs(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],u=s?Vr(p):pn(p),m={description:`Step ${d}: ${u}`,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"){m.description=`${RA} ${m.description}`,o&&(c=d);try{let h=yh.array().parse(p.details);for(let g of h)"pageState"in g&&a&&(m.pageState=g.pageState)}catch{}}r>0&&d>=t.length-r&&(m.afterScreenshot=await bf(n,e,p.afterScreenshot,p.afterSnapshot),i&&(m.beforeScreenshot=await bf(n,e,p.beforeScreenshot,p.beforeSnapshot))),l.push(m)}return{results:l,failureIndex:c}}function Vr(n){let e=pn(n);switch(n.type){case"AI_ACTION":case"AI_ACTION_DYNAMIC":e+=`
16
- `;for(let t=0;t<n.results.length;t++)e+=Qe(`Sub-step ${t} in AI action:
17
- `,2),e+=`${Qe(Vr(n.results[t]),2)}
18
- `,e+=Qe(`${"=".repeat(10)}
14
+ `)),console.log(" ",t(s))}}setMinLevel(e){this.minLogLevel=e}log(...e){this.logWithLevel(1,In.reset,...e)}info(...e){this.logWithLevel(1,In.white,...e)}debug(...e){this.logWithLevel(0,In.dim,...e)}warn(...e){this.logWithLevel(2,In.yellow,...e)}error(...e){this.logWithLevel(3,In.red,...e)}success(...e){this.logWithLevel(4,In.green,...e)}dimmed(...e){this.logWithLevel(1,In.dim,...e)}underline(...e){this.logWithLevel(2,In.underline,...e)}bold(...e){this.logWithLevel(2,In.bold,...e)}grey(...e){this.logWithLevel(0,In.grey,...e)}child(e){return new n(this.minLogLevel,{...this.logBindings,...e})}flush(){}bindings(){return this.logBindings}},Id=class{debug(){}info(){}warn(){}error(){}success(){}dimmed(){}underline(){}bold(){}grey(){}child(){return this}flush(){}bindings(){return{}}},fg=new Id,b=new Ad(1,{}),jr={info:()=>{},error:()=>{},debug:()=>{},warn:()=>{},child:()=>jr,flush:()=>{},bindings:()=>({})},Gs={},$r=({logger:n,logKey:e,maxCount:t,intervalMs:r},o,i,...a)=>{let s=Gs[e];s?clearTimeout(s.timer):(s={count:0,totalCount:0},Gs[e]=s),s.totalCount++,s.count<t&&(s.count++,n.debug(o,i,...a)),s.timer=setTimeout(()=>{let l=Gs[e];l?.totalCount!==l?.count&&n.debug({logKey:e,totalCount:l?.totalCount,count:l?.count},`Debug logs were rate-limited for ${e}`),delete Gs[e]},r)};import{z as He}from"zod";var Sg=He.object({id:He.string(),createdAt:He.coerce.date(),createdBy:He.string(),organizationId:He.string(),name:He.string(),description:He.string().nullish(),enabled:He.boolean(),schemaVersion:He.string().describe("Schema version for steps"),parameters:He.string().array().nullish().describe("Parameter list"),parameterEnums:He.record(He.string(),He.string().array()).nullish(),defaultParameters:He.record(He.string(),He.string()).nullish(),defaultCacheKey:He.string().nullish(),defaultCacheTtl:He.number().nullish(),defaultCacheAllInvocations:He.boolean().nullish(),autoAuth:He.boolean().nullish(),advanced:Fc.nullish()}),Zj=Sg.extend({steps:He.lazy(()=>we.array())}),yg=5*60*1e3,Pd=Lt.merge(Sg.omit({id:!0,createdAt:!0,createdBy:!0,organizationId:!0,enabled:!0}));import{formatInTimeZone as t$}from"date-fns-tz";import{z as qe}from"zod";var Ld=pd.extend({aiAction:qe.boolean().optional(),stepLintSuggestions:qe.boolean().optional(),agentConfig:qe.record(qe.string(),qe.string()).optional(),aiPageFiltering:qe.boolean().optional().describe("rag v2 feature flag")}),bg=qe.object({fakerConstantSeed:qe.boolean().optional()}),a$=qe.object({ai:Ld.optional(),githubAppInstallationId:qe.number().nullish(),githubReleaseAppInstallationId:qe.number().nullish(),gitlabAppAccessToken:qe.string().nullish().optional(),gitlabAppBaseUrl:qe.string().nullish().optional(),qaseAccessToken:qe.string().nullish().optional(),browser:od.optional()}),s$=qe.object({globalOverrides:qe.record(qe.string()).optional(),agentConfig:qe.record(qe.string(),qe.string()).optional()});import*as C from"zod";var wg="x-momentic-cli-version",vg="x-momentic-main-branch-name",Eg="x-momentic-branch-name",Tg="x-momentic-commit-timestamp",xg="x-momentic-last-commit-on-main",Cg="x-momentic-last-commit-on-main-timestamp",E$=C.object({error:C.boolean(),reason:C.string(),message:C.string()}),T$=Jt.merge(hd),Rg=rs,x$=Jt.merge(hd);var C$=Jt.merge(Ih).extend({useConsensus:C.boolean().optional(),attemptNumber:C.number().optional()}),Od=sm,R$=Jt.merge(Ph),Ag=bm,A$=Jt.merge(Ch),Ig=ym,I$=Jt.merge(Rh),Pg=Sm,P$=Jt.merge(Ah);var L$=C.object({testPaths:C.string().array().describe("can be either hyphenated, lowercase test names or UUIDs"),env:C.string().optional(),all:C.boolean().optional(),urlOverride:C.string().optional(),customHeaders:C.record(C.string(),C.string()).optional(),testInputMatrix:C.record(C.string(),C.string()).array().optional()}),Lg=C.object({queuedTests:C.unknown().array(),runIds:C.string().uuid().array(),runGroupId:C.string().optional()});var O$=C.string().array(),M$=C.union([C.object({paths:C.string().array().describe("run specific test paths (e.g. todo-test)"),all:C.boolean().describe("run all tests").optional()}),C.object({path:C.string().describe("deprecated; present for backcompat")})]),Og=C.object({tests:C.record(C.string().describe("Test name"),C.string().describe("Test YAML")),modules:C.record(C.string().describe("Module name"),C.string().describe("Module YAML"))}),aA=C.object({test:C.string().describe("test YAML"),modules:C.record(C.string().describe("moduleId"),C.string().describe("module YAML"))}),N$=aA.array(),k$=C.object({testId:C.string(),schemaVersion:C.string()}).merge(Mr),_$=C.object({entries:C.array(Gc),testId:C.string()}),D$=C.object({testId:C.string(),uniqueKeys:C.string().array()}),F$=C.object({steps:C.array(C.record(C.unknown())),testId:C.string(),schemaVersion:C.string()});function sA(n){return C.record(C.unknown()).transform(e=>{let t={};for(let[r,o]of Object.entries(e)){let i=n.safeParse(o);i.success&&(t[r]=i.data)}return t})}var Mg=sA(Wc),Ng=C.object({trigger:C.nativeEnum(Kt),status:C.nativeEnum(se),startedAt:C.coerce.date().optional(),gitCommitSha:C.string().optional(),gitCommitShaShort:C.string().optional(),gitCommitTimestamp:C.coerce.date().optional(),gitBranchName:C.string().optional(),gitOriginUrl:C.string().optional(),gitCommitMessage:C.string().optional(),gitCommitAuthorName:C.string().optional(),githubRepository:C.string().optional(),gitlabProjectPath:C.string().optional(),pipelineId:C.string().optional(),cliVersion:C.string().optional()}),U$=C.object({id:C.string()}),kg=C.object({status:C.nativeEnum(se),updatedAt:C.coerce.date().optional(),finishedAt:C.coerce.date().optional()}),_g=C.object({stepsSnapshot:C.array(C.record(C.unknown())).optional(),runGroupId:C.string().optional(),testId:C.string(),testName:C.string(),resolvedBaseUrl:C.string().optional(),environmentName:C.string().optional(),labels:C.array(C.string()).optional(),cliVersion:C.string().optional(),trigger:C.nativeEnum(Kt),schemaVersion:C.string().optional(),section:C.nativeEnum(Ps).optional()}),B$=C.object({id:C.string()}),lA=ud.pick({id:!0,status:!0,testName:!0,testId:!0,test:!0,failureReason:!0,failureDetails:!0}),Dg=lA.array(),Fg=ud.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(),z$=C.object({id:C.string()}),Ug=C.object({status:C.nativeEnum(se),finishedAt:C.coerce.date().optional(),schemaVersion:C.string().optional().default("1.0.19"),results:C.record(C.string(),C.unknown()).array().optional(),beforeResults:C.record(C.string(),C.unknown()).array().optional(),afterResults:C.record(C.string(),C.unknown()).array().optional()}),H$=C.object({screenshot:C.string()}),Bg=C.object({key:C.string()}),zg=C.object({orgId:C.string(),userId:C.string()}),Hg=C.array(ah),j$=C.record(C.string(),C.union([C.string(),C.boolean()])),$$=C.object({paths:C.string().array(),env:C.string().optional(),urlOverride:C.string().optional(),customHeaders:C.record(C.string(),C.string()).optional()}),jg=C.object({suiteRunIds:C.string().array(),runGroupIds:C.string().array()}),G$=C.object({suiteRunIds:C.string().array()}),W$=vh.array(),V$=C.object({runGroupIds:C.string().array()}),sa=C.object({uploadUrl:C.string()}),q$=Jt.merge(Lh),K$=Jt.merge(Mh),Y$=Jt.merge(Oh),cA=C.object({testId:C.string().optional().default(""),testName:C.string().optional().default(""),suiteId:C.string().optional().default(""),suiteName:C.string().optional().default(""),creditsUsed:C.number().optional(),usedBy:C.string().optional()}),dA=C.object({transactionId:C.string(),timestamp:C.string(),event:C.nativeEnum(ta),properties:cA}),J$=dA.array(),$g=dh.omit({steps:!0}).extend({steps:C.array(C.record(C.string(),C.unknown())).describe("unparsed ResolvedStep[]")}),X$=C.object({limit:C.number().max(10).optional(),afterTime:C.number().optional()}),Gg=fh.array(),Z$=C.object({applied:C.boolean().optional(),appliedAt:C.coerce.date().optional()}),Wg=sa.extend({id:C.string()}),Q$=C.object({runGroupId:C.string().uuid().optional()}),Vg=C.object({runGroupId:C.string().uuid()});import{z as Ne}from"zod";var qg=Ne.object({orgId:Ne.string(),cacheKeys:Ne.string().array()}),nG=Ne.object({keyParams:qg,clientMetadata:Ne.string(),lockAcquisitionTimeoutMs:Ne.number().optional()}),Kg=Ne.object({acquired:Ne.boolean(),acquiredByMetadata:Ne.string(),keyPrefix:Ne.string()}),rG=Ne.object({keyPrefix:Ne.string(),result:Ne.string(),ttlMs:Ne.number()}),oG=Ne.union([Ne.object({keyPrefix:Ne.string()}),qg]),pA=Ne.object({remainingTtlMs:Ne.number(),value:Ne.string().nullish()}),iG=Ne.object({results:Ne.record(Ne.string(),pA),activeLocks:Ne.string().array()}),Yg=0,Jg=5*60*1e3;import{z as dn}from"zod";var Xg="test",Zg="module",_t=(t=>(t.TEST=`${Xg}.yaml`,t.MODULE=`${Zg}.yaml`,t))(_t||{}),ve=(t=>(t.TEST=`momentic/${Xg}`,t.MODULE=`momentic/${Zg}`,t))(ve||{}),uG=ht.merge(Mr),Md=Lt.extend({steps:dn.array(dn.record(dn.string(),dn.unknown())),schemaVersion:dn.string()}),mG=Md.extend({fileType:dn.literal(ve.MODULE)}),hG=dn.object({test:dn.string().describe("YAML for the test, including metadata and steps"),modules:dn.record(dn.string(),dn.string()).describe("Map of module name to YAML for the module")});import{z as st}from"zod";var uA=st.object({version:st.string(),json:st.record(st.unknown()),hash:st.string()}),Qg=st.record(st.unknown()),yG=st.object({newSvgs:st.array(uA),metadata:Qg.optional()}),mA=st.object({version:st.string(),json:st.record(st.unknown()).nullish(),hash:st.string(),description:st.string().nullish(),metadata:Qg.nullish()}),ef=st.record(st.string().describe("icon hash"),mA);import{validator as TG}from"@exodus/schemasafe";var tf=n=>{n.extraHeaders&&(n.extraHeaders=Object.fromEntries(Object.entries(n.extraHeaders).filter(([e,t])=>e.trim()&&t.trim())))};import{z as _G}from"zod";import{z as Xe}from"zod";var UG=Xe.object({repositoriesIndexed:Xe.boolean(),indexingInProgress:Xe.boolean(),indexesOutdated:Xe.boolean()}),nf=(a=>(a.Queued="queued",a.InProgress="in_progress",a.Completed="completed",a.Waiting="waiting",a.Requested="requested",a.Pending="pending",a))(nf||{}),rf=(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))(rf||{}),BG=Xe.object({name:Xe.string(),status:Xe.nativeEnum(nf),conclusion:Xe.nativeEnum(rf).nullable()}),la=Xe.object({sha:Xe.string(),message:Xe.string(),author:Xe.object({name:Xe.string().optional(),email:Xe.string().optional(),date:Xe.coerce.date().optional()}),committer:Xe.object({name:Xe.string().optional(),email:Xe.string().optional(),date:Xe.coerce.date().optional()})});import{z as _e}from"zod";var Nd=_e.object({assertion:_e.string().describe("A human readable assertion that evaluates to either true or false depending on the state of the system.")}),hA=_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:Nd.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.")}),of=hA.extend({subSteps:_e.lazy(()=>of.array().optional()).describe("More granular steps to be take to achieve the current step's higher level objective.")}),af=_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")}),sf=af.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)}),$G=sf.extend({testGenRuns:_e.tuple([]).or(_e.tuple([_e.object({id:_e.string(),startedAt:_e.coerce.date(),status:_e.nativeEnum(se)})]))}),lf=_e.object({preConditions:Nd.array().nullish().transform(n=>n??[]),postConditions:Nd.array().nullish().transform(n=>n??[]),steps:of.array().nullish().transform(n=>n??[])}),GG=sf.extend({plan:lf.nullish().transform(n=>n??{preConditions:[],postConditions:[],steps:[]})}),gA=af.extend({plan:lf.nullish().transform(n=>n??{preConditions:[],postConditions:[],steps:[]})}),WG=gA.array().nullish().transform(n=>n??[]);var JG=90*24*60*60*1e3,XG=14*24*60*60*1e3,ZG=7*24*60*60*1e3;import{z as Pe}from"zod";var fA=Pe.object({step:Le,status:Pe.nativeEnum(Re),startedAt:Pe.coerce.date(),finishedAt:Pe.coerce.date().optional(),healMetadata:Pe.object({healType:Pe.nativeEnum(qi).or(Pe.literal("AI")),healedAt:Pe.coerce.date()}).optional(),beforeSnapshotId:Pe.string().uuid().optional(),afterSnapshotId:Pe.string().uuid().optional(),message:Pe.string().optional()}),iW=fA.extend({finishedAt:Pe.coerce.date().optional().transform(n=>n??new Date)}),SA=Pe.object({id:Pe.string().uuid().optional(),startedAt:Pe.coerce.date()}).merge(Ug).merge(Es),aW=SA.extend({finishedAt:Pe.coerce.date().optional().transform(n=>n??new Date)}),yA=Fg.merge(_g).extend({status:Pe.nativeEnum(se),startedAt:Pe.coerce.date(),attempts:Pe.number()}),sW=yA.extend({finishedAt:Pe.coerce.date().optional().transform(n=>n??new Date)}),bA=Ng.merge(kg).extend({id:Pe.string().uuid().optional(),startedAt:Pe.coerce.date(),cliVersion:Pe.string()}),ca=bA.extend({updatedAt:Pe.coerce.date().optional().transform(n=>n??new Date),finishedAt:Pe.coerce.date().optional().transform(n=>n??new Date)});import wA from"semver";import{z as vA}from"zod";var pW=vA.string().refine(n=>wA.valid(n),{message:"must be a valid semver string"});function kd(n){let e={parentChain:[]};return Ws(n,e),e}function Ws(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||Ws({...n,steps:l.steps},e)&&i)return!0;if(Ws({...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),Ws({...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 cf(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!!EA([n],t,i).result}function EA(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 kd({steps:n,earlyStop:!0,onPresetAction:i,onConditional:i,onSimpleStepContainer:i}),{result:r,parentChain:o}}function df(n,e){e(n);for(let t in n){let r=n[t];r&&(Array.isArray(r)?Vs(r,e):typeof r=="object"&&df(r,e))}}function Vs(n,e){for(let t of n)t&&(Array.isArray(t)?Vs(t,e):typeof t=="object"&&df(t,e))}import{cloneDeep as pf}from"lodash-es";import{v4 as _d}from"uuid";async function gt(n){let e=new Map,t=new Set,r=pf(n.stepLists.steps),o=await Gr({...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=pf(n.stepLists[a]);if(!s)continue;let l=await Gr({...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 Gr({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?_d():d.id,d.type){case"PRESET_ACTION":{let u=d.command;u.id=l?_d():u.id,mf(u),"cache"in u&&u.cache&&(r&&(c.cachesToSave=c.cachesToSave.concat(uf({id:u.id,orgId:r.orgId,testId:r.testId,value:Pr.parse(u),moduleIdParents:o,moduleStepParents:i,skipIntermediateEntries:e.skipCacheIntermediateEntries}))),delete u.cache),u.thoughts&&delete u.thoughts,c.stepsToSave.push({...d,command:u});break}case"RESOLVED_MODULE":{let u=l?_d():d.id,m=d.moduleId;a.has(m)?m=a.get(m):s!==void 0&&(m=await s(d),a.set(d.moduleId,m));let{cachesToSave:h,stepsToSave:g,moduleUpdates:f}=await Gr({...e,steps:d.steps,cacheCreationParams:r?{...r}:void 0,createNewCacheIds:!1,moduleStepParents:[...i,u],moduleIdParents:[...o,m],skipCacheIntermediateEntries:l});c.moduleUpdates=c.moduleUpdates.concat(f),c.cachesToSave=c.cachesToSave.concat(h),t.has(m)||(t.add(m),c.moduleUpdates.push({...Lt.parse(d),steps:we.array().parse(g),moduleId:m}));let S={type:"MODULE",moduleId:m,inputs:d.inputs,id:u,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:u,cachesToSave:m}=await Gr({...e,steps:d.steps});try{d.steps=Pt.array().parse(u)}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(m);break}case"AI_ACTION_DYNAMIC":{c.stepsToSave.push(d);break}case"CONDITIONAL":{let u=[];for(let h of d.blocks){let{stepsToSave:g,cachesToSave:f,moduleUpdates:S}=await Gr({...e,steps:h.steps});u.push({...h,steps:g}),c.cachesToSave=c.cachesToSave.concat(f),c.moduleUpdates=c.moduleUpdates.concat(S)}let m={...d,elseSteps:void 0,blocks:u};if(d.elseSteps){let{stepsToSave:h,cachesToSave:g,moduleUpdates:f}=await Gr({...e,steps:d.elseSteps});m.elseSteps=h,c.cachesToSave=c.cachesToSave.concat(g),c.moduleUpdates=c.moduleUpdates.concat(f)}c.stepsToSave.push(m);break}case"IFRAME":case"SECTION":{let{stepsToSave:u,cachesToSave:m,moduleUpdates:h}=await Gr({...e,steps:d.steps}),g={...d,steps:u};c.moduleUpdates=c.moduleUpdates.concat(h),c.stepsToSave.push(g),c.cachesToSave=c.cachesToSave.concat(m);break}default:return(u=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(d)}return c}function Ho({steps:n,topLevel:e=!0,...t}){let{stepCacheEntries:r,logger:o,keyPrefix:i}=t,a=[],s=[],l=[],c=0,d=(u,m)=>{try{let h=Pr.parse(m.value);if(h.type!==u.type){o.warn({parsedCacheEntry:h,command:u},"Not using step cache due to type mismatch"),s.push(m.key);return}u.cache=h.cache,a.push(m.key),l.push(m.uniqueKey)}catch(h){s.push(m.key),o.error({err:h,cacheEntry:m},"Not using step cache due to parsing error")}},p=(u,m)=>{let h=xA(u.id,m),g=h.find(f=>!!r[f]);if(g)d(u,r[g]);else{if(u.type==="AI_ASSERTION")return;s.push(h[0])}};for(let u of n)switch(u.type){case"RESOLVED_MODULE":{c+=u.steps.length;let{cacheKeysHit:h,cacheKeysMissed:g,uniqueKeysHit:f}=Ho({...t,steps:u.steps,keyPrefix:i?`${i}:${u.id}`:u.id,topLevel:!1});a.push(...h),s.push(...g),l.push(...f);break}case"IFRAME":case"SECTION":case"AI_ACTION":{if(c+=u.steps?.length??0,!u.steps?.length)break;let{cacheKeysHit:h,cacheKeysMissed:g,uniqueKeysHit:f}=Ho({...t,steps:u.steps,topLevel:!1});a.push(...h),s.push(...g),l.push(...f);break}case"AI_ACTION_DYNAMIC":continue;case"PRESET_ACTION":{if(!Nc.includes(u.command.type)||(u.command.type==="TYPE"||u.command.type==="MOUSE_DRAG"||u.command.type==="VISUAL_DIFF"||u.command.type==="SCROLL_DOWN"||u.command.type==="SCROLL_UP"||u.command.type==="SCROLL_LEFT"||u.command.type==="SCROLL_RIGHT")&&!u.command.target||u.command.type==="ELEMENT_CHECK"&&u.command.assertion.type==="ELEMENT_EXISTENCE"&&u.command.assertion.negated||"cache"in u.command&&u.command.cache)continue;c++,p(u.command,i);break}case"CONDITIONAL":{for(let h of u.blocks){c++,p(h.assertion.command,i),c+=h.steps.length;let{cacheKeysHit:g,cacheKeysMissed:f,uniqueKeysHit:S}=Ho({...t,steps:h.steps,topLevel:!1});a.push(...g),s.push(...f),l.push(...S)}if(u.elseSteps){c+=u.elseSteps.length;let{cacheKeysHit:h,cacheKeysMissed:g,uniqueKeysHit:f}=Ho({...t,steps:u.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"})(u)}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 hf(n,e){return e?`${e}:${n}`:n}function xA(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 uf(n){let{moduleStepParents:e=[],moduleIdParents:t=[]}=n;if(e.length!==t.length)throw new Error(`Invalid cache entry parent length: ${JSON.stringify(e)}
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:hf(n.id,a),moduleId:i,organizationId:n.orgId,value:n.value})}return r.push({key:hf(n.id,e.join(":")),organizationId:n.orgId,value:n.value,testId:n.testId}),r}function mf(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 gf(n){let e=new Set;return Vs(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 ff(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 qs({logger:n,cacheStorage:e,orgId:t,testId:r,originalSteps:o,updatedSteps:i}){let a=TA(o,i);if(Object.keys(a).length>0){n.info({changes:a},"Updating steps caches post-run success");try{let{cachesToSave:s}=await gt({stepLists:i,cacheCreationParams:{testId:r,orgId:t}});await e.saveStepCacheEntries({logger:n,testId:r,entries:s})}catch(s){n.error({err:s},"Failed to save step caches after successful execution. This is not critical, but can impact future performance.")}}}function je(n,e,t=!1){return n.length<e?n:n.slice(0,e-3)+(t?"...TRUNCATED...":"[...]")}var dr={EQUALS:"equals",CONTAINS:"contains",STARTS_WITH:"starts with",EXISTS:"exists"},pr={EQUALS:"does not equal",CONTAINS:"does not contain",STARTS_WITH:"does not start with",EXISTS:"does not exist"},Dd={EXISTS:"exists",VISIBLE:"is visible",ENABLED:"is enabled",EDITABLE:"is editable"},Fd={EXISTS:"does not exist",VISIBLE:"is not visible",ENABLED:"is disabled",EDITABLE:"is not editable"};function CA(n){switch(n.type){case"ELEMENT_CONTENT":return`${n.negated?pr[n.operation]:dr[n.operation]} '${n.value}'`;case"ELEMENT_ATTRIBUTE":{let t=n.negated?pr[n.operation]:dr[n.operation];return n.operation==="EXISTS"?`attribute '${n.attr}' ${t}`:`attribute '${n.attr}' ${t} '${n.value}'`}case"ELEMENT_EXISTENCE":return n.negated?Fd[n.condition]:Dd[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 uq={CONTENT:"The page"};function RA(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 Ud(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 AA(n){switch(n.type){case"CONTENT":return`${n.negated?pr.CONTAINS:dr.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 Wr(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: ${je(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: ${ut(n.target)}`:""}`;case"SCROLL_UP":return`Scroll up ${n.deltaY?`${n.deltaY}px`:"1 page height"}${n.target?` in the container of: ${ut(n.target)}`:""}`;case"SCROLL_LEFT":return`Scroll left ${n.deltaX?`${n.deltaX}px`:"1 page width"}${n.target?` in the container of: ${ut(n.target)}`:""}`;case"SCROLL_RIGHT":return`Scroll right ${n.deltaX?`${n.deltaX}px`:"1 page width"}${n.target?` in the container of: ${ut(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: ${ut(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 ${ut(n.target)}`;case"BLUR":return`Focus ${ut(n.target)}`;case"DRAG":return`Drag ${ut(n.fromTarget)} onto ${ut(n.toTarget)}`;case"MOUSE_DRAG":return n.target?.type==="description"&&n.target.elementDescriptor?`Click and drag ${ut(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: ${ut(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: ${ut(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"KEY_DOWN":return`Hold down ${n.value} on the keyboard`;case"KEY_UP":return`Release ${n.value} on the keyboard`;case"SELECT_OPTION":{let t="",r=RA(n.choice);return n.target.type==="coordinates"?t=` from element at coordinates: ${ut(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: ${je(n.code,30)}`;case"AI_ASSERTION":return`Assertion: '${n.assertion}'`;case"VISUAL_DIFF":return`Visual diff against baseline ${n.target?`for element: ${ut(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 ${ut(n.target)} ${CA(n.assertion)}`;case"PAGE_CHECK":return`Check the page ${AA(n.assertion)}`;case"WAIT_FOR_URL":return`Wait for page URL to ${Ud(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";case"RECORD_REQUESTS":return n.pattern?`Start recording requests that match ${n.pattern}`:"Start recording network requests";case"GET_RECORDED_REQUESTS":return n.key?`Get the requests that were recorded for ${n.key}`:"Get the requests that were recorded";case"SET_HEADER":return n.name?n.urlPattern?`Set a ${n.name} header for requests that match ${n.urlPattern}`:`Set a ${n.name} header for all requests`:"Set a header";default:return(t=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(n)}}function Sf(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 IA}from"lodash-es";import{cloneDeep as fq,unset as Sq}from"lodash-es";function pn(n){switch(n.type){case"AI_ACTION":return`AI action: ${je(n.text,100)}`;case"AI_ACTION_DYNAMIC":return`AI action: ${je(n.text,100)}`;case"PRESET_ACTION":return Wr(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: ${je(n.description,100)}`:""}`;default:return(t=>{throw new Error("You missed a case in the switch above")})(n)}}var yf=1e3,bf=3e6,PA="[FAILED]";async function wf(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 Ks(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],u=s?Vr(p):pn(p),m={description:`Step ${d}: ${u}`,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"){m.description=`${PA} ${m.description}`,o&&(c=d);try{let h=bh.array().parse(p.details);for(let g of h)"pageState"in g&&a&&(m.pageState=g.pageState)}catch{}}r>0&&d>=t.length-r&&(m.afterScreenshot=await wf(n,e,p.afterScreenshot,p.afterSnapshot),i&&(m.beforeScreenshot=await wf(n,e,p.beforeScreenshot,p.beforeSnapshot))),l.push(m)}return{results:l,failureIndex:c}}function Vr(n){let e=pn(n);switch(n.type){case"AI_ACTION":case"AI_ACTION_DYNAMIC":e+=`
16
+ `;for(let t=0;t<n.results.length;t++)e+=Ze(`Sub-step ${t} in AI action:
17
+ `,2),e+=`${Ze(Vr(n.results[t]),2)}
18
+ `,e+=Ze(`${"=".repeat(10)}
19
19
  `,2);return e;case"PRESET_ACTION":return e;case"MODULE":{e+=`
20
- `;for(let t=0;t<n.results.length;t++)e+=Qe(`Sub-step ${t} in module:
21
- `,2),e+=`${Qe(Vr(n.results[t]),2)}
22
- `,e+=Qe(`${"=".repeat(10)}
20
+ `;for(let t=0;t<n.results.length;t++)e+=Ze(`Sub-step ${t} in module:
21
+ `,2),e+=`${Ze(Vr(n.results[t]),2)}
22
+ `,e+=Ze(`${"=".repeat(10)}
23
23
  `,2);return e}case"CONDITIONAL":{e+=`
24
- `,n.assertion&&(e+=Qe(`Conditional check:
25
- `,2),e+=`${Qe(Vr(n.assertion),2)}
26
- `,e+=Qe(`${"=".repeat(10)}
27
- `,2)),e+=Qe(`${n.assertion?"Branch steps":"Else branch steps"}
28
- `,2);for(let t=0;t<n.results.length;t++)e+=Qe(`Sub-step ${t} in conditional branch:
29
- `,2),e+=`${Qe(Vr(n.results[t]),2)}
30
- `,e+=Qe(`${"=".repeat(10)}
24
+ `,n.assertion&&(e+=Ze(`Conditional check:
25
+ `,2),e+=`${Ze(Vr(n.assertion),2)}
26
+ `,e+=Ze(`${"=".repeat(10)}
27
+ `,2)),e+=Ze(`${n.assertion?"Branch steps":"Else branch steps"}
28
+ `,2);for(let t=0;t<n.results.length;t++)e+=Ze(`Sub-step ${t} in conditional branch:
29
+ `,2),e+=`${Ze(Vr(n.results[t]),2)}
30
+ `,e+=Ze(`${"=".repeat(10)}
31
31
  `,2);return e}case"IFRAME":{e+=`
32
- `;for(let t=0;t<n.results.length;t++)e+=Qe(`Sub-step ${t} in frame step:
33
- `,2),e+=`${Qe(Vr(n.results[t]),2)}
34
- `,e+=Qe(`${"=".repeat(10)}
32
+ `;for(let t=0;t<n.results.length;t++)e+=Ze(`Sub-step ${t} in frame step:
33
+ `,2),e+=`${Ze(Vr(n.results[t]),2)}
34
+ `,e+=Ze(`${"=".repeat(10)}
35
35
  `,2);return e}case"SECTION":{e+=`
36
- `;for(let t=0;t<n.results.length;t++)e+=Qe(`Sub-step ${t} in section:
37
- `,2),e+=`${Qe(Vr(n.results[t]),2)}
38
- `,e+=Qe(`${"=".repeat(10)}
39
- `,2);return e}default:return(r=>{throw new Error("You missed a case in the switch above")})(n)}}function Qe(n,e){return n.split(`
36
+ `;for(let t=0;t<n.results.length;t++)e+=Ze(`Sub-step ${t} in section:
37
+ `,2),e+=`${Ze(Vr(n.results[t]),2)}
38
+ `,e+=Ze(`${"=".repeat(10)}
39
+ `,2);return e}default:return(r=>{throw new Error("You missed a case in the switch above")})(n)}}function Ze(n,e){return n.split(`
40
40
  `).map(t=>" ".repeat(e)+t).join(`
41
- `)}function Tf(n,e){try{if(!n)return n;if(typeof n=="string")return je(n,3e4);if(typeof n=="object"){let{jsonString:t}=Mo(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 Fd(n,e){for(let t=0;t<n.length;t++){let r=n[t];try{if(r.data){let{jsonString:o}=Mo(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":wf(r);break;case"CONDITIONAL":r.assertion&&wf(r.assertion),Fd(r.results,e);break;case"AI_ACTION_DYNAMIC":case"AI_ACTION":case"IFRAME":case"MODULE":case"SECTION":{Fd(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 wf(n){let e=n.command;"cache"in e&&e.cache&&(e.cache=void 0)}function vf(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 qs(n,e){let t=CA(n);if(Fd(t,e),t.length>Sf)return e.error("Database content violation: results too long, truncating before insertion"),t.slice(0,Sf);let r=vf(t,e);if(r.length>yf)for(e.error({serializedLength:r.length,resultsArrayLength:t.length},"Database content violation: results too large, truncating before insertion");r.length>yf;)t.pop(),r=vf(t,e);try{return Mt.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 Nq}from"lodash-es";var AA=/^(?!.*\S+\s+\S+).*$/,IA=/^[a-zA-Z0-9\s.,;:'"!?()\- \u00C0-\u00FF]+$/,PA=/style="([^"]*)/g,LA=/data-[\w-]+/g,OA=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 Ef(n){let e=OA(n),t=e.type==="AI_ASSERTION"?e.assertion:e.description;return!t||t==="NONE"?{thoughts:"NONE",category:"NO_DESCRIPTION_PROVIDED"}:AA.test(t)&&IA.test(t)?{thoughts:"The target description is too short. Please provide more details.",category:"FEW_WORDS"}:PA.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"}:LA.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 xf(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 Jf}from"lodash-es";import DA from"diff-lines";import Ys,{gte as FA}from"semver";var Cf={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 Rf={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 MA=["target","fromTarget","toTarget"];function Af(n){for(let e of MA){if(n[e]===void 0)continue;let t=n[e];t.elementDescriptor!==void 0?t.type="description":n[e]={type:"description",elementDescriptor:""}}}var If={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 Af(e.command),e;case"AI_ACTION":{let t=e.commands;for(let r of t??[])Af(r);return e}default:return e}})};import{v4 as NA}from"uuid";var Pf={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=NA()),e;default:return e}})};import{v4 as Lf}from"uuid";var Of={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??Lf(),e}case"AI_ACTION":return e.commands&&(e.steps=e.commands.map(t=>({type:"PRESET_ACTION",command:{...t,id:t.id??Lf()}})),delete e.commands),e;default:return e}})};var Mf={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 kA}from"uuid";var Nf={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=kA()),e))};import{v4 as kf}from"uuid";var _f={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=kf())}return e.id=kf(),e})};var Df={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 _A}from"uuid";var Ff={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=_A()),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 Uf={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 Bf={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&&zf(t),e})};function zf(n){n&&Object.keys(n).forEach(e=>{if(typeof n[e]=="object"&&n[e]){zf(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 Hf={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 jf={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 $f={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 Gf={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 Wf={name:"Migrate AI checks 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 Ks=new Set(["CLICK","TYPE","SELECT_OPTION"]),Vf={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||Ks.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||Ks.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||Ks.has(c))&&(s.target={elementDescriptor:l??""}),a.commands&&Array.isArray(a.commands)&&a.commands.forEach(p=>{let u=p?.elementDescriptor,m=p?.type;(u!==void 0||Ks.has(m))&&(p.target={elementDescriptor:u??""})})}),e}),stopOnFailure:!0};var qf={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 Kf={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 qr=[Wf,qf,Kf,Vf,Cf,Rf,If,Pf,Of,Mf,Nf,_f,Df,Ff,Uf,Bf,Hf,jf,$f,Gf];if(Oe!==qr[qr.length-1].toVersion)throw new Error("Please bump LATEST_SCHEMA_VERSION in types package after adding a migration");qr.forEach((n,e)=>{if(!Ys.valid(n.toVersion)||!Ys.valid(n.fromVersion))throw new Error(`Migration '${n.name}' has invalid version`);if(!Ys.gt(n.toVersion,n.fromVersion))throw new Error(`Migration '${n.name}' has toVersion <= fromVersion`);if(e===0)return;if(qr[e-1].toVersion!==n.fromVersion)throw new Error(`Migration '${n.name}' at index ${e} is not contiguous with previous migration`)});function UA(n){return n.every(e=>e&&typeof e=="object"&&!Array.isArray(e))}var da=async({metadata:n,steps:e,logger:t,toVersion:r})=>{let o=e,{schemaVersion:i,id:a}=n,s=qr.findIndex(d=>Ys.gt(d.toVersion,i));if(s===-1)return{steps:o,newVersion:i};let l=i;for(let d=s;d<qr.length;d++){if(r&&FA(l,r)){t.debug("Stopping migration early because toVersion was reached");break}let p=qr[d],u={id:a,migration:p.name,toVersion:p.toVersion};try{o=await Yf(o,p),l=p.toVersion}catch(m){throw t.error({err:m,...u},"Migration failed"),new Error(`Step migration ${p.name} failed: ${m}`)}}let c=DA(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)||UA(i)&&(r[o]=await Yf(i,e))}return t}async function Xf({rawSteps:n,metadata:e,logger:t,callbacks:r}){xf(e,"defaultOnCloud");let o={},{resolvedSteps:i,newSchemaVersion:a}=await Js({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 Js({rawSteps:c,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o});s[l]=d}return{resolvedTest:s,moduleIds:Array.from(Object.keys(o))}}async function Kr(n,e,t){let{newVersion:r,steps:o}=await da({metadata:n,steps:e,logger:t});try{return{steps:we.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 Js({rawSteps:n,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o={}}){let{newVersion:i,steps:a}=await Kr(e,n,t),s=[];for(let l of a)s.push(await pa({step:l,callbacks:r,logger:t,resolvedModuleCache:o}));return{resolvedSteps:s,newSchemaVersion:i}}async function pa({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{...Jf(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:u}=await da({metadata:{id:l,schemaVersion:d.schemaVersion},steps:d.steps,logger:t}),m;try{m=we.array().parse(u)}catch(f){throw t.error({type:"zod",err:f,steps:u,newVersion:p,id:l},"Module failed to parse"),f}let h;try{h=await Promise.all(m.map(f=>pa({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]=Jf(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 pa({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 pa({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 pa({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 BA(n){return typeof n=="object"&&n!==null}function $n(n){if(Array.isArray(n))return n.map($n);if(BA(n)){let e={};return Object.entries(n).forEach(([t,r])=>{r!==void 0&&(e[t]=$n(r))}),e}return n}import{cloneDeep as zA}from"lodash-es";import{stringify as Qf}from"yaml";async function Zf({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 HA({originalStepLists:{steps:n.steps,beforeSteps:n.beforeSteps,afterSteps:n.afterSteps},modules:o,processedModuleNames:e,createNewCacheIds:t}),a={fileType:ve.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:Qf(a),modules:o}}async function HA({originalStepLists:n,modules:e,processedModuleNames:t,createNewCacheIds:r}){let o=zA(n);Object.values(o).forEach(s=>{jA(s??[])});let{stepsToSave:i,moduleUpdates:a}=await gt({stepLists:o,createNewCacheIds:r});for(let s of a)t.has(s.name)||(e[s.name]=$A(s),t.add(s.name));return i}function jA(n){Md({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 $A(n){let e=Lt.parse(n),t={fileType:ve.MODULE,...e,schemaVersion:Oe,steps:n.steps};return Qf(t)}async function Z(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 ua({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 Yr({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 ua({promiseGenerator:n,signal:a.signal,codePath:t,logger:r})}finally{i=!0,o?.removeEventListener("abort",s),clearTimeout(l)}}function Xs(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(Bn.parse(r));break}case"IFRAME":case"SECTION":{let r={...t,steps:Xs(t.steps)};e.push(we.parse(r));break}case"CONDITIONAL":{let r={...t,blocks:t.blocks.map(o=>({assertion:o.assertion,steps:Xs(o.steps)})),elseSteps:t.elseSteps?Xs(t.elseSteps):void 0};e.push(Or.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 Qs(n){return Xs([n])[0]}import GA from"picomatch";var eS=(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||GA(o)(n);break}case"REGEX":{r=new RegExp(e.regex).test(n);break}}return t?.negated?!r:r},Zs=(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}},jo=n=>{try{return new URL(n),!0}catch{return!1}},tS=n=>!n.toLowerCase().startsWith("http"),$o=(n,e)=>{try{return new URL(n,e),!0}catch{return!1}};function Jr(n,e){try{return!!new URL(n).origin.trim()}catch(t){return e?.error({url:n,err:t},"Invalid URL in check"),!1}}import Go from"yaml";import{z as iS}from"zod";import{execSync as WA}from"child_process";function Xr(n,e){let t=e.hooks?.postSave;if(!t)return;let r;t.includes("$1")?r=t.replaceAll("$1",n):r=`${t} ${n}`,b.debug({postSaveCommand:r},"Executing post-save hook command");try{WA(r,{encoding:"utf-8"})}catch(o){b.warn({err:o,postSaveCommand:r},"Failed to execute post-save hook command, continuing...")}}import{diff as nS}from"deep-object-diff";import pr from"fs";import{cloneDeep as VA}from"lodash-es";import Ud from"path";import{v4 as qA}from"uuid";import ma from"yaml";function Qr({content:n,schemaVersion:e,momenticFiles:t,project:r,forceSaveOnNoDiffs:o}){let i=t.modules[n.moduleId]?.fullFilePath;if(!i||!pr.existsSync(i))throw new Error(`Tried to update module ${n.moduleId} that could not be found on disk`);let a=pr.readFileSync(i,"utf-8"),s=ma.parse(a),l;if(n.name&&n.name!==s.name){let m=`${Ie(n.name)}.${_t.MODULE}`;if(l=Ud.join(Ud.dirname(i),m),pr.existsSync(l))throw new Error(`Test with name '${n.name}' already exists at path '${l}'`)}let c={...n,schemaVersion:e},d=$n({fileType:ve.MODULE,...Ad.parse(c),steps:we.array().parse(n.steps)}),p=nS(d,s);if(p&&Object.keys(p).length===0&&!o){b.debug(`Skipping save for module ${n.moduleId} since there are no changes`);return}let u=ma.stringify(d);pr.writeFileSync(i,u,"utf-8"),l&&pr.renameSync(i,l),Xr(l||i,r.config)}function rS({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=Gn(i,o),s={...a,...e},l=$n({fileType:ve.MODULE,...Ad.parse(s),steps:a.steps}),c=nS(l,a);if(c&&Object.keys(c).length===0){b.debug(`Skipping save for module ${n} since there are no changes`);return}let d=ma.stringify(l);pr.writeFileSync(i,d,"utf-8"),Xr(i,r.config)}async function oS({name:n,description:e,enabled:t,steps:r,folder:o,project:i}){let a=Ie(n),s=Ud.join(o,`${a}.module.yaml`),l=qA(),{stepsToSave:c}=await gt({stepLists:{steps:r}}),d={fileType:ve.MODULE,schemaVersion:Oe,moduleId:l,name:n,description:e,enabled:t,steps:c.steps},p=ma.stringify(d);return pr.writeFileSync(s,p,"utf-8"),Xr(s,i.config),{moduleId:l,name:n,description:e,enabled:t,steps:r}}function Gn(n,e){let t=pr.readFileSync(n,"utf-8"),r=ma.parse(t);try{return Ld.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 el(n,e,t,r){let o=Gn(n.fullFilePath,t),{resolvedSteps:i}=await Js({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 Gn(l,t)}}}),a={...o,steps:i};return r&&(r[n.id]=VA(a)),a}async function tl(n,e){let t={};return await Promise.all(Object.values(n.modules).map(async r=>{await el(r,n,e,t)})),Array.from(Object.values(t))}async function aS({test:n,name:e,folder:t}){let r=await Zf({test:n});if(Object.keys(r.modules).length)throw new Error("A brand new test should not contain any modules in it");let i=`${Ie(e)}.${_t.TEST}`,a=Zr.join(t,i);return un.writeFileSync(a,r.test,"utf-8"),a}function Bd(n,e,t){let r=Zr.join(t.rootDir,n);if(!un.existsSync(r))throw new Error(`Test not found at path '${n}' in project '${t.rootDir}'`);let o=un.readFileSync(r,"utf-8"),i=Go.parse(o),a,s;if(e.name&&e.name!==i.name){let u=`${Ie(e.name)}.${_t.TEST}`;if(a=Zr.join(Zr.dirname(n),u),s=Zr.join(t.rootDir,a),un.existsSync(s))throw new Error(`Test with name '${e.name}' already exists at path '${s}'`)}let l={...i,...e},c=Zt.parse(l),d={fileType:ve.TEST,...Zt.parse(c),beforeSteps:i.beforeSteps??void 0,steps:i.steps,afterSteps:i.afterSteps??void 0},p=Go.stringify(d);return un.writeFileSync(r,p,"utf-8"),s&&un.renameSync(r,s),Xr(r,t.config),{newRelativeTestPath:a}}function Wn({relativeTestPath:n,steps:e,schemaVersion:t,project:r,forceSaveOnNoDiffs:o}){let i=Zr.join(r.rootDir,n);if(!un.existsSync(i))throw new Error(`Test not found at path '${n}' in project '${r.rootDir}'`);let a=un.readFileSync(i,"utf-8"),s=Go.parse(a),l=Zt.parse({...s,schemaVersion:t}),c=$n({fileType:ve.TEST,...l,beforeSteps:we.array().or(iS.undefined()).parse(e.beforeSteps),steps:we.array().parse(e.steps),afterSteps:we.array().or(iS.undefined()).parse(e.afterSteps)}),d=KA(c,s);if(d&&Object.keys(d).length===0&&!o){b.debug(`Skipping save for test ${l.name} since there are no changes`);return}let p=Go.stringify(c);un.writeFileSync(i,p,"utf-8"),b.debug(`Saving test ${l.name} to ${i}`),Xr(i,r.config)}function nl(n,e){let t=Zr.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=un.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=Go.parse(r)}catch(i){throw new Error(`Could not parse test file ${t} as YAML: ${i}`)}return ht.parse(o)}function eo(n,e,t){let r=t.project.rootDir,o;try{o=un.readFileSync(n,"utf-8")}catch(a){throw e.error({err:a,projectRoot:r},a.message),new Error(a.message)}let i=Go.parse(o);if(!i.steps||!Array.isArray(i.steps))throw new Error(`Test ${n} is missing steps`);return i}async function ha(n,e,t){let r=eo(n,e,t),o;try{o=Zt.parse(r)}catch(a){throw new Error(`Test ${n} is missing metadata or has invalid metadata: ${a}`)}let{resolvedTest:i}=await Xf({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 Gn(l,s)}}});return i}import YA from"@dotenvx/dotenvx";import JA from"fs";import sS from"path";function cS(n,e){return(n.config.environments??[]).map(t=>ga(t.name,n,e))}function lS(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 ga(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={[We]:lS(r.baseUrl)};if(r.envVariables){let a={};for(let[s,l]of Object.entries(r.envVariables))if(typeof l=="string"){let c=lS(l);c&&(a[s]=c)}else{let c=l.fromFile,d;try{d=JA.readFileSync(sS.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&&b.debug(a,"Set environment variables with interpolation from project configuration"),Object.assign(o,a)}if(r.envFile){let a={},s=YA.config({path:sS.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 AP,readFileSync as IP,readdirSync as PP,writeFileSync as LP}from"fs";var LS=nE(TS(),1);var Sa=n=>{if(typeof n!="string")throw new TypeError("invalid pattern");if(n.length>65536)throw new TypeError("pattern is too long")};var oI={"[: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]},ya=n=>n.replace(/[[\]\\-]/g,"\\$&"),iI=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),ES=n=>n.join(""),xS=(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,w,T]]of Object.entries(oI))if(n.startsWith(f,i)){if(p)return["$.",!1,n.length-t,!0];i+=f.length,T?o.push(S):r.push(S),s=s||w;continue e}}if(l=!1,p){g>p?r.push(ya(p)+"-"+ya(g)):g===p&&r.push(ya(g)),p="",i++;continue}if(n.startsWith("-]",i+1)){r.push(ya(g+"-")),i+=2;continue}if(n.startsWith("-",i+1)){p=g,i+=2;continue}r.push(ya(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[iI(g),!1,d-t,!1]}let u="["+(c?"^":"")+ES(r)+"]",m="["+(c?"":"^")+ES(o)+"]";return[r.length&&o.length?"("+u+"|"+m+")":r.length?u:m,s,d-t,!0]};var mn=(n,{windowsPathsNoEscape:e=!1}={})=>e?n.replace(/\[([^\/\\])\]/g,"$1"):n.replace(/((?!\\).|^)\[([^\/\\])\]/g,"$1$2").replace(/\\([^\/])/g,"$1");var aI=new Set(["!","?","+","*","@"]),CS=n=>aI.has(n),sI="(?!(?:^|/)\\.\\.?(?:$|/))",rl="(?!\\.)",lI=new Set(["[","."]),cI=new Set(["..","."]),dI=new Set("().*{}+?[]^$\\!"),pI=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),jd="[^/]",RS=jd+"*?",AS=jd+"+?",Wo=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 m=r,h="";for(;m<e.length;){let g=e.charAt(m++);if(i||g==="\\"){i=!i,h+=g;continue}if(a){m===s+1?(g==="^"||g==="!")&&(l=!0):g==="]"&&!(m===s+2&&l)&&(a=!1),h+=g;continue}else if(g==="["){a=!0,s=m,l=!1,h+=g;continue}if(!o.noext&&CS(g)&&e.charAt(m)==="("){t.push(h),h="";let f=new n(g,t);m=n.#S(e,f,m,o),t.push(f);continue}h+=g}return t.push(h),m}let c=r+1,d=new n(null,t),p=[],u="";for(;c<e.length;){let m=e.charAt(c++);if(i||m==="\\"){i=!i,u+=m;continue}if(a){c===s+1?(m==="^"||m==="!")&&(l=!0):m==="]"&&!(c===s+2&&l)&&(a=!1),u+=m;continue}else if(m==="["){a=!0,s=c,l=!1,u+=m;continue}if(CS(m)&&e.charAt(c)==="("){d.push(u),u="";let h=new n(m,d);d.push(h),c=n.#S(e,h,c,o);continue}if(m==="|"){d.push(u),u="",p.push(d),d=new n(null,t);continue}if(m===")")return u===""&&t.#r.length===0&&(t.#o=!0),d.push(u),u="",t.push(...p,d),c;u+=m}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(m=>{let[h,g,f,S]=typeof m=="string"?n.#u(m,this.#t,l):m.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&&cI.has(this.#r[0]))){let h=lI,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?sI:f?rl:""}let p="";return this.isEnd()&&this.#e.#p&&this.#a?.type==="!"&&(p="(?:$|\\/)"),[d+c+p,mn(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,mn(this.toString()),!1,!1]}let a=!r||e||t||!rl?"":this.#m(!0);a===i&&(a=""),a&&(i=`(?:${i})(?:${a})*?`);let s="";if(this.type==="!"&&this.#o)s=(this.isStart()&&!t?rl:"")+AS;else{let l=this.type==="!"?"))"+(this.isStart()&&!t&&!e?rl:"")+RS+")":this.type==="@"?")":this.type==="?"?")?":this.type==="+"&&a?")":this.type==="*"&&a?")?":`)${this.type}`;s=o+i+l}return[s,mn(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+=(dI.has(l)?"\\":"")+l;continue}if(l==="\\"){s===e.length-1?i+="\\\\":o=!0;continue}if(l==="["){let[c,d,p,u]=xS(e,s);if(p){i+=c,a=a||d,s+=p-1,t=t||u;continue}}if(l==="*"){r&&e==="*"?i+=AS:i+=RS,t=!0;continue}if(l==="?"){i+=jd,t=!0;continue}i+=pI(l)}return[i,mn(e),!!t,a]}};var Vo=(n,{windowsPathsNoEscape:e=!1}={})=>e?n.replace(/[?*()[\]]/g,"[$&]"):n.replace(/[?*()[\]\\]/g,"\\$&");var xt=(n,e,t={})=>(Sa(e),!t.nocomment&&e.charAt(0)==="#"?!1:new zt(e,t).match(n)),uI=/^\*+([^+@!?\*\[\(]*)$/,mI=n=>e=>!e.startsWith(".")&&e.endsWith(n),hI=n=>e=>e.endsWith(n),gI=n=>(n=n.toLowerCase(),e=>!e.startsWith(".")&&e.toLowerCase().endsWith(n)),fI=n=>(n=n.toLowerCase(),e=>e.toLowerCase().endsWith(n)),SI=/^\*+\.\*+$/,yI=n=>!n.startsWith(".")&&n.includes("."),bI=n=>n!=="."&&n!==".."&&n.includes("."),wI=/^\.\*+$/,vI=n=>n!=="."&&n!==".."&&n.startsWith("."),TI=/^\*+$/,EI=n=>n.length!==0&&!n.startsWith("."),xI=n=>n.length!==0&&n!=="."&&n!=="..",CI=/^\?+([^+@!?\*\[\(]*)?$/,RI=([n,e=""])=>{let t=OS([n]);return e?(e=e.toLowerCase(),r=>t(r)&&r.toLowerCase().endsWith(e)):t},AI=([n,e=""])=>{let t=MS([n]);return e?(e=e.toLowerCase(),r=>t(r)&&r.toLowerCase().endsWith(e)):t},II=([n,e=""])=>{let t=MS([n]);return e?r=>t(r)&&r.endsWith(e):t},PI=([n,e=""])=>{let t=OS([n]);return e?r=>t(r)&&r.endsWith(e):t},OS=([n])=>{let e=n.length;return t=>t.length===e&&!t.startsWith(".")},MS=([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",IS={win32:{sep:"\\"},posix:{sep:"/"}},LI=NS==="win32"?IS.win32.sep:IS.posix.sep;xt.sep=LI;var lt=Symbol("globstar **");xt.GLOBSTAR=lt;var OI="[^/]",MI=OI+"*?",NI="(?:(?!(?:\\/|^)(?:\\.{1,2})($|\\/)).)*?",kI="(?:(?!(?:\\/|^)\\.).)*?",_I=(n,e={})=>t=>xt(t,n,e);xt.filter=_I;var en=(n,e={})=>Object.assign({},n,e),DI=n=>{if(!n||typeof n!="object"||!Object.keys(n).length)return xt;let e=xt;return Object.assign((r,o,i={})=>e(r,o,en(n,i)),{Minimatch:class extends e.Minimatch{constructor(o,i={}){super(o,en(n,i))}static defaults(o){return e.defaults(en(n,o)).Minimatch}},AST:class extends e.AST{constructor(o,i,a={}){super(o,i,en(n,a))}static fromGlob(o,i={}){return e.AST.fromGlob(o,en(n,i))}},unescape:(r,o={})=>e.unescape(r,en(n,o)),escape:(r,o={})=>e.escape(r,en(n,o)),filter:(r,o={})=>e.filter(r,en(n,o)),defaults:r=>e.defaults(en(n,r)),makeRe:(r,o={})=>e.makeRe(r,en(n,o)),braceExpand:(r,o={})=>e.braceExpand(r,en(n,o)),match:(r,o,i={})=>e.match(r,o,en(n,i)),sep:e.sep,GLOBSTAR:lt})};xt.defaults=DI;var kS=(n,e={})=>(Sa(n),e.nobrace||!/\{(?:(?!\{).)*\}/.test(n)?[n]:(0,LS.default)(n));xt.braceExpand=kS;var FI=(n,e={})=>new zt(n,e).makeRe();xt.makeRe=FI;var UI=(n,e,t={})=>{let r=new zt(e,t);return n=n.filter(o=>r.match(o)),r.options.nonull&&!n.length&&n.push(e),n};xt.match=UI;var PS=/[?*]|[+@!]\(.*?\)|\[|\]/,BI=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),zt=class{options;set;pattern;windowsPathsNoEscape;nonegate;negate;comment;empty;preserveMultipleSlashes;partial;globSet;globParts;nocase;isWindows;platform;windowsNoMagicRoot;regexp;constructor(e,t={}){Sa(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]==="?"||!PS.test(i[2]))&&!PS.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]),w=!S&&t[0]===""&&t[1]===""&&t[2]==="?"&&typeof t[3]=="string"&&/^[a-z]:$/i.test(t[3]),T=f?3:g?0:void 0,y=w?3:S?0:void 0;if(typeof T=="number"&&typeof y=="number"){let[E,x]=[e[T],t[y]];E.toLowerCase()===x.toLowerCase()&&(t[y]=E,y>T?t=t.slice(y):T>y&&(e=e.slice(T)))}}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===lt){this.debug("GLOBSTAR",[t,d,p]);var u=a,m=s+1;if(m===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(;u<l;){var h=e[u];if(this.debug(`
41
+ `)}function Tf(n,e){try{if(!n)return n;if(typeof n=="string")return je(n,3e4);if(typeof n=="object"){let{jsonString:t}=Mo(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 Bd(n,e){for(let t=0;t<n.length;t++){let r=n[t];try{if(r.data){let{jsonString:o}=Mo(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":vf(r);break;case"CONDITIONAL":r.assertion&&vf(r.assertion),Bd(r.results,e);break;case"AI_ACTION_DYNAMIC":case"AI_ACTION":case"IFRAME":case"MODULE":case"SECTION":{Bd(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 vf(n){let e=n.command;"cache"in e&&e.cache&&(e.cache=void 0)}function Ef(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 Ys(n,e){let t=IA(n);if(Bd(t,e),t.length>yf)return e.error("Database content violation: results too long, truncating before insertion"),t.slice(0,yf);let r=Ef(t,e);if(r.length>bf)for(e.error({serializedLength:r.length,resultsArrayLength:t.length},"Database content violation: results too large, truncating before insertion");r.length>bf;)t.pop(),r=Ef(t,e);try{return Mt.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 Dq}from"lodash-es";var LA=/^(?!.*\S+\s+\S+).*$/,OA=/^[a-zA-Z0-9\s.,;:'"!?()\- \u00C0-\u00FF]+$/,MA=/style="([^"]*)/g,NA=/data-[\w-]+/g,kA=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 xf(n){let e=kA(n),t=e.type==="AI_ASSERTION"?e.assertion:e.description;return!t||t==="NONE"?{thoughts:"NONE",category:"NO_DESCRIPTION_PROVIDED"}:LA.test(t)&&OA.test(t)?{thoughts:"The target description is too short. Please provide more details.",category:"FEW_WORDS"}:MA.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"}:NA.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 Cf(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 Xf}from"lodash-es";import BA from"diff-lines";import Xs,{gte as zA}from"semver";var Rf={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 Af={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 _A=["target","fromTarget","toTarget"];function If(n){for(let e of _A){if(n[e]===void 0)continue;let t=n[e];t.elementDescriptor!==void 0?t.type="description":n[e]={type:"description",elementDescriptor:""}}}var Pf={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 If(e.command),e;case"AI_ACTION":{let t=e.commands;for(let r of t??[])If(r);return e}default:return e}})};import{v4 as DA}from"uuid";var Lf={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=DA()),e;default:return e}})};import{v4 as Of}from"uuid";var Mf={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??Of(),e}case"AI_ACTION":return e.commands&&(e.steps=e.commands.map(t=>({type:"PRESET_ACTION",command:{...t,id:t.id??Of()}})),delete e.commands),e;default:return e}})};var Nf={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 FA}from"uuid";var kf={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=FA()),e))};import{v4 as _f}from"uuid";var Df={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=_f())}return e.id=_f(),e})};var Ff={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 UA}from"uuid";var Uf={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=UA()),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 Bf={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 zf={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&&Hf(t),e})};function Hf(n){n&&Object.keys(n).forEach(e=>{if(typeof n[e]=="object"&&n[e]){Hf(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 jf={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 $f={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 Gf={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 Wf={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 Vf={name:"Migrate AI checks 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 Js=new Set(["CLICK","TYPE","SELECT_OPTION"]),qf={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||Js.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||Js.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||Js.has(c))&&(s.target={elementDescriptor:l??""}),a.commands&&Array.isArray(a.commands)&&a.commands.forEach(p=>{let u=p?.elementDescriptor,m=p?.type;(u!==void 0||Js.has(m))&&(p.target={elementDescriptor:u??""})})}),e}),stopOnFailure:!0};var Kf={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 Yf={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 qr=[Vf,Kf,Yf,qf,Rf,Af,Pf,Lf,Mf,Nf,kf,Df,Ff,Uf,Bf,zf,jf,$f,Gf,Wf];if(Oe!==qr[qr.length-1].toVersion)throw new Error("Please bump LATEST_SCHEMA_VERSION in types package after adding a migration");qr.forEach((n,e)=>{if(!Xs.valid(n.toVersion)||!Xs.valid(n.fromVersion))throw new Error(`Migration '${n.name}' has invalid version`);if(!Xs.gt(n.toVersion,n.fromVersion))throw new Error(`Migration '${n.name}' has toVersion <= fromVersion`);if(e===0)return;if(qr[e-1].toVersion!==n.fromVersion)throw new Error(`Migration '${n.name}' at index ${e} is not contiguous with previous migration`)});function HA(n){return n.every(e=>e&&typeof e=="object"&&!Array.isArray(e))}var da=async({metadata:n,steps:e,logger:t,toVersion:r})=>{let o=e,{schemaVersion:i,id:a}=n,s=qr.findIndex(d=>Xs.gt(d.toVersion,i));if(s===-1)return{steps:o,newVersion:i};let l=i;for(let d=s;d<qr.length;d++){if(r&&zA(l,r)){t.debug("Stopping migration early because toVersion was reached");break}let p=qr[d],u={id:a,migration:p.name,toVersion:p.toVersion};try{o=await Jf(o,p),l=p.toVersion}catch(m){throw t.error({err:m,...u},"Migration failed"),new Error(`Step migration ${p.name} failed: ${m}`)}}let c=BA(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 Jf(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)||HA(i)&&(r[o]=await Jf(i,e))}return t}async function Zf({rawSteps:n,metadata:e,logger:t,callbacks:r}){Cf(e,"defaultOnCloud");let o={},{resolvedSteps:i,newSchemaVersion:a}=await Zs({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 Zs({rawSteps:c,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o});s[l]=d}return{resolvedTest:s,moduleIds:Array.from(Object.keys(o))}}async function Kr(n,e,t){let{newVersion:r,steps:o}=await da({metadata:n,steps:e,logger:t});try{return{steps:we.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 Zs({rawSteps:n,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o={}}){let{newVersion:i,steps:a}=await Kr(e,n,t),s=[];for(let l of a)s.push(await pa({step:l,callbacks:r,logger:t,resolvedModuleCache:o}));return{resolvedSteps:s,newSchemaVersion:i}}async function pa({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{...Xf(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:u}=await da({metadata:{id:l,schemaVersion:d.schemaVersion},steps:d.steps,logger:t}),m;try{m=we.array().parse(u)}catch(f){throw t.error({type:"zod",err:f,steps:u,newVersion:p,id:l},"Module failed to parse"),f}let h;try{h=await Promise.all(m.map(f=>pa({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]=Xf(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 pa({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 pa({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 pa({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 jA(n){return typeof n=="object"&&n!==null}function $n(n){if(Array.isArray(n))return n.map($n);if(jA(n)){let e={};return Object.entries(n).forEach(([t,r])=>{r!==void 0&&(e[t]=$n(r))}),e}return n}import{cloneDeep as $A}from"lodash-es";import{stringify as Qf}from"yaml";async function eS({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 GA({originalStepLists:{steps:n.steps,beforeSteps:n.beforeSteps,afterSteps:n.afterSteps},modules:o,processedModuleNames:e,createNewCacheIds:t}),a={fileType:ve.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:Qf(a),modules:o}}async function GA({originalStepLists:n,modules:e,processedModuleNames:t,createNewCacheIds:r}){let o=$A(n);Object.values(o).forEach(s=>{WA(s??[])});let{stepsToSave:i,moduleUpdates:a}=await gt({stepLists:o,createNewCacheIds:r});for(let s of a)t.has(s.name)||(e[s.name]=VA(s),t.add(s.name));return i}function WA(n){kd({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 VA(n){let e=Lt.parse(n),t={fileType:ve.MODULE,...e,schemaVersion:Oe,steps:n.steps};return Qf(t)}async function Q(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 ua({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 Yr({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 ua({promiseGenerator:n,signal:a.signal,codePath:t,logger:r})}finally{i=!0,o?.removeEventListener("abort",s),clearTimeout(l)}}function Qs(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(zn.parse(r));break}case"IFRAME":case"SECTION":{let r={...t,steps:Qs(t.steps)};e.push(we.parse(r));break}case"CONDITIONAL":{let r={...t,blocks:t.blocks.map(o=>({assertion:o.assertion,steps:Qs(o.steps)})),elseSteps:t.elseSteps?Qs(t.elseSteps):void 0};e.push(Or.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 el(n){return Qs([n])[0]}import qA from"picomatch";var tS=(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||qA(o)(n);break}case"REGEX":{r=new RegExp(e.regex).test(n);break}}return t?.negated?!r:r},tl=(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}},jo=n=>{try{return new URL(n),!0}catch{return!1}},nS=n=>!n.toLowerCase().startsWith("http"),$o=(n,e)=>{try{return new URL(n,e),!0}catch{return!1}};function Jr(n,e){try{return!!new URL(n).origin.trim()}catch(t){return e?.error({url:n,err:t},"Invalid URL in check"),!1}}import Go from"yaml";import{z as aS}from"zod";import{execSync as KA}from"child_process";function Xr(n,e){let t=e.hooks?.postSave;if(!t)return;let r;t.includes("$1")?r=t.replaceAll("$1",n):r=`${t} ${n}`,b.debug({postSaveCommand:r},"Executing post-save hook command");try{KA(r,{encoding:"utf-8"})}catch(o){b.warn({err:o,postSaveCommand:r},"Failed to execute post-save hook command, continuing...")}}import{diff as rS}from"deep-object-diff";import ur from"fs";import{cloneDeep as YA}from"lodash-es";import zd from"path";import{v4 as JA}from"uuid";import ma from"yaml";function Zr({content:n,schemaVersion:e,momenticFiles:t,project:r,forceSaveOnNoDiffs:o}){let i=t.modules[n.moduleId]?.fullFilePath;if(!i||!ur.existsSync(i))throw new Error(`Tried to update module ${n.moduleId} that could not be found on disk`);let a=ur.readFileSync(i,"utf-8"),s=ma.parse(a),l;if(n.name&&n.name!==s.name){let m=`${Ie(n.name)}.${_t.MODULE}`;if(l=zd.join(zd.dirname(i),m),ur.existsSync(l))throw new Error(`Test with name '${n.name}' already exists at path '${l}'`)}let c={...n,schemaVersion:e},d=$n({fileType:ve.MODULE,...Pd.parse(c),steps:we.array().parse(n.steps)}),p=rS(d,s);if(p&&Object.keys(p).length===0&&!o){b.debug(`Skipping save for module ${n.moduleId} since there are no changes`);return}let u=ma.stringify(d);ur.writeFileSync(i,u,"utf-8"),l&&ur.renameSync(i,l),Xr(l||i,r.config)}function oS({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=Gn(i,o),s={...a,...e},l=$n({fileType:ve.MODULE,...Pd.parse(s),steps:a.steps}),c=rS(l,a);if(c&&Object.keys(c).length===0){b.debug(`Skipping save for module ${n} since there are no changes`);return}let d=ma.stringify(l);ur.writeFileSync(i,d,"utf-8"),Xr(i,r.config)}async function iS({name:n,description:e,enabled:t,steps:r,folder:o,project:i}){let a=Ie(n),s=zd.join(o,`${a}.module.yaml`),l=JA(),{stepsToSave:c}=await gt({stepLists:{steps:r}}),d={fileType:ve.MODULE,schemaVersion:Oe,moduleId:l,name:n,description:e,enabled:t,steps:c.steps},p=ma.stringify(d);return ur.writeFileSync(s,p,"utf-8"),Xr(s,i.config),{moduleId:l,name:n,description:e,enabled:t,steps:r}}function Gn(n,e){let t=ur.readFileSync(n,"utf-8"),r=ma.parse(t);try{return Md.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 nl(n,e,t,r){let o=Gn(n.fullFilePath,t),{resolvedSteps:i}=await Zs({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 Gn(l,t)}}}),a={...o,steps:i};return r&&(r[n.id]=YA(a)),a}async function rl(n,e){let t={};return await Promise.all(Object.values(n.modules).map(async r=>{await nl(r,n,e,t)})),Array.from(Object.values(t))}async function sS({test:n,name:e,folder:t}){let r=await eS({test:n});if(Object.keys(r.modules).length)throw new Error("A brand new test should not contain any modules in it");let i=`${Ie(e)}.${_t.TEST}`,a=Qr.join(t,i);return un.writeFileSync(a,r.test,"utf-8"),a}function Hd(n,e,t){let r=Qr.join(t.rootDir,n);if(!un.existsSync(r))throw new Error(`Test not found at path '${n}' in project '${t.rootDir}'`);let o=un.readFileSync(r,"utf-8"),i=Go.parse(o),a,s;if(e.name&&e.name!==i.name){let u=`${Ie(e.name)}.${_t.TEST}`;if(a=Qr.join(Qr.dirname(n),u),s=Qr.join(t.rootDir,a),un.existsSync(s))throw new Error(`Test with name '${e.name}' already exists at path '${s}'`)}let l={...i,...e},c=Qt.parse(l),d={fileType:ve.TEST,...Qt.parse(c),beforeSteps:i.beforeSteps??void 0,steps:i.steps,afterSteps:i.afterSteps??void 0},p=Go.stringify(d);return un.writeFileSync(r,p,"utf-8"),s&&un.renameSync(r,s),Xr(r,t.config),{newRelativeTestPath:a}}function Wn({relativeTestPath:n,steps:e,schemaVersion:t,project:r,forceSaveOnNoDiffs:o}){let i=Qr.join(r.rootDir,n);if(!un.existsSync(i))throw new Error(`Test not found at path '${n}' in project '${r.rootDir}'`);let a=un.readFileSync(i,"utf-8"),s=Go.parse(a),l=Qt.parse({...s,schemaVersion:t}),c=$n({fileType:ve.TEST,...l,beforeSteps:we.array().or(aS.undefined()).parse(e.beforeSteps),steps:we.array().parse(e.steps),afterSteps:we.array().or(aS.undefined()).parse(e.afterSteps)}),d=XA(c,s);if(d&&Object.keys(d).length===0&&!o){b.debug(`Skipping save for test ${l.name} since there are no changes`);return}let p=Go.stringify(c);un.writeFileSync(i,p,"utf-8"),b.debug(`Saving test ${l.name} to ${i}`),Xr(i,r.config)}function ol(n,e){let t=Qr.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=un.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=Go.parse(r)}catch(i){throw new Error(`Could not parse test file ${t} as YAML: ${i}`)}return ht.parse(o)}function eo(n,e,t){let r=t.project.rootDir,o;try{o=un.readFileSync(n,"utf-8")}catch(a){throw e.error({err:a,projectRoot:r},a.message),new Error(a.message)}let i=Go.parse(o);if(!i.steps||!Array.isArray(i.steps))throw new Error(`Test ${n} is missing steps`);return i}async function ha(n,e,t){let r=eo(n,e,t),o;try{o=Qt.parse(r)}catch(a){throw new Error(`Test ${n} is missing metadata or has invalid metadata: ${a}`)}let{resolvedTest:i}=await Zf({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 Gn(l,s)}}});return i}import ZA from"@dotenvx/dotenvx";import QA from"fs";import lS from"path";function dS(n,e){return(n.config.environments??[]).map(t=>ga(t.name,n,e))}function cS(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 ga(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={[We]:cS(r.baseUrl)};if(r.envVariables){let a={};for(let[s,l]of Object.entries(r.envVariables))if(typeof l=="string"){let c=cS(l);c&&(a[s]=c)}else{let c=l.fromFile,d;try{d=QA.readFileSync(lS.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&&b.debug(a,"Set environment variables with interpolation from project configuration"),Object.assign(o,a)}if(r.envFile){let a={},s=ZA.config({path:lS.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 LP,readFileSync as OP,readdirSync as MP,writeFileSync as NP}from"fs";var OS=iT(TS(),1);var Sa=n=>{if(typeof n!="string")throw new TypeError("invalid pattern");if(n.length>65536)throw new TypeError("pattern is too long")};var sI={"[: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]},ya=n=>n.replace(/[[\]\\-]/g,"\\$&"),lI=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),xS=n=>n.join(""),CS=(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,w,E]]of Object.entries(sI))if(n.startsWith(f,i)){if(p)return["$.",!1,n.length-t,!0];i+=f.length,E?o.push(S):r.push(S),s=s||w;continue e}}if(l=!1,p){g>p?r.push(ya(p)+"-"+ya(g)):g===p&&r.push(ya(g)),p="",i++;continue}if(n.startsWith("-]",i+1)){r.push(ya(g+"-")),i+=2;continue}if(n.startsWith("-",i+1)){p=g,i+=2;continue}r.push(ya(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[lI(g),!1,d-t,!1]}let u="["+(c?"^":"")+xS(r)+"]",m="["+(c?"":"^")+xS(o)+"]";return[r.length&&o.length?"("+u+"|"+m+")":r.length?u:m,s,d-t,!0]};var mn=(n,{windowsPathsNoEscape:e=!1}={})=>e?n.replace(/\[([^\/\\])\]/g,"$1"):n.replace(/((?!\\).|^)\[([^\/\\])\]/g,"$1$2").replace(/\\([^\/])/g,"$1");var cI=new Set(["!","?","+","*","@"]),RS=n=>cI.has(n),dI="(?!(?:^|/)\\.\\.?(?:$|/))",il="(?!\\.)",pI=new Set(["[","."]),uI=new Set(["..","."]),mI=new Set("().*{}+?[]^$\\!"),hI=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),Gd="[^/]",AS=Gd+"*?",IS=Gd+"+?",Wo=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 m=r,h="";for(;m<e.length;){let g=e.charAt(m++);if(i||g==="\\"){i=!i,h+=g;continue}if(a){m===s+1?(g==="^"||g==="!")&&(l=!0):g==="]"&&!(m===s+2&&l)&&(a=!1),h+=g;continue}else if(g==="["){a=!0,s=m,l=!1,h+=g;continue}if(!o.noext&&RS(g)&&e.charAt(m)==="("){t.push(h),h="";let f=new n(g,t);m=n.#S(e,f,m,o),t.push(f);continue}h+=g}return t.push(h),m}let c=r+1,d=new n(null,t),p=[],u="";for(;c<e.length;){let m=e.charAt(c++);if(i||m==="\\"){i=!i,u+=m;continue}if(a){c===s+1?(m==="^"||m==="!")&&(l=!0):m==="]"&&!(c===s+2&&l)&&(a=!1),u+=m;continue}else if(m==="["){a=!0,s=c,l=!1,u+=m;continue}if(RS(m)&&e.charAt(c)==="("){d.push(u),u="";let h=new n(m,d);d.push(h),c=n.#S(e,h,c,o);continue}if(m==="|"){d.push(u),u="",p.push(d),d=new n(null,t);continue}if(m===")")return u===""&&t.#r.length===0&&(t.#o=!0),d.push(u),u="",t.push(...p,d),c;u+=m}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(m=>{let[h,g,f,S]=typeof m=="string"?n.#u(m,this.#t,l):m.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&&uI.has(this.#r[0]))){let h=pI,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?dI:f?il:""}let p="";return this.isEnd()&&this.#e.#p&&this.#a?.type==="!"&&(p="(?:$|\\/)"),[d+c+p,mn(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,mn(this.toString()),!1,!1]}let a=!r||e||t||!il?"":this.#m(!0);a===i&&(a=""),a&&(i=`(?:${i})(?:${a})*?`);let s="";if(this.type==="!"&&this.#o)s=(this.isStart()&&!t?il:"")+IS;else{let l=this.type==="!"?"))"+(this.isStart()&&!t&&!e?il:"")+AS+")":this.type==="@"?")":this.type==="?"?")?":this.type==="+"&&a?")":this.type==="*"&&a?")?":`)${this.type}`;s=o+i+l}return[s,mn(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+=(mI.has(l)?"\\":"")+l;continue}if(l==="\\"){s===e.length-1?i+="\\\\":o=!0;continue}if(l==="["){let[c,d,p,u]=CS(e,s);if(p){i+=c,a=a||d,s+=p-1,t=t||u;continue}}if(l==="*"){r&&e==="*"?i+=IS:i+=AS,t=!0;continue}if(l==="?"){i+=Gd,t=!0;continue}i+=hI(l)}return[i,mn(e),!!t,a]}};var Vo=(n,{windowsPathsNoEscape:e=!1}={})=>e?n.replace(/[?*()[\]]/g,"[$&]"):n.replace(/[?*()[\]\\]/g,"\\$&");var xt=(n,e,t={})=>(Sa(e),!t.nocomment&&e.charAt(0)==="#"?!1:new zt(e,t).match(n)),gI=/^\*+([^+@!?\*\[\(]*)$/,fI=n=>e=>!e.startsWith(".")&&e.endsWith(n),SI=n=>e=>e.endsWith(n),yI=n=>(n=n.toLowerCase(),e=>!e.startsWith(".")&&e.toLowerCase().endsWith(n)),bI=n=>(n=n.toLowerCase(),e=>e.toLowerCase().endsWith(n)),wI=/^\*+\.\*+$/,vI=n=>!n.startsWith(".")&&n.includes("."),EI=n=>n!=="."&&n!==".."&&n.includes("."),TI=/^\.\*+$/,xI=n=>n!=="."&&n!==".."&&n.startsWith("."),CI=/^\*+$/,RI=n=>n.length!==0&&!n.startsWith("."),AI=n=>n.length!==0&&n!=="."&&n!=="..",II=/^\?+([^+@!?\*\[\(]*)?$/,PI=([n,e=""])=>{let t=MS([n]);return e?(e=e.toLowerCase(),r=>t(r)&&r.toLowerCase().endsWith(e)):t},LI=([n,e=""])=>{let t=NS([n]);return e?(e=e.toLowerCase(),r=>t(r)&&r.toLowerCase().endsWith(e)):t},OI=([n,e=""])=>{let t=NS([n]);return e?r=>t(r)&&r.endsWith(e):t},MI=([n,e=""])=>{let t=MS([n]);return e?r=>t(r)&&r.endsWith(e):t},MS=([n])=>{let e=n.length;return t=>t.length===e&&!t.startsWith(".")},NS=([n])=>{let e=n.length;return t=>t.length===e&&t!=="."&&t!==".."},kS=typeof process=="object"&&process?typeof process.env=="object"&&process.env&&process.env.__MINIMATCH_TESTING_PLATFORM__||process.platform:"posix",PS={win32:{sep:"\\"},posix:{sep:"/"}},NI=kS==="win32"?PS.win32.sep:PS.posix.sep;xt.sep=NI;var lt=Symbol("globstar **");xt.GLOBSTAR=lt;var kI="[^/]",_I=kI+"*?",DI="(?:(?!(?:\\/|^)(?:\\.{1,2})($|\\/)).)*?",FI="(?:(?!(?:\\/|^)\\.).)*?",UI=(n,e={})=>t=>xt(t,n,e);xt.filter=UI;var en=(n,e={})=>Object.assign({},n,e),BI=n=>{if(!n||typeof n!="object"||!Object.keys(n).length)return xt;let e=xt;return Object.assign((r,o,i={})=>e(r,o,en(n,i)),{Minimatch:class extends e.Minimatch{constructor(o,i={}){super(o,en(n,i))}static defaults(o){return e.defaults(en(n,o)).Minimatch}},AST:class extends e.AST{constructor(o,i,a={}){super(o,i,en(n,a))}static fromGlob(o,i={}){return e.AST.fromGlob(o,en(n,i))}},unescape:(r,o={})=>e.unescape(r,en(n,o)),escape:(r,o={})=>e.escape(r,en(n,o)),filter:(r,o={})=>e.filter(r,en(n,o)),defaults:r=>e.defaults(en(n,r)),makeRe:(r,o={})=>e.makeRe(r,en(n,o)),braceExpand:(r,o={})=>e.braceExpand(r,en(n,o)),match:(r,o,i={})=>e.match(r,o,en(n,i)),sep:e.sep,GLOBSTAR:lt})};xt.defaults=BI;var _S=(n,e={})=>(Sa(n),e.nobrace||!/\{(?:(?!\{).)*\}/.test(n)?[n]:(0,OS.default)(n));xt.braceExpand=_S;var zI=(n,e={})=>new zt(n,e).makeRe();xt.makeRe=zI;var HI=(n,e,t={})=>{let r=new zt(e,t);return n=n.filter(o=>r.match(o)),r.options.nonull&&!n.length&&n.push(e),n};xt.match=HI;var LS=/[?*]|[+@!]\(.*?\)|\[|\]/,jI=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),zt=class{options;set;pattern;windowsPathsNoEscape;nonegate;negate;comment;empty;preserveMultipleSlashes;partial;globSet;globParts;nocase;isWindows;platform;windowsNoMagicRoot;regexp;constructor(e,t={}){Sa(e),t=t||{},this.options=t,this.pattern=e,this.platform=t.platform||kS,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]==="?"||!LS.test(i[2]))&&!LS.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]),w=!S&&t[0]===""&&t[1]===""&&t[2]==="?"&&typeof t[3]=="string"&&/^[a-z]:$/i.test(t[3]),E=f?3:g?0:void 0,y=w?3:S?0:void 0;if(typeof E=="number"&&typeof y=="number"){let[x,T]=[e[E],t[y]];x.toLowerCase()===T.toLowerCase()&&(t[y]=x,y>E?t=t.slice(y):E>y&&(e=e.slice(E)))}}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===lt){this.debug("GLOBSTAR",[t,d,p]);var u=a,m=s+1;if(m===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(;u<l;){var h=e[u];if(this.debug(`
43
43
  globstar while`,e,u,t,m,h),this.matchOne(e.slice(u),t.slice(m),r))return this.debug("globstar found match!",u,l,h),!0;if(h==="."||h===".."||!o.dot&&h.charAt(0)==="."){this.debug("dot detected!",e,u,t,m);break}this.debug("globstar swallow a segment, and continue"),u++}return!!(r&&(this.debug(`
44
- >>> no match, partial?`,e,u,t,m),u===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 kS(this.pattern,this.options)}parse(e){Sa(e);let t=this.options;if(e==="**")return lt;if(e==="")return"";let r,o=null;(r=e.match(TI))?o=t.dot?xI:EI:(r=e.match(uI))?o=(t.nocase?t.dot?fI:gI:t.dot?hI:mI)(r[1]):(r=e.match(CI))?o=(t.nocase?t.dot?AI:RI:t.dot?II:PI)(r):(r=e.match(SI))?o=t.dot?bI:yI:(r=e.match(wI))&&(o=vI);let i=Wo.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?MI:t.dot?NI:kI,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"?BI(d):d===lt?lt:d._src});return c.forEach((d,p)=>{let u=c[p+1],m=c[p-1];d!==lt||m===lt||(m===void 0?u!==void 0&&u!==lt?c[p+1]="(?:\\/|"+r+"\\/)?"+u:c[p]=r:u===void 0?c[p-1]=m+"(?:\\/|"+r+")?":u!==lt&&(c[p-1]=m+"(?:\\/|\\/"+r+"\\/)"+u,c[p+1]=lt))}),c.filter(d=>d!==lt).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 xt.defaults(e).Minimatch}};xt.AST=Wo;xt.Minimatch=zt;xt.escape=Vo;xt.unescape=mn;import{fileURLToPath as SP}from"node:url";var qo=typeof performance=="object"&&performance&&typeof performance.now=="function"?performance:Date,DS=new Set,$d=typeof process=="object"&&process?process:{},FS=(n,e,t,r)=>{typeof $d.emitWarning=="function"?$d.emitWarning(n,e,t,r):console.error(`[${t}] ${e}: ${n}`)},ol=globalThis.AbortController,_S=globalThis.AbortSignal;if(typeof ol>"u"){_S=class{onabort;_onabort=[];reason;aborted=!1;addEventListener(r,o){this._onabort.push(o)}},ol=class{constructor(){e()}signal=new _S;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=$d.env?.LRU_CACHE_IGNORE_AC_WARNING!=="1",e=()=>{n&&(n=!1,FS("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 zI=n=>!DS.has(n),s4=Symbol("type"),ur=n=>n&&n===Math.floor(n)&&n>0&&isFinite(n),US=n=>ur(n)?n<=Math.pow(2,8)?Uint8Array:n<=Math.pow(2,16)?Uint16Array:n<=Math.pow(2,32)?Uint32Array:n<=Number.MAX_SAFE_INTEGER?Ko:null:null,Ko=class extends Array{constructor(e){super(e),this.fill(0)}},Gd=class n{heap;length;static#e=!1;static create(e){let t=US(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]}},ba=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;#E;#g;#x;#C;#b;#v;#T;#h;static unsafeExposeInternals(e){return{starts:e.#C,ttls:e.#b,sizes:e.#x,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.#E,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:u,maxSize:m=0,maxEntrySize:h=0,sizeCalculation:g,fetchMethod:f,memoMethod:S,noDeleteOnFetchRejection:w,noDeleteOnStaleGet:T,allowStaleOnFetchRejection:y,allowStaleOnFetchAbort:E,ignoreFetchAbort:x}=e;if(t!==0&&!ur(t))throw new TypeError("max option must be a nonnegative integer");let A=t?US(t):Array;if(!A)throw new Error("invalid max value: "+t);if(this.#e=t,this.#t=m,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.#E=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=!!u,this.noDeleteOnFetchRejection=!!w,this.allowStaleOnFetchRejection=!!y,this.allowStaleOnFetchAbort=!!E,this.ignoreFetchAbort=!!x,this.maxEntrySize!==0){if(this.#t!==0&&!ur(this.#t))throw new TypeError("maxSize must be a positive integer if specified");if(!ur(this.maxEntrySize))throw new TypeError("maxEntrySize must be a positive integer if specified");this.#L()}if(this.allowStale=!!l,this.noDeleteOnStaleGet=!!T,this.updateAgeOnGet=!!a,this.updateAgeOnHas=!!s,this.ttlResolution=ur(o)||o===0?o:1,this.ttlAutopurge=!!i,this.ttl=r||0,this.ttl){if(!ur(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 k="LRU_CACHE_UNBOUNDED";zI(k)&&(DS.add(k),FS("TTL caching without ttlAutopurge, max, or maxSize can result in unbounded memory consumption.","UnboundedCacheWarning",k,n))}}getRemainingTTL(e){return this.#s.has(e)?1/0:0}#P(){let e=new Ko(this.#e),t=new Ko(this.#e);this.#b=e,this.#C=t,this.#M=(i,a,s=qo.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?qo.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=qo.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=()=>{};#M=()=>{};#y=()=>!1;#L(){let e=new Ko(this.#e);this.#p=0,this.#x=e,this.#N=t=>{this.#p-=e[t],e[t]=0},this.#_=(t,r,o,i)=>{if(this.#d(r))return 0;if(!ur(o))if(i){if(typeof i!="function")throw new TypeError("sizeCalculation must be a function");if(o=i(r,t),!ur(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.#k=(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)}}#N=e=>{};#k=(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-(qo.now()-s);i.ttl=l,i.start=Date.now()}}return this.#x&&(i.size=this.#x[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=qo.now()-this.#C[t];a.start=Math.floor(Date.now()-s)}this.#x&&(a.size=this.#x[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=qo.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.#E.length!==0?this.#E.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.#k(p,d,l),l&&(l.set="add"),c=!1;else{this.#z(p);let u=this.#o[p];if(t!==u){if(this.#T&&this.#d(u)){u.__abortController.abort(new Error("replaced"));let{__staleWhileFetching:m}=u;m!==void 0&&!a&&(this.#v&&this.#i?.(m,e,"set"),this.#h&&this.#g?.push([m,e,"set"]))}else a||(this.#v&&this.#i?.(u,e,"set"),this.#h&&this.#g?.push([u,e,"set"]));if(this.#N(p),this.#k(p,d,l),this.#o[p]=t,l){l.set="replace";let m=u&&this.#d(u)?u.__staleWhileFetching:u;m!==void 0&&(l.oldValue=m)}}else l&&(l.set="update")}if(o!==0&&!this.#b&&this.#P(),this.#b&&(c||this.#M(p,o,i),l&&this.#n(l,p)),!a&&this.#h&&this.#g){let u=this.#g,m;for(;m=u?.shift();)this.#r?.(...m)}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.#N(t),e&&(this.#l[t]=void 0,this.#o[t]=void 0,this.#E.push(t)),this.#c===1?(this.#m=this.#u=0,this.#E.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 ol,{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,w=r.ignoreFetchAbort&&g!==void 0;if(r.status&&(S&&!f?(r.status.fetchAborted=!0,r.status.fetchError=a.signal.reason,w&&(r.status.fetchAbortIgnored=!0)):r.status.fetchResolved=!0),S&&!w&&!f)return p(a.signal.reason);let T=m;return this.#o[t]===m&&(g===void 0?T.__staleWhileFetching?this.#o[t]=T.__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,w=S||r.allowStaleOnFetchRejection,T=w||r.noDeleteOnFetchRejection,y=m;if(this.#o[t]===m&&(!T||y.__staleWhileFetching===void 0?this.#O(e,"fetch"):S||(this.#o[t]=y.__staleWhileFetching)),w)return r.status&&y.__staleWhileFetching!==void 0&&(r.status.returnedStale=!0),y.__staleWhileFetching;if(y.__returned===y)throw g},u=(g,f)=>{let S=this.#a?.(e,i,l);S&&S instanceof Promise&&S.then(w=>g(w===void 0?void 0:w),f),a.signal.addEventListener("abort",()=>{(!r.ignoreFetchAbort||r.allowStaleOnFetchAbort)&&(g(void 0),r.allowStaleOnFetchAbort&&(g=w=>c(w,!0)))})};r.status&&(r.status.fetchDispatched=!0);let m=new Promise(u).then(c,d),h=Object.assign(m,{__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 ol}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:u=this.allowStaleOnFetchRejection,ignoreFetchAbort:m=this.ignoreFetchAbort,allowStaleOnFetchAbort:h=this.allowStaleOnFetchAbort,context:g,forceRefresh:f=!1,status:S,signal:w}=t;if(!this.#T)return S&&(S.fetch="get"),this.get(e,{allowStale:r,updateAgeOnGet:o,noDeleteOnStaleGet:i,status:S});let T={allowStale:r,updateAgeOnGet:o,noDeleteOnStaleGet:i,ttl:a,noDisposeOnSet:s,size:l,sizeCalculation:c,noUpdateTTL:d,noDeleteOnFetchRejection:p,allowStaleOnFetchRejection:u,allowStaleOnFetchAbort:h,ignoreFetchAbort:m,status:S,signal:w},y=this.#s.get(e);if(y===void 0){S&&(S.fetch="miss");let E=this.#U(e,y,T,g);return E.__returned=E}else{let E=this.#o[y];if(this.#d(E)){let W=r&&E.__staleWhileFetching!==void 0;return S&&(S.fetch="inflight",W&&(S.returnedStale=!0)),W?E.__staleWhileFetching:E.__returned=E}let x=this.#y(y);if(!f&&!x)return S&&(S.fetch="hit"),this.#z(y),o&&this.#R(y),S&&this.#n(S,y),E;let A=this.#U(e,y,T,g),L=A.__staleWhileFetching!==void 0&&r;return S&&(S.fetch=x?"stale":"refresh",L&&x&&(S.returnedStale=!0)),L?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.#N(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.#E.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.#x&&this.#x.fill(0),this.#m=0,this.#u=0,this.#E.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 XI,win32 as ep}from"node:path";import{fileURLToPath as QI}from"node:url";import{lstatSync as ZI,readdir as eP,readdirSync as tP,readlinkSync as nP,realpathSync as rP}from"fs";import*as oP from"node:fs";import{lstat as aP,readdir as sP,readlink as lP,realpath as cP}from"node:fs/promises";import{EventEmitter as Xd}from"node:events";import $S from"node:stream";import{StringDecoder as HI}from"node:string_decoder";var BS=typeof process=="object"&&process?process:{stdout:null,stderr:null},jI=n=>!!n&&typeof n=="object"&&(n instanceof hr||n instanceof $S||$I(n)||GI(n)),$I=n=>!!n&&typeof n=="object"&&n instanceof Xd&&typeof n.pipe=="function"&&n.pipe!==$S.Writable.prototype.pipe,GI=n=>!!n&&typeof n=="object"&&n instanceof Xd&&typeof n.write=="function"&&typeof n.end=="function",Vn=Symbol("EOF"),qn=Symbol("maybeEmitEnd"),mr=Symbol("emittedEnd"),il=Symbol("emittingEnd"),wa=Symbol("emittedError"),al=Symbol("closed"),zS=Symbol("read"),sl=Symbol("flush"),HS=Symbol("flushChunk"),hn=Symbol("encoding"),Yo=Symbol("decoder"),nt=Symbol("flowing"),va=Symbol("paused"),Jo=Symbol("resume"),rt=Symbol("buffer"),Ct=Symbol("pipes"),ot=Symbol("bufferLength"),Wd=Symbol("bufferPush"),ll=Symbol("bufferShift"),ft=Symbol("objectMode"),$e=Symbol("destroyed"),Vd=Symbol("error"),qd=Symbol("emitData"),jS=Symbol("emitEnd"),Kd=Symbol("emitEnd2"),In=Symbol("async"),Yd=Symbol("abort"),cl=Symbol("aborted"),Ta=Symbol("signal"),to=Symbol("dataListeners"),Ht=Symbol("discarded"),Ea=n=>Promise.resolve().then(n),WI=n=>n(),VI=n=>n==="end"||n==="finish"||n==="prefinish",qI=n=>n instanceof ArrayBuffer||!!n&&typeof n=="object"&&n.constructor&&n.constructor.name==="ArrayBuffer"&&n.byteLength>=0,KI=n=>!Buffer.isBuffer(n)&&ArrayBuffer.isView(n),dl=class{src;dest;opts;ondrain;constructor(e,t,r){this.src=e,this.dest=t,this.opts=r,this.ondrain=()=>e[Jo](),this.dest.on("drain",this.ondrain)}unpipe(){this.dest.removeListener("drain",this.ondrain)}proxyErrors(e){}end(){this.unpipe(),this.opts.end&&this.dest.end()}},Jd=class extends dl{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)}},YI=n=>!!n.objectMode,JI=n=>!n.objectMode&&!!n.encoding&&n.encoding!=="buffer",hr=class extends Xd{[nt]=!1;[va]=!1;[Ct]=[];[rt]=[];[ft];[hn];[In];[Yo];[Vn]=!1;[mr]=!1;[il]=!1;[al]=!1;[wa]=null;[ot]=0;[$e]=!1;[Ta];[cl]=!1;[to]=0;[Ht]=!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");YI(t)?(this[ft]=!0,this[hn]=null):JI(t)?(this[hn]=t.encoding,this[ft]=!1):(this[ft]=!1,this[hn]=null),this[In]=!!t.async,this[Yo]=this[hn]?new HI(this[hn]):null,t&&t.debugExposeBuffer===!0&&Object.defineProperty(this,"buffer",{get:()=>this[rt]}),t&&t.debugExposePipes===!0&&Object.defineProperty(this,"pipes",{get:()=>this[Ct]});let{signal:r}=t;r&&(this[Ta]=r,r.aborted?this[Yd]():r.addEventListener("abort",()=>this[Yd]()))}get bufferLength(){return this[ot]}get encoding(){return this[hn]}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[ft]}set objectMode(e){throw new Error("objectMode must be set at instantiation time")}get async(){return this[In]}set async(e){this[In]=this[In]||!!e}[Yd](){this[cl]=!0,this.emit("abort",this[Ta]?.reason),this.destroy(this[Ta]?.reason)}get aborted(){return this[cl]}set aborted(e){}write(e,t,r){if(this[cl])return!1;if(this[Vn])throw new Error("write after end");if(this[$e])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[In]?Ea:WI;if(!this[ft]&&!Buffer.isBuffer(e)){if(KI(e))e=Buffer.from(e.buffer,e.byteOffset,e.byteLength);else if(qI(e))e=Buffer.from(e);else if(typeof e!="string")throw new Error("Non-contiguous data written to non-objectMode stream")}return this[ft]?(this[nt]&&this[ot]!==0&&this[sl](!0),this[nt]?this.emit("data",e):this[Wd](e),this[ot]!==0&&this.emit("readable"),r&&o(r),this[nt]):e.length?(typeof e=="string"&&!(t===this[hn]&&!this[Yo]?.lastNeed)&&(e=Buffer.from(e,t)),Buffer.isBuffer(e)&&this[hn]&&(e=this[Yo].write(e)),this[nt]&&this[ot]!==0&&this[sl](!0),this[nt]?this.emit("data",e):this[Wd](e),this[ot]!==0&&this.emit("readable"),r&&o(r),this[nt]):(this[ot]!==0&&this.emit("readable"),r&&o(r),this[nt])}read(e){if(this[$e])return null;if(this[Ht]=!1,this[ot]===0||e===0||e&&e>this[ot])return this[qn](),null;this[ft]&&(e=null),this[rt].length>1&&!this[ft]&&(this[rt]=[this[hn]?this[rt].join(""):Buffer.concat(this[rt],this[ot])]);let t=this[zS](e||null,this[rt][0]);return this[qn](),t}[zS](e,t){if(this[ft])this[ll]();else{let r=t;e===r.length||e===null?this[ll]():typeof r=="string"?(this[rt][0]=r.slice(e),t=r.slice(0,e),this[ot]-=e):(this[rt][0]=r.subarray(e),t=r.subarray(0,e),this[ot]-=e)}return this.emit("data",t),!this[rt].length&&!this[Vn]&&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[Vn]=!0,this.writable=!1,(this[nt]||!this[va])&&this[qn](),this}[Jo](){this[$e]||(!this[to]&&!this[Ct].length&&(this[Ht]=!0),this[va]=!1,this[nt]=!0,this.emit("resume"),this[rt].length?this[sl]():this[Vn]?this[qn]():this.emit("drain"))}resume(){return this[Jo]()}pause(){this[nt]=!1,this[va]=!0,this[Ht]=!1}get destroyed(){return this[$e]}get flowing(){return this[nt]}get paused(){return this[va]}[Wd](e){this[ft]?this[ot]+=1:this[ot]+=e.length,this[rt].push(e)}[ll](){return this[ft]?this[ot]-=1:this[ot]-=this[rt][0].length,this[rt].shift()}[sl](e=!1){do;while(this[HS](this[ll]())&&this[rt].length);!e&&!this[rt].length&&!this[Vn]&&this.emit("drain")}[HS](e){return this.emit("data",e),this[nt]}pipe(e,t){if(this[$e])return e;this[Ht]=!1;let r=this[mr];return t=t||{},e===BS.stdout||e===BS.stderr?t.end=!1:t.end=t.end!==!1,t.proxyErrors=!!t.proxyErrors,r?t.end&&e.end():(this[Ct].push(t.proxyErrors?new Jd(this,e,t):new dl(this,e,t)),this[In]?Ea(()=>this[Jo]()):this[Jo]()),e}unpipe(e){let t=this[Ct].find(r=>r.dest===e);t&&(this[Ct].length===1?(this[nt]&&this[to]===0&&(this[nt]=!1),this[Ct]=[]):this[Ct].splice(this[Ct].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[Ht]=!1,this[to]++,!this[Ct].length&&!this[nt]&&this[Jo]();else if(e==="readable"&&this[ot]!==0)super.emit("readable");else if(VI(e)&&this[mr])super.emit(e),this.removeAllListeners(e);else if(e==="error"&&this[wa]){let o=t;this[In]?Ea(()=>o.call(this,this[wa])):o.call(this,this[wa])}return r}removeListener(e,t){return this.off(e,t)}off(e,t){let r=super.off(e,t);return e==="data"&&(this[to]=this.listeners("data").length,this[to]===0&&!this[Ht]&&!this[Ct].length&&(this[nt]=!1)),r}removeAllListeners(e){let t=super.removeAllListeners(e);return(e==="data"||e===void 0)&&(this[to]=0,!this[Ht]&&!this[Ct].length&&(this[nt]=!1)),t}get emittedEnd(){return this[mr]}[qn](){!this[il]&&!this[mr]&&!this[$e]&&this[rt].length===0&&this[Vn]&&(this[il]=!0,this.emit("end"),this.emit("prefinish"),this.emit("finish"),this[al]&&this.emit("close"),this[il]=!1)}emit(e,...t){let r=t[0];if(e!=="error"&&e!=="close"&&e!==$e&&this[$e])return!1;if(e==="data")return!this[ft]&&!r?!1:this[In]?(Ea(()=>this[qd](r)),!0):this[qd](r);if(e==="end")return this[jS]();if(e==="close"){if(this[al]=!0,!this[mr]&&!this[$e])return!1;let i=super.emit("close");return this.removeAllListeners("close"),i}else if(e==="error"){this[wa]=r,super.emit(Vd,r);let i=!this[Ta]||this.listeners("error").length?super.emit("error",r):!1;return this[qn](),i}else if(e==="resume"){let i=super.emit("resume");return this[qn](),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[qn](),o}[qd](e){for(let r of this[Ct])r.dest.write(e)===!1&&this.pause();let t=this[Ht]?!1:super.emit("data",e);return this[qn](),t}[jS](){return this[mr]?!1:(this[mr]=!0,this.readable=!1,this[In]?(Ea(()=>this[Kd]()),!0):this[Kd]())}[Kd](){if(this[Yo]){let t=this[Yo].end();if(t){for(let r of this[Ct])r.dest.write(t);this[Ht]||super.emit("data",t)}}for(let t of this[Ct])t.end();let e=super.emit("end");return this.removeAllListeners("end"),e}async collect(){let e=Object.assign([],{dataLength:0});this[ft]||(e.dataLength=0);let t=this.promise();return this.on("data",r=>{e.push(r),this[ft]||(e.dataLength+=r.length)}),await t,e}async concat(){if(this[ft])throw new Error("cannot concat in objectMode");let e=await this.collect();return this[hn]?e.join(""):Buffer.concat(e,e.dataLength)}async promise(){return new Promise((e,t)=>{this.on($e,()=>t(new Error("stream destroyed"))),this.on("error",r=>t(r)),this.on("end",()=>e())})}[Symbol.asyncIterator](){this[Ht]=!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[Vn])return t();let i,a,s=p=>{this.off("data",l),this.off("end",c),this.off($e,d),t(),a(p)},l=p=>{this.off("error",s),this.off("end",c),this.off($e,d),this.pause(),i({value:p,done:!!this[Vn]})},c=()=>{this.off("error",s),this.off("data",l),this.off($e,d),t(),i({done:!0,value:void 0})},d=()=>s(new Error("stream destroyed"));return new Promise((p,u)=>{a=u,i=p,this.once($e,d),this.once("error",s),this.once("end",c),this.once("data",l)})},throw:t,return:t,[Symbol.asyncIterator](){return this}}}[Symbol.iterator](){this[Ht]=!1;let e=!1,t=()=>(this.pause(),this.off(Vd,t),this.off($e,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(Vd,t),this.once($e,t),{next:r,throw:t,return:t,[Symbol.iterator](){return this}}}destroy(e){if(this[$e])return e?this.emit("error",e):this.emit($e),this;this[$e]=!0,this[Ht]=!0,this[rt].length=0,this[ot]=0;let t=this;return typeof t.close=="function"&&!this[al]&&t.close(),e?this.emit("error",e):this.emit($e),this}static get isStream(){return jI}};var iP=rP.native,Ca={lstatSync:ZI,readdir:eP,readdirSync:tP,readlinkSync:nP,realpathSync:iP,promises:{lstat:aP,readdir:sP,readlink:lP,realpath:cP}},KS=n=>!n||n===Ca||n===oP?Ca:{...Ca,...n,promises:{...Ca.promises,...n.promises||{}}},YS=/^\\\\\?\\([a-z]:)\\?$/i,dP=n=>n.replace(/\//g,"\\").replace(YS,"$1\\"),pP=/[\\\/]/,nn=0,JS=1,XS=2,Pn=4,QS=6,ZS=8,no=10,ey=12,tn=15,xa=~tn,Qd=16,GS=32,Ra=64,gn=128,pl=256,ml=512,WS=Ra|gn|ml,uP=1023,Zd=n=>n.isFile()?ZS:n.isDirectory()?Pn:n.isSymbolicLink()?no:n.isCharacterDevice()?XS:n.isBlockDevice()?QS:n.isSocket()?ey:n.isFIFO()?JS:nn,VS=new Map,Aa=n=>{let e=VS.get(n);if(e)return e;let t=n.normalize("NFKD");return VS.set(n,t),t},qS=new Map,ul=n=>{let e=qS.get(n);if(e)return e;let t=Aa(n.toLowerCase());return qS.set(n,t),t},hl=class extends ba{constructor(){super({max:256})}},tp=class extends ba{constructor(e=16*1024){super({maxSize:e,sizeCalculation:t=>t.length+1})}},ty=Symbol("PathScurry setAsCwd"),St=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}#E;get atime(){return this.#E}#g;get mtime(){return this.#g}#x;get ctime(){return this.#x}#C;get birthtime(){return this.#C}#b;#v;#T;#h;#P;#R;#n;#M;#y;#L;get parentPath(){return(this.parent||this).fullpath()}get path(){return this.parentPath}constructor(e,t=nn,r,o,i,a,s){this.name=e,this.#b=i?ul(e):Aa(e),this.#n=t&uP,this.nocase=i,this.roots=o,this.root=r||this,this.#M=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=KS(s.fs)}depth(){return this.#v!==void 0?this.#v:this.parent?this.#v=this.parent.depth()+1:this.#v=0}childrenCache(){return this.#M}resolve(e){if(!e)return this;let t=this.getRootString(e),o=e.substring(t.length).split(this.splitSep);return t?this.getRoot(t).#N(o):this.#N(o)}#N(e){let t=this;for(let r of e)t=t.child(r);return t}children(){let e=this.#M.get(this);if(e)return e;let t=Object.assign([],{provisional:0});return this.#M.set(this,t),this.#n&=~Qd,t}child(e,t){if(e===""||e===".")return this;if(e==="..")return this.parent||this;let r=this.children(),o=this.nocase?ul(e):Aa(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,nn,{...t,parent:this,fullpath:a});return this.canReaddir()||(s.#n|=gn),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&tn)===nn}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&tn)===ZS}isDirectory(){return(this.#n&tn)===Pn}isCharacterDevice(){return(this.#n&tn)===XS}isBlockDevice(){return(this.#n&tn)===QS}isFIFO(){return(this.#n&tn)===JS}isSocket(){return(this.#n&tn)===ey}isSymbolicLink(){return(this.#n&no)===no}lstatCached(){return this.#n&GS?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&tn;return!(e!==nn&&e!==no||this.#n&pl||this.#n&gn)}calledReaddir(){return!!(this.#n&Qd)}isENOENT(){return!!(this.#n&gn)}isNamed(e){return this.nocase?this.#b===ul(e):this.#b===Aa(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}}#k(e){this.#n|=Qd;for(let t=e.provisional;t<e.length;t++){let r=e[t];r&&r.#_()}}#_(){this.#n&gn||(this.#n=(this.#n|gn)&xa,this.#A())}#A(){let e=this.children();e.provisional=0;for(let t of e)t.#_()}#I(){this.#n|=ml,this.#D()}#D(){if(this.#n&Ra)return;let e=this.#n;(e&tn)===Pn&&(e&=xa),this.#n=e|Ra,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|=pl,e==="ENOENT"&&(t|=gn),(e==="EINVAL"||e==="UNKNOWN")&&(t&=xa),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=Zd(e),o=this.newChild(e.name,r,{parent:this}),i=o.#n&tn;return i!==Pn&&i!==no&&i!==nn&&(o.#n|=Ra),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?ul(e.name):Aa(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&xa|Zd(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&gn))try{return this.#W(await this.#e.promises.lstat(this.fullpath())),this}catch(e){this.#U(e.code)}}lstatSync(){if(!(this.#n&gn))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:u,mode:m,mtime:h,mtimeMs:g,nlink:f,rdev:S,size:w,uid:T}=e;this.#E=t,this.#f=r,this.#C=o,this.#u=i,this.#p=a,this.#o=s,this.#x=l,this.#m=c,this.#t=d,this.#w=p,this.#s=u,this.#i=m,this.#g=h,this.#S=g,this.#r=f,this.#c=S,this.#l=w,this.#a=T;let y=Zd(e);this.#n=this.#n&xa|y|GS,y!==nn&&y!==Pn&&y!==no&&(this.#n|=Ra)}#$=[];#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.#k(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.#k(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.#k(e)}catch(r){this.#F(r.code),e.provisional=0}return e.slice(0,e.provisional)}canReaddir(){if(this.#n&WS)return!1;let e=tn&this.#n;return e===nn||e===Pn||e===no}shouldWalk(e,t){return(this.#n&Pn)===Pn&&!(this.#n&WS)&&!e.has(this)&&(!t||t(this))}async realpath(){if(this.#L)return this.#L;if(!((ml|pl|gn)&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(!((ml|pl|gn)&this.#n))try{let e=this.#e.realpathSync(this.fullpath());return this.#L=this.resolve(e)}catch{this.#I()}}[ty](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}},gl=class n extends St{sep="\\";splitSep=pP;constructor(e,t=nn,r,o,i,a,s){super(e,t,r,o,i,a,s)}newChild(e,t=nn,r={}){return new n(e,t,this.root,this.roots,this.nocase,this.childrenCache(),r)}getRootString(e){return ep.parse(e).root}getRoot(e){if(e=dP(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 Xo(e,this).root}sameRoot(e,t=this.root.name){return e=e.toUpperCase().replace(/\//g,"\\").replace(YS,"$1\\"),e===t}},fl=class n extends St{splitSep="/";sep="/";constructor(e,t=nn,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=nn,r={}){return new n(e,t,this.root,this.roots,this.nocase,this.childrenCache(),r)}},Sl=class{root;rootPath;roots;cwd;#e;#t;#i;nocase;#r;constructor(e=process.cwd(),t,r,{nocase:o,childrenCacheSize:i=16*1024,fs:a=Ca}={}){this.#r=KS(a),(e instanceof URL||e.startsWith("file://"))&&(e=QI(e));let s=t.resolve(e);this.roots=Object.create(null),this.rootPath=this.parseRootPath(s),this.#e=new hl,this.#t=new hl,this.#i=new tp(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,u=this.rootPath,m=!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:u+=(m?"":p)+h}),m=!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 St||(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 St||(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 St||(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 St||(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 St||(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 St||(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 St||(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,u)=>{l.add(p),p.readdirCB((m,h)=>{if(m)return u(m);let g=h.length;if(!g)return u();let f=()=>{--g===0&&u()};for(let S of h)(!i||i(S))&&s.push(r?S:S.fullpath()),o&&S.isSymbolicLink()?S.realpath().then(w=>w?.isUnknown()?w.lstat():w).then(w=>w?.shouldWalk(l,a)?c(w,f):f()):S.shouldWalk(l,a)?c(S,f):f()},!0)},d=e;return new Promise((p,u)=>{c(d,m=>{if(m)return u(m);p(s)})})}walkSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof St||(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 u=p;if(p.isSymbolicLink()){if(!(o&&(u=p.realpathSync())))continue;u.isUnknown()&&u.lstatSync()}u.shouldWalk(l,a)&&l.add(u)}}return s}[Symbol.asyncIterator](){return this.iterate()}iterate(e=this.cwd,t={}){return typeof e=="string"?e=this.cwd.resolve(e):e instanceof St||(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 St||(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 St||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t,s=new hr({objectMode:!0});(!i||i(e))&&s.write(r?e:e.fullpath());let l=new Set,c=[e],d=0,p=()=>{let u=!1;for(;!u;){let m=c.shift();if(!m){d===0&&s.end();return}d++,l.add(m);let h=(f,S,w=!1)=>{if(f)return s.emit("error",f);if(o&&!w){let T=[];for(let y of S)y.isSymbolicLink()&&T.push(y.realpath().then(E=>E?.isUnknown()?E.lstat():E));if(T.length){Promise.all(T).then(()=>h(null,S,!0));return}}for(let T of S)T&&(!i||i(T))&&(s.write(r?T:T.fullpath())||(u=!0));d--;for(let T of S){let y=T.realpathCached()||T;y.shouldWalk(l,a)&&c.push(y)}u&&!s.flowing?s.once("drain",p):g||p()},g=!0;m.readdirCB(h,!0),g=!1}};return p(),s}streamSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof St||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t,s=new hr({objectMode:!0}),l=new Set;(!i||i(e))&&s.write(r?e:e.fullpath());let c=[e],d=0,p=()=>{let u=!1;for(;!u;){let m=c.shift();if(!m){d===0&&s.end();return}d++,l.add(m);let h=m.readdirSync();for(let g of h)(!i||i(g))&&(s.write(r?g:g.fullpath())||(u=!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)}}u&&!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[ty](t)}},Xo=class extends Sl{sep="\\";constructor(e=process.cwd(),t={}){let{nocase:r=!0}=t;super(e,ep,"\\",{...t,nocase:r}),this.nocase=r;for(let o=this.cwd;o;o=o.parent)o.nocase=this.nocase}parseRootPath(e){return ep.parse(e).root.toUpperCase()}newRoot(e){return new gl(this.rootPath,Pn,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")||e.startsWith("\\")||/^[a-z]:(\/|\\)/i.test(e)}},Qo=class extends Sl{sep="/";constructor(e=process.cwd(),t={}){let{nocase:r=!1}=t;super(e,XI,"/",{...t,nocase:r}),this.nocase=r}parseRootPath(e){return"/"}newRoot(e){return new fl(this.rootPath,Pn,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")}},Ia=class extends Qo{constructor(e=process.cwd(),t={}){let{nocase:r=!0}=t;super(e,{...t,nocase:r})}},b4=process.platform==="win32"?gl:fl,ny=process.platform==="win32"?Xo:process.platform==="darwin"?Ia:Qo;var mP=n=>n.length>=1,hP=n=>n.length>=1,Zo=class n{#e;#t;#i;length;#r;#a;#w;#c;#p;#s;#l=!0;constructor(e,t,r,o){if(!mP(e))throw new TypeError("empty pattern list");if(!hP(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,u,m,...h]=this.#t;c[0]===""&&(c.shift(),h.shift());let g=[i,a,s,l,""].join("/"),f=[d,p,u,m,""].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]===lt}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 gP=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",ei=class{relative;relativeChildren;absolute;absoluteChildren;platform;mmopts;constructor(e,{nobrace:t,nocase:r,noext:o,noglobstar:i,platform:a=gP}){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 zt(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 Zo(o,i,0,this.platform),s=new zt(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 np=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()]))}},rp=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)])}},op=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())}},Pa=class n{hasWalkedCache;matches=new rp;subwalks=new op;patterns;follow;dot;opts;constructor(e,t){this.opts=e,this.follow=!!e.follow,this.dot=!!e.dot,this.hasWalkedCache=t?t.copy():new np}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===lt){(!o.isSymbolicLink()||this.follow||i.checkFollowGlobstar())&&this.subwalks.add(o,i);let p=c?.pattern(),u=c?.rest();if(!c||(p===""||p===".")&&!u)this.matches.add(o,s,p===""||p===".");else if(p===".."){let m=o.parent||o;u?this.hasWalkedCache.hasWalked(m,u)||this.subwalks.add(m,u):this.matches.add(m,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===lt?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 fP=(n,e)=>typeof n=="string"?new ei([n],e):Array.isArray(n)?new ei(n,e):n,yl=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=fP(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 Pa(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 Pa(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()}},La=class extends yl{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}},Oa=class extends yl{results;constructor(e,t,r){super(e,t,r),this.results=new hr({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 yP=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",fn=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=SP(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||yP,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"?Xo:t.platform==="darwin"?Ia:t.platform?Qo:ny;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 zt(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 Zo(l,d,0,this.platform)})}async walk(){return[...await new La(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 La(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 Oa(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 Oa(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 ip=(n,e={})=>{Array.isArray(n)||(n=[n]);for(let t of n)if(new zt(t,e).hasMagic())return!0;return!1};function bl(n,e={}){return new fn(n,e).streamSync()}function iy(n,e={}){return new fn(n,e).stream()}function ti(n,e={}){return new fn(n,e).walkSync()}async function ry(n,e={}){return new fn(n,e).walk()}function wl(n,e={}){return new fn(n,e).iterateSync()}function ay(n,e={}){return new fn(n,e).iterate()}var bP=bl,wP=Object.assign(iy,{sync:bl}),vP=wl,TP=Object.assign(ay,{sync:wl}),EP=Object.assign(ti,{stream:bl,iterate:wl}),oy=Object.assign(ry,{glob:ry,globSync:ti,sync:EP,globStream:iy,stream:wP,globStreamSync:bl,streamSync:bP,globIterate:ay,iterate:TP,globIterateSync:wl,iterateSync:vP,Glob:fn,hasMagic:ip,escape:Vo,unescape:mn});oy.glob=oy;import ro,{dirname as dy}from"path";import{cwd as dp}from"process";import py from"yaml";import{z as Te}from"zod";import sy from"fs";import Ma from"path";import xP from"yaml";import{z as ap}from"zod";var ly=!1,sp=[`**/*.${_t.TEST}`,`**/*.${_t.MODULE}`],lp=ap.string().refine(n=>/^[a-zA-Z0-9-]+$/.test(n)),cp=50,CP=ap.object({fileType:ap.nativeEnum(ve)});function Se(n,e){let t={project:n,tests:{},modules:{}},r=n.config.include??sp,o=Array.from(n.config.exclude??[]).concat(hg),i=ti(r,{absolute:!1,cwd:n.rootDir,ignore:o,dotRelative:!1,maxDepth:cp,nodir:!0});for(let a of i)RP(n.rootDir,a,t,e);return ly=!0,t}function RP(n,e,t,r){let o=Ma.join(n,e),i;try{i=sy.readFileSync(o,"utf-8")}catch(p){r.warn(`Could not read possible Momentic file at ${o}, skipping: ${p}`);return}let a;try{if(a=xP.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=CP.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=sy.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:Ma.sep,fullPathSegments:o.split(Ma.sep),relativePathSegments:e.split(Ma.sep),fileName:Ma.basename(o),lastModified:c.mtime,createdAt:c.birthtime};switch(l){case ve.TEST:try{let p=Zt.parse(a);if(t.tests[p.id]){let u=t.tests[p.id].fullFilePath;b.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,u,t,m),u===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 _S(this.pattern,this.options)}parse(e){Sa(e);let t=this.options;if(e==="**")return lt;if(e==="")return"";let r,o=null;(r=e.match(CI))?o=t.dot?AI:RI:(r=e.match(gI))?o=(t.nocase?t.dot?bI:yI:t.dot?SI:fI)(r[1]):(r=e.match(II))?o=(t.nocase?t.dot?LI:PI:t.dot?OI:MI)(r):(r=e.match(wI))?o=t.dot?EI:vI:(r=e.match(TI))&&(o=xI);let i=Wo.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?_I:t.dot?DI:FI,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"?jI(d):d===lt?lt:d._src});return c.forEach((d,p)=>{let u=c[p+1],m=c[p-1];d!==lt||m===lt||(m===void 0?u!==void 0&&u!==lt?c[p+1]="(?:\\/|"+r+"\\/)?"+u:c[p]=r:u===void 0?c[p-1]=m+"(?:\\/|"+r+")?":u!==lt&&(c[p-1]=m+"(?:\\/|\\/"+r+"\\/)"+u,c[p+1]=lt))}),c.filter(d=>d!==lt).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 xt.defaults(e).Minimatch}};xt.AST=Wo;xt.Minimatch=zt;xt.escape=Vo;xt.unescape=mn;import{fileURLToPath as wP}from"node:url";var qo=typeof performance=="object"&&performance&&typeof performance.now=="function"?performance:Date,FS=new Set,Wd=typeof process=="object"&&process?process:{},US=(n,e,t,r)=>{typeof Wd.emitWarning=="function"?Wd.emitWarning(n,e,t,r):console.error(`[${t}] ${e}: ${n}`)},al=globalThis.AbortController,DS=globalThis.AbortSignal;if(typeof al>"u"){DS=class{onabort;_onabort=[];reason;aborted=!1;addEventListener(r,o){this._onabort.push(o)}},al=class{constructor(){e()}signal=new DS;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=Wd.env?.LRU_CACHE_IGNORE_AC_WARNING!=="1",e=()=>{n&&(n=!1,US("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 $I=n=>!FS.has(n),d4=Symbol("type"),mr=n=>n&&n===Math.floor(n)&&n>0&&isFinite(n),BS=n=>mr(n)?n<=Math.pow(2,8)?Uint8Array:n<=Math.pow(2,16)?Uint16Array:n<=Math.pow(2,32)?Uint32Array:n<=Number.MAX_SAFE_INTEGER?Ko:null:null,Ko=class extends Array{constructor(e){super(e),this.fill(0)}},Vd=class n{heap;length;static#e=!1;static create(e){let t=BS(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]}},ba=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;#T;#g;#x;#C;#b;#v;#E;#h;static unsafeExposeInternals(e){return{starts:e.#C,ttls:e.#b,sizes:e.#x,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.#T,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:u,maxSize:m=0,maxEntrySize:h=0,sizeCalculation:g,fetchMethod:f,memoMethod:S,noDeleteOnFetchRejection:w,noDeleteOnStaleGet:E,allowStaleOnFetchRejection:y,allowStaleOnFetchAbort:x,ignoreFetchAbort:T}=e;if(t!==0&&!mr(t))throw new TypeError("max option must be a nonnegative integer");let A=t?BS(t):Array;if(!A)throw new Error("invalid max value: "+t);if(this.#e=t,this.#t=m,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.#E=!!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.#T=Vd.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=!!u,this.noDeleteOnFetchRejection=!!w,this.allowStaleOnFetchRejection=!!y,this.allowStaleOnFetchAbort=!!x,this.ignoreFetchAbort=!!T,this.maxEntrySize!==0){if(this.#t!==0&&!mr(this.#t))throw new TypeError("maxSize must be a positive integer if specified");if(!mr(this.maxEntrySize))throw new TypeError("maxEntrySize must be a positive integer if specified");this.#L()}if(this.allowStale=!!l,this.noDeleteOnStaleGet=!!E,this.updateAgeOnGet=!!a,this.updateAgeOnHas=!!s,this.ttlResolution=mr(o)||o===0?o:1,this.ttlAutopurge=!!i,this.ttl=r||0,this.ttl){if(!mr(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 D="LRU_CACHE_UNBOUNDED";$I(D)&&(FS.add(D),US("TTL caching without ttlAutopurge, max, or maxSize can result in unbounded memory consumption.","UnboundedCacheWarning",D,n))}}getRemainingTTL(e){return this.#s.has(e)?1/0:0}#P(){let e=new Ko(this.#e),t=new Ko(this.#e);this.#b=e,this.#C=t,this.#M=(i,a,s=qo.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?qo.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=qo.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=()=>{};#M=()=>{};#y=()=>!1;#L(){let e=new Ko(this.#e);this.#p=0,this.#x=e,this.#N=t=>{this.#p-=e[t],e[t]=0},this.#_=(t,r,o,i)=>{if(this.#d(r))return 0;if(!mr(o))if(i){if(typeof i!="function")throw new TypeError("sizeCalculation must be a function");if(o=i(r,t),!mr(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.#k=(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)}}#N=e=>{};#k=(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-(qo.now()-s);i.ttl=l,i.start=Date.now()}}return this.#x&&(i.size=this.#x[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=qo.now()-this.#C[t];a.start=Math.floor(Date.now()-s)}this.#x&&(a.size=this.#x[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=qo.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.#T.length!==0?this.#T.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.#k(p,d,l),l&&(l.set="add"),c=!1;else{this.#z(p);let u=this.#o[p];if(t!==u){if(this.#E&&this.#d(u)){u.__abortController.abort(new Error("replaced"));let{__staleWhileFetching:m}=u;m!==void 0&&!a&&(this.#v&&this.#i?.(m,e,"set"),this.#h&&this.#g?.push([m,e,"set"]))}else a||(this.#v&&this.#i?.(u,e,"set"),this.#h&&this.#g?.push([u,e,"set"]));if(this.#N(p),this.#k(p,d,l),this.#o[p]=t,l){l.set="replace";let m=u&&this.#d(u)?u.__staleWhileFetching:u;m!==void 0&&(l.oldValue=m)}}else l&&(l.set="update")}if(o!==0&&!this.#b&&this.#P(),this.#b&&(c||this.#M(p,o,i),l&&this.#n(l,p)),!a&&this.#h&&this.#g){let u=this.#g,m;for(;m=u?.shift();)this.#r?.(...m)}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.#E&&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.#N(t),e&&(this.#l[t]=void 0,this.#o[t]=void 0,this.#T.push(t)),this.#c===1?(this.#m=this.#u=0,this.#T.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 al,{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,w=r.ignoreFetchAbort&&g!==void 0;if(r.status&&(S&&!f?(r.status.fetchAborted=!0,r.status.fetchError=a.signal.reason,w&&(r.status.fetchAbortIgnored=!0)):r.status.fetchResolved=!0),S&&!w&&!f)return p(a.signal.reason);let E=m;return this.#o[t]===m&&(g===void 0?E.__staleWhileFetching?this.#o[t]=E.__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,w=S||r.allowStaleOnFetchRejection,E=w||r.noDeleteOnFetchRejection,y=m;if(this.#o[t]===m&&(!E||y.__staleWhileFetching===void 0?this.#O(e,"fetch"):S||(this.#o[t]=y.__staleWhileFetching)),w)return r.status&&y.__staleWhileFetching!==void 0&&(r.status.returnedStale=!0),y.__staleWhileFetching;if(y.__returned===y)throw g},u=(g,f)=>{let S=this.#a?.(e,i,l);S&&S instanceof Promise&&S.then(w=>g(w===void 0?void 0:w),f),a.signal.addEventListener("abort",()=>{(!r.ignoreFetchAbort||r.allowStaleOnFetchAbort)&&(g(void 0),r.allowStaleOnFetchAbort&&(g=w=>c(w,!0)))})};r.status&&(r.status.fetchDispatched=!0);let m=new Promise(u).then(c,d),h=Object.assign(m,{__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.#E)return!1;let t=e;return!!t&&t instanceof Promise&&t.hasOwnProperty("__staleWhileFetching")&&t.__abortController instanceof al}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:u=this.allowStaleOnFetchRejection,ignoreFetchAbort:m=this.ignoreFetchAbort,allowStaleOnFetchAbort:h=this.allowStaleOnFetchAbort,context:g,forceRefresh:f=!1,status:S,signal:w}=t;if(!this.#E)return S&&(S.fetch="get"),this.get(e,{allowStale:r,updateAgeOnGet:o,noDeleteOnStaleGet:i,status:S});let E={allowStale:r,updateAgeOnGet:o,noDeleteOnStaleGet:i,ttl:a,noDisposeOnSet:s,size:l,sizeCalculation:c,noUpdateTTL:d,noDeleteOnFetchRejection:p,allowStaleOnFetchRejection:u,allowStaleOnFetchAbort:h,ignoreFetchAbort:m,status:S,signal:w},y=this.#s.get(e);if(y===void 0){S&&(S.fetch="miss");let x=this.#U(e,y,E,g);return x.__returned=x}else{let x=this.#o[y];if(this.#d(x)){let j=r&&x.__staleWhileFetching!==void 0;return S&&(S.fetch="inflight",j&&(S.returnedStale=!0)),j?x.__staleWhileFetching:x.__returned=x}let T=this.#y(y);if(!f&&!T)return S&&(S.fetch="hit"),this.#z(y),o&&this.#R(y),S&&this.#n(S,y),x;let A=this.#U(e,y,E,g),L=A.__staleWhileFetching!==void 0&&r;return S&&(S.fetch=T?"stale":"refresh",L&&T&&(S.returnedStale=!0)),L?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.#N(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.#T.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.#x&&this.#x.fill(0),this.#m=0,this.#u=0,this.#T.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 eP,win32 as np}from"node:path";import{fileURLToPath as tP}from"node:url";import{lstatSync as nP,readdir as rP,readdirSync as oP,readlinkSync as iP,realpathSync as aP}from"fs";import*as sP from"node:fs";import{lstat as cP,readdir as dP,readlink as pP,realpath as uP}from"node:fs/promises";import{EventEmitter as Qd}from"node:events";import GS from"node:stream";import{StringDecoder as GI}from"node:string_decoder";var zS=typeof process=="object"&&process?process:{stdout:null,stderr:null},WI=n=>!!n&&typeof n=="object"&&(n instanceof gr||n instanceof GS||VI(n)||qI(n)),VI=n=>!!n&&typeof n=="object"&&n instanceof Qd&&typeof n.pipe=="function"&&n.pipe!==GS.Writable.prototype.pipe,qI=n=>!!n&&typeof n=="object"&&n instanceof Qd&&typeof n.write=="function"&&typeof n.end=="function",Vn=Symbol("EOF"),qn=Symbol("maybeEmitEnd"),hr=Symbol("emittedEnd"),sl=Symbol("emittingEnd"),wa=Symbol("emittedError"),ll=Symbol("closed"),HS=Symbol("read"),cl=Symbol("flush"),jS=Symbol("flushChunk"),hn=Symbol("encoding"),Yo=Symbol("decoder"),nt=Symbol("flowing"),va=Symbol("paused"),Jo=Symbol("resume"),rt=Symbol("buffer"),Ct=Symbol("pipes"),ot=Symbol("bufferLength"),qd=Symbol("bufferPush"),dl=Symbol("bufferShift"),ft=Symbol("objectMode"),$e=Symbol("destroyed"),Kd=Symbol("error"),Yd=Symbol("emitData"),$S=Symbol("emitEnd"),Jd=Symbol("emitEnd2"),Pn=Symbol("async"),Xd=Symbol("abort"),pl=Symbol("aborted"),Ea=Symbol("signal"),to=Symbol("dataListeners"),Ht=Symbol("discarded"),Ta=n=>Promise.resolve().then(n),KI=n=>n(),YI=n=>n==="end"||n==="finish"||n==="prefinish",JI=n=>n instanceof ArrayBuffer||!!n&&typeof n=="object"&&n.constructor&&n.constructor.name==="ArrayBuffer"&&n.byteLength>=0,XI=n=>!Buffer.isBuffer(n)&&ArrayBuffer.isView(n),ul=class{src;dest;opts;ondrain;constructor(e,t,r){this.src=e,this.dest=t,this.opts=r,this.ondrain=()=>e[Jo](),this.dest.on("drain",this.ondrain)}unpipe(){this.dest.removeListener("drain",this.ondrain)}proxyErrors(e){}end(){this.unpipe(),this.opts.end&&this.dest.end()}},Zd=class extends ul{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)}},ZI=n=>!!n.objectMode,QI=n=>!n.objectMode&&!!n.encoding&&n.encoding!=="buffer",gr=class extends Qd{[nt]=!1;[va]=!1;[Ct]=[];[rt]=[];[ft];[hn];[Pn];[Yo];[Vn]=!1;[hr]=!1;[sl]=!1;[ll]=!1;[wa]=null;[ot]=0;[$e]=!1;[Ea];[pl]=!1;[to]=0;[Ht]=!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");ZI(t)?(this[ft]=!0,this[hn]=null):QI(t)?(this[hn]=t.encoding,this[ft]=!1):(this[ft]=!1,this[hn]=null),this[Pn]=!!t.async,this[Yo]=this[hn]?new GI(this[hn]):null,t&&t.debugExposeBuffer===!0&&Object.defineProperty(this,"buffer",{get:()=>this[rt]}),t&&t.debugExposePipes===!0&&Object.defineProperty(this,"pipes",{get:()=>this[Ct]});let{signal:r}=t;r&&(this[Ea]=r,r.aborted?this[Xd]():r.addEventListener("abort",()=>this[Xd]()))}get bufferLength(){return this[ot]}get encoding(){return this[hn]}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[ft]}set objectMode(e){throw new Error("objectMode must be set at instantiation time")}get async(){return this[Pn]}set async(e){this[Pn]=this[Pn]||!!e}[Xd](){this[pl]=!0,this.emit("abort",this[Ea]?.reason),this.destroy(this[Ea]?.reason)}get aborted(){return this[pl]}set aborted(e){}write(e,t,r){if(this[pl])return!1;if(this[Vn])throw new Error("write after end");if(this[$e])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[Pn]?Ta:KI;if(!this[ft]&&!Buffer.isBuffer(e)){if(XI(e))e=Buffer.from(e.buffer,e.byteOffset,e.byteLength);else if(JI(e))e=Buffer.from(e);else if(typeof e!="string")throw new Error("Non-contiguous data written to non-objectMode stream")}return this[ft]?(this[nt]&&this[ot]!==0&&this[cl](!0),this[nt]?this.emit("data",e):this[qd](e),this[ot]!==0&&this.emit("readable"),r&&o(r),this[nt]):e.length?(typeof e=="string"&&!(t===this[hn]&&!this[Yo]?.lastNeed)&&(e=Buffer.from(e,t)),Buffer.isBuffer(e)&&this[hn]&&(e=this[Yo].write(e)),this[nt]&&this[ot]!==0&&this[cl](!0),this[nt]?this.emit("data",e):this[qd](e),this[ot]!==0&&this.emit("readable"),r&&o(r),this[nt]):(this[ot]!==0&&this.emit("readable"),r&&o(r),this[nt])}read(e){if(this[$e])return null;if(this[Ht]=!1,this[ot]===0||e===0||e&&e>this[ot])return this[qn](),null;this[ft]&&(e=null),this[rt].length>1&&!this[ft]&&(this[rt]=[this[hn]?this[rt].join(""):Buffer.concat(this[rt],this[ot])]);let t=this[HS](e||null,this[rt][0]);return this[qn](),t}[HS](e,t){if(this[ft])this[dl]();else{let r=t;e===r.length||e===null?this[dl]():typeof r=="string"?(this[rt][0]=r.slice(e),t=r.slice(0,e),this[ot]-=e):(this[rt][0]=r.subarray(e),t=r.subarray(0,e),this[ot]-=e)}return this.emit("data",t),!this[rt].length&&!this[Vn]&&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[Vn]=!0,this.writable=!1,(this[nt]||!this[va])&&this[qn](),this}[Jo](){this[$e]||(!this[to]&&!this[Ct].length&&(this[Ht]=!0),this[va]=!1,this[nt]=!0,this.emit("resume"),this[rt].length?this[cl]():this[Vn]?this[qn]():this.emit("drain"))}resume(){return this[Jo]()}pause(){this[nt]=!1,this[va]=!0,this[Ht]=!1}get destroyed(){return this[$e]}get flowing(){return this[nt]}get paused(){return this[va]}[qd](e){this[ft]?this[ot]+=1:this[ot]+=e.length,this[rt].push(e)}[dl](){return this[ft]?this[ot]-=1:this[ot]-=this[rt][0].length,this[rt].shift()}[cl](e=!1){do;while(this[jS](this[dl]())&&this[rt].length);!e&&!this[rt].length&&!this[Vn]&&this.emit("drain")}[jS](e){return this.emit("data",e),this[nt]}pipe(e,t){if(this[$e])return e;this[Ht]=!1;let r=this[hr];return t=t||{},e===zS.stdout||e===zS.stderr?t.end=!1:t.end=t.end!==!1,t.proxyErrors=!!t.proxyErrors,r?t.end&&e.end():(this[Ct].push(t.proxyErrors?new Zd(this,e,t):new ul(this,e,t)),this[Pn]?Ta(()=>this[Jo]()):this[Jo]()),e}unpipe(e){let t=this[Ct].find(r=>r.dest===e);t&&(this[Ct].length===1?(this[nt]&&this[to]===0&&(this[nt]=!1),this[Ct]=[]):this[Ct].splice(this[Ct].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[Ht]=!1,this[to]++,!this[Ct].length&&!this[nt]&&this[Jo]();else if(e==="readable"&&this[ot]!==0)super.emit("readable");else if(YI(e)&&this[hr])super.emit(e),this.removeAllListeners(e);else if(e==="error"&&this[wa]){let o=t;this[Pn]?Ta(()=>o.call(this,this[wa])):o.call(this,this[wa])}return r}removeListener(e,t){return this.off(e,t)}off(e,t){let r=super.off(e,t);return e==="data"&&(this[to]=this.listeners("data").length,this[to]===0&&!this[Ht]&&!this[Ct].length&&(this[nt]=!1)),r}removeAllListeners(e){let t=super.removeAllListeners(e);return(e==="data"||e===void 0)&&(this[to]=0,!this[Ht]&&!this[Ct].length&&(this[nt]=!1)),t}get emittedEnd(){return this[hr]}[qn](){!this[sl]&&!this[hr]&&!this[$e]&&this[rt].length===0&&this[Vn]&&(this[sl]=!0,this.emit("end"),this.emit("prefinish"),this.emit("finish"),this[ll]&&this.emit("close"),this[sl]=!1)}emit(e,...t){let r=t[0];if(e!=="error"&&e!=="close"&&e!==$e&&this[$e])return!1;if(e==="data")return!this[ft]&&!r?!1:this[Pn]?(Ta(()=>this[Yd](r)),!0):this[Yd](r);if(e==="end")return this[$S]();if(e==="close"){if(this[ll]=!0,!this[hr]&&!this[$e])return!1;let i=super.emit("close");return this.removeAllListeners("close"),i}else if(e==="error"){this[wa]=r,super.emit(Kd,r);let i=!this[Ea]||this.listeners("error").length?super.emit("error",r):!1;return this[qn](),i}else if(e==="resume"){let i=super.emit("resume");return this[qn](),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[qn](),o}[Yd](e){for(let r of this[Ct])r.dest.write(e)===!1&&this.pause();let t=this[Ht]?!1:super.emit("data",e);return this[qn](),t}[$S](){return this[hr]?!1:(this[hr]=!0,this.readable=!1,this[Pn]?(Ta(()=>this[Jd]()),!0):this[Jd]())}[Jd](){if(this[Yo]){let t=this[Yo].end();if(t){for(let r of this[Ct])r.dest.write(t);this[Ht]||super.emit("data",t)}}for(let t of this[Ct])t.end();let e=super.emit("end");return this.removeAllListeners("end"),e}async collect(){let e=Object.assign([],{dataLength:0});this[ft]||(e.dataLength=0);let t=this.promise();return this.on("data",r=>{e.push(r),this[ft]||(e.dataLength+=r.length)}),await t,e}async concat(){if(this[ft])throw new Error("cannot concat in objectMode");let e=await this.collect();return this[hn]?e.join(""):Buffer.concat(e,e.dataLength)}async promise(){return new Promise((e,t)=>{this.on($e,()=>t(new Error("stream destroyed"))),this.on("error",r=>t(r)),this.on("end",()=>e())})}[Symbol.asyncIterator](){this[Ht]=!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[Vn])return t();let i,a,s=p=>{this.off("data",l),this.off("end",c),this.off($e,d),t(),a(p)},l=p=>{this.off("error",s),this.off("end",c),this.off($e,d),this.pause(),i({value:p,done:!!this[Vn]})},c=()=>{this.off("error",s),this.off("data",l),this.off($e,d),t(),i({done:!0,value:void 0})},d=()=>s(new Error("stream destroyed"));return new Promise((p,u)=>{a=u,i=p,this.once($e,d),this.once("error",s),this.once("end",c),this.once("data",l)})},throw:t,return:t,[Symbol.asyncIterator](){return this}}}[Symbol.iterator](){this[Ht]=!1;let e=!1,t=()=>(this.pause(),this.off(Kd,t),this.off($e,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(Kd,t),this.once($e,t),{next:r,throw:t,return:t,[Symbol.iterator](){return this}}}destroy(e){if(this[$e])return e?this.emit("error",e):this.emit($e),this;this[$e]=!0,this[Ht]=!0,this[rt].length=0,this[ot]=0;let t=this;return typeof t.close=="function"&&!this[ll]&&t.close(),e?this.emit("error",e):this.emit($e),this}static get isStream(){return WI}};var lP=aP.native,Ca={lstatSync:nP,readdir:rP,readdirSync:oP,readlinkSync:iP,realpathSync:lP,promises:{lstat:cP,readdir:dP,readlink:pP,realpath:uP}},YS=n=>!n||n===Ca||n===sP?Ca:{...Ca,...n,promises:{...Ca.promises,...n.promises||{}}},JS=/^\\\\\?\\([a-z]:)\\?$/i,mP=n=>n.replace(/\//g,"\\").replace(JS,"$1\\"),hP=/[\\\/]/,nn=0,XS=1,ZS=2,Ln=4,QS=6,ey=8,no=10,ty=12,tn=15,xa=~tn,ep=16,WS=32,Ra=64,gn=128,ml=256,gl=512,VS=Ra|gn|gl,gP=1023,tp=n=>n.isFile()?ey:n.isDirectory()?Ln:n.isSymbolicLink()?no:n.isCharacterDevice()?ZS:n.isBlockDevice()?QS:n.isSocket()?ty:n.isFIFO()?XS:nn,qS=new Map,Aa=n=>{let e=qS.get(n);if(e)return e;let t=n.normalize("NFKD");return qS.set(n,t),t},KS=new Map,hl=n=>{let e=KS.get(n);if(e)return e;let t=Aa(n.toLowerCase());return KS.set(n,t),t},fl=class extends ba{constructor(){super({max:256})}},rp=class extends ba{constructor(e=16*1024){super({maxSize:e,sizeCalculation:t=>t.length+1})}},ny=Symbol("PathScurry setAsCwd"),St=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}#T;get atime(){return this.#T}#g;get mtime(){return this.#g}#x;get ctime(){return this.#x}#C;get birthtime(){return this.#C}#b;#v;#E;#h;#P;#R;#n;#M;#y;#L;get parentPath(){return(this.parent||this).fullpath()}get path(){return this.parentPath}constructor(e,t=nn,r,o,i,a,s){this.name=e,this.#b=i?hl(e):Aa(e),this.#n=t&gP,this.nocase=i,this.roots=o,this.root=r||this,this.#M=a,this.#E=s.fullpath,this.#P=s.relative,this.#R=s.relativePosix,this.parent=s.parent,this.parent?this.#e=this.parent.#e:this.#e=YS(s.fs)}depth(){return this.#v!==void 0?this.#v:this.parent?this.#v=this.parent.depth()+1:this.#v=0}childrenCache(){return this.#M}resolve(e){if(!e)return this;let t=this.getRootString(e),o=e.substring(t.length).split(this.splitSep);return t?this.getRoot(t).#N(o):this.#N(o)}#N(e){let t=this;for(let r of e)t=t.child(r);return t}children(){let e=this.#M.get(this);if(e)return e;let t=Object.assign([],{provisional:0});return this.#M.set(this,t),this.#n&=~ep,t}child(e,t){if(e===""||e===".")return this;if(e==="..")return this.parent||this;let r=this.children(),o=this.nocase?hl(e):Aa(e);for(let l of r)if(l.#b===o)return l;let i=this.parent?this.sep:"",a=this.#E?this.#E+i+e:void 0,s=this.newChild(e,nn,{...t,parent:this,fullpath:a});return this.canReaddir()||(s.#n|=gn),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.#E!==void 0)return this.#E;let e=this.name,t=this.parent;if(!t)return this.#E=this.name;let o=t.fullpath()+(t.parent?this.sep:"")+e;return this.#E=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&tn)===nn}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&tn)===ey}isDirectory(){return(this.#n&tn)===Ln}isCharacterDevice(){return(this.#n&tn)===ZS}isBlockDevice(){return(this.#n&tn)===QS}isFIFO(){return(this.#n&tn)===XS}isSocket(){return(this.#n&tn)===ty}isSymbolicLink(){return(this.#n&no)===no}lstatCached(){return this.#n&WS?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&tn;return!(e!==nn&&e!==no||this.#n&ml||this.#n&gn)}calledReaddir(){return!!(this.#n&ep)}isENOENT(){return!!(this.#n&gn)}isNamed(e){return this.nocase?this.#b===hl(e):this.#b===Aa(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}}#k(e){this.#n|=ep;for(let t=e.provisional;t<e.length;t++){let r=e[t];r&&r.#_()}}#_(){this.#n&gn||(this.#n=(this.#n|gn)&xa,this.#A())}#A(){let e=this.children();e.provisional=0;for(let t of e)t.#_()}#I(){this.#n|=gl,this.#D()}#D(){if(this.#n&Ra)return;let e=this.#n;(e&tn)===Ln&&(e&=xa),this.#n=e|Ra,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|=ml,e==="ENOENT"&&(t|=gn),(e==="EINVAL"||e==="UNKNOWN")&&(t&=xa),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=tp(e),o=this.newChild(e.name,r,{parent:this}),i=o.#n&tn;return i!==Ln&&i!==no&&i!==nn&&(o.#n|=Ra),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?hl(e.name):Aa(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&xa|tp(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&gn))try{return this.#W(await this.#e.promises.lstat(this.fullpath())),this}catch(e){this.#U(e.code)}}lstatSync(){if(!(this.#n&gn))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:u,mode:m,mtime:h,mtimeMs:g,nlink:f,rdev:S,size:w,uid:E}=e;this.#T=t,this.#f=r,this.#C=o,this.#u=i,this.#p=a,this.#o=s,this.#x=l,this.#m=c,this.#t=d,this.#w=p,this.#s=u,this.#i=m,this.#g=h,this.#S=g,this.#r=f,this.#c=S,this.#l=w,this.#a=E;let y=tp(e);this.#n=this.#n&xa|y|WS,y!==nn&&y!==Ln&&y!==no&&(this.#n|=Ra)}#$=[];#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.#k(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.#k(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.#k(e)}catch(r){this.#F(r.code),e.provisional=0}return e.slice(0,e.provisional)}canReaddir(){if(this.#n&VS)return!1;let e=tn&this.#n;return e===nn||e===Ln||e===no}shouldWalk(e,t){return(this.#n&Ln)===Ln&&!(this.#n&VS)&&!e.has(this)&&(!t||t(this))}async realpath(){if(this.#L)return this.#L;if(!((gl|ml|gn)&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(!((gl|ml|gn)&this.#n))try{let e=this.#e.realpathSync(this.fullpath());return this.#L=this.resolve(e)}catch{this.#I()}}[ny](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}},Sl=class n extends St{sep="\\";splitSep=hP;constructor(e,t=nn,r,o,i,a,s){super(e,t,r,o,i,a,s)}newChild(e,t=nn,r={}){return new n(e,t,this.root,this.roots,this.nocase,this.childrenCache(),r)}getRootString(e){return np.parse(e).root}getRoot(e){if(e=mP(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 Xo(e,this).root}sameRoot(e,t=this.root.name){return e=e.toUpperCase().replace(/\//g,"\\").replace(JS,"$1\\"),e===t}},yl=class n extends St{splitSep="/";sep="/";constructor(e,t=nn,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=nn,r={}){return new n(e,t,this.root,this.roots,this.nocase,this.childrenCache(),r)}},bl=class{root;rootPath;roots;cwd;#e;#t;#i;nocase;#r;constructor(e=process.cwd(),t,r,{nocase:o,childrenCacheSize:i=16*1024,fs:a=Ca}={}){this.#r=YS(a),(e instanceof URL||e.startsWith("file://"))&&(e=tP(e));let s=t.resolve(e);this.roots=Object.create(null),this.rootPath=this.parseRootPath(s),this.#e=new fl,this.#t=new fl,this.#i=new rp(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,u=this.rootPath,m=!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:u+=(m?"":p)+h}),m=!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 St||(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 St||(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 St||(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 St||(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 St||(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 St||(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 St||(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,u)=>{l.add(p),p.readdirCB((m,h)=>{if(m)return u(m);let g=h.length;if(!g)return u();let f=()=>{--g===0&&u()};for(let S of h)(!i||i(S))&&s.push(r?S:S.fullpath()),o&&S.isSymbolicLink()?S.realpath().then(w=>w?.isUnknown()?w.lstat():w).then(w=>w?.shouldWalk(l,a)?c(w,f):f()):S.shouldWalk(l,a)?c(S,f):f()},!0)},d=e;return new Promise((p,u)=>{c(d,m=>{if(m)return u(m);p(s)})})}walkSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof St||(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 u=p;if(p.isSymbolicLink()){if(!(o&&(u=p.realpathSync())))continue;u.isUnknown()&&u.lstatSync()}u.shouldWalk(l,a)&&l.add(u)}}return s}[Symbol.asyncIterator](){return this.iterate()}iterate(e=this.cwd,t={}){return typeof e=="string"?e=this.cwd.resolve(e):e instanceof St||(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 St||(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 St||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t,s=new gr({objectMode:!0});(!i||i(e))&&s.write(r?e:e.fullpath());let l=new Set,c=[e],d=0,p=()=>{let u=!1;for(;!u;){let m=c.shift();if(!m){d===0&&s.end();return}d++,l.add(m);let h=(f,S,w=!1)=>{if(f)return s.emit("error",f);if(o&&!w){let E=[];for(let y of S)y.isSymbolicLink()&&E.push(y.realpath().then(x=>x?.isUnknown()?x.lstat():x));if(E.length){Promise.all(E).then(()=>h(null,S,!0));return}}for(let E of S)E&&(!i||i(E))&&(s.write(r?E:E.fullpath())||(u=!0));d--;for(let E of S){let y=E.realpathCached()||E;y.shouldWalk(l,a)&&c.push(y)}u&&!s.flowing?s.once("drain",p):g||p()},g=!0;m.readdirCB(h,!0),g=!1}};return p(),s}streamSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof St||(t=e,e=this.cwd);let{withFileTypes:r=!0,follow:o=!1,filter:i,walkFilter:a}=t,s=new gr({objectMode:!0}),l=new Set;(!i||i(e))&&s.write(r?e:e.fullpath());let c=[e],d=0,p=()=>{let u=!1;for(;!u;){let m=c.shift();if(!m){d===0&&s.end();return}d++,l.add(m);let h=m.readdirSync();for(let g of h)(!i||i(g))&&(s.write(r?g:g.fullpath())||(u=!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)}}u&&!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[ny](t)}},Xo=class extends bl{sep="\\";constructor(e=process.cwd(),t={}){let{nocase:r=!0}=t;super(e,np,"\\",{...t,nocase:r}),this.nocase=r;for(let o=this.cwd;o;o=o.parent)o.nocase=this.nocase}parseRootPath(e){return np.parse(e).root.toUpperCase()}newRoot(e){return new Sl(this.rootPath,Ln,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")||e.startsWith("\\")||/^[a-z]:(\/|\\)/i.test(e)}},Zo=class extends bl{sep="/";constructor(e=process.cwd(),t={}){let{nocase:r=!1}=t;super(e,eP,"/",{...t,nocase:r}),this.nocase=r}parseRootPath(e){return"/"}newRoot(e){return new yl(this.rootPath,Ln,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")}},Ia=class extends Zo{constructor(e=process.cwd(),t={}){let{nocase:r=!0}=t;super(e,{...t,nocase:r})}},E4=process.platform==="win32"?Sl:yl,ry=process.platform==="win32"?Xo:process.platform==="darwin"?Ia:Zo;var fP=n=>n.length>=1,SP=n=>n.length>=1,Qo=class n{#e;#t;#i;length;#r;#a;#w;#c;#p;#s;#l=!0;constructor(e,t,r,o){if(!fP(e))throw new TypeError("empty pattern list");if(!SP(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,u,m,...h]=this.#t;c[0]===""&&(c.shift(),h.shift());let g=[i,a,s,l,""].join("/"),f=[d,p,u,m,""].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]===lt}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 yP=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",ei=class{relative;relativeChildren;absolute;absoluteChildren;platform;mmopts;constructor(e,{nobrace:t,nocase:r,noext:o,noglobstar:i,platform:a=yP}){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 zt(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 Qo(o,i,0,this.platform),s=new zt(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 op=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()]))}},ip=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)])}},ap=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())}},Pa=class n{hasWalkedCache;matches=new ip;subwalks=new ap;patterns;follow;dot;opts;constructor(e,t){this.opts=e,this.follow=!!e.follow,this.dot=!!e.dot,this.hasWalkedCache=t?t.copy():new op}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===lt){(!o.isSymbolicLink()||this.follow||i.checkFollowGlobstar())&&this.subwalks.add(o,i);let p=c?.pattern(),u=c?.rest();if(!c||(p===""||p===".")&&!u)this.matches.add(o,s,p===""||p===".");else if(p===".."){let m=o.parent||o;u?this.hasWalkedCache.hasWalked(m,u)||this.subwalks.add(m,u):this.matches.add(m,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===lt?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 bP=(n,e)=>typeof n=="string"?new ei([n],e):Array.isArray(n)?new ei(n,e):n,wl=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=bP(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 Pa(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 Pa(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()}},La=class extends wl{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}},Oa=class extends wl{results;constructor(e,t,r){super(e,t,r),this.results=new gr({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 vP=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",fn=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=wP(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||vP,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"?Xo:t.platform==="darwin"?Ia:t.platform?Zo:ry;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 zt(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 Qo(l,d,0,this.platform)})}async walk(){return[...await new La(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 La(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 Oa(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 Oa(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 sp=(n,e={})=>{Array.isArray(n)||(n=[n]);for(let t of n)if(new zt(t,e).hasMagic())return!0;return!1};function vl(n,e={}){return new fn(n,e).streamSync()}function ay(n,e={}){return new fn(n,e).stream()}function ti(n,e={}){return new fn(n,e).walkSync()}async function oy(n,e={}){return new fn(n,e).walk()}function El(n,e={}){return new fn(n,e).iterateSync()}function sy(n,e={}){return new fn(n,e).iterate()}var EP=vl,TP=Object.assign(ay,{sync:vl}),xP=El,CP=Object.assign(sy,{sync:El}),RP=Object.assign(ti,{stream:vl,iterate:El}),iy=Object.assign(oy,{glob:oy,globSync:ti,sync:RP,globStream:ay,stream:TP,globStreamSync:vl,streamSync:EP,globIterate:sy,iterate:CP,globIterateSync:El,iterateSync:xP,Glob:fn,hasMagic:sp,escape:Vo,unescape:mn});iy.glob=iy;import ro,{dirname as py}from"path";import{cwd as up}from"process";import uy from"yaml";import{z as Ee}from"zod";import ly from"fs";import Ma from"path";import AP from"yaml";import{z as lp}from"zod";var cy=!1,cp=[`**/*.${_t.TEST}`,`**/*.${_t.MODULE}`],dp=lp.string().refine(n=>/^[a-zA-Z0-9-]+$/.test(n)),pp=50,IP=lp.object({fileType:lp.nativeEnum(ve)});function ye(n,e){let t={project:n,tests:{},modules:{}},r=n.config.include??cp,o=Array.from(n.config.exclude??[]).concat(gg),i=ti(r,{absolute:!1,cwd:n.rootDir,ignore:o,dotRelative:!1,maxDepth:pp,nodir:!0});for(let a of i)PP(n.rootDir,a,t,e);return cy=!0,t}function PP(n,e,t,r){let o=Ma.join(n,e),i;try{i=ly.readFileSync(o,"utf-8")}catch(p){r.warn(`Could not read possible Momentic file at ${o}, skipping: ${p}`);return}let a;try{if(a=AP.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=IP.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=ly.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:Ma.sep,fullPathSegments:o.split(Ma.sep),relativePathSegments:e.split(Ma.sep),fileName:Ma.basename(o),lastModified:c.mtime,createdAt:c.birthtime};switch(l){case ve.TEST:try{let p=Qt.parse(a);if(t.tests[p.id]){let u=t.tests[p.id].fullFilePath;b.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: ${u}
47
47
 
48
- Second test path: ${o}`)}t.tests[p.id]={type:ve.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 ve.MODULE:try{let p=Lt.parse(a);t.modules[p.moduleId]={type:ve.MODULE,name:p.name,id:p.moduleId,description:p.description??void 0,...d};let u=d.fileName.replace(".module.yaml","");!ly&&Ie(p.name)!==u&&r.warn(`The module with ID ${p.moduleId} has a name (${p.name}) that does not match its file name (${u}). 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 ni="momentic.config.yaml",cy="momentic.workspace.yaml",OP=Te.object({projects:Te.string().array().describe("list of glob patterns to find project (momentic.config.yaml) files")}),MP=Te.union([Te.string(),Te.object({fromFile:Te.string(),json:Te.boolean().optional()})]),NP=Te.object({name:lp,baseUrl:Te.string(),envFile:Te.string().optional().describe("path to a file on disk to read environment variables from. can be relative to project root or absolute."),envVariables:Te.record(Te.string(),MP).optional(),inheritFromShell:Te.boolean().optional().describe("inherit all environment variables from the shell - might be noisy"),browser:kr.optional()}),kP=Te.object({postSave:Te.string().optional()}),_P=Te.object({name:lp,include:Te.string().array().optional().describe("list of glob patterns that match momentic files (optional)"),exclude:Te.string().array().optional().describe("opposite of include, takes precedence over include"),goldenFileDir:Te.string().optional(),reporterDir:Te.string().optional(),outputDir:Te.string().optional(),retries:Te.number().optional().describe("number of retries per test"),parallel:Te.number().optional().describe("degree of parallelism"),environments:Te.array(NP).optional(),gitMainBranch:Te.string().optional(),gitProtectedBranches:Te.string().array().optional(),ai:Id.optional(),browser:kr.extend({disableSecondaryCacheResolution:Te.boolean().optional()}).optional(),advanced:yg.optional(),hooks:kP.optional()});function uy(n,e){let t;try{t=IP(n,"utf-8")}catch(o){b.warn(`Could not read possible Momentic ${e} file at ${n}: ${o}`);return}let r;try{if(r=py.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){b.warn(`Possible Momentic ${e} file at ${n} does not parse as valid YAML: ${o}`);return}return r}function pp(n){let e=uy(n,"project configuration");if(e!==void 0)try{return _P.parse(e)}catch(t){b.warn(`Possible Momentic project configuration file at ${n} does not adhere to the required schema: ${t}`);return}}function DP(n){let e=uy(n,"workspace configuration");if(e!==void 0)try{return OP.parse(e)}catch(t){b.warn(`Possible Momentic workspace configuration file at ${n} does not adhere to the required schema: ${t}`);return}}function FP(){let n=[],e=dp(),t=ro.parse(e).root,r=15,o=0;for(;o<r;){o++;let i=ro.basename(e);if(Hs.includes(i))return b.warn(`Stopping search for Momentic projects since the current directory name (${i}) is likely a system artifact folder.`),n;for(let a of PP(e))if(a.endsWith(ni)){let s=ro.join(e,a),l=pp(s);l&&n.push({configFilePath:s,config:l,rootDir:dy(s)})}if(n.length)return n;if(e=ro.dirname(e),e===t)break}return n}function jt(n={}){let{configFilePath:e,nameFilter:t}=n,r=up(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 b.debug(`Found valid project configuration at ${r[0].configFilePath}`),r[0]}function UP(n){let e=DP(n);if(!e||!e.projects||!e.projects.length)return;let t=e.projects.map(i=>(i.endsWith("/")||(i+="/"),`${i}*${ni}`)),r=ti(t,{absolute:!1,cwd:dp(),dotRelative:!1,maxDepth:cp,nodir:!0}),o=[];for(let i of r){let a=ro.join(dp(),i),s=pp(a);s&&o.push({configFilePath:a,config:s,rootDir:dy(a)})}return o}function up(n){if(n){n=ro.resolve(n);let t=pp(n);return t||(console.error(`No valid Momentic project file found at ${n}.`),process.exit(1)),[{config:t,configFilePath:n,rootDir:ro.dirname(n)}]}if(AP(cy)){let t=UP(cy);if(t)return t}return FP()}function ri(n,e){let t=py.stringify(n);LP(e,t)}import oi from"fs";import mp from"path";import{z as hp}from"zod";var my="golden/visual-diff",hy="reports",gy="test-results";var BP=hp.object({width:hp.number(),height:hp.number()}),ii=class{defaultGoldenScreenshotDir;regenerateGoldenFiles;constructor(e,t){let r=mp.join(e.rootDir,e.config.goldenFileDir??my);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=mp.join(this.defaultGoldenScreenshotDir,`${t.id}.jpg`));let i=`${o}.metadata.json`;if(this.regenerateGoldenFiles)return oi.mkdirSync(mp.dirname(o),{recursive:!0}),oi.writeFileSync(o,r.buffer),oi.writeFileSync(i,JSON.stringify({width:r.width,height:r.height})),{buffer:Buffer.from(r.buffer),width:r.width,height:r.height};if(oi.existsSync(o)){let a=oi.readFileSync(o),s=BP.parse(JSON.parse(oi.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 ai=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,disable_clickhouse_caches:!1,disable_clickhouse_last_updated_endpoint:!1}}isBooleanFlagEnabled(e){return this.flags[e]}getAllFlags(){return{...this.flags}}getFlagPayload(e){}async refresh(){}};import zP from"simple-git";var Ee=zP();function vl(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 xe(n,e){try{return(await e).trim()}catch(t){n.error({err:t},"Failed to run git command");return}}function HP(){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";if(process.env.PROJECT_ID&&process.env.BUILD_ID)return"GCPCloudBuild"}async function jP(n){let[e,t,r,o]=await Promise.all([xe(n,Ee.show(["--no-patch","--format=%ci"])),xe(n,Ee.listRemote(["--get-url","origin"])),xe(n,Ee.show(["-s","--pretty=%B"])),xe(n,Ee.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 $P(n){let[e,t,r]=await Promise.all([xe(n,Ee.listRemote(["--get-url","origin"])),xe(n,Ee.show(["-s","--pretty=%B"])),xe(n,Ee.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_PROJECT_PATH,pipelineId:`${process.env.CI_PIPELINE_ID}:${process.env.CI_JOB_ID}`}}async function GP(n){let[e,t,r,o]=await Promise.all([xe(n,Ee.show(["--no-patch","--format=%ci"])),xe(n,Ee.listRemote(["--get-url","origin"])),xe(n,Ee.show(["-s","--pretty=%B"])),xe(n,Ee.show(["-s","--pretty=%an"]))]),i=t?.includes("github.com"),a=t?.includes("gitlab.com"),s=t?vl(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 WP(n){let[e,t,r]=await Promise.all([xe(n,Ee.show(["--no-patch","--format=%ci"])),xe(n,Ee.show(["-s","--pretty=%B"])),xe(n,Ee.show(["-s","--pretty=%an"]))]),o=process.env.BUILDKITE_REPO,i=o?.includes("github.com"),a=o?.includes("gitlab.com"),s=o?vl(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 VP(n){let[e,t,r]=await Promise.all([xe(n,Ee.show(["--no-patch","--format=%ci"])),xe(n,Ee.show(["-s","--pretty=%B"])),xe(n,Ee.show(["-s","--pretty=%an"]))]),o=process.env["Build.Repository.Uri"],i=o?.includes("github.com"),a=o?.includes("gitlab.com"),s=o?vl(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 qP(n,e){let[t,r,o,i,a,s,l,c]=await Promise.all([xe(n,Ee.revparse(["HEAD"])),xe(n,Ee.revparse(["--short","HEAD"])),xe(n,Ee.revparse(["--abbrev-ref","HEAD"])),xe(n,Ee.listRemote(["--get-url","origin"])),xe(n,Ee.show(["--no-patch","--format=%ci"])),xe(n,Ee.show(["-s","--pretty=%B"])),xe(n,Ee.show(["-s","--pretty=%an"])),e?xe(n,Ee.raw(["merge-base","--fork-point",e])):Promise.resolve(void 0)]),d=c?await xe(n,Ee.show(["--no-patch","--format=%ci",c])):void 0,p=i?.includes("github.com"),u=i?.includes("gitlab.com"),m=i?vl(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?m:void 0,gitlabProjectPath:u?m:void 0,pipelineId:void 0}}async function KP(){let n=process.env._HEAD_REPO_URL;return{gitCommitSha:process.env.COMMIT_SHA,gitCommitShaShort:process.env.COMMIT_SHA?.slice(0,6),gitBranchName:process.env.BRANCH_NAME,gitOriginUrl:n?process.env._HEAD_REPO_URL:void 0,gitCommitTimestamp:void 0,gitCommitMessage:void 0,gitCommitAuthorName:void 0,githubRepository:n?process.env.REPO_FULL_NAME:void 0,gitlabProjectPath:n?void 0:process.env.REPO_FULL_NAME,pipelineId:`${process.env.PROJECT_ID}:${process.env.BUILD_ID}`}}async function YP(n){let e=n.config.gitProtectedBranches??[];return n.config.gitMainBranch&&e.push(n.config.gitMainBranch),{gitMainBranch:n.config.gitMainBranch,gitProtectedBranches:e}}async function JP(n,e){let t=HP();if(!t)return qP(n,e);switch(t){case"GithubActions":return jP(n);case"GitlabCI":return $P(n);case"CircleCI":return GP(n);case"Buildkite":return WP(n);case"AzureDevOps":return VP(n);case"GCPCloudBuild":return KP()}}async function XP(n,e,t,r){let o=r;if(!r.gitCommitSha)return o;if(r.gitMainBranch&&(!o.lastCommitOnMainSha||!o.lastCommitOnMainTimestamp)){let i=await e.getMergeBaseCommitFromGitlab(t,r.gitMainBranch,r.gitCommitSha);o={...o,lastCommitOnMainSha:i.sha,lastCommitOnMainTimestamp:i.committer.date}}if(!o.gitCommitTimestamp||!o.gitCommitAuthorName||!o.gitCommitMessage||!o.gitCommitAuthorName){let i=await e.getCommitFromGitlab(t,r.gitCommitSha);i&&(o={...o,gitCommitTimestamp:o.gitCommitTimestamp??i.committer.date,gitCommitAuthorName:o.gitCommitAuthorName??i.author.name,gitCommitMessage:o.gitCommitMessage??i.message})}return o}async function QP(n,e,t,r,o){let i=o;if(!o.gitCommitSha)return i;if(o.gitMainBranch&&(!i.lastCommitOnMainSha||!i.lastCommitOnMainTimestamp)){let a=await e.getMergeBaseCommitFromGithub(t,r,o.gitMainBranch,o.gitCommitSha);i={...i,lastCommitOnMainSha:a.sha,lastCommitOnMainTimestamp:a.committer.date}}if(!i.gitCommitTimestamp||!i.gitCommitAuthorName||!i.gitCommitMessage||!i.gitCommitAuthorName){let a=await e.getCommitFromGithub(t,r,o.gitCommitSha);a&&(i={...i,gitCommitTimestamp:i.gitCommitTimestamp??a.committer.date,gitCommitAuthorName:i.gitCommitAuthorName??a.author.name,gitCommitMessage:i.gitCommitMessage??a.message})}return i}async function ZP(n,e,t){try{if(t.githubRepository){let[r,o]=t.githubRepository.split("/");return await QP(n,e,r,o,t)}else if(t.gitlabProjectPath)return await XP(n,e,t.gitlabProjectPath,t)}catch(r){n.warn({err:r},"Failed to get remote git metadata")}return t}async function si(n,e,t){let r=await YP(t),o=await JP(n,r.gitMainBranch),i={...r,...o},a=await ZP(n,e,i);return{...r,...o,...a}}import mk from"http";import{z as Sp}from"zod";var z="v1",Na="2.7.1";var gr=class extends Error{constructor(e){super(e),this.name="TimeoutError"}};var fy=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")};function B(n,e){let{milliseconds:t,fallback:r,message:o,customTimers:i={setTimeout,clearTimeout}}=e,a,s;if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);return new Promise((l,c)=>{if(e.signal){let{signal:p}=e;if(p.aborted)return c(fy(p));s=()=>c(fy(p)),p.addEventListener("abort",s)}let d=()=>{if(r)try{l(r())}catch(p){c(p)}else{typeof n.cancel=="function"&&Promise.resolve().then(()=>n.cancel()).catch(()=>{});let p=o instanceof Error?o:new gr(o??`Promise timed out after ${t}ms`);c(p)}};a=i.setTimeout(d,t),Promise.resolve(n).then(p=>l(p)).catch(p=>c(p))}).finally(()=>{i.clearTimeout(a),e.signal&&s&&e.signal.removeEventListener("abort",s)})}var Tl=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)}};var gp=["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 Sy(n){return new Array(n).fill(0).map(()=>gp[Math.floor(Math.random()*gp.length)]).join("-")}var eL=9e4,tL=3,nL=1500,rL=15e3,Sn=class extends Error{status;rawError;constructor(e,t,r,o={}){super(r,o),this.status=e,this.rawError=t}};async function oL(n){return n.text().then(e=>{try{return JSON.parse(e).error}catch{return e}})}var fp=class{baseUrl;logger;constructor(e){this.baseUrl=e.baseUrl,this.logger=e.logger}getHeaders(){let e={"Content-Type":"application/json"};return Na&&(e[bg]=Na),e}async sendRequest(e,t){let{retries:r=tL,requestTimeoutMs:o=eL,initialRetryDelayMs:i=nL,maxRetryDelayMs:a=rL}=t,s=r,l=r,c,d={path:e,baseUrl:this.baseUrl,method:t.method};for(;s>0;)try{return s--,await this.sendSingleRequestHelper(e,t,o)}catch(p){if(c=p,p instanceof Sn&&p.status>=400&&p.status<500)throw p;if(p instanceof Error&&p.name==="AbortError"&&(c=new gr),s===0)throw c;let u=l-s,m=Math.min(i*Math.pow(2,u-1),a);await new Promise(h=>setTimeout(h,m))}throw this.logger.warn({...d,err:c},"Got fatal error response from Momentic server"),c}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 oL(c);throw new Sn(c.status,p,`Request to ${t.method} ${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)}}},Dt=class extends fp{apiKey;constructor(e){super(e),this.apiKey=e.apiKey}getHeaders(){return{...super.getHeaders(),Authorization:`Bearer ${this.apiKey}`}}};var ct=class extends Dt{constructor(e){super(e)}getAppUrl(){return this.baseUrl.replace(/\/\/api/,"//app")}async getAuthInfo(){let e=await this.sendRequest(`/${z}/auth/check`,{method:"GET",noLog:!0,retries:10,requestTimeoutMs:5e3});return Bg.parse(e)}async bulkGetRunStatus(e){let t=await this.sendRequest(`/${z}/runs/status`,{method:"POST",body:e,noLog:!0,retries:3,requestTimeoutMs:1e4});return _g.parse(t)}async getTestYAMLExport(e){let t=await this.sendRequest(`/${z}/tests/export`,{method:"POST",body:e,retries:3,requestTimeoutMs:3e4});return Lg.parse(t)}async updateStepCaches(e,t){await this.sendRequest(`/${z}/cache`,{method:"PATCH",body:e,extraHeaders:t,retries:3,requestTimeoutMs:1e4,initialRetryDelayMs:3e3})}async getStepCacheForTest(e,t){let r=await this.sendRequest(`/${z}/cache`,{method:"POST",body:e,extraHeaders:t,retries:10,requestTimeoutMs:3e4,initialRetryDelayMs:3e3});return Og.parse(r)}async queueTests(e){let t=await this.sendRequest(`/${z}/tests/queue`,{method:"POST",body:e,retries:3,requestTimeoutMs:1e4});return Pg.parse(t)}async uploadScreenshot(e){let t=await this.sendRequest(`/${z}/screenshots`,{method:"POST",body:e,noLog:!0,retries:3,requestTimeoutMs:5e3});return Ug.parse(t)}async getAllEnvironments(){let e=await this.sendRequest(`/${z}/environments`,{method:"GET",retries:3,requestTimeoutMs:5e3});return zg.parse(e)}async acquireCacheLock(e,t){let r=await this.sendRequest(`/${z}/result-cache/lock`,{method:"POST",body:e,signal:t,retries:3,requestTimeoutMs:3e4});return qg.parse(r)}async releaseCacheLock(e){await this.sendRequest(`/${z}/result-cache/lock`,{method:"DELETE",body:{key:e},retries:3,requestTimeoutMs:5e3})}async deleteCacheResult(e){await this.sendRequest(`/${z}/result-cache/entry`,{method:"DELETE",body:e,retries:3,requestTimeoutMs:5e3})}async setCacheResult(e){await this.sendRequest(`/${z}/result-cache/entry`,{method:"PATCH",body:e,retries:3,requestTimeoutMs:5e3})}async getCacheResult(e){try{return await this.sendRequest(`/${z}/result-cache/entry`,{method:"POST",body:e,retries:3,requestTimeoutMs:5e3})}catch(t){if(t instanceof Error&&t.message.includes("404"))return null;throw t}}async queueSuiteRuns(e){let t=await this.sendRequest(`/${z}/suites/queue`,{method:"POST",body:e,retries:3,requestTimeoutMs:5e3});return Hg.parse(t)}async bulkGetRunGroupStatus(e){let t={runGroupIds:e},r=await this.sendRequest(`/${z}/run-groups/status`,{method:"POST",body:t,noLog:!0,retries:3,requestTimeoutMs:5e3});return Sh.array().parse(r)}async uploadProposedSteps(e,t){try{await this.sendRequest(`/${z}/test-fragments/`,{method:"POST",body:e,retries:3,requestTimeoutMs:1e4})}catch(r){t.error({err:r},"Failed to upload proposed steps")}}async uploadSnapshotScreenshot(e,t,r){try{await this.sendRequest(`/${z}/snapshots/${t}/screenshot`,{method:"POST",body:r,noLog:!0,retries:3,requestTimeoutMs:1e4})}catch(o){e.error({err:o},"Failed to upload screenshot")}}async generateConsoleLogsForRunAttemptUploadUrl(e,t,r){let o=await this.sendRequest(`/${z}/runs/${t}/attempts/${r}/console-logs`,{method:"POST",noLog:!0,retries:3,requestTimeoutMs:5e3});return sa.parse(o)}async generateNetworkLogsForRunAttemptUploadUrl(e,t,r){let o=await this.sendRequest(`/${z}/runs/${t}/attempts/${r}/network-logs`,{method:"POST",noLog:!0,retries:3,requestTimeoutMs:1e4});return sa.parse(o)}async generateHtmlSnapshotUploadUrl(e,t){let r=await this.sendRequest(`/${z}/snapshots/${t}/html`,{method:"POST",noLog:!0,retries:3,requestTimeoutMs:1e4});return sa.parse(r)}async reportBillableEvents(e,t){try{await this.sendRequest(`/${z}/billing/events`,{method:"POST",body:t,noLog:!0,retries:10,requestTimeoutMs:1e4})}catch(r){e.error({err:r},"Failed to report billable event")}}async fetchTestFragment(e){let t=await this.sendRequest(`/${z}/test-fragments/${e}`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:1e4});return jg.parse(t)}async patchTestFragment(e,t){await this.sendRequest(`/${z}/test-fragments/${e}`,{method:"PATCH",body:t,retries:3,requestTimeoutMs:1e4})}async getPastTestResults(e,t){let r=await this.sendRequest(`/${z}/results/tests/${e}`,{method:"POST",body:t,retries:3,requestTimeoutMs:1e4});return $g.parse(r)}async generateTestResultsUploadUrl(){let e=await this.sendRequest(`/${z}/results/uploads`,{method:"POST",noLog:!0,retries:3,requestTimeoutMs:1e4});return Gg.parse(e)}async startProcessingResultsUpload(e,t){let r=await this.sendRequest(`/${z}/results/uploads/${e}/process`,{method:"POST",noLog:!0,body:t,retries:3,requestTimeoutMs:1e4});return Wg.parse(r)}async fetchIconKnowledgeBase(e){try{let t=await this.sendRequest(`/${z}/knowledge-base/icons`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:5e3});return Zg.parse(t)}catch(t){return e.error({err:t},"Failed to fetch icon knowledge base"),null}}async saveNewIcons(e,t){try{await this.sendRequest(`/${z}/knowledge-base/icons`,{method:"POST",body:e,noLog:!0,retries:3,requestTimeoutMs: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(`/${z}/git/github/${e}/${t}/merge-base-commit?${i.toString()}`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:1e4});return la.parse(a)}async getCommitFromGithub(e,t,r){let o=await this.sendRequest(`/${z}/git/github/${e}/${t}/commits/${r}`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:1e4});return la.parse(o)}async getMergeBaseCommitFromGitlab(e,t,r){let o=new URLSearchParams;o.set("base",t),o.set("head",r);let i=await this.sendRequest(`/${z}/git/gitlab/${e}/merge-base-commit?${o.toString()}`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:5e3});return la.parse(i)}async getCommitFromGitlab(e,t){let r=await this.sendRequest(`/${z}/git/gitlab/${e}/commits/${t}`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:1e4});return la.parse(r)}async getAgentConfig(){let e=await this.sendRequest(`/${z}/web-agent/agent-config`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:5e3});return Sp.record(Sp.string(),Sp.string()).parse(e)}};import{randomUUID as yy}from"crypto";var El=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??yy(),properties:yd({},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??yy(),properties:yd({creditsUsed:r,usedBy:t},o)}])}catch(i){e.error({err:i},"Failed to report credits used")}}};function li(n,e,t){return fetch(n,{method:"PUT",body:t,headers:{"Content-Type":e}})}var xl=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 li(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 li(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 li(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 ci=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){return this.client.fetchIconKnowledgeBase(e)}saveNewIcons(e,t){return this.client.saveNewIcons(e,t)}};import{Faker as iL,en as aL}from"@faker-js/faker";var di="v1",fr=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 iL({locale:aL}),this.fakerInstance.seed(e.fakerSeed))}async sendAiGenerate(e){let t=typeof e=="string"?{input:e}:e;return this.httpClient.sendRequest(`/${di}/tools/ai/generate`,{method:"POST",body:t}).catch(r=>{throw r instanceof Sn?new Error(r.rawError):new Error(`Failed to send AI generation: ${r.message}`)})}async sendSms(e){return this.httpClient.sendRequest(`/${di}/tools/sms/send`,{method:"POST",body:e}).then(()=>{}).catch(t=>{throw t instanceof Sn?new Error(t.rawError):new Error(`Failed to send sms: ${t.message}`)})}async fetchLatestSms(e){return this.httpClient.sendRequest(`/${di}/tools/sms/fetchLatest`,{method:"POST",body:e}).catch(t=>{throw t instanceof Sn?new Error(t.rawError):t})}async sendEmail(e){return this.httpClient.sendRequest(`/${di}/tools/email/send`,{method:"POST",body:e}).then(()=>{}).catch(t=>{throw t instanceof Sn?new Error(t.rawError):new Error(`Failed to send email: ${t.message}`)})}async fetchAllEmails(e){return this.httpClient.sendRequest(`/${di}/tools/email/fetchAll`,{method:"POST",body:e}).catch(t=>{throw t instanceof Sn?new Error(t.rawError):new Error(`Failed to fetch all emails: ${t.message}`)})}async fetchLatestEmail(e){return this.httpClient.sendRequest(`/${di}/tools/email/fetchLatest`,{method:"POST",body:e}).catch(t=>{throw t instanceof Sn?new Error(t.rawError):new Error(`Failed to fetch latest emails: ${t.message}`)})}};import{z as sL}from"zod";var pi=class extends Dt{agentConfig;constructor(e,t){super(t),this.agentConfig=e}async rankChunksWithAi(e,t){let r={...e,loggerTags:t.loggerTags},o=await this.sendRequest(`/${z}/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(`/${z}/web-agent/recommend-chunks`,{method:"POST",body:{cliVersion:Na,...e},signal:t.abortSignal});return Th.parse(r)}async getScreenshotFromS3(e){let t=await this.sendRequest(`/${z}/s3/visual-diff-screenshot`,{method:"POST",body:{url:e}});return sL.string().parse(t)}async getElementLocation(e,t){let r={...e,disableCache:t.disableCache,loggerTags:t.loggerTags,useMemory:t.useMemory,agentConfigVersion:this.agentConfig?.locator},o=await this.sendRequest(`/${z}/web-agent/locate-element`,{method:"POST",body:r,signal:t.abortSignal});return Ag.parse(o)}async getAssertionResult(e,t){let r={...e,disableCache:!!t.disableCache,useConsensus:!!t.useConsensus,attemptNumber:t.attemptNumber,loggerTags:t.loggerTags,useMemory:t.useMemory,agentConfigVersion:this.agentConfig?.locator},o=await this.sendRequest(`/${z}/web-agent/assertion`,{method:"POST",body:r,signal:t.abortSignal});return Pd.parse(o)}async getLintStepResult(e,t){let r={...e,disableCache:!!t.disableCache,loggerTags:t.loggerTags},o=await this.sendRequest(`/${z}/web-agent/lint/step`,{method:"POST",body:r,signal:t.abortSignal});return Rg.parse(o)}async getVisualAssertionResult(e,t){let r={...e,disableCache:!!t.disableCache,useConsensus:!!t.useConsensus,loggerTags:t.loggerTags},o=await this.sendRequest(`/${z}/web-agent/visual-assertion`,{method:"POST",body:r,signal:t.abortSignal});return Pd.parse(o)}async getAiActionCommand(e,t){let r=await this.sendRequest(`/${z}/web-agent/next-command-dynamic`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Cg.parse(r)}async getMultiturnAiActionCommand(e,t){return await this.sendRequest(`/${z}/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(`/${z}/web-agent/ai-action/evaluate`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Wc.parse(r)}async getReverseMappedDescription(e,t){let r=await this.sendRequest(`/${z}/web-agent/reverse-mapped-description`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Ig.parse(r)}async getTextExtraction(e,t){let r={...e,disableCache:t.disableCache,loggerTags:t.loggerTags},o=await this.sendRequest(`/${z}/web-agent/text-extraction`,{method:"POST",body:r,signal:t.abortSignal});return Gc.parse(o)}async getTestResultClassification(e,t){let r=await this.sendRequest(`/${z}/web-agent/result-classification`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return rd.parse(r)}async getExtractedKeywords(e,t){let r=await this.sendRequest(`/${z}/web-agent/extract-keywords`,{method:"POST",body:{goal:e,disableCache:t.disableCache,context:e},signal:t.abortSignal});return Mh.parse(r)}async getAutohealingProposal(e,t){let r=await this.sendRequest(`/${z}/web-agent/autoheal-section`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return wm.parse(r)}async getFailureRecoveryProposal(e,t){let r=await this.sendRequest(`/${z}/web-agent/failure-recovery`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return vm.parse(r)}async getIframeRegex(e,t){let r=await this.sendRequest(`/${z}/web-agent/iframe-regex`,{method:"POST",body:e,signal:t.abortSignal});return nm.parse(r)}};var ui=class extends Dt{generator;constructor(e,t){super(e),this.generator=t}async runTemplateMatching(e,t={}){let r=await this.sendRequest(`/${z}/web-agent/template-matching`,{method:"POST",body:e,signal:t?.signal});return rm.parse(r)}async constructIframeRegex(e,t={}){return this.generator.getIframeRegex(e,{abortSignal:t.signal})}};var Cl=class{constructor(e){this.client=e}async uploadResultsArchive(e,t){let{uploadUrl:r,id:o}=await this.client.generateTestResultsUploadUrl(),i=await li(r,"application/zip",t);if(!i.ok)throw new Error(`Failed to upload test results: ${await i.text()}`);let{runGroupId:a}=await this.client.startProcessingResultsUpload(o,{runGroupId:e});return a}};function mi({orgId:n,client:e,gitMetadata:t,alwaysSaveCache:r,noCache:o}){return o?new Xa:new yp(n,e,t,r)}var yp=class{constructor(e,t,{gitMainBranch:r,gitBranchName:o,gitProtectedBranches:i,gitCommitTimestamp:a,lastCommitOnMainSha:s,lastCommitOnMainTimestamp:l},c){this.orgId=e;this.client=t;this.cacheHeaders={},r&&(this.cacheHeaders[wg]=r),o&&(this.cacheHeaders[vg]=o),a&&(this.cacheHeaders[Tg]=a.toISOString()),s&&(this.cacheHeaders[Eg]=s),l&&(this.cacheHeaders[xg]=l.toISOString()),c?this.writeCaches=!0:o?this.writeCaches=!i.includes(o):this.writeCaches=!0}cacheHeaders;writeCaches;async saveStepCacheEntries({entries:e,testId:t,logger: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{steps:t,beforeSteps:r,afterSteps:o}=e.stepLists,i=await this.client.getStepCacheForTest({testId:e.testId,steps:t,schemaVersion:e.schemaVersion},this.cacheHeaders);if(!this.writeCaches){e.logger.debug("Skipping cache last used at update because branch is protected");return}for(let s of[t,r,o])s&&Ho({steps:s,stepCacheEntries:i,logger:e.logger});let{cachesToSave:a}=await gt({stepLists:e.stepLists,cacheCreationParams:{testId:e.testId,orgId:this.orgId}});this.client.updateStepCaches({entries:a,testId:e.testId},this.cacheHeaders)}};import hk from"path";import{Server as UN}from"socket.io";import{cloneDeep as lL}from"lodash-es";var cL={showOverlay:!1},bp=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}){return this.sessions.set(i,{controller:e,context:t,cleanup:r,clientIp:o,browserBehavior:lL(cL)}),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)}},X=new bp;function by(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(),w=g.toEditorDisplayCopy();JSON.stringify(w)===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:w,isInPageLoad:h.isInPageLoad}),r=Date.now()),l=S,i=w}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=X.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),u=(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),m=setInterval(async()=>{let g=X.getSession(e)?.controller?.browser;if(!g||g.closed){clearInterval(m);return}else if(c)return;c=!0;try{let f=await g.getAllFrameUrls(),S=g.retrieveAndClearDebugData();u(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,m]}}var Sr={};var dL=n=>()=>{let{sessionId:e}=n.metadata;Sr[e]?.abort?.abort()},wy={event:"cancelApiTest",createHandler:dL};import{CookieJar as PL}from"tough-cookie";import{randomUUID as yL}from"crypto";import{faker as pL}from"@faker-js/faker";import uL from"assert";import mL from"axios";import hL from"moment";import*as gL from"otpauth";import fL from"pg";async function vy(n){let e;try{e=new URL(n.url).hostname}catch{}let t=[];return n.headers.getSetCookie()?.forEach(r=>{let o=_s(r,e);t.push(...o)}),t}var SL=Object.getPrototypeOf(async function(){}).constructor;async function Ty(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 u=async()=>await Promise.resolve(new SL("axios","moment","faker","assert","pg","Octokit","createAppAuth","OTPAuth","extractCookiesFromResponse","env","setVariable","setPersistentVariable","sendSms","waitForLatestSms","email","sms","ai",r)(mL,hL,i.fakerInstance??pL,uL,fL,d,p,gL,vy,o,s,c,S=>i.sms.send(S),S=>i.sms.fetchLatest(S),i.email,i.sms,i.ai)),m=!0,h,g;try{h=await B(u(),{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}`),m=!1,f instanceof gr?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:m,error:g}}async function Ey({code:n,fragment:e,context:t,localTools:r,logger:o,signal:i,timeoutMs:a=sr}){let s=yL(),l=await Ty(s,{code:n,options:{fragment:e,timeoutMs:a},bindings:t.toObjectCopy(),tools:r,signal:i},o);return b.debug(`[${s}] Got execution result: ${JSON.stringify(l)}`),l}import{createHmac as bL,randomUUID as wL}from"crypto";import vL from"fetch-retry";var TL=vL(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}}),xy=process.env.GCP_JS_EVAL_FUNCTION_ENDPOINT,Cy=process.env.MOMENTIC_LAMBDA_AUTH_SECRET;async function Ry({orgId:n,code:e,fragment:t,context:r,timeoutMs:o=sr,retries:i=2,signal:a,logger:s}){if(!xy)throw new Error("GCP_JS_EVAL_FUNCTION_ENDPOINT environment variable not set");let l,c,d=0;if(!Cy)throw new Error("Missing lambda auth secret.");let p=bL("sha256",Cy).update(n).digest("hex");for(;d<=i;){d++,a?.throwIfAborted();let m={id:wL(),orgId:n,momenticLambdaAuthHash:p,code:e,fragment:t,state:r.toObjectCopy(),timeoutMs:o};try{if(l=await B(TL(xy,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(m)}),{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 u;try{u=zh.parse(await l.json())}catch(m){throw new Error(`Code evaluation server returned invalid response: ${m}`)}if(u.error)throw new Error(`Code evaluation error: ${u.error}`);return u}async function Kn(n){let e;if(process.env.GCP_JS_EVAL_FUNCTION_ENDPOINT)e=await Ry(n);else if(n.localTools)e=await Ey({...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:ve.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 ve.MODULE:try{let p=Lt.parse(a);t.modules[p.moduleId]={type:ve.MODULE,name:p.name,id:p.moduleId,description:p.description??void 0,...d};let u=d.fileName.replace(".module.yaml","");!cy&&Ie(p.name)!==u&&r.warn(`The module with ID ${p.moduleId} has a name (${p.name}) that does not match its file name (${u}). 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 ni="momentic.config.yaml",dy="momentic.workspace.yaml",kP=Ee.object({projects:Ee.string().array().describe("list of glob patterns to find project (momentic.config.yaml) files")}),_P=Ee.union([Ee.string(),Ee.object({fromFile:Ee.string(),json:Ee.boolean().optional()})]),DP=Ee.object({name:dp,baseUrl:Ee.string(),envFile:Ee.string().optional().describe("path to a file on disk to read environment variables from. can be relative to project root or absolute."),envVariables:Ee.record(Ee.string(),_P).optional(),inheritFromShell:Ee.boolean().optional().describe("inherit all environment variables from the shell - might be noisy"),browser:kr.optional()}),FP=Ee.object({postSave:Ee.string().optional()}),UP=Ee.object({name:dp,include:Ee.string().array().optional().describe("list of glob patterns that match momentic files (optional)"),exclude:Ee.string().array().optional().describe("opposite of include, takes precedence over include"),goldenFileDir:Ee.string().optional(),reporterDir:Ee.string().optional(),outputDir:Ee.string().optional(),retries:Ee.number().optional().describe("number of retries per test"),parallel:Ee.number().optional().describe("degree of parallelism"),environments:Ee.array(DP).optional(),gitMainBranch:Ee.string().optional(),gitProtectedBranches:Ee.string().array().optional(),ai:Ld.optional(),browser:kr.extend({disableSecondaryCacheResolution:Ee.boolean().optional()}).optional(),advanced:bg.optional(),hooks:FP.optional()});function my(n,e){let t;try{t=OP(n,"utf-8")}catch(o){b.warn(`Could not read possible Momentic ${e} file at ${n}: ${o}`);return}let r;try{if(r=uy.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){b.warn(`Possible Momentic ${e} file at ${n} does not parse as valid YAML: ${o}`);return}return r}function mp(n){let e=my(n,"project configuration");if(e!==void 0)try{return UP.parse(e)}catch(t){b.warn(`Possible Momentic project configuration file at ${n} does not adhere to the required schema: ${t}`);return}}function BP(n){let e=my(n,"workspace configuration");if(e!==void 0)try{return kP.parse(e)}catch(t){b.warn(`Possible Momentic workspace configuration file at ${n} does not adhere to the required schema: ${t}`);return}}function zP(){let n=[],e=up(),t=ro.parse(e).root,r=15,o=0;for(;o<r;){o++;let i=ro.basename(e);if($s.includes(i))return b.warn(`Stopping search for Momentic projects since the current directory name (${i}) is likely a system artifact folder.`),n;for(let a of MP(e))if(a.endsWith(ni)){let s=ro.join(e,a),l=mp(s);l&&n.push({configFilePath:s,config:l,rootDir:py(s)})}if(n.length)return n;if(e=ro.dirname(e),e===t)break}return n}function jt(n={}){let{configFilePath:e,nameFilter:t}=n,r=hp(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 b.debug(`Found valid project configuration at ${r[0].configFilePath}`),r[0]}function HP(n){let e=BP(n);if(!e||!e.projects||!e.projects.length)return;let t=e.projects.map(i=>(i.endsWith("/")||(i+="/"),`${i}*${ni}`)),r=ti(t,{absolute:!1,cwd:up(),dotRelative:!1,maxDepth:pp,nodir:!0}),o=[];for(let i of r){let a=ro.join(up(),i),s=mp(a);s&&o.push({configFilePath:a,config:s,rootDir:py(a)})}return o}function hp(n){if(n){n=ro.resolve(n);let t=mp(n);return t||(console.error(`No valid Momentic project file found at ${n}.`),process.exit(1)),[{config:t,configFilePath:n,rootDir:ro.dirname(n)}]}if(LP(dy)){let t=HP(dy);if(t)return t}return zP()}function ri(n,e){let t=uy.stringify(n);NP(e,t)}import oi from"fs";import gp from"path";import{z as fp}from"zod";var hy="golden/visual-diff",gy="reports",fy="test-results";var jP=fp.object({width:fp.number(),height:fp.number()}),ii=class{defaultGoldenScreenshotDir;regenerateGoldenFiles;constructor(e,t){let r=gp.join(e.rootDir,e.config.goldenFileDir??hy);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=gp.join(this.defaultGoldenScreenshotDir,`${t.id}.jpg`));let i=`${o}.metadata.json`;if(this.regenerateGoldenFiles)return oi.mkdirSync(gp.dirname(o),{recursive:!0}),oi.writeFileSync(o,r.buffer),oi.writeFileSync(i,JSON.stringify({width:r.width,height:r.height})),{buffer:Buffer.from(r.buffer),width:r.width,height:r.height};if(oi.existsSync(o)){let a=oi.readFileSync(o),s=jP.parse(JSON.parse(oi.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 ai=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,disable_clickhouse_caches:!1,disable_clickhouse_last_updated_endpoint:!1}}isBooleanFlagEnabled(e){return this.flags[e]}getAllFlags(){return{...this.flags}}getFlagPayload(e){}async refresh(){}};import $P from"simple-git";var Te=$P();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 xe(n,e){try{return(await e).trim()}catch(t){n.error({err:t},"Failed to run git command");return}}function GP(){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";if(process.env.PROJECT_ID&&process.env.BUILD_ID)return"GCPCloudBuild"}async function WP(n){let[e,t,r,o]=await Promise.all([xe(n,Te.show(["--no-patch","--format=%ci"])),xe(n,Te.listRemote(["--get-url","origin"])),xe(n,Te.show(["-s","--pretty=%B"])),xe(n,Te.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 VP(n){let[e,t,r]=await Promise.all([xe(n,Te.listRemote(["--get-url","origin"])),xe(n,Te.show(["-s","--pretty=%B"])),xe(n,Te.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_PROJECT_PATH,pipelineId:`${process.env.CI_PIPELINE_ID}:${process.env.CI_JOB_ID}`}}async function qP(n){let[e,t,r,o]=await Promise.all([xe(n,Te.show(["--no-patch","--format=%ci"])),xe(n,Te.listRemote(["--get-url","origin"])),xe(n,Te.show(["-s","--pretty=%B"])),xe(n,Te.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 KP(n){let[e,t,r]=await Promise.all([xe(n,Te.show(["--no-patch","--format=%ci"])),xe(n,Te.show(["-s","--pretty=%B"])),xe(n,Te.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 YP(n){let[e,t,r]=await Promise.all([xe(n,Te.show(["--no-patch","--format=%ci"])),xe(n,Te.show(["-s","--pretty=%B"])),xe(n,Te.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 JP(n,e){let[t,r,o,i,a,s,l,c]=await Promise.all([xe(n,Te.revparse(["HEAD"])),xe(n,Te.revparse(["--short","HEAD"])),xe(n,Te.revparse(["--abbrev-ref","HEAD"])),xe(n,Te.listRemote(["--get-url","origin"])),xe(n,Te.show(["--no-patch","--format=%ci"])),xe(n,Te.show(["-s","--pretty=%B"])),xe(n,Te.show(["-s","--pretty=%an"])),e?xe(n,Te.raw(["merge-base","--fork-point",e])):Promise.resolve(void 0)]),d=c?await xe(n,Te.show(["--no-patch","--format=%ci",c])):void 0,p=i?.includes("github.com"),u=i?.includes("gitlab.com"),m=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?m:void 0,gitlabProjectPath:u?m:void 0,pipelineId:void 0}}async function XP(){let n=process.env._HEAD_REPO_URL;return{gitCommitSha:process.env.COMMIT_SHA,gitCommitShaShort:process.env.COMMIT_SHA?.slice(0,6),gitBranchName:process.env.BRANCH_NAME,gitOriginUrl:n?process.env._HEAD_REPO_URL:void 0,gitCommitTimestamp:void 0,gitCommitMessage:void 0,gitCommitAuthorName:void 0,githubRepository:n?process.env.REPO_FULL_NAME:void 0,gitlabProjectPath:n?void 0:process.env.REPO_FULL_NAME,pipelineId:`${process.env.PROJECT_ID}:${process.env.BUILD_ID}`}}async function ZP(n){let e=n.config.gitProtectedBranches??[];return n.config.gitMainBranch&&e.push(n.config.gitMainBranch),{gitMainBranch:n.config.gitMainBranch,gitProtectedBranches:e}}async function QP(n,e){let t=GP();if(!t)return JP(n,e);switch(t){case"GithubActions":return WP(n);case"GitlabCI":return VP(n);case"CircleCI":return qP(n);case"Buildkite":return KP(n);case"AzureDevOps":return YP(n);case"GCPCloudBuild":return XP()}}async function eL(n,e,t,r){let o=r;if(!r.gitCommitSha)return o;if(r.gitMainBranch&&(!o.lastCommitOnMainSha||!o.lastCommitOnMainTimestamp)){let i=await e.getMergeBaseCommitFromGitlab(t,r.gitMainBranch,r.gitCommitSha);o={...o,lastCommitOnMainSha:i.sha,lastCommitOnMainTimestamp:i.committer.date}}if(!o.gitCommitTimestamp||!o.gitCommitAuthorName||!o.gitCommitMessage||!o.gitCommitAuthorName){let i=await e.getCommitFromGitlab(t,r.gitCommitSha);i&&(o={...o,gitCommitTimestamp:o.gitCommitTimestamp??i.committer.date,gitCommitAuthorName:o.gitCommitAuthorName??i.author.name,gitCommitMessage:o.gitCommitMessage??i.message})}return o}async function tL(n,e,t,r,o){let i=o;if(!o.gitCommitSha)return i;if(o.gitMainBranch&&(!i.lastCommitOnMainSha||!i.lastCommitOnMainTimestamp)){let a=await e.getMergeBaseCommitFromGithub(t,r,o.gitMainBranch,o.gitCommitSha);i={...i,lastCommitOnMainSha:a.sha,lastCommitOnMainTimestamp:a.committer.date}}if(!i.gitCommitTimestamp||!i.gitCommitAuthorName||!i.gitCommitMessage||!i.gitCommitAuthorName){let a=await e.getCommitFromGithub(t,r,o.gitCommitSha);a&&(i={...i,gitCommitTimestamp:i.gitCommitTimestamp??a.committer.date,gitCommitAuthorName:i.gitCommitAuthorName??a.author.name,gitCommitMessage:i.gitCommitMessage??a.message})}return i}async function nL(n,e,t){try{if(t.githubRepository){let[r,o]=t.githubRepository.split("/");return await tL(n,e,r,o,t)}else if(t.gitlabProjectPath)return await eL(n,e,t.gitlabProjectPath,t)}catch(r){n.warn({err:r},"Failed to get remote git metadata")}return t}async function si(n,e,t){let r=await ZP(t),o=await QP(n,r.gitMainBranch),i={...r,...o},a=await nL(n,e,i);return{...r,...o,...a}}import fk from"http";import{z as bp}from"zod";var z="v1",Na="2.7.2";var fr=class extends Error{constructor(e){super(e),this.name="TimeoutError"}};var Sy=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")};function B(n,e){let{milliseconds:t,fallback:r,message:o,customTimers:i={setTimeout,clearTimeout}}=e,a,s;if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);return new Promise((l,c)=>{if(e.signal){let{signal:p}=e;if(p.aborted)return c(Sy(p));s=()=>c(Sy(p)),p.addEventListener("abort",s)}let d=()=>{if(r)try{l(r())}catch(p){c(p)}else{typeof n.cancel=="function"&&Promise.resolve().then(()=>n.cancel()).catch(()=>{});let p=o instanceof Error?o:new fr(o??`Promise timed out after ${t}ms`);c(p)}};a=i.setTimeout(d,t),Promise.resolve(n).then(p=>l(p)).catch(p=>c(p))}).finally(()=>{i.clearTimeout(a),e.signal&&s&&e.signal.removeEventListener("abort",s)})}var xl=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)}};var Sp=["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 yy(n){return new Array(n).fill(0).map(()=>Sp[Math.floor(Math.random()*Sp.length)]).join("-")}var rL=9e4,oL=3,iL=1500,aL=15e3,Sn=class extends Error{status;rawError;constructor(e,t,r,o={}){super(r,o),this.status=e,this.rawError=t}};async function sL(n){return n.text().then(e=>{try{return JSON.parse(e).error}catch{return e}})}var yp=class{baseUrl;logger;constructor(e){this.baseUrl=e.baseUrl,this.logger=e.logger}getHeaders(){let e={"Content-Type":"application/json"};return Na&&(e[wg]=Na),e}async sendRequest(e,t){let{retries:r=oL,requestTimeoutMs:o=rL,initialRetryDelayMs:i=iL,maxRetryDelayMs:a=aL}=t,s=r,l=r,c,d={path:e,baseUrl:this.baseUrl,method:t.method};for(;s>0;)try{return s--,await this.sendSingleRequestHelper(e,t,o)}catch(p){if(c=p,p instanceof Sn&&p.status>=400&&p.status<500)throw p;if(p instanceof Error&&p.name==="AbortError"&&(c=new fr),s===0)throw c;let u=l-s,m=Math.min(i*Math.pow(2,u-1),a);await new Promise(h=>setTimeout(h,m))}throw this.logger.warn({...d,err:c},"Got fatal error response from Momentic server"),c}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 sL(c);throw new Sn(c.status,p,`Request to ${t.method} ${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)}}},Dt=class extends yp{apiKey;constructor(e){super(e),this.apiKey=e.apiKey}getHeaders(){return{...super.getHeaders(),Authorization:`Bearer ${this.apiKey}`}}};var ct=class extends Dt{constructor(e){super(e)}getAppUrl(){return this.baseUrl.replace(/\/\/api/,"//app")}async getAuthInfo(){let e=await this.sendRequest(`/${z}/auth/check`,{method:"GET",noLog:!0,retries:10,requestTimeoutMs:5e3});return zg.parse(e)}async bulkGetRunStatus(e){let t=await this.sendRequest(`/${z}/runs/status`,{method:"POST",body:e,noLog:!0,retries:3,requestTimeoutMs:1e4});return Dg.parse(t)}async getTestYAMLExport(e){let t=await this.sendRequest(`/${z}/tests/export`,{method:"POST",body:e,retries:3,requestTimeoutMs:3e4});return Og.parse(t)}async updateStepCaches(e,t){await this.sendRequest(`/${z}/cache`,{method:"PATCH",body:e,extraHeaders:t,retries:3,requestTimeoutMs:1e4,initialRetryDelayMs:3e3})}async getStepCacheForTest(e,t){let r=await this.sendRequest(`/${z}/cache`,{method:"POST",body:e,extraHeaders:t,retries:10,requestTimeoutMs:3e4,initialRetryDelayMs:3e3});return Mg.parse(r)}async queueTests(e){let t=await this.sendRequest(`/${z}/tests/queue`,{method:"POST",body:e,retries:3,requestTimeoutMs:1e4});return Lg.parse(t)}async uploadScreenshot(e){let t=await this.sendRequest(`/${z}/screenshots`,{method:"POST",body:e,noLog:!0,retries:3,requestTimeoutMs:5e3});return Bg.parse(t)}async getAllEnvironments(){let e=await this.sendRequest(`/${z}/environments`,{method:"GET",retries:3,requestTimeoutMs:5e3});return Hg.parse(e)}async acquireCacheLock(e,t){let r=await this.sendRequest(`/${z}/result-cache/lock`,{method:"POST",body:e,signal:t,retries:3,requestTimeoutMs:3e4});return Kg.parse(r)}async releaseCacheLock(e){await this.sendRequest(`/${z}/result-cache/lock`,{method:"DELETE",body:{key:e},retries:3,requestTimeoutMs:5e3})}async deleteCacheResult(e){await this.sendRequest(`/${z}/result-cache/entry`,{method:"DELETE",body:e,retries:3,requestTimeoutMs:5e3})}async setCacheResult(e){await this.sendRequest(`/${z}/result-cache/entry`,{method:"PATCH",body:e,retries:3,requestTimeoutMs:5e3})}async getCacheResult(e){try{return await this.sendRequest(`/${z}/result-cache/entry`,{method:"POST",body:e,retries:3,requestTimeoutMs:5e3})}catch(t){if(t instanceof Error&&t.message.includes("404"))return null;throw t}}async queueSuiteRuns(e){let t=await this.sendRequest(`/${z}/suites/queue`,{method:"POST",body:e,retries:3,requestTimeoutMs:5e3});return jg.parse(t)}async bulkGetRunGroupStatus(e){let t={runGroupIds:e},r=await this.sendRequest(`/${z}/run-groups/status`,{method:"POST",body:t,noLog:!0,retries:3,requestTimeoutMs:5e3});return yh.array().parse(r)}async uploadProposedSteps(e,t){try{await this.sendRequest(`/${z}/test-fragments/`,{method:"POST",body:e,retries:3,requestTimeoutMs:1e4})}catch(r){t.error({err:r},"Failed to upload proposed steps")}}async uploadSnapshotScreenshot(e,t,r){try{await this.sendRequest(`/${z}/snapshots/${t}/screenshot`,{method:"POST",body:r,noLog:!0,retries:3,requestTimeoutMs:1e4})}catch(o){e.error({err:o},"Failed to upload screenshot")}}async generateConsoleLogsForRunAttemptUploadUrl(e,t,r){let o=await this.sendRequest(`/${z}/runs/${t}/attempts/${r}/console-logs`,{method:"POST",noLog:!0,retries:3,requestTimeoutMs:5e3});return sa.parse(o)}async generateNetworkLogsForRunAttemptUploadUrl(e,t,r){let o=await this.sendRequest(`/${z}/runs/${t}/attempts/${r}/network-logs`,{method:"POST",noLog:!0,retries:3,requestTimeoutMs:1e4});return sa.parse(o)}async generateHtmlSnapshotUploadUrl(e,t){let r=await this.sendRequest(`/${z}/snapshots/${t}/html`,{method:"POST",noLog:!0,retries:3,requestTimeoutMs:1e4});return sa.parse(r)}async reportBillableEvents(e,t){try{await this.sendRequest(`/${z}/billing/events`,{method:"POST",body:t,noLog:!0,retries:10,requestTimeoutMs:1e4})}catch(r){e.error({err:r},"Failed to report billable event")}}async fetchTestFragment(e){let t=await this.sendRequest(`/${z}/test-fragments/${e}`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:1e4});return $g.parse(t)}async patchTestFragment(e,t){await this.sendRequest(`/${z}/test-fragments/${e}`,{method:"PATCH",body:t,retries:3,requestTimeoutMs:1e4})}async getPastTestResults(e,t){let r=await this.sendRequest(`/${z}/results/tests/${e}`,{method:"POST",body:t,retries:3,requestTimeoutMs:1e4});return Gg.parse(r)}async generateTestResultsUploadUrl(){let e=await this.sendRequest(`/${z}/results/uploads`,{method:"POST",noLog:!0,retries:3,requestTimeoutMs:1e4});return Wg.parse(e)}async startProcessingResultsUpload(e,t){let r=await this.sendRequest(`/${z}/results/uploads/${e}/process`,{method:"POST",noLog:!0,body:t,retries:3,requestTimeoutMs:1e4});return Vg.parse(r)}async fetchIconKnowledgeBase(e){try{let t=await this.sendRequest(`/${z}/knowledge-base/icons`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:5e3});return ef.parse(t)}catch(t){return e.error({err:t},"Failed to fetch icon knowledge base"),null}}async saveNewIcons(e,t){try{await this.sendRequest(`/${z}/knowledge-base/icons`,{method:"POST",body:e,noLog:!0,retries:3,requestTimeoutMs: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(`/${z}/git/github/${e}/${t}/merge-base-commit?${i.toString()}`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:1e4});return la.parse(a)}async getCommitFromGithub(e,t,r){let o=await this.sendRequest(`/${z}/git/github/${e}/${t}/commits/${r}`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:1e4});return la.parse(o)}async getMergeBaseCommitFromGitlab(e,t,r){let o=new URLSearchParams;o.set("base",t),o.set("head",r);let i=await this.sendRequest(`/${z}/git/gitlab/${e}/merge-base-commit?${o.toString()}`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:5e3});return la.parse(i)}async getCommitFromGitlab(e,t){let r=await this.sendRequest(`/${z}/git/gitlab/${e}/commits/${t}`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:1e4});return la.parse(r)}async getAgentConfig(){let e=await this.sendRequest(`/${z}/web-agent/agent-config`,{method:"GET",noLog:!0,retries:3,requestTimeoutMs:5e3});return bp.record(bp.string(),bp.string()).parse(e)}};import{randomUUID as by}from"crypto";var Cl=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??by(),properties:wd({},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??by(),properties:wd({creditsUsed:r,usedBy:t},o)}])}catch(i){e.error({err:i},"Failed to report credits used")}}};function li(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 li(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 li(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 li(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 ci=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){return this.client.fetchIconKnowledgeBase(e)}saveNewIcons(e,t){return this.client.saveNewIcons(e,t)}};import{Faker as lL,en as cL}from"@faker-js/faker";var di="v1",Sr=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 lL({locale:cL}),this.fakerInstance.seed(e.fakerSeed))}async sendAiGenerate(e){let t=typeof e=="string"?{input:e}:e;return this.httpClient.sendRequest(`/${di}/tools/ai/generate`,{method:"POST",body:t}).catch(r=>{throw r instanceof Sn?new Error(r.rawError):new Error(`Failed to send AI generation: ${r.message}`)})}async sendSms(e){return this.httpClient.sendRequest(`/${di}/tools/sms/send`,{method:"POST",body:e}).then(()=>{}).catch(t=>{throw t instanceof Sn?new Error(t.rawError):new Error(`Failed to send sms: ${t.message}`)})}async fetchLatestSms(e){return this.httpClient.sendRequest(`/${di}/tools/sms/fetchLatest`,{method:"POST",body:e}).catch(t=>{throw t instanceof Sn?new Error(t.rawError):t})}async sendEmail(e){return this.httpClient.sendRequest(`/${di}/tools/email/send`,{method:"POST",body:e}).then(()=>{}).catch(t=>{throw t instanceof Sn?new Error(t.rawError):new Error(`Failed to send email: ${t.message}`)})}async fetchAllEmails(e){return this.httpClient.sendRequest(`/${di}/tools/email/fetchAll`,{method:"POST",body:e}).catch(t=>{throw t instanceof Sn?new Error(t.rawError):new Error(`Failed to fetch all emails: ${t.message}`)})}async fetchLatestEmail(e){return this.httpClient.sendRequest(`/${di}/tools/email/fetchLatest`,{method:"POST",body:e}).catch(t=>{throw t instanceof Sn?new Error(t.rawError):new Error(`Failed to fetch latest emails: ${t.message}`)})}};import{z as dL}from"zod";var pi=class extends Dt{agentConfig;constructor(e,t){super(t),this.agentConfig=e}async rankChunksWithAi(e,t){let r={...e,loggerTags:t.loggerTags},o=await this.sendRequest(`/${z}/web-agent/recommend-chunks-ai`,{method:"POST",body:r,signal:t.abortSignal});return xh.parse(o)}async rankChunksWithRag(e,t){let r=await this.sendRequest(`/${z}/web-agent/recommend-chunks`,{method:"POST",body:{cliVersion:Na,...e},signal:t.abortSignal});return Th.parse(r)}async getScreenshotFromS3(e){let t=await this.sendRequest(`/${z}/s3/visual-diff-screenshot`,{method:"POST",body:{url:e}});return dL.string().parse(t)}async getElementLocation(e,t){let r={...e,disableCache:t.disableCache,loggerTags:t.loggerTags,useMemory:t.useMemory,agentConfigVersion:this.agentConfig?.locator},o=await this.sendRequest(`/${z}/web-agent/locate-element`,{method:"POST",body:r,signal:t.abortSignal});return Ig.parse(o)}async getAssertionResult(e,t){let r={...e,disableCache:!!t.disableCache,useConsensus:!!t.useConsensus,attemptNumber:t.attemptNumber,loggerTags:t.loggerTags,useMemory:t.useMemory,agentConfigVersion:this.agentConfig?.locator},o=await this.sendRequest(`/${z}/web-agent/assertion`,{method:"POST",body:r,signal:t.abortSignal});return Od.parse(o)}async getLintStepResult(e,t){let r={...e,disableCache:!!t.disableCache,loggerTags:t.loggerTags},o=await this.sendRequest(`/${z}/web-agent/lint/step`,{method:"POST",body:r,signal:t.abortSignal});return Ag.parse(o)}async getVisualAssertionResult(e,t){let r={...e,disableCache:!!t.disableCache,useConsensus:!!t.useConsensus,loggerTags:t.loggerTags},o=await this.sendRequest(`/${z}/web-agent/visual-assertion`,{method:"POST",body:r,signal:t.abortSignal});return Od.parse(o)}async getAiActionCommand(e,t){let r=await this.sendRequest(`/${z}/web-agent/next-command-dynamic`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Rg.parse(r)}async getMultiturnAiActionCommand(e,t){return await this.sendRequest(`/${z}/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(`/${z}/web-agent/ai-action/evaluate`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return qc.parse(r)}async getReverseMappedDescription(e,t){let r=await this.sendRequest(`/${z}/web-agent/reverse-mapped-description`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Pg.parse(r)}async getTextExtraction(e,t){let r={...e,disableCache:t.disableCache,loggerTags:t.loggerTags},o=await this.sendRequest(`/${z}/web-agent/text-extraction`,{method:"POST",body:r,signal:t.abortSignal});return Vc.parse(o)}async getTestResultClassification(e,t){let r=await this.sendRequest(`/${z}/web-agent/result-classification`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return id.parse(r)}async getExtractedKeywords(e,t){let r=await this.sendRequest(`/${z}/web-agent/extract-keywords`,{method:"POST",body:{goal:e,disableCache:t.disableCache,context:e},signal:t.abortSignal});return Nh.parse(r)}async getAutohealingProposal(e,t){let r=await this.sendRequest(`/${z}/web-agent/autoheal-section`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return vm.parse(r)}async getFailureRecoveryProposal(e,t){let r=await this.sendRequest(`/${z}/web-agent/failure-recovery`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return Em.parse(r)}async getIframeRegex(e,t){let r=await this.sendRequest(`/${z}/web-agent/iframe-regex`,{method:"POST",body:e,signal:t.abortSignal});return rm.parse(r)}};var ui=class extends Dt{generator;constructor(e,t){super(e),this.generator=t}async runTemplateMatching(e,t={}){let r=await this.sendRequest(`/${z}/web-agent/template-matching`,{method:"POST",body:e,signal:t?.signal});return om.parse(r)}async constructIframeRegex(e,t={}){return this.generator.getIframeRegex(e,{abortSignal:t.signal})}};var Al=class{constructor(e){this.client=e}async uploadResultsArchive(e,t){let{uploadUrl:r,id:o}=await this.client.generateTestResultsUploadUrl(),i=await li(r,"application/zip",t);if(!i.ok)throw new Error(`Failed to upload test results: ${await i.text()}`);let{runGroupId:a}=await this.client.startProcessingResultsUpload(o,{runGroupId:e});return a}};function mi({orgId:n,client:e,gitMetadata:t,alwaysSaveCache:r,noCache:o}){return o?new Xa:new wp(n,e,t,r)}var wp=class{constructor(e,t,{gitMainBranch:r,gitBranchName:o,gitProtectedBranches:i,gitCommitTimestamp:a,lastCommitOnMainSha:s,lastCommitOnMainTimestamp:l},c){this.orgId=e;this.client=t;this.cacheHeaders={},r&&(this.cacheHeaders[vg]=r),o&&(this.cacheHeaders[Eg]=o),a&&(this.cacheHeaders[Tg]=a.toISOString()),s&&(this.cacheHeaders[xg]=s),l&&(this.cacheHeaders[Cg]=l.toISOString()),c?this.writeCaches=!0:o?this.writeCaches=!i.includes(o):this.writeCaches=!0}cacheHeaders;writeCaches;async saveStepCacheEntries({entries:e,testId:t,logger: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{steps:t,beforeSteps:r,afterSteps:o}=e.stepLists,i=await this.client.getStepCacheForTest({testId:e.testId,steps:t,schemaVersion:e.schemaVersion},this.cacheHeaders);if(!this.writeCaches){e.logger.debug("Skipping cache last used at update because branch is protected");return}for(let s of[t,r,o])s&&Ho({steps:s,stepCacheEntries:i,logger:e.logger});let{cachesToSave:a}=await gt({stepLists:e.stepLists,cacheCreationParams:{testId:e.testId,orgId:this.orgId}});this.client.updateStepCaches({entries:a,testId:e.testId},this.cacheHeaders)}};import Sk from"path";import{Server as HN}from"socket.io";import{cloneDeep as pL}from"lodash-es";var uL={showOverlay:!1},vp=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}){return this.sessions.set(i,{controller:e,context:t,cleanup:r,clientIp:o,browserBehavior:pL(uL)}),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)}},J=new vp;function wy(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(),w=g.toEditorDisplayCopy();JSON.stringify(w)===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:w,isInPageLoad:h.isInPageLoad}),r=Date.now()),l=S,i=w}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=J.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),u=(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),m=setInterval(async()=>{let g=J.getSession(e)?.controller?.browser;if(!g||g.closed){clearInterval(m);return}else if(c)return;c=!0;try{let f=await g.getAllFrameUrls(),S=g.retrieveAndClearDebugData();u(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,m]}}var yr={};var mL=n=>()=>{let{sessionId:e}=n.metadata;yr[e]?.abort?.abort()},vy={event:"cancelApiTest",createHandler:mL};import{CookieJar as ML}from"tough-cookie";import{randomUUID as vL}from"crypto";import{faker as hL}from"@faker-js/faker";import gL from"assert";import fL from"axios";import SL from"moment";import*as yL from"otpauth";import bL from"pg";async function Ey(n){let e;try{e=new URL(n.url).hostname}catch{}let t=[];return n.headers.getSetCookie()?.forEach(r=>{let o=_s(r,e);t.push(...o)}),t}var wL=Object.getPrototypeOf(async function(){}).constructor;async function Ty(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 u=async()=>await Promise.resolve(new wL("axios","moment","faker","assert","pg","Octokit","createAppAuth","OTPAuth","extractCookiesFromResponse","env","setVariable","setPersistentVariable","sendSms","waitForLatestSms","email","sms","ai",r)(fL,SL,i.fakerInstance??hL,gL,bL,d,p,yL,Ey,o,s,c,S=>i.sms.send(S),S=>i.sms.fetchLatest(S),i.email,i.sms,i.ai)),m=!0,h,g;try{h=await B(u(),{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}`),m=!1,f instanceof fr?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:m,error:g}}async function xy({code:n,fragment:e,context:t,localTools:r,logger:o,signal:i,timeoutMs:a=lr}){let s=vL(),l=await Ty(s,{code:n,options:{fragment:e,timeoutMs:a},bindings:t.toObjectCopy(),tools:r,signal:i},o);return b.debug(`[${s}] Got execution result: ${JSON.stringify(l)}`),l}import{createHmac as EL,randomUUID as TL}from"crypto";import xL from"fetch-retry";var CL=xL(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}}),Cy=process.env.GCP_JS_EVAL_FUNCTION_ENDPOINT,Ry=process.env.MOMENTIC_LAMBDA_AUTH_SECRET;async function Ay({orgId:n,code:e,fragment:t,context:r,timeoutMs:o=lr,retries:i=2,signal:a,logger:s}){if(!Cy)throw new Error("GCP_JS_EVAL_FUNCTION_ENDPOINT environment variable not set");let l,c,d=0;if(!Ry)throw new Error("Missing lambda auth secret.");let p=EL("sha256",Ry).update(n).digest("hex");for(;d<=i;){d++,a?.throwIfAborted();let m={id:TL(),orgId:n,momenticLambdaAuthHash:p,code:e,fragment:t,state:r.toObjectCopy(),timeoutMs:o};try{if(l=await B(CL(Cy,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(m)}),{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 u;try{u=Hh.parse(await l.json())}catch(m){throw new Error(`Code evaluation server returned invalid response: ${m}`)}if(u.error)throw new Error(`Code evaluation error: ${u.error}`);return u}async function Kn(n){let e;if(process.env.GCP_JS_EVAL_FUNCTION_ENDPOINT)e=await Ay(n);else if(n.localTools)e=await xy({...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}import{set as EL}from"lodash-es";async function $t(n){let{orgId:e,s:t,context:r,logger:o,signal:i,flagStore:a,retries:s=2,timeoutMs:l=sr,allowUndefined:c=!1}=n,d=/{{(.*?)}}/g,p=t.matchAll(d),u=t;for(let m of p){if(m.length<2)continue;let h=m[1].trim(),g;try{g=await Kn({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,"$$$$"),u=u.replace(m[0],f)}return u}async function hi(n){return Ay(n)}async function Ay({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,s];if(typeof c=="string"&&c.includes("{{")){let p=await $t({s:c,context:r,...a});if(c===p)continue;i.push({path:d,original:c}),n[s]=p}else typeof c=="object"&&c!==null&&!Array.isArray(c)&&await Ay({obj:c,bannedKeys:e,context:r,prefixPath:d,replacements:i,allowList:l?void 0:t,...a})}return i}function Iy(n,e){for(let{path:t,original:r}of e)EL(n,t,r)}import xL from"fetch-retry";var N6=process.env.MAILINATOR_API_KEY,k6=xL(global.fetch,{retryOn:function(n,e,t){return n>3?!1:!!(e!==null||t&&t.status>=400)},retryDelay:function(n){return 500}});import RL from"fetch-cookie";import{cloneDeep as AL}from"lodash-es";var CL=3e4;async function Rl({command:n,logger:e,baseUrl:t,fetchImplementation:r=fetch}){let o=n.timeout??CL/1e3,i=Object.fromEntries(Object.entries(n.headers||{}).filter(([m,h])=>m&&h)),a=new URLSearchParams;Object.entries(n.params||{}).filter(([m,h])=>m&&h).forEach(([m,h])=>{a.append(m,h)});let s=a.toString(),l;if(jo(n.url)&&(l=n.url),t&&$o(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 B((async()=>{let m=s?`${l}?${s}`:l;try{return await r(m,{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 m;try{m=await d.text()}catch(h){m=`Failed to read response body: ${h}`}throw new R("ActionFailureError",`Fetch request failed with status ${d.status}: ${m}`)}let p={};d.headers.forEach((m,h)=>{p[h]=m});let u={status:d.status,headers:p};if(d.headers.get("content-type")?.includes("json"))try{u.json=await d.json()}catch{}else d.headers.get("content-type")?.includes("text")&&(u.text=await d.text());return u}async function Py(n){let{fixtures:e,inputs:t}=n,{context:r}=e,{orgId:o,step:i}=t,a=AL(i);await hi({obj:a,orgId:o,bannedKeys:["code"],...e});let s=await IL(n);return a.envKey&&s.data&&r.setVariable(a.envKey,s.data),s}async function IL(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 Kn({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=RL(fetch,a),d=await Rl({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 Ly(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,u=new PL,m={cookieJar:u,...t};for(let h of i){let g=new Date;c.onStarted?.(h.id);let f;try{o?.throwIfAborted(),f=await Py({inputs:{step:h,baseUrl:s,orgId:a},fixtures:m})}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:Fs(u,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 Oy(n){let{socket:e,storageFactory: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 n.getOrgId({type:"api-test",testId:o}),a=await t(i),{baseUrl:s,envName:l,testName:c,environmentVariables:d}=await wp({testId:o,orgId:i,logger:n.logger,storage:a,authorization:n.authorization}),p={type:"api-test",orgId:await n.getOrgId({type:"api-test",testId:o}),testId:o,sessionId:r,latestContext:new Ot({baseUrl:s||"",currentUrl:s||"",variablesFromEnvironment:d,envName:l,testName:c})};return Sr[r]=p,p}async function wp({testId:n,logger:e,storage:t,authorization:r}){let o=await t.fetchApiTestMetadata(n,e);if(!o)throw new Error(`Failed to fetch API test metadata for test ID: ${n}`);let i;r?.type==="API_KEY"&&(i=new fr({httpClient:new Dt({...r,logger:e}),fakerSeed:void 0}));let a=o.envs?.find(d=>d.default),s;a&&(s=await t.fetchEnvironment(a.name,e));let l=o.baseUrl||s?.variables?.[We];if(!l)throw new Error("Base URL is empty in both API test options and the configured environment");let c={...s?.variables};return{baseUrl:l,envName:s?.name,testName:o.name,environmentVariables:c,localCodeEvalTools:i}}var LL=n=>async(e,t)=>{let{steps:r}=e,{authorization:o,metadata:i,socket:a,logger:s,flagStoreFactory:l,storageFactory:c}=n,{orgId:d,testId:p,sessionId:u}=i,m=s.child({testId:p,orgId:d,sessionId:u}),h=Sr[u];if(!h)throw new Error(`No api testing session with id ${u} could be found. Please reconnect and try again.`);let g=new AbortController;h.abort=g;let f=h.latestContext,S=await c(d),{localCodeEvalTools:w,baseUrl:T}=await wp({testId:p,orgId:d,logger:m,storage:S,authorization:o}),y={context:f,logger:m,localTools:w,signal:g.signal,flagStore:await l(d)},A=await Ly({inputs:{steps:r,orgId:d,baseUrl:T},fixtures:y,callbacks:{test:{onFinished:()=>{a.emit("apiTestFinished")}},step:{onStarted:k=>{a.emit("apiStepStarted",k)},onFinished:k=>{a.emit("apiStepFinished",k)}}}});t({result:A})},My={event:"executeApiTest",createHandler:LL};var OL=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async()=>{e.info({sessionId:t},"Cancel event received");let r=X.getSession(t);if(!r)throw new Error("No active session found");try{r.controller.setClosed()}catch{}}},Ny={event:"cancel",createHandler:OL};var ML=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async(r,o)=>{let i=X.getSession(t);if(!i)throw new Error("No active session found");i.controller.setOpen();let a=i.controller.browser;try{let l=(await a.getBrowserState({skipWait:!0})).serialize();e.debug({a11yTree:l},"Fetched a11y tree from the browser"),o({a11yTree:l})}catch(s){e.error({err:s},"Error fetching a11y tree from the browser"),o({err:s.message})}}},ky={event:"fetchA11yTree",createHandler:ML};var NL=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async(r,o)=>{let i=X.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})}}},_y={event:"fetchDom",createHandler:NL};var kL=({metadata:n,logger:e})=>{let{sessionId:t,type:r}=n;return o=>{e.info({sessionId:t,reason:o},`Disconnect event received (${o})`),r==="e2e"?X.removeSession(t,e):r==="api-test"&&delete Sr[t]}},Dy={event:"disconnect",createHandler:kL};function rn(n){let{result:e,nestedResults:t}=n;if(!n.nestedResults.length)return;let{firstMetadata:r,lastMetadata:o}=_L(t);DL(e,r,o);let i=[...n.asyncTasks];n.asyncTasks.push((async()=>{try{await FL(i,e,r,o)}catch(a){n.logger.error({result:n.result,err:a},"Error hoisting scalar result metadata")}})())}function _L(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 DL(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 FL(n,e,t,r){await Promise.allSettled(n),t&&(e.beforeSnapshot=t.beforeSnapshot),r&&(e.afterSnapshot=r.afterSnapshot)}import ka from"os";import UL from"v8";var Fy,Ln,BL=ka.platform(),zL=ka.cpus().map(n=>({model:n.model,speed:n.speed}));function Uy(n){let e=()=>{try{let t=!1,r=HL(),o=jL();r.freeMemory<1e6&&(t=!0);let i=UL.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:zL,platform:BL}}function HL(){let n=ka.totalmem(),e=ka.freemem(),t=n-e;return{totalMemory:n,freeMemory:e,usedMemory:t}}function jL(){let n=ka.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,!Ln)return Ln=t,null;let r={user:t.user-Ln.user,nice:t.nice-Ln.nice,sys:t.sys-Ln.sys,idle:t.idle-Ln.idle,irq:t.irq-Ln.irq,total:t.total-Ln.total};return Fy={measurementTime:e,intervalMs:e-Ln.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},Ln=t,Fy}import{hostname as qL}from"os";async function zy(n){let{command:e,tracer:t,timeoutMs:r,targetingWrapper:o,disableCache:i,fixtures:a}=n,{logger:s,abortSignal:l}=a;if(e.target&&!or(e.target))throw new Error("Element assertion with x/y is not supported yet");let c=e.assertion.type==="ELEMENT_EXISTENCE"&&e.assertion.negated&&(e.assertion.condition==="EXISTS"||e.assertion.condition==="VISIBLE"),d=Date.now(),p=0,u,m=500;for(;p<2||Date.now()-d<r;){p++,p>1&&await Z(m,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=>$L(S.locator,n),options:{...e,disableCache:i,disableGlobalLocatorRedirect:!0,source:Nr(e)}});if(u={success:f.success,data:f.data,err:f.err,newTarget:h,elementInteractedDisplayString:g},!f.success){u=f,m=Math.min(m*2,1e4);continue}return u}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;u={success:!1,err:h}}}if(!u)throw new Error(`Failed to evaluate manual element assertion in ${r}ms.`);return u}async function $L(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:je(s,500,!0)},!By(s,r.value,r.operation,!!r.negated)){let l=r.negated?cr[r.operation]:dr[r.operation];o=!1,i=new R("AssertionFailureError",`The content ${l} '${r.value}': ${s}`)}break}case"ELEMENT_ATTRIBUTE":{a={elementOuterHtml:je(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(!By(s,r.value,r.operation,!!r.negated)){let l=r.negated?cr[r.operation]:dr[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.evaluate(async(l,c)=>{let d=Date.now();for(;Date.now()-d<c;){let p=l.getBoundingClientRect();if(p.width>0&&p.height>0)return!0;await new Promise(u=>setTimeout(u,250))}return!1},Cn*1e3);break}case"EDITABLE":{o=await n.isEditable({timeout:Cn*1e3});break}case"EXISTS":{o=!0;break}case"ENABLED":{o=await n.isEnabled({timeout:Cn*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?kd[r.condition]:_d[r.condition];i=new R("AssertionFailureError",`The element ${s}`)}break}}return{success:o,data:a,err:i}}function By(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 GL}from"jimp";async function _a(n,e){let t=await n.screenshot(e),r=await GL.fromBuffer(t);return{buffer:t,width:Math.ceil(r.bitmap.width??0),height:Math.ceil(r.bitmap.height??0)}}import{Jimp as Hy}from"jimp";import vp from"jpeg-js";import WL from"pixelmatch";async function jy({ctx:n,tracer:e,command:t,disableCache:r,browser:o,targetingWrapper:i,logger:a,screenshotStorage:s}){if(t.target&&!or(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 q=>_a(o,{locator:q.locator,...l}),options:{...t,disableCache:r,disableGlobalLocatorRedirect:!0}})).result:c=await _a(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 W=`${c.width}x${c.height}`,q=`${d.width}x${d.height}`;return{fail:!0,thoughts:`Current screenshot (${W}) does not match saved screenshot dimensions (${q}) - 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 Hy.fromBuffer(c.buffer),u={width:c.width,height:c.height},m=await Hy.fromBuffer(d.buffer),h={width:d.width,height:d.height},g,f=u.width*u.height,S=h.width*h.height,w=Math.abs(u.height-h.height),T=Math.abs(u.width-h.width);if(f>S){let W=p.cover({w:h.width,h:h.height});c.buffer=await W.getBuffer("image/jpeg"),g="current",c.width=h.width,c.height=h.height}else if(S>f){let W=m.cover({w:u.width,h:u.height});d.buffer=await W.getBuffer("image/jpeg"),g="saved"}let y={data:Buffer.alloc(c.width*c.height*4),width:c.width,height:c.height},E=t.threshold??.1,A=WL(vp.decode(d.buffer).data,vp.decode(c.buffer).data,y.data,c.width,c.height,{threshold:E,diffColorAlt:[0,255,0]})/(c.width*c.height)*100,k=A>E*100,L=`Visual diff of ${A.toFixed(2)}% detected, which is ${k?"over":"under"} the threshold of ${E*100}%.`;if(g&&(L+=` The ${g} screenshot was cropped since it was taller by ${w} pixels and wider by ${T} pixels.`),k)throw new R("ActionFailureError",L);return{fail:k,thoughts:L,beforeScreenshotOverride:c.buffer,afterScreenshotOverride:vp.encode(y,75).data,succeedImmediately:!1,urlAfterCommand:o.url()}}var VL=5e3;async function Al({timeout:n=Cn,...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 $y(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 Z(s,e.signal),s=Math.min(Math.floor(s*1.5),VL);else return i}return i=await $y(e),i}async function $y({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(Gy,{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(Gy,{value:n.value,negated:!!n.negated,returnHtml:!0},"checking page content"));if(!i){let l=n.negated?cr.CONTAINS:dr.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 Gy({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 Tp=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 u,m=!1,h,g;if(e.cacheConfig||e.defaultCacheAllInvocations){let f=e.cacheConfig?.cacheKey||e.defaultCacheKey||"",S=await $t({orgId:c,s:f,context:o,logger:r,localTools:a,signal:p,flagStore:s.flagStore});g={orgId:c,cacheKeys:[S,...Object.entries(t).map(([T,y])=>`${T}:${y}`)]},r.debug({original:f,keyParams:g},"Module cache key params");let w=Date.now();for(;Date.now()-w<Sg;){p?.throwIfAborted();let T=await i.getCacheResult(g);if(T){r.debug({cacheResult:T},"Got result from module execution cache"),u=Il(e,t,"SUCCESS"),u.message="Used cached module result.",u.data=JSON.parse(T),m=!0;break}else r.debug({cacheKey:f,keyParams:g},"No cache result found, continuing with lock acquisition");let y=await i.acquireCacheLock({keyParams:g,clientMetadata:`hostName:${qL()};runId:${d}`},p);if(y.acquired){h=y.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 Z(2500+Math.random()*1e4,p)}}try{if(!u)u=await KL(n);else if(e.autoAuth){let f=Ds.safeParse(u.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,w=e.advanced?.cacheInvalidation;if(w&&w.type==="PAGE_CHECK"){let T={type:"CONTENT",value:w.substring},y=await Al({timeout:Cn,assertion:T,browser:l,flagStore:s.flagStore,logger:r,signal:p});y.success?r.debug({invalResult:y},"Cached result still valid after page check, continuing..."):(r.info({invalResult:y},"Invalidating cached result due to page check failure"),S=!0)}if(g&&S)return await i.deleteCacheResult(g),Tp(n)}}finally{try{h!==void 0&&!m&&u?.status==="SUCCESS"&&await YL({step:e,result:u,browser:s.browser,cacheKeyPrefix:h,logger:r,storage:i})}finally{h!==void 0&&await i.releaseCacheLock(h)}}return u},KL=async n=>{let{step:e,tracer:t}=n.moduleParams,r=Il(e,n.moduleParams.resolvedInputs,"SUCCESS"),o=await t.startSubSteps(),{status:i,results:a}=await yr(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,rn({asyncTasks:n.work.asyncTasks,nestedResults:a,result:r,logger:n.fixtures.logger}),r};function Il(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 Wy({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 Kn({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 YL({step:n,result:e,browser:t,cacheKeyPrefix:r,logger:o,storage:i}){let a=n.cacheConfig?.cacheExpiryMs;(!a||a===Kg)&&(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:Tf(s)},"Setting module cache result"),await i.setCacheResult({result:s,keyPrefix:r,ttlMs:a})}async function br(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=Il(n,{},"FAILED");return l.message=s,l.startedAt=r,l.finishedAt=i,l}return{...Qs(n),startedAt:r,finishedAt:i,status:a,data:null,message:s,results:[]}}}async function yr(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 Vy}from"crypto";import{cloneDeep as XL}from"lodash-es";function Pl(n,e){n.state.healingDetails?n.state.healingDetails.push(e):n.state.healingDetails=[e]}var Ll=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}),u=ra(e.command);n.work.asyncTasks.push(a.reportCreditsUsed(p,d,u,{testId:l?.id,testName:l?.name,suiteId:c?.id,suiteName:c?.name}));let m=o.browser.url(),h=new Date,g,f=Vy(),S=Vy();if(s)try{g=await o.browser.screenshot({retries:1,clearHighlights:!0,quality:75});let x=await o.browser.getRawCondensedHtml();t.attachBeforeHtmlSnapshot({logger:p,snapshotId:f,html:x}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeHtmlSnapshot(p,f,x))}catch(x){p.debug({err:x},"Failed to take before screenshot, continuing...")}let w,T,y,E=Ms();try{let x=await o.executePresetCommand(E,t,e.command,i,l?.advanced.disableAICaching??!1);x.beforeScreenshotOverride&&(g=x.beforeScreenshotOverride),y=x.afterScreenshotOverride;let{proposedStep:A}=QL({work:n.work,step:e,newTargets:x.newTargets,logger:p}),k=new Date,L=o.browser.url();T={beforeUrl:m,afterUrl:L,startedAt:h,finishedAt:k,viewport:o.browser.getViewport(),status:x.fail?"FAILED":"SUCCESS",elementInteracted:x.elementInteracted},w={...e,message:x.thoughts??ZL(x.newTargets)??"Successfully executed preset action.",beforeUrl:m,afterUrl:L,finishedAt:k,startedAt:h,status:x.fail?"FAILED":"SUCCESS",data:x.data,results:[T],details:E.details,proposedStep:A},"assertion"in e.command&&(w.message=x.thoughts||"Assertion passed.")}catch(x){p.error({message:x.message,stack:x.stack},`Failed executing preset step ${Wr(e.command)}`);let A=o.browser.url(),k=new Date,L=x instanceof Error?x.message:`${x}`;x instanceof R&&x.getLastScreenshotBuffer()&&(y=x.getLastScreenshotBuffer()),T={beforeUrl:m,afterUrl:A,startedAt:h,finishedAt:k,viewport:o.browser.getViewport(),status:x instanceof DOMException&&x.name==="AbortError"?"CANCELLED":"FAILED",message:L},w={...e,startedAt:h,finishedAt:k,beforeUrl:m,afterUrl:A,status:x instanceof DOMException&&x.name==="AbortError"?"CANCELLED":"FAILED",message:L,failureReason:x instanceof R?x.reason:void 0,results:[T],details:E.details}}if(s)try{y||(y=await o.browser.screenshot({retries:1,quality:75}));let x=await o.browser.getRawCondensedHtml();t.attachAfterHtmlSnapshot({logger:p,snapshotId:S,html:x}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeHtmlSnapshot(p,S,x))}catch(x){p.debug({err:x},"Failed store debug data after step, likely because the page is still loading. This is non-fatal and does not affect the test.")}return T.beforeSnapshot=f,w.beforeSnapshot=f,T.afterSnapshot=S,w.afterSnapshot=S,g&&(t.attachBeforeScreenshot({logger:p,snapshotId:f,screenshot:g}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(p,f,g))),y&&(t.attachAfterScreenshot({logger:p,snapshotId:S,screenshot:y}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(p,S,y))),w};function QL({work:n,step:e,newTargets:t,logger:r}){if(!t?.length)return{proposedStep:void 0};let o=e.command;gf(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={...XL(e),command:a};return Pl(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 ZL(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
- Located second element: ${n[1]?.thoughts}`}}async function qy({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 On({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 eO=["NAVIGATE","NEW_TAB","TAB","REFRESH","WAIT_FOR_URL"];async function Ky({beforeUrl:n,beforePages:e,browser:t,command:r,logger:o}){if(eO.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 Z(250),c++;let d=(await t.getOpenPages()).map(u=>u.url),p=t.url();if(d.length!==e.length)for(let u=d.length-1;u>=e.length;u--){let m=d[u];if(Jr(m,o)&&m!==n&&m!==p){o.info({beforePages:e,afterPages:d,beforeUrl:n},"Auto-following new tab after preset action"),await t.switchToPage({type:"INDEX",index:String(u)});break}}}}var Yy="MOMENTIC_RUN_ID",Jy="FINAL_SCREENSHOT_URL";import{cloneDeep as cO}from"lodash-es";async function Xy(n){let{step:e,tracer:t}=n.conditionalParams,{logger:r,controller:o}=n.fixtures,i=new Date,a=Qs(e),s=e.elseSteps,l=!0,c=[],d,p=Ms();for(let f=0;f<e.blocks.length;f++){r.info(`Evaluating condition ${f} in conditional step`);let S=e.blocks[f];try{let w=await Ll({...n,presetParams:{tracer:t,step:S.assertion}});c.push(w),r.info(`Condition ${f} resolved to true, executing the corresponding ${S.steps.length} steps`),l=!1,s=S.steps,d=w}catch(w){r.info({err:w},`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 u=await n.conditionalParams.tracer.startSubSteps(),m=await n.executeStepList({...n,listParams:{steps:s,containerName:"conditional block",tracer:u}}),g={...a,assertion:d,...m,startedAt:i,finishedAt:new Date};return rn({asyncTasks:n.work.asyncTasks,nestedResults:[...c,...m.results],result:g,logger:r}),g}import{randomUUID as Qy}from"crypto";var Zy=async n=>{let{controller:e}=n.fixtures;await e.browser.waitForDOMStability();let t=await e.browser.screenshot({}),r=await tO(n);r.finishedAt=new Date,rn({asyncTasks:n.work.asyncTasks,result:r,nestedResults:r.results,logger:n.fixtures.logger});let o=await e.browser.screenshot({}),i=Qy();r.beforeSnapshot=i,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,i,t));let a=Qy();return r.afterSnapshot=a,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,a,o)),r},tO=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 Ep}from"crypto";var eb=15,nO=7,tb=async n=>{let{controller:e}=n.fixtures;await e.browser.waitForDOMStability();let t=await e.browser.screenshot({quality:75}),r=await rO(n);r.finishedAt=new Date,rn({asyncTasks:n.work.asyncTasks,result:r,nestedResults:r.results,logger:n.fixtures.logger});let o=await e.browser.screenshot({quality:75}),i=Ep();r.beforeSnapshot=i,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,i,t));let a=Ep();return r.afterSnapshot=a,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,a,o)),r},rO=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}),u={...e,startedAt:new Date,beforeTestContext:a.toRedactedDisplayCopy(),results:[],finishedAt:new Date,status:"SUCCESS"},m=await $t({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,w=0,T,y;for(;;){if(S>eb)return u.message=`Exceeded the maximum number of commands allowed per AI step (${eb})`,u.status="FAILED",u;if(i.executeAbortController.signal.aborted)return u.message="Test execution was cancelled",u.status="CANCELLED",u;c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Evaluating current state..."});let E=await i.evaluateAiAction({goal:m,startingScreenshot:S===0?void 0:g,history:f,logger:p,langfuseSessionId:d,lastError:y}),{evaluation:x,reasoning:A,summary:k}=E;p.info(E,"Got AI evaluation");let L=u.results[S-1]?.id;switch(x.type){case"DONE":return u.message=`Our AI evaluator confirmed all tasks are complete: ${A}`,u.status="SUCCESS",L&&c.onDynamicAIActionEvaluatingEvent?.({stepId:L,status:"SUCCESS",message:`${k}
54
- ${A}`}),u;case"RIGHT_TRACK":{T=void 0,S===0?c.onDynamicAIActionEvaluatingEvent?.({stepId:e.id,status:"RUNNING",message:A}):L&&c.onDynamicAIActionEvaluatingEvent?.({stepId:L,status:"SUCCESS",message:A});break}case"WRONG_TRACK":{if(T=`${A}
55
- ${x.feedback}`,w++,w>=nO)return u.message=`Our AI agent requires additional information to achieve this goal:
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}import{set as RL}from"lodash-es";async function $t(n){let{orgId:e,s:t,context:r,logger:o,signal:i,flagStore:a,retries:s=2,timeoutMs:l=lr,allowUndefined:c=!1}=n,d=/{{(.*?)}}/g,p=t.matchAll(d),u=t;for(let m of p){if(m.length<2)continue;let h=m[1].trim(),g;try{g=await Kn({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,"$$$$"),u=u.replace(m[0],f)}return u}async function hi(n){return Iy(n)}async function Iy({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,s];if(typeof c=="string"&&c.includes("{{")){let p=await $t({s:c,context:r,...a});if(c===p)continue;i.push({path:d,original:c}),n[s]=p}else typeof c=="object"&&c!==null&&!Array.isArray(c)&&await Iy({obj:c,bannedKeys:e,context:r,prefixPath:d,replacements:i,allowList:l?void 0:t,...a})}return i}function Py(n,e){for(let{path:t,original:r}of e)RL(n,t,r)}import AL from"fetch-retry";var D6=process.env.MAILINATOR_API_KEY,F6=AL(global.fetch,{retryOn:function(n,e,t){return n>3?!1:!!(e!==null||t&&t.status>=400)},retryDelay:function(n){return 500}});import PL from"fetch-cookie";import{cloneDeep as LL}from"lodash-es";var IL=3e4;async function Il({command:n,logger:e,baseUrl:t,fetchImplementation:r=fetch}){let o=n.timeout??IL/1e3,i=Object.fromEntries(Object.entries(n.headers||{}).filter(([m,h])=>m&&h)),a=new URLSearchParams;Object.entries(n.params||{}).filter(([m,h])=>m&&h).forEach(([m,h])=>{a.append(m,h)});let s=a.toString(),l;if(jo(n.url)&&(l=n.url),t&&$o(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 B((async()=>{let m=s?`${l}?${s}`:l;try{return await r(m,{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 m;try{m=await d.text()}catch(h){m=`Failed to read response body: ${h}`}throw new R("ActionFailureError",`Fetch request failed with status ${d.status}: ${m}`)}let p={};d.headers.forEach((m,h)=>{p[h]=m});let u={status:d.status,headers:p};if(d.headers.get("content-type")?.includes("json"))try{u.json=await d.json()}catch{}else d.headers.get("content-type")?.includes("text")&&(u.text=await d.text());return u}async function Ly(n){let{fixtures:e,inputs:t}=n,{context:r}=e,{orgId:o,step:i}=t,a=LL(i);await hi({obj:a,orgId:o,bannedKeys:["code"],...e});let s=await OL(n);return a.envKey&&s.data&&r.setVariable(a.envKey,s.data),s}async function OL(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 Kn({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=PL(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 Oy(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,u=new ML,m={cookieJar:u,...t};for(let h of i){let g=new Date;c.onStarted?.(h.id);let f;try{o?.throwIfAborted(),f=await Ly({inputs:{step:h,baseUrl:s,orgId:a},fixtures:m})}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:Fs(u,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 My(n){let{socket:e,storageFactory: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 n.getOrgId({type:"api-test",testId:o}),a=await t(i),{baseUrl:s,envName:l,testName:c,environmentVariables:d}=await Ep({testId:o,orgId:i,logger:n.logger,storage:a,authorization:n.authorization}),p={type:"api-test",orgId:await n.getOrgId({type:"api-test",testId:o}),testId:o,sessionId:r,latestContext:new Ot({baseUrl:s||"",currentUrl:s||"",variablesFromEnvironment:d,envName:l,testName:c})};return yr[r]=p,p}async function Ep({testId:n,logger:e,storage:t,authorization:r}){let o=await t.fetchApiTestMetadata(n,e);if(!o)throw new Error(`Failed to fetch API test metadata for test ID: ${n}`);let i;r?.type==="API_KEY"&&(i=new Sr({httpClient:new Dt({...r,logger:e}),fakerSeed:void 0}));let a=o.envs?.find(d=>d.default),s;a&&(s=await t.fetchEnvironment(a.name,e));let l=o.baseUrl||s?.variables?.[We];if(!l)throw new Error("Base URL is empty in both API test options and the configured environment");let c={...s?.variables};return{baseUrl:l,envName:s?.name,testName:o.name,environmentVariables:c,localCodeEvalTools:i}}var NL=n=>async(e,t)=>{let{steps:r}=e,{authorization:o,metadata:i,socket:a,logger:s,flagStoreFactory:l,storageFactory:c}=n,{orgId:d,testId:p,sessionId:u}=i,m=s.child({testId:p,orgId:d,sessionId:u}),h=yr[u];if(!h)throw new Error(`No api testing session with id ${u} could be found. Please reconnect and try again.`);let g=new AbortController;h.abort=g;let f=h.latestContext,S=await c(d),{localCodeEvalTools:w,baseUrl:E}=await Ep({testId:p,orgId:d,logger:m,storage:S,authorization:o}),y={context:f,logger:m,localTools:w,signal:g.signal,flagStore:await l(d)},A=await Oy({inputs:{steps:r,orgId:d,baseUrl:E},fixtures:y,callbacks:{test:{onFinished:()=>{a.emit("apiTestFinished")}},step:{onStarted:D=>{a.emit("apiStepStarted",D)},onFinished:D=>{a.emit("apiStepFinished",D)}}}});t({result:A})},Ny={event:"executeApiTest",createHandler:NL};var kL=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async()=>{e.info({sessionId:t},"Cancel event received");let r=J.getSession(t);if(!r)throw new Error("No active session found");try{r.controller.setClosed()}catch{}}},ky={event:"cancel",createHandler:kL};var _L=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async(r,o)=>{let i=J.getSession(t);if(!i)throw new Error("No active session found");i.controller.setOpen();let a=i.controller.browser;try{let l=(await a.getBrowserState({skipWait:!0})).serialize();e.debug({a11yTree:l},"Fetched a11y tree from the browser"),o({a11yTree:l})}catch(s){e.error({err:s},"Error fetching a11y tree from the browser"),o({err:s.message})}}},_y={event:"fetchA11yTree",createHandler:_L};var DL=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async(r,o)=>{let i=J.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})}}},Dy={event:"fetchDom",createHandler:DL};var FL=({metadata:n,logger:e})=>{let{sessionId:t,type:r}=n;return o=>{e.info({sessionId:t,reason:o},`Disconnect event received (${o})`),r==="e2e"?J.removeSession(t,e):r==="api-test"&&delete yr[t]}},Fy={event:"disconnect",createHandler:FL};function rn(n){let{result:e,nestedResults:t}=n;if(!n.nestedResults.length)return;let{firstMetadata:r,lastMetadata:o}=UL(t);BL(e,r,o);let i=[...n.asyncTasks];n.asyncTasks.push((async()=>{try{await zL(i,e,r,o)}catch(a){n.logger.error({result:n.result,err:a},"Error hoisting scalar result metadata")}})())}function UL(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 BL(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 zL(n,e,t,r){await Promise.allSettled(n),t&&(e.beforeSnapshot=t.beforeSnapshot),r&&(e.afterSnapshot=r.afterSnapshot)}import ka from"os";import HL from"v8";var Uy,On,jL=ka.platform(),$L=ka.cpus().map(n=>({model:n.model,speed:n.speed}));function By(n){let e=()=>{try{let t=!1,r=GL(),o=WL();r.freeMemory<1e6&&(t=!0);let i=HL.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:$L,platform:jL}}function GL(){let n=ka.totalmem(),e=ka.freemem(),t=n-e;return{totalMemory:n,freeMemory:e,usedMemory:t}}function WL(){let n=ka.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,!On)return On=t,null;let r={user:t.user-On.user,nice:t.nice-On.nice,sys:t.sys-On.sys,idle:t.idle-On.idle,irq:t.irq-On.irq,total:t.total-On.total};return Uy={measurementTime:e,intervalMs:e-On.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},On=t,Uy}import{hostname as JL}from"os";async function Hy(n){let{command:e,tracer:t,timeoutMs:r,targetingWrapper:o,disableCache:i,fixtures:a}=n,{logger:s,abortSignal:l}=a;if(e.target&&!ir(e.target))throw new Error("Element assertion with x/y is not supported yet");let c=e.assertion.type==="ELEMENT_EXISTENCE"&&e.assertion.negated&&(e.assertion.condition==="EXISTS"||e.assertion.condition==="VISIBLE"),d=Date.now(),p=0,u,m=500;for(;p<2||Date.now()-d<r;){p++,p>1&&await Q(m,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=>VL(S.locator,n),options:{...e,disableCache:i,disableGlobalLocatorRedirect:!0,source:Nr(e),allowZeroOpacityOverride:!0}});if(u={success:f.success,data:f.data,err:f.err,newTarget:h,elementInteractedDisplayString:g},!f.success){u=f,m=Math.min(m*2,1e4);continue}return u}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;u={success:!1,err:h}}}if(!u)throw new Error(`Failed to evaluate manual element assertion in ${r}ms.`);return u}async function VL(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:je(s,500,!0)},!zy(s,r.value,r.operation,!!r.negated)){let l=r.negated?dr[r.operation]:pr[r.operation];o=!1,i=new R("AssertionFailureError",`The content ${l} '${r.value}': ${s}`)}break}case"ELEMENT_ATTRIBUTE":{a={elementOuterHtml:je(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(!zy(s,r.value,r.operation,!!r.negated)){let l=r.negated?dr[r.operation]:pr[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.evaluate(async(l,c)=>{let d=Date.now();for(;Date.now()-d<c;){await new Promise(u=>setTimeout(u,250));let p=l.getBoundingClientRect();if(!(p.width===0||p.height===0)&&window.getComputedStyle(l).visibility!=="hidden"&&window.getComputedStyle(l).display!=="none")return!0}return!1},Cn*1e3);break}case"EDITABLE":{o=await n.isEditable({timeout:Cn*1e3});break}case"EXISTS":{o=!0;break}case"ENABLED":{o=await n.isEnabled({timeout:Cn*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?Dd[r.condition]:Fd[r.condition];i=new R("AssertionFailureError",`The element ${s}`)}break}}return{success:o,data:a,err:i}}function zy(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 qL}from"jimp";async function _a(n,e){let t=await n.screenshot(e),r=await qL.fromBuffer(t);return{buffer:t,width:Math.ceil(r.bitmap.width??0),height:Math.ceil(r.bitmap.height??0)}}import{Jimp as jy}from"jimp";import Tp from"jpeg-js";import KL from"pixelmatch";async function $y({ctx:n,tracer:e,command:t,disableCache:r,browser:o,targetingWrapper:i,logger:a,screenshotStorage:s}){if(t.target&&!ir(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 V=>_a(o,{locator:V.locator,...l}),options:{...t,disableCache:r,disableGlobalLocatorRedirect:!0}})).result:c=await _a(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 j=`${c.width}x${c.height}`,V=`${d.width}x${d.height}`;return{fail:!0,thoughts:`Current screenshot (${j}) does not match saved screenshot dimensions (${V}) - 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 jy.fromBuffer(c.buffer),u={width:c.width,height:c.height},m=await jy.fromBuffer(d.buffer),h={width:d.width,height:d.height},g,f=u.width*u.height,S=h.width*h.height,w=Math.abs(u.height-h.height),E=Math.abs(u.width-h.width);if(f>S){let j=p.cover({w:h.width,h:h.height});c.buffer=await j.getBuffer("image/jpeg"),g="current",c.width=h.width,c.height=h.height}else if(S>f){let j=m.cover({w:u.width,h:u.height});d.buffer=await j.getBuffer("image/jpeg"),g="saved"}let y={data:Buffer.alloc(c.width*c.height*4),width:c.width,height:c.height},x=t.threshold??.1,A=KL(Tp.decode(d.buffer).data,Tp.decode(c.buffer).data,y.data,c.width,c.height,{threshold:x,diffColorAlt:[0,255,0]})/(c.width*c.height)*100,D=A>x*100,L=`Visual diff of ${A.toFixed(2)}% detected, which is ${D?"over":"under"} the threshold of ${x*100}%.`;if(g&&(L+=` The ${g} screenshot was cropped since it was taller by ${w} pixels and wider by ${E} pixels.`),D)throw new R("ActionFailureError",L);return{fail:D,thoughts:L,beforeScreenshotOverride:c.buffer,afterScreenshotOverride:Tp.encode(y,75).data,succeedImmediately:!1,urlAfterCommand:o.url()}}var YL=5e3;async function Pl({timeout:n=Cn,...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 Gy(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 Q(s,e.signal),s=Math.min(Math.floor(s*1.5),YL);else return i}return i=await Gy(e),i}async function Gy({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(Wy,{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(Wy,{value:n.value,negated:!!n.negated,returnHtml:!0},"checking page content"));if(!i){let l=n.negated?dr.CONTAINS:pr.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 Wy({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 xp=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 u,m=!1,h,g;if(e.cacheConfig||e.defaultCacheAllInvocations){let f=e.cacheConfig?.cacheKey||e.defaultCacheKey||"",S=await $t({orgId:c,s:f,context:o,logger:r,localTools:a,signal:p,flagStore:s.flagStore});g={orgId:c,cacheKeys:[S,...Object.entries(t).map(([E,y])=>`${E}:${y}`)]},r.debug({original:f,keyParams:g},"Module cache key params");let w=Date.now();for(;Date.now()-w<yg;){p?.throwIfAborted();let E=await i.getCacheResult(g);if(E){r.debug({cacheResult:E},"Got result from module execution cache"),u=Ll(e,t,"SUCCESS"),u.message="Used cached module result.",u.data=JSON.parse(E),m=!0;break}else r.debug({cacheKey:f,keyParams:g},"No cache result found, continuing with lock acquisition");let y=await i.acquireCacheLock({keyParams:g,clientMetadata:`hostName:${JL()};runId:${d}`},p);if(y.acquired){h=y.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 Q(2500+Math.random()*1e4,p)}}try{if(!u)u=await XL(n);else if(e.autoAuth){let f=Ds.safeParse(u.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,w=e.advanced?.cacheInvalidation;if(w&&w.type==="PAGE_CHECK"){let E={type:"CONTENT",value:w.substring},y=await Pl({timeout:Cn,assertion:E,browser:l,flagStore:s.flagStore,logger:r,signal:p});y.success?r.debug({invalResult:y},"Cached result still valid after page check, continuing..."):(r.info({invalResult:y},"Invalidating cached result due to page check failure"),S=!0)}if(g&&S)return await i.deleteCacheResult(g),xp(n)}}finally{try{h!==void 0&&!m&&u?.status==="SUCCESS"&&await ZL({step:e,result:u,browser:s.browser,cacheKeyPrefix:h,logger:r,storage:i})}finally{h!==void 0&&await i.releaseCacheLock(h)}}return u},XL=async n=>{let{step:e,tracer:t}=n.moduleParams,r=Ll(e,n.moduleParams.resolvedInputs,"SUCCESS"),o=await t.startSubSteps(),{status:i,results:a}=await br(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,rn({asyncTasks:n.work.asyncTasks,nestedResults:a,result:r,logger:n.fixtures.logger}),r};function Ll(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 Vy({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 Kn({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 ZL({step:n,result:e,browser:t,cacheKeyPrefix:r,logger:o,storage:i}){let a=n.cacheConfig?.cacheExpiryMs;(!a||a===Yg)&&(a=n.defaultCacheTtl??Jg);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:Tf(s)},"Setting module cache result"),await i.setCacheResult({result:s,keyPrefix:r,ttlMs:a})}async function wr(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=Ll(n,{},"FAILED");return l.message=s,l.startedAt=r,l.finishedAt=i,l}return{...el(n),startedAt:r,finishedAt:i,status:a,data:null,message:s,results:[]}}}async function br(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 qy}from"crypto";import{cloneDeep as eO}from"lodash-es";function Ol(n,e){n.state.healingDetails?n.state.healingDetails.push(e):n.state.healingDetails=[e]}var Ml=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}),u=ra(e.command);n.work.asyncTasks.push(a.reportCreditsUsed(p,d,u,{testId:l?.id,testName:l?.name,suiteId:c?.id,suiteName:c?.name}));let m=o.browser.url(),h=new Date,g,f=qy(),S=qy();if(s)try{g=await o.browser.screenshot({retries:1,clearHighlights:!0,quality:75});let T=await o.browser.getRawCondensedHtml();t.attachBeforeHtmlSnapshot({logger:p,snapshotId:f,html:T}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeHtmlSnapshot(p,f,T))}catch(T){p.debug({err:T},"Failed to take before screenshot, continuing...")}let w,E,y,x=Ms();try{let T=await o.executePresetCommand(x,t,e.command,i,l?.advanced.disableAICaching??!1);T.beforeScreenshotOverride&&(g=T.beforeScreenshotOverride),y=T.afterScreenshotOverride;let{proposedStep:A}=tO({work:n.work,step:e,newTargets:T.newTargets,logger:p}),D=new Date,L=o.browser.url();E={beforeUrl:m,afterUrl:L,startedAt:h,finishedAt:D,viewport:o.browser.getViewport(),status:T.fail?"FAILED":"SUCCESS",elementInteracted:T.elementInteracted},w={...e,message:T.thoughts??nO(T.newTargets)??"Successfully executed preset action.",beforeUrl:m,afterUrl:L,finishedAt:D,startedAt:h,status:T.fail?"FAILED":"SUCCESS",data:T.data,results:[E],details:x.details,proposedStep:A},"assertion"in e.command&&(w.message=T.thoughts||"Assertion passed.")}catch(T){p.error({message:T.message,stack:T.stack},`Failed executing preset step ${Wr(e.command)}`);let A=o.browser.url(),D=new Date,L=T instanceof Error?T.message:`${T}`;T instanceof R&&T.getLastScreenshotBuffer()&&(y=T.getLastScreenshotBuffer()),E={beforeUrl:m,afterUrl:A,startedAt:h,finishedAt:D,viewport:o.browser.getViewport(),status:T instanceof DOMException&&T.name==="AbortError"?"CANCELLED":"FAILED",message:L},w={...e,startedAt:h,finishedAt:D,beforeUrl:m,afterUrl:A,status:T instanceof DOMException&&T.name==="AbortError"?"CANCELLED":"FAILED",message:L,failureReason:T instanceof R?T.reason:void 0,results:[E],details:x.details}}if(s)try{y||(y=await o.browser.screenshot({retries:1,quality:75}));let T=await o.browser.getRawCondensedHtml();t.attachAfterHtmlSnapshot({logger:p,snapshotId:S,html:T}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeHtmlSnapshot(p,S,T))}catch(T){p.debug({err:T},"Failed store debug data after step, likely because the page is still loading. This is non-fatal and does not affect the test.")}return E.beforeSnapshot=f,w.beforeSnapshot=f,E.afterSnapshot=S,w.afterSnapshot=S,g&&(t.attachBeforeScreenshot({logger:p,snapshotId:f,screenshot:g}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(p,f,g))),y&&(t.attachAfterScreenshot({logger:p,snapshotId:S,screenshot:y}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(p,S,y))),w};function tO({work:n,step:e,newTargets:t,logger:r}){if(!t?.length)return{proposedStep:void 0};let o=e.command;ff(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={...eO(e),command:a};return Ol(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 nO(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
+ Located second element: ${n[1]?.thoughts}`}}async function Ky({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 Mn({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 rO=["NAVIGATE","NEW_TAB","TAB","REFRESH","WAIT_FOR_URL"];async function Yy({beforeUrl:n,beforePages:e,browser:t,command:r,logger:o}){if(rO.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 Q(250),c++;let d=(await t.getOpenPages()).map(u=>u.url),p=t.url();if(d.length!==e.length)for(let u=d.length-1;u>=e.length;u--){let m=d[u];if(Jr(m,o)&&m!==n&&m!==p){o.info({beforePages:e,afterPages:d,beforeUrl:n},"Auto-following new tab after preset action"),await t.switchToPage({type:"INDEX",index:String(u)});break}}}}var Jy="MOMENTIC_RUN_ID",Xy="FINAL_SCREENSHOT_URL";import{cloneDeep as uO}from"lodash-es";async function Zy(n){let{step:e,tracer:t}=n.conditionalParams,{logger:r,controller:o}=n.fixtures,i=new Date,a=el(e),s=e.elseSteps,l=!0,c=[],d,p=Ms();for(let f=0;f<e.blocks.length;f++){r.info(`Evaluating condition ${f} in conditional step`);let S=e.blocks[f];try{let w=await Ml({...n,presetParams:{tracer:t,step:S.assertion}});c.push(w),r.info(`Condition ${f} resolved to true, executing the corresponding ${S.steps.length} steps`),l=!1,s=S.steps,d=w}catch(w){r.info({err:w},`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 u=await n.conditionalParams.tracer.startSubSteps(),m=await n.executeStepList({...n,listParams:{steps:s,containerName:"conditional block",tracer:u}}),g={...a,assertion:d,...m,startedAt:i,finishedAt:new Date};return rn({asyncTasks:n.work.asyncTasks,nestedResults:[...c,...m.results],result:g,logger:r}),g}import{randomUUID as Qy}from"crypto";var eb=async n=>{let{controller:e}=n.fixtures;await e.browser.waitForDOMStability();let t=await e.browser.screenshot({}),r=await oO(n);r.finishedAt=new Date,rn({asyncTasks:n.work.asyncTasks,result:r,nestedResults:r.results,logger:n.fixtures.logger});let o=await e.browser.screenshot({}),i=Qy();r.beforeSnapshot=i,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,i,t));let a=Qy();return r.afterSnapshot=a,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,a,o)),r},oO=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 Cp}from"crypto";var tb=15,iO=7,nb=async n=>{let{controller:e}=n.fixtures;await e.browser.waitForDOMStability();let t=await e.browser.screenshot({quality:75}),r=await aO(n);r.finishedAt=new Date,rn({asyncTasks:n.work.asyncTasks,result:r,nestedResults:r.results,logger:n.fixtures.logger});let o=await e.browser.screenshot({quality:75}),i=Cp();r.beforeSnapshot=i,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,i,t));let a=Cp();return r.afterSnapshot=a,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,a,o)),r},aO=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}),u={...e,startedAt:new Date,beforeTestContext:a.toRedactedDisplayCopy(),results:[],finishedAt:new Date,status:"SUCCESS"},m=await $t({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,w=0,E,y;for(;;){if(S>tb)return u.message=`Exceeded the maximum number of commands allowed per AI step (${tb})`,u.status="FAILED",u;if(i.executeAbortController.signal.aborted)return u.message="Test execution was cancelled",u.status="CANCELLED",u;c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Evaluating current state..."});let x=await i.evaluateAiAction({goal:m,startingScreenshot:S===0?void 0:g,history:f,logger:p,langfuseSessionId:d,lastError:y}),{evaluation:T,reasoning:A,summary:D}=x;p.info(x,"Got AI evaluation");let L=u.results[S-1]?.id;switch(T.type){case"DONE":return u.message=`Our AI evaluator confirmed all tasks are complete: ${A}`,u.status="SUCCESS",L&&c.onDynamicAIActionEvaluatingEvent?.({stepId:L,status:"SUCCESS",message:`${D}
54
+ ${A}`}),u;case"RIGHT_TRACK":{E=void 0,S===0?c.onDynamicAIActionEvaluatingEvent?.({stepId:e.id,status:"RUNNING",message:A}):L&&c.onDynamicAIActionEvaluatingEvent?.({stepId:L,status:"SUCCESS",message:A});break}case"WRONG_TRACK":{if(E=`${A}
55
+ ${T.feedback}`,w++,w>=iO)return u.message=`Our AI agent requires additional information to achieve this goal:
56
56
  ${A}
57
- ${x.feedback}`,u.status="FAILED",c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,status:"FAILED",message:u.message}),u;L&&c.onDynamicAIActionEvaluatingEvent?.({stepId:L,status:"FAILED",message:x.feedback});break}case"IMPOSSIBLE":return u.message=`Our AI evaluator determined this task cannot be achieved: ${A}`,u.status="FAILED",c.onDynamicAIActionEvaluatingEvent?.({stepId:L??e.id,status:"FAILED",message:u.message}),u}let W=setTimeout(()=>{c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Deciding what to do next..."})},1500);p.info({commandIndex:S,lastActionHint:T},`Generating new sub-command ${S} within AI action`);let q,M;try{({command:q,reasoning:M}=await i.promptToCommand({goal:m,history:f,startingScreenshot:g,disableCache:r?.advanced.disableAICaching??!1,logger:p,actionHint:T,langfuseSessionId:d})),p.info({command:q,reasoning:M},"Got proposed command")}finally{clearTimeout(W)}if(q.type==="FAILURE")return clearTimeout(W),u.status="FAILED",u.message=`Our AI agent determined that no supported actions can fulfill the goals: ${M}`,u;let D={id:Ep(),type:"PRESET_ACTION",command:q},O={substepIndex:S+1,message:M||"Generated new command."};c.onDynamicCommandGenerated?.({...O,step:D,parentStepId:e.id}),p.info({commandId:q.id},`Executing sub-command ${S} within AI step: ${Wr(q)}`);let Y=await t.startSubSteps(),re=(await n.executeStepList({...n,options:{...n.options,disableHealing:!0},listParams:{containerName:"AI action newly generated step",steps:[D],tracer:Y}})).results[0];c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Waiting for page to stabilize before next action..."}),await i.browser.waitForDOMStability({logger:p});let oe=await i.browser.screenshot({clearHighlights:!0,retries:1});u.results.push(re),f.push({screenshotBase64AfterCommand:`data:image/jpeg;base64,${oe.toString("base64")}`,urlAfterCommand:i.browser.url(),serializedCommand:Wr(q),elementInteracted:re.results[0]?.elementInteracted,thoughts:M});let de={substepIndex:S,output:{...re,message:re.message??"Successfully executed preset action."},step:D,parentStepId:e.id};if(c.onDynamicCommandExecuted?.(de),await t.finish({output:ws.parse(re),step:re,message:re.message}),re.status==="FAILED")if(u.status="FAILED",u.message=re.message,w<3)w++,y=`The last attempted action resulted in a Momentic error. A different element may need to be targeted. Error: ${re.message}`;else return u;else if(re.status==="CANCELLED")return u.status="CANCELLED",u.message=re.message,u;S++}};async function rb(n){let{results:e}=n.failureRecoveryParams,t=e[e.length-1],r=iO(t);if(r)return n.fixtures.logger.info({failedResult:t,isNotEligible:r},"Skipping failure recovery because of ineligible failure"),null;try{return await oO(n)}catch(o){return n.fixtures.logger.error({err:o},"Error during failure recovery attempt"),null}}async function nb({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 oO(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")}`,u=(await o.browser.getBrowserState({skipWait:!0})).serialize(),{results:m}=await Vs(i,e.debugDataStorage,a,{numScreenshots:3,addIndices:!0}),h=l.map(T=>pn(T)),g=await o.runFailureRecovery({currentUrl:d,currentScreenshot:p,failedResults:m,currentPageState:u,nextStepsSerialized:h});if(g.scenario==="INELIGIBLE"||!g.patch)return null;let f=[];if(g.patch.op==="add"){let T=g.patch.value;if(!T)throw new Error("No value in add patch in failure recovery");await nb({screenshot:p,controller:o,currentPageState:u,newStep:T,patch:g.patch,logger:i}),f=[T,s]}else if(g.patch.op==="replace"){let T=g.patch.value;if(!T)throw new Error("No value in replace patch in failure recovery");await nb({screenshot:p,controller:o,currentPageState:u,newStep:T,patch:g.patch,logger:i}),f=[T]}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(),w;if(f.length){w=await yr(n.work,()=>n.executeStepList({...n,fixtures:{...n.fixtures},listParams:{steps:f,containerName:"AI-recovered step list",tracer:S}}));for(let T of w.results)T.aiSuggested&&T.type==="PRESET_ACTION"&&(T.message=`AI suggested step: ${T.command.thoughts}`)}else w={status:"SUCCESS",results:[],proposedSteps:[]};return Pl(t,{type:"FAILURE_RECOVERY",thoughts:g.reasoning}),t.state.failureRecoveryDisabled=!0,w}function iO(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":lh.some(t=>e.includes(t))?"User fault and likely irrecoverable":"":"No error message available"}async function ob(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 rn({asyncTasks:n.work.asyncTasks,nestedResults:s.results,result:c,logger:r}),c}import{randomUUID as Ol}from"crypto";import aO from"fast-json-patch";import{cloneDeep as sO}from"lodash-es";async function ib(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:u}=o,m=c?.autohealingConfig,h=m?.restartBehavior??{type:"GO_TO_SECTION_START"},g=m?.attempts??1;for(let f=0;f<g;f++){if(!e.terminalResult?.message)throw new Error("No error message in terminal result");let S=sO(c.steps);await Promise.allSettled(i.asyncTasks??[]);let{results:w}=await Vs(p,u,e.results,{numScreenshots:4}),T=await d.runSectionAutohealing({results:w,errorMessage:e.terminalResult?.message,goal:c.description});S=aO.applyPatch(S,T.patches).newDocument;let y=Ot.fromSnapshot({snapshot:s,environmentVariables:o.context.getVariablesFromEnvironmentCopy()});await lO({logger:p,controller:d,tracer:l,context:y,restartConfig:h,startingUrl:a});let E=await yr(n.work,()=>n.executeStepList({...n,fixtures:{...n.fixtures,context:y},listParams:{steps:S,containerName:"auto-healed step list",tracer:l}}));if(t.push(E.results),E.status==="SUCCESS")return{successfulHealing:{proposedStep:{...c,steps:S},listResult:E,context:y},healingAttempts:t};e=E}return{healingAttempts:t}}async function lO({logger:n,controller:e,tracer:t,restartConfig:r,context:o,startingUrl:i}){switch(r.type){case"NAVIGATE_URL":{let a={id:Ol(),type:"PRESET_ACTION",command:{id:Ol(),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:Ol(),type:"PRESET_ACTION",command:{id:Ol(),type:"NAVIGATE",url:i}},s=await t.startStep({logger:n,step:a});await e.executePresetCommand(null,s,a.command,o,!1);break}}}function ab(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"&&mm(e.command.type))}}async function sb(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 yr(n.work,d):await d(),u,m;if(p.status==="FAILED"&&e.autohealingConfig&&!n.work.state.autoHealingDisabled&&ab(e.autohealingConfig.trigger,p.terminalResult)){let g=await t.startSubSteps(),f=await ib({...n,startingContextSnapshot:l,startingUrl:s,failedResults:p,tracer:g});f.successfulHealing&&(u=f.successfulHealing.proposedStep,p=f.successfulHealing.listResult,n.fixtures.context=f.successfulHealing.context),m=f.healingAttempts}let h={...e,...p,startedAt:a,finishedAt:new Date,proposedStep:u,healingAttempts:m};return rn({asyncTasks:n.work.asyncTasks,nestedResults:p.results,result:h,logger:r}),h}async function Mn(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:u,fromStep:m,toStep:h}=n.inputs,g=n.work,f=[],S="SUCCESS",w,T=0;for(T;T<r.length;T++){let y=r[T],E,x=pn(y);if(y.skipped)continue;if(g.fastForwardingToStep&&m){let K=JSON.stringify(p);if(y.id===m.fromStepId&&K===JSON.stringify(m.parentStepIdChain))g.fastForwardingToStep=!1;else if(!lf(y,p,m.fromStepId,m.parentStepIdChain))continue}let A=new Date,k=d.child({step_id:y.id});i.info({step:y},`Executing step ${T+1}/${r.length} in ${t}: ${x}`);let L=await o.startStep({logger:i,step:y}),W=cO(y),q=a.toRedactedDisplayCopy(),M=s.browser.url(),D=s.executeAbortController.signal,O=na(y.type);g.asyncTasks.push(c.reportCreditsUsed(i,y.type,O,{testId:n.inputs.testMetadata?.id,testName:n.inputs.testMetadata?.name,suiteId:n.inputs.suiteMetadata?.id,suiteName:n.inputs.suiteMetadata?.name}));let Y,U;switch(y.type){case"PRESET_ACTION":{Y="Preset action",U=await br(y,async()=>await Ll({...n,presetParams:{tracer:L,step:y}}),D),"proposedStep"in U&&U.proposedStep&&(E=U.proposedStep,U.proposedStep=void 0);break}case"AI_ACTION":{Y="AI action",U=await br(y,()=>Zy({...n,aiStepParams:{step:y,tracer:L},executeStepList:Mn}),D);break}case"AI_ACTION_DYNAMIC":{Y="AI action",U=await br(y,()=>tb({...n,aiStepParams:{step:y,tracer:L},executeStepList:Mn}),D);break}case"RESOLVED_MODULE":{Y=`Module (${y.name})`,U=await br(y,async()=>{let K=await Wy({orgId:u,step:y,context:a,logger:i,flagStore:s.flagStore,codeEvalTools:l,signal:D});return Tp({...n,executeStepList:Mn,moduleParams:{step:y,resolvedInputs:K,tracer:L}})},D);break}case"CONDITIONAL":{Y="Conditional step",U=await br(y,()=>Xy({...n,conditionalParams:{step:y,tracer:L},executeStepList:Mn}),D);break}case"IFRAME":{Y="Frame step",U=await br(y,()=>ob({...n,frameParams:{step:y,tracer:L},executeStepList:Mn}),D);break}case"SECTION":{Y="Section";let K=await br(y,()=>sb({...n,sectionParams:{step:y,tracer:L},executeStepList:Mn}),D);"proposedStep"in K&&K.proposedStep&&(E=K.proposedStep,K.proposedStep=void 0),U=K;break}default:return(De=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(y)}U.beforeUrl=U.beforeUrl??M,U.beforeTestContext=q,y.envKey&&a.setVariable(y.envKey,U.data);let re=s.browser.url();a.setCurrentUrl(re),U.afterUrl=U.afterUrl??re,U.afterTestContext=a.toRedactedDisplayCopy(),e.push(U),await dO({startedAt:A,stepTypeName:Y,result:U,callbacks:n.callbacks,globalWorkRef:n.work,tracer:L});let oe;if(U.status==="FAILED"&&!g.state.failureRecoveryDisabled&&m?.fromStepId===void 0&&h?.toStepId===void 0){let K=await rb({...n,executeStepList:Mn,failureRecoveryParams:{failedStep:W,nextSteps:r.slice(T+1),results:e,tracer:L}});K&&K.status==="SUCCESS"&&(oe=K.proposedSteps,e.push(...K.results))}if(oe?f.push(...oe):E?f.push(E):f.push(y),g.fastForwardingToStep&&m&&m.fromStepId===y.id&&JSON.stringify(p)===JSON.stringify(m.parentStepIdChain)&&(g.fastForwardingToStep=!1),U.status!=="SUCCESS"&&!oe||s.closed){S=U.status,w=U;break}else if(h&&y.id===h.toStepId&&JSON.stringify(p)===JSON.stringify(h.parentStepIdChain)){s.setClosed();break}}return{status:S,results:e,terminalResult:w,proposedSteps:f}}async function dO({stepTypeName:n,result:e,tracer:t}){let r=n.toLowerCase(),o=n.charAt(0).toUpperCase()+n.slice(1),i="";switch(e.status){case"SUCCESS":i=e.message??`${o} executed successfully.`;break;case"FAILED":i=e.message??`${o} failed.`;break;case"CANCELLED":i=e.message??`${o} cancelled.`;break;default:throw new Error(`Unexpected ${r} status: ${e.status}`)}await t.finish({step:e,message:i,output:ws.parse(e)})}import{randomUUID as lb}from"crypto";async function cb({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:lb(),type:"PRESET_ACTION",status:e.aborted||r.name==="AbortError"?"CANCELLED":"FAILED",failureReason:"UserInfrastructureError",message:r.message,startedAt:t,finishedAt:new Date,results:[],command:{id:lb(),type:"NAVIGATE",url:n.baseUrl}};return{status:e.aborted||r.name==="AbortError"?"CANCELLED":"FAILED",results:[],failedStepResult:o}}}var Ml=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,u=Uy(l);if(n.options.reinitializeBrowser){let h=await cb({browser:c.browser,signal:c.executeAbortController.signal});if(h.status!=="PASSED")return await d?.(),clearInterval(u?.interval),h}let m;try{return l.info({platform:u?.platform,cpuMetadata:u?.cpuMetadata,labels:o?.labels},`Starting run for Momentic test '${o?.name??"Unnamed test"}'`),m=await pO(n),m}finally{if(l.info({status:m?.status,labels:o?.labels},"Momentic test final result"),clearInterval(u?.interval),await d?.(),m?.status==="PASSED")try{await p?.({steps:i,beforeSteps:a,afterSteps:s})}catch(h){l.warn({err:h},"Error running test success handler, continuing...")}}},pO=async n=>{let{tracer:e}=n.testParams,{runId:t,runAttemptId:r,testMetadata:o,fromStep:i,toStep:a,steps:s,beforeSteps:l,afterSteps:c}=n.inputs,{logger:d,controller:p,context:u,storage:m}=n.fixtures,{collectDebugData:h,disableHealing:g}=n.options;u.setCurrentUrl(p.browser.url());let f="test",S=s,w=[],T=g||i!==void 0||a!==void 0||void 0,y={results:w,state:{failureRecoveryDisabled:T,autoHealingDisabled:T},asyncTasks:[]},E=!1;i?.fromStepId&&i.fromStepId===a?.toStepId?(f="filtered step",y.fastForwardingToStep=!0):i?.fromStepId?(f="partial steps list from step",y.fastForwardingToStep=!0):a?f="partial steps list until step":(f="entire test",E=!0);let x;if(E&&l&&l.length>0){let{status:D,results:O}=await db(l,"beforeSteps",n);if(x=O,D!=="PASSED")return h&&pb({tracer:e,debugDataStorage:n.fixtures.debugDataStorage,work:y,controller:p,storage:m,context:u,runId:t,runAttemptId:r,logger:d,status:D}),y.asyncTasks.push(Promise.resolve(n.callbacks.test.onSaveFinalRunResults?.({beforeResults:x,results:[]}))),{status:D,beforeResults:x,results:[]}}d.debug({stepsToExecute:S,fromStep:i,toStep:a},`Starting step execution for ${f}`);let A=await e.startStepList(),{status:k,terminalResult:L,proposedSteps:W}=await Mn({...n,work:y,listParams:{steps:S,containerName:f,results:w,tracer:A}}),q;if(E&&c&&c.length>0){d.debug("Starting step execution for after step list");try{let{results:D}=await db(c,"afterSteps",n);q=D}catch(D){d.error({err:D},"Failed to execute after steps list, continuing...")}}if(h&&pb({tracer:e,debugDataStorage:n.fixtures.debugDataStorage,work:y,controller:p,storage:m,context:u,runId:t,runAttemptId:r,logger:d,status:k}),await Promise.allSettled(y.asyncTasks),y.asyncTasks.push(Promise.resolve(n.callbacks.test.onSaveFinalRunResults?.({results:w,beforeResults:x,afterResults:q}))),k==="FAILED")return{status:"FAILED",results:w,beforeResults:x,afterResults:q,failedStepResult:L};if(k==="CANCELLED")return{status:"CANCELLED",results:w,beforeResults:x,afterResults:q};let M;if(W&&y.state.healingDetails&&o){let D=Sy(3);await n.callbacks.test.onProposedTestSteps?.({name:D,testId:o.id,orgId:n.inputs.orgId,runId:n.inputs.runId,steps:W,details:y.state.healingDetails,purpose:"AUTO_HEALING"}),M={orgId:n.inputs.orgId,name:D}}return{proposedTest:M,status:"PASSED",results:w,beforeResults:x,afterResults:q}};async function db(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 Mn({...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 pb({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=ff(d.logsPerPage),u=wd(d.harPages||{},d.harEntries||{});n.attachConsoleLogs({logger:i,logs:p}),n.attachNetworkLogs({logger:i,logs:u}),t.asyncTasks.push((async()=>{try{let m=await r.browser.screenshot({quality:75}),h=await qy({codePath:"test-complete-final",storage:o,screenshotBuff:m,logger:i}),g=await B(r.browser.html(),{milliseconds:2e3});a.setVariable(Jy,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,u):Promise.resolve(null))}async function Nl({settings:n,customHeaders:e,envVariables:t,envName:r,testName:o,baseUrl:i,logger:a,localTools:s,orgId:l,flagStore:c}){let d=Rs.parse(n);e&&(d.extraHeaders={...d.extraHeaders,...e});let p=new Ot({baseUrl:i,envName:r,testName:o,variablesFromEnvironment:t,currentUrl:i});await hi({obj:d,context:p,bannedKeys:[],allowList:mh,localTools:s,logger:a,orgId:l,flagStore:c});try{return Rs.parse(d)}catch(u){throw new R("UserConfigurationError",`The templated browser settings configured by the user are invalid: ${u.message}`)}}import{cloneDeep as TN}from"lodash-es";var ub={vimiumJs:'var D=Object.defineProperty;var P=(t,e,n)=>e in t?D(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n;var b=(t,e,n)=>(P(t,typeof e!="symbol"?e+"":e,n),n);var y=t=>function(e){return e&&e.isTrusted?t.apply(this,arguments):!0};globalThis.forTrusted==null&&(globalThis.forTrusted=y);var E={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?[E.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 T={_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=y(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=y(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(E.copy(n));return i})(),r=function(){let i=window.getComputedStyle(t,null),h=i.getPropertyValue("display").indexOf("inline")===0&&i.getPropertyValue("font-size")==="0px";return r=()=>h,h};for(n of o){let i;if((n.width===0||n.height===0)&&e)for(let h of Array.from(t.children)){i=window.getComputedStyle(h,null);let m=i.getPropertyValue("position");if(i.getPropertyValue("float")==="none"&&!["absolute","fixed"].includes(m)&&!(n.height===0&&r()&&i.getPropertyValue("display").indexOf("inline")===0))continue;let s=this.getVisibleClientRect(h,!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=E.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,h,m,s=o.coords.split(",").map(l=>parseInt(l,10)),a=o.shape.toLowerCase();if(["rect","rectangle"].includes(a))s.length==4&&([r,h,i,m]=s);else if(["circle","circ"].includes(a)){if(s.length==3){let[l,c,d]=s,p=d/Math.sqrt(2);r=l-p,i=l+p,h=c-p,m=c+p}}else a==="default"?s.length==2&&([r,h,i,m]=[0,0,t.width,t.height]):s.length>=4&&([r,h,i,m]=s);let u=E.translate(E.create(r,h,i,m),t.left,t.top);u=this.cropRectToVisible(u),u&&!isNaN(u.top)&&!isNaN(u.left)&&!isNaN(u.width)&&!isNaN(u.height)&&n.push({element:o,rect:u})}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{}},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:h}=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&&h===!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 T.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?.parentNode,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 R={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){let e={};this.addAttributes(t,this.commonAttributes,e);let n=t.tagName.toLowerCase?.()||"";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,{tag:n,attributes:e,...o&&{content:o}})},getContent(t){let e=t.tagName.toLowerCase?.()||"";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){if((t.tagName.toLowerCase?.()||"")=="label"&&t.hasAttribute("for")){let o=t.getAttribute("for"),r=document.getElementById(o);r&&(e.target=this.describe(r))}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 C=null,k=()=>j()||document.scrollingElement||document.body,_=function(t){return t?t<0?-1:1:0},F={x:{axisName:"scrollLeft",max:"scrollWidth",viewSize:"clientWidth"},y:{axisName:"scrollTop",max:"scrollHeight",viewSize:"clientHeight"}},O=function(t,e,n){if(T.isString(n)){let o=n;return o==="viewSize"&&t===k()?e==="x"?window.innerWidth:window.innerHeight:t[F[e][o]]}else return n},I=function(t,e,n){let o=F[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},V=function(t,e){let n=window.getComputedStyle(t);return!(n.getPropertyValue(`overflow-${e}`)==="hidden"||["hidden","collapse"].includes(n.getPropertyValue("visibility"))||n.getPropertyValue("display")==="none")},v=function(t,e,n,o){let r=o*O(t,e,n)||-1;return r=_(r),I(t,e,r)&&I(t,e,-r)},U=function(t,e,n,o){return e==null&&(e="y"),n==null&&(n=1),o==null&&(o=1),v(t,e,n,o)&&V(t,e)},H=function(t=null){let e;if(!t){let n=k();if(v(n,"y",1,1)||v(n,"y",-1,1))return n;t=document.body||k()}if(v(t,"y",1,1)||v(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=H(e.element);if(o)return o}return null}},M={init(){C=null},isScrollableElement(t){return C||(C=k()&&H()||k()),t!==C&&U(t)}},j=function(){let t=K[window.location.host];if(t)return document.querySelector(t)},K={"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=M;var x=function(){let t=null;return f.documentReady(()=>t=document.hasFocus()),globalThis.addEventListener("focus",y(function(e){return e.target===window&&(t=!0),!0}),!0),globalThis.addEventListener("blur",y(function(e){return e.target===window&&(t=!1),!0}),!0),()=>t}();Object.assign(globalThis,{windowIsFocused:x});var L=class{constructor(e){b(this,"element");b(this,"image");b(this,"rect");b(this,"linkText");b(this,"showLinkText");b(this,"reason");b(this,"secondClassCitizen");b(this,"possibleFalsePositive");Object.seal(this),e&&Object.assign(this,e)}},S={getLocalHintsForElement(t){let e=t.tagName.toLowerCase?.()||"",n=!1,o=!1,r=!1,i=[],h=[],m=null;if(e==="img"){let l=t.getAttribute("usemap");if(l){let c=t.getClientRects();l=l.replace(/^#/,"").replace(\'"\',\'\\\\"\');let d=document.querySelector(`map[name="${l}"]`);if(d&&c.length>0){n=!0;let p=d.getElementsByTagName("area"),g=f.getClientRectsForAreas(c[0],p);g=g.map(N=>Object.assign(N,{image:t})),h.push(...g)}}}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 c=[];for(let d of["","data-","x-"])for(let p of["-",":","_"])c.push(`${d}ng${p}click`);return function(d){for(let p of c)if(d.hasAttribute(p))return!0;return!1}}}()),n||(n=this.checkForAngularJs(t)),t.hasAttribute("onclick"))n=!0;else{let l=t.getAttribute("role"),c=["button","tab","link","checkbox","menuitem","menuitemcheckbox","menuitemradio","radio"];if(l!=null&&c.includes(l.toLowerCase()))n=!0;else{let d=t.getAttribute("contentEditable");d!=null&&["","contenteditable","true","plaintext-only"].includes(d.toLowerCase())&&(n=!0)}}if(!n&&t.hasAttribute("jsaction")){let l=t.getAttribute("jsaction").split(";");for(let c of l){let d=c.trim().split(":");if(d.length>=1&&d.length<=2){let[p,g,N]=d.length===1?["click",...d[0].trim().split("."),"_"]:[d[0],...d[1].trim().split("."),"_"];n||(n=p==="click"&&g!=="none"&&N!=="_")}}}switch(e){case"a":n=!0;break;case"textarea":n||=!t.disabled&&!t.readOnly;break;case"input":n||=!(t.getAttribute("type")?.toLowerCase()=="hidden"||t.disabled||t.readOnly&&f.isSelectable(t));break;case"button":case"select":n||=!t.disabled;break;case"object":case"embed":n=!0;break;case"label":n||=t.control!=null&&!t.control.disabled&&this.getLocalHintsForElement(t.control).length===0;break;case"body":n||=t===document.body&&!x()&&window.innerWidth>3&&window.innerHeight>3&&(document.body!=null?document.body.tagName.toLowerCase():void 0)!=="frameset"?m="Frame.":void 0,n||=t===document.body&&x()&&M.isScrollableElement(t)?m="Scroll.":void 0;break;case"img":n||=["zoom-in","zoom-out"].includes(t.style.cursor);break;case"div":case"ol":case"ul":n||=t.clientHeight<t.scrollHeight&&M.isScrollableElement(t)?m="Scroll.":void 0;break;case"details":n=!0,m="Open.";break}let a=t.getAttribute("class");!n&&a?.toLowerCase().includes("button")&&(n=!0,r=!0);let u=t.getAttribute("tabindex"),w=u?parseInt(u):-1;if(!n&&!(w<0)&&!isNaN(w)&&(n=!0,o=!0),n)if(h.length>0){let l=h.map(c=>new L({element:c.element,image:t,rect:c.rect,secondClassCitizen:o,possibleFalsePositive:r,reason:m}));i.push(...l)}else{let l=f.getVisibleClientRect(t,!0);if(l!==null){let c=new L({element:t,rect:l,secondClassCitizen:o,possibleFalsePositive:r,reason:m});i.push(c)}}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?S.getElementFromPoint(t,e,r.shadowRoot,o):r)},getLocalHints(t){if(!document.body)return[];let e=(s,a)=>{a==null&&(a=[]);for(let u of Array.from(s.querySelectorAll("*")))a.push(u),u.shadowRoot&&e(u.shadowRoot,a);return a},n=e(document.body),o=[];for(let s of Array.from(n))if(!t||s.href){let a=this.getLocalHintsForElement(s);o.push(...a)}o=o.reverse();let r=[1,2,3];o=o.filter((s,a)=>{if(!s.possibleFalsePositive)return!0;let w=Math.max(0,a-6);for(;w<a;){let l=o[w].element;for(let c of r)if(l=l?.parentElement,l===s.element)return!1;w+=1}return!0});let i=o.filter(s=>{if(s.secondClassCitizen)return!1;let a=s.rect,u=S.getElementFromPoint(a.left+a.width*.5,a.top+a.height*.5);if(u&&(s.element.contains(u)||u.contains(s.element))||s.element.localName=="area"&&u==s.image)return!0;let l=[a.top+.1,a.bottom-.1],c=[a.left+.1,a.right-.1];for(let d of l)for(let p of c){let g=S.getElementFromPoint(p,d);if(g&&(s.element.contains(g)||g.contains(s.element)))return!0}});i.reverse();let{top:h,left:m}=f.getViewportTopLeft();for(let s of i)s.rect.top+=h,s.rect.left+=m;return i}};var A=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}async capture(){this.reset(),this.createMarkers(),this.displayMarkers()}createMarkers(){this.hints=S.getLocalHints(),this.hintMarkers=new Map,this.hints.forEach((e,n)=>{let o=f.createElement("div"),r=e.element.attributes["data-momentic-id"]?.value??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(R.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=A;\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:`// src/html/cache-evaluation.ts
57
+ ${T.feedback}`,u.status="FAILED",c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,status:"FAILED",message:u.message}),u;L&&c.onDynamicAIActionEvaluatingEvent?.({stepId:L,status:"FAILED",message:T.feedback});break}case"IMPOSSIBLE":return u.message=`Our AI evaluator determined this task cannot be achieved: ${A}`,u.status="FAILED",c.onDynamicAIActionEvaluatingEvent?.({stepId:L??e.id,status:"FAILED",message:u.message}),u}let j=setTimeout(()=>{c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Deciding what to do next..."})},1500);p.info({commandIndex:S,lastActionHint:E},`Generating new sub-command ${S} within AI action`);let V,k;try{({command:V,reasoning:k}=await i.promptToCommand({goal:m,history:f,startingScreenshot:g,disableCache:r?.advanced.disableAICaching??!1,logger:p,actionHint:E,langfuseSessionId:d})),p.info({command:V,reasoning:k},"Got proposed command")}finally{clearTimeout(j)}if(V.type==="FAILURE")return clearTimeout(j),u.status="FAILED",u.message=`Our AI agent determined that no supported actions can fulfill the goals: ${k}`,u;let N={id:Cp(),type:"PRESET_ACTION",command:V},O={substepIndex:S+1,message:k||"Generated new command."};c.onDynamicCommandGenerated?.({...O,step:N,parentStepId:e.id}),p.info({commandId:V.id},`Executing sub-command ${S} within AI step: ${Wr(V)}`);let q=await t.startSubSteps(),ie=(await n.executeStepList({...n,options:{...n.options,disableHealing:!0},listParams:{containerName:"AI action newly generated step",steps:[N],tracer:q}})).results[0];c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Waiting for page to stabilize before next action..."}),await i.browser.waitForDOMStability({logger:p});let oe=await i.browser.screenshot({clearHighlights:!0,retries:1});u.results.push(ie),f.push({screenshotBase64AfterCommand:`data:image/jpeg;base64,${oe.toString("base64")}`,urlAfterCommand:i.browser.url(),serializedCommand:Wr(V),elementInteracted:ie.results[0]?.elementInteracted,thoughts:k});let pe={substepIndex:S,output:{...ie,message:ie.message??"Successfully executed preset action."},step:N,parentStepId:e.id};if(c.onDynamicCommandExecuted?.(pe),await t.finish({output:ws.parse(ie),step:ie,message:ie.message}),ie.status==="FAILED")if(u.status="FAILED",u.message=ie.message,w<3)w++,y=`The last attempted action resulted in a Momentic error. A different element may need to be targeted. Error: ${ie.message}`;else return u;else if(ie.status==="CANCELLED")return u.status="CANCELLED",u.message=ie.message,u;S++}};async function ob(n){let{results:e}=n.failureRecoveryParams,t=e[e.length-1],r=lO(t);if(r)return n.fixtures.logger.info({failedResult:t,isNotEligible:r},"Skipping failure recovery because of ineligible failure"),null;try{return await sO(n)}catch(o){return n.fixtures.logger.error({err:o},"Error during failure recovery attempt"),null}}async function rb({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 sO(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")}`,u=(await o.browser.getBrowserState({skipWait:!0})).serialize(),{results:m}=await Ks(i,e.debugDataStorage,a,{numScreenshots:3,addIndices:!0}),h=l.map(E=>pn(E)),g=await o.runFailureRecovery({currentUrl:d,currentScreenshot:p,failedResults:m,currentPageState:u,nextStepsSerialized:h});if(g.scenario==="INELIGIBLE"||!g.patch)return null;let f=[];if(g.patch.op==="add"){let E=g.patch.value;if(!E)throw new Error("No value in add patch in failure recovery");await rb({screenshot:p,controller:o,currentPageState:u,newStep:E,patch:g.patch,logger:i}),f=[E,s]}else if(g.patch.op==="replace"){let E=g.patch.value;if(!E)throw new Error("No value in replace patch in failure recovery");await rb({screenshot:p,controller:o,currentPageState:u,newStep:E,patch:g.patch,logger:i}),f=[E]}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(),w;if(f.length){w=await br(n.work,()=>n.executeStepList({...n,fixtures:{...n.fixtures},listParams:{steps:f,containerName:"AI-recovered step list",tracer:S}}));for(let E of w.results)E.aiSuggested&&E.type==="PRESET_ACTION"&&(E.message=`AI suggested step: ${E.command.thoughts}`)}else w={status:"SUCCESS",results:[],proposedSteps:[]};return Ol(t,{type:"FAILURE_RECOVERY",thoughts:g.reasoning}),t.state.failureRecoveryDisabled=!0,w}function lO(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":ch.some(t=>e.includes(t))?"User fault and likely irrecoverable":"":"No error message available"}async function ib(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 rn({asyncTasks:n.work.asyncTasks,nestedResults:s.results,result:c,logger:r}),c}import{randomUUID as Nl}from"crypto";import cO from"fast-json-patch";import{cloneDeep as dO}from"lodash-es";async function ab(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:u}=o,m=c?.autohealingConfig,h=m?.restartBehavior??{type:"GO_TO_SECTION_START"},g=m?.attempts??1;for(let f=0;f<g;f++){if(!e.terminalResult?.message)throw new Error("No error message in terminal result");let S=dO(c.steps);await Promise.allSettled(i.asyncTasks??[]);let{results:w}=await Ks(p,u,e.results,{numScreenshots:4}),E=await d.runSectionAutohealing({results:w,errorMessage:e.terminalResult?.message,goal:c.description});S=cO.applyPatch(S,E.patches).newDocument;let y=Ot.fromSnapshot({snapshot:s,environmentVariables:o.context.getVariablesFromEnvironmentCopy()});await pO({logger:p,controller:d,tracer:l,context:y,restartConfig:h,startingUrl:a});let x=await br(n.work,()=>n.executeStepList({...n,fixtures:{...n.fixtures,context:y},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:y},healingAttempts:t};e=x}return{healingAttempts:t}}async function pO({logger:n,controller:e,tracer:t,restartConfig:r,context:o,startingUrl:i}){switch(r.type){case"NAVIGATE_URL":{let a={id:Nl(),type:"PRESET_ACTION",command:{id:Nl(),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:Nl(),type:"PRESET_ACTION",command:{id:Nl(),type:"NAVIGATE",url:i}},s=await t.startStep({logger:n,step:a});await e.executePresetCommand(null,s,a.command,o,!1);break}}}function sb(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"&&hm(e.command.type))}}async function lb(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 br(n.work,d):await d(),u,m;if(p.status==="FAILED"&&e.autohealingConfig&&!n.work.state.autoHealingDisabled&&sb(e.autohealingConfig.trigger,p.terminalResult)){let g=await t.startSubSteps(),f=await ab({...n,startingContextSnapshot:l,startingUrl:s,failedResults:p,tracer:g});f.successfulHealing&&(u=f.successfulHealing.proposedStep,p=f.successfulHealing.listResult,n.fixtures.context=f.successfulHealing.context),m=f.healingAttempts}let h={...e,...p,startedAt:a,finishedAt:new Date,proposedStep:u,healingAttempts:m};return rn({asyncTasks:n.work.asyncTasks,nestedResults:p.results,result:h,logger:r}),h}async function Nn(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:u,fromStep:m,toStep:h}=n.inputs,g=n.work,f=[],S="SUCCESS",w,E=0;for(E;E<r.length;E++){let y=r[E],x,T=pn(y);if(y.skipped)continue;if(g.fastForwardingToStep&&m){let K=JSON.stringify(p);if(y.id===m.fromStepId&&K===JSON.stringify(m.parentStepIdChain))g.fastForwardingToStep=!1;else if(!cf(y,p,m.fromStepId,m.parentStepIdChain))continue}let A=new Date,D=d.child({step_id:y.id});i.info({step:y},`Executing step ${E+1}/${r.length} in ${t}: ${T}`);let L=await o.startStep({logger:i,step:y}),j=uO(y),V=a.toRedactedDisplayCopy(),k=s.browser.url(),N=s.executeAbortController.signal,O=na(y.type);g.asyncTasks.push(c.reportCreditsUsed(i,y.type,O,{testId:n.inputs.testMetadata?.id,testName:n.inputs.testMetadata?.name,suiteId:n.inputs.suiteMetadata?.id,suiteName:n.inputs.suiteMetadata?.name}));let q,F;switch(y.type){case"PRESET_ACTION":{q="Preset action",F=await wr(y,async()=>await Ml({...n,presetParams:{tracer:L,step:y}}),N),"proposedStep"in F&&F.proposedStep&&(x=F.proposedStep,F.proposedStep=void 0);break}case"AI_ACTION":{q="AI action",F=await wr(y,()=>eb({...n,aiStepParams:{step:y,tracer:L},executeStepList:Nn}),N);break}case"AI_ACTION_DYNAMIC":{q="AI action",F=await wr(y,()=>nb({...n,aiStepParams:{step:y,tracer:L},executeStepList:Nn}),N);break}case"RESOLVED_MODULE":{q=`Module (${y.name})`,F=await wr(y,async()=>{let K=await Vy({orgId:u,step:y,context:a,logger:i,flagStore:s.flagStore,codeEvalTools:l,signal:N});return xp({...n,executeStepList:Nn,moduleParams:{step:y,resolvedInputs:K,tracer:L}})},N);break}case"CONDITIONAL":{q="Conditional step",F=await wr(y,()=>Zy({...n,conditionalParams:{step:y,tracer:L},executeStepList:Nn}),N);break}case"IFRAME":{q="Frame step",F=await wr(y,()=>ib({...n,frameParams:{step:y,tracer:L},executeStepList:Nn}),N);break}case"SECTION":{q="Section";let K=await wr(y,()=>lb({...n,sectionParams:{step:y,tracer:L},executeStepList:Nn}),N);"proposedStep"in K&&K.proposedStep&&(x=K.proposedStep,K.proposedStep=void 0),F=K;break}default:return(De=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(y)}F.beforeUrl=F.beforeUrl??k,F.beforeTestContext=V,y.envKey&&a.setVariable(y.envKey,F.data);let ie=s.browser.url();a.setCurrentUrl(ie),F.afterUrl=F.afterUrl??ie,F.afterTestContext=a.toRedactedDisplayCopy(),e.push(F),await mO({startedAt:A,stepTypeName:q,result:F,callbacks:n.callbacks,globalWorkRef:n.work,tracer:L});let oe;if(F.status==="FAILED"&&!g.state.failureRecoveryDisabled&&m?.fromStepId===void 0&&h?.toStepId===void 0){let K=await ob({...n,executeStepList:Nn,failureRecoveryParams:{failedStep:j,nextSteps:r.slice(E+1),results:e,tracer:L}});K&&K.status==="SUCCESS"&&(oe=K.proposedSteps,e.push(...K.results))}if(oe?f.push(...oe):x?f.push(x):f.push(y),g.fastForwardingToStep&&m&&m.fromStepId===y.id&&JSON.stringify(p)===JSON.stringify(m.parentStepIdChain)&&(g.fastForwardingToStep=!1),F.status!=="SUCCESS"&&!oe||s.closed){S=F.status,w=F;break}else if(h&&y.id===h.toStepId&&JSON.stringify(p)===JSON.stringify(h.parentStepIdChain)){s.setClosed();break}}return{status:S,results:e,terminalResult:w,proposedSteps:f}}async function mO({stepTypeName:n,result:e,tracer:t}){let r=n.toLowerCase(),o=n.charAt(0).toUpperCase()+n.slice(1),i="";switch(e.status){case"SUCCESS":i=e.message??`${o} executed successfully.`;break;case"FAILED":i=e.message??`${o} failed.`;break;case"CANCELLED":i=e.message??`${o} cancelled.`;break;default:throw new Error(`Unexpected ${r} status: ${e.status}`)}await t.finish({step:e,message:i,output:ws.parse(e)})}import{randomUUID as cb}from"crypto";async function db({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:cb(),type:"PRESET_ACTION",status:e.aborted||r.name==="AbortError"?"CANCELLED":"FAILED",failureReason:"UserInfrastructureError",message:r.message,startedAt:t,finishedAt:new Date,results:[],command:{id:cb(),type:"NAVIGATE",url:n.baseUrl}};return{status:e.aborted||r.name==="AbortError"?"CANCELLED":"FAILED",results:[],failedStepResult:o}}}var kl=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,u=By(l);if(n.options.reinitializeBrowser){let h=await db({browser:c.browser,signal:c.executeAbortController.signal});if(h.status!=="PASSED")return await d?.(),clearInterval(u?.interval),h}let m;try{return l.info({platform:u?.platform,cpuMetadata:u?.cpuMetadata,labels:o?.labels},`Starting run for Momentic test '${o?.name??"Unnamed test"}'`),m=await hO(n),m}finally{if(l.info({status:m?.status,labels:o?.labels},"Momentic test final result"),clearInterval(u?.interval),await d?.(),m?.status==="PASSED")try{await p?.({steps:i,beforeSteps:a,afterSteps:s})}catch(h){l.warn({err:h},"Error running test success handler, continuing...")}}},hO=async n=>{let{tracer:e}=n.testParams,{runId:t,runAttemptId:r,testMetadata:o,fromStep:i,toStep:a,steps:s,beforeSteps:l,afterSteps:c}=n.inputs,{logger:d,controller:p,context:u,storage:m}=n.fixtures,{collectDebugData:h,disableHealing:g}=n.options;u.setCurrentUrl(p.browser.url());let f="test",S=s,w=[],E=g||i!==void 0||a!==void 0||void 0,y={results:w,state:{failureRecoveryDisabled:E,autoHealingDisabled:E},asyncTasks:[]},x=!1;i?.fromStepId&&i.fromStepId===a?.toStepId?(f="filtered step",y.fastForwardingToStep=!0):i?.fromStepId?(f="partial steps list from step",y.fastForwardingToStep=!0):a?f="partial steps list until step":(f="entire test",x=!0);let T;if(x&&l&&l.length>0){let{status:N,results:O}=await pb(l,"beforeSteps",n);if(T=O,N!=="PASSED")return h&&ub({tracer:e,debugDataStorage:n.fixtures.debugDataStorage,work:y,controller:p,storage:m,context:u,runId:t,runAttemptId:r,logger:d,status:N}),y.asyncTasks.push(Promise.resolve(n.callbacks.test.onSaveFinalRunResults?.({beforeResults:T,results:[]}))),{status:N,beforeResults:T,results:[]}}d.debug({stepsToExecute:S,fromStep:i,toStep:a},`Starting step execution for ${f}`);let A=await e.startStepList(),{status:D,terminalResult:L,proposedSteps:j}=await Nn({...n,work:y,listParams:{steps:S,containerName:f,results:w,tracer:A}}),V;if(x&&c&&c.length>0){d.debug("Starting step execution for after step list");try{let{results:N}=await pb(c,"afterSteps",n);V=N}catch(N){d.error({err:N},"Failed to execute after steps list, continuing...")}}if(h&&ub({tracer:e,debugDataStorage:n.fixtures.debugDataStorage,work:y,controller:p,storage:m,context:u,runId:t,runAttemptId:r,logger:d,status:D}),await Promise.allSettled(y.asyncTasks),y.asyncTasks.push(Promise.resolve(n.callbacks.test.onSaveFinalRunResults?.({results:w,beforeResults:T,afterResults:V}))),D==="FAILED")return{status:"FAILED",results:w,beforeResults:T,afterResults:V,failedStepResult:L};if(D==="CANCELLED")return{status:"CANCELLED",results:w,beforeResults:T,afterResults:V};let k;if(j&&y.state.healingDetails&&o){let N=yy(3);await n.callbacks.test.onProposedTestSteps?.({name:N,testId:o.id,orgId:n.inputs.orgId,runId:n.inputs.runId,steps:j,details:y.state.healingDetails,purpose:"AUTO_HEALING"}),k={orgId:n.inputs.orgId,name:N}}return{proposedTest:k,status:"PASSED",results:w,beforeResults:T,afterResults:V}};async function pb(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 Nn({...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 ub({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=Sf(d.logsPerPage),u=Ed(d.harPages||{},d.harEntries||{});n.attachConsoleLogs({logger:i,logs:p}),n.attachNetworkLogs({logger:i,logs:u}),t.asyncTasks.push((async()=>{try{let m=await r.browser.screenshot({quality:75}),h=await Ky({codePath:"test-complete-final",storage:o,screenshotBuff:m,logger:i}),g=await B(r.browser.html(),{milliseconds:2e3});a.setVariable(Xy,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,u):Promise.resolve(null))}async function _l({settings:n,customHeaders:e,envVariables:t,envName:r,testName:o,baseUrl:i,logger:a,localTools:s,orgId:l,flagStore:c}){let d=Rs.parse(n);e&&(d.extraHeaders={...d.extraHeaders,...e});let p=new Ot({baseUrl:i,envName:r,testName:o,variablesFromEnvironment:t,currentUrl:i});await hi({obj:d,context:p,bannedKeys:[],allowList:hh,localTools:s,logger:a,orgId:l,flagStore:c});try{return Rs.parse(d)}catch(u){throw new R("UserConfigurationError",`The templated browser settings configured by the user are invalid: ${u.message}`)}}import{cloneDeep as CN}from"lodash-es";var mb={vimiumJs:'var D=Object.defineProperty;var P=(t,e,n)=>e in t?D(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n;var b=(t,e,n)=>(P(t,typeof e!="symbol"?e+"":e,n),n);var y=t=>function(e){return e&&e.isTrusted?t.apply(this,arguments):!0};globalThis.forTrusted==null&&(globalThis.forTrusted=y);var E={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?[E.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 T={_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=y(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=y(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(E.copy(n));return i})(),r=function(){let i=window.getComputedStyle(t,null),h=i.getPropertyValue("display").indexOf("inline")===0&&i.getPropertyValue("font-size")==="0px";return r=()=>h,h};for(n of o){let i;if((n.width===0||n.height===0)&&e)for(let h of Array.from(t.children)){i=window.getComputedStyle(h,null);let m=i.getPropertyValue("position");if(i.getPropertyValue("float")==="none"&&!["absolute","fixed"].includes(m)&&!(n.height===0&&r()&&i.getPropertyValue("display").indexOf("inline")===0))continue;let s=this.getVisibleClientRect(h,!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=E.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,h,m,s=o.coords.split(",").map(l=>parseInt(l,10)),a=o.shape.toLowerCase();if(["rect","rectangle"].includes(a))s.length==4&&([r,h,i,m]=s);else if(["circle","circ"].includes(a)){if(s.length==3){let[l,c,d]=s,p=d/Math.sqrt(2);r=l-p,i=l+p,h=c-p,m=c+p}}else a==="default"?s.length==2&&([r,h,i,m]=[0,0,t.width,t.height]):s.length>=4&&([r,h,i,m]=s);let u=E.translate(E.create(r,h,i,m),t.left,t.top);u=this.cropRectToVisible(u),u&&!isNaN(u.top)&&!isNaN(u.left)&&!isNaN(u.width)&&!isNaN(u.height)&&n.push({element:o,rect:u})}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{}},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:h}=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&&h===!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 T.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?.parentNode,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 R={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){let e={};this.addAttributes(t,this.commonAttributes,e);let n=t.tagName.toLowerCase?.()||"";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,{tag:n,attributes:e,...o&&{content:o}})},getContent(t){let e=t.tagName.toLowerCase?.()||"";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){if((t.tagName.toLowerCase?.()||"")=="label"&&t.hasAttribute("for")){let o=t.getAttribute("for"),r=document.getElementById(o);r&&(e.target=this.describe(r))}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 C=null,k=()=>j()||document.scrollingElement||document.body,_=function(t){return t?t<0?-1:1:0},F={x:{axisName:"scrollLeft",max:"scrollWidth",viewSize:"clientWidth"},y:{axisName:"scrollTop",max:"scrollHeight",viewSize:"clientHeight"}},O=function(t,e,n){if(T.isString(n)){let o=n;return o==="viewSize"&&t===k()?e==="x"?window.innerWidth:window.innerHeight:t[F[e][o]]}else return n},I=function(t,e,n){let o=F[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},V=function(t,e){let n=window.getComputedStyle(t);return!(n.getPropertyValue(`overflow-${e}`)==="hidden"||["hidden","collapse"].includes(n.getPropertyValue("visibility"))||n.getPropertyValue("display")==="none")},v=function(t,e,n,o){let r=o*O(t,e,n)||-1;return r=_(r),I(t,e,r)&&I(t,e,-r)},U=function(t,e,n,o){return e==null&&(e="y"),n==null&&(n=1),o==null&&(o=1),v(t,e,n,o)&&V(t,e)},H=function(t=null){let e;if(!t){let n=k();if(v(n,"y",1,1)||v(n,"y",-1,1))return n;t=document.body||k()}if(v(t,"y",1,1)||v(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=H(e.element);if(o)return o}return null}},M={init(){C=null},isScrollableElement(t){return C||(C=k()&&H()||k()),t!==C&&U(t)}},j=function(){let t=K[window.location.host];if(t)return document.querySelector(t)},K={"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=M;var x=function(){let t=null;return f.documentReady(()=>t=document.hasFocus()),globalThis.addEventListener("focus",y(function(e){return e.target===window&&(t=!0),!0}),!0),globalThis.addEventListener("blur",y(function(e){return e.target===window&&(t=!1),!0}),!0),()=>t}();Object.assign(globalThis,{windowIsFocused:x});var L=class{constructor(e){b(this,"element");b(this,"image");b(this,"rect");b(this,"linkText");b(this,"showLinkText");b(this,"reason");b(this,"secondClassCitizen");b(this,"possibleFalsePositive");Object.seal(this),e&&Object.assign(this,e)}},S={getLocalHintsForElement(t){let e=t.tagName.toLowerCase?.()||"",n=!1,o=!1,r=!1,i=[],h=[],m=null;if(e==="img"){let l=t.getAttribute("usemap");if(l){let c=t.getClientRects();l=l.replace(/^#/,"").replace(\'"\',\'\\\\"\');let d=document.querySelector(`map[name="${l}"]`);if(d&&c.length>0){n=!0;let p=d.getElementsByTagName("area"),g=f.getClientRectsForAreas(c[0],p);g=g.map(N=>Object.assign(N,{image:t})),h.push(...g)}}}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 c=[];for(let d of["","data-","x-"])for(let p of["-",":","_"])c.push(`${d}ng${p}click`);return function(d){for(let p of c)if(d.hasAttribute(p))return!0;return!1}}}()),n||(n=this.checkForAngularJs(t)),t.hasAttribute("onclick"))n=!0;else{let l=t.getAttribute("role"),c=["button","tab","link","checkbox","menuitem","menuitemcheckbox","menuitemradio","radio"];if(l!=null&&c.includes(l.toLowerCase()))n=!0;else{let d=t.getAttribute("contentEditable");d!=null&&["","contenteditable","true","plaintext-only"].includes(d.toLowerCase())&&(n=!0)}}if(!n&&t.hasAttribute("jsaction")){let l=t.getAttribute("jsaction").split(";");for(let c of l){let d=c.trim().split(":");if(d.length>=1&&d.length<=2){let[p,g,N]=d.length===1?["click",...d[0].trim().split("."),"_"]:[d[0],...d[1].trim().split("."),"_"];n||(n=p==="click"&&g!=="none"&&N!=="_")}}}switch(e){case"a":n=!0;break;case"textarea":n||=!t.disabled&&!t.readOnly;break;case"input":n||=!(t.getAttribute("type")?.toLowerCase()=="hidden"||t.disabled||t.readOnly&&f.isSelectable(t));break;case"button":case"select":n||=!t.disabled;break;case"object":case"embed":n=!0;break;case"label":n||=t.control!=null&&!t.control.disabled&&this.getLocalHintsForElement(t.control).length===0;break;case"body":n||=t===document.body&&!x()&&window.innerWidth>3&&window.innerHeight>3&&(document.body!=null?document.body.tagName.toLowerCase():void 0)!=="frameset"?m="Frame.":void 0,n||=t===document.body&&x()&&M.isScrollableElement(t)?m="Scroll.":void 0;break;case"img":n||=["zoom-in","zoom-out"].includes(t.style.cursor);break;case"div":case"ol":case"ul":n||=t.clientHeight<t.scrollHeight&&M.isScrollableElement(t)?m="Scroll.":void 0;break;case"details":n=!0,m="Open.";break}let a=t.getAttribute("class");!n&&a?.toLowerCase().includes("button")&&(n=!0,r=!0);let u=t.getAttribute("tabindex"),w=u?parseInt(u):-1;if(!n&&!(w<0)&&!isNaN(w)&&(n=!0,o=!0),n)if(h.length>0){let l=h.map(c=>new L({element:c.element,image:t,rect:c.rect,secondClassCitizen:o,possibleFalsePositive:r,reason:m}));i.push(...l)}else{let l=f.getVisibleClientRect(t,!0);if(l!==null){let c=new L({element:t,rect:l,secondClassCitizen:o,possibleFalsePositive:r,reason:m});i.push(c)}}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?S.getElementFromPoint(t,e,r.shadowRoot,o):r)},getLocalHints(t){if(!document.body)return[];let e=(s,a)=>{a==null&&(a=[]);for(let u of Array.from(s.querySelectorAll("*")))a.push(u),u.shadowRoot&&e(u.shadowRoot,a);return a},n=e(document.body),o=[];for(let s of Array.from(n))if(!t||s.href){let a=this.getLocalHintsForElement(s);o.push(...a)}o=o.reverse();let r=[1,2,3];o=o.filter((s,a)=>{if(!s.possibleFalsePositive)return!0;let w=Math.max(0,a-6);for(;w<a;){let l=o[w].element;for(let c of r)if(l=l?.parentElement,l===s.element)return!1;w+=1}return!0});let i=o.filter(s=>{if(s.secondClassCitizen)return!1;let a=s.rect,u=S.getElementFromPoint(a.left+a.width*.5,a.top+a.height*.5);if(u&&(s.element.contains(u)||u.contains(s.element))||s.element.localName=="area"&&u==s.image)return!0;let l=[a.top+.1,a.bottom-.1],c=[a.left+.1,a.right-.1];for(let d of l)for(let p of c){let g=S.getElementFromPoint(p,d);if(g&&(s.element.contains(g)||g.contains(s.element)))return!0}});i.reverse();let{top:h,left:m}=f.getViewportTopLeft();for(let s of i)s.rect.top+=h,s.rect.left+=m;return i}};var A=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}async capture(){this.reset(),this.createMarkers(),this.displayMarkers()}createMarkers(){this.hints=S.getLocalHints(),this.hintMarkers=new Map,this.hints.forEach((e,n)=>{let o=f.createElement("div"),r=e.element.attributes["data-momentic-id"]?.value??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(R.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=A;\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:`// src/html/cache-evaluation.ts
58
58
  function isEligibleForAttrRemoval(bestCandidate, attrToRemove) {
59
59
  const customWindow = window;
60
60
  if (bestCandidate.textContent?.trim()) {
@@ -419,7 +419,8 @@ function addMomenticConstantsToWindow() {
419
419
  }
420
420
  customWindow.momenticConstants = momenticConstants;
421
421
  }
422
- var BoundingBoxMovedErrorName = "ElementMovedError";
422
+ var BoundingBoxMovedErrorName = "BoundingBoxMovedError";
423
+ var ZeroOpacityErrorName = "ZeroOpacityError";
423
424
 
424
425
  // src/html/cache-generation.ts
425
426
  function generateHtmlCacheAttributes(ele, opts) {
@@ -439,6 +440,15 @@ function generateHtmlCacheAttributes(ele, opts) {
439
440
  };
440
441
  }
441
442
  }
443
+ if (opts?.disqualifyZeroOpacity) {
444
+ const computedStyleOpacity = window.getComputedStyle(ele).opacity;
445
+ if (computedStyleOpacity === "0") {
446
+ return {
447
+ error: \`\${ZeroOpacityErrorName}: Element has zero opacity, which is not allowed for interactive actions\`,
448
+ warnings: []
449
+ };
450
+ }
451
+ }
442
452
  const logTimings = {};
443
453
  const warnings = [];
444
454
  const cssStart = Date.now();
@@ -3886,53 +3896,53 @@ function registerAllMomenticListeners() {
3886
3896
 
3887
3897
  // src/html/index.ts
3888
3898
  registerAllMomenticListeners();
3889
- `};var Yn={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-overlay","data-content-editable-leaf","data-wf-icon","data-tns","data-sticky-stack-name","data-popup-origin","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"],stronglyIdentifyingAttributes:["aria-label","data-testid","id","name","href","aria-labelledby","aria-description","data-row","data-col","data-row-index","data-col-index","for","aria-labelledby","aria-modal"],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 xp="ElementMovedError";import{execSync as BM}from"child_process";import{randomUUID as bw}from"crypto";import{diff as zM}from"deep-object-diff";import{existsSync as Gl,mkdirSync as HM,readFileSync as jM,writeFileSync as $M}from"fs";import{Jimp as ww}from"jimp";import GM from"js-beautify";import{cloneDeep as vw}from"lodash-es";var mb={"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(mb);var hb=mb;var gb={"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(gb);var fb=gb;var on=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)},gi,Da,oo,Cp=class{constructor(...e){gi.set(this,new Map),Da.set(this,new Map),oo.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()),on(this,oo,"f").has(r)||on(this,oo,"f").set(r,new Set);let i=on(this,oo,"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&&on(this,Da,"f").set(r,s),a=!1,l)continue;let c=on(this,gi,"f").get(s);if(c&&c!=r&&!t)throw new Error(`"${r} -> ${s}" conflicts with "${c} -> ${s}". Pass \`force=true\` to override this definition.`);on(this,gi,"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:on(this,gi,"f").get(r)??null}getExtension(e){return typeof e!="string"?null:(e=e?.split?.(";")[0],(e&&on(this,Da,"f").get(e.trim().toLowerCase()))??null)}getAllExtensions(e){return typeof e!="string"?null:on(this,oo,"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 on(this,oo,"f").values())Object.freeze(e);return this}_getTestState(){return{types:on(this,gi,"f"),extensions:on(this,Da,"f")}}};gi=new WeakMap,Da=new WeakMap,oo=new WeakMap;var Rp=Cp;var Sb=new Rp(fb,hb)._freeze();import{homedir as Jp,hostname as WM,platform as VM}from"os";import{basename as qM,extname as KM,join as yi,resolve as YM}from"path";import{chromium as Ew,devices as JM}from"playwright";import{addExtra as XM}from"playwright-extra";import QM from"puppeteer-extra-plugin-recaptcha";import{v4 as ZM}from"uuid";import{rmSync as iw}from"fs";import{basename as uM,join as mM}from"path";import{errors as hM}from"playwright-core";var mO=new Set(["b","c","d","f","g","h","j","k","l","m","n","p","q","r","s","t","v","w","x","y","z"]),hO=new Set(["a","e","i","o","u","y"]);function yb(n){if(n.length>75)return!1;if(n.match(/^[0-9]+$/))return n.length>4;if(n[0]?.match(/[0-9a-zA-Z]/)===null)return!0;if(n.length>10){let u=Math.floor(n.length/8);if((n.match(/[-_:A-Z/ ]/g)??[]).length<u)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 u of n.toLowerCase())mO.has(u)?(a++,a>i&&(i=a)):a=0;if(i>4)return!0;let s=0,l=0;for(let u of n.toLowerCase())u>="a"&&u<="z"&&!hO.has(u)?(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 bb(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(`
3899
+ `};var Yn={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-overlay","data-content-editable-leaf","data-wf-icon","data-tns","data-sticky-stack-name","data-popup-origin","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"],stronglyIdentifyingAttributes:["aria-label","data-testid","id","name","href","aria-labelledby","aria-description","data-row","data-col","data-row-index","data-col-index","for","aria-labelledby","aria-modal"],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 hb="BoundingBoxMovedError",gb="ZeroOpacityError";import{execSync as jM}from"child_process";import{randomUUID as Ew}from"crypto";import{diff as $M}from"deep-object-diff";import{existsSync as Vl,mkdirSync as GM,readFileSync as WM,writeFileSync as VM}from"fs";import{Jimp as Tw}from"jimp";import qM from"js-beautify";import{cloneDeep as xw}from"lodash-es";var fb={"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(fb);var Sb=fb;var yb={"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(yb);var bb=yb;var on=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)},gi,Da,oo,Rp=class{constructor(...e){gi.set(this,new Map),Da.set(this,new Map),oo.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()),on(this,oo,"f").has(r)||on(this,oo,"f").set(r,new Set);let i=on(this,oo,"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&&on(this,Da,"f").set(r,s),a=!1,l)continue;let c=on(this,gi,"f").get(s);if(c&&c!=r&&!t)throw new Error(`"${r} -> ${s}" conflicts with "${c} -> ${s}". Pass \`force=true\` to override this definition.`);on(this,gi,"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:on(this,gi,"f").get(r)??null}getExtension(e){return typeof e!="string"?null:(e=e?.split?.(";")[0],(e&&on(this,Da,"f").get(e.trim().toLowerCase()))??null)}getAllExtensions(e){return typeof e!="string"?null:on(this,oo,"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 on(this,oo,"f").values())Object.freeze(e);return this}_getTestState(){return{types:on(this,gi,"f"),extensions:on(this,Da,"f")}}};gi=new WeakMap,Da=new WeakMap,oo=new WeakMap;var Ap=Rp;var wb=new Ap(bb,Sb)._freeze();import{homedir as Xp,hostname as KM,platform as YM}from"os";import{basename as JM,extname as XM,join as yi,resolve as ZM}from"path";import{chromium as Rw,devices as QM}from"playwright";import{addExtra as eN}from"playwright-extra";import tN from"puppeteer-extra-plugin-recaptcha";import{v4 as nN}from"uuid";import{rmSync as lw}from"fs";import{basename as gM,join as fM}from"path";import{errors as SM}from"playwright-core";var fO=new Set(["b","c","d","f","g","h","j","k","l","m","n","p","q","r","s","t","v","w","x","y","z"]),SO=new Set(["a","e","i","o","u","y"]);function vb(n){if(n.length>75)return!1;if(n.match(/^[0-9]+$/))return n.length>4;if(n[0]?.match(/[0-9a-zA-Z]/)===null)return!0;if(n.length>10){let u=Math.floor(n.length/8);if((n.match(/[-_:A-Z/ ]/g)??[]).length<u)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 u of n.toLowerCase())fO.has(u)?(a++,a>i&&(i=a)):a=0;if(i>4)return!0;let s=0,l=0;for(let u of n.toLowerCase())u>="a"&&u<="z"&&!SO.has(u)?(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 Eb(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(`
3890
3900
  `,o);a>0&&a<r&&(o=a);let s=i,l=0;for(;l<1e3&&s>r&&n[s]!==`
3891
3901
  `;)l++,s--;return s>r&&n[s]===`
3892
- `&&(i=s),n.slice(o,i)}import{randomUUID as xO}from"crypto";import{cloneDeep as Op}from"lodash-es";import{randomUUID as wO}from"crypto";var wb=new Set(["about:blank","chrome-error://chromewebdata/"]);var an="data-momentic-id";var Ap=["button","image","generic","graphics-symbol","tab","link","menuitem","group"],Ip=1e4,Fa=500;function wr(n,e){let t=n.findIndex(r=>r===e);if(!(t===-1||!n[t+1]))return n[t+1]}import{createHash as gO}from"crypto";var fO="v1";function kl(n,e){if(n.tagName.toLowerCase()==="svg"&&!yO(n))try{let t=vb(n,e),r=SO(JSON.stringify(t));return{version:fO,json:t,hash:r}}catch{return}}function SO(n){return gO("md5").update(n).digest("hex")}function vb(n,e){let t=n.tagName.toLowerCase(),r=bO(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=vb(a,e);s&&o.children.push(s)}}return o}function yO(n){let e=n.computedStyles.display,t=n.computedStyles.visibility,r=n.computedStyles.opacity;return e==="none"||t==="hidden"||r==="0"}function bO(n){let e={},t=n.attributes;for(let r of Object.keys(t))Yn.visualAttributesForSvgSerialization.includes(r)&&(e[r]=t[r]);return t.id&&n.tagName.toLowerCase()!=="svg"&&(e.id=t.id),e}var io={r:147,g:196,b:125,a:.55},xb={showRulers:!1,showStyles:!1,showExtensionLines:!1,contrastAlgorithm:"aa",contentColor:io,paddingColor:io,borderColor:io,marginColor:io,eventTargetColor:io,shapeColor:io,shapeMarginColor:io,showInfo:!0,showAccessibilityInfo:!0},_l=["display","opacity","visibility","height","position"];function Cb({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=vO({allDocuments:o,stringConstants:r,frameIndex:c,devicePixelRatio:e,backendIdToNode:i,frameIndexToIframeNode:a,logger:t});s.roots.push(d)}),s}function vO({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((x,A)=>{c[x]=A});let d=l.styles,p=l.bounds??[],u=s.nodes,m=u.contentDocumentIndex??{index:[],value:[]},h=u.backendNodeId??[],g=u.attributes??[],f=u.parentIndex??[],S=u.nodeName??[],w=u.nodeType??[],T=u.pseudoType??{index:[],value:[]},y=u.inputChecked??{index:[]},E=e[s.frameId];for(let x=0;x<h.length;x++){let A=h[x],k=w[x],L=g[x]??[],W=f[x]!==void 0&&f[x]>=0?f[x]:void 0,q=W!==void 0?h[W]:void 0,M=q!==void 0?i[q]:void 0,D=T.index.indexOf(x),O=D!==-1?e[T.value[D]]:void 0,Y=c[x],U;Y?U=p[Y]??[]:U=[];let re=S[x]!==void 0?e[S[x]]?.toLowerCase():void 0;if(!re){a.warn({backendNodeId:A,frameId:E,frameIndex:r,nodeBounds:U},"DOM node has no tag name");continue}let oe={backendNodeId:A,psuedoType:O,nodeType:k,frameIndex:r,parentFrameId:E,ownedFrameId:void 0,bounds:{x:U[0]??null,y:U[1]??null,width:U[2]??null,height:U[3]??null},computedStyles:{},attributes:{},parentBackendNodeId:q??null,tagName:re,parent:M??void 0,childrenBackendIds:[],momenticIgnored:void 0,mPathSelector:void 0};M&&M.childrenBackendIds.push(A);let de=m.index.indexOf(x);if(de!==-1){let De=m.value[de];o[De]=oe;let pe=n[De]?.frameId;oe.ownedFrameId=pe!==void 0?e[pe]:void 0}for(let De of Object.keys(oe.bounds)){let pe=De;oe.bounds[pe]!==null&&(oe.bounds[pe]/=t)}let K=Y!==void 0?d[Y]??[]:[];for(let De=0;De<K.length&&!(De>=_l.length);De++){let pe=K[De];if(pe===void 0||isNaN(pe))continue;let At=e[pe];if(At===void 0)continue;let wt=_l[De];oe.computedStyles[wt]=At}for(let De=0;De<L.length;De+=2){let pe=L[De],At=L[De+1];if(!pe||!At)continue;let wt=e[pe],Tn=e[At];!wt||!Tn||(oe.attributes[wt]=Tn)}y.index.includes(x)&&(oe.attributes.checked="true"),i[oe.backendNodeId]=oe}return i[h[0]]}function Lp(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=`${Lp(t,e)}${a}`}return n.mPathSelector=r,r}function Tb({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,u=p.width??0,m=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-u)<200||Math.abs(s-m)<200?!0:($r({logger:r,logKey:t,maxCount:5,intervalMs:3e3},{candidate:e,originalNode:n},"Filtering out click candidate since it has a significantly different area"),!1):($r({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 Rb(n,e,t){let r=Object.values(e.backendIdToNode),o,i=wO();for(let c of r)if(c.attributes?.[an]===n){o=c;break}if(!o)return[];let a=[],s=e.backendIdToNode[o.parentBackendNodeId??-1];for(;s&&(s?.momenticIgnored||!Tb({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&&Tb({originalNode:o,candidate:p,logKey:i,logger:t})?a.push(p):p&&l.push(p)}}return a}function Eb(n,e){return n.parentBackendNodeId!==null?e.backendIdToNode[n.parentBackendNodeId]:n.frameIndex===0?void 0:e.frameIndexToIframeNode[n.frameIndex]}var TO=["html","#document","#document-fragment"];function Ab({node:n,domGraph:e}){let t=[],r=n,o=Eb(n,e);if(!o)return[n.tagName];let i=()=>{if(r=o,o=Eb(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++,TO.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],u=e.backendIdToNode[p];if(p===r.backendNodeId){t.push(`${r.tagName}:nth-child(${c})`),l=!0;break}else u?.nodeType===1&&!u.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 Ib(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 Pb(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=wr(o,an);if(!i)throw new Error(`Could not find attribute ${an} for object ${e}`);return i}function Lb(n){let e=[];for(let t=0;t<n.domGraph.roots.length;t++){let r=n.domGraph.roots[t],o=EO({root:r,domGraph:n.domGraph,existingHashes:n.existingHashes,flagStore:n.flagStore,logger:n.logger});e=e.concat(o)}return e}function EO(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=kl(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 CO=["focusable","keyshortcuts","controls","live","relevant","orientation"],RO=["selected","readonly","modal","required","invalid"],AO=["id","name","role","content"],Ob=["absolute","fixed","sticky"],IO=["path"],PO=["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"],kb=["ariaHiddenElement","ariaHiddenSubtree","hiddenByChildTree","inertElement","inertSubtree","notRendered","notVisible"],_b=["activeAriaModalDialog","activeFullscreenElement","activeModalDialog"],LO=["menulistpopup","statictext","inlinetextbox"],OO=80,Mb=100,Dl=["StaticText","ListMarker","RootWebArea","LineBreak","emphasis","::before","::after"],MO=["cite"],NO={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"]},kO={name:!0,value:!0,title:!0,alt:!0,placeholder:!0,checked:!0,selected:!0,contenteditable:!0},Nb={indentLevel:0},Mp=class n{id;role;name;nameSources;tagName;content;properties;internalProperties;ignoredReasons;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,this.ignoredReasons=e.ignoredReasons,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&&!yb(t)?t:""),this.role=this.role||(e.domNode.attributes.role??""),UO(this.properties,e.domNode)}zO(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&&IO.includes(this.domNode.tagName))return!1;if(PO.includes(this.role.toLowerCase()))return!0;if(this.domNode?.computedStyles.display==="contents"||this.ignoredReasons.some(t=>_b.includes(t)))return!1;if(this.role.toLowerCase()==="inlinetextbox"&&this.tagName||!this.properties.hidden&&(this.properties.focusable||this.properties.settable)||Yn.alwaysInterestingTruthyPropertyNames.some(t=>!!this.properties[t]))return!0;let e=this.properties.class;return typeof e=="string"&&e.split(" ").some(t=>Bb(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=Nb){let t=Object.assign({},Nb,e),{indentLevel:r,noChildren:o,noProperties:i,noId:a,noContent:s,condensedMode:l}=t,c=Op(this.properties),d=" ".repeat(r),p=this.role||"",u=this.tagName??"unknown",m=this.name;p==="heading"&&m==="heading"&&(m=""),this.nameSources?.find(E=>!E.superseded&&E.type==="contents")&&this.children.length>0&&(m="");let g=this.nameSources?.find(E=>!E.superseded);if(g&&!g.nativeSource&&g.type==="relatedElement"){let E=g.attributeValue?.relatedNodes??[];E.length===1&&E[0].text&&E[0].text===m&&(m="")}let f=Dl.includes(this.role)||MO.includes(this.tagName||"");if(this.role==="StaticText"||this.role==="ListMarker")return`${d}${m}
3893
- `;let S=`${d}<${u}`;!a&&!f&&(S+=` id="${this.id}"`);let w=s??!1;(c.multiline||c.contenteditable)&&this.children.length>0&&(w=!0),p&&p!=="generic"&&p!==u&&!(NO[p]??[]).includes(u)&&(S+=` role=${JSON.stringify(p)}`),m&&(S+=` name=${JSON.stringify(m)}`),this.content&&!w&&(S+=` content=${JSON.stringify(this.content)}`);let T=Date.now();if(Object.keys(c).length>0&&!i){if(Date.now()-T>1e3)throw new Error(`Serialization for the HTML element with tag ${u} and internal ID ${this.id} took too long. Please ensure your machine has enough resources to run Momentic.`);Object.entries(c).forEach(([E,x])=>{if(!CO.includes(E)){{if(RO.includes(E)&&(!x||x==="false"))return;if(E==="value"&&w&&(c.type==="text"||this.role==="textbox"))return;if(E==="level"&&`${x}`=="1")return;if(E==="url"&&c.src&&u==="img")return;if(E==="url"&&c.href&&u==="a")return;if(E==="editable"&&x==="plaintext")return;if(E==="type"&&x===u)return;if(l&&!kO[E])return}typeof x=="string"?S+=` ${E}="${je(x,Mb,!0)}"`:typeof x=="boolean"?x?S+=` ${E}`:S+=` ${E}={false}`:typeof x<"u"&&(S+=` ${E}={${je(JSON.stringify(x),Mb,!0)}}`)}})}if(u==="::before"||u==="::after"){let E="";for(let x of this.children)E+=x.serialize({...e,indentLevel:r,neighbors:0});return E}let y=e.maxLevel!==void 0&&r/2>=e.maxLevel;if(this.children.length===0||o||y)S+=` />
3894
- `;else{let E="";for(let A of this.children)E+=A.serialize({...e,indentLevel:r+2,neighbors:0});let x=E.trim();x.length<=OO&&!x.includes(`
3895
- `)?S+=`>${x}</${u}>
3902
+ `&&(i=s),n.slice(o,i)}import{randomUUID as AO}from"crypto";import{cloneDeep as Mp}from"lodash-es";import{randomUUID as TO}from"crypto";var Tb=new Set(["about:blank","chrome-error://chromewebdata/"]);var an="data-momentic-id";var Ip=["button","image","generic","graphics-symbol","tab","link","menuitem","group"],Pp=1e4,Fa=500;function vr(n,e){let t=n.findIndex(r=>r===e);if(!(t===-1||!n[t+1]))return n[t+1]}import{createHash as yO}from"crypto";var bO="v1";function Dl(n,e){if(n.tagName.toLowerCase()==="svg"&&!vO(n))try{let t=xb(n,e),r=wO(JSON.stringify(t));return{version:bO,json:t,hash:r}}catch{return}}function wO(n){return yO("md5").update(n).digest("hex")}function xb(n,e){let t=n.tagName.toLowerCase(),r=EO(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=xb(a,e);s&&o.children.push(s)}}return o}function vO(n){let e=n.computedStyles.display,t=n.computedStyles.visibility,r=n.computedStyles.opacity;return e==="none"||t==="hidden"||r==="0"}function EO(n){let e={},t=n.attributes;for(let r of Object.keys(t))Yn.visualAttributesForSvgSerialization.includes(r)&&(e[r]=t[r]);return t.id&&n.tagName.toLowerCase()!=="svg"&&(e.id=t.id),e}var io={r:147,g:196,b:125,a:.55},Ab={showRulers:!1,showStyles:!1,showExtensionLines:!1,contrastAlgorithm:"aa",contentColor:io,paddingColor:io,borderColor:io,marginColor:io,eventTargetColor:io,shapeColor:io,shapeMarginColor:io,showInfo:!0,showAccessibilityInfo:!0},Fl=["display","opacity","visibility","height","position"];function Ib({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=xO({allDocuments:o,stringConstants:r,frameIndex:c,devicePixelRatio:e,backendIdToNode:i,frameIndexToIframeNode:a,logger:t});s.roots.push(d)}),s}function xO({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((T,A)=>{c[T]=A});let d=l.styles,p=l.bounds??[],u=s.nodes,m=u.contentDocumentIndex??{index:[],value:[]},h=u.backendNodeId??[],g=u.attributes??[],f=u.parentIndex??[],S=u.nodeName??[],w=u.nodeType??[],E=u.pseudoType??{index:[],value:[]},y=u.inputChecked??{index:[]},x=e[s.frameId];for(let T=0;T<h.length;T++){let A=h[T],D=w[T],L=g[T]??[],j=f[T]!==void 0&&f[T]>=0?f[T]:void 0,V=j!==void 0?h[j]:void 0,k=V!==void 0?i[V]:void 0,N=E.index.indexOf(T),O=N!==-1?e[E.value[N]]:void 0,q=c[T],F;q?F=p[q]??[]:F=[];let ie=S[T]!==void 0?e[S[T]]?.toLowerCase():void 0;if(!ie){a.warn({backendNodeId:A,frameId:x,frameIndex:r,nodeBounds:F},"DOM node has no tag name");continue}let oe={backendNodeId:A,psuedoType:O,nodeType:D,frameIndex:r,parentFrameId:x,ownedFrameId:void 0,bounds:{x:F[0]??null,y:F[1]??null,width:F[2]??null,height:F[3]??null},computedStyles:{},attributes:{},parentBackendNodeId:V??null,tagName:ie,parent:k??void 0,childrenBackendIds:[],momenticIgnored:void 0,mPathSelector:void 0};k&&k.childrenBackendIds.push(A);let pe=m.index.indexOf(T);if(pe!==-1){let De=m.value[pe];o[De]=oe;let ue=n[De]?.frameId;oe.ownedFrameId=ue!==void 0?e[ue]:void 0}for(let De of Object.keys(oe.bounds)){let ue=De;oe.bounds[ue]!==null&&(oe.bounds[ue]/=t)}let K=q!==void 0?d[q]??[]:[];for(let De=0;De<K.length&&!(De>=Fl.length);De++){let ue=K[De];if(ue===void 0||isNaN(ue))continue;let At=e[ue];if(At===void 0)continue;let wt=Fl[De];oe.computedStyles[wt]=At}for(let De=0;De<L.length;De+=2){let ue=L[De],At=L[De+1];if(!ue||!At)continue;let wt=e[ue],En=e[At];!wt||!En||(oe.attributes[wt]=En)}y.index.includes(T)&&(oe.attributes.checked="true"),i[oe.backendNodeId]=oe}return i[h[0]]}function Op(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=`${Op(t,e)}${a}`}return n.mPathSelector=r,r}function Cb({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,u=p.width??0,m=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-u)<200||Math.abs(s-m)<200?!0:($r({logger:r,logKey:t,maxCount:5,intervalMs:3e3},{candidate:e,originalNode:n},"Filtering out click candidate since it has a significantly different area"),!1):($r({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 Pb(n,e,t){let r=Object.values(e.backendIdToNode),o,i=TO();for(let c of r)if(c.attributes?.[an]===n){o=c;break}if(!o)return[];let a=[],s=e.backendIdToNode[o.parentBackendNodeId??-1];for(;s&&(s?.momenticIgnored||!Cb({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&&Cb({originalNode:o,candidate:p,logKey:i,logger:t})?a.push(p):p&&l.push(p)}}return a}function Rb(n,e){return n.parentBackendNodeId!==null?e.backendIdToNode[n.parentBackendNodeId]:n.frameIndex===0?void 0:e.frameIndexToIframeNode[n.frameIndex]}var CO=["html","#document","#document-fragment"];function Lb({node:n,domGraph:e}){let t=[],r=n,o=Rb(n,e);if(!o)return[n.tagName];let i=()=>{if(r=o,o=Rb(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++,CO.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],u=e.backendIdToNode[p];if(p===r.backendNodeId){t.push(`${r.tagName}:nth-child(${c})`),l=!0;break}else u?.nodeType===1&&!u.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 Ob(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 Mb(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=vr(o,an);if(!i)throw new Error(`Could not find attribute ${an} for object ${e}`);return i}function Nb(n){let e=[];for(let t=0;t<n.domGraph.roots.length;t++){let r=n.domGraph.roots[t],o=RO({root:r,domGraph:n.domGraph,existingHashes:n.existingHashes,flagStore:n.flagStore,logger:n.logger});e=e.concat(o)}return e}function RO(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=Dl(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 IO=["focusable","keyshortcuts","controls","live","relevant","orientation"],PO=["selected","readonly","modal","required","invalid"],LO=["id","name","role","content"],kb=["absolute","fixed","sticky"],OO=["path"],MO=["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"],Fb=["ariaHiddenElement","ariaHiddenSubtree","hiddenByChildTree","inertElement","inertSubtree","notRendered","notVisible"],Ub=["activeAriaModalDialog","activeFullscreenElement","activeModalDialog"],NO=["menulistpopup","statictext","inlinetextbox"],kO=80,_b=100,Ul=["StaticText","ListMarker","RootWebArea","LineBreak","emphasis","::before","::after"],_O=["cite"],DO={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"]},FO={name:!0,value:!0,title:!0,alt:!0,placeholder:!0,checked:!0,selected:!0,contenteditable:!0},Db={indentLevel:0},Np=class n{id;role;name;nameSources;tagName;content;properties;internalProperties;ignoredReasons;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,this.ignoredReasons=e.ignoredReasons,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&&!vb(t)?t:""),this.role=this.role||(e.domNode.attributes.role??""),HO(this.properties,e.domNode)}$O(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&&OO.includes(this.domNode.tagName))return!1;if(MO.includes(this.role.toLowerCase()))return!0;if(this.domNode?.computedStyles.display==="contents"||this.ignoredReasons.some(t=>Ub.includes(t)))return!1;if(this.role.toLowerCase()==="inlinetextbox"&&this.tagName||!this.properties.hidden&&(this.properties.focusable||this.properties.settable)||Yn.alwaysInterestingTruthyPropertyNames.some(t=>!!this.properties[t]))return!0;let e=this.properties.class;return typeof e=="string"&&e.split(" ").some(t=>jb(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=Db){let t=Object.assign({},Db,e),{indentLevel:r,noChildren:o,noProperties:i,noId:a,noContent:s,condensedMode:l}=t,c=Mp(this.properties),d=" ".repeat(r),p=this.role||"",u=this.tagName??"unknown",m=this.name;p==="heading"&&m==="heading"&&(m=""),this.nameSources?.find(x=>!x.superseded&&x.type==="contents")&&this.children.length>0&&(m="");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===m&&(m="")}let f=Ul.includes(this.role)||_O.includes(this.tagName||"");if(this.role==="StaticText"||this.role==="ListMarker")return`${d}${m}
3903
+ `;let S=`${d}<${u}`;!a&&!f&&(S+=` id="${this.id}"`);let w=s??!1;(c.multiline||c.contenteditable)&&this.children.length>0&&(w=!0),p&&p!=="generic"&&p!==u&&!(DO[p]??[]).includes(u)&&(S+=` role=${JSON.stringify(p)}`),m&&(S+=` name=${JSON.stringify(m)}`),this.content&&!w&&(S+=` content=${JSON.stringify(this.content)}`);let E=Date.now();if(Object.keys(c).length>0&&!i){if(Date.now()-E>1e3)throw new Error(`Serialization for the HTML element with tag ${u} and internal ID ${this.id} took too long. Please ensure your machine has enough resources to run Momentic.`);Object.entries(c).forEach(([x,T])=>{if(!IO.includes(x)){{if(PO.includes(x)&&(!T||T==="false"))return;if(x==="value"&&w&&(c.type==="text"||this.role==="textbox"))return;if(x==="level"&&`${T}`=="1")return;if(x==="url"&&c.src&&u==="img")return;if(x==="url"&&c.href&&u==="a")return;if(x==="editable"&&T==="plaintext")return;if(x==="type"&&T===u)return;if(l&&!FO[x])return}typeof T=="string"?S+=` ${x}="${je(T,_b,!0)}"`:typeof T=="boolean"?T?S+=` ${x}`:S+=` ${x}={false}`:typeof T<"u"&&(S+=` ${x}={${je(JSON.stringify(T),_b,!0)}}`)}})}if(u==="::before"||u==="::after"){let x="";for(let T of this.children)x+=T.serialize({...e,indentLevel:r,neighbors:0});return x}let y=e.maxLevel!==void 0&&r/2>=e.maxLevel;if(this.children.length===0||o||y)S+=` />
3904
+ `;else{let x="";for(let A of this.children)x+=A.serialize({...e,indentLevel:r+2,neighbors:0});let T=x.trim();T.length<=kO&&!T.includes(`
3905
+ `)?S+=`>${T}</${u}>
3896
3906
  `:S+=`>
3897
- ${E}${d}</${u}>
3898
- `}if(e.neighbors!==void 0&&e.neighbors>0&&this.parent){let E=this.parent.children.findIndex(k=>k.id===this.id),x=E>0?this.parent.children[E-1]?.serialize({...e,neighbors:0}):"",A=E<this.parent.children.length-1?this.parent.children[E+1]?.serialize({...e,neighbors:0}):"";return`${x||""}
3907
+ ${x}${d}</${u}>
3908
+ `}if(e.neighbors!==void 0&&e.neighbors>0&&this.parent){let x=this.parent.children.findIndex(D=>D.id===this.id),T=x>0?this.parent.children[x-1]?.serialize({...e,neighbors:0}):"",A=x<this.parent.children.length-1?this.parent.children[x+1]?.serialize({...e,neighbors:0}):"";return`${T||""}
3899
3909
  ${S}
3900
- ${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:[],ignoredReasons:this.ignoredReasons,backendNodeID:this.backendNodeId,ignoredByCDP:this.ignoredByCDP,internalProperties:Op(this.internalProperties),parentFrame:this.parentFrame});return e.tagName=this.tagName,e.dataMomenticId=this.dataMomenticId,e.properties=Op(this.properties),e}},Np=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 u of c){let m=r(u,s||d);m&&(p.push(m),m.parent=l,d=!0)}if(l.children=p,s||d)return l;if(Dl.includes(i.role)&&a)return l}let o=r(t);return new n(o,this.a11yIdNodeMap,this.dataMomenticIdMap,this.selectorToNodeMap)}};function _O(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 DO(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?($r({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?($r({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 Db({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:u,callId:m}){if(!e&&n.parentId)throw new Error(`Got no parent for accessibility node ${n.nodeId}: ${JSON.stringify(n)}`);let h=(M,D={})=>{},g=n.backendDOMNodeId,f=LO.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 M=await B(p.send({method:"DOM.describeNode",params:{backendNodeId:g}}),{milliseconds:750,fallback:()=>{u.debug("Timeout getting node from CDP while processing a11y tree")}});if(M&&M.node.nodeName.toLowerCase()==="slot"&&M.node.distributedNodes?.length)u.debug({redirectedDomNode:S,parentAXNode:e?.getNodeOnlySerializedForm(),originalAXNode:n,cdpResult:M},"Redirecting node to assigned slot");else return h("Filtering out node since it doesn't exist in the DOM",{cdpResult:M}),[]}catch(M){return h("Filtering out node since it doesn't exist in the DOM",{err:M}),[]}if(S&&e&&l&&c&&n.backendDOMNodeId&&!DO(S,c,u,m))return S.momenticIgnored=!0,[];if(S&&S.computedStyles.display==="none")return u.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 $r({logger:u,logKey:m,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 w=n.name?.value?typeof n.name.value=="string"?n.name.value:`${n.name.value}`:"",T=n.value?.value?typeof n.value.value=="string"?n.value.value:`${n.value.value}`:"",y=new Mp({domNode:S,id:parseInt(n.nodeId),role:n.role?.value||"",name:w,nameSources:n.name?.sources,content:T,properties:n.properties,children:[],ignoredReasons:n.ignoredReasons?.filter(M=>kb.includes(M.name)||_b.includes(M.name))??[],pathFromRoot:(e?`${e.pathFromRoot} `:"")+_O(n),backendNodeID:n.backendDOMNodeId,ignoredByCDP:n.ignored,internalProperties:{inCodeMirrorEditor:e?.internalProperties?.inCodeMirrorEditor},parentFrame:r.type==="root"?void 0:r}),E=r,x=a[t],A=t;if(S?.tagName.toLowerCase()==="iframe"&&S.ownedFrameId){let M=r.childFrames.find(Y=>Y.frameId===S.ownedFrameId),D=o[M?.frameId??""]?.root,O=a[M?.frameId??""];if(M&&D&&O){n.childIds&&n.childIds.length>0&&u.debug("Replacing existing node's children with children from the iframe");let Y=D;n.childIds=Y.childIds,E=M,x=O,A=M.frameId}}let k=S?.childrenBackendIds?.length??0,L=n.childIds?.length??0;if(k>L){let M=n.childIds?.map(O=>x.get(parseInt(O))).filter(Boolean).map(O=>O?.backendDOMNodeId).filter(O=>O!==void 0)??[],D=0;for(let O of S?.childrenBackendIds??[]){if(M.includes(O)){D=(n.childIds?.findIndex(de=>x.get(parseInt(de))?.backendDOMNodeId===O)??0)+1;continue}let Y=i.backendIdToNode[O];if(!Y||Y?.tagName.toLowerCase()!=="svg")continue;let U=Math.floor(-1*Math.random()*1e7),re={nodeId:U.toString(),parentId:n.nodeId,ignored:!1,backendDOMNodeId:O,frameId:A,role:{type:"string",value:"graphics-symbol"}};x.set(U,re),n.childIds||(n.childIds=[]),n.childIds.splice(D,0,U.toString()),D++}}for(let M of n.childIds??[]){if(!M)continue;let D=x.get(parseInt(M));if(!D)continue;let O=await Db({node:D,parent:y,domGraph:i,axGraph:o,frameId:A,frameContext:E,inputNodeMap:a,cdpClient:p,logger:u,callId:m,filterByViewport:l,showZeroOpacityElements:s,viewportDetails:c,useMPaths:d});O.length&&(y.children=y.children.concat(O))}if(y.role==="StaticText"&&(y.children=[]),y.children.length===1&&y.children[0].role==="StaticText"){let M=y.name,D=y.children[0]?.name;(M===D||!D)&&(y.children=[])}let W=[];for(let M=y.children.length-1;M>=0;M--){let D=y.children[M];if(D.role!=="StaticText"){W.push(D);continue}if(M===0||y.children[M-1].role!=="StaticText"){W.push(D);continue}y.children[M-1].name+=D.name}if(y.children=W.reverse(),y.role==="generic"&&y.children.length===1){let M=y.children[0];if(y.name&&!Dl.includes(M.role)&&y.name===M.name)return S&&(S.momenticIgnored=!0),y.children}if(!y.isInteresting()&&n.parentId)return S&&(S.momenticIgnored=!0),y.children;for(let M of y.children)M.parent=y;return BO(y),S&&d&&Lp(S,i),[y]}function Fb({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:Dl.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 u=kl(p,i),m=u?l[u.hash]:void 0,h=m?m.description:void 0;m&&(n.properties["data-momentic-description"]=h)}for(let u of n.children)c=Fb({node:u,a11yIdNodeMap:e,dataMomenticIdMap:t,logger:r,callId:o,startId:c,useMPaths:a,domGraph:i,selectorToNodeMap:s,iconKnowledgeBase:l});return c}async function Ub({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",u=n[p]?.root;if(!u)throw new Error("A11y tree has no root");let m=xO(),h=y=>{let E=y.allNodes.filter(A=>!A.ignoredReasons?.find(L=>kb.includes(L.name))),x=new Map;return E.forEach(A=>{x.set(parseInt(A.nodeId),A)}),x},g={};Object.entries(n).forEach(([y,E])=>{g[y]=h(E)});let f=await Db({node:u,domGraph:e,parent:null,inputNodeMap:g,axGraph:n,frameId:p,frameContext:c,cdpClient:o,logger:r,callId:m,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={},w={},T={};return Fb({node:f[0],a11yIdNodeMap:S,dataMomenticIdMap:w,selectorToNodeMap:T,domGraph:e,logger:r,callId:m,useMPaths:l,iconKnowledgeBase:d}),new Np(f[0],S,w,T)}function FO(n,e,t){if(n==="class"){if(t.tagName?.toLowerCase()==="svg")return e.split(" ").filter(i=>i.length<50&&!Yn.bannedClassSubstrings.some(a=>i.includes(a))).slice(0,3).join(" ");let r=e.split(" "),o=[];for(let i of r)if(Bb(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 UO(n,e){if(!e)return;Object.entries(e.attributes).forEach(([i,a])=>{if(Yn.relevantElementAttributes.includes(i)&&!AO.includes(i)&&!n[i]&&!i.startsWith("aria")){let s=FO(i,a,e);s!==null&&(n[i]=s)}});let t,r=[];if(e.computedStyles.position&&Ob.includes(e.computedStyles.position))t=e.computedStyles.position;else if(e.attributes.style){for(let i of Ob)if(e.attributes.style.includes(`position: ${i}`)){t=i;break}}t&&r.push(`position: ${t}`);let o;e.computedStyles.opacity&&e.computedStyles.opacity==="0"&&(o="opacity: 0"),o&&r.push(o),r.length>0&&(n.style=r.join("; "))}function BO(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(je(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 m=d.children.filter(h=>h.tagName==="th");if(m.length){if(i=m.map(h=>je(h.name,100,!1)),i.length===m.length)continue;i=void 0}}s+=1,d.properties["row-index"]||(d.properties["row-index"]=s);let p=d.children.filter(m=>m.tagName==="td"||m.tagName==="th"),u=p.length===i?.length;p.forEach((m,h)=>{m.tagName!=="th"&&(m.properties["col-index"]||(m.properties["col-index"]=h+1),u&&(m.properties.col||(m.properties.col=i[h])))})}}}function zO(n){let e=n.properties.class,t=typeof e=="string"&&e.includes("cm-content");n.internalProperties.inCodeMirrorEditor=n.internalProperties?.inCodeMirrorEditor||t}function Bb(n){if(Yn.bannedClassSubstrings.some(e=>n.includes(e)))return!1;if(Yn.alwaysInterestingClassNames.includes(n))return!0;for(let e of Yn.alwaysInterestingClassPrefixes)if(n.startsWith(e))return!0;return!1}var Fl=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 B(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 Z(500),l=p}if(!s)throw l;let c=new n(s,e,t,r,o);try{await B(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(`[${new Date(Date.now()).toLocaleString("en-US",{timeZone:"America/Los_Angeles"})}] Frame requested navigation: ${JSON.stringify(t)}`)}),e.on("Page.navigatedWithinDocument",t=>{this.loadEventLogs.push(`[${new Date(Date.now()).toLocaleString("en-US",{timeZone:"America/Los_Angeles"})}] Navigated within document: ${JSON.stringify(t)}`)}),e.on("Page.lifecycleEvent",t=>{this.loadEventLogs.push(`[${new Date(Date.now()).toLocaleString("en-US",{timeZone:"America/Los_Angeles"})}] Page lifecycle event: ${JSON.stringify(t)}`)}),e.on("Page.loadEventFired",()=>{this.loadEventLogs.push(`[${new Date(Date.now()).toLocaleString("en-US",{timeZone:"America/Los_Angeles"})}] 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 B(this.cdpInitializingPromise,{milliseconds:r});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 B(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 B(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 B(this.registerHandlers(this.session),{milliseconds:e,message:`Failed to register CDP handlers within ${e}ms`}),this.logger.debug("Successfully reinitialized and attached new handlers to CDP session");try{await B(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 HO,rmSync as zb,statSync as jO}from"fs";import*as Dp from"node:fs";import $O from"nodejs-file-downloader";import{tmpdir as GO}from"os";import vr,{basename as WO,dirname as VO}from"path";var Fp="file://",_p=vr.join(GO(),"momentic","downloads"),kp=1e4,qO=50*1024*1024;async function Hb(n){let{uri:e}=n;return e.startsWith(Fp)?YO(n):e.startsWith("http")?XO(n):JO(n)}function KO(n,e){let t=vr.join(_p,n,e.slice(Fp.length)),r=vr.join(_p,n),o=t.startsWith(r);if(!Dp.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 YO({uri:n,orgId:e}){let t=KO(e,n);return{filePath:t,cleanup:()=>{zb(VO(t),{recursive:!0,force:!0})}}}async function JO({uri:n}){let e=vr.resolve(n);if(!Dp.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 XO({uri:n,logger:e,orgId:t}){let r=new URL(n);r.search&&(r.search="");let o=WO(r.href),i=Bp(o),a=vr.extname(i);if(Qh.includes(a))throw new Error(`Downloading files with extension ${a} is not allowed.`);let s=Up(t),l=new $O({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:kp}),{downloadStatus:c,filePath:d}=await B(l.download(),{milliseconds:kp,message:`Download timed out after ${kp}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 u=jO(d).size;if(u>qO)throw new Error("File size exceeds the maximum limit of 50MB");e.info({fileSizeInBytes:u,filePath:d,fileName:i},"Downloaded file to disk");let m;return{filePath:d,cleanup:()=>{clearTimeout(m),m=setTimeout(()=>zb(s,{recursive:!0,force:!0}),10*60*1e3)}}}function jb(n,e){return`${Fp}${n}/${e}`}function Up(n){let e=Math.random().toString(36).substring(4),t=vr.join(_p,n,e);return HO(t,{recursive:!0}),t}function Bp(n){let e=vr.extname(n),t=vr.basename(n,e);return n=(t.length>100?t.slice(t.length-100):t)+e,n=n.trim().replaceAll(" ","_"),n}async function yn(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}}async function $b(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 B(t,{milliseconds:3e3});return o&&e.warn({err:o},"Failed to fetch indexedDB data"),r}async function Gb(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 B(r,{milliseconds:3e3})}catch(r){t.warn({err:r},"Failed to import indexedDB data")}}}async function Wb(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 B(t,{milliseconds:3e3})}catch(t){e.debug({err:t},"Failed clearing index db data, continuing...")}}async function Vb(n,e,t,r,o){try{await QO(n,e,t,r)}catch(i){o.error({err:i,tabIndex:e},"Error handling new console log")}}async function QO(n,e,t,r){let o=r.text();o.length>Fa&&(o=o.slice(0,Fa)+"...(TRUNCATED)");let i=[];for(let a of r.args())try{let s=await a.jsonValue(),l=JSON.stringify(s);l.length>Fa?i.push(l.slice(0,Fa)+"...(TRUNCATED)"):(typeof s!="object"||Object.keys(s).length>0)&&i.push(s)}catch{}zp(n,t,e,{url:n.url(),location:r.location(),type:r.type(),text:r.text(),args:i})}function zp(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>Ip&&(i[t]=i[t].slice(Math.floor(Ip/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 sn({fn:n,codePath:e,logObject:t,signal:r,logger:o}){r?.throwIfAborted();let i=Date.now(),a=await ua({promiseGenerator:n,signal:r,codePath:e,logger:o}),s=Date.now();return t[e]=s-i,a}import{randomUUID as ZO}from"crypto";var eM="[redacted due to size]",tM=1e4;async function Xb(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 Qb(n,e,t,r){try{await nM(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 ao(n){return n<0?0:n}function qb(n){return{timings:{blocked:ao(n.domainLookupStart),dns:ao(n.domainLookupEnd-n.domainLookupStart),connect:ao(n.connectEnd-n.connectStart),send:ao(n.responseStart-n.requestStart),wait:0,receive:ao(n.responseEnd-n.responseStart),ssl:ao(n.connectEnd-n.secureConnectionStart)},total:ao(n.responseEnd)}}async function nM(n,e,t){let r=ZO(),o=t.timing(),i=new URL(t.url()),a=[...i.searchParams.entries()].map(([h,g])=>({name:h,value:g})),s={...await Jb(t),url:i.toString(),method:t.method(),queryString:a,postData:await oM(t)},l={pageref:n,_resourceType:t.resourceType(),startedDateTime:new Date(o.startTime).toISOString(),request:s,timings:qb(o).timings};Kb(e,l,r);let c=await t.response();if(c){await c.finished();let h={};try{h=await iM(c)}catch{}let g={...await Jb(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:u,total:m}=qb(p);l.time=m,l.timings=u,Kb(e,l,r)}function Kb(n,e,t){n.harEntries||(n.harEntries={}),n.harEntries[t]=e}function Yb(n){try{return new Date(n).toISOString()}catch{return}}function rM(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=Nn(i),e.value=Nn(a);continue}i==="Domain"&&(e.domain=Nn(a)),i==="Expires"&&(e.expires=Yb(a)),i==="HttpOnly"&&(e.httpOnly=!0),i==="Max-Age"&&(e.expires=Yb(Date.now()+ +a*1e3)),i==="Path"&&(e.path=Nn(a)),i==="Secure"&&(e.secure=!0)}return e}async function Jb(n){let e=await n.allHeaders(),t=e.cookie?.split(";").map(rM)??[];return{headers:Object.entries(e).map(([r,o])=>({name:Nn(r),value:Nn(o)})),cookies:t}}async function oM(n){let e=n.postData();if(!e)return;let t=await n.headerValue("content-type"),r={mimeType:t??"application/octet-stream",text:Nn(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:Nn(i),value:a?Nn(a):void 0})}return r}async function iM(n){return{mimeType:await n.headerValue("content-type")??void 0,text:Nn(await n.text()),encoding:await n.headerValue("content-encoding")??void 0}}function Nn(n){return n.length>tM?eM:n}function Zb(){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 Ke({root:n,fn:e,arg:t,timeout:r,waitForPageLoad:o,codePath:i}){return await o(),await B(n.evaluate(e,t),{milliseconds:r,message:`Timed out ${i} after ${r}ms. This indicates that either the page is unresponsive or your machine is severely resource constrained.`})}function Hp(){return window.lastCursorPos}import{errors as aM}from"playwright-core";async function so({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(ia(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 aM.TimeoutError)t.warn({err:c,rootUrl:(await r.state.getRoot()).url()},`Encountered Playwright error while performing ${e}`),s=await sM(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 sM(n,e,t,r){return n.message.includes("attempt #")?lM(n,e,t,r):cM(n)}async function lM(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(`
3910
+ ${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:[],ignoredReasons:this.ignoredReasons,backendNodeID:this.backendNodeId,ignoredByCDP:this.ignoredByCDP,internalProperties:Mp(this.internalProperties),parentFrame:this.parentFrame});return e.tagName=this.tagName,e.dataMomenticId=this.dataMomenticId,e.properties=Mp(this.properties),e}},kp=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 u of c){let m=r(u,s||d);m&&(p.push(m),m.parent=l,d=!0)}if(l.children=p,s||d)return l;if(Ul.includes(i.role)&&a)return l}let o=r(t);return new n(o,this.a11yIdNodeMap,this.dataMomenticIdMap,this.selectorToNodeMap)}};function UO(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 BO(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?($r({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?($r({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 Bb({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:u,callId:m}){if(!e&&n.parentId)throw new Error(`Got no parent for accessibility node ${n.nodeId}: ${JSON.stringify(n)}`);let h=(k,N={})=>{},g=n.backendDOMNodeId,f=NO.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 k=await B(p.send({method:"DOM.describeNode",params:{backendNodeId:g}}),{milliseconds:750,fallback:()=>{u.debug("Timeout getting node from CDP while processing a11y tree")}});if(k&&k.node.nodeName.toLowerCase()==="slot"&&k.node.distributedNodes?.length)u.debug({redirectedDomNode:S,parentAXNode:e?.getNodeOnlySerializedForm(),originalAXNode:n,cdpResult:k},"Redirecting node to assigned slot");else return h("Filtering out node since it doesn't exist in the DOM",{cdpResult:k}),[]}catch(k){return h("Filtering out node since it doesn't exist in the DOM",{err:k}),[]}if(S&&e&&l&&c&&n.backendDOMNodeId&&!BO(S,c,u,m))return S.momenticIgnored=!0,[];if(S&&S.computedStyles.display==="none")return u.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 $r({logger:u,logKey:m,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 w=n.name?.value?typeof n.name.value=="string"?n.name.value:`${n.name.value}`:"",E=n.value?.value?typeof n.value.value=="string"?n.value.value:`${n.value.value}`:"",y=new Np({domNode:S,id:parseInt(n.nodeId),role:n.role?.value||"",name:w,nameSources:n.name?.sources,content:E,properties:n.properties,children:[],ignoredReasons:n.ignoredReasons?.filter(k=>Fb.includes(k.name)||Ub.includes(k.name))??[],pathFromRoot:(e?`${e.pathFromRoot} `:"")+UO(n),backendNodeID:n.backendDOMNodeId,ignoredByCDP:n.ignored,internalProperties:{inCodeMirrorEditor:e?.internalProperties?.inCodeMirrorEditor},parentFrame:r.type==="root"?void 0:r}),x=r,T=a[t],A=t;if(S?.tagName.toLowerCase()==="iframe"&&S.ownedFrameId){let k=r.childFrames.find(q=>q.frameId===S.ownedFrameId),N=o[k?.frameId??""]?.root,O=a[k?.frameId??""];if(k&&N&&O){n.childIds&&n.childIds.length>0&&u.debug("Replacing existing node's children with children from the iframe");let q=N;n.childIds=q.childIds,x=k,T=O,A=k.frameId}}let D=S?.childrenBackendIds?.length??0,L=n.childIds?.length??0;if(D>L){let k=n.childIds?.map(O=>T.get(parseInt(O))).filter(Boolean).map(O=>O?.backendDOMNodeId).filter(O=>O!==void 0)??[],N=0;for(let O of S?.childrenBackendIds??[]){if(k.includes(O)){N=(n.childIds?.findIndex(pe=>T.get(parseInt(pe))?.backendDOMNodeId===O)??0)+1;continue}let q=i.backendIdToNode[O];if(!q||q?.tagName.toLowerCase()!=="svg")continue;let F=Math.floor(-1*Math.random()*1e7),ie={nodeId:F.toString(),parentId:n.nodeId,ignored:!1,backendDOMNodeId:O,frameId:A,role:{type:"string",value:"graphics-symbol"}};T.set(F,ie),n.childIds||(n.childIds=[]),n.childIds.splice(N,0,F.toString()),N++}}for(let k of n.childIds??[]){if(!k)continue;let N=T.get(parseInt(k));if(!N)continue;let O=await Bb({node:N,parent:y,domGraph:i,axGraph:o,frameId:A,frameContext:x,inputNodeMap:a,cdpClient:p,logger:u,callId:m,filterByViewport:l,showZeroOpacityElements:s,viewportDetails:c,useMPaths:d});O.length&&(y.children=y.children.concat(O))}if(y.role==="StaticText"&&(y.children=[]),y.children.length===1&&y.children[0].role==="StaticText"){let k=y.name,N=y.children[0]?.name;(k===N||!N)&&(y.children=[])}let j=[];for(let k=y.children.length-1;k>=0;k--){let N=y.children[k];if(N.role!=="StaticText"){j.push(N);continue}if(k===0||y.children[k-1].role!=="StaticText"){j.push(N);continue}y.children[k-1].name+=N.name}if(y.children=j.reverse(),y.role==="generic"&&y.children.length===1){let k=y.children[0];if(y.name&&!Ul.includes(k.role)&&y.name===k.name)return S&&(S.momenticIgnored=!0),y.children}if(!y.isInteresting()&&n.parentId)return S&&(S.momenticIgnored=!0),y.children;for(let k of y.children)k.parent=y;return jO(y),S&&d&&Op(S,i),[y]}function zb({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:Ul.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 u=Dl(p,i),m=u?l[u.hash]:void 0,h=m?m.description:void 0;m&&(n.properties["data-momentic-description"]=h)}for(let u of n.children)c=zb({node:u,a11yIdNodeMap:e,dataMomenticIdMap:t,logger:r,callId:o,startId:c,useMPaths:a,domGraph:i,selectorToNodeMap:s,iconKnowledgeBase:l});return c}async function Hb({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",u=n[p]?.root;if(!u)throw new Error("A11y tree has no root");let m=AO(),h=y=>{let x=y.allNodes.filter(A=>!A.ignoredReasons?.find(L=>Fb.includes(L.name))),T=new Map;return x.forEach(A=>{T.set(parseInt(A.nodeId),A)}),T},g={};Object.entries(n).forEach(([y,x])=>{g[y]=h(x)});let f=await Bb({node:u,domGraph:e,parent:null,inputNodeMap:g,axGraph:n,frameId:p,frameContext:c,cdpClient:o,logger:r,callId:m,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={},w={},E={};return zb({node:f[0],a11yIdNodeMap:S,dataMomenticIdMap:w,selectorToNodeMap:E,domGraph:e,logger:r,callId:m,useMPaths:l,iconKnowledgeBase:d}),new kp(f[0],S,w,E)}function zO(n,e,t){if(n==="class"){if(t.tagName?.toLowerCase()==="svg")return e.split(" ").filter(i=>i.length<50&&!Yn.bannedClassSubstrings.some(a=>i.includes(a))).slice(0,3).join(" ");let r=e.split(" "),o=[];for(let i of r)if(jb(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 HO(n,e){if(!e)return;Object.entries(e.attributes).forEach(([i,a])=>{if(Yn.relevantElementAttributes.includes(i)&&!LO.includes(i)&&!n[i]&&!i.startsWith("aria")){let s=zO(i,a,e);s!==null&&(n[i]=s)}});let t,r=[];if(e.computedStyles.position&&kb.includes(e.computedStyles.position))t=e.computedStyles.position;else if(e.attributes.style){for(let i of kb)if(e.attributes.style.includes(`position: ${i}`)){t=i;break}}t&&r.push(`position: ${t}`);let o;e.computedStyles.opacity&&e.computedStyles.opacity==="0"&&(o="opacity: 0"),o&&r.push(o),r.length>0&&(n.style=r.join("; "))}function jO(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(je(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 m=d.children.filter(h=>h.tagName==="th");if(m.length){if(i=m.map(h=>je(h.name,100,!1)),i.length===m.length)continue;i=void 0}}s+=1,d.properties["row-index"]||(d.properties["row-index"]=s);let p=d.children.filter(m=>m.tagName==="td"||m.tagName==="th"),u=p.length===i?.length;p.forEach((m,h)=>{m.tagName!=="th"&&(m.properties["col-index"]||(m.properties["col-index"]=h+1),u&&(m.properties.col||(m.properties.col=i[h])))})}}}function $O(n){let e=n.properties.class,t=typeof e=="string"&&e.includes("cm-content");n.internalProperties.inCodeMirrorEditor=n.internalProperties?.inCodeMirrorEditor||t}function jb(n){if(Yn.bannedClassSubstrings.some(e=>n.includes(e)))return!1;if(Yn.alwaysInterestingClassNames.includes(n))return!0;for(let e of Yn.alwaysInterestingClassPrefixes)if(n.startsWith(e))return!0;return!1}var Bl=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 B(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 Q(500),l=p}if(!s)throw l;let c=new n(s,e,t,r,o);try{await B(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(`[${new Date(Date.now()).toLocaleString("en-US",{timeZone:"America/Los_Angeles"})}] Frame requested navigation: ${JSON.stringify(t)}`)}),e.on("Page.navigatedWithinDocument",t=>{this.loadEventLogs.push(`[${new Date(Date.now()).toLocaleString("en-US",{timeZone:"America/Los_Angeles"})}] Navigated within document: ${JSON.stringify(t)}`)}),e.on("Page.lifecycleEvent",t=>{this.loadEventLogs.push(`[${new Date(Date.now()).toLocaleString("en-US",{timeZone:"America/Los_Angeles"})}] Page lifecycle event: ${JSON.stringify(t)}`)}),e.on("Page.loadEventFired",()=>{this.loadEventLogs.push(`[${new Date(Date.now()).toLocaleString("en-US",{timeZone:"America/Los_Angeles"})}] 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 B(this.cdpInitializingPromise,{milliseconds:r});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 B(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 B(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 B(this.registerHandlers(this.session),{milliseconds:e,message:`Failed to register CDP handlers within ${e}ms`}),this.logger.debug("Successfully reinitialized and attached new handlers to CDP session");try{await B(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 GO,rmSync as $b,statSync as WO}from"fs";import*as Fp from"node:fs";import VO from"nodejs-file-downloader";import{tmpdir as qO}from"os";import Er,{basename as KO,dirname as YO}from"path";var Up="file://",Dp=Er.join(qO(),"momentic","downloads"),_p=1e4,JO=50*1024*1024;async function Gb(n){let{uri:e}=n;return e.startsWith(Up)?ZO(n):e.startsWith("http")?eM(n):QO(n)}function XO(n,e){let t=Er.join(Dp,n,e.slice(Up.length)),r=Er.join(Dp,n),o=t.startsWith(r);if(!Fp.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 ZO({uri:n,orgId:e}){let t=XO(e,n);return{filePath:t,cleanup:()=>{$b(YO(t),{recursive:!0,force:!0})}}}async function QO({uri:n}){let e=Er.resolve(n);if(!Fp.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 eM({uri:n,logger:e,orgId:t}){let r=new URL(n);r.search&&(r.search="");let o=KO(r.href),i=zp(o),a=Er.extname(i);if(Qh.includes(a))throw new Error(`Downloading files with extension ${a} is not allowed.`);let s=Bp(t),l=new VO({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:_p}),{downloadStatus:c,filePath:d}=await B(l.download(),{milliseconds:_p,message:`Download timed out after ${_p}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 u=WO(d).size;if(u>JO)throw new Error("File size exceeds the maximum limit of 50MB");e.info({fileSizeInBytes:u,filePath:d,fileName:i},"Downloaded file to disk");let m;return{filePath:d,cleanup:()=>{clearTimeout(m),m=setTimeout(()=>$b(s,{recursive:!0,force:!0}),10*60*1e3)}}}function Wb(n,e){return`${Up}${n}/${e}`}function Bp(n){let e=Math.random().toString(36).substring(4),t=Er.join(Dp,n,e);return GO(t,{recursive:!0}),t}function zp(n){let e=Er.extname(n),t=Er.basename(n,e);return n=(t.length>100?t.slice(t.length-100):t)+e,n=n.trim().replaceAll(" ","_"),n}async function yn(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}}async function Vb(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 B(t,{milliseconds:3e3});return o&&e.warn({err:o},"Failed to fetch indexedDB data"),r}async function qb(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 B(r,{milliseconds:3e3})}catch(r){t.warn({err:r},"Failed to import indexedDB data")}}}async function Kb(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 B(t,{milliseconds:3e3})}catch(t){e.debug({err:t},"Failed clearing index db data, continuing...")}}async function Yb(n,e,t,r,o){try{await tM(n,e,t,r)}catch(i){o.error({err:i,tabIndex:e},"Error handling new console log")}}async function tM(n,e,t,r){let o=r.text();o.length>Fa&&(o=o.slice(0,Fa)+"...(TRUNCATED)");let i=[];for(let a of r.args())try{let s=await a.jsonValue(),l=JSON.stringify(s);l.length>Fa?i.push(l.slice(0,Fa)+"...(TRUNCATED)"):(typeof s!="object"||Object.keys(s).length>0)&&i.push(s)}catch{}Hp(n,t,e,{url:n.url(),location:r.location(),type:r.type(),text:r.text(),args:i})}function Hp(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>Pp&&(i[t]=i[t].slice(Math.floor(Pp/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 sn({fn:n,codePath:e,logObject:t,signal:r,logger:o}){r?.throwIfAborted();let i=Date.now(),a=await ua({promiseGenerator:n,signal:r,codePath:e,logger:o}),s=Date.now();return t[e]=s-i,a}import{randomUUID as nM}from"crypto";var rM="[redacted due to size]",oM=1e4;async function ew(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 tw(n,e,t,r){try{await iM(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 ao(n){return n<0?0:n}function Jb(n){return{timings:{blocked:ao(n.domainLookupStart),dns:ao(n.domainLookupEnd-n.domainLookupStart),connect:ao(n.connectEnd-n.connectStart),send:ao(n.responseStart-n.requestStart),wait:0,receive:ao(n.responseEnd-n.responseStart),ssl:ao(n.connectEnd-n.secureConnectionStart)},total:ao(n.responseEnd)}}async function iM(n,e,t){let r=nM(),o=t.timing(),i=new URL(t.url()),a=[...i.searchParams.entries()].map(([h,g])=>({name:h,value:g})),s={...await Qb(t),url:i.toString(),method:t.method(),queryString:a,postData:await sM(t)},l={pageref:n,_resourceType:t.resourceType(),startedDateTime:new Date(o.startTime).toISOString(),request:s,timings:Jb(o).timings};Xb(e,l,r);let c=await t.response();if(c){await c.finished();let h={};try{h=await lM(c)}catch{}let g={...await Qb(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:u,total:m}=Jb(p);l.time=m,l.timings=u,Xb(e,l,r)}function Xb(n,e,t){n.harEntries||(n.harEntries={}),n.harEntries[t]=e}function Zb(n){try{return new Date(n).toISOString()}catch{return}}function aM(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=kn(i),e.value=kn(a);continue}i==="Domain"&&(e.domain=kn(a)),i==="Expires"&&(e.expires=Zb(a)),i==="HttpOnly"&&(e.httpOnly=!0),i==="Max-Age"&&(e.expires=Zb(Date.now()+ +a*1e3)),i==="Path"&&(e.path=kn(a)),i==="Secure"&&(e.secure=!0)}return e}async function Qb(n){let e=await n.allHeaders(),t=e.cookie?.split(";").map(aM)??[];return{headers:Object.entries(e).map(([r,o])=>({name:kn(r),value:kn(o)})),cookies:t}}async function sM(n){let e=n.postData();if(!e)return;let t=await n.headerValue("content-type"),r={mimeType:t??"application/octet-stream",text:kn(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:kn(i),value:a?kn(a):void 0})}return r}async function lM(n){return{mimeType:await n.headerValue("content-type")??void 0,text:kn(await n.text()),encoding:await n.headerValue("content-encoding")??void 0}}function kn(n){return n.length>oM?rM:n}function nw(){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 Ke({root:n,fn:e,arg:t,timeout:r,waitForPageLoad:o,codePath:i}){return await o(),await B(n.evaluate(e,t),{milliseconds:r,message:`Timed out ${i} after ${r}ms. This indicates that either the page is unresponsive or your machine is severely resource constrained.`})}function jp(){return window.lastCursorPos}import{errors as cM}from"playwright-core";async function so({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(ia(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 cM.TimeoutError)t.warn({err:c,rootUrl:(await r.state.getRoot()).url()},`Encountered Playwright error while performing ${e}`),s=await dM(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 dM(n,e,t,r){return n.message.includes("attempt #")?pM(n,e,t,r):uM(n)}async function pM(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(`
3901
3911
  `,";").replace(/\s+/g," ");let a="",s=await yn(e,r);if(s&&(a=`Target element HTML: ${je(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 yn(d,r);p&&(l=`Covering element HTML: ${je(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}
3902
- ${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 cM(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 ew(n){try{return await dM(n)}catch(e){n.logger.warn({err:e},"Failed to transform locator for Chakra click, continuing...");return}}async function dM({locator:n,logger:e}){let[t,r]=await n.evaluate(l=>[l.id,l.tagName.toLowerCase()],{timeout:1e3}),o=await yn(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,d=l.parentElement;if(!d)return{type:"error",error:"Input click target has no parent for redirection"};let p=l.getBoundingClientRect(),u=d.getBoundingClientRect();if(u.width===0||u.height===0)return{type:"error",error:"Parent element has no width or height"};let m={x:Math.min(Math.max(1,p.left-u.left),u.width-1),y:Math.min(Math.max(1,p.top-u.top),u.height-1)},g=c._MOMENTIC_FEATURE_FLAGS?.visual_actions?c.getMPath?.(l)?.join(" >"):`[data-momentic-id=${JSON.stringify(l.getAttribute("data-momentic-id"))}]`;return g?{type:"result",selector:g,relativePoint:m,serializedForm:d.outerHTML.slice(0,500)}:{type:"error",error:"Could not generate selector for parent element"}},{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 nw=["date","datetime-local","month","time","week"],tw={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 rw(n){try{await B(pM(n),{milliseconds:3e3})}catch(e){n.logger.warn({err:e},"Failed to transform native datetime input, continuing...")}}async function pM({root:n,text:e,options:t,logger:r,callbacks:o}){let i=(await Ke({root:n,fn:()=>document.activeElement?.getAttribute("type")??"",timeout:1e3,arg:void 0,waitForPageLoad:o.waitForPageLoad,codePath:"transforming native datetime input"})).toLowerCase();if(!tw[i])return;tw[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 Ul({locator:n,callbacks:e,logger:t,timeoutMs:r=1e3}){try{await jp(e,r);let o=n.evaluate(i=>{let a=window;a.momenticIsEligible=p=>{let m=window.getComputedStyle(p,null).getPropertyValue("display");if(m==="none"||m==="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 B(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 jp(n,e=1e3){let t=await n.state.getRoot();await Ke({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:"removing element highlights"})}async function Gp(n){let e=n.flagStore.isBooleanFlagEnabled("visual_actions");return so({action:"clicking element",targetingResult:n.targetingResult,logger:n.logger,retryTimeoutMs:n.retryTimeoutMs,callbacks:n.browserCallbacks,func:async t=>$p({...n,targetingResult:t,useVisualClick:e})})}async function gM(n,e){let{redirectionAttempts:t=0}=e;if(t>=2)throw n;try{return await fM(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 fM(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"),$p({...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 vM(a,s,t);if(l)return $p({...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 SM(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 Yr({promiseGenerator:async()=>s.boundingBox(),timeoutMs:3e3,logger:t}):null}catch(m){throw new R("UserInfrastructureError",`The frame containing the element Momentic was instructed to interact with was removed. Error: ${m.message}`)}finally{await s?.dispose()}let c=Date.now(),{clickX:d,clickY:p,reason:u}=await wM({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:u},duration:Date.now()-c},"Visual click")}async function yM(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 ew({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(EM(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..."),gM(c,{...n,targetingResult:{...i,locator:i}})}}async function $p(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 hM.TimeoutError?new R("ActionFailureError",`Download did not complete in ${l}ms`):new R("ActionFailureError",`Download failed: ${c.message}`)}})());try{await Ul({locator:a.locator,callbacks:r,logger:t,timeoutMs:1e3})}catch(l){t.warn({err:l},"Error highlighting locator in click, continuing...")}if(i?await SM(n):await yM(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 B(s,{milliseconds:e.downloadTimeoutMs??3e4});if(l instanceof Error)throw l;return{downloadedFile:await TM(l,o.createIsolatedFolder,t)}}else throw new Error("No download promise or error but the step requested to wait for a download")}async function bM(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 wM({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,u]=await bM(n,r);i=p.x,a=p.y,s=u}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 vM(n,e,t){let r=await n.evaluate(s=>s.getAttribute("data-momentic-id"));if(!r)return;let o=Rb(r,e,t);if(!o.length){t.error("No candidates found for parent-based locator redirection");return}let i=parseInt(o[0].attributes?.[an]??"");if(isNaN(i))return;n=n.page().locator(`[data-momentic-id="${i}"]`);let a=await yn(n,t);return t.warn({candidateMomenticId:i,serializedHtml:a},"Trying new locator based on parent-direction after covering error"),n}async function TM(n,e,t){t.info("Download detected, saving file to disk");let r=await n.path(),o=Bp(n.suggestedFilename()),i=e();await n.saveAs(mM(i,o)),iw(r,{force:!0}),setTimeout(()=>{iw(i,{recursive:!0,force:!0})},5*60*1e3);let a=jb(uM(i),o);return t.debug({uri:a,downloadFolder:i},"Saved download to isolated folder"),a}function EM(n){return n.message.includes("locator.click: Timeout")&&n.message.includes("click action done")}import{platform as xM}from"os";var CM={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 RM(){let n=xM();return n==="win32"?"win32":n==="darwin"?"darwin":"linux"}function aw(n){return JSON.stringify(n.split("+").sort())}function Bl(n){let e=RM(),t=aw(n);for(let r of Object.values(CM))if(Object.values(r).some(o=>aw(o)===t))return r[e];return process.platform==="darwin"?n=n.replaceAll("Control","Meta"):n=n.replaceAll("Meta","Control"),n}async function Wp({frame:n,page:e,deltaX:t,directionX:r,deltaY:o,directionY:i,signal:a,callbacks:s,logger:l}){if(!t&&!o)return;let c=r==="left"?-1:1,d=i==="up"?-1:1;if(n)await Ke({root:n,fn:([p,u,m,h])=>window.scrollTo(window.scrollX+(p??window.innerWidth)*m,window.scrollY+(u??window.innerHeight)*h),arg:[t,o,c,d],waitForPageLoad:s.waitForPageLoad,timeout:2e3,codePath:"scrolling page"});else{let p=e.viewportSize()||qt,u=await Ke({root:e,fn:()=>document.body.scrollHeight,arg:void 0,waitForPageLoad:s.waitForPageLoad,timeout:2e3,codePath:"computing page height"}),[m,h,g]=await Ke({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:"computing active element position"});await e.mouse.wheel((t??p.width)*c,(o??p.height)*d);try{let f=Date.now();for(;Date.now()-f<2e3;){a?.throwIfAborted();let S=await B(e.evaluate(()=>document.body.scrollHeight),{milliseconds:1e3}),[w,T,y]=await B(e.evaluate(()=>{let E=document.activeElement;if(!E)return[void 0,void 0,void 0];let x=E.getBoundingClientRect();return[E.scrollTop,x.x,x.y]}),{milliseconds:1e3});if(S===u&&w===m&&T===h&&y===g)break;u=S,m=w,h=T,g=y,await Z(500)}}catch(f){l.warn({err:f},"Failed to wait for scroll to complete, continuing...")}}}async function Vp(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 Z(500)}throw new Error(`Failed to get tab titles after all retries: ${r?.message}`)}var fi="<empty>";function AM(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 lw(n){let e=n.adFrameStatus?.adFrameType;return e==="child"||e==="root"||AM(n.url)}async function IM(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 Si({cdpClient:n,page:e,logger:t}){let r={type:"root",childFrames:[],page:e},o=[],[i,a]=await Promise.all([n.send({timeout:3e3,method:"Page.getFrameTree",params:{}}),n.send({timeout:3e3,method:"DOM.getDocument",params:{depth:0}})]),c=(i.frameTree.childFrames??[]).map(async(p,u)=>{if(lw(p.frame))return null;try{return await cw({cdpClient:n,rawFrameTree:p,indices:[u],parent:r,warnings:o,logger:t})}catch(m){return o.push(`Failed to get child frame: ${m}`),null}}),d=await Promise.all(c);return r.childFrames=d.filter(p=>p!==null),o.length&&t?.warn({warnings:o},"Got warnings when fetching frame tree"),r}async function cw({cdpClient:n,rawFrameTree:e,indices:t,parent:r,warnings:o,logger:i}){let a=e.frame.id,s=await IM(n,a),l=s.attributes??[],c=null,d=[];for(let h of["src","name","id","title","srcdoc","sandbox"]){let g=wr(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},m=(e.childFrames??[]).map(async(h,g)=>{if(lw(h.frame))return null;try{return await cw({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(m)).filter(h=>h!==null),p}async function PM(n){try{return await n.owner().count()===1}catch{return!1}}async function LM(n){try{return await n.count()===1}catch{return!1}}async function kn(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,fi]){let u=o.frameLocator(p===fi?"iframe":`iframe[${p}]`);if(await PM(u)){d=!0,o=u,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,fi]){let d=o.locator(c===fi?"iframe":`iframe[${c}]`);if(await LM(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 sw(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 dw({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===fi?s=s.length===1?s[0].childFrames:[]:s=s.filter(u=>u.locationData.attributeSelectors.includes(p)).map(u=>u.childFrames).flat()}let l=[],c=t.mPathSelectorTokens[t.mPathSelectorTokens.length-1];if(c===fi?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 kn(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=sw(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 kn(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=sw(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 kn(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 kn(r,n)).frame,handle:r,mPathSelectorTokens:t.mPathSelectorTokens,frameTree:e},logs:i};throw i.push(`Found ${a.length} frames with indices ${t.indices}`),new Hn("Failed to find the iframe that previously contained this element",[{type:"AUTO_FRAME",matched:!1,logs:i}])}function zl(n){return n.type==="auto"?JSON.stringify({type:"auto",frameId:n.handle.frameId}):JSON.stringify(n)}function qp(n){for(;n.parent.type==="frame";)n=n.parent;return n.parent}function pw(n){let e=qp(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 uw(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 mw({frame:n,logger:e,signal:t}){let r;try{r=await n.frameElement(),await OM({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 OM({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 Yr({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 u=document.activeElement,m,h,g;if(!u)m=void 0,h=void 0,g=void 0;else{let f=u.getBoundingClientRect();m=u.scrollTop,h=f.x,g=f.y}if(c!==void 0&&d!==void 0&&p!==void 0&&m===c&&h===d&&g===p)break;c=m,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 hw({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 u,m;if(c)try{let h=await r.frameElement();u=await B(h?.boundingBox(),{milliseconds:1e3})??void 0;let g=await t.constructIframeRegex({urls:p,srcs:[],desiredUrl:c});if(g.urlRegex)m={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"),m={type:"url",url:c}}(async()=>{try{await e.recordElementAction({...n,screenshotBase64:o,frameConfig:m,frameBoundingBox:u})}catch(h){i.error({err:h},"Failed to transform passive click action")}})()}import{randomUUID as _n}from"crypto";import MM from"js-beautify";var NM=["Dead"],Hl=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:_n(),type:"PRESET_ACTION",command:Un(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=Un(i);a={id:_n(),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=Un(i);a={id:_n(),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=Un(i);a={id:_n(),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=MM.html(p,{indent_size:1,indent_with_tabs:!1,preserve_newlines:!1}),p=bb(p,"data-momentic-interacted",4e4)}catch{}let u;try{u=(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"),u=s}let m=this.recordedSteps.get(d)?.step??a,h=m?.command;h&&"target"in h&&h.target?(h.target={type:"description",elementDescriptor:u},this.callbacks.onStepRecorded({...m,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(NM.includes(t)||this.signal.aborted)return;let o="normal";t.length>1&&(o="special");let i;if(o==="normal"){let p=Un("TYPE");i={id:_n(),type:"PRESET_ACTION",command:{...p,target:void 0,value:t,clearContent:!1}}}else{let p=Un("PRESS");i={id:_n(),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,u=i.command.value;i={id:_n(),type:"PRESET_ACTION",command:{...d,value:i.command.type==="PRESS"?`${p}+${u}`:`${p}${u}`}},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:_n(),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=Un(c);d.deltaY=Math.abs(i);let p={id:_n(),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=Un(c);d.deltaX=Math.abs(i);let p={id:_n(),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 jl=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=qp(e),{frame:o,mPathSelectorTokens:i}=await kn(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 Si({cdpClient:this.cdpClient,page:t,logger:this.logger}),{resolution:o,logs:i}=await dw({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(zl(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:zl(this.frameConfig),cacheTime:Date.now(),frameTree:this.frameConfig.frameTree,mPathSelectorTokens:this.frameConfig.mPathSelectorTokens},await mw({frame:r.frame,logger:e,signal:t}),this.activeFrameCache=r,r}async executeFunctionInAllFrames(e,t){let r=this.pageGetter(),o=await Si({cdpClient:this.cdpClient,page:r,logger:this.logger}),i=[B(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(kn(l,r).then(({frame:d})=>B(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 Si({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 sn({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 sn({fn:()=>Si({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 sn({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 sn({fn:()=>this.getDOMTree({devicePixelRatio:e.devicePixelRatio??1,signal:o,logger:r}),codePath:"domFetch",logObject:t,signal:o,logger:r}),d=await sn({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 sn({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(u=>u>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:jr,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=Ab({node:o,domGraph:this.domGraph});return Ib(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 Pb(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(`[${an}="${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 Si({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 Z(500,t)}finally{l++}if(a)return{source:"url",frame:a.frame,handle:a.handle,frameIdentifierStringified:zl(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=wr(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 kn(s,o)});break}}else if(r.trim()===p.trim()){a.push({handle:s,matchType:"url",...await kn(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 Ub({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 kn(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 Ke({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:"adding Momentic element IDs to the page"})??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(wr(t,"aria-hidden")==="true")return{shouldUnroll:!1,reason:"aria-hidden"};let r=wr(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(m){i.warn({err:m},"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 m=0;m<3;m++)try{c=await sn({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),u=[];for(;p.length>0;){let m=p.shift();try{let{shouldUnroll:g}=await this.decideChildFrameUnrollEligibility({handle:m,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 ${m.frameId} with url ${m.url}, allowing it to be fetched: ${g}`)}p.push(...m.childFrames);let h=async()=>{try{let g=await sn({fn:()=>this.getRawA11yTreeForFrame({frameId:m.frameId,timeoutMs:this.smartWaitingTimeoutMs,logTimings:o}),codePath:`a11y-tree-fetch-child-${m.frameId}`,logObject:o,signal:a,logger:i});d[m.frameId]=g}catch(g){i.warn({err:g,url:m.url,src:m.src},`Error getting raw a11y tree for child frame ${m.frameId}, continuing...`)}};u.push(h())}return await Promise.all(u),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 sn({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 sn({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 sn({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,a;for(;!o&&i<3;)try{if(o=await this.cdpClient.send({method:"DOMSnapshot.captureSnapshot",params:{computedStyles:_l},timeout:3e3}),!o||!o.documents.length)throw new Error("Got empty DOM tree")}catch(s){await Z(500,t),i++,a=s}if(!o||!o.documents.length)throw r.error({err:a},"Fatal error fetching DOM tree"),new R("UserInfrastructureError","Received an empty HTML snapshot from the browser. This indicates the page has crashed due to resource consumption issues or hanging client-side JavaScript code.");return Cb({snapshot:o,devicePixelRatio:e,logger:r})}constructIframeRegexAsync(e,t){if(t.frameSrcRegex||t.frameUrlRegex)return;let r=pw(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...")}})()}};function Kp(n){let e=[],t="";for(let r of n)r==="+"&&t?(e.push(t),t=""):t+=r;return e.push(t),e}function gw(n){return async(e,t)=>{let r=await t.allHeaders();for(let{key:o,value:i,matcher:a}of n)(!a||a.test(t.url()))&&(r[o]=i);await e.continue({headers:r})}}var Yp=yi(Jp(),"momentic","chromium"),eN=yi(Jp(),"video"),Wl=process.env.TWO_CAPTCHA_KEY,xw=XM(Ew);xw.use(QM({provider:{id:"2captcha",token:Wl},visualFeedback:!0}));var Dn=class n{static USER_AGENT=JM["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={};requestRecorders={};customHeaders=[];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:u,clientCallbacks:m,iconKnowledgeBase:h}){if(ef(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||qt,this.properties=u,this.clientCallbacks=m,u.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","geolocation"]);let e=this.flagStore.getAllFlags(),t=[this.context.addInitScript({content:ub.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'); });`})];await this.context.route("**/*",gw(this.customHeaders));let 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"&&VM()==="darwin"&&BM("system_profiler SPDisplaysDataType").toString().includes("Retina")?(b.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 Fl.init({logger:this.logger,contextGetter:()=>this.context,pageGetter:()=>this.page,defaultTimeoutMs:this.pageLoadTimeout}),await this.initializeScreencast(),this.stateManager=new jl({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,recordVideo:c,iconKnowledgeBase:d,callbacks:p}){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 m={headless:process.env.MOMENTIC_HEADFUL_BROWSER!=="true",handleSIGTERM:!1,chromiumSandbox:!1,channel:u},h={...l??{},geolocation:l?.geolocation||Fo,locale:l?.locale||_o,timezoneId:l?.timezoneId||Do,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??qt},g=["--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"],f=null,S,w,T={systemDevicePixelRatio:l?.deviceScaleFactor,recordVideo:c,isNewHeadless:!1};(s.browserType==="Chromium"||s.browserType==="Google Chrome")&&(T.isNewHeadless=!0,m.headless&&g.push("--headless=new")),process.env.BROWSER_MEMORY_MB&&g.push(`--js-flags=--max_old_space_size=${process.env.BROWSER_MEMORY_MB}`),s.disableGpu&&g.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 y=s.localChromeExtensionPaths?.map(x=>x.startsWith("~")?yi(Jp(),x.slice(1)):x);if(y?.length){if(s.browserType==="Chrome for Testing")throw new R("UserConfigurationError","Chrome extensions are only supported on Chromium and Google Chrome.");for(let L of y){let W=yi(L,"manifest.json");if(!Gl(W))throw new R("UserConfigurationError",`Chrome extension path ${W} does not exist.`)}let x=yi(Yp,`momentic-session-${Date.now()}`);if(!Gl(x))try{HM(x,{recursive:!0})}catch(L){throw new R("UserConfigurationError",`Failed to create browser cache directory. Please make sure you have sufficient permissions to create the ${Yp} folder: ${L}`)}let A=[...g],k=y.map(L=>YM(L)).join(",");A.push(`--disable-extensions-except=${k}`),h?.deviceScaleFactor&&A.push(`--force-device-scale-factor=${h.deviceScaleFactor}`,`--device-scale-factor=${h.deviceScaleFactor}`),h.viewport&&A.push(`--window-size=${h.viewport.width},${h.viewport.height}`),S=await Ew.launchPersistentContext(yi(Yp,`momentic-session-${Date.now()}`),{...m,...h,ignoreDefaultArgs:["--disable-extensions","--disable-component-extensions-with-background-pages"],args:A,baseURL:e}),t.debug({sharedContextOptions:h,sharedBrowserOptions:m,userBrowserSettings:s,chromeArgs:A,flags:o.getAllFlags()},"Browser initialization context args (persistent)"),w=S.pages()[0]}else{f=await xw.launch({...m,args:g});let x={...h,baseURL:e,recordVideo:c?{dir:eN}:void 0};S=await f.newContext(x),t.debug({contextArgs:x,sharedBrowserOptions:m,chromeArgs:g,userBrowserSettings:s,flags:o.getAllFlags()},"Browser initialization context args (standard)"),w=await S.newPage()}let E=new n({browser:f,context:S,page:w,baseUrl:e,logger:t,storage:r,flagStore:o,mockedServices:a||{},enricher:i,userBrowserSettings:s,viewport:h.viewport||qt,properties:T,clientCallbacks:p,iconKnowledgeBase:d});return await E.initialize(),E}async handleAvailableTabsChangeHelper(){try{let e=await Vp(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=bw(),o=`${e}-${r}`,i=Date.now(),a=!1,s=async()=>{try{await B(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()||!Jr(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=bw(),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=>{Vb(e,o,this.debugData,a,this.logger)}),e.on("request",a=>{Qb(t,this.debugData,a,this.logger),this.recordRequest(a)});let i=async()=>{await Xb(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=Lb({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:WM()};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"||!Jr(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 B(jp(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 Ke({fn:()=>{let l=window;return!!(l.generateCssSelectors&&l.evaluateCssSelectors&&l.evaluatePrimaryCaches&&l.generateHtmlCacheAttributes&&l.ldist)},timeout:1e3,arg:void 0,waitForPageLoad:()=>this.waitForPageLoad(),root:e,codePath:"ensuring Momentic system scripts are loaded"}))return}catch(s){if(i++,i>=3){t.warn({err:s},"Multiple errors checking if Momentic scripts are loaded, aborting...");return}}await Z(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),Ke({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:"getting the full HTML tree"})}url(){return this.page.url()}async stabilizePageForScreenshot(){try{await this.evaluateFunctionInPage(()=>{let e=window,t=[],r=new Map;document.querySelectorAll("input,textarea,[contenteditable]").forEach(o=>{r.set(o,{value:o.style.getPropertyValue("caret-color"),priority:o.style.getPropertyPriority("caret-color")}),o.style.setProperty("caret-color","transparent","important")}),t.push(()=>{for(let[o,i]of r)o.style.setProperty("caret-color",i.value,i.priority)}),e._MOMENTIC_SCREENSHOT_CLEANUP=()=>{for(let o of t)o();delete e._MOMENTIC_SCREENSHOT_CLEANUP}},void 0,"stabilizing page for screenshot")}catch(e){(!(e instanceof Error)||!e.message.includes("Execution context was destroyed"))&&this.logger.warn({err:e},"Failed to stabilize page before screenshot, continuing...")}}async removeScreenshotStabilization(){try{await this.evaluateFunctionInPage(()=>{window._MOMENTIC_SCREENSHOT_CLEANUP?.()},void 0,"removing screenshot stabilization")}catch{}}async screenshot(e){let{retries:t=1,stabilizeBeforeScreenshot:r=!1}=e,o=this.page.url();r&&await this.stabilizePageForScreenshot();let i=Date.now();try{await this.fixViewportForNewHeadless();let a=await this.screenshotHelper({...e,retries:t});if(a.byteLength>5e6)this.logger.error("Page screenshot is greater than 5MB, which may cause performance issues with some AI models");else if(a.length===0)throw new Error("Got empty screenshot");return a}catch(a){if(t<=0||a.message.includes("has been closed"))throw a;return this.logger.debug({err:a,pageUrl:o},"Failed taking screenshot, retrying..."),await Z(250),this.screenshot({...e,retries:t-1})}finally{Date.now()-i>1e3&&this.logger.warn({pageUrl:o,duration:Date.now()-i},"Screenshot took longer than expected"),r&&await this.removeScreenshotStabilization()}}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 ww.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&&$M(r,l),this.lastScreenshotForRecording=l,!e)return l;let u=await e.boundingBox({timeout:1e3});if(!u)throw new Error("Attempted to screenshot an element that is not visible on the page");let{x:m,y:h,width:g,height:f}=u;if(!g||!f)throw new Error("Attempted to screenshot an element with zero width or height");if(m<0||h<0)throw new Error("Attempted to screenshot an element with negative coordinates");m=Math.floor(m),h=Math.floor(h),g=Math.floor(g),f=Math.floor(f);try{l=await(await ww.fromBuffer(l)).crop({x:m,y:h,w:g,h:f}).getBuffer("image/jpeg")}catch(S){throw new Error(`Failed taking element screenshot at coordinates (${m}, ${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}){tS(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 Z(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(wb.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 Ke({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:"getting the active element"})}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 rw({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 Z(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.debug({activeElementDetails:i},"Currently active element is not eligible for replace content, skipping...")),await this.page.keyboard.type(e,{delay:t.delay??dm}),t.pressEnter&&await this.press("Enter",{})}async scrollIntoViewIfNeeded(e){try{await e.scrollIntoViewIfNeeded({timeout:2e3})}catch(t){this.logger.warn({err:t},"Failed to scroll into view, trying with raw JS");try{await e.evaluate(async r=>{let o=r.scrollTop;r.scrollIntoView(),await new Promise(a=>setTimeout(a,250));let i=Date.now();for(;Date.now()-i<1e3;){let a=r.scrollTop;if(a===o)break;o=a,await new Promise(s=>setTimeout(s,250))}},void 0,{timeout:2e3})}catch(r){this.logger.warn({err:r},"Failed to scroll into view using JS, continuing...")}}}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 Ul({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 Wb(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 Gb(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 $b(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 Vp(this.context,e)}saveA11yDetailsToCache(e,t){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 updateCacheWithNewNodeDetails({node:e,target:t,locator:r,forceSaveNewCssSelectors:o,startingBoundingBox:i,logger:a=this.logger}){if(e&&this.saveA11yDetailsToCache(e,t),t.frameCache=this.stateManager.saveAutoFrameCacheDetails(t.frameCache),r)try{let s=await this.fetchHtmlAttributes({locator:r,logger:a,startingBoundingBox:i}),l=!1;for(let c of["generatedSelectors","serializedHtml","nodeOnlySerializedHtml","hybridSelector"]){let d=s?.[c];if(d&&!t[c]){l=!0;break}if(d&&JSON.stringify(d)!==JSON.stringify(t[c])){l=!0;break}}s&&(o||l)&&(t.generatedSelectors=s.generatedSelectors,t.serializedHtml=s.serializedHtml,t.nodeOnlySerializedHtml=s.nodeOnlySerializedHtml,t.hybridSelector=s.hybridSelector)}catch(s){if(s instanceof jn)throw s;a.warn({err:s},"Failed to fetch HTML attributes for target, continuing...")}try{await this.saveElementVisualAttributes(t,r,a)}catch(s){a.debug({err:s},"Failed to save element visual details, continuing...")}}async saveElementVisualAttributes(e,t,r){if(!t)return{scrollPerformed:!1};if(!Ap.includes(e?.role??""))return{scrollPerformed:!1};await this.scrollIntoViewIfNeeded(t);let o=await t.boundingBox({timeout:1e3});if(!o||!o.width||!o.height)return r.debug("Skipping visual attributes saving for element with no bounding box after action"),e.boundingBox=void 0,e.screenshotUrl=void 0,{scrollPerformed:!0};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)return{scrollPerformed:!0};e.boundingBox=o;let c=await this.screenshot({locator:t,quality:75,retries:0});return e.screenshotUrl=await this.storage.uploadScreenshot(c),{scrollPerformed:!0}}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:w}=await this.stateManager.getAutoFrameDetailsFromHandle(f);c=S,d=w,l=w.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 u=await this.stateManager.getLocatorFromA11yNode({page:this.page,root:l,node:a}),m={id:e,inputDescription:t??void 0,targetSource:r,targetUpdateTime:new Date().toISOString(),frameCache:c},h,g=!1;o||(d&&(i.debug({frameConfigSource:p,frameConfig:uw(d)},"A11y node was resolved to a target within an iframe"),h=this.stateManager.frameConfig,this.stateManager.setActiveFrameConfig(d),g=!0),await this.updateCacheWithNewNodeDetails({node:a,target:m,locator:u,logger:i,forceSaveNewCssSelectors:!0}));try{return{resolution:{locator:u,a11yNode:a,displayString:a.getNodeOnlySerializedForm(),decisions:[]},target:m,frameConfig:d,frameConfigSource:p}}finally{g&&this.stateManager.setActiveFrameConfig(h)}}async resolveTarget(e,t,r={}){let{targetName:o,logger:i=this.logger,signal:a=this.abortSignal}=r;if(t.frameCache&&this.flagStore.isBooleanFlagEnabled("auto_expand_iframes")){let u,m=!1,h=Date.now();for(;Date.now()-h<this.smartWaitingTimeout;)try{let g=await this.stateManager.resolveAutoFrameCache(t.frameCache);this.setActiveFrameConfig(g),m=!0;break}catch(g){u=g,await Z(500,a)}if(!m)throw u}let s=await this.getActivePageOrFrame();await this.ensureMomenticBrowserScriptsLoaded(s,i,a);let l=Date.now(),c=0,d=0,p;for(;Date.now()-l<this.smartWaitingTimeout;){this.abortSignal?.throwIfAborted(),c++;let u=c===1||Date.now()-l>this.smartWaitingTimeout-2e3&&c%2===0;try{p=await this.resolveTargetHelper({root:s,target:t,primaryOnly:!0,logger:u?i:jr,signal:a});break}catch(m){if(m instanceof oa)break;if(m instanceof jn){if(d++,d>2)throw i.error({err:m},"Got multiple bounding box moved errors, giving up"),m;i.warn({err:m},"Got bounding box moved error, waiting and retrying resolution"),await Z(500,a)}a?.throwIfAborted(),u&&i.debug({err:m},`Could not resolve target through CSS selectors only (x${c})`),await Z(500,a)}}return p||(p=await this.resolveTargetHelper({root:s,target:t,primaryOnly:!1,logger:i,signal:a}),t.targetSource="HEURISTIC_HEALED",t.targetUpdateTime=new Date().toISOString(),t.targetUpdateLoggerTags=ze(i),i.debug({decisions:p.decisions},"Target resolution succeeded after waiting")),e?.details?.push({type:"TARGETING",name:o,elementLocationDecisions:p?.decisions??[],pageState:void 0,targetSource:t.targetSource,targetUpdateTime:t.targetUpdateTime}),p}async resolveTargetWithPrimaryMethods({root:e,target:t,logger:r}){if(!t.nodeOnlySerializedHtml)throw new oa("Insufficient data to resolve target using primary methods (missing node HTML)");let o=this.userControlledBrowserSettings.hybridSelectorMode,i={ldistThreshold:.05,requireBoundingBox:!0,ignoreHrefForCaching:this.userControlledBrowserSettings.ignoreHrefForCaching,requireMatchingBoundingBox:this.userControlledBrowserSettings.bustCacheOnBoundingBoxChange?t.boundingBox:void 0},{css:a,hybrid:s}=await Ke({fn:f=>window.evaluatePrimaryCaches(f),arg:{cssParams:{selectors:t.generatedSelectors??[],cachedElementSerialized:t.nodeOnlySerializedHtml,opts:i},hybridParams:o&&t.hybridSelector?{nodes:t.hybridSelector,cachedElementSerialized:t.nodeOnlySerializedHtml,opts:i}:void 0},root:e,timeout:3e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"evaluating target caches"}),l,c,d=[];if(o==="prefer"&&s?.result){l=s,c=s.result;let f={type:"HYBRID_SELECTOR",matched:!0,logs:s.logs,reason:"Discovered a match using Momentic's hybrid text and CSS selector approach"};d.push(f)}else if(a?.result)l=a,c=a.result,d.push({type:"CSS_SELECTOR",matched:!0,logs:a.logs,reason:`${c.workingSelectors.length} CSS selectors matched the following element: ${c.serializedElement}`,selectors:c.workingSelectors.slice(0,5)});else throw d.push({type:"CSS_SELECTOR",matched:!1,reason:a.logs.length===1?"CSS evaluation failed":"No CSS selectors matched",selectors:[],logs:a.logs}),s&&d.push({type:"HYBRID_SELECTOR",matched:!1,reason:s.logs.length===1?"Hybrid evaluation failed":"No hybrid selectors matched",logs:s.logs}),new Hn("Cache evaluation failed",d);let p,u,m,h=!1;if(this.flagStore.isBooleanFlagEnabled("visual_actions")){let f=c.mPath;if(!f)throw new Error("Found element did not have an mPath despite using visual actions");let S=f.join(" > ");p=e.locator(S),u=this.stateManager.getNodeUsingMPathSelector(S)}else if(c.dataMomenticId!==void 0)m=parseInt(c.dataMomenticId),u=this.stateManager.dataMomenticIdToNodeMap[m],"workingSelectors"in c?(p=e.locator(c.workingSelectors[0]),h=c.workingSelectors.length<5):p=e.locator(`[data-momentic-id=${JSON.stringify(m)}]`);else throw new R("InternalWebAgentError","Received an element resolution result with no identifying attributes");o&&t.hybridSelector&&(s?.logs.length===1?r.warn({hybridResult:s,cssResult:a,hybridMode:o},"Hybrid selector resolution rejected, continuing..."):s?.result?a?.result&&s?.result&&s.result.serializedElement!==a.result.serializedElement&&(this.flagStore.isBooleanFlagEnabled("visual_actions")&&JSON.stringify(a.result.mPath)!==JSON.stringify(s.result.mPath)?r.warn({originalCache:t,hybridResult:s,cssResult:a,hybridMode:o,mode:"visualActions"},"Hybrid selector resolution returned a different element than CSS selector resolution, continuing..."):a.result.dataMomenticId!==s.result.dataMomenticId&&r.warn({originalCache:t,hybridResult:s,cssResult:a,hybridMode:o,mode:"dataMomenticId"},"Hybrid selector resolution returned a different element than CSS selector resolution, continuing...")):r.warn({originalCache:t,hybridResult:s,cssResult:a,hybridMode:o},"Hybrid selector resolution returned no eligible elements while CSS resolution did, continuing..."));let g=vw(t);return await this.updateCacheWithNewNodeDetails({node:u,target:t,locator:p,logger:r,startingBoundingBox:c.boundingBox,forceSaveNewCssSelectors:h}),r.info({diffs:zM(g,t),locationResult:l},"Updated cache with new details after resolution"),{a11yNode:u,displayString:c.serializedElement,locator:p,decisions:d}}async resolveTargetHelper({root:e,target:t,primaryOnly:r,logger:o,signal:i,skipSaveToCache:a}){let s=[],l=(await this.getBrowserState({logger:o,abortSignal:i,skipWait:!0})).serialize();o.debug({tree:l.length>4e5?l.slice(0,4e5):l},"Got a11y tree before attempting target resolution");let c;if(t.generatedSelectors||t.hybridSelector){let d;try{d=await this.resolveTargetWithPrimaryMethods({root:e,target:t,logger:o})}catch(p){c=p}if(d)return{...d,pageState:void 0,decisions:[...s,...d.decisions]};r||(s.push({type:"CSS_SELECTOR",matched:!1,reason:c?.message,selectors:vw(t.generatedSelectors??[])}),t.generatedSelectors=void 0,t.hybridSelector=void 0)}if(r)throw c;if(!this.flagStore.isBooleanFlagEnabled("disable_secondary_cache_resolution")){let d=await this.resolveTargetWithSecondaryMethods({root:e,tree:l,target:t,decisions:s,logger:o,signal:i,skipSaveToCache:a});if(d)return d}throw o.warn({target:t,decisions:s},"Failed to find any relevant node"),new Hn(`Could not find any relevant node given target: ${JSON.stringify(t)}`,s)}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 u=s.locator(r),m;try{return await u.waitFor({state:"attached",timeout:1e3}),m=await yn(u,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:u,displayString:m,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 Z(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 Ke({fn:p=>window.findClosestElementByLDist?.(p),arg:{nodeOnlySerializedHtml:t.nodeOnlySerializedHtml},timeout:2e3,root:e,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"finding the closest element on the page"}),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,u,m;if(p)u=this.stateManager.dataMomenticIdToNodeMap[p],m=e.locator(`[${an}="${p}"]`);else if(c.mPathSelector)u=this.stateManager.getNodeUsingMPathSelector(c.mPathSelector),m=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 yn(m,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.updateCacheWithNewNodeDetails({node:u,target:t,locator:m,logger:o,startingBoundingBox:c.boundingBox,forceSaveNewCssSelectors:!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:m,a11yNode:u,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&&Ap.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=ZM(),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:u,locator:m}=await this.getTargetFromPositionPercentages({percentX:p.x,percentY:p.y}),h=u.boundingBox?.width,g=u.boundingBox?.height;if(!h||!g)throw a="Rejecting target from screenshot due to no bounding box",new Error(a);let f=u.id,S=this.stateManager.a11yIdToNodeMap[f];return i||await this.updateCacheWithNewNodeDetails({target:r,node:S,locator:m,forceSaveNewCssSelectors:!0}),{locator:m,a11yNode:S,displayString:u.nodeOnlySerializedHtml??"",decisions:[{type:"TEMPLATE_MATCHING",matched:!0,reason:"Found element using screenshot",elementImageUrl:t}]}}async typeIntoTarget(e,t,r={}){await this.highlight(t.locator);let o=await t.locator.getAttribute("type",{timeout:1e3})??"",i=nw.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(),eS(s,t,r)){a=!0;break}await Z(500,this.abortSignal)}if(!a)throw new R("ActionFailureError",`The active page URL ${r?.negated?"still does":"does not"} ${Dd(t)} in ${o}ms.
3903
- 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 Z(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(Hp);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 Z(250),await this.page.mouse.up()}async hover(e){await this.highlight(e.locator),await so({func:async t=>{await this.scrollIntoViewIfNeeded(t.locator);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 so({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 Ke({fn:()=>{let r=document.activeElement;r&&r.nodeType===1&&r.blur()},root:t,arg:void 0,waitForPageLoad:()=>this.waitForPageLoad(),timeout:1e3,codePath:"blurring the active element"});return}await this.highlight(e.locator),await so({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 so({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=Bl(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 keyDown(e,t){if(t.convertMeta){let r=Bl(e);r!==e&&(this.logger.debug({keyString:e,convertedKey:r},"Converted platform dependent keys"),e=r)}for(let r of Kp(e))await this.page.keyboard.down(r)}async keyUp(e,t){if(t.convertMeta){let r=Bl(e);r!==e&&(this.logger.debug({keyString:e,convertedKey:r},"Converted platform dependent keys"),e=r)}for(let r of Kp(e))await this.page.keyboard.up(r)}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 B(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 Ke({root:e,fn:()=>[window.scrollY,window.scrollX,window.screen.width,window.screen.height,window.devicePixelRatio],arg:void 0,timeout:3e3,waitForPageLoad:async()=>{},codePath:"getting current viewport details"});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=u=>{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,stabilizeBeforeScreenshot:!0},c=!1,d=0;for(;Date.now()-a<r;){if(o?.throwIfAborted(),await Z(500,this.abortSignal),s)try{let u=await this.screenshot(l);if(!u.equals(s)){s=u,c=!1;continue}c=!0}catch(u){d++,d%3===0&&t.warn({err:u,screenshotErrors:d},"Failed to take screenshot for DOM stability check"),o?.throwIfAborted()}else try{s=await this.screenshot(l)}catch(u){d++,d%3===0&&t.warn({err:u,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.debug(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 Z(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(Hp);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 Z(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 B(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 w=0;w<s.length;w++)if(l[w]===e){p=c.indexOf(w);break}if(p===-1)throw new Error(`Could not find any backend node with ID ${e}`);let[u=0,m=0,h=0,g=0]=d[p];u/=r,m/=r,h/=r,g/=r;let f=u+h/2,S=m+g/2;return{centerX:f,centerY:S}}async scrollVertical(e){return Wp({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(),logger:this.logger})}async scrollHorizontal(e){return Wp({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(),logger:this.logger})}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 B(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 Z(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)}.
3904
- Available pages:${JSON.stringify(r.map(i=>i.url))}`);if(!Jr(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=_s(e):t=[e],await this.context.addCookies(t),t}async setLocalStorage(e,t){let r;for(let o=0;o<2;o++)try{await this.evaluateFunctionInPage(([i,a])=>{i&&localStorage.setItem(i,a||"")},[e,t],`setting local storage key ${e}`);return}catch(i){r=i}if(r)throw r}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:Wl,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 Z(2500);let s=await fetch("https://api.2captcha.com/getTaskResult",{method:"POST",body:JSON.stringify({clientKey:Wl,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&&hw({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];Jr(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.debug({url:i,codePath:r},"Skipping load for chrome-error:// URL");return}try{await Yr({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 ${je(i,50)} did not load within the configured timeout (${o}ms): ${s}`);if(!s.message.includes("detached"))throw s}try{await Yr({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 GM.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 Ke({fn:()=>window.getCondensedHtmlTree(),root:e,arg:void 0,timeout:2e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"getting condensed HTML tree"});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,r){let o=await this.getActivePageOrFrame();return Ke({root:o,fn:e,arg:t,timeout:2e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:r})}async evaluateCodeInPage({code:e,fragment:t,context:r,timeoutMs:o=sr}){let i=Zb(),a={code:e,fragment:t,context:r},{result:s}=await B(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),u=d+c,m=p+l;return this.getDomNodeFromPixelPosition(u,m)}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:xb,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 getTargetFromPositionPercentages(e){let t=await this.getActivePageOrFrame(),r=await this.getDomNodeFromPositionPercentages(t,e);return this.getTargetFromBackendNodeId(t,r.backendNodeId)}async getTargetFromBackendNodeId(e,t){let r=this.stateManager.domGraph?.backendIdToNode[t];if(!r)throw new Error("No DOM node was found with the given backend ID");let o=r?.attributes[an],i=parseInt(o??"");if(!o||isNaN(i))throw new Error("No data-momentic-id was found on the DOM node");let a=e.locator(`[${an}="${o}"]`),s;r.bounds.x!==null&&r.bounds.y!==null&&(s={x:r.bounds.x,y:r.bounds.y,width:r.bounds.width??0,height:r.bounds.height??0});let l=await this.fetchHtmlAttributes({locator:a,logger:this.logger,startingBoundingBox:s}),c={id:-1,dataMomenticId:i,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString(),...l};return this.logger.debug({target:c},"Tied backend ID to HTML node"),{target:c,locator:a}}async performTargetRedirection(e,t,r){try{return await this.scrollIntoViewIfNeeded(e),await B(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 yn(e,t);if(r===void 0&&(r=await e.boundingBox({timeout:1e3})??void 0),!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:u,mPathSelector:m,error:h,serializedElement:g,point:f,force:S,logs:w}=await e.evaluate(y=>{let E=window;if(!E.performTargetRedirection)throw new Error("performTargetRedirection script is not defined");return E.performTargetRedirection(y)},void 0,{timeout:1e3}),T=Date.now()-o;if(h){t.warn({error:h,serializedElement:g,duration:T,force:S,logs:w},"Got error from target redirection with bounding box");return}else{if(u)return t.debug({newDataMomenticId:u,serializedElement:g,duration:T,force:S,logs:w},"Redirected target to new element with bounding box with data-momentic-id"),{locator:p.locator(`[data-momentic-id="${u}"]`),hints:{clickableXY:f,force:S}};if(m)return t.debug({newMPathSelector:m,serializedElement:g,duration:T,force:S,logs:w},"Redirected target to new element with bounding box with mPath"),{locator:p.locator(m),hints:{clickableXY:f,force:S}};if(f)return t.debug({point:f,serializedElement:g,duration:T,force:S,logs:w},"Chose specific visible point on original element"),{locator:e,hints:{clickableXY:f,force:S}};if(S)return t.debug({serializedElement:g,duration:T,force:S,logs:w},"Forcing click on original element"),{locator:e,hints:{force:S}}}}async fetchHtmlAttributes({locator:e,logger:t=this.logger,startingBoundingBox:r}){let o=await e.evaluate((i,a)=>{let s=window;return s.generateHtmlCacheAttributes?s.generateHtmlCacheAttributes(i,a):{warnings:[],error:"generateHtmlCacheAttributes is not defined"}},{generateHybridSelector:!!this.userControlledBrowserSettings.hybridSelectorMode,startingBoundingBox:r},{timeout:2e3});if("error"in o&&o.error)throw o.error.startsWith(xp)?new jn(o.error.slice(xp.length)):new Error(o.error);return o.warnings.length&&t.warn(o,"Got warnings while generating HTML attributes for target"),o.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!!Wl}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,zp(e,this.debugData,i,{type:t,text:`[MOMENTIC] ${r}`,args:o})}async setFileChooserHandlerHelper({filePath:e,filename:t}){if(!Gl(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()||qM(e),o=jM(e),i=KM(e),a=Ed[i];this.page.once("filechooser",async l=>{this.logger.info({filePath:e,fileName:r},"File chooser triggered");try{if(!Gl(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:Sb.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 this.evaluateFunctionInPage(({fileName:l,base64Data:c,mimeType:d})=>{let p=window;p.momenticFileName=l,p.momenticFileBase64=c;let u=atob(c),m=new Array(u.length);for(let g=0;g<u.length;g++)m[g]=u.charCodeAt(g);let h=new Uint8Array(m);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},"set-file-chooser-handler")}getSerializedFormFromA11yId(e){return this.stateManager.a11yIdToNodeMap[e]?.getNodeOnlySerializedForm()}retrieveAndClearDebugData(){let e=this.cdpClient.loadEventLogs;e.length>0&&(this.logger.debug({logs: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,"copying text to clipboard")}catch(t){if(t instanceof Error&&t.message.includes("Document is not focused")){await this.evaluateFunctionInPage(()=>{document.activeElement||document.body.focus()},void 0,"focusing on body element before copying to clipboard"),await this.press("Tab",{}),await this.press("Shift+Tab",{}),await this.evaluateFunctionInPage(r=>navigator.clipboard.writeText(r),e,"copying text to clipboard");return}throw t}}async paste(){await this.waitForPageLoad(),await this.press("Meta+V",{convertMeta:!0})}async registerRequestListener(e){return this.page.waitForResponse(e)}registerRequestRecorder(e,t,r){this.requestRecorders[e]=o=>{t.test(o.url())&&r(o)}}removeRequestRecorder(e){delete this.requestRecorders[e]}setHeader(e,t,r){this.customHeaders.push({key:e.toLowerCase(),value:t,matcher:r})}async recordRequest(e){Object.values(this.requestRecorders).forEach(t=>{try{t(e)}catch(r){this.logger.error({err:r,url:e.url()},"Error while recording request")}})}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 SN from"fetch-cookie";import{cloneDeep as yN}from"lodash-es";import{CookieJar as bN}from"tough-cookie";import{z as Ft}from"zod";var die=Ft.object({doubleClick:Ft.boolean().optional(),rightClick:Ft.boolean().optional(),force:Ft.boolean().optional(),waitForDownload:Ft.boolean().optional(),delayMs:Ft.number().optional(),downloadTimeoutMs:Ft.number().optional(),relativePosition:Ft.object({x:Ft.number(),y:Ft.number()}).optional()}),pie=Ft.object({repeat:Ft.number().optional(),convertMeta:Ft.boolean().optional().describe("misleading name due to backcompat. converts keyshortcuts + meta/control to platform-specific combos. defaults to true"),delayMs:Ft.number().optional()});async function Tr(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 bi=3.1783027;function tN(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 Ua(n){return Math.ceil(Xp(n)/bi)}function Xp(n){let e=0;if(typeof n=="string"){let t=n;t=t.replaceAll(`
3905
- `,""),t=t.replaceAll(" ","");let r=tN(t);return t.length-r+bi*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*bi:e+=85*bi: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 Rw={minChunkTokenCount:500,acceptableChunkTokenCount:3e3,maxChunkTokenCount:8e3,maxLineLength:4e3},Aw={minChunkTokenCount:5e3,acceptableChunkTokenCount:1e4,maxChunkTokenCount:15e3,maxLineLength:500},Cw=/<(\S+) id="(\d+)".*?>/g,nN=/(<\/(\S+)>)|(<(\S+).*?\/>)/g,Iw=["h1","h2","section","footer","nav","aside","form","label","dialog"],rN=[...Iw,"span","div","h3"],oN=["table","select","form","ul","ol","menu","pre","code","dialog"],iN=["table","form","dialog","nav","section","ul","select"];function Qp(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)),aN(n)}function aN({serializedTree:n,options:e,logger:t}){let{minChunkTokenCount:r,acceptableChunkTokenCount:o,maxChunkTokenCount:i,maxLineLength:a}=e,s=[],l=n.split(`
3912
+ ${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:3e3});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 uM(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 rw(n){try{return await mM(n)}catch(e){n.logger.warn({err:e},"Failed to transform locator for Chakra click, continuing...");return}}async function mM({locator:n,logger:e}){let[t,r]=await n.evaluate(l=>[l.id,l.tagName.toLowerCase()],{timeout:1e3}),o=await yn(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,d=l.parentElement;if(!d)return{type:"error",error:"Input click target has no parent for redirection"};let p=l.getBoundingClientRect(),u=d.getBoundingClientRect();if(u.width===0||u.height===0)return{type:"error",error:"Parent element has no width or height"};let m={x:Math.min(Math.max(1,p.left-u.left),u.width-1),y:Math.min(Math.max(1,p.top-u.top),u.height-1)},g=c._MOMENTIC_FEATURE_FLAGS?.visual_actions?c.getMPath?.(l)?.join(" >"):`[data-momentic-id=${JSON.stringify(l.getAttribute("data-momentic-id"))}]`;return g?{type:"result",selector:g,relativePoint:m,serializedForm:d.outerHTML.slice(0,500)}:{type:"error",error:"Could not generate selector for parent element"}},{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 iw=["date","datetime-local","month","time","week"],ow={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 aw(n){try{await B(hM(n),{milliseconds:3e3})}catch(e){n.logger.warn({err:e},"Failed to transform native datetime input, continuing...")}}async function hM({root:n,text:e,options:t,logger:r,callbacks:o}){let i=(await Ke({root:n,fn:()=>document.activeElement?.getAttribute("type")??"",timeout:1e3,arg:void 0,waitForPageLoad:o.waitForPageLoad,codePath:"transforming native datetime input"})).toLowerCase();if(!ow[i])return;ow[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 zl({locator:n,callbacks:e,logger:t,timeoutMs:r=1e3}){try{await $p(e,r);let o=n.evaluate(i=>{let a=window;a.momenticIsEligible=p=>{let m=window.getComputedStyle(p,null).getPropertyValue("display");if(m==="none"||m==="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 B(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 $p(n,e=1e3){let t=await n.state.getRoot();await Ke({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:"removing element highlights"})}async function Wp(n){let e=n.flagStore.isBooleanFlagEnabled("visual_actions");return so({action:"clicking element",targetingResult:n.targetingResult,logger:n.logger,retryTimeoutMs:n.retryTimeoutMs,callbacks:n.browserCallbacks,func:async t=>Gp({...n,targetingResult:t,useVisualClick:e})})}async function yM(n,e){let{redirectionAttempts:t=0}=e;if(t>=2)throw n;try{return await bM(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 bM(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"),Gp({...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 xM(a,s,t);if(l)return Gp({...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 wM(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 Yr({promiseGenerator:async()=>s.boundingBox(),timeoutMs:3e3,logger:t}):null}catch(m){throw new R("UserInfrastructureError",`The frame containing the element Momentic was instructed to interact with was removed. Error: ${m.message}`)}finally{await s?.dispose()}let c=Date.now(),{clickX:d,clickY:p,reason:u}=await TM({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:u},duration:Date.now()-c},"Visual click")}async function vM(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 rw({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(RM(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..."),yM(c,{...n,targetingResult:{...i,locator:i}})}}async function Gp(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 SM.TimeoutError?new R("ActionFailureError",`Download did not complete in ${l}ms`):new R("ActionFailureError",`Download failed: ${c.message}`)}})());try{await zl({locator:a.locator,callbacks:r,logger:t,timeoutMs:1e3})}catch(l){t.warn({err:l},"Error highlighting locator in click, continuing...")}if(i?await wM(n):await vM(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 B(s,{milliseconds:e.downloadTimeoutMs??3e4});if(l instanceof Error)throw l;return{downloadedFile:await CM(l,o.createIsolatedFolder,t)}}else throw new Error("No download promise or error but the step requested to wait for a download")}async function EM(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:3e3});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 TM({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,u]=await EM(n,r);i=p.x,a=p.y,s=u}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 xM(n,e,t){let r=await n.evaluate(s=>s.getAttribute("data-momentic-id"));if(!r)return;let o=Pb(r,e,t);if(!o.length){t.error("No candidates found for parent-based locator redirection");return}let i=parseInt(o[0].attributes?.[an]??"");if(isNaN(i))return;n=n.page().locator(`[data-momentic-id="${i}"]`);let a=await yn(n,t);return t.warn({candidateMomenticId:i,serializedHtml:a},"Trying new locator based on parent-direction after covering error"),n}async function CM(n,e,t){t.info("Download detected, saving file to disk");let r=await n.path(),o=zp(n.suggestedFilename()),i=e();await n.saveAs(fM(i,o)),lw(r,{force:!0}),setTimeout(()=>{lw(i,{recursive:!0,force:!0})},5*60*1e3);let a=Wb(gM(i),o);return t.debug({uri:a,downloadFolder:i},"Saved download to isolated folder"),a}function RM(n){return n.message.includes("locator.click: Timeout")&&n.message.includes("click action done")}import{platform as AM}from"os";var IM={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 PM(){let n=AM();return n==="win32"?"win32":n==="darwin"?"darwin":"linux"}function cw(n){return JSON.stringify(n.split("+").sort())}function Hl(n){let e=PM(),t=cw(n);for(let r of Object.values(IM))if(Object.values(r).some(o=>cw(o)===t))return r[e];return process.platform==="darwin"?n=n.replaceAll("Control","Meta"):n=n.replaceAll("Meta","Control"),n}async function Vp({frame:n,page:e,deltaX:t,directionX:r,deltaY:o,directionY:i,signal:a,callbacks:s,logger:l}){if(!t&&!o)return;let c=r==="left"?-1:1,d=i==="up"?-1:1;if(n)await Ke({root:n,fn:([p,u,m,h])=>window.scrollTo(window.scrollX+(p??window.innerWidth)*m,window.scrollY+(u??window.innerHeight)*h),arg:[t,o,c,d],waitForPageLoad:s.waitForPageLoad,timeout:2e3,codePath:"scrolling page"});else{let p=e.viewportSize()||qt,u=await Ke({root:e,fn:()=>document.body.scrollHeight,arg:void 0,waitForPageLoad:s.waitForPageLoad,timeout:2e3,codePath:"computing page height"}),[m,h,g]=await Ke({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:"computing active element position"});await e.mouse.wheel((t??p.width)*c,(o??p.height)*d);try{let f=Date.now();for(;Date.now()-f<2e3;){a?.throwIfAborted();let S=await B(e.evaluate(()=>document.body.scrollHeight),{milliseconds:1e3}),[w,E,y]=await B(e.evaluate(()=>{let x=document.activeElement;if(!x)return[void 0,void 0,void 0];let T=x.getBoundingClientRect();return[x.scrollTop,T.x,T.y]}),{milliseconds:1e3});if(S===u&&w===m&&E===h&&y===g)break;u=S,m=w,h=E,g=y,await Q(500)}}catch(f){l.warn({err:f},"Failed to wait for scroll to complete, continuing...")}}}async function qp(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 Q(500)}throw new Error(`Failed to get tab titles after all retries: ${r?.message}`)}var fi="<empty>";function LM(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 pw(n){let e=n.adFrameStatus?.adFrameType;return e==="child"||e==="root"||LM(n.url)}async function OM(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 Si({cdpClient:n,page:e,logger:t}){let r={type:"root",childFrames:[],page:e},o=[],[i,a]=await Promise.all([n.send({timeout:3e3,method:"Page.getFrameTree",params:{}}),n.send({timeout:3e3,method:"DOM.getDocument",params:{depth:0}})]),c=(i.frameTree.childFrames??[]).map(async(p,u)=>{if(pw(p.frame))return null;try{return await uw({cdpClient:n,rawFrameTree:p,indices:[u],parent:r,warnings:o,logger:t})}catch(m){return o.push(`Failed to get child frame: ${m}`),null}}),d=await Promise.all(c);return r.childFrames=d.filter(p=>p!==null),o.length&&t?.warn({warnings:o},"Got warnings when fetching frame tree"),r}async function uw({cdpClient:n,rawFrameTree:e,indices:t,parent:r,warnings:o,logger:i}){let a=e.frame.id,s=await OM(n,a),l=s.attributes??[],c=null,d=[];for(let h of["src","name","id","title","srcdoc","sandbox"]){let g=vr(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},m=(e.childFrames??[]).map(async(h,g)=>{if(pw(h.frame))return null;try{return await uw({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(m)).filter(h=>h!==null),p}async function MM(n){try{return await n.owner().count()===1}catch{return!1}}async function NM(n){try{return await n.count()===1}catch{return!1}}async function _n(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,fi]){let u=o.frameLocator(p===fi?"iframe":`iframe[${p}]`);if(await MM(u)){d=!0,o=u,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,fi]){let d=o.locator(c===fi?"iframe":`iframe[${c}]`);if(await NM(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 dw(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 mw({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===fi?s=s.length===1?s[0].childFrames:[]:s=s.filter(u=>u.locationData.attributeSelectors.includes(p)).map(u=>u.childFrames).flat()}let l=[],c=t.mPathSelectorTokens[t.mPathSelectorTokens.length-1];if(c===fi?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 _n(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=dw(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 _n(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=dw(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 _n(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 _n(r,n)).frame,handle:r,mPathSelectorTokens:t.mPathSelectorTokens,frameTree:e},logs:i};throw i.push(`Found ${a.length} frames with indices ${t.indices}`),new jn("Failed to find the iframe that previously contained this element",[{type:"AUTO_FRAME",matched:!1,logs:i}])}function jl(n){return n.type==="auto"?JSON.stringify({type:"auto",frameId:n.handle.frameId}):JSON.stringify(n)}function Kp(n){for(;n.parent.type==="frame";)n=n.parent;return n.parent}function hw(n){let e=Kp(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 gw(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 fw({frame:n,logger:e,signal:t}){let r;try{r=await n.frameElement(),await kM({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 kM({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 Yr({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 u=document.activeElement,m,h,g;if(!u)m=void 0,h=void 0,g=void 0;else{let f=u.getBoundingClientRect();m=u.scrollTop,h=f.x,g=f.y}if(c!==void 0&&d!==void 0&&p!==void 0&&m===c&&h===d&&g===p)break;c=m,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 Sw({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 u,m;if(c)try{let h=await r.frameElement();u=await B(h?.boundingBox(),{milliseconds:3e3})??void 0;let g=await t.constructIframeRegex({urls:p,srcs:[],desiredUrl:c});if(g.urlRegex)m={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"),m={type:"url",url:c}}(async()=>{try{await e.recordElementAction({...n,screenshotBase64:o,frameConfig:m,frameBoundingBox:u})}catch(h){i.error({err:h},"Failed to transform passive click action")}})()}import{randomUUID as Dn}from"crypto";import _M from"js-beautify";var DM=["Dead"],$l=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:Dn(),type:"PRESET_ACTION",command:Bn(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=Bn(i);a={id:Dn(),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=Bn(i);a={id:Dn(),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=Bn(i);a={id:Dn(),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=_M.html(p,{indent_size:1,indent_with_tabs:!1,preserve_newlines:!1}),p=Eb(p,"data-momentic-interacted",4e4)}catch{}let u;try{u=(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"),u=s}let m=this.recordedSteps.get(d)?.step??a,h=m?.command;h&&"target"in h&&h.target?(h.target={type:"description",elementDescriptor:u},this.callbacks.onStepRecorded({...m,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(DM.includes(t)||this.signal.aborted)return;let o="normal";t.length>1&&(o="special");let i;if(o==="normal"){let p=Bn("TYPE");i={id:Dn(),type:"PRESET_ACTION",command:{...p,target:void 0,value:t,clearContent:!1}}}else{let p=Bn("PRESS");i={id:Dn(),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,u=i.command.value;i={id:Dn(),type:"PRESET_ACTION",command:{...d,value:i.command.type==="PRESS"?`${p}+${u}`:`${p}${u}`}},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:Dn(),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=Bn(c);d.deltaY=Math.abs(i);let p={id:Dn(),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=Bn(c);d.deltaX=Math.abs(i);let p={id:Dn(),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 Gl=class{smartWaitingTimeoutMs;pageLoadTimeoutMs;allowPartialAccessibilityTree;logger;cdpClient;pageGetter;abortSignalGetter;flagStore;enricher;iconKnowledgeBase;activeFrameCache;activeFrameConfig;lastA11yIdToNodeMap={};lastDataMomenticIdToNodeMap={};lastSelectorToNodeMap={};lastA11yTreeRoot;lastDomGraph;constructor({smartWaitingTimeoutMs:e,pageLoadTimeoutMs:t,allowPartialAccessibilityTree:r,logger:o,cdpClient:i,pageGetter:a,flagStore:s,abortSignalGetter:l,enricher:c,iconKnowledgeBase:d}){this.smartWaitingTimeoutMs=e,this.pageLoadTimeoutMs=t,this.allowPartialAccessibilityTree=r,this.logger=o,this.cdpClient=i,this.pageGetter=a,this.flagStore=s,this.abortSignalGetter=l,this.enricher=c,this.iconKnowledgeBase=d}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=Kp(e),{frame:o,mPathSelectorTokens:i}=await _n(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 Si({cdpClient:this.cdpClient,page:t,logger:this.logger}),{resolution:o,logs:i}=await mw({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(jl(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:jl(this.frameConfig),cacheTime:Date.now(),frameTree:this.frameConfig.frameTree,mPathSelectorTokens:this.frameConfig.mPathSelectorTokens},await fw({frame:r.frame,logger:e,signal:t}),this.activeFrameCache=r,r}async executeFunctionInAllFrames(e,t){let r=this.pageGetter(),o=await Si({cdpClient:this.cdpClient,page:r,logger:this.logger}),i=[B(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(_n(l,r).then(({frame:d})=>B(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 Si({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 sn({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 sn({fn:()=>Si({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 sn({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 sn({fn:()=>this.getDOMTree({devicePixelRatio:e.devicePixelRatio??1,signal:o,logger:r}),codePath:"domFetch",logObject:t,signal:o,logger:r}),d=await sn({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 sn({fn:()=>this.composeA11yDomGraph({opts:e,a11yGraph:d,domGraph:c,startingFrameId:l,frameContext:s,logger:r,iconKnowledgeBase:this.iconKnowledgeBase,showZeroOpacityElements:!!e.showZeroOpacityElements}),codePath:"a11yProcess",logObject:t,signal:o,logger:r});return Object.values(t).some(u=>u>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:jr,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=Lb({node:o,domGraph:this.domGraph});return Ob(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 Mb(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(`[${an}="${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 Si({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 Q(500,t)}finally{l++}if(a)return{source:"url",frame:a.frame,handle:a.handle,frameIdentifierStringified:jl(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=vr(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 _n(s,o)});break}}else if(r.trim()===p.trim()){a.push({handle:s,matchType:"url",...await _n(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,showZeroOpacityElements:l}){let c=await Hb({rawA11yGraph:t,startingFrameId:o,frameContext:i,domGraph:r,logger:a,cdpClient:this.cdpClient,showZeroOpacityElements:l,filterByViewport:e.filterByViewport,viewportDetails:void 0,iconKnowledgeBase:s,useMPaths:this.flagStore.isBooleanFlagEnabled("visual_actions")});if(!c||!c.root)throw new Error("Accessibility tree appears empty");return{tree:c}}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 _n(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 Ke({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:"adding Momentic element IDs to the page"})??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(vr(t,"aria-hidden")==="true")return{shouldUnroll:!1,reason:"aria-hidden"};let r=vr(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(m){i.warn({err:m},"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 m=0;m<3;m++)try{c=await sn({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),u=[];for(;p.length>0;){let m=p.shift();try{let{shouldUnroll:g}=await this.decideChildFrameUnrollEligibility({handle:m,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 ${m.frameId} with url ${m.url}, allowing it to be fetched: ${g}`)}p.push(...m.childFrames);let h=async()=>{try{let g=await sn({fn:()=>this.getRawA11yTreeForFrame({frameId:m.frameId,timeoutMs:this.smartWaitingTimeoutMs,logTimings:o}),codePath:`a11y-tree-fetch-child-${m.frameId}`,logObject:o,signal:a,logger:i});d[m.frameId]=g}catch(g){i.warn({err:g,url:m.url,src:m.src},`Error getting raw a11y tree for child frame ${m.frameId}, continuing...`)}};u.push(h())}return await Promise.all(u),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 sn({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 sn({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 sn({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,a;for(;!o&&i<3;)try{if(o=await this.cdpClient.send({method:"DOMSnapshot.captureSnapshot",params:{computedStyles:Fl},timeout:3e3}),!o||!o.documents.length)throw new Error("Got empty DOM tree")}catch(s){await Q(500,t),i++,a=s}if(!o||!o.documents.length)throw r.error({err:a},"Fatal error fetching DOM tree"),new R("UserInfrastructureError","Received an empty HTML snapshot from the browser. This indicates the page has crashed due to resource consumption issues or hanging client-side JavaScript code.");return Ib({snapshot:o,devicePixelRatio:e,logger:r})}constructIframeRegexAsync(e,t){if(t.frameSrcRegex||t.frameUrlRegex)return;let r=hw(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...")}})()}};function Yp(n){let e=[],t="";for(let r of n)r==="+"&&t?(e.push(t),t=""):t+=r;return e.push(t),e}function yw(n){return async(e,t)=>{let r=await t.allHeaders();for(let{key:o,value:i,matcher:a}of n)(!a||a.test(t.url()))&&(r[o]=i);await e.continue({headers:r})}}var Jp=yi(Xp(),"momentic","chromium"),rN=yi(Xp(),"video"),ql=process.env.TWO_CAPTCHA_KEY,Aw=eN(Rw);Aw.use(tN({provider:{id:"2captcha",token:ql},visualFeedback:!0}));var Fn=class n{static USER_AGENT=QM["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={};requestRecorders={};customHeaders=[];enricher;storage;flagStore;logger;stateManager;transformer;lastScreenshotForRecording=void 0;originsVisited=new Set;viewport;videos=[];baseUrl;constructor({storage:e,flagStore:t,enricher:r,browser:o,context:i,page:a,baseUrl:s,logger:l,mockedServices:c,userBrowserSettings:d,viewport:p,properties:u,clientCallbacks:m,iconKnowledgeBase:h}){if(tf(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||qt,this.properties=u,this.clientCallbacks=m,u.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","geolocation"]);let e=this.flagStore.getAllFlags(),t=[this.context.addInitScript({content:mb.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'); });`})];await this.context.route("**/*",yw(this.customHeaders));let 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"&&YM()==="darwin"&&jM("system_profiler SPDisplaysDataType").toString().includes("Retina")?(b.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 Bl.init({logger:this.logger,contextGetter:()=>this.context,pageGetter:()=>this.page,defaultTimeoutMs:this.pageLoadTimeout}),await this.initializeScreencast(),this.stateManager=new Gl({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,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,recordVideo:c,iconKnowledgeBase:d,callbacks:p}){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 m={headless:process.env.MOMENTIC_HEADFUL_BROWSER!=="true",handleSIGTERM:!1,chromiumSandbox:!1,channel:u},h={...l??{},geolocation:l?.geolocation||Fo,locale:l?.locale||_o,timezoneId:l?.timezoneId||Do,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??qt},g=["--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"],f=null,S,w,E={systemDevicePixelRatio:l?.deviceScaleFactor,recordVideo:c,isNewHeadless:!1};(s.browserType==="Chromium"||s.browserType==="Google Chrome")&&(E.isNewHeadless=!0,m.headless&&g.push("--headless=new")),process.env.BROWSER_MEMORY_MB&&g.push(`--js-flags=--max_old_space_size=${process.env.BROWSER_MEMORY_MB}`),s.disableGpu&&g.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 y=s.localChromeExtensionPaths?.map(T=>T.startsWith("~")?yi(Xp(),T.slice(1)):T);if(y?.length){if(s.browserType==="Chrome for Testing")throw new R("UserConfigurationError","Chrome extensions are only supported on Chromium and Google Chrome.");for(let L of y){let j=yi(L,"manifest.json");if(!Vl(j))throw new R("UserConfigurationError",`Chrome extension path ${j} does not exist.`)}let T=yi(Jp,`momentic-session-${Date.now()}`);if(!Vl(T))try{GM(T,{recursive:!0})}catch(L){throw new R("UserConfigurationError",`Failed to create browser cache directory. Please make sure you have sufficient permissions to create the ${Jp} folder: ${L}`)}let A=[...g],D=y.map(L=>ZM(L)).join(",");A.push(`--disable-extensions-except=${D}`),h?.deviceScaleFactor&&A.push(`--force-device-scale-factor=${h.deviceScaleFactor}`,`--device-scale-factor=${h.deviceScaleFactor}`),h.viewport&&A.push(`--window-size=${h.viewport.width},${h.viewport.height}`),S=await Rw.launchPersistentContext(yi(Jp,`momentic-session-${Date.now()}`),{...m,...h,ignoreDefaultArgs:["--disable-extensions","--disable-component-extensions-with-background-pages"],args:A,baseURL:e}),t.debug({sharedContextOptions:h,sharedBrowserOptions:m,userBrowserSettings:s,chromeArgs:A,flags:o.getAllFlags()},"Browser initialization context args (persistent)"),w=S.pages()[0]}else{f=await Aw.launch({...m,args:g});let T={...h,baseURL:e,recordVideo:c?{dir:rN}:void 0};S=await f.newContext(T),t.debug({contextArgs:T,sharedBrowserOptions:m,chromeArgs:g,userBrowserSettings:s,flags:o.getAllFlags()},"Browser initialization context args (standard)"),w=await S.newPage()}let x=new n({browser:f,context:S,page:w,baseUrl:e,logger:t,storage:r,flagStore:o,mockedServices:a||{},enricher:i,userBrowserSettings:s,viewport:h.viewport||qt,properties:E,clientCallbacks:p,iconKnowledgeBase:d});return await x.initialize(),x}async handleAvailableTabsChangeHelper(){try{let e=await qp(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=Ew(),o=`${e}-${r}`,i=Date.now(),a=!1,s=async()=>{try{await B(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()||!Jr(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=Ew(),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=>{Yb(e,o,this.debugData,a,this.logger)}),e.on("request",a=>{tw(t,this.debugData,a,this.logger),this.recordRequest(a)});let i=async()=>{await ew(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=Nb({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:KM()};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"||!Jr(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 B($p(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 Ke({fn:()=>{let l=window;return!!(l.generateCssSelectors&&l.evaluateCssSelectors&&l.evaluatePrimaryCaches&&l.generateHtmlCacheAttributes&&l.ldist)},timeout:1e3,arg:void 0,waitForPageLoad:()=>this.waitForPageLoad(),root:e,codePath:"ensuring Momentic system scripts are loaded"}))return}catch(s){if(i++,i>=3){t.warn({err:s},"Multiple errors checking if Momentic scripts are loaded, aborting...");return}}await Q(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),Ke({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:"getting the full HTML tree"})}url(){return this.page.url()}async stabilizePageForScreenshot(){try{await this.evaluateFunctionInPage(()=>{let e=window,t=[],r=new Map;document.querySelectorAll("input,textarea,[contenteditable]").forEach(o=>{r.set(o,{value:o.style.getPropertyValue("caret-color"),priority:o.style.getPropertyPriority("caret-color")}),o.style.setProperty("caret-color","transparent","important")}),t.push(()=>{for(let[o,i]of r)o.style.setProperty("caret-color",i.value,i.priority)}),e._MOMENTIC_SCREENSHOT_CLEANUP=()=>{for(let o of t)o();delete e._MOMENTIC_SCREENSHOT_CLEANUP}},void 0,"stabilizing page for screenshot")}catch(e){(!(e instanceof Error)||!e.message.includes("Execution context was destroyed"))&&this.logger.warn({err:e},"Failed to stabilize page before screenshot, continuing...")}}async removeScreenshotStabilization(){try{await this.evaluateFunctionInPage(()=>{window._MOMENTIC_SCREENSHOT_CLEANUP?.()},void 0,"removing screenshot stabilization")}catch{}}async screenshot(e){let{retries:t=1,stabilizeBeforeScreenshot:r=!1}=e,o=this.page.url();r&&await this.stabilizePageForScreenshot();let i=Date.now();try{await this.fixViewportForNewHeadless();let a=await this.screenshotHelper({...e,retries:t});if(a.byteLength>5e6)this.logger.error("Page screenshot is greater than 5MB, which may cause performance issues with some AI models");else if(a.length===0)throw new Error("Got empty screenshot");return a}catch(a){if(t<=0||a.message.includes("has been closed"))throw a;return this.logger.debug({err:a,pageUrl:o},"Failed taking screenshot, retrying..."),await Q(250),this.screenshot({...e,retries:t-1})}finally{Date.now()-i>1e3&&this.logger.warn({pageUrl:o,duration:Date.now()-i},"Screenshot took longer than expected"),r&&await this.removeScreenshotStabilization()}}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 Tw.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&&VM(r,l),this.lastScreenshotForRecording=l,!e)return l;let u=await e.boundingBox({timeout:3e3});if(!u)throw new Error("Attempted to screenshot an element that is not visible on the page");let{x:m,y:h,width:g,height:f}=u;if(!g||!f)throw new Error("Attempted to screenshot an element with zero width or height");if(m<0||h<0)throw new Error("Attempted to screenshot an element with negative coordinates");m=Math.floor(m),h=Math.floor(h),g=Math.floor(g),f=Math.floor(f);try{l=await(await Tw.fromBuffer(l)).crop({x:m,y:h,w:g,h:f}).getBuffer("image/jpeg")}catch(S){throw new Error(`Failed taking element screenshot at coordinates (${m}, ${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}){nS(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 Q(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(Tb.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 Ke({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:"getting the active element"})}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 aw({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 Q(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.debug({activeElementDetails:i},"Currently active element is not eligible for replace content, skipping...")),await this.page.keyboard.type(e,{delay:t.delay??pm}),t.pressEnter&&await this.press("Enter",{})}async scrollIntoViewIfNeeded(e){try{await e.scrollIntoViewIfNeeded({timeout:2e3})}catch(t){this.logger.warn({err:t},"Failed to scroll into view, trying with raw JS");try{await e.evaluate(async r=>{let o=r.scrollTop;r.scrollIntoView(),await new Promise(a=>setTimeout(a,250));let i=Date.now();for(;Date.now()-i<1e3;){let a=r.scrollTop;if(a===o)break;o=a,await new Promise(s=>setTimeout(s,250))}},void 0,{timeout:2e3})}catch(r){this.logger.warn({err:r},"Failed to scroll into view using JS, continuing...")}}}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 zl({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 Kb(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 qb(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 Vb(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 qp(this.context,e)}saveA11yDetailsToCache(e,t){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 updateCacheWithNewNodeDetails({node:e,target:t,locator:r,forceSaveNewCssSelectors:o,startingBoundingBox:i,allowZeroOpacityOverride:a,logger:s=this.logger}){if(e&&this.saveA11yDetailsToCache(e,t),t.frameCache=this.stateManager.saveAutoFrameCacheDetails(t.frameCache),r)try{let l=await this.fetchHtmlAttributes({locator:r,logger:s,startingBoundingBox:i,allowZeroOpacityOverride:a}),c=!1;for(let d of["generatedSelectors","serializedHtml","nodeOnlySerializedHtml","hybridSelector"]){let p=l?.[d];if(p&&!t[d]){c=!0;break}if(p&&JSON.stringify(p)!==JSON.stringify(t[d])){c=!0;break}}l&&(o||c)&&(t.generatedSelectors=l.generatedSelectors,t.serializedHtml=l.serializedHtml,t.nodeOnlySerializedHtml=l.nodeOnlySerializedHtml,t.hybridSelector=l.hybridSelector)}catch(l){if(l instanceof Rn)throw l;s.warn({err:l},"Failed to fetch HTML attributes for target, continuing...")}try{await this.saveElementVisualAttributes({target:t,locator:r,logger:s,boundingBox:i})}catch(l){s.debug({err:l},"Failed to save element visual details, continuing...")}}async saveElementVisualAttributes({target:e,locator:t,logger:r,boundingBox:o}){if(!t)return{scrollPerformed:!1};if(!Ip.includes(e?.role??""))return{scrollPerformed:!1};if(await this.scrollIntoViewIfNeeded(t),o||(o=await t.boundingBox({timeout:3e3})),!o||!o.width||!o.height)return r.debug("Skipping visual attributes saving for element with no bounding box after action"),e.boundingBox=void 0,e.screenshotUrl=void 0,{scrollPerformed:!0};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)return{scrollPerformed:!0};e.boundingBox=o;let c=await this.screenshot({locator:t,quality:75,retries:0});return e.screenshotUrl=await this.storage.uploadScreenshot(c),{scrollPerformed:!0}}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:w}=await this.stateManager.getAutoFrameDetailsFromHandle(f);c=S,d=w,l=w.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 u=await this.stateManager.getLocatorFromA11yNode({page:this.page,root:l,node:a}),m={id:e,inputDescription:t??void 0,targetSource:r,targetUpdateTime:new Date().toISOString(),frameCache:c},h,g=!1;o||(d&&(i.debug({frameConfigSource:p,frameConfig:gw(d)},"A11y node was resolved to a target within an iframe"),h=this.stateManager.frameConfig,this.stateManager.setActiveFrameConfig(d),g=!0),await this.updateCacheWithNewNodeDetails({node:a,target:m,locator:u,logger:i,forceSaveNewCssSelectors:!0,allowZeroOpacityOverride:!0}));try{return{resolution:{locator:u,a11yNode:a,displayString:a.getNodeOnlySerializedForm(),decisions:[]},target:m,frameConfig:d,frameConfigSource:p}}finally{g&&this.stateManager.setActiveFrameConfig(h)}}async resolveTarget(e,t,r={}){let{targetName:o,logger:i=this.logger,signal:a=this.abortSignal,allowZeroOpacityOverride:s}=r;if(t.frameCache&&this.flagStore.isBooleanFlagEnabled("auto_expand_iframes")){let m,h=!1,g=Date.now();for(;Date.now()-g<this.smartWaitingTimeout;)try{let f=await this.stateManager.resolveAutoFrameCache(t.frameCache);this.setActiveFrameConfig(f),h=!0;break}catch(f){m=f,await Q(500,a)}if(!h)throw m}let l=await this.getActivePageOrFrame();await this.ensureMomenticBrowserScriptsLoaded(l,i,a);let c=Date.now(),d=0,p=0,u;for(;Date.now()-c<this.smartWaitingTimeout;){this.abortSignal?.throwIfAborted(),d++;let m=d===1||Date.now()-c>this.smartWaitingTimeout-2e3&&d%2===0;try{u=await this.resolveTargetHelper({root:l,target:t,primaryOnly:!0,logger:m?i:jr,allowZeroOpacityOverride:s,signal:a});break}catch(h){if(h instanceof oa)break;if(h instanceof Rn){if(p++,p>2)throw i.error({err:h},"Got multiple cache disqualification errors, giving up"),h;i.warn({err:h},"Got cache disqualification error, waiting and retrying resolution"),await Q(500,a)}a?.throwIfAborted(),m&&i.debug({err:h},`Could not resolve target through CSS selectors only (x${d})`),await Q(500,a)}}return u||(u=await this.resolveTargetHelper({root:l,target:t,primaryOnly:!1,logger:i,signal:a,allowZeroOpacityOverride:s}),t.targetSource="HEURISTIC_HEALED",t.targetUpdateTime=new Date().toISOString(),t.targetUpdateLoggerTags=ze(i),i.debug({decisions:u.decisions},"Target resolution succeeded after waiting")),e?.details?.push({type:"TARGETING",name:o,elementLocationDecisions:u?.decisions??[],pageState:void 0,targetSource:t.targetSource,targetUpdateTime:t.targetUpdateTime}),u}async resolveTargetHelper({root:e,target:t,primaryOnly:r,logger:o,signal:i,allowZeroOpacityOverride:a}){let s=[],l=(await this.getBrowserState({logger:o,abortSignal:i,skipWait:!0,allowZeroOpacityOverride:a})).serialize();o.debug({tree:l.length>4e5?l.slice(0,4e5):l},"Got a11y tree before attempting target resolution");let c;if(t.generatedSelectors||t.hybridSelector){let d;try{d=await this.resolveTargetWithPrimaryMethods({root:e,target:t,logger:o,allowZeroOpacityOverride:a})}catch(p){c=p}if(d)return{...d,pageState:void 0,decisions:[...s,...d.decisions]};r||(s.push({type:"CSS_SELECTOR",matched:!1,reason:c?.message,selectors:xw(t.generatedSelectors??[])}),t.generatedSelectors=void 0,t.hybridSelector=void 0)}if(r)throw c;if(!this.flagStore.isBooleanFlagEnabled("disable_secondary_cache_resolution")){let d=await this.resolveTargetWithSecondaryMethods({root:e,tree:l,target:t,decisions:s,logger:o,signal:i,allowZeroOpacityOverride:a});if(d)return d}throw o.warn({target:t,decisions:s},"Failed to find any relevant node"),new jn(`Could not find any relevant node given target: ${JSON.stringify(t)}`,s)}async resolveTargetWithPrimaryMethods({root:e,target:t,logger:r,allowZeroOpacityOverride:o}){if(!t.nodeOnlySerializedHtml)throw new oa("Insufficient data to resolve target using primary methods (missing node HTML)");let i=this.userControlledBrowserSettings.hybridSelectorMode,a={ldistThreshold:.05,requireBoundingBox:!o,ignoreHrefForCaching:this.userControlledBrowserSettings.ignoreHrefForCaching,requireMatchingBoundingBox:this.userControlledBrowserSettings.bustCacheOnBoundingBoxChange?t.boundingBox:void 0},{css:s,hybrid:l}=await Ke({fn:S=>window.evaluatePrimaryCaches(S),arg:{cssParams:{selectors:t.generatedSelectors??[],cachedElementSerialized:t.nodeOnlySerializedHtml,opts:a},hybridParams:i&&t.hybridSelector?{nodes:t.hybridSelector,cachedElementSerialized:t.nodeOnlySerializedHtml,opts:a}:void 0},root:e,timeout:3e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"evaluating target caches"}),c,d,p=[];if(i==="prefer"&&l?.result){c=l,d=l.result;let S={type:"HYBRID_SELECTOR",matched:!0,logs:l.logs,reason:"Discovered a match using Momentic's hybrid text and CSS selector approach"};p.push(S)}else if(s?.result)c=s,d=s.result,p.push({type:"CSS_SELECTOR",matched:!0,logs:s.logs,reason:`${d.workingSelectors.length} CSS selectors matched the following element: ${d.serializedElement}`,selectors:d.workingSelectors.slice(0,5)});else throw p.push({type:"CSS_SELECTOR",matched:!1,reason:s.logs.length===1?"CSS evaluation failed":"No CSS selectors matched",selectors:[],logs:s.logs}),l&&p.push({type:"HYBRID_SELECTOR",matched:!1,reason:l.logs.length===1?"Hybrid evaluation failed":"No hybrid selectors matched",logs:l.logs}),new jn("Cache evaluation failed",p);let u,m,h,g=!1;if(this.flagStore.isBooleanFlagEnabled("visual_actions")){let S=d.mPath;if(!S)throw new Error("Found element did not have an mPath despite using visual actions");let w=S.join(" > ");u=e.locator(w),m=this.stateManager.getNodeUsingMPathSelector(w)}else if(d.dataMomenticId!==void 0)h=parseInt(d.dataMomenticId),m=this.stateManager.dataMomenticIdToNodeMap[h],"workingSelectors"in d?(u=e.locator(d.workingSelectors[0]),g=d.workingSelectors.length<5):u=e.locator(`[data-momentic-id=${JSON.stringify(h)}]`);else throw new R("InternalWebAgentError","Received an element resolution result with no identifying attributes");i&&t.hybridSelector&&(l?.logs.length===1?r.warn({hybridResult:l,cssResult:s,hybridMode:i},"Hybrid selector resolution rejected, continuing..."):l?.result?s?.result&&l?.result&&l.result.serializedElement!==s.result.serializedElement&&(this.flagStore.isBooleanFlagEnabled("visual_actions")&&JSON.stringify(s.result.mPath)!==JSON.stringify(l.result.mPath)?r.warn({originalCache:t,hybridResult:l,cssResult:s,hybridMode:i,mode:"visualActions"},"Hybrid selector resolution returned a different element than CSS selector resolution, continuing..."):s.result.dataMomenticId!==l.result.dataMomenticId&&r.warn({originalCache:t,hybridResult:l,cssResult:s,hybridMode:i,mode:"dataMomenticId"},"Hybrid selector resolution returned a different element than CSS selector resolution, continuing...")):r.warn({originalCache:t,hybridResult:l,cssResult:s,hybridMode:i},"Hybrid selector resolution returned no eligible elements while CSS resolution did, continuing..."));let f=xw(t);return await this.updateCacheWithNewNodeDetails({node:m,target:t,locator:u,logger:r,startingBoundingBox:d.boundingBox,forceSaveNewCssSelectors:g,allowZeroOpacityOverride:o}),r.info({diffs:$M(f,t),locationResult:c},"Updated cache with new details after resolution"),{a11yNode:m,displayString:d.serializedElement,locator:u,decisions:p}}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 u=s.locator(r),m;try{return await u.waitFor({state:"attached",timeout:1e3}),m=await yn(u,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:u,displayString:m,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 Q(500,i)}}throw d}async resolveTargetWithSecondaryMethods(e){if(!e.target.boundingBox)return;let{x:t,y:r,width:o,height:i}=e.target.boundingBox,a=await this.resolveTargetWithSecondaryMethodsHelper(e);if(!a)return;let s=await a.locator.boundingBox({timeout:3e3});if(!s){this.logger.debug({proposedNode:a.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-o)>10||Math.abs(p-i)>10){this.logger.debug({newW:d,oldW:o,newH:p,oldH:i,proposedNode:a.displayString},"Rejecting secondary matching result due to difference in dimensions");return}else if(!t||!r||!l||!c){this.logger.debug({oldX:t,oldY:r,newX:l,newY:c,proposedNode:a.displayString},"Rejecting secondary matching result due to missing x/y coords");return}else if(Math.abs(l-t)>100||Math.abs(c-r)>100){this.logger.debug({newX:l,newY:c,oldX:t,oldY:r,proposedNode:a.displayString},"Rejecting secondary matching result due to large difference in x/y coords");return}return a}async resolveTargetWithSecondaryMethodsHelper({root:e,target:t,decisions:r,logger:o,signal:i,allowZeroOpacityOverride: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 Ke({fn:p=>window.findClosestElementByLDist?.(p),arg:{nodeOnlySerializedHtml:t.nodeOnlySerializedHtml},timeout:2e3,root:e,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"finding the closest element on the page"}),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,u,m;if(p)u=this.stateManager.dataMomenticIdToNodeMap[p],m=e.locator(`[${an}="${p}"]`);else if(c.mPathSelector)u=this.stateManager.getNodeUsingMPathSelector(c.mPathSelector),m=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 yn(m,o)??"unknown element";return o.warn({result:c,originalTarget:t,displayString:h},"Resolved cached target to new node with pure html levenshtein distance"),await this.updateCacheWithNewNodeDetails({node:u,target:t,locator:m,logger:o,startingBoundingBox:c.boundingBox,allowZeroOpacityOverride:a,forceSaveNewCssSelectors:!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:m,a11yNode:u,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&&Ip.includes(l))try{let c=await this.resolveTargetWithTemplateMatching({root:e,oldTarget:t,screenshotUrl:s,signal:i,allowZeroOpacityOverride: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,allowZeroOpacityOverride: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=nN(),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:u,locator:m}=await this.getTargetFromPositionPercentages({percentX:p.x,percentY:p.y,allowZeroOpacityOverride:i}),h=u.boundingBox?.width,g=u.boundingBox?.height;if(!h||!g)throw a="Rejecting target from screenshot due to no bounding box",new Error(a);let f=u.id,S=this.stateManager.a11yIdToNodeMap[f];return await this.updateCacheWithNewNodeDetails({target:r,node:S,locator:m,forceSaveNewCssSelectors:!0,allowZeroOpacityOverride:i}),{locator:m,a11yNode:S,displayString:u.nodeOnlySerializedHtml??"",decisions:[{type:"TEMPLATE_MATCHING",matched:!0,reason:"Found element using screenshot",elementImageUrl:t}]}}async typeIntoTarget(e,t,r={}){await this.highlight(t.locator);let o=await t.locator.getAttribute("type",{timeout:1e3})??"",i=iw.some(a=>a===o.toLowerCase());return await Wp({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 Wp({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(),tS(s,t,r)){a=!0;break}await Q(500,this.abortSignal)}if(!a)throw new R("ActionFailureError",`The active page URL ${r?.negated?"still does":"does not"} ${Ud(t)} in ${o}ms.
3913
+ 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:3e3});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 Q(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(jp);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 Q(250),await this.page.mouse.up()}async hover(e){await this.highlight(e.locator),await so({func:async t=>{await this.scrollIntoViewIfNeeded(t.locator);let r=await t.locator.boundingBox({timeout:3e3});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 so({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 Ke({fn:()=>{let r=document.activeElement;r&&r.nodeType===1&&r.blur()},root:t,arg:void 0,waitForPageLoad:()=>this.waitForPageLoad(),timeout:1e3,codePath:"blurring the active element"});return}await this.highlight(e.locator),await so({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 so({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=Hl(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 keyDown(e,t){if(t.convertMeta){let r=Hl(e);r!==e&&(this.logger.debug({keyString:e,convertedKey:r},"Converted platform dependent keys"),e=r)}for(let r of Yp(e))await this.page.keyboard.down(r)}async keyUp(e,t){if(t.convertMeta){let r=Hl(e);r!==e&&(this.logger.debug({keyString:e,convertedKey:r},"Converted platform dependent keys"),e=r)}for(let r of Yp(e))await this.page.keyboard.up(r)}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"}),await this.waitForDOMStability()}async getBrowserState(e){let{maxAttempts:t=2,logger:r=this.logger,skipWaitForPageLoad:o,allowZeroOpacityOverride:i}=e,a=e.abortSignal??this.abortSignal,s=i??this.userControlledBrowserSettings.showZeroOpacityElements;o||await this.waitForPageLoad(),e.skipWait||await this.waitForDOMStability({logger:r,signal:a});let l=0,c;for(;l<t;){l++;try{return await B(this.stateManager.getA11yTree({devicePixelRatio:this.devicePixelRatio,abortSignal:a,logger:r,filterByViewport:e.filterByViewport,showZeroOpacityElements:s}),{milliseconds:this.pageLoadTimeout*l,signal:a,message:"Getting browser state took too long"})}catch(d){if(a?.throwIfAborted(),c=d instanceof Error?d.message:`${d}`,l>=t)throw d;r.debug({err:d,url:this.url()},"Error getting a11y tree, retrying...")}}throw new R("ActionFailureError",`Getting page content failed after ${t} attempts. Error: ${c}`)}async getViewportOffsetDetails(e){let[t,r,o,i,a]=await Ke({root:e,fn:()=>[window.scrollY,window.scrollX,window.screen.width,window.screen.height,window.devicePixelRatio],arg:void 0,timeout:3e3,waitForPageLoad:async()=>{},codePath:"getting current viewport details"});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=u=>{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,stabilizeBeforeScreenshot:!0},c=!1,d=0;for(;Date.now()-a<r;){if(o?.throwIfAborted(),await Q(500,this.abortSignal),s)try{let u=await this.screenshot(l);if(!u.equals(s)){s=u,c=!1;continue}c=!0}catch(u){d++,d%3===0&&t.warn({err:u,screenshotErrors:d},"Failed to take screenshot for DOM stability check"),o?.throwIfAborted()}else try{s=await this.screenshot(l)}catch(u){d++,d%3===0&&t.warn({err:u,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.debug(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 Q(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(jp);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 Q(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 B(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 w=0;w<s.length;w++)if(l[w]===e){p=c.indexOf(w);break}if(p===-1)throw new Error(`Could not find any backend node with ID ${e}`);let[u=0,m=0,h=0,g=0]=d[p];u/=r,m/=r,h/=r,g/=r;let f=u+h/2,S=m+g/2;return{centerX:f,centerY:S}}async scrollVertical(e){return Vp({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(),logger:this.logger})}async scrollHorizontal(e){return Vp({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(),logger:this.logger})}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 B(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 Q(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)}.
3914
+ Available pages:${JSON.stringify(r.map(i=>i.url))}`);if(!Jr(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=_s(e):t=[e],await this.context.addCookies(t),t}async setLocalStorage(e,t){let r;for(let o=0;o<2;o++)try{await this.evaluateFunctionInPage(([i,a])=>{i&&localStorage.setItem(i,a||"")},[e,t],`setting local storage key ${e}`);return}catch(i){r=i}if(r)throw r}async solveCaptcha(){await this.getBrowserState({allowZeroOpacityOverride:!0});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:ql,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 Q(2500);let s=await fetch("https://api.2captcha.com/getTaskResult",{method:"POST",body:JSON.stringify({clientKey:ql,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&&Sw({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];Jr(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.debug({url:i,codePath:r},"Skipping load for chrome-error:// URL");return}try{await Yr({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 ${je(i,50)} did not load within the configured timeout (${o}ms): ${s}`);if(!s.message.includes("detached"))throw s}try{await Yr({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 qM.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 Ke({fn:()=>window.getCondensedHtmlTree(),root:e,arg:void 0,timeout:2e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"getting condensed HTML tree"});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,r){let o=await this.getActivePageOrFrame();return Ke({root:o,fn:e,arg:t,timeout:2e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:r})}async evaluateCodeInPage({code:e,fragment:t,context:r,timeoutMs:o=lr}){let i=nw(),a={code:e,fragment:t,context:r},{result:s}=await B(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),u=d+c,m=p+l;return this.getDomNodeFromPixelPosition(u,m)}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:Ab,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 getTargetFromPositionPercentages(e){let t=await this.getActivePageOrFrame(),r=await this.getDomNodeFromPositionPercentages(t,e);return this.getTargetFromBackendNodeId({root:t,backendNodeId:r.backendNodeId,allowZeroOpacityOverride:e.allowZeroOpacityOverride})}async getTargetFromBackendNodeId({root:e,backendNodeId:t,allowZeroOpacityOverride: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[an],a=parseInt(i??"");if(!i||isNaN(a))throw new Error("No data-momentic-id was found on the DOM node");let s=e.locator(`[${an}="${i}"]`),l;o.bounds.x!==null&&o.bounds.y!==null&&(l={x:o.bounds.x,y:o.bounds.y,width:o.bounds.width??0,height:o.bounds.height??0});let c=await this.fetchHtmlAttributes({locator:s,logger:this.logger,startingBoundingBox:l,allowZeroOpacityOverride:r}),d={id:-1,dataMomenticId:a,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString(),...c};return this.logger.debug({target:d},"Tied backend ID to HTML node"),{target:d,locator:s}}async performTargetRedirection(e,t,r){try{return await this.scrollIntoViewIfNeeded(e),await B(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 yn(e,t);if(r===void 0&&(r=await e.boundingBox({timeout:3e3})??void 0),!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:u,mPathSelector:m,error:h,serializedElement:g,point:f,force:S,logs:w}=await e.evaluate(y=>{let x=window;if(!x.performTargetRedirection)throw new Error("performTargetRedirection script is not defined");return x.performTargetRedirection(y)},void 0,{timeout:1e3}),E=Date.now()-o;if(h){t.warn({error:h,serializedElement:g,duration:E,force:S,logs:w},"Got error from target redirection with bounding box");return}else{if(u)return t.debug({newDataMomenticId:u,serializedElement:g,duration:E,force:S,logs:w},"Redirected target to new element with bounding box with data-momentic-id"),{locator:p.locator(`[data-momentic-id="${u}"]`),hints:{clickableXY:f,force:S}};if(m)return t.debug({newMPathSelector:m,serializedElement:g,duration:E,force:S,logs:w},"Redirected target to new element with bounding box with mPath"),{locator:p.locator(m),hints:{clickableXY:f,force:S}};if(f)return t.debug({point:f,serializedElement:g,duration:E,force:S,logs:w},"Chose specific visible point on original element"),{locator:e,hints:{clickableXY:f,force:S}};if(S)return t.debug({serializedElement:g,duration:E,force:S,logs:w},"Forcing click on original element"),{locator:e,hints:{force:S}}}}async fetchHtmlAttributes({locator:e,logger:t=this.logger,startingBoundingBox:r,allowZeroOpacityOverride:o}){let i=await e.evaluate((a,s)=>{let l=window;return l.generateHtmlCacheAttributes?l.generateHtmlCacheAttributes(a,s):{warnings:[],error:"generateHtmlCacheAttributes is not defined"}},{generateHybridSelector:!!this.userControlledBrowserSettings.hybridSelectorMode,startingBoundingBox:r,disqualifyZeroOpacity:!this.userControlledBrowserSettings.showZeroOpacityElements&&!o},{timeout:2e3});if("error"in i&&i.error)throw i.error.startsWith(hb)?new zs(i.error):i.error.startsWith(gb)?new Hs(i.error):new Error(i.error);return i.warnings.length&&t.warn(i,"Got warnings while generating HTML attributes for target"),i.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!!ql}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,Hp(e,this.debugData,i,{type:t,text:`[MOMENTIC] ${r}`,args:o})}async setFileChooserHandlerHelper({filePath:e,filename:t}){if(!Vl(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()||JM(e),o=WM(e),i=XM(e),a=Cd[i];this.page.once("filechooser",async l=>{this.logger.info({filePath:e,fileName:r},"File chooser triggered");try{if(!Vl(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:wb.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 this.evaluateFunctionInPage(({fileName:l,base64Data:c,mimeType:d})=>{let p=window;p.momenticFileName=l,p.momenticFileBase64=c;let u=atob(c),m=new Array(u.length);for(let g=0;g<u.length;g++)m[g]=u.charCodeAt(g);let h=new Uint8Array(m);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},"set-file-chooser-handler")}getSerializedFormFromA11yId(e){return this.stateManager.a11yIdToNodeMap[e]?.getNodeOnlySerializedForm()}retrieveAndClearDebugData(){let e=this.cdpClient.loadEventLogs;e.length>0&&(this.logger.debug({logs: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,"copying text to clipboard")}catch(t){if(t instanceof Error&&t.message.includes("Document is not focused")){await this.evaluateFunctionInPage(()=>{document.activeElement||document.body.focus()},void 0,"focusing on body element before copying to clipboard"),await this.press("Tab",{}),await this.press("Shift+Tab",{}),await this.evaluateFunctionInPage(r=>navigator.clipboard.writeText(r),e,"copying text to clipboard");return}throw t}}async paste(){await this.waitForPageLoad(),await this.press("Meta+V",{convertMeta:!0})}async registerRequestListener(e){return this.page.waitForResponse(e)}registerRequestRecorder(e,t,r){this.requestRecorders[e]=o=>{t.test(o.url())&&r(o)}}removeRequestRecorder(e){delete this.requestRecorders[e]}setHeader(e,t,r){this.customHeaders.push({key:e.toLowerCase(),value:t,matcher:r})}async recordRequest(e){Object.values(this.requestRecorders).forEach(t=>{try{t(e)}catch(r){this.logger.error({err:r,url:e.url()},"Error while recording request")}})}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 wN from"fetch-cookie";import{cloneDeep as vN}from"lodash-es";import{CookieJar as EN}from"tough-cookie";import{z as Ft}from"zod";var gie=Ft.object({doubleClick:Ft.boolean().optional(),rightClick:Ft.boolean().optional(),force:Ft.boolean().optional(),waitForDownload:Ft.boolean().optional(),delayMs:Ft.number().optional(),downloadTimeoutMs:Ft.number().optional(),relativePosition:Ft.object({x:Ft.number(),y:Ft.number()}).optional()}),fie=Ft.object({repeat:Ft.number().optional(),convertMeta:Ft.boolean().optional().describe("misleading name due to backcompat. converts keyshortcuts + meta/control to platform-specific combos. defaults to true"),delayMs:Ft.number().optional()});async function Tr(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 bi=3.1783027;function oN(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 Ua(n){return Math.ceil(Zp(n)/bi)}function Zp(n){let e=0;if(typeof n=="string"){let t=n;t=t.replaceAll(`
3915
+ `,""),t=t.replaceAll(" ","");let r=oN(t);return t.length-r+bi*r}if(typeof n>"u")return 0;if(typeof n=="number")return String(n).length;if(Array.isArray(n))return n.forEach(t=>{e+=Zp(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*bi:e+=85*bi:e+=Zp(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 Pw={minChunkTokenCount:500,acceptableChunkTokenCount:3e3,maxChunkTokenCount:8e3,maxLineLength:4e3},Lw={minChunkTokenCount:5e3,acceptableChunkTokenCount:1e4,maxChunkTokenCount:15e3,maxLineLength:500},Iw=/<(\S+) id="(\d+)".*?>/g,iN=/(<\/(\S+)>)|(<(\S+).*?\/>)/g,Ow=["h1","h2","section","footer","nav","aside","form","label","dialog"],aN=[...Ow,"span","div","h3"],sN=["table","select","form","ul","ol","menu","pre","code","dialog"],lN=["table","form","dialog","nav","section","ul","select"];function Qp(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)),cN(n)}function cN({serializedTree:n,options:e,logger:t}){let{minChunkTokenCount:r,acceptableChunkTokenCount:o,maxChunkTokenCount:i,maxLineLength:a}=e,s=[],l=n.split(`
3906
3916
  `),c=0,d=[],p=0,u=[],m=[],h=!1;for(;c<l.length;){h&&(s.push({ids:u,content:d.join(`
3907
- `),tokenLength:p}),d=[],p=0,u=m.length?[m[m.length-1].id]:[],h=!1);let g=l[c],f=Ua(g);p+=f,g.length>a&&(g=g.slice(0,a));let T=Array.from(g.matchAll(Cw)).map(O=>O&&O.length>=3?{tagName:O[1],id:O[2]}:void 0).filter(O=>!!O),E=Array.from(g.matchAll(nN)).map(O=>O&&(O[2]||O[4])).filter(O=>!!O);E.reverse();let x=g.replace(/ id="[0-9]+"/g,"");d.push(x);for(let O of T)u.push(O.id),m.push(O);for(let O of E){let Y=m[m.length-1];Y&&Y.tagName===O&&m.pop()}let A=m.some(O=>oN.includes(O.tagName)),k=l[c+1]??"",L=Ua(k),q=Array.from(k.matchAll(Cw)).map(O=>O&&O.length>2?O[1]:void 0).filter(O=>!!O),M=q.some(O=>Iw.includes(O)),D=q.some(O=>rN.includes(O));p+L>=i&&(h=!0),p>=r&&(M&&!A||E.some(O=>iN.includes(O)))&&(h=!0),p>=o&&D&&!A&&(h=!0),c++}return d.length&&s.push({ids:u,content:d.join(`
3908
- `),tokenLength:p}),s.forEach((g,f)=>{t.debug({chunk:g},`Chunk for page filtering (index ${f+1}/${s.length})`)}),{chunks:s}}var Zp=4e4,eu=8e4;async function lo(n){let{serializedTree:e,logger:t,aiPageFiltering:r,softTokenLimit:o=Zp}=n;if(Ua(e)<o)return e;let a;r?a=Qp({serializedTree:e,options:Aw,logger:t,maxCharacterLength:1e6}):a=Qp({serializedTree:e,options:Rw,logger:t,maxCharacterLength:3e6});try{return r?await B(sN({...n,chunks:a.chunks}),{milliseconds:2e4}):await B(cN({...n,chunkResult:a}),{milliseconds:15e3})}catch(s){t.warn({err:s},"Error executing page filtering, attempting AI keyword fallback");try{return await lN({...n,chunks:a.chunks})}catch(l){return t.warn({err:l},"Error executing page filtering using keyword matching, using naive truncation"),e.slice(0,eu*bi)}}}async function sN({chunks:n,generator:e,description:t,type:r,logger:o,signal:i,tree:a,softTokenLimit:s=Zp,hardTokenLimit:l=eu}){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((u,m)=>{c.indices.includes(m)&&(d=d.concat(u.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 lN(n){let{type:e,description:t,generator:r,tree:o,logger:i,hardTokenLimit:a=eu}=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(m=>m.content.toLowerCase().includes(l.toLowerCase()));if(!c.length||c.reduce((m,h)=>m+h.tokenLength,0)>a&&c.length>1)continue;let p=c.flatMap(m=>m.ids),u=o.pruneUsingRelevantIds(new Set(p)).serialize();return i.debug({description:t,type:e,selectedChunks:c,tree:u},"Pruned a11y tree with keyword page filtering"),u}throw new Error("No keywords were unique enough for page filtering")}async function cN(n){let{description:e,generator:t,tree:r,logger:o,signal:i,chunkResult:a,softTokenLimit:s=Zp}=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 nu(n,e){if(!n.description)throw new R("ActionFailureError","Cannot locate element with empty description");return On({action:async()=>dN(n,e),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,browser:e.browser,logger:n.logger})}async function dN(n,e){let{disableCache:t,testContext:r,filterByViewport:o,skipWait:i,source:a,memory:s,aiPageFiltering:l,logger:c}=n,{ctx:d,orgId:p,browser:u,localCodeEvalTools:m,generator:h,abortSignal:g,flagStore:f}=e,S=n.description,w=n.useMemory&&!t;r&&(S=await $t({orgId:p,s:S,context:r,localTools:m,signal:g,logger:c,flagStore:f})),a&&(S=uN(S,a));let{serializedTree:T,tree:y}=await Tr(u,{filterByViewport:o,abortSignal:g,skipWait:i,logger:c}),E,x=Date.now(),A;for(;!E&&Date.now()-x<3e3;){g.throwIfAborted();try{E=await u.screenshot({clearHighlights:!0,respectActiveFrame:!0,retries:2})}catch(re){A=re}}if(!E)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: ${A?.message}`);let k=T,L=!1;k=await lo({type:"locator",description:S,serializedTree:T,aiPageFiltering:l,tree:y,logger:c,generator:h}),k!==T&&(L=!0);let q=`data:image/jpeg;base64,${E.toString("base64")}`,M=await h.getElementLocation({browserState:k,goal:S,screenshot:q,source:a,memory:w?s:void 0},{disableCache:t,abortSignal:g,loggerTags:ze(c),useMemory:w});c.debug({usedRag:L,result:M},"Got locator result");let D=M.id>0;if(d?.details?.push({type:"AI_LOCATION",matched:D,pageState:k,ragUsed:L,thoughts:M.thoughts}),!D)throw new R("ActionFailureError",`Could not find any relevant element: ${M.thoughts}`);let{resolution:O,target:Y,frameConfig:U}=await u.createTargetFromA11yId({id:M.id,description:S,targetSource:"AI",logger:c});if(O.a11yNode?.properties?.hidden&&O.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: ${O.displayString}`);return w&&(M.updatedMemory?Y.memory={type:"GCS_TRACES",traces:M.updatedMemory}:s&&(Y.memory=s)),{thoughts:M.thoughts,target:Y,resolution:O,frameConfig:U,screenshot:q}}var pN=["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:","Element closely matching the description below. Interpret the description narrowly and do not return elements that are merely loosely related. Description:"],Pw="<select> element:",Lw="text input or contenteditable element:",Ow="Element matching the description below. This element is being located as part of a negative check step (i.e. we are trying to verify the element does not exist). Therefore, interpret the description narrowly, do not assume there are typos, and err on the side of returning -1 unless there is a perfect match. Description:",Mw="Element matching the description below. It is possible the element is hidden or doesn't exist. Interpret the description narrowly and do not assume there are typos. Return -1 unless there is an straightforward match. Description:",Nw="Element matching the description below. This element is being located as part of a check step (i.e. we are trying to verify certain properties about the element). Interpret the description narrowly and do not return elements that are merely loosely related. Description:",tu=[Pw,Lw,Ow,Mw,Nw,...pN];function kw(n,e){if(n===e)return!0;for(let t of tu){if(!n.startsWith(t))continue;let r=n.slice(t.length).trim();if(tu.some(o=>e.startsWith(o)&&e.slice(o.length).trim()===r)||r===e.trim())return!0}return!!tu.some(t=>e.startsWith(t)&&e.slice(t.length).trim()===n.trim())}function uN(n,e){if(!n||!e)return n;switch(e){case"SELECT_OPTION":return`${Pw} ${n}`;case"TYPE":return`${Lw} ${n}`;case"NEGATED_CHECK":return`${Ow}
3909
- ${n}`;case"NEGATED_ELEMENT_VISIBLE_CHECK":return`${Mw}
3910
- ${n}`;case"ELEMENT_CHECK":return`${Nw}
3911
- ${n}`;default:return n}}var mN=15;async function ru({command:n,aiPageFiltering:e,logger:t,fixtures:r,useMemory:o}){if(!n.assertion.trim())throw new R("ActionFailureError","Assertion command is missing the assertion content");let{browser:i}=r,a=n.timeout?n.timeout*1e3:i.smartWaitingTimeout,s=hN(a),l=0,c=Date.now(),d,p,u;try{await On({action:()=>i.clearHighlights(),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,browser:i,logger:t})}catch(h){t.warn({err:h},"Failed to clear highlights before AI check, continuing...")}let m;for(;l<mN&&(!m||m-c<a);){r.abortSignal.throwIfAborted(),l!==0&&(t.info(`Waiting ${s}ms before retrying AI check`),await Z(s,r.abortSignal)),m=Date.now();try{let h=await On({action:async()=>{let g=await _w(i,t,r.abortSignal);return p&&p.serializedTree===g.serializedTree&&p.screenshotBuff.equals(g.screenshotBuff)?!1:(p=g,Dw({command:n,state:g,fixtures:r,useMemory:o,useConsensus:!1,highlightElementsOnFailure:!1,attemptNumber:l,aiPageFiltering:e,logger:t}))},frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,logger:t,browser:i});if(!h)continue;d=h;break}catch(h){r.abortSignal.throwIfAborted(),u=h instanceof Error?h:new Error(`${h}`),t.info({err:h},`AI check assert attempt ${l} failed, retrying...`)}finally{l++}}if(!d)try{d=await On({action:async()=>Dw({command:n,state:await _w(i,t,r.abortSignal),fixtures:r,useMemory:o,useConsensus:!0,highlightElementsOnFailure:!0,attemptNumber:l,aiPageFiltering:e,logger:t}),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,logger:t,browser:i})}catch(h){r.abortSignal.throwIfAborted(),u=h instanceof Error?h:new Error(`${h}`)}finally{l++}if(!d){let h=`AI check still failing after ${l} attempts.`;throw u&&(h+=` Latest result: ${u.message}`),new R("AssertionFailureError",h,{lastScreenshotBuffer:p?.screenshotBuff})}return d.updatedMemory&&(n.cache={...n.cache,memory:{type:"GCS_TRACES",traces:d.updatedMemory}}),d}async function _w(n,e,t){let[r,o]=await Promise.all([Tr(n,{abortSignal:t,skipWait:!0,skipWaitForPageLoad:!0,logger:e}),n.screenshot({retries:1,respectActiveFrame:!0})]);return{...r,screenshotBuff:o}}async function Dw({command:n,state:e,fixtures:t,useConsensus:r,useMemory:o,highlightElementsOnFailure:i,aiPageFiltering:a,attemptNumber:s,logger:l}){let{browser:c,generator:d,abortSignal:p}=t,u={type:"ASSERTION"},{serializedTree:m,tree:h}=e,g=e.screenshotBuff,f=c.url(),S=m;n.contextChoice==="MULTIMODAL"&&(S=await lo({type:"assertion",serializedTree:m,description:n.assertion,aiPageFiltering:a,tree:h,generator:d,logger:l,signal:p}),S!==m&&(u.ragUsed=!0),u.pageState=S);let w={goal:n.assertion,url:f,memory:o?n.cache?.memory:void 0,browserState:S,screenshot:g.toString("base64"),contextChoice:n.contextChoice},y=await(n.contextChoice==="VISION_ONLY"?(E,x)=>d.getVisualAssertionResult(E,x):(E,x)=>d.getAssertionResult(E,x))(w,{useConsensus:r,attemptNumber:s,useMemory:o,disableCache:!!n.disableCache,abortSignal:p,logger:l,loggerTags:ze(l)});if((y.result||i)&&y.relevantElements&&(u.relevantElementsSerialized=y.relevantElements.map(E=>c.getSerializedFormFromA11yId(E)).filter(E=>!!E),await gN(y.relevantElements,c,l)),!y.result)throw new R("AssertionFailureError",y.thoughts);return{succeedImmediately:!1,thoughts:y.thoughts,urlAfterCommand:f,afterScreenshotOverride:g,updatedMemory:o?y.updatedMemory:void 0}}function hN(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 gN(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 B(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 fN=3e4;async function Fw({command:n,logger:e,baseUrl:t,fetchImplementation:r=fetch}){let o=n.timeout??fN/1e3,i=new AbortController,a=Object.fromEntries(Object.entries(n.headers||{}).filter(([p,u])=>p&&u)),s;if(jo(n.url)&&(s=n.url),t&&$o(n.url,t)&&(s=new URL(n.url,t).toString()),!s)throw new R("ActionFailureError",`Invalid URL: ${n.url}`);let c=await B((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,u)=>{d[u]=p}),{status:c.status,headers:d,json:await c.json()}}function Vl(n){try{return new RegExp(n)}catch(e){throw new R("UserConfigurationError",`The provided regex expression was invalid: ${e}`)}}async function Uw(n){let e=n.postData();if(e){if((await n.headerValue("content-type"))?.includes("json"))try{return{json:n.postDataJSON()}}catch{return{}}else if((await n.headerValue("content-type"))?.includes("text"))return{text:e}}return{}}async function Bw(n){let e=await n.text();if(e){if((await n.headerValue("content-type"))?.includes("json"))try{return{json:await n.json()}}catch{return{}}else if((await n.headerValue("content-type"))?.includes("text"))return{text:e}}return{}}async function zw(n){return{request:{url:n.url(),method:n.method(),headers:await n.allHeaders(),...await Uw(n)}}}async function Hw(n,e){let t=await e.response();if(t)return n.response={status:t.status(),headers:await t.allHeaders(),...await Bw(t)},n}async function jw(n){let e=n.request(),t=n.status(),r=n.headers(),o=await Bw(n);return{request:{url:e.url(),method:e.method(),headers:e.headers(),...await Uw(e)},response:{status:t,headers:r,...o},status:t,headers:r,...o}}var wi=class{flagStore;orgId;options;storage;localCodeEvalTools;uploadedFileStorage;visualDiffScreenshotStorage;browser;generator;executeAbortController=new AbortController;logger;recordAbortController=null;registeredListeners={};recordedRequests={};constructor({browser:e,generator:t,logger:r,flagStore:o,storage:i,orgId:a,localCodeEvalTools:s,uploadedFileStorage:l,visualDiffScreenshotStorage:c,options:d}){this.orgId=a,this.options=d,this.browser=e,this.browser.registerAbortSignal(this.executeAbortController.signal),this.storage=i,this.uploadedFileStorage=l,this.visualDiffScreenshotStorage=c,this.localCodeEvalTools=s,this.generator=t,this.logger=r,this.flagStore=o}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([Tr(this.browser,{abortSignal:this.executeAbortController.signal,skipWait:!0,skipWaitForPageLoad:!0,logger:s}),this.browser.screenshot({retries:1,clearHighlights:!0})]),d=await lo({type:"ai-action",description:e,serializedTree:l.serializedTree,tree:l.tree,logger:s,generator:this.generator,aiPageFiltering:!!this.options?.aiPageFiltering,softTokenLimit:25e3,hardTokenLimit:5e4}),p=`data:image/jpeg;base64,${c.toString("base64")}`,u={url:this.browser.url(),browserState:d,startingScreenshot:t,history:r,goal:e,screenshot:p,lastError:a};return await this.generator.getMultiturnAiActionEvaluation(u,{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([Tr(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")}`,u=await lo({type:"ai-action",description:e,serializedTree:c.serializedTree,tree:c.tree,logger:a,generator:this.generator,aiPageFiltering:!!this.options?.aiPageFiltering,softTokenLimit:25e3,hardTokenLimit:5e4}),m={url:l,browserState:u,startingScreenshot:t,history:r,goal:e,actionHint:o,screenshot:p};try{return await this.generator.getMultiturnAiActionCommand(m,{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 Tr(this.browser,e)}async locateElement(e){return nu({...e,aiPageFiltering:!!this.options?.aiPageFiltering},this.getControllerFixtures())}async locateElementWithSelector(e,t){return On({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}}shouldUseMemory(){return this.options?.useMemory??(this.orgId==="org_01HMSCJQBCCG51M2ZF65YC5B8W"||this.orgId==="org_01HMJTX4GT1KG94KZRCT8MZ6YB")}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 u=i[p],m=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:u,cache:a[p],action:async h=>h,options:{...l,targetName:o[p]}});d.push(m)}try{return{result:await s(...d.map(u=>u.result)),elementInteractedDisplayStrings:d.map(u=>u.elementInteractedDisplayString),newTargets:d.map(u=>u.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 On({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")&&Td(i)){t.warn({err:i},"Invalid mpath error, retrying element targeting command");continue}if(!this.flagStore.isBooleanFlagEnabled("visual_actions")&&ia(i)){t.warn({err:i},"Invalid momentic id error, retrying element targeting command");continue}if(i instanceof jn){t.warn({err:i},"Element bounding box moved 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:u}=a,m=this.logger.child({commandId:s.id}),h=this.shouldUseMemory(),g=a.retriesWithAI??1,f=!1,S=e.cache;if((!S||l)&&!xc(o))throw new R("ActionFailureError","Cannot target element with no cached data or element descriptor");if(c)return this.wrapHardcodedCssTargetingCommandHelper(e);l&&(m.debug("Cache explicitly disabled for this step"),f=!0,S=void 0),S?.inputDescription&&!kw(o.elementDescriptor,S.inputDescription)&&(m.warn({old:S.inputDescription,new:o.elementDescriptor},"Target cache was generated with a different description, clearing it automatically"),f=!0,S=void 0);let w=!!S&&om(S);if(!S){let T=new Date;m.debug({targetHealingInProgress:p,cacheBustedBeforeAction:f,memory:a.memory,useMemory:h},"Prompting AI for an updated element location"),f&&await Z(this.browser.smartWaitingTimeout,this.executeAbortController.signal),g--;let y=await nu({description:o.elementDescriptor,disableCache:!!a.disableCache,iframeUrl:a.iframeUrl,source:u,useMemory:h,memory:h?a.memory:void 0,aiPageFiltering:!!this.options?.aiPageFiltering,logger:m},this.getControllerFixtures(t));y.frameConfig&&this.browser.setActiveFrameConfig(y.frameConfig);let E=a.disableGlobalLocatorRedirect?{locator:y.resolution.locator}:await this.attemptLocatorRedirect(y.resolution.locator,m),x=await i(E);return p&&(r.heal({healType:"AI"}),y.target.targetSource="AI_HEALED",y.target.targetUpdateTime=new Date().toUTCString(),y.target.targetUpdateLoggerTags=ze(m)),{result:x,elementInteractedDisplayString:y.resolution.displayString,newTarget:{cache:y.target,thoughts:y.thoughts}}}try{let T=new Date,y=await this.browser.resolveTarget(t,S,{targetName:d,logger:m});(this.flagStore.isBooleanFlagEnabled("global_locator_redirect")||this.flagStore.isBooleanFlagEnabled("visual_actions"))&&await this.browser.scrollIntoViewIfNeeded(y.locator);let E=a.disableGlobalLocatorRedirect?{locator:y.locator}:await this.attemptLocatorRedirect(y.locator,m),x=await i(E);if(w){let A=y.decisions.filter(k=>k.matched);if(A.length!==1)m.warn({decisions:y.decisions},"Expected exactly 1 matching method for element location, got more or less");else{let k=A[0].type;r.heal({healType:k})}}return{result:x,elementInteractedDisplayString:y.displayString,newTarget:{cache:S}}}catch(T){this.throwIfClosed();let y=Jh(T)&&!Td(T)&&!ia(T)&&!(T instanceof jn);if(T instanceof R&&!y)throw T;if(g>0&&o)return m.info({err:T,cache:S,memory:S.memory},"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,memory:S.memory,retriesWithAI:g,targetHealingInProgress:!0}});throw new R("ActionFailureError",T.message,{errOptions:{cause:T}})}}async attemptLocatorRedirect(e,t){return this.flagStore.isBooleanFlagEnabled("global_locator_redirect")?this.browser.performTargetRedirection(e,t):{locator:e}}async screenshotWithDimensions(e){return _a(this.browser,e)}async executePresetCommand(e,t,r,o,i){this.options?.slowMoMs&&await Z(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")&&um(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 Ky({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){Iy(e,t)}createCallbacksForBrowser(e){return{createIsolatedFolder:()=>Up(e)}}async resolveCommandTemplateStrings(e,t){return hi({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){i=i||"disableCache"in r&&!!r.disableCache;let a=this.logger.child({commandId:r.id});switch(r.type){case"SUCCESS":let s=r.condition;return s?.assertion.trim()?ru({command:s,fixtures:this.getControllerFixtures(e),useMemory:this.shouldUseMemory(),aiPageFiltering:!!this.options?.aiPageFiltering,logger:a}):{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 check timeout of ${r.timeout} exceeds the maximum allowed value of 30 minutes.`);return ru({command:r,fixtures:this.getControllerFixtures(e),useMemory:this.shouldUseMemory(),aiPageFiltering:!!this.options?.aiPageFiltering,logger:a})}case"AI_EXTRACT":{if(!r.goal.trim())throw new R("ActionFailureError","Cannot perform AI extraction without goal");let h=await this.browser.getCondensedHtml(),g=await this.browser.screenshot({retries:2});try{let f=await this.generator.getTextExtraction({goal:r.goal,browserState:h,returnSchema:r.schema,screenshot:`data:image/jpeg;base64,${g.toString("base64")}`},{disableCache:i,abortSignal:this.executeAbortController.signal,loggerTags:ze(a)});if(f.result==="NOT_FOUND")throw new R("ActionFailureError","No relevant data found for extraction goal on this page");if(f.thoughts?.includes("MaxGenerationLengthExceededError"))throw new R("UserConfigurationError",f.thoughts);return{thoughts:f.thoughts||void 0,data:f.result,succeedImmediately:!1,urlAfterCommand:this.browser.url()}}catch(f){let S=f.message;throw S.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."):S.includes("AIProviderError")&&S.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:f}}):f}}case"NAVIGATE":if(!jo(r.url)&&!$o(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 l=await this.browser.solveCaptcha();l&&(await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:{type:"description",elementDescriptor:"the captcha image solution input"},cache:void 0,action:h=>this.browser.click(h,this.createCallbacksForBrowser(this.orgId),{}),options:{...r,disableCache:i}}),await this.browser.type(l,{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 h,g=[];if(r.target&&En(r.target))await this.browser.hoverUsingVisualCoordinates(r.target.pixels);else if(r.target&&r.target.elementDescriptor.trim()){let{newTarget:f,elementInteractedDisplayString:S}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:w=>this.browser.hover(w),options:{...r,disableGlobalLocatorRedirect:!0,disableCache:i}});h=S,g.push(f)}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:h,newTargets:g}}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 h=r.matcher;await this.browser.waitForUrl({beforeUrl:this.browser.url(),matcher:h},{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 c=r.delay*1e3;await Z(c,this.executeAbortController.signal);break;case"REFRESH":await this.browser.refresh({loadTimeoutMs:r.loadTimeout?r.loadTimeout*1e3:void 0});break;case"CLICK":{if(En(r.target)){await this.browser.clickUsingVisualCoordinates(r.target.pixels,r);break}let h=this.browser.url(),{elementInteractedDisplayString:g,newTarget:f,result:S}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,target:r.target,command:r,cache:r.cache?.target,action:T=>this.browser.click(T,this.createCallbacksForBrowser(this.orgId),r),options:{disableCache:i,...r}});f.cache&&(r.cache={target:f.cache});let w={urlAfterCommand:this.browser.url(),succeedImmediately:!1,elementInteracted:g,newTargets:[f],data:S};return Zs(h,w.urlAfterCommand)&&(w.succeedImmediately=!0,w.succeedImmediatelyReason="URL changed"),w}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(En(r.fromTarget)&&En(r.toTarget)){await this.browser.dragAndDropUsingVisualCoordinates(r.fromTarget.pixels,r.toTarget.pixels,{hoverSeconds:r.hoverSeconds});break}if(En(r.fromTarget)||En(r.toTarget))throw new Error("Drag and drop targets must be both coordinates or both descriptions");let{newTargets:h,elementInteractedDisplayStrings:g}=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:(f,S)=>this.browser.dragAndDrop(f.locator,S.locator,{hoverSeconds:r.hoverSeconds,steps:r.steps}),options:{useSelector:!!r.useSelector,disableCache:i}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:g[0],newTargets:h}}case"MOUSE_DRAG":{let h=parseInt(r.deltaX),g=parseInt(r.deltaY),f=r.steps??5;if(isNaN(h)||isNaN(g))throw new R("ActionFailureError",`Invalid pixel values passed to mouse drag command: (${r.deltaX}, ${r.deltaY})`);if(r.target&&En(r.target)){await this.browser.mouseDragUsingVisualCoordinates(h,g,f,r.target.pixels,{force:r.force});break}let S,w,T=[];if(r.target?.elementDescriptor){let{newTarget:y,elementInteractedDisplayString:E,result:x}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:async A=>A.locator,options:{disableCache:i,...r}});S=x,w=E,T.push(y)}return await this.browser.mouseDrag(h,g,f,S,{force:r.force}),{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:w,newTargets:T}}case"SELECT_OPTION":{if(!or(r.target))throw new Error("Select with x/y is not supported yet");let h=r.target.elementDescriptor,g=r.choice,{newTarget:f,elementInteractedDisplayString:S}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:{type:"description",elementDescriptor:h},cache:r.cache?.target,action:w=>this.browser.selectOption(w,g,r.force),options:{...r,disableCache:i,source:Nr(r)}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:S,newTargets:[f]}}case"TAB":{let h={loadTimeoutMs:r.loadTimeout?r.loadTimeout*1e3:void 0,retry:!0};await this.browser.switchToPage(r.action,h);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 d=await this.browser.setCookie(r.value);a.debug({results:d},"Set cookies");break;case"LOCAL_STORAGE":if(!r.value||!r.key)break;await this.browser.setLocalStorage(r.key,r.value);break;case"JAVASCRIPT":{let h;try{r.environment==="BROWSER"?(h=await this.browser.evaluateCodeInPage({code:r.code,fragment:r.fragment??!1,context:o.toObjectCopy(),timeoutMs:r.timeout?r.timeout*1e3:void 0}),a.debug({result:h},"Executed JavaScript in browser")):h=await Kn({orgId:this.orgId,code:r.code,fragment:!!r.fragment,context:o,timeoutMs:r.timeout?r.timeout*1e3:void 0,logger:a,localTools:this.localCodeEvalTools,signal:this.executeAbortController.signal,flagStore:this.flagStore,callbacks:{onPersistentVariableUpdates:async g=>{if(!this.options?.scratchPadId){a.warn({updates:g},"Got persistent variable updates but scratch pad is not available");return}await this.storage.savePersistentVariables?.({scratchPadId:this.options?.scratchPadId,orgId:this.orgId,updates:g,logger:a})}}})}catch(g){throw this.throwIfClosed(),new R("ActionFailureError",g instanceof Error?g.message:`${g}`,{errOptions:{cause:g}})}try{JSON.stringify(h)}catch(g){throw new R("ActionFailureError",`Return value is not serializable: ${g instanceof Error?g.message:`${g}`}`,{errOptions:{cause:g}})}return{urlAfterCommand:this.browser.url(),succeedImmediately:!1,data:h}}case"TYPE":{if(r.target&&En(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 h=this.browser.url(),g,f=[],S=yN(r.target);if(S){let{elementInteractedDisplayString:T,newTarget:y}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:S,cache:r.cache?.target,action:E=>this.browser.typeIntoTarget(r.value,E,{force:r.force,clearContent:r.clearContent,forceClearContent:r.forceClearContent,delay:r.delay,pressEnter:r.pressEnter}),options:{...r,disableCache:i,disableGlobalLocatorRedirect:!0,source:Nr(r)}});f.push(y),g=T}else await this.browser.type(r.value,{force:r.force,clearContent:r.clearContent,forceClearContent:r.forceClearContent,delay:r.delay,pressEnter:r.pressEnter},!0);let w={urlAfterCommand:this.browser.url(),succeedImmediately:!1,elementInteracted:g,newTargets:f};return Zs(h,w.urlAfterCommand)&&(w.succeedImmediately=!0,w.succeedImmediatelyReason="URL changed"),w}case"HOVER":{if(En(r.target)){await this.browser.hoverUsingVisualCoordinates(r.target.pixels);break}let{newTarget:h,elementInteractedDisplayString:g}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:f=>this.browser.hover(f),options:{...r,disableCache:i}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:g,newTargets:[h]}}case"FOCUS":{if(!or(r.target))throw new Error("Focus with x/y is not supported yet");let{elementInteractedDisplayString:h,newTarget:g}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:f=>this.browser.focus(f),options:{...r,disableCache:i}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:h,newTargets:[g]}}case"BLUR":{if(r.target&&!or(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:h,elementInteractedDisplayString:g}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,target:r.target,command:r,cache:r.cache?.target,action:f=>this.browser.blur(f),options:{...r,disableCache:i}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:g,newTargets:[h]}}case"PRESS":let p=this.browser.url();await this.browser.press(r.value,{repeat:r.repeat,convertMeta:r.convertMeta??!0,delayMs:r.delayMs});let u={urlAfterCommand:this.browser.url(),succeedImmediately:!1};return Zs(p,u.urlAfterCommand)&&(u.succeedImmediately=!0,u.succeedImmediatelyReason="URL changed"),u;case"KEY_DOWN":return await this.browser.keyDown(r.value,{convertMeta:r.convertMeta??!0}),{urlAfterCommand:this.browser.url(),succeedImmediately:!1};case"KEY_UP":return await this.browser.keyUp(r.value,{convertMeta:r.convertMeta??!0}),{urlAfterCommand:this.browser.url(),succeedImmediately:!1};case"REQUEST":{let h=new bN,g=SN(fetch,h),f;try{f=new URL(r.url).hostname}catch{}return{data:{...await Rl({command:r,baseUrl:this.browser.baseUrl,logger:a,fetchImplementation:g}),cookies:Fs(h,f)},succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"GRAPHQL_REQUEST":return{data:await Fw({command:r,baseUrl:this.browser.baseUrl,logger:a}),succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"VISUAL_DIFF":return jy({ctx:e,tracer:t,command:r,disableCache:i,browser:this.browser,logger:a,storage:this.storage,screenshotStorage:this.visualDiffScreenshotStorage,targetingWrapper:h=>this.wrapElementTargetingCommand(h)});case"FILE_UPLOAD":{let h,g;if(r.fileSource.type==="URL"?(g=r.fileSource.url,h=await Hb({uri:r.fileSource.url,logger:a,orgId:this.orgId})):r.fileSource.type==="USER_FILE"&&(g=r.fileSource.name,h=await this.uploadedFileStorage?.getFileForUpload(r.fileSource.name,this.orgId)),!h)throw new R("UserConfigurationError",`Attempted to use non-existent file for upload step: ${g}`);await this.browser.setFileChooserHandler({...h,filename:r.filename});break}case"AUTH_SAVE":return{data:await this.browser.saveAuthState(),succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"AUTH_LOAD":{let h;if(!r.storageState.trim())h=void 0;else if(h=await Kn({orgId:this.orgId,code:r.storageState,fragment:!1,context:o,logger:a,localTools:this.localCodeEvalTools,signal:this.executeAbortController.signal,flagStore:this.flagStore}),typeof h!="object")throw new R("ActionFailureError",`Credentials must evaluate to an object (received ${typeof h} instead)`);let g;try{g=Ds.optional().parse(h)}catch(f){throw new R("ActionFailureError",`Credentials provided do not follow the required format: ${f}`)}await this.browser.loadAuthState(g);break}case"ELEMENT_CHECK":{let h=(r.timeout??Cn)*1e3,g=await zy({command:r,tracer:t,timeoutMs:h,targetingWrapper:f=>this.wrapElementTargetingCommand(f),fixtures:this.getControllerFixtures(e),disableCache:i});return{fail:!g.success,data:g.data,elementInteracted:g.elementInteractedDisplayString,newTargets:g.newTarget?[g.newTarget]:[],thoughts:g.err?.message??g.thoughts??`Element assertion ${g.success?"succeeded":"failed"}.`,succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"PAGE_CHECK":{let h=await On({action:async()=>Al({assertion:r.assertion,browser:this.browser,logger:a,timeout:r.timeout,signal:this.executeAbortController.signal,flagStore:this.flagStore}),frameConfig:r.iframeUrl?{type:"url",url:r.iframeUrl}:void 0,browser:this.browser,logger:a});return{fail:!h.success,data:h.data,thoughts:h.success?"Page assertion passed.":h.err?.message??`Page assertion still failing after ${r.timeout} seconds.`,urlAfterCommand:this.browser.url(),succeedImmediately:!1}}case"REGISTER_REQUEST_LISTENER":{let h=Vl(r.pattern),g=this.browser.registerRequestListener(h);return this.registeredListeners[r.key]=g.then(async f=>await jw(f)).catch(f=>{a.error({err:f},"Failed to get request listener response")}),{succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"AWAIT_LISTENER":{let h=this.registeredListeners[r.key];if(!h)throw new R("ActionFailureError",`No listener registered with key: ${r.key}`);let g=r.timeout??10;return{data:await B(h,{milliseconds:g*1e3,message:`Request listener timed out after ${g} seconds`}),succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"RECORD_REQUESTS":{let h=Vl(r.pattern);return this.recordedRequests[r.key]=[],this.browser.registerRequestRecorder(r.key,h,async g=>{try{let f=await zw(g);this.recordedRequests[r.key]?.push(f),await Hw(f,g)}catch(f){a.warn({err:f},"Unexpected error while recording request")}}),{succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"GET_RECORDED_REQUESTS":{let h=this.recordedRequests[r.key];if(!h)throw new R("ActionFailureError",`No recorder registered with key: ${r.key}`);return delete this.recordedRequests[r.key],{data:h,succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"SET_HEADER":{let h;return r.urlPattern&&(h=Vl(r.urlPattern)),this.browser.setHeader(r.name,r.value,h),{succeedImmediately:!1,urlAfterCommand:this.browser.url()}}default:return(h=>{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 Hl({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)})}};import{z as Er}from"zod";var Pse=Er.object({useSelector:Er.boolean().optional(),disableCache:Er.boolean().optional(),iframeUrl:Er.string().optional(),retriesWithAI:Er.number().optional(),targetName:Er.string().optional(),source:as.optional(),disableGlobalLocatorRedirect:Er.boolean().optional(),targetHealingInProgress:Er.boolean().optional(),memory:Ni.optional()});var wN=4;async function $w({socket:n,logger:e,analytics:t,storageFactory:r,uploadedFileStorage:o,visualDiffScreenshotStorage:i,serviceMocker:a,devicePixelRatio:s,generatorFactory:l,enricherFactory:c,authorization:d,flagStoreFactory:p,settingsFactory:u,getOrgId:m}){let h=n.id,g=n.handshake.query.testId;if(!g)throw new Error("Socket connection request is missing testId");let f=await m({type:"e2e",testId:g});e=e.child({testId:g,orgId:f,sessionId:h});let S=await l(f,e),w=await c(f,e),T=await p(f),y=await u(f,e),E=await r(f),{testMetadata:x,baseUrl:A,envName:k,browserConfig:L,aiSettings:W,environmentVariables:q,localCodeEvalTools:M}=await co({testId:g,orgId:f,logger:e,storage:E,authorization:d,flagStore:T,settings:y}),D=X.getSession(h);if(D)return e.info("Associating connection with existing session (likely reconnect)"),await D.controller.browser.clearAllCdpHighlights(),{type:"e2e",sessionId:h,orgId:f,testId:g};let O=n.handshake.headers["x-forwarded-for"]?.split(",")[0];if(e.info({clientIp:O,event:"connect",args:n.handshake.query},"Websocket event (connect)"),O&&X.getCurrentConnectionsByIp(O)>=wN)throw e.error({clientIp:O,sessions:X.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.");X.reserveCapacityByIp(O);try{await vN({socket:n,baseUrl:A,envName:k,testMetadata:x,orgId:f,sessionId:h,logger:e,analytics:t,environmentVariables:q,clientIp:O,devicePixelRatio:s,storage:E,uploadedFileStorage:o,visualDiffScreenshotStorage:i,serviceMocker:a,localCodeEvalTools:M,generator:S,enricher:w,browserConfig:L,aiSettings:W,flagStore:T})}catch(Y){throw e.warn({err:Y},"Error setting up socket session, possibly due to client closing the connection"),X.releaseCapacityByIp(O),Y}return{type:"e2e",sessionId:h,testId:g,orgId:f}}async function vN({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:u,localCodeEvalTools:m,generator:h,environmentVariables:g,browserConfig:f,aiSettings:S,clientIp:w,enricher:T,flagStore:y}){let E={viewport:o.advanced?.viewport??qt,locale:o.advanced?.locale??_o,timezoneId:o.advanced?.timezone??Do,geolocation:o.advanced?.geolocation??Fo,colorScheme:o.advanced?.colorScheme};r&&(E.deviceScaleFactor=r);let x=o.id,A=await u?.initializeServicesForTest(i,x),k=await Nl({settings:f,orgId:i,baseUrl:e,envName:t,testName:o.name,localTools:m,envVariables:g,logger:s,customHeaders:void 0,flagStore:y});s=s.child({orgId:i,sessionId:a,testId:x});let L=!1,W=y.isBooleanFlagEnabled("icon_knowledge_base")?await c.fetchIconKnowledgeBase(s):null,q=await Dn.init({baseUrl:e,userBrowserSettings:k,enricher:T,storage:c,flagStore:y,mockedServices:A,logger:s,contextArgs:E,iconKnowledgeBase:W,callbacks:{onTabsChange:(U,re)=>{n.emit("tabs",{tabs:U,activeTab:re})},onScreencastFrame:(U,re)=>{let oe=n;L&&(oe=n.compress(!0)),oe.emit("screenshot",{buffer:U},()=>{re()})},onSvgsCollected:U=>{n.emit("newIconDetected",{numIcons:U.newSvgs.length}),c.saveNewIcons(U,s)}}});await q.navigate({url:e,initialNavigation:!0});let M=new wi({browser:q,generator:h,logger:s,flagStore:y,orgId:i,options:{scratchPadId:void 0,slowMoMs:k.slowMoMs,autoFollowNewTabs:k.autoFollowNewTabs,useMemory:S.useMemory,aiPageFiltering:S.aiPageFiltering??y.isBooleanFlagEnabled("rag_v2")},storage:c,localCodeEvalTools:m,uploadedFileStorage:d,visualDiffScreenshotStorage:p}),D=by(n,a,s),O=async()=>{D.timers.forEach(U=>clearInterval(U))},Y=new Ot({baseUrl:e,testName:o.name,currentUrl:M.browser.url(),variablesFromEnvironment:g,envName:t});if(!n.connected)throw await q.cleanup(),new Error("Socket not connected anymore, not proceeding with session setup");n.emit("session",{url:e,userAgent:Dn.USER_AGENT,viewport:M.browser.getViewport(),sessionId:a}),X.registerSession({controller:M,context:Y,sessionId:a,cleanup:O,clientIp:w})}async function co({testId:n,orgId:e,logger:t,storage:r,authorization:o,flagStore:i,settings:a}){let s=await r.fetchTestMetadata(n,t);if(!s)throw new Error(`Test metadata could not found for test ${n}`);let l;o?.type==="API_KEY"&&(l=new fr({httpClient:new Dt({...o,logger:t}),fakerSeed:void 0}));let c=s.envs?.find(f=>f.default),d;c&&(d=await r.fetchEnvironment(c.name,t));let p=d&&"browser"in d?d.browser:void 0,u={...a.browser,...p,...s.advanced},m=s.baseUrl||d?.variables?.[We];if(!m)throw new Error("Base URL is empty in both test options and the configured environment");let h={...d?.variables};await Promise.all((s.parameters??[]).map(async f=>{let S=await $t({orgId:e,s:f.defaultValue,context:Ot.dummyContext(s.name,d?.name,h),logger:t,flagStore:i,localTools:l});h[f.name]=S}));let g={...a.ai,...s.advanced};return{localCodeEvalTools:l,baseUrl:m,envName:d?.name,testName:s.name,browserConfig:u,environmentVariables:h,testMetadata:s,aiSettings:g}}var ou=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 ql({parentStep:this.step,socket:this.socket,parentTracer:this})}},ql=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 ou({step:e.step,parentTracer:this,socket:this.socket})}},Kl=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 ql({parentStep:null,parentTracer:null,socket:this.socket})}};var iu={currentlyExecutingRequests:{}},EN=n=>async(e,t)=>{let{testId:r,orgId:o}=n.metadata,i=await n.flagStoreFactory(o),a=await n.settingsFactory(o,n.logger),s=await n.storageFactory(o),l,c=await co({testId:r,orgId:o,logger:n.logger,storage:s,authorization:n.authorization,flagStore:i,settings:a}),d=`${r}|${c.baseUrl}`;try{let p=iu.currentlyExecutingRequests[d]??0;iu.currentlyExecutingRequests[d]=p+1,l=await xN({...n,...e,...c,done:t})}finally{n.logger.info({result:l,sessionId:n.metadata.sessionId},"Test execution complete"),iu.currentlyExecutingRequests[d]--}},xN=async({socket:n,steps:e,baseUrl:t,testMetadata:r,reInitialize:o,toStep:i,fromStep:a,storageFactory:s,metadata:l,logger:c,analytics:d,envName:p,testName:u,environmentVariables:m,localCodeEvalTools:h,done:g,cacheStorageFactory:f})=>{let{testId:S,sessionId:w,orgId:T}=l,y=w,E=X.getSession(w);if(!E)throw new Error("No active session found");let{controller:x,context:A}=E;x.setOpen(),c=c.child({testId:S,orgId:T,sessionId:w,runId:y}),c.info({steps:e.map(K=>`${K.type}${"command"in K?` - ${K.command.type}`:""}`),toStep:i,fromStep:a,reInitialize:o,envName:p,testName:u,baseUrl:t,context:A,flags:x.flagStore.getAllFlags()},"Socket execution parameters");let k=m??{},L=async()=>{o&&(await x.browser.reset({newUrl:t}),A.reset({baseUrl:t,currentUrl:x.browser.url(),variablesFromEnvironment:k,envName:p,testName:u}))},W=await s(T),q=await f(T),M=async()=>{try{await q.resolveStepCacheEntries({schemaVersion:r.schemaVersion,testId:S,stepLists:{steps:e},logger:c})}catch(K){c.error({err:K},"Failed to fetch step cache entries from Momentic server. This can drastically reduce test reliability and performance.")}};try{await ua({promiseGenerator:async()=>Promise.all([L(),M()]),signal:x.executeAbortController.signal,codePath:"resolveStepCacheAndInitBrowser"}),x.setOpen()}catch(K){if(n.emit("finished"),K.name!=="AbortError")throw new Error(`Failed to setup browser for execution: ${K}`)}let D=TN(e),O={collectDebugData:!1,reinitializeBrowser:!1,disableHealing:!0},Y={orgId:T,runId:y,testMetadata:r,steps:e,fromStep:a,toStep:i},U={controller:x,context:A,storage:W,debugDataStorage:new Hr,codeEvalTools:h,billingReporter:new zo,logger:c,analytics:d},re={test:{},step:{onDynamicAIActionStatusUpdateEvent:K=>{n.emit("dynamicCommandStatusUpdate",K)},onDynamicAIActionEvaluatingEvent:K=>{n.emit("dynamicCommandEvaluating",K)},onDynamicCommandGenerated:K=>{n.emit("dynamicCommandGenerated",K)},onDynamicCommandExecuted:K=>{n.emit("dynamicCommandExecuted",K)}}},oe=new Kl(n,W,T,S,D),de=await Ml({fixtures:U,options:O,callbacks:re,inputs:Y,testParams:{tracer:oe}});return de?.status==="PASSED"&&await Ws({logger:c,cacheStorage:q,orgId:T,testId:S,originalSteps:{steps:D},updatedSteps:{steps:e}}),await oe.finish(),g?.(de),de.status};var Gw={event:"execute",createHandler:EN};import{cloneDeep as CN}from"lodash-es";var RN=n=>async({command:e},t)=>{let{logger:r,generatorFactory:o,metadata:i}=n,a=CN(e),s=Ef(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})}}},Ww={event:"lintStep",createHandler:RN};var AN=({metadata:n,logger:e,storageFactory:t})=>{let{sessionId:r,orgId:o}=n;return async(i,a)=>{let{description:s,command:l,testMetadata:c,returnScreenshot:d}=i;e.info({params:i},`Locate handler called - ${s}`);let p=X.getSession(r);if(!p)throw new Error("No active session found");let{controller:u,context:m}=p;u.setOpen();let h=await t(o),g=Fr.parse(c.advanced??{}),f={},S;if(s){if("useSelector"in l&&l.useSelector)try{let w=await u.locateElementWithSelector(s,"iframeUrl"in l?l.iframeUrl:void 0);S=w.resolution.locator,f={target:w.target,thoughts:w.thoughts}}catch(w){e.warn({err:w},"Failed resolving target with selector"),a({err:`Failed locating element: ${w.message}`,decisions:w instanceof Hn?w.decisions:void 0});return}else try{let w=await u.locateElement({description:s,disableCache:g.disableAICaching??!1,skipWait:!0,testContext:m,source:Nr(l),iframeUrl:"iframeUrl"in l?l.iframeUrl:void 0,memory:"cache"in l&&l.cache&&"target"in l.cache?l.cache.target.memory:void 0,logger:e});f={target:w.target,thoughts:w.thoughts},S=w.resolution.locator}catch(w){(async()=>{try{let T=await u.browser.getCondensedHtml({skipWait:!0});e.warn({err:w,html:T.slice(0,1e5)},"Failed locating element with AI")}catch(T){e.warn({err:T},"Failed grabbing HTML after trying to locate element with AI")}})(),a({err:`Failed locating element with AI: ${w.message}`});return}if(l.type==="SELECT_OPTION"&&S)try{f.options=await u.browser.getSelectOptions(S)}catch(w){e.warn({err:w},"Failed getting select options"),a({err:`Failed getting select options: ${w.message}`});return}e.info({result:f},"Locate handler result")}if(d)try{let{buffer:w,width:T,height:y}=await u.screenshotWithDimensions({clearHighlights:!0,locator:S}),E=await h.uploadScreenshot(w);f.screenshot={data:E,width:T,height:y},e.info({width:T,height:y},"Captured screenshot during locate")}catch(w){e.error({err:w},"Error capturing screenshot during locate"),a({err:`Error taking screenshot: ${w.message}`});return}if(a({result:f}),S)try{await Promise.all([u.browser.scrollIntoViewIfNeeded(S),u.browser.highlight(S)])}catch(w){e.warn({err:w},"Error highlighting element, continuing...")}}},Vw={event:"locate",createHandler:AN};var IN=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({event:r,percentX:o,percentY:i})=>{let a=X.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")}}},qw={event:"mouseClickEvent",createHandler:IN};var PN=({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=X.getSession(o);if(!d)throw new Error("No active session found");let{controller:p}=d,u=await e(i,t);p.setOpen(),d.browserBehavior.showOverlay=!0;let m=new AbortController;m.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}),m.abort(),h=!0)};setTimeout(()=>{h||(m.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:u,logger:t,testId:a,orgId:i,callbacks:{onActionReceived:f=>g("clickReceived",f),onStepRecorded:f=>g("descriptionGenerated",f)}},abortController:m,isClickToRecord:!0}),r.emit("targetRecordingUpdate",{type:"listenersInitialized",stepId:s,parentStepIdChain:l,attribute:c})}},Kw={event:"recordTargetClick",createHandler:PN};var LN=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({key:r})=>{let o=X.getSession(t);if(!o)throw new Error("No active session found");if(r==="Dead")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(),await i.browser.keyDown(r,{})}catch(a){if(a.message.includes("has been closed")){e.debug({sessionId:t,err:a},"Browser is closed, ignoring key down socket event error");return}throw a}}},Yw={event:"keyDownEvent",createHandler:LN};var ON=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({key:r})=>{let o=X.getSession(t);if(!o)throw new Error("No active session found");if(r==="Dead")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(),await i.browser.keyUp(r,{})}catch(a){if(a.message.includes("has been closed")){e.debug({sessionId:t,err:a},"Browser is closed, ignoring key up socket event error");return}throw a}}},Jw={event:"keyUpEvent",createHandler:ON};var MN=({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=X.getSession(t);if(!c)throw new Error("No active session found");let{controller:d,browserBehavior:p}=c,u=d.browser;if(u.closed||u.getActivePage().isClosed()){e.warn("Ignoring mouse move because the page is closed");return}if(l.event==="scroll"){let m=await u.scrollFromPositionPercentages(l.percentX,l.percentY,a?.x??0,a?.y??0),h=c.browserBehavior.recordingState?.transformer;h&&m&&h.recordScroll(m);return}p.showOverlay&&i(u,l);try{let m=await u.moveMouseFromPositionPercentages(l.percentX,l.percentY);s=0,a=m}catch(m){s++,s%5===0&&e.warn({err:m,mouseErrors:s},"Error in socket mouse move handler")}}},Xw={event:"mouseMoveEvent",createHandler:MN};var NN=({metadata:n,generatorFactory:e,socket:t,logger:r})=>{let{sessionId:o,orgId:i,testId:a}=n;return async({stepId:s})=>{let l=X.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 u=new AbortController,m=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:u,isClickToRecord:!1});d.recordingState={transformer:m}}},Qw={event:"recordingStart",createHandler:NN};var kN=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async()=>{let r=X.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}},Zw={event:"recordingStop",createHandler:kN};var _N=({socket:n,metadata:e,logger:t,storageFactory: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 u=await i(p),m=await a(p,t),h=await r(p),{baseUrl:g}=await co({testId:c,orgId:p,logger:t,storage:h,authorization:o,flagStore:u,settings:m}),f=X.getSession(d);if(!f){n.emit("error",{message:"No session to refresh"});return}let{controller:S}=f;S.setOpen(),await S.browser.refresh();let w=S.browser.getViewport();t.info({baseUrl:g,viewport:w},`Session refreshed for test ${c} at ${g}`),l()},ev={event:"refresh",createHandler:_N};var DN=({socket:n,metadata:e,logger:t,storageFactory: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),u=await r(c),{baseUrl:m,envName:h,testName:g,environmentVariables:f}=await co({testId:s,orgId:c,logger:t,storage:u,authorization:o,flagStore:d,settings:p}),S=X.getSession(l);if(!S){n.emit("error",{message:"No session to reset"});return}let{controller:w,context:T}=S;await w.browser.reset({newUrl:m});let y=w.browser.baseUrl;T.reset({baseUrl:y,currentUrl:w.browser.url(),variablesFromEnvironment:f,envName:h,testName:g});let E=w.browser.getViewport(),x=Dn.USER_AGENT;t.info({baseUrl:m,viewport:E},`Session reset for test ${s} at ${y}`),n.emit("session",{url:y,userAgent:x,viewport:E,sessionId:l})},tv={event:"reset",createHandler:DN};var FN=({metadata:n})=>{let{sessionId:e}=n;return async({url:t})=>{let r=X.getSession(e);if(!r)throw new Error("No active session found");await r.controller.browser.switchToPage({type:"SUBSTRING",substring:t})}},nv={event:"switchTab",createHandler:FN};async function rv(n){let{socket:e}=n;return e.handshake.query.type==="api-test"?Oy(n):$w(n)}var ov=[Dy,Gw,Vw,tv,ev,Ny,nv,Ww,Kw,Qw,Zw,Xw,qw,Yw,Jw,My,wy,_y,ky];var iv=n=>{let{logger:e}=n,t=new UN(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 rv({...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}ov.forEach(i=>BN(i,{socket:r,metadata:o,...n,logger:e}))}),t},BN=(n,e)=>{let t=n.createHandler(e),r=(...o)=>{["mouseMoveEvent","keyDownEvent","keyUpEvent","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 JN}from"express";import cu from"fs";import GN from"path";import sv,{multistream as zN}from"pino";import HN from"pino-pretty";var av=["lastScreenshotBuffer"];var au=new Map,jN=!0,su=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=jN?sv(i):sv(i,zN([{stream:HN({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))av.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}},Yl=({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 au.has(n)||au.set(n,new su({bindings:{app:n},hostname:t,clientToken:e||process.env.NEXT_PUBLIC_DD_CLIENT_TOKEN||process.env.DD_CLIENT_TOKEN,disableConsoleLogs:r})),au.get(n)};import{hostname as $N}from"os";var Ge=Yl({app:"desktop-server",clientToken:"pubcfd7516a5c0ba852b42675cd97bee027",hostname:$N(),disableConsoleLogs:!0}),lv=n=>{Ge.addBinding("version",n)};var WN=new Tl(30,60*1e3),uu="https://api.momentic.ai",mu,lu,cv=n=>{uu=n},Jl=()=>uu,dv=(n,e)=>{mu=n,lu?.abort(),lu=new AbortController;let t=lu.signal,r=[n.configFilePath];n.config.environments?.forEach(o=>{if(!o.envFile)return;let i=GN.resolve(n.rootDir,o.envFile);try{if(cu.lstatSync(i).isSymbolicLink())return;cu.existsSync(i)&&r.push(i)}catch(a){Ge.warn({err:a},`Failed to check if env file ${i} exists`)}});try{VN({filesToWatch:r,revalidator:e,signal:t,project:n})}catch(o){Ge.error({err:o},"Failed to start config file watchers")}},ne=()=>mu,vi,du,pu,pv=async n=>{if(vi)return vi;let e=new ct({baseUrl:uu,apiKey:n,logger:Ge});try{let t=await e.getAuthInfo();return vi=t.orgId,du=t.userId,pu=n,vi}catch(t){throw new Error(`Error checking API key against server: ${t}`)}},bn=()=>{if(!vi)throw new Error("Your organization ID is invalid.");return vi},Xl=()=>{if(!du)throw new Error("Your user ID is invalid.");return du},uv=()=>{if(!pu)throw new Error("Your API key is invalid.");return pu};function VN({filesToWatch:n,revalidator:e,signal:t,project:r}){n.forEach(o=>{cu.watch(o,{signal:t,persistent:!1,recursive:!1},(i,a)=>{a&&(WN.increment("setLocalProject")&&b.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.`),mu=e(r.configFilePath))})})}var Ql=class extends ci{constructor(t,r){super(t,r);this.client=t;this.orgId=r}async fetchTestMetadata(t,r){let o=ne(),a=Se(o,r).tests[t];if(a)return nl(a.relativePath,o)}async fetchApiTestMetadata(){throw new Error("API tests are not available in the desktop app")}async fetchEnvironment(t,r){let o=ne();return ga(t,o,jr)}async fetchIconKnowledgeBase(t){try{return await this.client.fetchIconKnowledgeBase(t)}catch(r){return t.error({err:r},"Failed to fetch icon knowledge base"),null}}};function se(n){return function(...e){let t=e[e.length-1],r=n(...e);Promise.resolve(r).catch(t)}}import{Router as qN}from"express";import za from"fs";import Ba from"path";import{v4 as KN}from"uuid";import YN from"yaml";var Ti=qN();async function hu(n){return(await tl(n,Ge)).map(r=>{let o=n.modules[r.moduleId];if(!o){b.warn(`Found a dangling module with ID ${r.moduleId} that could not be found on disk.`);return}return{...o,content:r}}).filter(r=>r!==void 0)}Ti.get("/",se(async(n,e)=>{let t=ne(),r=Se(t,b),o=await hu(r);e.status(200).json(o)}));Ti.post("/",se(async(n,e)=>{let t;try{t=ag.parse(n.body)}catch(s){e.status(400).json({error:`Invalid request body: ${s}`});return}try{zr(t.name)}catch(s){e.status(400).json({error:`Invalid module name: ${s}`});return}let r=ne(),o=Se(r,b).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=Ba.join(r.rootDir,t.folderPath??"");if(!za.existsSync(i)||!za.statSync(i).isDirectory()){e.status(400).json({error:`The folder configured for module creation '${i}' does not exist.`});return}let a=await oS({...t,folder:i,project:r});e.status(201).json(a)}));Ti.get("/:moduleId",se(async(n,e)=>{if(!n.params.moduleId){e.status(400).json({error:"Missing moduleId in url path."});return}let t=Se(ne(),b),r=t.modules[n.params.moduleId];if(!r){e.status(404).json({error:"Module not found."});return}try{let o=await el(r,t,b);e.json(o)}catch(o){e.status(400).json({err:o})}}));Ti.post("/:moduleId/duplicate",se(async(n,e)=>{if(!n.params.moduleId){e.status(400).json({error:"Missing moduleId in url path."});return}let t;try{t=ig.parse(n.body)}catch(g){e.status(400).json({error:`Invalid request body: ${g}`});return}try{zr(t.name)}catch(g){e.status(400).json({error:g.message});return}let r=ne(),o=Se(r,b),i=o.modules[n.params.moduleId];if(!i){e.status(404).json({error:"Module not found."});return}if(Object.values(o.modules).find(g=>g.name===t.name)){e.status(400).send(`A module with the name "${t.name}" already exists. Please choose a different name.`);return}let a=await el(i,o,b),s=Ba.join(r.rootDir,Ba.dirname(i.relativePath));if(!za.existsSync(s)||!za.statSync(s).isDirectory()){e.status(400).json({error:`The folder configured for module creation '${s}' does not exist.`});return}let l=Ie(t.name),c=Ba.join(s,`${l}.module.yaml`),d=KN(),{stepsToSave:p}=await gt({stepLists:{steps:a.steps},createNewCacheIds:!0,cacheCreationParams:{orgId:bn()}}),u={fileType:ve.MODULE,schemaVersion:Oe,moduleId:d,name:t.name,description:"",enabled:!0,steps:p.steps,parameters:a.parameters,defaultParameters:a.defaultParameters,parameterEnums:a.parameterEnums,defaultCacheKey:a.defaultCacheKey,defaultCacheTtl:a.defaultCacheTtl,defaultCacheAllInvocations:a.defaultCacheAllInvocations,autoAuth:a.autoAuth,advanced:a.advanced},m=YN.stringify(u);za.writeFileSync(c,m,"utf-8");let h={relativeFilePath:Ba.relative(r.rootDir,c)};e.status(201).json(h)}));Ti.patch("/:moduleId/metadata",se(async(n,e)=>{if(!n.params.moduleId){e.status(400).json({error:"Missing moduleId in url path."});return}let t;try{t=sg.parse(n.body)}catch(i){e.status(400).json({error:`Invalid request body: ${i}`});return}let r=ne(),o=Se(r,b);rS({moduleId:n.params.moduleId,content:t,momenticFiles:o,logger:b,project:r}),e.status(201).json({message:"ok"})}));var mv=Ti;var hv=JN();hv.get("/",se(async(n,e)=>{let t=ne(),r=Se(t,b),o=new Set;r?.tests&&Object.values(r.tests).forEach(c=>{c.labels?.forEach(d=>o.add(d))});let i=Array.from(o).sort(),a=Object.values(r.tests),s=await hu(r),l={labels:i,tests:a,modules:s};e.status(200).json(l)}));var gv=hv;import{Router as XN}from"express";var gu=XN();gu.get("/",se((n,e)=>{let t=cS(ne(),Ge);e.status(200).json(t)}));gu.get("/names",se((n,e)=>{let r=ne().config.environments?.map(o=>o.name)??[];e.status(200).json(r)}));var fv=gu;import{Router as QN}from"express";import yt from"fs";import it from"path";var ja=QN();function Ha(n){let e=ne(),t=it.dirname(e.configFilePath);return it.join(t,...n)}function ZN(n){let e=ne(),t=it.dirname(e.configFilePath),r=it.relative(t,n);return r?r.split(it.sep):[]}function ek(n,e){let t=yt.statSync(n),r=ZN(n);return xd.parse({name:e,absolutePath:n,relativePath:r.join(it.sep),pathSegments:r,isDirectory:t.isDirectory(),size:t.size,createdAt:t.birthtime,modifiedAt:t.mtime,accessedAt:t.atime})}ja.post("/",se(async(n,e,t)=>{let r;try{r=dg.parse(n.body).pathSegments}catch(l){e.status(400).json({error:`Failed to parse folder read body: ${l}`});return}let o=Ha(r);if(!yt.existsSync(o)){e.status(404).json({error:`Path not found: ${r.join(it.sep)}`});return}if(!yt.statSync(o).isDirectory()){e.status(400).json({error:`Path is not a directory: ${r.join(it.sep)}`});return}let a=yt.readdirSync(o).map(l=>{let c=it.join(o,l);return ek(c,l)}),s={absolutePath:o,pathSegments:r,contents:a};e.status(200).json(s)}));ja.put("/",se(async(n,e,t)=>{let r;try{r=pg.parse(n.body).pathSegments}catch(a){e.status(400).json({error:`Failed to parse folder create body: ${a}`});return}let o=Ha(r);if(yt.existsSync(o)){e.status(200).json({success:!0,message:`Folder already exists: ${r.join(it.sep)}`,pathSegments:r});return}yt.mkdirSync(o,{recursive:!0});let i={success:!0,message:`Folder created: ${r.join(it.sep)}`,pathSegments:r};e.status(201).json(i)}));ja.patch("/",se(async(n,e,t)=>{let r,o;try{let c=ug.parse(n.body);r=c.pathSegments,o=c.newPathSegments}catch(c){e.status(400).json({error:`Failed to parse folder update body: ${c}`});return}let i=Ha(r),a=Ha(o);if(!yt.existsSync(i)){e.status(400).json({error:`Folder not found: ${r.join(it.sep)}`});return}if(yt.existsSync(a)){e.status(400).json({error:`Destination already exists: ${o.join(it.sep)}`});return}let s=it.dirname(a);yt.existsSync(s)||yt.mkdirSync(s,{recursive:!0}),yt.renameSync(i,a);let l={success:!0,message:`Folder moved from ${r.join(it.sep)} to ${o.join(it.sep)}`,pathSegments:o};e.status(200).json(l)}));ja.delete("/",se(async(n,e,t)=>{let r,o=!0;try{let l=mg.parse(n.body);r=l.pathSegments,o=l.recursive??!0}catch(l){e.status(400).json({error:`Failed to parse folder delete body: ${l}`});return}let i=Ha(r);if(!yt.existsSync(i)){e.status(200).json({success:!0,message:`Folder not found: ${r.join(it.sep)}`,pathSegments:r});return}if(!yt.statSync(i).isDirectory()){e.status(400).json({error:`Path is not a directory: ${r.join(it.sep)}`});return}if(o)yt.rmSync(i,{recursive:!0,force:!0});else{if(yt.readdirSync(i).length>0){e.status(409).json({error:`Cannot delete non-empty directory without recursive flag: ${r.join("/")}`});return}yt.rmdirSync(i)}let s={success:!0,message:`Folder deleted: ${r.join("/")}`,pathSegments:r};e.status(200).json(s)}));var Sv=ja;import{Router as tk}from"express";var yv=tk();yv.get("/",se((n,e)=>{e.status(200).json({userId:Xl(),orgId:bn()})}));var bv=yv;import{Router as nk}from"express";var wv=nk();wv.get("/",se((n,e)=>{let t=ne(),r=Se(t,b),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 vv=wv;import{Router as rk}from"express";var Zl=rk();Zl.get("/",se((n,e)=>{let t=up().map(r=>({name:r.config.name,configFilePath:r.configFilePath}));e.status(200).json(t)}));Zl.get("/current",se((n,e)=>{let t=ne(),r={name:t.config.name,configFilePath:t.configFilePath};e.status(200).json(r)}));Zl.post("/set",se((n,e)=>{let t;try{t=cg.parse(n.body)}catch(r){e.status(400).json({error:`Invalid request body: ${r}`});return}try{let r=jt({configFilePath:t.configFilePath});dv(r,o=>jt({configFilePath:o}))}catch(r){e.status(400).json({error:`Error setting project: ${r}`});return}e.sendStatus(204)}));var Tv=Zl;import{Router as ok}from"express";var Ev=ok();Ev.get("/",se((n,e)=>{let r={ai:ne().config.ai};e.status(200).json(r)}));var xv=Ev;import{Router as sk}from"express";import Cv from"fs";import po from"path";import{v4 as Rv}from"uuid";import lk from"yaml";import{randomUUID as ik}from"node:crypto";import{PostHog as ak}from"posthog-node";var ec=class{identify(){return this}child(){return this}track(){return this}async shutdown(){}},Ei=class n{bindings;client;options;constructor(e,t={}){this.bindings=e,this.options=t,this.client=new ak("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(!Nh(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:ik(),event:r,timestamp:t?.timestamp,properties:{...this.bindings,...o}}),this}};var xi=new Ei({platform:"local_app"},{flushAt:1,flushInterval:0});var xr=sk();xr.get("/",se((n,e)=>{let t=ne(),r=Se(t,b),o=Object.values(r.tests);e.status(200).json(o)}));xr.post("/",se(async(n,e)=>{let t;try{t=rg.parse(n.body)}catch(p){e.status(400).json({error:`Invalid request body: ${p}`});return}try{zr(t.name)}catch(p){e.status(400).json({error:p.message});return}let o={id:Rv(),name:t.name,description:t.description,baseUrl:t.baseUrl,schemaVersion:Oe,advanced:{browserType:t.browserType??"Chromium",viewport:t.viewport??qt},retries:0,steps:[]};t.environment&&(o.envs=[{name:t.environment,default:!0}]);let i=ne(),a=Se(i,b);if(Object.values(a.tests).find(p=>p.name===t.name)){e.status(400).send(`A test with the name "${t.name}" already exists. Please use a different name.`);return}let l=po.join(i.rootDir,...t.pathSegments||[]),c=await aS({test:o,name:t.name,folder:l}),d={...o,relativeFilePath:po.relative(i.rootDir,c)};xi.track({type:"test_editor:test_create"}),e.status(201).json(d)}));xr.get("/:testPath",se(async(n,e)=>{let{testPath:t}=n.params;if(!t){e.status(400).json({error:"Missing testPath in url path."});return}let r=ne(),o=Se(r,b),i;try{i=await ha(po.join(r.rootDir,t),Ge,o),e.status(200).json(i)}catch(a){e.status(400).send({error:a.message});return}(async()=>{try{let{stepsToSave:a,moduleUpdates:s}=await gt({stepLists:{steps:i.steps,beforeSteps:i.beforeSteps,afterSteps:i.afterSteps}});s.forEach(l=>{Qr({content:l,schemaVersion:Oe,momenticFiles:o,project:r})}),Wn({relativeTestPath:t,steps:a,schemaVersion:Oe,project:r})}catch(a){Ge.error({err:a},"Failed to save migrated test to disk after initial fetch")}})()}));xr.patch("/:testPath/metadata",se(async(n,e)=>{if(!n.params.testPath){e.status(400).json({error:"Missing testPath in url path."});return}let t;try{t=ng.parse(n.body)}catch(i){e.status(400).json({error:`Invalid request body: ${i}`});return}let o={message:"ok",newRelativeTestPath:Bd(n.params.testPath,t,ne()).newRelativeTestPath};e.status(200).json(o)}));xr.patch("/:testPath",se(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=tg.parse(n.body)}catch(m){e.status(400).json({error:`Invalid request body: ${m}`});return}let o=ne(),i=Se(o,b),a;try{a=nl(t,o)}catch(m){e.status(400).json({error:`Existing test file on disk is invalid: ${m}`});return}let{stepsToSave:s,moduleUpdates:l,cachesToSave:c}=await gt({stepLists:r.stepLists,cacheCreationParams:{testId:a.id,orgId:bn()}}),d=new ct({apiKey:uv(),baseUrl:Jl(),logger:Ge}),p=await si(Ge,d,o);await mi({orgId:bn(),client:d,gitMetadata:p}).saveStepCacheEntries({logger:Ge,testId:a.id,entries:c}),l.forEach(m=>{Qr({content:m,schemaVersion:r.schemaVersion,momenticFiles:i,project:o})}),Wn({relativeTestPath:t,steps:s,schemaVersion:r.schemaVersion,project:o}),e.status(201).json({message:"ok"})}));xr.patch("/:testPath/environments",se(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=lg.parse(n.body)}catch(o){e.status(400).json({error:`Invalid request body: ${o}`});return}Bd(t,{envs:r.defaultEnv?[{name:r.defaultEnv,default:!0}]:[]},ne()),e.status(201).json({message:"ok"})}));xr.post("/:testPath/duplicate",se(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=og.parse(n.body)}catch(f){e.status(400).json({error:`Invalid request body: ${f}`});return}try{zr(r.name)}catch(f){e.status(400).json({error:f.message});return}let o=ne(),i=po.join(o.rootDir,t);if(!Cv.existsSync(i)){e.status(404).json({error:"Test not found."});return}let a=Se(o,b),s;try{s=await ha(i,Ge,a)}catch(f){e.status(400).send({error:f.message});return}let l=Rv(),c=Zt.parse({...s,name:r.name,id:l}),{stepsToSave:d}=await gt({stepLists:{steps:s.steps,beforeSteps:s.beforeSteps,afterSteps:s.afterSteps},createNewCacheIds:!0,cacheCreationParams:{testId:l,orgId:bn()}}),p=$n({fileType:ve.TEST,...c,beforeSteps:d.beforeSteps??void 0,steps:d.steps,afterSteps:d.afterSteps??void 0}),u=po.dirname(i),m=po.join(u,`${r.name}.${_t.TEST}`),h=lk.stringify(p);Cv.writeFileSync(m,h,"utf-8");let g={relativeFilePath:po.relative(o.rootDir,m)};xi.track({type:"test_editor:test_create"}),e.status(201).json(g)}));var Av=xr;var $a=class{async prepareGoldenScreenshotForComparison(e,t,r){return await new ii(ne(),!1).prepareGoldenScreenshotForComparison(e,t,r)}};async function Ov(n){let{momenticServerUrl:e,apiKey:t,serverPort:r,staticDir:o,devicePixelRatio:i,version:a,logger:s=Ge,alwaysSaveCache:l,noCache:c}=n;lv(a),e&&cv(e),await pv(t);let d=bn(),p=Xl();xi.identify({user_id:p,org_id:d}),s.debug({params:n,orgId:d,userId:p},"Desktop server init and api key check done");let u=gk(o,r,s),m=`http://localhost:${r}`;b.info(`Desktop server is running at ${m}`),await new Promise(y=>{try{u.listen(r,()=>{s.info(`Desktop server is running at ${m}`),y()})}catch(E){E.message.includes("EADDRINUSE")?Mv(r):b.error(`An unexpected error occurred while starting the server: ${E.message}`),process.exit(1)}});let g={type:"API_KEY",baseUrl:Jl(),apiKey:t,logger:s},f=async()=>{let y=ne();return new pi(y.config.ai?.agentConfig,g)},S=async()=>new ui(g,await f()),w=new ct(g),T=new $a;iv({baseServer:u,getOrgId:async()=>bn(),generatorFactory:f,enricherFactory:S,cacheStorageFactory:async y=>{let E=ne(),x=await si(s,w,E);return mi({orgId:y,client:w,gitMetadata:x,alwaysSaveCache:l,noCache:c})},flagStoreFactory:async y=>{let E=ne();return new ai(E.config)},settingsFactory:async()=>{let y=ne();return{ai:{},browser:{},...y.config}},storageFactory:async y=>new Ql(w,y),logger:s,devicePixelRatio:i,authorization:g,visualDiffScreenshotStorage:T,analytics:xi})}var Lv="25mb";function gk(n,e,t){let r=Pv();r.use(ck()),r.use(Iv.json({limit:Lv})),r.use(Iv.urlencoded({extended:!1,limit:Lv}));let o=uk();if(o.use("/tests",Av),o.use("/modules",mv),o.use("/environments",fv),o.use("/projects",Tv),o.use("/labels",vv),o.use("/folders",Sv),o.use("/settings",xv),o.use("/identify",bv),o.use("/entities",gv),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"),b.error(`Oh no! We seem to have hit an unexpected snag \u{1F61E}. Please contact Momentic Support with the following error: ${a.message}
3912
- ${a.stack}`),l.status(500).send("Internal Server Error")}),n){let a=Pv.static(n,{setHeaders:s=>{s.setHeader("Cache-Control","no-cache")},redirect:!1});r.use(a),r.use("*",(s,l)=>{l.sendFile(hk.join(n,"index.html"))})}let i=mk.createServer(r);return i.once("error",a=>{"code"in a&&a.code==="EADDRINUSE"?(Mv(e),process.exit(1)):console.error("An unexpected server error occurred:",a.message)}),i}pk.setMaxListeners(50);process.on("warning",n=>{Ge.warn({err:n},`Node warning received on desktop-server: ${n.message}`)});process.on("uncaughtException",n=>{Ge.error({err:n},"Uncaught exception leading to exit on desktop-server"),b.error(`Oh no! The Momentic desktop app encountered a fatal error \u{1F61E}. Error logs: ${n.message}`)});process.on("unhandledRejection",(n,e)=>{Ge.error({reason:`${n}`,promise:`${e}`,stack:n?.stack},"Uncaught exception leading to exit on desktop-server (promise rejection)"),b.error(`Oh no! The Momentic desktop app encountered an asynchronous error \u{1F61E}. Error logs: ${n}`)});function Mv(n){b.error(dk`Port ${n} is already in use by another process. Please close the other process and try again.
3917
+ `),tokenLength:p}),d=[],p=0,u=m.length?[m[m.length-1].id]:[],h=!1);let g=l[c],f=Ua(g);p+=f,g.length>a&&(g=g.slice(0,a));let E=Array.from(g.matchAll(Iw)).map(O=>O&&O.length>=3?{tagName:O[1],id:O[2]}:void 0).filter(O=>!!O),x=Array.from(g.matchAll(iN)).map(O=>O&&(O[2]||O[4])).filter(O=>!!O);x.reverse();let T=g.replace(/ id="[0-9]+"/g,"");d.push(T);for(let O of E)u.push(O.id),m.push(O);for(let O of x){let q=m[m.length-1];q&&q.tagName===O&&m.pop()}let A=m.some(O=>sN.includes(O.tagName)),D=l[c+1]??"",L=Ua(D),V=Array.from(D.matchAll(Iw)).map(O=>O&&O.length>2?O[1]:void 0).filter(O=>!!O),k=V.some(O=>Ow.includes(O)),N=V.some(O=>aN.includes(O));p+L>=i&&(h=!0),p>=r&&(k&&!A||x.some(O=>lN.includes(O)))&&(h=!0),p>=o&&N&&!A&&(h=!0),c++}return d.length&&s.push({ids:u,content:d.join(`
3918
+ `),tokenLength:p}),s.forEach((g,f)=>{t.debug({chunk:g},`Chunk for page filtering (index ${f+1}/${s.length})`)}),{chunks:s}}var eu=4e4,tu=8e4;async function lo(n){let{serializedTree:e,logger:t,aiPageFiltering:r,softTokenLimit:o=eu}=n;if(Ua(e)<o)return e;let a;r?a=Qp({serializedTree:e,options:Lw,logger:t,maxCharacterLength:1e6}):a=Qp({serializedTree:e,options:Pw,logger:t,maxCharacterLength:3e6});try{return r?await B(dN({...n,chunks:a.chunks}),{milliseconds:2e4}):await B(uN({...n,chunkResult:a}),{milliseconds:15e3})}catch(s){t.warn({err:s},"Error executing page filtering, attempting AI keyword fallback");try{return await pN({...n,chunks:a.chunks})}catch(l){return t.warn({err:l},"Error executing page filtering using keyword matching, using naive truncation"),e.slice(0,tu*bi)}}}async function dN({chunks:n,generator:e,description:t,type:r,logger:o,signal:i,tree:a,softTokenLimit:s=eu,hardTokenLimit:l=tu}){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((u,m)=>{c.indices.includes(m)&&(d=d.concat(u.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 pN(n){let{type:e,description:t,generator:r,tree:o,logger:i,hardTokenLimit:a=tu}=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(m=>m.content.toLowerCase().includes(l.toLowerCase()));if(!c.length||c.reduce((m,h)=>m+h.tokenLength,0)>a&&c.length>1)continue;let p=c.flatMap(m=>m.ids),u=o.pruneUsingRelevantIds(new Set(p)).serialize();return i.debug({description:t,type:e,selectedChunks:c,tree:u},"Pruned a11y tree with keyword page filtering"),u}throw new Error("No keywords were unique enough for page filtering")}async function uN(n){let{description:e,generator:t,tree:r,logger:o,signal:i,chunkResult:a,softTokenLimit:s=eu}=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 ru(n,e){if(!n.description)throw new R("ActionFailureError","Cannot locate element with empty description");return Mn({action:async()=>mN(n,e),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,browser:e.browser,logger:n.logger})}async function mN(n,e){let{disableCache:t,testContext:r,filterByViewport:o,skipWait:i,source:a,memory:s,aiPageFiltering:l,logger:c,allowZeroOpacityOverride:d}=n,{ctx:p,orgId:u,browser:m,localCodeEvalTools:h,generator:g,abortSignal:f,flagStore:S}=e,w=n.description,E=n.useMemory&&!t;r&&(w=await $t({orgId:u,s:w,context:r,localTools:h,signal:f,logger:c,flagStore:S})),a&&(w=gN(w,a));let{serializedTree:y,tree:x}=await Tr(m,{allowZeroOpacityOverride:d,filterByViewport:o,abortSignal:f,skipWait:i,logger:c}),T,A=Date.now(),D;for(;!T&&Date.now()-A<3e3;){f.throwIfAborted();try{T=await m.screenshot({clearHighlights:!0,respectActiveFrame:!0,retries:2})}catch(oe){D=oe}}if(!T)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: ${D?.message}`);let L=y,j=!1;L=await lo({type:"locator",description:w,serializedTree:y,aiPageFiltering:l,tree:x,logger:c,generator:g}),L!==y&&(j=!0);let k=`data:image/jpeg;base64,${T.toString("base64")}`,N=await g.getElementLocation({browserState:L,goal:w,screenshot:k,source:a,memory:E?s:void 0},{disableCache:t,abortSignal:f,loggerTags:ze(c),useMemory:E});c.debug({usedRag:j,result:N},"Got locator result");let O=N.id>0;if(p?.details?.push({type:"AI_LOCATION",matched:O,pageState:L,ragUsed:j,thoughts:N.thoughts}),!O)throw new R("ActionFailureError",`Could not find any relevant element: ${N.thoughts}`);let{resolution:q,target:F,frameConfig:ie}=await m.createTargetFromA11yId({id:N.id,description:w,targetSource:"AI",logger:c});if(q.a11yNode?.properties?.hidden&&q.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: ${q.displayString}`);return E&&(N.updatedMemory?F.memory={type:"GCS_TRACES",traces:N.updatedMemory}:s&&(F.memory=s)),{thoughts:N.thoughts,target:F,resolution:q,frameConfig:ie,screenshot:k}}var hN=["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:","Element closely matching the description below. Interpret the description narrowly and do not return elements that are merely loosely related. Description:"],Mw="<select> element:",Nw="text input or contenteditable element:",kw="Element matching the description below. This element is being located as part of a negative check step (i.e. we are trying to verify the element does not exist). Therefore, interpret the description narrowly, do not assume there are typos, and err on the side of returning -1 unless there is a perfect match. Description:",_w="Element matching the description below. It is possible the element is hidden or doesn't exist. Interpret the description narrowly and do not assume there are typos. Return -1 unless there is an straightforward match. Description:",Dw="Element matching the description below. This element is being located as part of a check step (i.e. we are trying to verify certain properties about the element). Interpret the description narrowly and do not return elements that are merely loosely related. Description:",nu=[Mw,Nw,kw,_w,Dw,...hN];function Fw(n,e){if(n===e)return!0;for(let t of nu){if(!n.startsWith(t))continue;let r=n.slice(t.length).trim();if(nu.some(o=>e.startsWith(o)&&e.slice(o.length).trim()===r)||r===e.trim())return!0}return!!nu.some(t=>e.startsWith(t)&&e.slice(t.length).trim()===n.trim())}function gN(n,e){if(!n||!e)return n;switch(e){case"SELECT_OPTION":return`${Mw} ${n}`;case"TYPE":return`${Nw} ${n}`;case"NEGATED_CHECK":return`${kw}
3919
+ ${n}`;case"NEGATED_ELEMENT_VISIBLE_CHECK":return`${_w}
3920
+ ${n}`;case"ELEMENT_CHECK":return`${Dw}
3921
+ ${n}`;default:return n}}var fN=15;async function ou({command:n,aiPageFiltering:e,logger:t,fixtures:r,useMemory:o}){if(!n.assertion.trim())throw new R("ActionFailureError","Assertion command is missing the assertion content");let{browser:i}=r,a=n.timeout?n.timeout*1e3:i.smartWaitingTimeout,s=SN(a),l=0,c=Date.now(),d,p,u;try{await Mn({action:()=>i.clearHighlights(),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,browser:i,logger:t})}catch(h){t.warn({err:h},"Failed to clear highlights before AI check, continuing...")}let m;for(;l<fN&&(!m||m-c<a);){r.abortSignal.throwIfAborted(),l!==0&&(t.info(`Waiting ${s}ms before retrying AI check`),await Q(s,r.abortSignal)),m=Date.now();try{let h=await Mn({action:async()=>{let g=await Uw(i,t,r.abortSignal);return p&&p.serializedTree===g.serializedTree&&p.screenshotBuff.equals(g.screenshotBuff)?!1:(p=g,Bw({command:n,state:g,fixtures:r,useMemory:o,useConsensus:!1,highlightElementsOnFailure:!1,attemptNumber:l,aiPageFiltering:e,logger:t}))},frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,logger:t,browser:i});if(!h)continue;d=h;break}catch(h){r.abortSignal.throwIfAborted(),u=h instanceof Error?h:new Error(`${h}`),t.info({err:h},`AI check assert attempt ${l} failed, retrying...`)}finally{l++}}if(!d)try{d=await Mn({action:async()=>Bw({command:n,state:await Uw(i,t,r.abortSignal),fixtures:r,useMemory:o,useConsensus:!0,highlightElementsOnFailure:!0,attemptNumber:l,aiPageFiltering:e,logger:t}),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,logger:t,browser:i})}catch(h){r.abortSignal.throwIfAborted(),u=h instanceof Error?h:new Error(`${h}`)}finally{l++}if(!d){let h=`AI check still failing after ${l} attempts.`;throw u&&(h+=` Latest result: ${u.message}`),new R("AssertionFailureError",h,{lastScreenshotBuffer:p?.screenshotBuff})}return d.updatedMemory&&(n.cache={...n.cache,memory:{type:"GCS_TRACES",traces:d.updatedMemory}}),d}async function Uw(n,e,t){let[r,o]=await Promise.all([Tr(n,{abortSignal:t,skipWait:!0,skipWaitForPageLoad:!0,logger:e}),n.screenshot({retries:1,respectActiveFrame:!0})]);return{...r,screenshotBuff:o}}async function Bw({command:n,state:e,fixtures:t,useConsensus:r,useMemory:o,highlightElementsOnFailure:i,aiPageFiltering:a,attemptNumber:s,logger:l}){let{browser:c,generator:d,abortSignal:p}=t,u={type:"ASSERTION"},{serializedTree:m,tree:h}=e,g=e.screenshotBuff,f=c.url(),S=m;n.contextChoice==="MULTIMODAL"&&(S=await lo({type:"assertion",serializedTree:m,description:n.assertion,aiPageFiltering:a,tree:h,generator:d,logger:l,signal:p}),S!==m&&(u.ragUsed=!0),u.pageState=S);let w={goal:n.assertion,url:f,memory:o?n.cache?.memory:void 0,browserState:S,screenshot:g.toString("base64"),contextChoice:n.contextChoice},y=await(n.contextChoice==="VISION_ONLY"?(x,T)=>d.getVisualAssertionResult(x,T):(x,T)=>d.getAssertionResult(x,T))(w,{useConsensus:r,attemptNumber:s,useMemory:o,disableCache:!!n.disableCache,abortSignal:p,logger:l,loggerTags:ze(l)});if((y.result||i)&&y.relevantElements&&(u.relevantElementsSerialized=y.relevantElements.map(x=>c.getSerializedFormFromA11yId(x)).filter(x=>!!x),await yN(y.relevantElements,c,l)),!y.result)throw new R("AssertionFailureError",y.thoughts);return{succeedImmediately:!1,thoughts:y.thoughts,urlAfterCommand:f,afterScreenshotOverride:g,updatedMemory:o?y.updatedMemory:void 0}}function SN(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 yN(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 B(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 bN=3e4;async function zw({command:n,logger:e,baseUrl:t,fetchImplementation:r=fetch}){let o=n.timeout??bN/1e3,i=new AbortController,a=Object.fromEntries(Object.entries(n.headers||{}).filter(([p,u])=>p&&u)),s;if(jo(n.url)&&(s=n.url),t&&$o(n.url,t)&&(s=new URL(n.url,t).toString()),!s)throw new R("ActionFailureError",`Invalid URL: ${n.url}`);let c=await B((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,u)=>{d[u]=p}),{status:c.status,headers:d,json:await c.json()}}function Kl(n){try{return new RegExp(n)}catch(e){throw new R("UserConfigurationError",`The provided regex expression was invalid: ${e}`)}}async function Hw(n){let e=n.postData();if(e){if((await n.headerValue("content-type"))?.includes("json"))try{return{json:n.postDataJSON()}}catch{return{}}else if((await n.headerValue("content-type"))?.includes("text"))return{text:e}}return{}}async function jw(n){let e=await n.text();if(e){if((await n.headerValue("content-type"))?.includes("json"))try{return{json:await n.json()}}catch{return{}}else if((await n.headerValue("content-type"))?.includes("text"))return{text:e}}return{}}async function $w(n){return{request:{url:n.url(),method:n.method(),headers:await n.allHeaders(),...await Hw(n)}}}async function Gw(n,e){let t=await e.response();if(t)return n.response={status:t.status(),headers:await t.allHeaders(),...await jw(t)},n}async function Ww(n){let e=n.request(),t=n.status(),r=n.headers(),o=await jw(n);return{request:{url:e.url(),method:e.method(),headers:e.headers(),...await Hw(e)},response:{status:t,headers:r,...o},status:t,headers:r,...o}}var wi=class{flagStore;orgId;options;storage;localCodeEvalTools;uploadedFileStorage;visualDiffScreenshotStorage;browser;generator;executeAbortController=new AbortController;logger;recordAbortController=null;registeredListeners={};recordedRequests={};constructor({browser:e,generator:t,logger:r,flagStore:o,storage:i,orgId:a,localCodeEvalTools:s,uploadedFileStorage:l,visualDiffScreenshotStorage:c,options:d}){this.orgId=a,this.options=d,this.browser=e,this.browser.registerAbortSignal(this.executeAbortController.signal),this.storage=i,this.uploadedFileStorage=l,this.visualDiffScreenshotStorage=c,this.localCodeEvalTools=s,this.generator=t,this.logger=r,this.flagStore=o}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([Tr(this.browser,{abortSignal:this.executeAbortController.signal,skipWait:!0,skipWaitForPageLoad:!0,logger:s}),this.browser.screenshot({retries:1,clearHighlights:!0})]),d=await lo({type:"ai-action",description:e,serializedTree:l.serializedTree,tree:l.tree,logger:s,generator:this.generator,aiPageFiltering:!!this.options?.aiPageFiltering,softTokenLimit:25e3,hardTokenLimit:5e4}),p=`data:image/jpeg;base64,${c.toString("base64")}`,u={url:this.browser.url(),browserState:d,startingScreenshot:t,history:r,goal:e,screenshot:p,lastError:a};return await this.generator.getMultiturnAiActionEvaluation(u,{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([Tr(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")}`,u=await lo({type:"ai-action",description:e,serializedTree:c.serializedTree,tree:c.tree,logger:a,generator:this.generator,aiPageFiltering:!!this.options?.aiPageFiltering,softTokenLimit:25e3,hardTokenLimit:5e4}),m={url:l,browserState:u,startingScreenshot:t,history:r,goal:e,actionHint:o,screenshot:p};try{return await this.generator.getMultiturnAiActionCommand(m,{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 Tr(this.browser,e)}async locateElement(e){return ru({...e,aiPageFiltering:!!this.options?.aiPageFiltering},this.getControllerFixtures())}async locateElementWithSelector(e,t){return Mn({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}}shouldUseMemory(){return this.options?.useMemory??(this.orgId==="org_01HMSCJQBCCG51M2ZF65YC5B8W"||this.orgId==="org_01HMJTX4GT1KG94KZRCT8MZ6YB")}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 u=i[p],m=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:u,cache:a[p],action:async h=>h,options:{...l,targetName:o[p]}});d.push(m)}try{return{result:await s(...d.map(u=>u.result)),elementInteractedDisplayStrings:d.map(u=>u.elementInteractedDisplayString),newTargets:d.map(u=>u.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 Mn({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")&&xd(i)){t.warn({err:i},"Invalid mpath error, retrying element targeting command");continue}if(!this.flagStore.isBooleanFlagEnabled("visual_actions")&&ia(i)){t.warn({err:i},"Invalid momentic id error, retrying element targeting command");continue}if(i instanceof Rn&&i.retryableWithAI){t.warn({err:i},"Element cache disqualification 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,c=Date.now();for(;Date.now()-c<this.browser.smartWaitingTimeout;)try{let d=await this.browser.resolveHardcodedCssSelector({ctx:e,selector:t.elementDescriptor,targetName:s,logger:a});return{result:await r({locator:d.locator}),elementInteractedDisplayString:d.displayString,newTarget:{cache:{id:-1,selector:t.elementDescriptor,targetSource:"USER_CSS_SELECTOR",targetUpdateTime:new Date().toUTCString()}}}}catch(d){l=d,a.warn({err:d},"Failed to action on hardcoded css selector")}throw l}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:u}=a,m=this.logger.child({commandId:s.id}),h=this.shouldUseMemory(),g=a.retriesWithAI??1,f=!1,S=e.cache;if((!S||l)&&!Rc(o))throw new R("ActionFailureError","Cannot target element with no cached data or element descriptor");if(c)return this.wrapHardcodedCssTargetingCommandHelper(e);l&&(m.debug("Cache explicitly disabled for this step"),f=!0,S=void 0),S?.inputDescription&&!Fw(o.elementDescriptor,S.inputDescription)&&(m.warn({old:S.inputDescription,new:o.elementDescriptor},"Target cache was generated with a different description, clearing it automatically"),f=!0,S=void 0);let w=!!S&&im(S);if(!S){m.debug({targetHealingInProgress:p,cacheBustedBeforeAction:f,memory:a.memory,useMemory:h},"Prompting AI for an updated element location"),f&&await Q(this.browser.smartWaitingTimeout,this.executeAbortController.signal),g--;let E=await ru({description:o.elementDescriptor,disableCache:!!a.disableCache,iframeUrl:a.iframeUrl,source:u,useMemory:h,memory:h?a.memory:void 0,aiPageFiltering:!!this.options?.aiPageFiltering,allowZeroOpacityOverride:a.allowZeroOpacityOverride,logger:m},this.getControllerFixtures(t));E.frameConfig&&this.browser.setActiveFrameConfig(E.frameConfig);let y=a.disableGlobalLocatorRedirect?{locator:E.resolution.locator}:await this.attemptLocatorRedirect(E.resolution.locator,m),x=await i(y);return p&&(r.heal({healType:"AI"}),E.target.targetSource="AI_HEALED",E.target.targetUpdateTime=new Date().toUTCString(),E.target.targetUpdateLoggerTags=ze(m)),{result:x,elementInteractedDisplayString:E.resolution.displayString,newTarget:{cache:E.target,thoughts:E.thoughts}}}try{let E=await this.browser.resolveTarget(t,S,{allowZeroOpacityOverride:a.allowZeroOpacityOverride,targetName:d,logger:m,signal:this.executeAbortController.signal});(this.flagStore.isBooleanFlagEnabled("global_locator_redirect")||this.flagStore.isBooleanFlagEnabled("visual_actions"))&&await this.browser.scrollIntoViewIfNeeded(E.locator);let y=a.disableGlobalLocatorRedirect?{locator:E.locator}:await this.attemptLocatorRedirect(E.locator,m),x=await i(y);if(w){let T=E.decisions.filter(A=>A.matched);if(T.length!==1)m.warn({decisions:E.decisions},"Expected exactly 1 matching method for element location, got more or less");else{let A=T[0].type;r.heal({healType:A})}}return{result:x,elementInteractedDisplayString:E.displayString,newTarget:{cache:S}}}catch(E){this.throwIfClosed();let y=!1;if((E instanceof Rn||xd(E)||ia(E)||Xh(E))&&(y=!0),E instanceof R&&!y)throw m.error({err:E},"Failed to execute action with cached target (fatal)"),E;if(g>0&&o)return m.info({err:E,cache:S,memory:S.memory},"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,memory:S.memory,retriesWithAI:g,targetHealingInProgress:!0}});throw new R("ActionFailureError",E.message,{errOptions:{cause:E}})}}async attemptLocatorRedirect(e,t){return this.flagStore.isBooleanFlagEnabled("global_locator_redirect")?this.browser.performTargetRedirection(e,t):{locator:e}}async screenshotWithDimensions(e){return _a(this.browser,e)}async executePresetCommand(e,t,r,o,i){this.options?.slowMoMs&&await Q(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")&&mm(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 Yy({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){Py(e,t)}createCallbacksForBrowser(e){return{createIsolatedFolder:()=>Bp(e)}}async resolveCommandTemplateStrings(e,t){return hi({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){i=i||"disableCache"in r&&!!r.disableCache;let a=this.logger.child({commandId:r.id});switch(r.type){case"SUCCESS":let s=r.condition;return s?.assertion.trim()?ou({command:s,fixtures:this.getControllerFixtures(e),useMemory:this.shouldUseMemory(),aiPageFiltering:!!this.options?.aiPageFiltering,logger:a}):{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 check timeout of ${r.timeout} exceeds the maximum allowed value of 30 minutes.`);return ou({command:r,fixtures:this.getControllerFixtures(e),useMemory:this.shouldUseMemory(),aiPageFiltering:!!this.options?.aiPageFiltering,logger:a})}case"AI_EXTRACT":{if(!r.goal.trim())throw new R("ActionFailureError","Cannot perform AI extraction without goal");let h=await this.browser.getCondensedHtml(),g=await this.browser.screenshot({retries:2});try{let f=await this.generator.getTextExtraction({goal:r.goal,browserState:h,returnSchema:r.schema,screenshot:`data:image/jpeg;base64,${g.toString("base64")}`},{disableCache:i,abortSignal:this.executeAbortController.signal,loggerTags:ze(a)});if(f.result==="NOT_FOUND")throw new R("ActionFailureError","No relevant data found for extraction goal on this page");if(f.thoughts?.includes("MaxGenerationLengthExceededError"))throw new R("UserConfigurationError",f.thoughts);return{thoughts:f.thoughts||void 0,data:f.result,succeedImmediately:!1,urlAfterCommand:this.browser.url()}}catch(f){let S=f.message;throw S.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."):S.includes("AIProviderError")&&S.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:f}}):f}}case"NAVIGATE":if(!jo(r.url)&&!$o(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 l=await this.browser.solveCaptcha();l&&(await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:{type:"description",elementDescriptor:"the captcha image solution input"},cache:void 0,action:h=>this.browser.click(h,this.createCallbacksForBrowser(this.orgId),{}),options:{...r,disableCache:i}}),await this.browser.type(l,{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 h,g=[];if(r.target&&Tn(r.target))await this.browser.hoverUsingVisualCoordinates(r.target.pixels);else if(r.target&&r.target.elementDescriptor.trim()){let{newTarget:f,elementInteractedDisplayString:S}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:w=>this.browser.hover(w),options:{...r,disableGlobalLocatorRedirect:!0,disableCache:i}});h=S,g.push(f)}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:h,newTargets:g}}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 h=r.matcher;await this.browser.waitForUrl({beforeUrl:this.browser.url(),matcher:h},{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 c=r.delay*1e3;await Q(c,this.executeAbortController.signal);break;case"REFRESH":await this.browser.refresh({loadTimeoutMs:r.loadTimeout?r.loadTimeout*1e3:void 0});break;case"CLICK":{if(Tn(r.target)){await this.browser.clickUsingVisualCoordinates(r.target.pixels,r);break}let h=this.browser.url(),{elementInteractedDisplayString:g,newTarget:f,result:S}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,target:r.target,command:r,cache:r.cache?.target,action:E=>this.browser.click(E,this.createCallbacksForBrowser(this.orgId),r),options:{disableCache:i,...r}});f.cache&&(r.cache={target:f.cache});let w={urlAfterCommand:this.browser.url(),succeedImmediately:!1,elementInteracted:g,newTargets:[f],data:S};return tl(h,w.urlAfterCommand)&&(w.succeedImmediately=!0,w.succeedImmediatelyReason="URL changed"),w}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(Tn(r.fromTarget)&&Tn(r.toTarget)){await this.browser.dragAndDropUsingVisualCoordinates(r.fromTarget.pixels,r.toTarget.pixels,{hoverSeconds:r.hoverSeconds});break}if(Tn(r.fromTarget)||Tn(r.toTarget))throw new Error("Drag and drop targets must be both coordinates or both descriptions");let{newTargets:h,elementInteractedDisplayStrings:g}=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:(f,S)=>this.browser.dragAndDrop(f.locator,S.locator,{hoverSeconds:r.hoverSeconds,steps:r.steps}),options:{useSelector:!!r.useSelector,disableCache:i}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:g[0],newTargets:h}}case"MOUSE_DRAG":{let h=parseInt(r.deltaX),g=parseInt(r.deltaY),f=r.steps??5;if(isNaN(h)||isNaN(g))throw new R("ActionFailureError",`Invalid pixel values passed to mouse drag command: (${r.deltaX}, ${r.deltaY})`);if(r.target&&Tn(r.target)){await this.browser.mouseDragUsingVisualCoordinates(h,g,f,r.target.pixels,{force:r.force});break}let S,w,E=[];if(r.target?.elementDescriptor){let{newTarget:y,elementInteractedDisplayString:x,result:T}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:async A=>A.locator,options:{disableCache:i,...r}});S=T,w=x,E.push(y)}return await this.browser.mouseDrag(h,g,f,S,{force:r.force}),{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:w,newTargets:E}}case"SELECT_OPTION":{if(!ir(r.target))throw new Error("Select with x/y is not supported yet");let h=r.target.elementDescriptor,g=r.choice,{newTarget:f,elementInteractedDisplayString:S}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:{type:"description",elementDescriptor:h},cache:r.cache?.target,action:w=>this.browser.selectOption(w,g,r.force),options:{...r,disableCache:i,source:Nr(r)}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:S,newTargets:[f]}}case"TAB":{let h={loadTimeoutMs:r.loadTimeout?r.loadTimeout*1e3:void 0,retry:!0};await this.browser.switchToPage(r.action,h);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 d=await this.browser.setCookie(r.value);a.debug({results:d},"Set cookies");break;case"LOCAL_STORAGE":if(!r.value||!r.key)break;await this.browser.setLocalStorage(r.key,r.value);break;case"JAVASCRIPT":{let h;try{r.environment==="BROWSER"?(h=await this.browser.evaluateCodeInPage({code:r.code,fragment:r.fragment??!1,context:o.toObjectCopy(),timeoutMs:r.timeout?r.timeout*1e3:void 0}),a.debug({result:h},"Executed JavaScript in browser")):h=await Kn({orgId:this.orgId,code:r.code,fragment:!!r.fragment,context:o,timeoutMs:r.timeout?r.timeout*1e3:void 0,logger:a,localTools:this.localCodeEvalTools,signal:this.executeAbortController.signal,flagStore:this.flagStore,callbacks:{onPersistentVariableUpdates:async g=>{if(!this.options?.scratchPadId){a.warn({updates:g},"Got persistent variable updates but scratch pad is not available");return}await this.storage.savePersistentVariables?.({scratchPadId:this.options?.scratchPadId,orgId:this.orgId,updates:g,logger:a})}}})}catch(g){throw this.throwIfClosed(),new R("ActionFailureError",g instanceof Error?g.message:`${g}`,{errOptions:{cause:g}})}try{JSON.stringify(h)}catch(g){throw new R("ActionFailureError",`Return value is not serializable: ${g instanceof Error?g.message:`${g}`}`,{errOptions:{cause:g}})}return{urlAfterCommand:this.browser.url(),succeedImmediately:!1,data:h}}case"TYPE":{if(r.target&&Tn(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 h=this.browser.url(),g,f=[],S=vN(r.target);if(S){let{elementInteractedDisplayString:E,newTarget:y}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:S,cache:r.cache?.target,action:x=>this.browser.typeIntoTarget(r.value,x,{force:r.force,clearContent:r.clearContent,forceClearContent:r.forceClearContent,delay:r.delay,pressEnter:r.pressEnter}),options:{...r,disableCache:i,disableGlobalLocatorRedirect:!0,source:Nr(r)}});f.push(y),g=E}else await this.browser.type(r.value,{force:r.force,clearContent:r.clearContent,forceClearContent:r.forceClearContent,delay:r.delay,pressEnter:r.pressEnter},!0);let w={urlAfterCommand:this.browser.url(),succeedImmediately:!1,elementInteracted:g,newTargets:f};return tl(h,w.urlAfterCommand)&&(w.succeedImmediately=!0,w.succeedImmediatelyReason="URL changed"),w}case"HOVER":{if(Tn(r.target)){await this.browser.hoverUsingVisualCoordinates(r.target.pixels);break}let{newTarget:h,elementInteractedDisplayString:g}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:f=>this.browser.hover(f),options:{...r,disableCache:i}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:g,newTargets:[h]}}case"FOCUS":{if(!ir(r.target))throw new Error("Focus with x/y is not supported yet");let{elementInteractedDisplayString:h,newTarget:g}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:f=>this.browser.focus(f),options:{...r,disableCache:i}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:h,newTargets:[g]}}case"BLUR":{if(r.target&&!ir(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:h,elementInteractedDisplayString:g}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,target:r.target,command:r,cache:r.cache?.target,action:f=>this.browser.blur(f),options:{...r,disableCache:i}});return{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:g,newTargets:[h]}}case"PRESS":let p=this.browser.url();await this.browser.press(r.value,{repeat:r.repeat,convertMeta:r.convertMeta??!0,delayMs:r.delayMs});let u={urlAfterCommand:this.browser.url(),succeedImmediately:!1};return tl(p,u.urlAfterCommand)&&(u.succeedImmediately=!0,u.succeedImmediatelyReason="URL changed"),u;case"KEY_DOWN":return await this.browser.keyDown(r.value,{convertMeta:r.convertMeta??!0}),{urlAfterCommand:this.browser.url(),succeedImmediately:!1};case"KEY_UP":return await this.browser.keyUp(r.value,{convertMeta:r.convertMeta??!0}),{urlAfterCommand:this.browser.url(),succeedImmediately:!1};case"REQUEST":{let h=new EN,g=wN(fetch,h),f;try{f=new URL(r.url).hostname}catch{}return{data:{...await Il({command:r,baseUrl:this.browser.baseUrl,logger:a,fetchImplementation:g}),cookies:Fs(h,f)},succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"GRAPHQL_REQUEST":return{data:await zw({command:r,baseUrl:this.browser.baseUrl,logger:a}),succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"VISUAL_DIFF":return $y({ctx:e,tracer:t,command:r,disableCache:i,browser:this.browser,logger:a,storage:this.storage,screenshotStorage:this.visualDiffScreenshotStorage,targetingWrapper:h=>this.wrapElementTargetingCommand(h)});case"FILE_UPLOAD":{let h,g;if(r.fileSource.type==="URL"?(g=r.fileSource.url,h=await Gb({uri:r.fileSource.url,logger:a,orgId:this.orgId})):r.fileSource.type==="USER_FILE"&&(g=r.fileSource.name,h=await this.uploadedFileStorage?.getFileForUpload(r.fileSource.name,this.orgId)),!h)throw new R("UserConfigurationError",`Attempted to use non-existent file for upload step: ${g}`);await this.browser.setFileChooserHandler({...h,filename:r.filename});break}case"AUTH_SAVE":return{data:await this.browser.saveAuthState(),succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"AUTH_LOAD":{let h;if(!r.storageState.trim())h=void 0;else if(h=await Kn({orgId:this.orgId,code:r.storageState,fragment:!1,context:o,logger:a,localTools:this.localCodeEvalTools,signal:this.executeAbortController.signal,flagStore:this.flagStore}),typeof h!="object")throw new R("ActionFailureError",`Credentials must evaluate to an object (received ${typeof h} instead)`);let g;try{g=Ds.optional().parse(h)}catch(f){throw new R("ActionFailureError",`Credentials provided do not follow the required format: ${f}`)}await this.browser.loadAuthState(g);break}case"ELEMENT_CHECK":{let h=(r.timeout??Cn)*1e3,g=await Hy({command:r,tracer:t,timeoutMs:h,targetingWrapper:f=>this.wrapElementTargetingCommand(f),fixtures:this.getControllerFixtures(e),disableCache:i});return{fail:!g.success,data:g.data,elementInteracted:g.elementInteractedDisplayString,newTargets:g.newTarget?[g.newTarget]:[],thoughts:g.err?.message??g.thoughts??`Element assertion ${g.success?"succeeded":"failed"}.`,succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"PAGE_CHECK":{let h=await Mn({action:async()=>Pl({assertion:r.assertion,browser:this.browser,logger:a,timeout:r.timeout,signal:this.executeAbortController.signal,flagStore:this.flagStore}),frameConfig:r.iframeUrl?{type:"url",url:r.iframeUrl}:void 0,browser:this.browser,logger:a});return{fail:!h.success,data:h.data,thoughts:h.success?"Page assertion passed.":h.err?.message??`Page assertion still failing after ${r.timeout} seconds.`,urlAfterCommand:this.browser.url(),succeedImmediately:!1}}case"REGISTER_REQUEST_LISTENER":{let h=Kl(r.pattern),g=this.browser.registerRequestListener(h);return this.registeredListeners[r.key]=g.then(async f=>await Ww(f)).catch(f=>{a.error({err:f},"Failed to get request listener response")}),{succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"AWAIT_LISTENER":{let h=this.registeredListeners[r.key];if(!h)throw new R("ActionFailureError",`No listener registered with key: ${r.key}`);let g=r.timeout??10;return{data:await B(h,{milliseconds:g*1e3,message:`Request listener timed out after ${g} seconds`}),succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"RECORD_REQUESTS":{let h=Kl(r.pattern);return this.recordedRequests[r.key]=[],this.browser.registerRequestRecorder(r.key,h,async g=>{try{let f=await $w(g);this.recordedRequests[r.key]?.push(f),await Gw(f,g)}catch(f){a.warn({err:f},"Unexpected error while recording request")}}),{succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"GET_RECORDED_REQUESTS":{let h=this.recordedRequests[r.key];if(!h)throw new R("ActionFailureError",`No recorder registered with key: ${r.key}`);return delete this.recordedRequests[r.key],{data:h,succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"SET_HEADER":{let h;return r.urlPattern&&(h=Kl(r.urlPattern)),this.browser.setHeader(r.name,r.value,h),{succeedImmediately:!1,urlAfterCommand:this.browser.url()}}default:return(h=>{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 $l({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)})}};import{z as Jn}from"zod";var kse=Jn.object({useSelector:Jn.boolean().optional(),disableCache:Jn.boolean().optional(),iframeUrl:Jn.string().optional(),retriesWithAI:Jn.number().optional(),targetName:Jn.string().optional(),source:as.optional(),disableGlobalLocatorRedirect:Jn.boolean().optional(),allowZeroOpacityOverride:Jn.boolean().optional(),targetHealingInProgress:Jn.boolean().optional(),memory:Ni.optional()});var TN=4;async function Vw({socket:n,logger:e,analytics:t,storageFactory:r,uploadedFileStorage:o,visualDiffScreenshotStorage:i,serviceMocker:a,devicePixelRatio:s,generatorFactory:l,enricherFactory:c,authorization:d,flagStoreFactory:p,settingsFactory:u,getOrgId:m}){let h=n.id,g=n.handshake.query.testId;if(!g)throw new Error("Socket connection request is missing testId");let f=await m({type:"e2e",testId:g});e=e.child({testId:g,orgId:f,sessionId:h});let S=await l(f,e),w=await c(f,e),E=await p(f),y=await u(f,e),x=await r(f),{testMetadata:T,baseUrl:A,envName:D,browserConfig:L,aiSettings:j,environmentVariables:V,localCodeEvalTools:k}=await co({testId:g,orgId:f,logger:e,storage:x,authorization:d,flagStore:E,settings:y}),N=J.getSession(h);if(N)return e.info("Associating connection with existing session (likely reconnect)"),await N.controller.browser.clearAllCdpHighlights(),{type:"e2e",sessionId:h,orgId:f,testId:g};let O=n.handshake.headers["x-forwarded-for"]?.split(",")[0];if(e.info({clientIp:O,event:"connect",args:n.handshake.query},"Websocket event (connect)"),O&&J.getCurrentConnectionsByIp(O)>=TN)throw e.error({clientIp:O,sessions:J.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.");J.reserveCapacityByIp(O);try{await xN({socket:n,baseUrl:A,envName:D,testMetadata:T,orgId:f,sessionId:h,logger:e,analytics:t,environmentVariables:V,clientIp:O,devicePixelRatio:s,storage:x,uploadedFileStorage:o,visualDiffScreenshotStorage:i,serviceMocker:a,localCodeEvalTools:k,generator:S,enricher:w,browserConfig:L,aiSettings:j,flagStore:E})}catch(q){throw e.warn({err:q},"Error setting up socket session, possibly due to client closing the connection"),J.releaseCapacityByIp(O),q}return{type:"e2e",sessionId:h,testId:g,orgId:f}}async function xN({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:u,localCodeEvalTools:m,generator:h,environmentVariables:g,browserConfig:f,aiSettings:S,clientIp:w,enricher:E,flagStore:y}){let x={viewport:o.advanced?.viewport??qt,locale:o.advanced?.locale??_o,timezoneId:o.advanced?.timezone??Do,geolocation:o.advanced?.geolocation??Fo,colorScheme:o.advanced?.colorScheme};r&&(x.deviceScaleFactor=r);let T=o.id,A=await u?.initializeServicesForTest(i,T),D=await _l({settings:f,orgId:i,baseUrl:e,envName:t,testName:o.name,localTools:m,envVariables:g,logger:s,customHeaders:void 0,flagStore:y});s=s.child({orgId:i,sessionId:a,testId:T});let L=!1,j=y.isBooleanFlagEnabled("icon_knowledge_base")?await c.fetchIconKnowledgeBase(s):null,V=await Fn.init({baseUrl:e,userBrowserSettings:D,enricher:E,storage:c,flagStore:y,mockedServices:A,logger:s,contextArgs:x,iconKnowledgeBase:j,callbacks:{onTabsChange:(F,ie)=>{n.emit("tabs",{tabs:F,activeTab:ie})},onScreencastFrame:(F,ie)=>{let oe=n;L&&(oe=n.compress(!0)),oe.emit("screenshot",{buffer:F},()=>{ie()})},onSvgsCollected:F=>{n.emit("newIconDetected",{numIcons:F.newSvgs.length}),c.saveNewIcons(F,s)}}});await V.navigate({url:e,initialNavigation:!0});let k=new wi({browser:V,generator:h,logger:s,flagStore:y,orgId:i,options:{scratchPadId:void 0,slowMoMs:D.slowMoMs,autoFollowNewTabs:D.autoFollowNewTabs,useMemory:S.useMemory,aiPageFiltering:S.aiPageFiltering??y.isBooleanFlagEnabled("rag_v2")},storage:c,localCodeEvalTools:m,uploadedFileStorage:d,visualDiffScreenshotStorage:p}),N=wy(n,a,s),O=async()=>{N.timers.forEach(F=>clearInterval(F))},q=new Ot({baseUrl:e,testName:o.name,currentUrl:k.browser.url(),variablesFromEnvironment:g,envName:t});if(!n.connected)throw await V.cleanup(),new Error("Socket not connected anymore, not proceeding with session setup");n.emit("session",{url:e,userAgent:Fn.USER_AGENT,viewport:k.browser.getViewport(),sessionId:a}),J.registerSession({controller:k,context:q,sessionId:a,cleanup:O,clientIp:w})}async function co({testId:n,orgId:e,logger:t,storage:r,authorization:o,flagStore:i,settings:a}){let s=await r.fetchTestMetadata(n,t);if(!s)throw new Error(`Test metadata could not found for test ${n}`);let l;o?.type==="API_KEY"&&(l=new Sr({httpClient:new Dt({...o,logger:t}),fakerSeed:void 0}));let c=s.envs?.find(f=>f.default),d;c&&(d=await r.fetchEnvironment(c.name,t));let p=d&&"browser"in d?d.browser:void 0,u={...a.browser,...p,...s.advanced},m=s.baseUrl||d?.variables?.[We];if(!m)throw new Error("Base URL is empty in both test options and the configured environment");let h={...d?.variables};await Promise.all((s.parameters??[]).map(async f=>{let S=await $t({orgId:e,s:f.defaultValue,context:Ot.dummyContext(s.name,d?.name,h),logger:t,flagStore:i,localTools:l});h[f.name]=S}));let g={...a.ai,...s.advanced};return{localCodeEvalTools:l,baseUrl:m,envName:d?.name,testName:s.name,browserConfig:u,environmentVariables:h,testMetadata:s,aiSettings:g}}var iu=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 Yl({parentStep:this.step,socket:this.socket,parentTracer:this})}},Yl=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 iu({step:e.step,parentTracer:this,socket:this.socket})}},Jl=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 Yl({parentStep:null,parentTracer:null,socket:this.socket})}};var au={currentlyExecutingRequests:{}},RN=n=>async(e,t)=>{let{testId:r,orgId:o}=n.metadata,i=await n.flagStoreFactory(o),a=await n.settingsFactory(o,n.logger),s=await n.storageFactory(o),l,c=await co({testId:r,orgId:o,logger:n.logger,storage:s,authorization:n.authorization,flagStore:i,settings:a}),d=`${r}|${c.baseUrl}`;try{let p=au.currentlyExecutingRequests[d]??0;au.currentlyExecutingRequests[d]=p+1,l=await AN({...n,...e,...c,done:t})}finally{n.logger.info({result:l,sessionId:n.metadata.sessionId},"Test execution complete"),au.currentlyExecutingRequests[d]--}},AN=async({socket:n,steps:e,baseUrl:t,testMetadata:r,reInitialize:o,toStep:i,fromStep:a,storageFactory:s,metadata:l,logger:c,analytics:d,envName:p,testName:u,environmentVariables:m,localCodeEvalTools:h,done:g,cacheStorageFactory:f})=>{let{testId:S,sessionId:w,orgId:E}=l,y=w,x=J.getSession(w);if(!x)throw new Error("No active session found");let{controller:T,context:A}=x;T.setOpen(),c=c.child({testId:S,orgId:E,sessionId:w,runId:y}),c.info({steps:e.map(K=>`${K.type}${"command"in K?` - ${K.command.type}`:""}`),toStep:i,fromStep:a,reInitialize:o,envName:p,testName:u,baseUrl:t,context:A,flags:T.flagStore.getAllFlags()},"Socket execution parameters");let D=m??{},L=async()=>{o&&(await T.browser.reset({newUrl:t}),A.reset({baseUrl:t,currentUrl:T.browser.url(),variablesFromEnvironment:D,envName:p,testName:u}))},j=await s(E),V=await f(E),k=async()=>{try{await V.resolveStepCacheEntries({schemaVersion:r.schemaVersion,testId:S,stepLists:{steps:e},logger:c})}catch(K){c.error({err:K},"Failed to fetch step cache entries from Momentic server. This can drastically reduce test reliability and performance.")}};try{await ua({promiseGenerator:async()=>Promise.all([L(),k()]),signal:T.executeAbortController.signal,codePath:"resolveStepCacheAndInitBrowser"}),T.setOpen()}catch(K){if(n.emit("finished"),K.name!=="AbortError")throw new Error(`Failed to setup browser for execution: ${K}`)}let N=CN(e),O={collectDebugData:!1,reinitializeBrowser:!1,disableHealing:!0},q={orgId:E,runId:y,testMetadata:r,steps:e,fromStep:a,toStep:i},F={controller:T,context:A,storage:j,debugDataStorage:new Hr,codeEvalTools:h,billingReporter:new zo,logger:c,analytics:d},ie={test:{},step:{onDynamicAIActionStatusUpdateEvent:K=>{n.emit("dynamicCommandStatusUpdate",K)},onDynamicAIActionEvaluatingEvent:K=>{n.emit("dynamicCommandEvaluating",K)},onDynamicCommandGenerated:K=>{n.emit("dynamicCommandGenerated",K)},onDynamicCommandExecuted:K=>{n.emit("dynamicCommandExecuted",K)}}},oe=new Jl(n,j,E,S,N),pe=await kl({fixtures:F,options:O,callbacks:ie,inputs:q,testParams:{tracer:oe}});return pe?.status==="PASSED"&&await qs({logger:c,cacheStorage:V,orgId:E,testId:S,originalSteps:{steps:N},updatedSteps:{steps:e}}),await oe.finish(),g?.(pe),pe.status};var qw={event:"execute",createHandler:RN};import{cloneDeep as IN}from"lodash-es";var PN=n=>async({command:e},t)=>{let{logger:r,generatorFactory:o,metadata:i}=n,a=IN(e),s=xf(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})}}},Kw={event:"lintStep",createHandler:PN};var LN=({metadata:n,logger:e,storageFactory:t})=>{let{sessionId:r,orgId:o}=n;return async(i,a)=>{let{description:s,command:l,testMetadata:c,returnScreenshot:d}=i;e.info({params:i},`Locate handler called - ${s}`);let p=J.getSession(r);if(!p)throw new Error("No active session found");let{controller:u,context:m}=p;u.setOpen();let h=await t(o),g=Fr.parse(c.advanced??{}),f={},S;if(s){if("useSelector"in l&&l.useSelector)try{let w=await u.locateElementWithSelector(s,"iframeUrl"in l?l.iframeUrl:void 0);S=w.resolution.locator,f={target:w.target,thoughts:w.thoughts}}catch(w){e.warn({err:w},"Failed resolving target with selector"),a({err:`Failed locating element: ${w.message}`,decisions:w instanceof jn?w.decisions:void 0});return}else try{let w=await u.locateElement({description:s,disableCache:g.disableAICaching??!1,skipWait:!0,testContext:m,source:Nr(l),iframeUrl:"iframeUrl"in l?l.iframeUrl:void 0,memory:"cache"in l&&l.cache&&"target"in l.cache?l.cache.target.memory:void 0,logger:e});f={target:w.target,thoughts:w.thoughts},S=w.resolution.locator}catch(w){(async()=>{try{let E=await u.browser.getCondensedHtml({skipWait:!0});e.warn({err:w,html:E.slice(0,1e5)},"Failed locating element with AI")}catch(E){e.warn({err:E},"Failed grabbing HTML after trying to locate element with AI")}})(),a({err:`Failed locating element with AI: ${w.message}`});return}if(l.type==="SELECT_OPTION"&&S)try{f.options=await u.browser.getSelectOptions(S)}catch(w){e.warn({err:w},"Failed getting select options"),a({err:`Failed getting select options: ${w.message}`});return}e.info({result:f},"Locate handler result")}if(d)try{let{buffer:w,width:E,height:y}=await u.screenshotWithDimensions({clearHighlights:!0,locator:S}),x=await h.uploadScreenshot(w);f.screenshot={data:x,width:E,height:y},e.info({width:E,height:y},"Captured screenshot during locate")}catch(w){e.error({err:w},"Error capturing screenshot during locate"),a({err:`Error taking screenshot: ${w.message}`});return}if(a({result:f}),S)try{await Promise.all([u.browser.scrollIntoViewIfNeeded(S),u.browser.highlight(S)])}catch(w){e.warn({err:w},"Error highlighting element, continuing...")}}},Yw={event:"locate",createHandler:LN};var ON=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({event:r,percentX:o,percentY:i})=>{let a=J.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")}}},Jw={event:"mouseClickEvent",createHandler:ON};var MN=({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=J.getSession(o);if(!d)throw new Error("No active session found");let{controller:p}=d,u=await e(i,t);p.setOpen(),d.browserBehavior.showOverlay=!0;let m=new AbortController;m.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}),m.abort(),h=!0)};setTimeout(()=>{h||(m.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:u,logger:t,testId:a,orgId:i,callbacks:{onActionReceived:f=>g("clickReceived",f),onStepRecorded:f=>g("descriptionGenerated",f)}},abortController:m,isClickToRecord:!0}),r.emit("targetRecordingUpdate",{type:"listenersInitialized",stepId:s,parentStepIdChain:l,attribute:c})}},Xw={event:"recordTargetClick",createHandler:MN};var NN=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({key:r})=>{let o=J.getSession(t);if(!o)throw new Error("No active session found");if(r==="Dead")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(),await i.browser.keyDown(r,{})}catch(a){if(a.message.includes("has been closed")){e.debug({sessionId:t,err:a},"Browser is closed, ignoring key down socket event error");return}throw a}}},Zw={event:"keyDownEvent",createHandler:NN};var kN=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({key:r})=>{let o=J.getSession(t);if(!o)throw new Error("No active session found");if(r==="Dead")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(),await i.browser.keyUp(r,{})}catch(a){if(a.message.includes("has been closed")){e.debug({sessionId:t,err:a},"Browser is closed, ignoring key up socket event error");return}throw a}}},Qw={event:"keyUpEvent",createHandler:kN};var _N=({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=J.getSession(t);if(!c)throw new Error("No active session found");let{controller:d,browserBehavior:p}=c,u=d.browser;if(u.closed||u.getActivePage().isClosed()){e.warn("Ignoring mouse move because the page is closed");return}if(l.event==="scroll"){let m=await u.scrollFromPositionPercentages(l.percentX,l.percentY,a?.x??0,a?.y??0),h=c.browserBehavior.recordingState?.transformer;h&&m&&h.recordScroll(m);return}p.showOverlay&&i(u,l);try{let m=await u.moveMouseFromPositionPercentages(l.percentX,l.percentY);s=0,a=m}catch(m){s++,s%5===0&&e.warn({err:m,mouseErrors:s},"Error in socket mouse move handler")}}},ev={event:"mouseMoveEvent",createHandler:_N};var DN=({metadata:n,generatorFactory:e,socket:t,logger:r})=>{let{sessionId:o,orgId:i,testId:a}=n;return async({stepId:s})=>{let l=J.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 u=new AbortController,m=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:u,isClickToRecord:!1});d.recordingState={transformer:m}}},tv={event:"recordingStart",createHandler:DN};var FN=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async()=>{let r=J.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}},nv={event:"recordingStop",createHandler:FN};var UN=({socket:n,metadata:e,logger:t,storageFactory: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 u=await i(p),m=await a(p,t),h=await r(p),{baseUrl:g}=await co({testId:c,orgId:p,logger:t,storage:h,authorization:o,flagStore:u,settings:m}),f=J.getSession(d);if(!f){n.emit("error",{message:"No session to refresh"});return}let{controller:S}=f;S.setOpen(),await S.browser.refresh();let w=S.browser.getViewport();t.info({baseUrl:g,viewport:w},`Session refreshed for test ${c} at ${g}`),l()},rv={event:"refresh",createHandler:UN};var BN=({socket:n,metadata:e,logger:t,storageFactory: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),u=await r(c),{baseUrl:m,envName:h,testName:g,environmentVariables:f}=await co({testId:s,orgId:c,logger:t,storage:u,authorization:o,flagStore:d,settings:p}),S=J.getSession(l);if(!S){n.emit("error",{message:"No session to reset"});return}let{controller:w,context:E}=S;await w.browser.reset({newUrl:m});let y=w.browser.baseUrl;E.reset({baseUrl:y,currentUrl:w.browser.url(),variablesFromEnvironment:f,envName:h,testName:g});let x=w.browser.getViewport(),T=Fn.USER_AGENT;t.info({baseUrl:m,viewport:x},`Session reset for test ${s} at ${y}`),n.emit("session",{url:y,userAgent:T,viewport:x,sessionId:l})},ov={event:"reset",createHandler:BN};var zN=({metadata:n})=>{let{sessionId:e}=n;return async({url:t})=>{let r=J.getSession(e);if(!r)throw new Error("No active session found");await r.controller.browser.switchToPage({type:"SUBSTRING",substring:t})}},iv={event:"switchTab",createHandler:zN};async function av(n){let{socket:e}=n;return e.handshake.query.type==="api-test"?My(n):Vw(n)}var sv=[Fy,qw,Yw,ov,rv,ky,iv,Kw,Xw,tv,nv,ev,Jw,Zw,Qw,Ny,vy,Dy,_y];var lv=n=>{let{logger:e}=n,t=new HN(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 av({...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}sv.forEach(i=>jN(i,{socket:r,metadata:o,...n,logger:e}))}),t},jN=(n,e)=>{let t=n.createHandler(e),r=(...o)=>{["mouseMoveEvent","keyDownEvent","keyUpEvent","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 QN}from"express";import du from"fs";import qN from"path";import dv,{multistream as $N}from"pino";import GN from"pino-pretty";var cv=["lastScreenshotBuffer"];var su=new Map,WN=!0,lu=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=WN?dv(i):dv(i,$N([{stream:GN({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))cv.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}},Xl=({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 su.has(n)||su.set(n,new lu({bindings:{app:n},hostname:t,clientToken:e||process.env.NEXT_PUBLIC_DD_CLIENT_TOKEN||process.env.DD_CLIENT_TOKEN,disableConsoleLogs:r})),su.get(n)};import{hostname as VN}from"os";var Ge=Xl({app:"desktop-server",clientToken:"pubcfd7516a5c0ba852b42675cd97bee027",hostname:VN(),disableConsoleLogs:!0}),pv=n=>{Ge.addBinding("version",n)};var KN=new xl(30,60*1e3),mu="https://api.momentic.ai",hu,cu,uv=n=>{mu=n},Zl=()=>mu,mv=(n,e)=>{hu=n,cu?.abort(),cu=new AbortController;let t=cu.signal,r=[n.configFilePath];n.config.environments?.forEach(o=>{if(!o.envFile)return;let i=qN.resolve(n.rootDir,o.envFile);try{if(du.lstatSync(i).isSymbolicLink())return;du.existsSync(i)&&r.push(i)}catch(a){Ge.warn({err:a},`Failed to check if env file ${i} exists`)}});try{YN({filesToWatch:r,revalidator:e,signal:t,project:n})}catch(o){Ge.error({err:o},"Failed to start config file watchers")}},re=()=>hu,vi,pu,uu,hv=async n=>{if(vi)return vi;let e=new ct({baseUrl:mu,apiKey:n,logger:Ge});try{let t=await e.getAuthInfo();return vi=t.orgId,pu=t.userId,uu=n,vi}catch(t){throw new Error(`Error checking API key against server: ${t}`)}},bn=()=>{if(!vi)throw new Error("Your organization ID is invalid.");return vi},Ql=()=>{if(!pu)throw new Error("Your user ID is invalid.");return pu},gv=()=>{if(!uu)throw new Error("Your API key is invalid.");return uu};function YN({filesToWatch:n,revalidator:e,signal:t,project:r}){n.forEach(o=>{du.watch(o,{signal:t,persistent:!1,recursive:!1},(i,a)=>{a&&(KN.increment("setLocalProject")&&b.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.`),hu=e(r.configFilePath))})})}var ec=class extends ci{constructor(t,r){super(t,r);this.client=t;this.orgId=r}async fetchTestMetadata(t,r){let o=re(),a=ye(o,r).tests[t];if(a)return ol(a.relativePath,o)}async fetchApiTestMetadata(){throw new Error("API tests are not available in the desktop app")}async fetchEnvironment(t,r){let o=re();return ga(t,o,jr)}async fetchIconKnowledgeBase(t){try{return await this.client.fetchIconKnowledgeBase(t)}catch(r){return t.error({err:r},"Failed to fetch icon knowledge base"),null}}};function le(n){return function(...e){let t=e[e.length-1],r=n(...e);Promise.resolve(r).catch(t)}}import{Router as JN}from"express";import za from"fs";import Ba from"path";import{v4 as XN}from"uuid";import ZN from"yaml";var Ei=JN();async function gu(n){return(await rl(n,Ge)).map(r=>{let o=n.modules[r.moduleId];if(!o){b.warn(`Found a dangling module with ID ${r.moduleId} that could not be found on disk.`);return}return{...o,content:r}}).filter(r=>r!==void 0)}Ei.get("/",le(async(n,e)=>{let t=re(),r=ye(t,b),o=await gu(r);e.status(200).json(o)}));Ei.post("/",le(async(n,e)=>{let t;try{t=sg.parse(n.body)}catch(s){e.status(400).json({error:`Invalid request body: ${s}`});return}try{zr(t.name)}catch(s){e.status(400).json({error:`Invalid module name: ${s}`});return}let r=re(),o=ye(r,b).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=Ba.join(r.rootDir,t.folderPath??"");if(!za.existsSync(i)||!za.statSync(i).isDirectory()){e.status(400).json({error:`The folder configured for module creation '${i}' does not exist.`});return}let a=await iS({...t,folder:i,project:r});e.status(201).json(a)}));Ei.get("/:moduleId",le(async(n,e)=>{if(!n.params.moduleId){e.status(400).json({error:"Missing moduleId in url path."});return}let t=ye(re(),b),r=t.modules[n.params.moduleId];if(!r){e.status(404).json({error:"Module not found."});return}try{let o=await nl(r,t,b);e.json(o)}catch(o){e.status(400).json({err:o})}}));Ei.post("/:moduleId/duplicate",le(async(n,e)=>{if(!n.params.moduleId){e.status(400).json({error:"Missing moduleId in url path."});return}let t;try{t=ag.parse(n.body)}catch(g){e.status(400).json({error:`Invalid request body: ${g}`});return}try{zr(t.name)}catch(g){e.status(400).json({error:g.message});return}let r=re(),o=ye(r,b),i=o.modules[n.params.moduleId];if(!i){e.status(404).json({error:"Module not found."});return}if(Object.values(o.modules).find(g=>g.name===t.name)){e.status(400).send(`A module with the name "${t.name}" already exists. Please choose a different name.`);return}let a=await nl(i,o,b),s=Ba.join(r.rootDir,Ba.dirname(i.relativePath));if(!za.existsSync(s)||!za.statSync(s).isDirectory()){e.status(400).json({error:`The folder configured for module creation '${s}' does not exist.`});return}let l=Ie(t.name),c=Ba.join(s,`${l}.module.yaml`),d=XN(),{stepsToSave:p}=await gt({stepLists:{steps:a.steps},createNewCacheIds:!0,cacheCreationParams:{orgId:bn()}}),u={fileType:ve.MODULE,schemaVersion:Oe,moduleId:d,name:t.name,description:"",enabled:!0,steps:p.steps,parameters:a.parameters,defaultParameters:a.defaultParameters,parameterEnums:a.parameterEnums,defaultCacheKey:a.defaultCacheKey,defaultCacheTtl:a.defaultCacheTtl,defaultCacheAllInvocations:a.defaultCacheAllInvocations,autoAuth:a.autoAuth,advanced:a.advanced},m=ZN.stringify(u);za.writeFileSync(c,m,"utf-8");let h={relativeFilePath:Ba.relative(r.rootDir,c)};e.status(201).json(h)}));Ei.patch("/:moduleId/metadata",le(async(n,e)=>{if(!n.params.moduleId){e.status(400).json({error:"Missing moduleId in url path."});return}let t;try{t=lg.parse(n.body)}catch(i){e.status(400).json({error:`Invalid request body: ${i}`});return}let r=re(),o=ye(r,b);oS({moduleId:n.params.moduleId,content:t,momenticFiles:o,logger:b,project:r}),e.status(201).json({message:"ok"})}));var fv=Ei;var Sv=QN();Sv.get("/",le(async(n,e)=>{let t=re(),r=ye(t,b),o=new Set;r?.tests&&Object.values(r.tests).forEach(c=>{c.labels?.forEach(d=>o.add(d))});let i=Array.from(o).sort(),a=Object.values(r.tests),s=await gu(r),l={labels:i,tests:a,modules:s};e.status(200).json(l)}));var yv=Sv;import{Router as ek}from"express";var fu=ek();fu.get("/",le((n,e)=>{let t=dS(re(),Ge);e.status(200).json(t)}));fu.get("/names",le((n,e)=>{let r=re().config.environments?.map(o=>o.name)??[];e.status(200).json(r)}));var bv=fu;import{Router as tk}from"express";import yt from"fs";import it from"path";var ja=tk();function Ha(n){let e=re(),t=it.dirname(e.configFilePath);return it.join(t,...n)}function nk(n){let e=re(),t=it.dirname(e.configFilePath),r=it.relative(t,n);return r?r.split(it.sep):[]}function rk(n,e){let t=yt.statSync(n),r=nk(n);return Rd.parse({name:e,absolutePath:n,relativePath:r.join(it.sep),pathSegments:r,isDirectory:t.isDirectory(),size:t.size,createdAt:t.birthtime,modifiedAt:t.mtime,accessedAt:t.atime})}ja.post("/",le(async(n,e,t)=>{let r;try{r=pg.parse(n.body).pathSegments}catch(l){e.status(400).json({error:`Failed to parse folder read body: ${l}`});return}let o=Ha(r);if(!yt.existsSync(o)){e.status(404).json({error:`Path not found: ${r.join(it.sep)}`});return}if(!yt.statSync(o).isDirectory()){e.status(400).json({error:`Path is not a directory: ${r.join(it.sep)}`});return}let a=yt.readdirSync(o).map(l=>{let c=it.join(o,l);return rk(c,l)}),s={absolutePath:o,pathSegments:r,contents:a};e.status(200).json(s)}));ja.put("/",le(async(n,e,t)=>{let r;try{r=ug.parse(n.body).pathSegments}catch(a){e.status(400).json({error:`Failed to parse folder create body: ${a}`});return}let o=Ha(r);if(yt.existsSync(o)){e.status(200).json({success:!0,message:`Folder already exists: ${r.join(it.sep)}`,pathSegments:r});return}yt.mkdirSync(o,{recursive:!0});let i={success:!0,message:`Folder created: ${r.join(it.sep)}`,pathSegments:r};e.status(201).json(i)}));ja.patch("/",le(async(n,e,t)=>{let r,o;try{let c=mg.parse(n.body);r=c.pathSegments,o=c.newPathSegments}catch(c){e.status(400).json({error:`Failed to parse folder update body: ${c}`});return}let i=Ha(r),a=Ha(o);if(!yt.existsSync(i)){e.status(400).json({error:`Folder not found: ${r.join(it.sep)}`});return}if(yt.existsSync(a)){e.status(400).json({error:`Destination already exists: ${o.join(it.sep)}`});return}let s=it.dirname(a);yt.existsSync(s)||yt.mkdirSync(s,{recursive:!0}),yt.renameSync(i,a);let l={success:!0,message:`Folder moved from ${r.join(it.sep)} to ${o.join(it.sep)}`,pathSegments:o};e.status(200).json(l)}));ja.delete("/",le(async(n,e,t)=>{let r,o=!0;try{let l=hg.parse(n.body);r=l.pathSegments,o=l.recursive??!0}catch(l){e.status(400).json({error:`Failed to parse folder delete body: ${l}`});return}let i=Ha(r);if(!yt.existsSync(i)){e.status(200).json({success:!0,message:`Folder not found: ${r.join(it.sep)}`,pathSegments:r});return}if(!yt.statSync(i).isDirectory()){e.status(400).json({error:`Path is not a directory: ${r.join(it.sep)}`});return}if(o)yt.rmSync(i,{recursive:!0,force:!0});else{if(yt.readdirSync(i).length>0){e.status(409).json({error:`Cannot delete non-empty directory without recursive flag: ${r.join("/")}`});return}yt.rmdirSync(i)}let s={success:!0,message:`Folder deleted: ${r.join("/")}`,pathSegments:r};e.status(200).json(s)}));var wv=ja;import{Router as ok}from"express";var vv=ok();vv.get("/",le((n,e)=>{e.status(200).json({userId:Ql(),orgId:bn()})}));var Ev=vv;import{Router as ik}from"express";var Tv=ik();Tv.get("/",le((n,e)=>{let t=re(),r=ye(t,b),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 xv=Tv;import{Router as ak}from"express";var tc=ak();tc.get("/",le((n,e)=>{let t=hp().map(r=>({name:r.config.name,configFilePath:r.configFilePath}));e.status(200).json(t)}));tc.get("/current",le((n,e)=>{let t=re();if(!t){e.status(404).json({error:"No project found."});return}let r={name:t.config.name,configFilePath:t.configFilePath};e.status(200).json(r)}));tc.post("/set",le((n,e)=>{let t;try{t=dg.parse(n.body)}catch(r){e.status(400).json({error:`Invalid request body: ${r}`});return}try{let r=jt({configFilePath:t.configFilePath});mv(r,o=>jt({configFilePath:o}))}catch(r){e.status(400).json({error:`Error setting project: ${r}`});return}e.sendStatus(204)}));var Cv=tc;import{Router as sk}from"express";var Rv=sk();Rv.get("/",le((n,e)=>{let r={ai:re().config.ai};e.status(200).json(r)}));var Av=Rv;import{Router as dk}from"express";import Iv from"fs";import po from"path";import{v4 as Pv}from"uuid";import pk from"yaml";import{randomUUID as lk}from"node:crypto";import{PostHog as ck}from"posthog-node";var nc=class{identify(){return this}child(){return this}track(){return this}async shutdown(){}},Ti=class n{bindings;client;options;constructor(e,t={}){this.bindings=e,this.options=t,this.client=new ck("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(!kh(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:lk(),event:r,timestamp:t?.timestamp,properties:{...this.bindings,...o}}),this}};var xi=new Ti({platform:"local_app"},{flushAt:1,flushInterval:0});var xr=dk();xr.get("/",le((n,e)=>{let t=re(),r=ye(t,b),o=Object.values(r.tests);e.status(200).json(o)}));xr.post("/",le(async(n,e)=>{let t;try{t=og.parse(n.body)}catch(p){e.status(400).json({error:`Invalid request body: ${p}`});return}try{zr(t.name)}catch(p){e.status(400).json({error:p.message});return}let o={id:Pv(),name:t.name,description:t.description,baseUrl:t.baseUrl,schemaVersion:Oe,advanced:{browserType:t.browserType??"Chromium",viewport:t.viewport??qt},retries:0,steps:[]};t.environment&&(o.envs=[{name:t.environment,default:!0}]);let i=re(),a=ye(i,b);if(Object.values(a.tests).find(p=>p.name===t.name)){e.status(400).send(`A test with the name "${t.name}" already exists. Please use a different name.`);return}let l=po.join(i.rootDir,...t.pathSegments||[]),c=await sS({test:o,name:t.name,folder:l}),d={...o,relativeFilePath:po.relative(i.rootDir,c)};xi.track({type:"test_editor:test_create"}),e.status(201).json(d)}));xr.get("/:testPath",le(async(n,e)=>{let{testPath:t}=n.params;if(!t){e.status(400).json({error:"Missing testPath in url path."});return}let r=re(),o=ye(r,b),i;try{i=await ha(po.join(r.rootDir,t),Ge,o),e.status(200).json(i)}catch(a){e.status(400).send({error:a.message});return}(async()=>{try{let{stepsToSave:a,moduleUpdates:s}=await gt({stepLists:{steps:i.steps,beforeSteps:i.beforeSteps,afterSteps:i.afterSteps}});s.forEach(l=>{Zr({content:l,schemaVersion:Oe,momenticFiles:o,project:r})}),Wn({relativeTestPath:t,steps:a,schemaVersion:Oe,project:r})}catch(a){Ge.error({err:a},"Failed to save migrated test to disk after initial fetch")}})()}));xr.patch("/:testPath/metadata",le(async(n,e)=>{if(!n.params.testPath){e.status(400).json({error:"Missing testPath in url path."});return}let t;try{t=rg.parse(n.body)}catch(i){e.status(400).json({error:`Invalid request body: ${i}`});return}let o={message:"ok",newRelativeTestPath:Hd(n.params.testPath,t,re()).newRelativeTestPath};e.status(200).json(o)}));xr.patch("/:testPath",le(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=ng.parse(n.body)}catch(m){e.status(400).json({error:`Invalid request body: ${m}`});return}let o=re(),i=ye(o,b),a;try{a=ol(t,o)}catch(m){e.status(400).json({error:`Existing test file on disk is invalid: ${m}`});return}let{stepsToSave:s,moduleUpdates:l,cachesToSave:c}=await gt({stepLists:r.stepLists,cacheCreationParams:{testId:a.id,orgId:bn()}}),d=new ct({apiKey:gv(),baseUrl:Zl(),logger:Ge}),p=await si(Ge,d,o);await mi({orgId:bn(),client:d,gitMetadata:p}).saveStepCacheEntries({logger:Ge,testId:a.id,entries:c}),l.forEach(m=>{Zr({content:m,schemaVersion:r.schemaVersion,momenticFiles:i,project:o})}),Wn({relativeTestPath:t,steps:s,schemaVersion:r.schemaVersion,project:o}),e.status(201).json({message:"ok"})}));xr.patch("/:testPath/environments",le(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=cg.parse(n.body)}catch(o){e.status(400).json({error:`Invalid request body: ${o}`});return}Hd(t,{envs:r.defaultEnv?[{name:r.defaultEnv,default:!0}]:[]},re()),e.status(201).json({message:"ok"})}));xr.post("/:testPath/duplicate",le(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=ig.parse(n.body)}catch(f){e.status(400).json({error:`Invalid request body: ${f}`});return}try{zr(r.name)}catch(f){e.status(400).json({error:f.message});return}let o=re(),i=po.join(o.rootDir,t);if(!Iv.existsSync(i)){e.status(404).json({error:"Test not found."});return}let a=ye(o,b),s;try{s=await ha(i,Ge,a)}catch(f){e.status(400).send({error:f.message});return}let l=Pv(),c=Qt.parse({...s,name:r.name,id:l}),{stepsToSave:d}=await gt({stepLists:{steps:s.steps,beforeSteps:s.beforeSteps,afterSteps:s.afterSteps},createNewCacheIds:!0,cacheCreationParams:{testId:l,orgId:bn()}}),p=$n({fileType:ve.TEST,...c,beforeSteps:d.beforeSteps??void 0,steps:d.steps,afterSteps:d.afterSteps??void 0}),u=po.dirname(i),m=po.join(u,`${r.name}.${_t.TEST}`),h=pk.stringify(p);Iv.writeFileSync(m,h,"utf-8");let g={relativeFilePath:po.relative(o.rootDir,m)};xi.track({type:"test_editor:test_create"}),e.status(201).json(g)}));var Lv=xr;var $a=class{async prepareGoldenScreenshotForComparison(e,t,r){return await new ii(re(),!1).prepareGoldenScreenshotForComparison(e,t,r)}};async function kv(n){let{momenticServerUrl:e,apiKey:t,serverPort:r,staticDir:o,devicePixelRatio:i,version:a,logger:s=Ge,alwaysSaveCache:l,noCache:c}=n;pv(a),e&&uv(e),await hv(t);let d=bn(),p=Ql();xi.identify({user_id:p,org_id:d}),s.debug({params:n,orgId:d,userId:p},"Desktop server init and api key check done");let u=yk(o,r,s),m=`http://localhost:${r}`;b.info(`Desktop server is running at ${m}`),await new Promise(y=>{try{u.listen(r,()=>{s.info(`Desktop server is running at ${m}`),y()})}catch(x){x.message.includes("EADDRINUSE")?_v(r):b.error(`An unexpected error occurred while starting the server: ${x.message}`),process.exit(1)}});let g={type:"API_KEY",baseUrl:Zl(),apiKey:t,logger:s},f=async()=>{let y=re();return new pi(y.config.ai?.agentConfig,g)},S=async()=>new ui(g,await f()),w=new ct(g),E=new $a;lv({baseServer:u,getOrgId:async()=>bn(),generatorFactory:f,enricherFactory:S,cacheStorageFactory:async y=>{let x=re(),T=await si(s,w,x);return mi({orgId:y,client:w,gitMetadata:T,alwaysSaveCache:l,noCache:c})},flagStoreFactory:async y=>{let x=re();return new ai(x.config)},settingsFactory:async()=>{let y=re();return{ai:{},browser:{},...y.config}},storageFactory:async y=>new ec(w,y),logger:s,devicePixelRatio:i,authorization:g,visualDiffScreenshotStorage:E,analytics:xi})}var Nv="25mb";function yk(n,e,t){let r=Mv();r.use(uk()),r.use(Ov.json({limit:Nv})),r.use(Ov.urlencoded({extended:!1,limit:Nv}));let o=gk();if(o.use("/tests",Lv),o.use("/modules",fv),o.use("/environments",bv),o.use("/projects",Cv),o.use("/labels",xv),o.use("/folders",wv),o.use("/settings",Av),o.use("/identify",Ev),o.use("/entities",yv),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"),b.error(`Oh no! We seem to have hit an unexpected snag \u{1F61E}. Please contact Momentic Support with the following error: ${a.message}
3922
+ ${a.stack}`),l.status(500).send("Internal Server Error")}),n){let a=Mv.static(n,{setHeaders:s=>{s.setHeader("Cache-Control","no-cache")},redirect:!1});r.use(a),r.use("*",(s,l)=>{l.sendFile(Sk.join(n,"index.html"))})}let i=fk.createServer(r);return i.once("error",a=>{"code"in a&&a.code==="EADDRINUSE"?(_v(e),process.exit(1)):console.error("An unexpected server error occurred:",a.message)}),i}hk.setMaxListeners(50);process.on("warning",n=>{Ge.warn({err:n},`Node warning received on desktop-server: ${n.message}`)});process.on("uncaughtException",n=>{Ge.error({err:n},"Uncaught exception leading to exit on desktop-server"),b.error(`Oh no! The Momentic desktop app encountered a fatal error \u{1F61E}. Error logs: ${n.message}`)});process.on("unhandledRejection",(n,e)=>{Ge.error({reason:`${n}`,promise:`${e}`,stack:n?.stack},"Uncaught exception leading to exit on desktop-server (promise rejection)"),b.error(`Oh no! The Momentic desktop app encountered an asynchronous error \u{1F61E}. Error logs: ${n}`)});function _v(n){b.error(mk`Port ${n} is already in use by another process. Please close the other process and try again.
3913
3923
  Using Bash on MacOS or Linux:
3914
3924
  lsof -t -i :58888 | xargs kill -9
3915
3925
 
3916
3926
  Using Command Prompt on Windows:
3917
3927
  for /f "tokens=5" %a in ('netstat -ano ^| findstr :58888') do taskkill /PID %a /F
3918
- `)}import P_ from"events";import vc from"fs";import L_ from"open";import{cpus as GT}from"os";import wc from"path";import{fileURLToPath as O_}from"url";import kk from"diff-lines";import{gt as _k}from"semver";import{execSync as fk}from"child_process";import{platform as Sk}from"os";function fu(){return Nv()?(b.dimmed("Setting device pixel ratio to 2 automatically since a Mac OS Retina screen was detected."),b.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.
3928
+ `)}import M_ from"events";import Tc from"fs";import N_ from"open";import{cpus as qE}from"os";import Ec from"path";import{fileURLToPath as k_}from"url";import Fk from"diff-lines";import{gt as Uk}from"semver";import{execSync as bk}from"child_process";import{platform as wk}from"os";function Su(){return Dv()?(b.dimmed("Setting device pixel ratio to 2 automatically since a Mac OS Retina screen was detected."),b.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.
3919
3929
  `),2):(b.dimmed("Setting device pixel ratio to 1."),b.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.
3920
- l.`),1)}function Nv(){return Sk()==="darwin"&&fk("system_profiler SPDisplaysDataType").toString().includes("Retina")}function Su(n){Nv()&&n===1&&(b.warn("If you are using Momentic on a Retina screen, relaunch with the --pixel-ratio option to avoid incorrect viewport calculations."),b.warn("Confirm your device's pixel-ratio at https://www.mydevice.io."))}import yk from"@actions/exec";import bk from"@actions/io";import wk from"quote";import vk from"string-argv";async function kv(n,e=!0){let t=vk(n),r=await bk.which(t[0],!0),o=t.slice(1),i=yk.exec(wk(r),o,{delay:100});if(e)return i}import{existsSync as Tk,statSync as Ek}from"fs";var Ga=!!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 _v(n){try{return Tk(n)&&Ek(n).isDirectory()}catch(e){return b.error({err:e},`Error reading path ${n} during directory existence check`),!1}}import xk from"csv-parser";import{createReadStream as Ck}from"fs";function yu(n){return new Promise((e,t)=>{let r=[];Ck(n).pipe(xk()).on("data",o=>r.push(o)).on("end",()=>e(r)).on("error",o=>t(o))})}import tc from"semver";import{z as nc}from"zod";var wn="2.7.1",Rk="https://registry.npmjs.org/momentic",Ak=nc.object({versions:nc.record(nc.string(),nc.unknown()).optional()});async function Dv(n){try{await Ik(n)}catch(e){b.warn({err:e},"Failed to check CLI version against NPM servers")}}async function Ik(n){if(!wn){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 B(fetch(Rk),{milliseconds:5e3});if(!o.ok)throw new Error(`Got error status code ${o.statusText}`);let i=await o.json();e=Ak.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))tc.valid(r)&&(!t||tc.gt(r,t))&&tc.gt(r,wn)&&tc.lt(r,"2.0.0")&&!r.includes("alpha")&&(t=r);t&&(b.warn(`Update available: v${wn} -> v${t}`),b.warn("This version may be missing critical fixes, features, and security updates."),b.warn(`Run "npx momentic@${t} -V" to update`))}import{existsSync as Lk,mkdirSync as Ok,statSync as Mk}from"fs";import{dirname as Nk}from"path";import Uv from"readline/promises";import{hostname as Pk}from"os";var ee=Yl({app:"cli",clientToken:"pub7eb923f18fb3f1d42ac5eba8c5ea13a5",hostname:Pk(),disableConsoleLogs:!0}).child({version:"2.7.1"});var bu=!1,Bv=(()=>{try{return Mk("/.dockerenv"),!0}catch{return!1}})();async function bt(n,e){if(Ga||bu||Bv)return!0;ee.flush(),await new Promise(a=>setTimeout(a,500));let t=Uv.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?b.warn(a):b.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"?(bu=!0,setTimeout(()=>{bu=!1},3e3),!0):i.toLowerCase()==="y"}async function wu(n){let e=Nk(n);return _v(e)?Lk(n)?bt(`File '${Fv(n)}' already exists. Overwrite existing content?`,!0):!0:await bt(`Directory '${Fv(e)}' doesn't exist. Create it now?`,!0)?(Ok(e,{recursive:!0}),!0):!1}function Fv(n){return n.replace(/(\s+)/g,"\\$1")}async function zv(n,e){if(Ga||Bv)return e;let t=Uv.createInterface({input:process.stdin,output:process.stdout}),r=await t.question(`${n} `);return t.close(),r.trim()||e}async function Hv({test:n,fragment:e,entities:t,client:r,logger:o,yes:i}){_k(e.schemaVersion,Oe)&&(b.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)),hf(e.steps).forEach(g=>{t.modules[g]||(b.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 bt("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 bt("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=eo(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!==Oe){let{steps:g,newVersion:f}=await da({metadata:{id:e.id,schemaVersion:e.schemaVersion},steps:e.steps,logger:b});d=f,p=Le.array().parse(g)}else p=Le.array().parse(e.steps);let{stepsToSave:u,moduleUpdates:m}=await gt({stepLists:{steps:p}});u.beforeSteps=l.beforeSteps??void 0,u.afterSteps=l.afterSteps??void 0;let h=kk(JSON.stringify(c,void 0,2),JSON.stringify(u,void 0,2),{n_surrounding:5});b.dimmed("=".repeat(30)),b.dimmed(h),b.dimmed("=".repeat(30)),b.dimmed(""),d&&b.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 bt("Do you want to apply this patch?")&&(b.dimmed("Cancelled."),process.exit(1)),Wn({relativeTestPath:n.relativePath,steps:u,schemaVersion:d??e.schemaVersion,project:t.project}),b.success("Patch applied successfully."),await r.patchTestFragment(e.id,{applied:!0,appliedAt:new Date})}import{randomUUID as uo}from"crypto";import{z as iT}from"zod";var Ut=" ".repeat(6);import oT from"chalk";import{Argument as Ci,InvalidArgumentError as Wa,Option as ke}from"@commander-js/extra-typings";import{validateHeaderValue as Dk}from"http";import{z as $v}from"zod";var jv=58888,rc=30*60*1e3;function Jn(n){let e=parseInt(n,10);if(isNaN(e))throw new Wa("Not a number.");return e}function oc(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);Dk(o,i),e[o]=i}return e}var Xn=new ke("--api-key <key>","Momentic API key").env("MOMENTIC_API_KEY").argParser(n=>{if(!n)throw new Wa("API key is required.");return n}).makeOptionMandatory(),Qn=new ke("--server <server>","Momentic server to use.").default("https://api.momentic.ai").argParser(n=>{try{return $v.string().url().parse(n),n}catch{throw new Wa("Not a valid URL.")}}),Cr=new ke("-y, --yes","Skip all confirmation prompts.").env("CI"),vu=new ke("-w, --wait","Wait for tests to finish running before exiting."),Tu=new ke("--wait-timeout <waitTimeout>",`The maximum number of seconds to wait for tests to complete. Defaults to ${rc/1e3} seconds.`).default(rc/1e3).implies({wait:!0}).argParser(Jn),ic=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."),Gv=new ke("--reporter <reporter>","Output report files in a standardized format to a local directory.").choices(Object.values(Os)),Wv=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.").default("reports"),Eu=new ke("--output-dir <outputDir>","Output directory to store run artifacts such as screenshots, results, and logs."),Vv=new ke("--upload-results","Upload test results to Momentic Cloud.").default(!1),xu=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."),Cu=new ke("--exclude <excludePatterns...>","The inverted version of --include: a test that matches any of the provided exclusion patterns will be excluded from running."),Ru=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.").argParser(Jn),qv=new ke("--port <port>",`Port to run the app on. Defaults to ${jv}.`).default(jv).argParser(Jn),Au=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."),ac=new ke("--env <env>","Name of the environment to use when running tests."),sc=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.").argParser(n=>{try{return $v.string().url().parse(n),n}catch{throw new Wa("Not a valid URL.")}}),Kv=new ke("--shard-index <shardIndex>","The index of the shard to run tests for. Defaults to 1.").default(1).argParser(n=>{let e=Jn(n);if(e<1)throw new Wa("Shard index must be greater than 0.");return e}),Yv=new ke("--shard-count <shardCount>","The number of shards that tests are being run on. Defaults to 1.").default(1).argParser(Jn),vn=new ke("-c, --config <configPath>","Absolute or relative path to a Momentic configuration file."),lc=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."),Jv=new ke("--fix","Attempt to fix any issues found."),Iu=new ke("--save-cache","Always save updated step caches after successful test runs. By default, caches are not saved when running on protected branches.").env("CI"),Pu=new ke("--disable-cache","Disable caching of test results."),Xv=new Ci("<tests...>","One or more test paths to queue on Momentic Cloud."),Qv=new Ci("<tests...>","One or more test paths to import from Momentic Cloud.").argOptional(),Lu=new Ci("<tests...>","One or more test file path or folders that exist on the local machine.").argOptional(),Zv=new Ci("<suites...>","One or more suite paths that exist on Momentic Cloud."),eT=new Ci("<resultsPath>","Path to a directory that contains on or more test results archives.").argRequired(),tT=new Ci("<results>","Path to the results archive.").argRequired();async function Ou(n){let e=process.versions.node,t=parseInt(e.split(".")[0]);(isNaN(t)||t<18)&&(b.error(`Node.js version 18 or higher is required to run the CLI. Detected: ${process.versions.node}.`),process.exit(1)),b.debug(`Identified node version ${e}`);let r=await n.client.getAuthInfo();return b.debug("Got auth info from API"),r}import{Console as nT}from"console";import{format as Va}from"util";var Mu=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}},cc=class n extends nT{_buffer=[];_groupDepth=0;Console=nT;constructor(){super({write:e=>(n.write(this._buffer,"log",e),!0)})}static write(e,t,r,o=2){let i=new Mu(void 0,n.write).stack;if(!i)return e;let a=i.split(`
3930
+ l.`),1)}function Dv(){return wk()==="darwin"&&bk("system_profiler SPDisplaysDataType").toString().includes("Retina")}function yu(n){Dv()&&n===1&&(b.warn("If you are using Momentic on a Retina screen, relaunch with the --pixel-ratio option to avoid incorrect viewport calculations."),b.warn("Confirm your device's pixel-ratio at https://www.mydevice.io."))}import vk from"@actions/exec";import Ek from"@actions/io";import Tk from"quote";import xk from"string-argv";async function Fv(n,e=!0){let t=xk(n),r=await Ek.which(t[0],!0),o=t.slice(1),i=vk.exec(Tk(r),o,{delay:100});if(e)return i}import{existsSync as Ck,statSync as Rk}from"fs";var Ga=!!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 Uv(n){try{return Ck(n)&&Rk(n).isDirectory()}catch(e){return b.error({err:e},`Error reading path ${n} during directory existence check`),!1}}import Ak from"csv-parser";import{createReadStream as Ik}from"fs";function bu(n){return new Promise((e,t)=>{let r=[];Ik(n).pipe(Ak()).on("data",o=>r.push(o)).on("end",()=>e(r)).on("error",o=>t(o))})}import rc from"semver";import{z as oc}from"zod";var wn="2.7.2",Pk="https://registry.npmjs.org/momentic",Lk=oc.object({versions:oc.record(oc.string(),oc.unknown()).optional()});async function Bv(n){try{await Ok(n)}catch(e){b.warn({err:e},"Failed to check CLI version against NPM servers")}}async function Ok(n){if(!wn){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 B(fetch(Pk),{milliseconds:5e3});if(!o.ok)throw new Error(`Got error status code ${o.statusText}`);let i=await o.json();e=Lk.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))rc.valid(r)&&(!t||rc.gt(r,t))&&rc.gt(r,wn)&&rc.lt(r,"2.0.0")&&!r.includes("alpha")&&(t=r);t&&(b.warn(`Update available: v${wn} -> v${t}`),b.warn("This version may be missing critical fixes, features, and security updates."),b.warn(`Run "npx momentic@${t} -V" to update`))}import{existsSync as Nk,mkdirSync as kk,statSync as _k}from"fs";import{dirname as Dk}from"path";import Hv from"readline/promises";import{hostname as Mk}from"os";var te=Xl({app:"cli",clientToken:"pub7eb923f18fb3f1d42ac5eba8c5ea13a5",hostname:Mk(),disableConsoleLogs:!0}).child({version:"2.7.2"});var wu=!1,jv=(()=>{try{return _k("/.dockerenv"),!0}catch{return!1}})();async function bt(n,e){if(Ga||wu||jv)return!0;te.flush(),await new Promise(a=>setTimeout(a,500));let t=Hv.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?b.warn(a):b.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"?(wu=!0,setTimeout(()=>{wu=!1},3e3),!0):i.toLowerCase()==="y"}async function vu(n){let e=Dk(n);return Uv(e)?Nk(n)?bt(`File '${zv(n)}' already exists. Overwrite existing content?`,!0):!0:await bt(`Directory '${zv(e)}' doesn't exist. Create it now?`,!0)?(kk(e,{recursive:!0}),!0):!1}function zv(n){return n.replace(/(\s+)/g,"\\$1")}async function $v(n,e){if(Ga||jv)return e;let t=Hv.createInterface({input:process.stdin,output:process.stdout}),r=await t.question(`${n} `);return t.close(),r.trim()||e}async function Gv({test:n,fragment:e,entities:t,client:r,logger:o,yes:i}){Uk(e.schemaVersion,Oe)&&(b.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)),gf(e.steps).forEach(g=>{t.modules[g]||(b.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 bt("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 bt("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=eo(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!==Oe){let{steps:g,newVersion:f}=await da({metadata:{id:e.id,schemaVersion:e.schemaVersion},steps:e.steps,logger:b});d=f,p=Le.array().parse(g)}else p=Le.array().parse(e.steps);let{stepsToSave:u,moduleUpdates:m}=await gt({stepLists:{steps:p}});u.beforeSteps=l.beforeSteps??void 0,u.afterSteps=l.afterSteps??void 0;let h=Fk(JSON.stringify(c,void 0,2),JSON.stringify(u,void 0,2),{n_surrounding:5});b.dimmed("=".repeat(30)),b.dimmed(h),b.dimmed("=".repeat(30)),b.dimmed(""),d&&b.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 bt("Do you want to apply this patch?")&&(b.dimmed("Cancelled."),process.exit(1)),Wn({relativeTestPath:n.relativePath,steps:u,schemaVersion:d??e.schemaVersion,project:t.project}),b.success("Patch applied successfully."),await r.patchTestFragment(e.id,{applied:!0,appliedAt:new Date})}import{randomUUID as uo}from"crypto";import{z as lE}from"zod";var Ut=" ".repeat(6);import sE from"chalk";import{Argument as Ci,InvalidArgumentError as Wa,Option as ke}from"@commander-js/extra-typings";import{validateHeaderValue as Bk}from"http";import{z as Vv}from"zod";var Wv=58888,ic=30*60*1e3;function Xn(n){let e=parseInt(n,10);if(isNaN(e))throw new Wa("Not a number.");return e}function ac(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);Bk(o,i),e[o]=i}return e}var Zn=new ke("--api-key <key>","Momentic API key").env("MOMENTIC_API_KEY").argParser(n=>{if(!n)throw new Wa("API key is required.");return n}).makeOptionMandatory(),Qn=new ke("--server <server>","Momentic server to use.").default("https://api.momentic.ai").argParser(n=>{try{return Vv.string().url().parse(n),n}catch{throw new Wa("Not a valid URL.")}}),Cr=new ke("-y, --yes","Skip all confirmation prompts.").env("CI"),Eu=new ke("-w, --wait","Wait for tests to finish running before exiting."),Tu=new ke("--wait-timeout <waitTimeout>",`The maximum number of seconds to wait for tests to complete. Defaults to ${ic/1e3} seconds.`).default(ic/1e3).implies({wait:!0}).argParser(Xn),sc=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."),qv=new ke("--reporter <reporter>","Output report files in a standardized format to a local directory.").choices(Object.values(Os)),Kv=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.").default("reports"),xu=new ke("--output-dir <outputDir>","Output directory to store run artifacts such as screenshots, results, and logs."),Yv=new ke("--upload-results","Upload test results to Momentic Cloud.").default(!1),Cu=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."),Ru=new ke("--exclude <excludePatterns...>","The inverted version of --include: a test that matches any of the provided exclusion patterns will be excluded from running."),Au=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.").argParser(Xn),Jv=new ke("--port <port>",`Port to run the app on. Defaults to ${Wv}.`).default(Wv).argParser(Xn),Iu=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."),lc=new ke("--env <env>","Name of the environment to use when running tests."),cc=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.").argParser(n=>{try{return Vv.string().url().parse(n),n}catch{throw new Wa("Not a valid URL.")}}),Xv=new ke("--shard-index <shardIndex>","The index of the shard to run tests for. Defaults to 1.").default(1).argParser(n=>{let e=Xn(n);if(e<1)throw new Wa("Shard index must be greater than 0.");return e}),Zv=new ke("--shard-count <shardCount>","The number of shards that tests are being run on. Defaults to 1.").default(1).argParser(Xn),vn=new ke("-c, --config <configPath>","Absolute or relative path to a Momentic configuration file."),dc=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."),Qv=new ke("--fix","Attempt to fix any issues found."),Pu=new ke("--save-cache","Always save updated step caches after successful test runs. By default, caches are not saved when running on protected branches.").env("CI"),Lu=new ke("--disable-cache","Disable caching of test results."),eE=new Ci("<tests...>","One or more test paths to queue on Momentic Cloud."),tE=new Ci("<tests...>","One or more test paths to import from Momentic Cloud.").argOptional(),Ou=new Ci("<tests...>","One or more test file path or folders that exist on the local machine.").argOptional(),nE=new Ci("<suites...>","One or more suite paths that exist on Momentic Cloud."),rE=new Ci("<resultsPath>","Path to a directory that contains on or more test results archives.").argRequired(),oE=new Ci("<results>","Path to the results archive.").argRequired();async function Mu(n){let e=process.versions.node,t=parseInt(e.split(".")[0]);(isNaN(t)||t<18)&&(b.error(`Node.js version 18 or higher is required to run the CLI. Detected: ${process.versions.node}.`),process.exit(1)),b.debug(`Identified node version ${e}`);let r=await n.client.getAuthInfo();return b.debug("Got auth info from API"),r}import{Console as iE}from"console";import{format as Va}from"util";var Nu=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}},pc=class n extends iE{_buffer=[];_groupDepth=0;Console=iE;constructor(){super({write:e=>(n.write(this._buffer,"log",e),!0)})}static write(e,t,r,o=2){let i=new Nu(void 0,n.write).stack;if(!i)return e;let a=i.split(`
3921
3931
  `).slice(o).filter(Boolean).join(`
3922
- `);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",Va(e,...t))}error(e,...t){this._log("error",Va(e,...t))}info(e,...t){this._log("info",Va(e,...t))}log(e,...t){this._log("log",Va(e,...t))}warn(e,...t){this._log("warn",Va(e,...t))}getBuffer(){return this._buffer.length>0?this._buffer:void 0}};function rT(n){let e=globalThis.console,t=new cc;globalThis.console=t;try{n()}finally{let o=t.getBuffer()?.map(i=>i.message).join(`
3932
+ `);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",Va(e,...t))}error(e,...t){this._log("error",Va(e,...t))}info(e,...t){this._log("info",Va(e,...t))}log(e,...t){this._log("log",Va(e,...t))}warn(e,...t){this._log("warn",Va(e,...t))}getBuffer(){return this._buffer.length>0?this._buffer:void 0}};function aE(n){let e=globalThis.console,t=new pc;globalThis.console=t;try{n()}finally{let o=t.getBuffer()?.map(i=>i.message).join(`
3923
3933
  `);process.stderr.write(`${o}
3924
- `),globalThis.console=e}}var Uk=5;async function dc({getResults:n,checkDone:e,name:t,timeoutMs:r=rc}){let o=Date.now(),i=0;for(;Date.now()-o<r;){let a;i>Uk&&(b.error(`Failed to fetch ${t} status too many times.`),process.exit(1));try{a=await n(),i=0}catch(c){i++,ee.warn({err:c},"Failed to fetch run status, retrying..."),b.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))}b.error(`Timeout elapsed waiting for ${t} to complete (${Math.floor(r/1e3)}s).`),process.exit(1)}function Ri({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 rT(()=>{a.forEach(l=>{b.log(""),o(l)}),a.length&&(b.log(""),b.error(`${a.length} ${t}s failed:`),a.forEach(l=>{b.dimmed(r(l))})),s.length&&(b.log(""),b.warn(`${s.length} ${t}s cancelled:`),s.forEach(l=>{b.dimmed(r(l))})),i.length&&(b.log(""),b.success(`${i.length} ${t}s passed:`),i.forEach(l=>{b.dimmed(r(l))})),b.log(""),b.dimmed(`Total time: ${Math.round((Date.now()-e)/1e3)}s`)}),{passed:i.length,failed:a.length,cancelled:s.length}}var pc=(n,e)=>{if(!n.failureDetails||!n.failureReason)return;let t=Ss[n.failureDetails?.classification?.reason||n.failureReason],r=n.failureDetails?.classification?.summary||ko[n.failureReason];b.error(e),b.log(`${Ut}Reason: ${oT.red(t)}`),b.log(`${Ut}Description: ${oT.red(r)}`)};async function Nu({fix:n,project:e}){let t=Se(e,b),r=Object.values(t.tests),o={},i={},a={},s=new Set,l={},c=new Set,d=0;for(let u of r)try{let m=eo(u.fullFilePath,ee,t),h=m.steps;if(!h||h.length===0||!Array.isArray(h)){b.debug(`Test ${u.name} (${u.relativePath}) has no steps, skipping...`);continue}let g=ht.parse(m),f=await Kr(g,h,b),S=!1,w=!1;f.steps=f.steps.map((T,y)=>{T.id||(b.error(`Step ${y} in test '${u.name}' (${u.relativePath}) does not have an ID`),w=!0,n&&(S=!0,T.id=uo())),iT.string().uuid().safeParse(T.id)||(b.error(`Step ${y} in test '${u.name}' (${u.relativePath}) has an ID that does not parse as a UUID: '${T.id}'`),w=!0,n&&(S=!0,T.id=uo()));let E=o[T.id]?.testId,x=o[T.id]?.testRelativePath;if(E?(d++,w=!0,E===u.id?b.error(`Multiple steps in the test '${u.name}' (${u.relativePath}) have the same ID '${T.id}'`):b.error(`Step ${y} in test '${u.name}' (${u.relativePath}) has the ID ${T.id} which is duplicated in ${x}`),n&&(S=!0,T.id=uo())):o[T.id]={testId:u.id,testRelativePath:u.relativePath},T.type==="PRESET_ACTION"){let A=T.command.id,k=a[A]?.testId,L=a[A]?.testRelativePath;k?(d++,w=!0,k===u.id?b.error(`Multiple commands in the test '${u.name}' (${u.relativePath}) have the same ID '${A}'`):b.error(`Command ${y} in test '${u.name}' (${u.relativePath}) has the ID ${A} which is duplicated in test ${L}`),n&&(S=!0,T.command.id=uo())):a[A]={testId:u.id,testRelativePath:u.relativePath}}return we.parse(T)}),w&&b.dimmed("=".repeat(80)),S&&n&&(Wn({relativeTestPath:u.relativePath,steps:{beforeSteps:m.beforeSteps,steps:f.steps,afterSteps:m.afterSteps},schemaVersion:Oe,project:e}),s.add(u.fullFilePath))}catch(m){b.error({err:m},`Failed to parse test ${u.name} (${u.relativePath})`);continue}let p=Object.values(t.modules);for(let u of p)try{let m=Gn(u.fullFilePath,b),h=m.steps;if(!h||h.length===0||!Array.isArray(h)){b.debug(`Module ${u.name} (${u.relativePath}) has no steps, skipping...`);continue}let g,f;try{let y=await Kr({id:m.moduleId,schemaVersion:m.schemaVersion},m.steps,b);g=y.steps,f=y.newVersion}catch(y){b.error({err:y},`Failed to migrate module ${u.name} (${u.relativePath})`);continue}let S=!1,w=!1,T=g.map((y,E)=>{if(iT.string().uuid().safeParse(y.id)||(b.error(`Step ${E} in module '${u.name}' (${u.relativePath}) has an ID that does not parse as a UUID: '${y.id}'`),w=!0,n&&(S=!0,y.id=uo())),o[y.id]?.testId){let A=o[y.id]?.testRelativePath;d++,w=!0,b.error(`Step ${E} in module '${u.name}' (${u.relativePath}) has the ID ${y.id} which is duplicated in test ${A}`),n&&(S=!0,y.id=uo())}if(y.type==="PRESET_ACTION"){let A=y.command.id,k=a[A],L=l[A];k||L?(d++,w=!0,L?.moduleId===u.id?b.error(`Multiple commands in module '${u.name}' (${u.relativePath}) have the same ID '${A}'`):k?b.error(`Command in module '${u.name}' (${u.relativePath}) has the ID ${A} which is duplicated in test ${k.testRelativePath}`):b.error(`Command ${E} in module '${u.name}' (${u.relativePath}) has the ID ${A} which is duplicated in module ${L.moduleRelativePath}`),n&&(S=!0,y.command.id=uo())):l[A]={moduleId:u.id,moduleRelativePath:u.relativePath}}return we.parse(y)});w&&b.dimmed("=".repeat(80)),S&&n&&(Qr({content:{...m,steps:T},schemaVersion:f,momenticFiles:t,project:e,forceSaveOnNoDiffs:!0}),c.add(u.fullFilePath))}catch(m){b.error({err:m},`Failed to parse module ${u.name} (${u.relativePath})`);continue}return{errors:d,modifiedTestFilePaths:s,modifiedModuleFilePaths:c}}async function aT({fix:n,project:e}){let{errors:t,modifiedTestFilePaths:r,modifiedModuleFilePaths:o}=await Nu({fix:n,project:e});t>0?(b.error(`Found errors in ${t} steps`),n?(b.warn(`Modified the following test files:
3934
+ `),globalThis.console=e}}var Hk=5;async function uc({getResults:n,checkDone:e,name:t,timeoutMs:r=ic}){let o=Date.now(),i=0;for(;Date.now()-o<r;){let a;i>Hk&&(b.error(`Failed to fetch ${t} status too many times.`),process.exit(1));try{a=await n(),i=0}catch(c){i++,te.warn({err:c},"Failed to fetch run status, retrying..."),b.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))}b.error(`Timeout elapsed waiting for ${t} to complete (${Math.floor(r/1e3)}s).`),process.exit(1)}function Ri({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 aE(()=>{a.forEach(l=>{b.log(""),o(l)}),a.length&&(b.log(""),b.error(`${a.length} ${t}s failed:`),a.forEach(l=>{b.dimmed(r(l))})),s.length&&(b.log(""),b.warn(`${s.length} ${t}s cancelled:`),s.forEach(l=>{b.dimmed(r(l))})),i.length&&(b.log(""),b.success(`${i.length} ${t}s passed:`),i.forEach(l=>{b.dimmed(r(l))})),b.log(""),b.dimmed(`Total time: ${Math.round((Date.now()-e)/1e3)}s`)}),{passed:i.length,failed:a.length,cancelled:s.length}}var mc=(n,e)=>{if(!n.failureDetails||!n.failureReason)return;let t=Ss[n.failureDetails?.classification?.reason||n.failureReason],r=n.failureDetails?.classification?.summary||ko[n.failureReason];b.error(e),b.log(`${Ut}Reason: ${sE.red(t)}`),b.log(`${Ut}Description: ${sE.red(r)}`)};async function ku({fix:n,project:e}){let t=ye(e,b),r=Object.values(t.tests),o={},i={},a={},s=new Set,l={},c=new Set,d=0;for(let u of r)try{let m=eo(u.fullFilePath,te,t),h=m.steps;if(!h||h.length===0||!Array.isArray(h)){b.debug(`Test ${u.name} (${u.relativePath}) has no steps, skipping...`);continue}let g=ht.parse(m),f=await Kr(g,h,b),S=!1,w=!1;f.steps=f.steps.map((E,y)=>{E.id||(b.error(`Step ${y} in test '${u.name}' (${u.relativePath}) does not have an ID`),w=!0,n&&(S=!0,E.id=uo())),lE.string().uuid().safeParse(E.id)||(b.error(`Step ${y} in test '${u.name}' (${u.relativePath}) has an ID that does not parse as a UUID: '${E.id}'`),w=!0,n&&(S=!0,E.id=uo()));let x=o[E.id]?.testId,T=o[E.id]?.testRelativePath;if(x?(d++,w=!0,x===u.id?b.error(`Multiple steps in the test '${u.name}' (${u.relativePath}) have the same ID '${E.id}'`):b.error(`Step ${y} in test '${u.name}' (${u.relativePath}) has the ID ${E.id} which is duplicated in ${T}`),n&&(S=!0,E.id=uo())):o[E.id]={testId:u.id,testRelativePath:u.relativePath},E.type==="PRESET_ACTION"){let A=E.command.id,D=a[A]?.testId,L=a[A]?.testRelativePath;D?(d++,w=!0,D===u.id?b.error(`Multiple commands in the test '${u.name}' (${u.relativePath}) have the same ID '${A}'`):b.error(`Command ${y} in test '${u.name}' (${u.relativePath}) has the ID ${A} which is duplicated in test ${L}`),n&&(S=!0,E.command.id=uo())):a[A]={testId:u.id,testRelativePath:u.relativePath}}return we.parse(E)}),w&&b.dimmed("=".repeat(80)),S&&n&&(Wn({relativeTestPath:u.relativePath,steps:{beforeSteps:m.beforeSteps,steps:f.steps,afterSteps:m.afterSteps},schemaVersion:Oe,project:e}),s.add(u.fullFilePath))}catch(m){b.error({err:m},`Failed to parse test ${u.name} (${u.relativePath})`);continue}let p=Object.values(t.modules);for(let u of p)try{let m=Gn(u.fullFilePath,b),h=m.steps;if(!h||h.length===0||!Array.isArray(h)){b.debug(`Module ${u.name} (${u.relativePath}) has no steps, skipping...`);continue}let g,f;try{let y=await Kr({id:m.moduleId,schemaVersion:m.schemaVersion},m.steps,b);g=y.steps,f=y.newVersion}catch(y){b.error({err:y},`Failed to migrate module ${u.name} (${u.relativePath})`);continue}let S=!1,w=!1,E=g.map((y,x)=>{if(lE.string().uuid().safeParse(y.id)||(b.error(`Step ${x} in module '${u.name}' (${u.relativePath}) has an ID that does not parse as a UUID: '${y.id}'`),w=!0,n&&(S=!0,y.id=uo())),o[y.id]?.testId){let A=o[y.id]?.testRelativePath;d++,w=!0,b.error(`Step ${x} in module '${u.name}' (${u.relativePath}) has the ID ${y.id} which is duplicated in test ${A}`),n&&(S=!0,y.id=uo())}if(y.type==="PRESET_ACTION"){let A=y.command.id,D=a[A],L=l[A];D||L?(d++,w=!0,L?.moduleId===u.id?b.error(`Multiple commands in module '${u.name}' (${u.relativePath}) have the same ID '${A}'`):D?b.error(`Command in module '${u.name}' (${u.relativePath}) has the ID ${A} which is duplicated in test ${D.testRelativePath}`):b.error(`Command ${x} in module '${u.name}' (${u.relativePath}) has the ID ${A} which is duplicated in module ${L.moduleRelativePath}`),n&&(S=!0,y.command.id=uo())):l[A]={moduleId:u.id,moduleRelativePath:u.relativePath}}return we.parse(y)});w&&b.dimmed("=".repeat(80)),S&&n&&(Zr({content:{...m,steps:E},schemaVersion:f,momenticFiles:t,project:e,forceSaveOnNoDiffs:!0}),c.add(u.fullFilePath))}catch(m){b.error({err:m},`Failed to parse module ${u.name} (${u.relativePath})`);continue}return{errors:d,modifiedTestFilePaths:s,modifiedModuleFilePaths:c}}async function cE({fix:n,project:e}){let{errors:t,modifiedTestFilePaths:r,modifiedModuleFilePaths:o}=await ku({fix:n,project:e});t>0?(b.error(`Found errors in ${t} steps`),n?(b.warn(`Modified the following test files:
3925
3935
  ${[...r].map(i=>`${Ut}- ${i}`).join(`
3926
3936
  `)}`),o.size>0&&b.warn(`Modified the following module files:
3927
3937
  ${[...o].map(i=>`${Ut}- ${i}`).join(`
3928
- `)}`)):b.warn("To fix these errors automatically, re-run this check with the --fix flag and then commit the resulting changes"),process.exit(1)):(b.success("No step ID errors found!"),process.exit(0))}async function sT({project:n}){let e=Se(n,b),t=Object.values(e.tests),r=await tl(e,ee),o={},i={},a={},s={},l=new Set,c=new Set,d=new Set,p=new Set;for(let m of t)o[m.id]?a[m.id]?a[m.id].push(m.fullFilePath):a[m.id]=[o[m.id],m.fullFilePath]:o[m.id]=m.fullFilePath,i[m.name]?s[m.name]?s[m.name].push(m.fullFilePath):s[m.name]=[i[m.name],m.fullFilePath]:i[m.name]=m.fullFilePath;for(let m of r)p.has(m.moduleId)&&l.add(m.moduleId),d.has(m.name)&&c.add(m.name),p.add(m.moduleId),d.add(m.name);if(Object.entries(a).length>0||Object.entries(s).length>0||l.size>0||c.size>0){for(let[m,h]of Object.entries(a))for(let g of h)b.error(`Test ID ${m} is duplicated in ${g}`);for(let[m,h]of Object.entries(s))for(let g of h)b.error(`Test Name ${m} is duplicated in ${g}`);for(let m of l)b.error(`Module id ${m} is duplicated in your project`);for(let m of c)b.error(`Module name ${m} is duplicated in your project`);process.exit(1)}b.success("No duplicates detected. All test and module names and ids are unique."),process.exit(0)}import{cloneDeep as Bk}from"lodash-es";async function lT({client:n,skipPrompts:e,project:t}){let r=await n.getAllEnvironments(),o=Bk(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 bt(`Environment ${i.name} already exists in the project configuration file. Would you like to overwrite its variables?`)&&process.exit(1),a.baseUrl=i.variables[We],delete i.variables[We],a.envVariables=i.variables;else{let s=i.variables[We];delete i.variables[We],o.environments.push({name:i.name,baseUrl:s,envVariables:i.variables})}}ri(o,t.configFilePath),b.success(`Pulled ${r.length} environments successfully! Please make sure to commit any changes to your project configuration file.`)}import{createHash as cT}from"crypto";import dT from"fs";async function ku({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=pT(l,ve.TEST);!r&&!await wu(d)||(a+=1,dT.writeFileSync(d,c,"utf-8"),ee.info({checksum:cT("md5").update(c).digest("hex")},`Wrote '${d}'`))}let s=0;for(let[l,c]of Object.entries(i)){let d=pT(l,ve.MODULE);!r&&!await wu(d)||(s+=1,dT.writeFileSync(d,c,"utf-8"),ee.info({checksum:cT("md5").update(c).digest("hex")},`Wrote '${d}'`))}a===0?b.success("Pulled 0 tests."):b.success(`Pulled ${a} test${a>1?"s":""}${s?` and ${s} module${s>1?"s":""}`:""}!`)}function pT(n,e){switch(e){case ve.TEST:return`${Ie(n)}.${_t.TEST}`;case ve.MODULE:return`${Ie(n)}.${_t.MODULE}`;default:throw new Error(`Unknown entity type ${e}`)}}async function uT(n){let{project:e,client:t,skipPrompts:r}=n;b.info("Welcome to the Momentic Cloud importer wizard! \u{1F636}\u200D\u{1F32B}\uFE0F"),b.info("Importing environments from Momentic Cloud."),b.info(`This command will overwrite all local environment configuration in ${e.configFilePath} with environments from Momentic Cloud.`),await bt("Are you sure you want to proceed?",!0)||(b.info("Aborting..."),process.exit(1)),await lT({client:t,project:e,skipPrompts:r}),b.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.`),b.info("Importing tests and modules from Momentic Cloud."),await ku({testsToFetch:[],client:t,all:!0,yes:r}),b.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 mT(n){let{client:e,skipPrompts:t,paths:r}=n;await ku({testsToFetch:r,client:e,all:void 0,yes:t}),b.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 zk from"fs";import{tmpdir as Hk}from"os";import jk from"path";import{registry as qa}from"playwright-core/lib/server";import hT from"proper-lockfile";var gT=jk.join(Hk(),"momenticBrowserInstallation");var _u=["chrome","chromium","chrome-for-testing"],$k={Chromium:"chromium","Google Chrome":"chrome","Chrome for Testing":"chrome-for-testing"},fT={chrome:"chrome",chromium:"chromium","chrome-for-testing":"chromium-headless-shell"};function ST(n){let e=fT[$k[n]??""]??"",t=qa.findExecutable(e);return!t||t.installType==="none"?!1:Du(t)}function Du(n){let e=n.executablePath();return zk.existsSync(e)}function Gk(n,e){let t=fT[n];if(!t)throw new Error(`Requested install of unknown browser type ${n}`);let r=qa.findExecutable(t);if(!r||r.installType==="none")throw new Error(`Requested install of unknown browser type ${n}`);if(!(!e&&Du(r)))return r}async function Wk({browser:n,force:e}){let t=Gk(n,e);if(!t){b.info(`Browser '${n}' is already installed, skipping...`);return}b.info(`Installing browser '${n}'...`);try{await qa.installDeps([t],!1),await qa.install([t],!1)}catch(r){if(r.message.includes("Lock file is already being held")){b.warn("Another process is installing Playwright browsers. Waiting for completion before proceeding..");let o=qa.findExecutable(n),i=5*60*1e3,a=Date.now();for(;Date.now()-a<i&&!Du(o);)b.info("Waiting for browser to finish installing..."),await new Promise(s=>setTimeout(s,5e3))}else throw r}}async function yT({rawBrowsers:n,force:e=!1,all:t=!1}){let r=t?_u:Array.from(new Set(n));try{await hT.lock(gT,{stale:1e3*60*5,update:1e3*60,realpath:!1,retries:{retries:30,factor:2,maxTimeout:15e3,minTimeout:500}})}catch(i){b.warn(`Failed to acquire lock to install browsers. Please ensure that any other process installing browsers completes within 5 minutes: ${i}. Continuing without installation...`);return}let o;try{for(let i of r)try{await Wk({browser:i,force:e})}catch(a){o=a,b.error(`Failed to install the ${i} browser: ${a}`)}}finally{await hT.unlock(gT,{realpath:!1})}if(o)throw o}async function bT(n){let e=Se(n,b),t=Object.values(e.tests);for(let r of t)try{let o=eo(r.fullFilePath,b,e),i=o.steps;if(!i||i.length===0||!Array.isArray(i)){b.debug(`Test ${r.name} (${r.relativePath}) has no steps, skipping...`);continue}let a=ht.parse(o),s=await Kr(a,i,b);b.dimmed(`Updating ${r.relativePath}`),Wn({relativeTestPath:r.relativePath,steps:{beforeSteps:o.beforeSteps,steps:s.steps,afterSteps:o.afterSteps},schemaVersion:Oe,project:n,forceSaveOnNoDiffs:!0})}catch(o){b.error({err:o},`Failed to read or migrate test ${r.name} (${r.relativePath}), continuing...`)}for(let r of Object.values(e.modules)){b.dimmed(`Updating ${r.relativePath}`);try{let o=Gn(r.fullFilePath,b),i=o.steps;if(!i||i.length===0||!Array.isArray(i)){b.debug(`Module ${r.name} (${r.relativePath}) has no steps, skipping...`);continue}let a=await Kr({id:o.moduleId,schemaVersion:o.schemaVersion},i,b);Qr({content:{...o,steps:a.steps},schemaVersion:Oe,momenticFiles:e,project:n,forceSaveOnNoDiffs:!0})}catch(o){b.error({err:o},`Failed to read or migrate module ${r.name} (${r.relativePath}), continuing...`)}}}import{spawnSync as qk}from"child_process";import{PostHog as Vk}from"posthog-node";async function wT(n,e){let t,r=0,o=3,i,a;for(;r<o;)try{let s=await B(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 uc=class n extends aa{constructor(t,r,o,i){super(o,i);this.client=t;this.orgId=r}static async init(t){let r=new Vk("phc_WRWd8LYIv6rolgDsyCdrPpxtZhsu6qXAkEwPicl44bI",{host:"https://us.i.posthog.com"}),{flags:o,payloads:i}=await wT(r,t);return new n(r,t,o,i)}async refresh(){let{flags:t,payloads:r}=await wT(this.client,this.orgId);this.flags=t,this.payloads=r}};function Kk(){try{let e=qk("git remote show origin",{encoding:"utf8",maxBuffer:5242880}).stdout.match(/HEAD branch: (.*)$/m);if(e&&e[1])return e[1].trim();b.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);b.warn(`Could not determine Git main branch. Please set it manually in your project configuration under the 'gitMainBranch' field. Error:
3929
- ${e}`)}}async function vT({project:n,orgId:e,apiClient:t}){b.info("Pulling browser and AI configuration options from Cloud");let r=await uc.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},b.info(`Updated ${n.configFilePath} to include V2 browser and AI configuration options`),b.info("Determining main Git branch"),n.config.gitMainBranch=Kk(),ri(n.config,n.configFilePath),b.success("Migration complete!")}function TT(n){return n?Ie(n):"Unknown suite"}async function ET({client:n,orgId:e,suitePaths:t,wait:r,waitTimeout:o,...i}){let{suiteRunIds:a,runGroupIds:s}=await n.queueSuiteRuns({paths:t,...i});ee.info({orgId:e,suiteRunIds:a,runGroupIds:s,suitePaths:t},"Queued suites remotely"),b.dimmed(`Queued ${t.length} suites.`),r||process.exit(0);let l=Date.now();b.dimmed(`Waiting for ${t.length} suites to finish. You can view results upon completion at:`);for(let f of s)b.dimmed(`${Ut}- ${n.getAppUrl()}/run-groups/${f}`);let c=new Set,d=[],p=f=>(f.status==="FAILED"||f.status==="PASSED"||f.status==="CANCELLED")&&f.runs.every(w=>w.status==="FAILED"&&(w.failureReason||w.finishedAt&&Date.now()-w.finishedAt.getTime()>30*1e3)||w.status==="PASSED"||w.status==="CANCELLED"),u=await dc({name:"suites",getResults:async()=>{let f=s.filter(T=>!d.some(y=>y.id===T)),S=await n.bulkGetRunGroupStatus(f),w=[];for(let T of S)p(T)?d.push(T):w.push(T);return[...d,...w]},timeoutMs:o?o*1e3:void 0,checkDone:f=>(f.forEach(S=>{S.status==="RUNNING"&&(c.has(S.id)||(c.add(S.id),b.log(`${c.size}/${s.length} ${TT(S.suite?.name)}`)))}),f.every(p))}),m=n.getAppUrl(),g=Ri({results:u,startTime:l,onFailed:f=>{let S=TT(f.suite?.name),w=f.runs.filter(y=>y.status==="FAILED").length,T=f.runs.length;b.error(`${S} (${w}/${T} tests failed):`);for(let y of f.runs)if(y.status==="FAILED"){let E=y.testName||y.test?.name;b.error(` ${E?Ie(E):"Unknown test"} (${m}/runs/${y.id})`)}},entity:"suite",getDisplayLine:f=>` ${f.suite?.name?Ie(f.suite.name):"Unknown suite name"} (${m}/run-groups/${f.id})`});process.exit(g.failed>0?1:0)}async function xT({tests:n,client:e,orgId:t,...r}){!r.yes&&!await bt(`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(ee.info({queuedTests:o,runIds:i,orgId:t},"Queued tests remotely"),b.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;b.dimmed(`Waiting for ${o.length} tests to complete.`);let a=new Set,s=[],l=m=>m.status==="FAILED"&&m.failureReason||m.status==="PASSED"||m.status==="CANCELLED",c=e.getAppUrl(),d=Date.now(),p=await dc({name:"runs",getResults:async()=>{let m=i.filter(f=>!s.some(S=>S.id===f)),h=await e.bulkGetRunStatus(m),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:m=>(m.forEach(h=>{if(h.status==="RUNNING"&&!a.has(h.id)){a.add(h.id);let g=h.testName||h.test?.name;g&&b.log(`${a.size}/${o.length} ${Ie(g)}`)}}),m.every(l))}),u=Ri({results:p,startTime:d,onFailed:m=>{let h=m.testName||m.test?.name;pc(m,h?Ie(h):"Unknown test")},getDisplayLine:m=>{let h=m.testName||m.test?.name,g=` ${h?Ie(h):"Unknown test"}`;return m.id&&(g+=` (${c}/runs/${m.id})`),g},entity:"test"});process.exit(u.failed>0?1:0)}import Pi,{supportsColor as v_}from"chalk";import T_ from"fs";import{existsSync as s_,mkdirSync as l_,statSync as c_}from"fs";import{randomUUID as Fu}from"crypto";import mc from"fs";import{hostname as Yk}from"os";import Ka from"path";async function hc(n,e,t,r,o){if(r){let i=Ka.extname(r),a=`${Fu()}-screenshot${i}`,s=Ka.join(t,a),c=await(await fetch(r)).arrayBuffer();return mc.writeFileSync(s,Buffer.from(c)),a}if(o){let i=await e.getScreenshot(n,o);if(i){let a=`${o}-screenshot.jpeg`,s=Ka.join(t,a);return mc.writeFileSync(s,i),a}}}async function Jk(n,e,t,r){let o=r.runId??Fu(),i={uuid:o,historyId:o,testCaseId:r.test.id,fullName:r.test.name,name:Ie(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:Yk()},{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 Xk(n,e,t.folder,i.steps,r.results);let a=`${o}-result.json`;mc.writeFileSync(Ka.join(t.folder,a),JSON.stringify(i,void 0,2))}async function Ai(n,e,t,r){let o={name:pn(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 hc(n,e,t,r.beforeScreenshot,r.beforeSnapshot);i&&o.attachments.push({name:"Screenshot before step",source:i,type:"image/jpeg"});let a=await hc(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=`${Fu()}-attachment.json`,l=Ka.join(t,s);mc.writeFileSync(l,JSON.stringify(r.data,null,2)),o.attachments.push({name:"Step output data",source:s,type:"text/plain"})}return o}async function Xk(n,e,t,r,o){for(let i of o)switch(i.type){case"PRESET_ACTION":{r.push(await Ai(n,e,t,i));break}case"CONDITIONAL":{let a=await Ai(n,e,t,i);a.steps=[],i.assertion&&a.steps.push(await Ai(n,e,t,i.assertion)),a.steps.push(...await Promise.all(i.results.map(s=>Ai(n,e,t,s)))),r.push(a);break}case"AI_ACTION":case"IFRAME":case"SECTION":case"MODULE":{let a=await Ai(n,e,t,i);if(a.steps=await Promise.all(i.results.map(s=>Ai(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 CT(n,e,t,r){for(let o of r.runs)await Jk(n,e,{folder:t,suiteName:r.suiteName},o)}import RT from"junit-report-builder";import Uu from"path";function Qk(n,e){let t=e??RT.testCase();if(t.name(n.test.name).className(n.test.name).file(Uu.relative(".",n.filePath)).property("id",n.test.id),n.test.labels&&(t.property("labels",n.test.labels.join(",")),n.test.labels.forEach(r=>{t.property("dd_tags[label]",r)})),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=Ss[n.failureDetails?.classification?.reason||n.failureReason],o=n.failureDetails?.classification?.summary||ko[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 Zk(n,{suiteId:e,suiteName:t,startedAt:r,finishedAt:o,runs:i,skippedTests:a}){let s=n.testSuite().name(t);e&&s.property("id",e),s.timestamp(r).property("startedAt",r.toISOString()).property("finishedAt",o.toISOString()).time((o.getTime()-r.getTime())/1e3);for(let l of i){let c=s.testCase();Qk(l,c)}for(let l of a){let c=s.testCase();c.name(l.name).className(l.name).file(Uu.relative(".",l.relativeFilePath)).property("id",l.id),l.baseUrl&&c.property("baseUrl",l.baseUrl),l.labels&&(c.property("labels",l.labels.join(",")),l.labels.forEach(d=>{c.property("dd_tags[label]",d)})),c.skipped()}return s}function AT(n,e){let t=RT.newBuilder();Zk(t,e),t.writeTo(Uu.join(n,`${e.suiteName}.xml`))}import e_ from"fs";import t_ from"path";function IT(n){return{title:pn(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(IT):[]}}async function n_(n,e,t,r){if(r.results?.length){let o=await hc(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 r_(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||ko[r.failureReason]}:void 0,retry:r.attempts-1,steps:r.results?.map(IT)||[],startTime:r.lastAttemptStartedAt.toISOString(),attachments:await n_(n,e,t,r)}}async function o_(n,e,t,r){return{expectedStatus:"passed",status:r.status==="PASSED"?"expected":"unexpected",results:[await r_(n,e,t,r)]}}async function i_(n,e,t,r){return{tags:[],title:r.test.name,ok:r.status==="PASSED",tests:[await o_(n,e,t,r)],id:r.runId,file:r.filePath}}function Bu(n,e){return n.reduce((t,r)=>e(r)?t+1:t,0)}async function a_(n,e,t,r){return{suites:[{title:r.suiteName,file:r.projectConfigPath,specs:await Promise.all(r.runs.map(o=>i_(n,e,t,o)))}],errors:[],stats:{startTime:r.startedAt.toISOString(),duration:r.finishedAt.getTime()-r.startedAt.getTime(),expected:Bu(r.runs,o=>o.status==="PASSED"),unexpected:Bu(r.runs,o=>o.status!=="PASSED"),flaky:Bu(r.runs,o=>!!o.isFlake),skipped:0}}}async function PT(n,e,t,r){let o=await a_(n,e,t,r);e_.writeFileSync(t_.join(t,`${r.suiteName}.json`),JSON.stringify(o,null,2))}async function LT(n,e,t,r,o){switch(s_(o)?c_(o).isDirectory()||(b.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)):(b.info(`Reporter output directory '${o}' does not exist on disk, creating it now...`),l_(o,{recursive:!0})),t){case"junit":AT(o,r);return;case"allure":case"allure-json":await CT(n,e,o,r);return;case"playwright-json":await PT(n,e,o,r);return;default:throw new Error(`Unknown reporter format requested: '${t}'`)}}import E_ from"wait-on";import zu from"fs";import{compact as d_}from"lodash-es";import Hu from"path";import{cwd as p_}from"process";import u_ from"semver";async function gc({tests:n,momenticFiles:e,project:t,yes:r,include:o,exclude:i,labels:a,logger:s}){let l=new Set;if(n&&n.length>0){let d=n.some(u=>zu.existsSync(u)),p=p_();d?(p!==t.rootDir&&s.warn(`The current working directory ('${p}') 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.`),s.info(`Reading tests from the following local file paths:
3938
+ `)}`)):b.warn("To fix these errors automatically, re-run this check with the --fix flag and then commit the resulting changes"),process.exit(1)):(b.success("No step ID errors found!"),process.exit(0))}async function dE({project:n}){let e=ye(n,b),t=Object.values(e.tests),r=await rl(e,te),o={},i={},a={},s={},l=new Set,c=new Set,d=new Set,p=new Set;for(let m of t)o[m.id]?a[m.id]?a[m.id].push(m.fullFilePath):a[m.id]=[o[m.id],m.fullFilePath]:o[m.id]=m.fullFilePath,i[m.name]?s[m.name]?s[m.name].push(m.fullFilePath):s[m.name]=[i[m.name],m.fullFilePath]:i[m.name]=m.fullFilePath;for(let m of r)p.has(m.moduleId)&&l.add(m.moduleId),d.has(m.name)&&c.add(m.name),p.add(m.moduleId),d.add(m.name);if(Object.entries(a).length>0||Object.entries(s).length>0||l.size>0||c.size>0){for(let[m,h]of Object.entries(a))for(let g of h)b.error(`Test ID ${m} is duplicated in ${g}`);for(let[m,h]of Object.entries(s))for(let g of h)b.error(`Test Name ${m} is duplicated in ${g}`);for(let m of l)b.error(`Module id ${m} is duplicated in your project`);for(let m of c)b.error(`Module name ${m} is duplicated in your project`);process.exit(1)}b.success("No duplicates detected. All test and module names and ids are unique."),process.exit(0)}import{cloneDeep as jk}from"lodash-es";async function pE({client:n,skipPrompts:e,project:t}){let r=await n.getAllEnvironments(),o=jk(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 bt(`Environment ${i.name} already exists in the project configuration file. Would you like to overwrite its variables?`)&&process.exit(1),a.baseUrl=i.variables[We],delete i.variables[We],a.envVariables=i.variables;else{let s=i.variables[We];delete i.variables[We],o.environments.push({name:i.name,baseUrl:s,envVariables:i.variables})}}ri(o,t.configFilePath),b.success(`Pulled ${r.length} environments successfully! Please make sure to commit any changes to your project configuration file.`)}import{createHash as uE}from"crypto";import mE from"fs";async function _u({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=hE(l,ve.TEST);!r&&!await vu(d)||(a+=1,mE.writeFileSync(d,c,"utf-8"),te.info({checksum:uE("md5").update(c).digest("hex")},`Wrote '${d}'`))}let s=0;for(let[l,c]of Object.entries(i)){let d=hE(l,ve.MODULE);!r&&!await vu(d)||(s+=1,mE.writeFileSync(d,c,"utf-8"),te.info({checksum:uE("md5").update(c).digest("hex")},`Wrote '${d}'`))}a===0?b.success("Pulled 0 tests."):b.success(`Pulled ${a} test${a>1?"s":""}${s?` and ${s} module${s>1?"s":""}`:""}!`)}function hE(n,e){switch(e){case ve.TEST:return`${Ie(n)}.${_t.TEST}`;case ve.MODULE:return`${Ie(n)}.${_t.MODULE}`;default:throw new Error(`Unknown entity type ${e}`)}}async function gE(n){let{project:e,client:t,skipPrompts:r}=n;b.info("Welcome to the Momentic Cloud importer wizard! \u{1F636}\u200D\u{1F32B}\uFE0F"),b.info("Importing environments from Momentic Cloud."),b.info(`This command will overwrite all local environment configuration in ${e.configFilePath} with environments from Momentic Cloud.`),await bt("Are you sure you want to proceed?",!0)||(b.info("Aborting..."),process.exit(1)),await pE({client:t,project:e,skipPrompts:r}),b.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.`),b.info("Importing tests and modules from Momentic Cloud."),await _u({testsToFetch:[],client:t,all:!0,yes:r}),b.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 fE(n){let{client:e,skipPrompts:t,paths:r}=n;await _u({testsToFetch:r,client:e,all:void 0,yes:t}),b.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 $k from"fs";import{tmpdir as Gk}from"os";import Wk from"path";import{registry as qa}from"playwright-core/lib/server";import SE from"proper-lockfile";var yE=Wk.join(Gk(),"momenticBrowserInstallation");var Du=["chrome","chromium","chrome-for-testing"],Vk={Chromium:"chromium","Google Chrome":"chrome","Chrome for Testing":"chrome-for-testing"},bE={chrome:"chrome",chromium:"chromium","chrome-for-testing":"chromium-headless-shell"};function wE(n){let e=bE[Vk[n]??""]??"",t=qa.findExecutable(e);return!t||t.installType==="none"?!1:Fu(t)}function Fu(n){let e=n.executablePath();return $k.existsSync(e)}function qk(n,e){let t=bE[n];if(!t)throw new Error(`Requested install of unknown browser type ${n}`);let r=qa.findExecutable(t);if(!r||r.installType==="none")throw new Error(`Requested install of unknown browser type ${n}`);if(!(!e&&Fu(r)))return r}async function Kk({browser:n,force:e}){let t=qk(n,e);if(!t){b.info(`Browser '${n}' is already installed, skipping...`);return}b.info(`Installing browser '${n}'...`);try{await qa.installDeps([t],!1),await qa.install([t],!1)}catch(r){if(r.message.includes("Lock file is already being held")){b.warn("Another process is installing Playwright browsers. Waiting for completion before proceeding..");let o=qa.findExecutable(n),i=5*60*1e3,a=Date.now();for(;Date.now()-a<i&&!Fu(o);)b.info("Waiting for browser to finish installing..."),await new Promise(s=>setTimeout(s,5e3))}else throw r}}async function vE({rawBrowsers:n,force:e=!1,all:t=!1}){let r=t?Du:Array.from(new Set(n));try{await SE.lock(yE,{stale:1e3*60*5,update:1e3*60,realpath:!1,retries:{retries:30,factor:2,maxTimeout:15e3,minTimeout:500}})}catch(i){b.warn(`Failed to acquire lock to install browsers. Please ensure that any other process installing browsers completes within 5 minutes: ${i}. Continuing without installation...`);return}let o;try{for(let i of r)try{await Kk({browser:i,force:e})}catch(a){o=a,b.error(`Failed to install the ${i} browser: ${a}`)}}finally{await SE.unlock(yE,{realpath:!1})}if(o)throw o}async function EE(n){let e=ye(n,b),t=Object.values(e.tests);for(let r of t)try{let o=eo(r.fullFilePath,b,e),i=o.steps;if(!i||i.length===0||!Array.isArray(i)){b.debug(`Test ${r.name} (${r.relativePath}) has no steps, skipping...`);continue}let a=ht.parse(o),s=await Kr(a,i,b);b.dimmed(`Updating ${r.relativePath}`),Wn({relativeTestPath:r.relativePath,steps:{beforeSteps:o.beforeSteps,steps:s.steps,afterSteps:o.afterSteps},schemaVersion:Oe,project:n,forceSaveOnNoDiffs:!0})}catch(o){b.error({err:o},`Failed to read or migrate test ${r.name} (${r.relativePath}), continuing...`)}for(let r of Object.values(e.modules)){b.dimmed(`Updating ${r.relativePath}`);try{let o=Gn(r.fullFilePath,b),i=o.steps;if(!i||i.length===0||!Array.isArray(i)){b.debug(`Module ${r.name} (${r.relativePath}) has no steps, skipping...`);continue}let a=await Kr({id:o.moduleId,schemaVersion:o.schemaVersion},i,b);Zr({content:{...o,steps:a.steps},schemaVersion:Oe,momenticFiles:e,project:n,forceSaveOnNoDiffs:!0})}catch(o){b.error({err:o},`Failed to read or migrate module ${r.name} (${r.relativePath}), continuing...`)}}}import{spawnSync as Jk}from"child_process";import{PostHog as Yk}from"posthog-node";async function TE(n,e){let t,r=0,o=3,i,a;for(;r<o;)try{let s=await B(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 hc=class n extends aa{constructor(t,r,o,i){super(o,i);this.client=t;this.orgId=r}static async init(t){let r=new Yk("phc_WRWd8LYIv6rolgDsyCdrPpxtZhsu6qXAkEwPicl44bI",{host:"https://us.i.posthog.com"}),{flags:o,payloads:i}=await TE(r,t);return new n(r,t,o,i)}async refresh(){let{flags:t,payloads:r}=await TE(this.client,this.orgId);this.flags=t,this.payloads=r}};function Xk(){try{let e=Jk("git remote show origin",{encoding:"utf8",maxBuffer:5242880}).stdout.match(/HEAD branch: (.*)$/m);if(e&&e[1])return e[1].trim();b.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);b.warn(`Could not determine Git main branch. Please set it manually in your project configuration under the 'gitMainBranch' field. Error:
3939
+ ${e}`)}}async function xE({project:n,orgId:e,apiClient:t}){b.info("Pulling browser and AI configuration options from Cloud");let r=await hc.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},b.info(`Updated ${n.configFilePath} to include V2 browser and AI configuration options`),b.info("Determining main Git branch"),n.config.gitMainBranch=Xk(),ri(n.config,n.configFilePath),b.success("Migration complete!")}function CE(n){return n?Ie(n):"Unknown suite"}async function RE({client:n,orgId:e,suitePaths:t,wait:r,waitTimeout:o,...i}){let{suiteRunIds:a,runGroupIds:s}=await n.queueSuiteRuns({paths:t,...i});te.info({orgId:e,suiteRunIds:a,runGroupIds:s,suitePaths:t},"Queued suites remotely"),b.dimmed(`Queued ${t.length} suites.`),r||process.exit(0);let l=Date.now();b.dimmed(`Waiting for ${t.length} suites to finish. You can view results upon completion at:`);for(let f of s)b.dimmed(`${Ut}- ${n.getAppUrl()}/run-groups/${f}`);let c=new Set,d=[],p=f=>(f.status==="FAILED"||f.status==="PASSED"||f.status==="CANCELLED")&&f.runs.every(w=>w.status==="FAILED"&&(w.failureReason||w.finishedAt&&Date.now()-w.finishedAt.getTime()>30*1e3)||w.status==="PASSED"||w.status==="CANCELLED"),u=await uc({name:"suites",getResults:async()=>{let f=s.filter(E=>!d.some(y=>y.id===E)),S=await n.bulkGetRunGroupStatus(f),w=[];for(let E of S)p(E)?d.push(E):w.push(E);return[...d,...w]},timeoutMs:o?o*1e3:void 0,checkDone:f=>(f.forEach(S=>{S.status==="RUNNING"&&(c.has(S.id)||(c.add(S.id),b.log(`${c.size}/${s.length} ${CE(S.suite?.name)}`)))}),f.every(p))}),m=n.getAppUrl(),g=Ri({results:u,startTime:l,onFailed:f=>{let S=CE(f.suite?.name),w=f.runs.filter(y=>y.status==="FAILED").length,E=f.runs.length;b.error(`${S} (${w}/${E} tests failed):`);for(let y of f.runs)if(y.status==="FAILED"){let x=y.testName||y.test?.name;b.error(` ${x?Ie(x):"Unknown test"} (${m}/runs/${y.id})`)}},entity:"suite",getDisplayLine:f=>` ${f.suite?.name?Ie(f.suite.name):"Unknown suite name"} (${m}/run-groups/${f.id})`});process.exit(g.failed>0?1:0)}async function AE({tests:n,client:e,orgId:t,...r}){!r.yes&&!await bt(`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(te.info({queuedTests:o,runIds:i,orgId:t},"Queued tests remotely"),b.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;b.dimmed(`Waiting for ${o.length} tests to complete.`);let a=new Set,s=[],l=m=>m.status==="FAILED"&&m.failureReason||m.status==="PASSED"||m.status==="CANCELLED",c=e.getAppUrl(),d=Date.now(),p=await uc({name:"runs",getResults:async()=>{let m=i.filter(f=>!s.some(S=>S.id===f)),h=await e.bulkGetRunStatus(m),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:m=>(m.forEach(h=>{if(h.status==="RUNNING"&&!a.has(h.id)){a.add(h.id);let g=h.testName||h.test?.name;g&&b.log(`${a.size}/${o.length} ${Ie(g)}`)}}),m.every(l))}),u=Ri({results:p,startTime:d,onFailed:m=>{let h=m.testName||m.test?.name;mc(m,h?Ie(h):"Unknown test")},getDisplayLine:m=>{let h=m.testName||m.test?.name,g=` ${h?Ie(h):"Unknown test"}`;return m.id&&(g+=` (${c}/runs/${m.id})`),g},entity:"test"});process.exit(u.failed>0?1:0)}import Pi,{supportsColor as x_}from"chalk";import C_ from"fs";import{existsSync as d_,mkdirSync as p_,statSync as u_}from"fs";import{randomUUID as Uu}from"crypto";import gc from"fs";import{hostname as Zk}from"os";import Ka from"path";async function fc(n,e,t,r,o){if(r){let i=Ka.extname(r),a=`${Uu()}-screenshot${i}`,s=Ka.join(t,a),c=await(await fetch(r)).arrayBuffer();return gc.writeFileSync(s,Buffer.from(c)),a}if(o){let i=await e.getScreenshot(n,o);if(i){let a=`${o}-screenshot.jpeg`,s=Ka.join(t,a);return gc.writeFileSync(s,i),a}}}async function Qk(n,e,t,r){let o=r.runId??Uu(),i={uuid:o,historyId:o,testCaseId:r.test.id,fullName:r.test.name,name:Ie(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:Zk()},{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 e_(n,e,t.folder,i.steps,r.results);let a=`${o}-result.json`;gc.writeFileSync(Ka.join(t.folder,a),JSON.stringify(i,void 0,2))}async function Ai(n,e,t,r){let o={name:pn(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 fc(n,e,t,r.beforeScreenshot,r.beforeSnapshot);i&&o.attachments.push({name:"Screenshot before step",source:i,type:"image/jpeg"});let a=await fc(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=`${Uu()}-attachment.json`,l=Ka.join(t,s);gc.writeFileSync(l,JSON.stringify(r.data,null,2)),o.attachments.push({name:"Step output data",source:s,type:"text/plain"})}return o}async function e_(n,e,t,r,o){for(let i of o)switch(i.type){case"PRESET_ACTION":{r.push(await Ai(n,e,t,i));break}case"CONDITIONAL":{let a=await Ai(n,e,t,i);a.steps=[],i.assertion&&a.steps.push(await Ai(n,e,t,i.assertion)),a.steps.push(...await Promise.all(i.results.map(s=>Ai(n,e,t,s)))),r.push(a);break}case"AI_ACTION":case"IFRAME":case"SECTION":case"MODULE":{let a=await Ai(n,e,t,i);if(a.steps=await Promise.all(i.results.map(s=>Ai(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 IE(n,e,t,r){for(let o of r.runs)await Qk(n,e,{folder:t,suiteName:r.suiteName},o)}import PE from"junit-report-builder";import Bu from"path";function t_(n,e){let t=e??PE.testCase();if(t.name(n.test.name).className(n.test.name).file(Bu.relative(".",n.filePath)).property("id",n.test.id),n.test.labels&&(t.property("labels",n.test.labels.join(",")),n.test.labels.forEach(r=>{t.property("dd_tags[label]",r)})),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=Ss[n.failureDetails?.classification?.reason||n.failureReason],o=n.failureDetails?.classification?.summary||ko[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 n_(n,{suiteId:e,suiteName:t,startedAt:r,finishedAt:o,runs:i,skippedTests:a}){let s=n.testSuite().name(t);e&&s.property("id",e),s.timestamp(r).property("startedAt",r.toISOString()).property("finishedAt",o.toISOString()).time((o.getTime()-r.getTime())/1e3);for(let l of i){let c=s.testCase();t_(l,c)}for(let l of a){let c=s.testCase();c.name(l.name).className(l.name).file(Bu.relative(".",l.relativeFilePath)).property("id",l.id),l.baseUrl&&c.property("baseUrl",l.baseUrl),l.labels&&(c.property("labels",l.labels.join(",")),l.labels.forEach(d=>{c.property("dd_tags[label]",d)})),c.skipped()}return s}function LE(n,e){let t=PE.newBuilder();n_(t,e),t.writeTo(Bu.join(n,`${e.suiteName}.xml`))}import r_ from"fs";import o_ from"path";function OE(n){return{title:pn(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(OE):[]}}async function i_(n,e,t,r){if(r.results?.length){let o=await fc(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 a_(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||ko[r.failureReason]}:void 0,retry:r.attempts-1,steps:r.results?.map(OE)||[],startTime:r.lastAttemptStartedAt.toISOString(),attachments:await i_(n,e,t,r)}}async function s_(n,e,t,r){return{expectedStatus:"passed",status:r.status==="PASSED"?"expected":"unexpected",results:[await a_(n,e,t,r)]}}async function l_(n,e,t,r){return{tags:[],title:r.test.name,ok:r.status==="PASSED",tests:[await s_(n,e,t,r)],id:r.runId,file:r.filePath}}function zu(n,e){return n.reduce((t,r)=>e(r)?t+1:t,0)}async function c_(n,e,t,r){return{suites:[{title:r.suiteName,file:r.projectConfigPath,specs:await Promise.all(r.runs.map(o=>l_(n,e,t,o)))}],errors:[],stats:{startTime:r.startedAt.toISOString(),duration:r.finishedAt.getTime()-r.startedAt.getTime(),expected:zu(r.runs,o=>o.status==="PASSED"),unexpected:zu(r.runs,o=>o.status!=="PASSED"),flaky:zu(r.runs,o=>!!o.isFlake),skipped:0}}}async function ME(n,e,t,r){let o=await c_(n,e,t,r);r_.writeFileSync(o_.join(t,`${r.suiteName}.json`),JSON.stringify(o,null,2))}async function NE(n,e,t,r,o){switch(d_(o)?u_(o).isDirectory()||(b.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)):(b.info(`Reporter output directory '${o}' does not exist on disk, creating it now...`),p_(o,{recursive:!0})),t){case"junit":LE(o,r);return;case"allure":case"allure-json":await IE(n,e,o,r);return;case"playwright-json":await ME(n,e,o,r);return;default:throw new Error(`Unknown reporter format requested: '${t}'`)}}import R_ from"wait-on";import Hu from"fs";import{compact as m_}from"lodash-es";import ju from"path";import{cwd as h_}from"process";import g_ from"semver";async function Sc({tests:n,momenticFiles:e,project:t,yes:r,include:o,exclude:i,labels:a,logger:s}){let l=new Set;if(n&&n.length>0){let d=n.some(u=>Hu.existsSync(u)),p=h_();d?(p!==t.rootDir&&s.warn(`The current working directory ('${p}') 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.`),s.info(`Reading tests from the following local file paths:
3930
3940
  ${n.map(u=>`${Ut}- ${u}`).join(`
3931
3941
  `)}
3932
- `),n.forEach(u=>{if(!zu.existsSync(u))throw new Error(`Path '${u}' does not exist.`);let m,h;try{m=zu.statSync(u),h=m.isDirectory()}catch(f){s.warn({err:f},`Skipping path ${u} because it cannot be read`);return}let g=Hu.resolve(u);Object.values(e.tests).filter(f=>h?f.fullFilePath.startsWith(g):f.fullFilePath===g).forEach(f=>{l.add(f.fullFilePath)})})):(s.info(`Reading all tests from the project and running those matching the following substring filters:
3942
+ `),n.forEach(u=>{if(!Hu.existsSync(u))throw new Error(`Path '${u}' does not exist.`);let m,h;try{m=Hu.statSync(u),h=m.isDirectory()}catch(f){s.warn({err:f},`Skipping path ${u} because it cannot be read`);return}let g=ju.resolve(u);Object.values(e.tests).filter(f=>h?f.fullFilePath.startsWith(g):f.fullFilePath===g).forEach(f=>{l.add(f.fullFilePath)})})):(s.info(`Reading all tests from the project and running those matching the following substring filters:
3933
3943
  ${n.map(u=>`${Ut}- ${u}`).join(`
3934
- `)}`),Object.values(e.tests).forEach(u=>{n.some(m=>u.relativePath.includes(m))&&l.add(u.fullFilePath)}))}else{!r&&!await bt("No test paths or substrings were provided. Do you want to run all tests?")&&(s.error("Cancelled by user."),process.exit(1));let d=Object.values(e.tests);s.info(`Reading all ${d.length} tests in the project from local disk.`),d.forEach(p=>{l.add(p.fullFilePath)})}for(let d of l){let p=Hu.relative(t.rootDir,d);o&&!o.some(u=>new RegExp(u).test(p))&&l.delete(d),i&&i.some(u=>new RegExp(u).test(p))&&l.delete(d)}let c=Array.from(l).map(async d=>{try{let p=await ha(d,ee,e);if(u_.gt(p.schemaVersion,Oe)&&s.warn(`Test ${d} has schema version ${p.schemaVersion}, which is greater than what is currently supported by this SDK. Please update your momentic package version to avoid unexpected behavior.`),a&&a.length>0){let u=p.labels||[];if(!a.some(h=>u.includes(h)))return null}return{...p,fullFilePath:d,relativeFilePath:Hu.relative(t.rootDir,d)}}catch(p){s.error(`Failed to read and resolve test at '${d}': ${p}`),process.exit(1)}});return Promise.all(c).then(d_)}import{cloneDeep as Ii}from"lodash-es";async function OT({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 $t({orgId:n,s:c,localTools:e,logger:t,context:o,flagStore:i})}return a}async function MT({baseUrl:n,envName:e,testName:t,devicePixelRatio:r,apiClient:o,test:i,storageClient:a,codeEvalTools:s,generator:l,orgId:c,variables:d,logger:p,customHeaders:u,testInputs:m,localBrowserConfig:h,aiSettings:g,visualDiffScreenshotStorage:f,flagStore:S}){let w=await Nl({settings:h,customHeaders:u,envVariables:d,envName:e,testName:t,baseUrl:n,logger:p,localTools:s,orgId:c,flagStore:S}),T={baseUrl:o.baseUrl,apiKey:o.apiKey,logger:ee},y=S.isBooleanFlagEnabled("icon_knowledge_base")?await a.fetchIconKnowledgeBase(p):null,E=w.browserType??"Chromium";if(!ST(E)){let L=`Browser ${E} is required by the test named ${i.name} but does not appear to be installed on this machine. Please install it using 'momentic install-browser' before running tests. Attempting to continue...`;b.warn(L),ee.warn(L)}let x=await Dn.init({baseUrl:n,logger:p,userBrowserSettings:w,storage:a,flagStore:S,enricher:new ui(T,l),contextArgs:{viewport:i.advanced.viewport??qt,locale:i.advanced.locale??_o,geolocation:i.advanced.geolocation??Fo,timezoneId:i.advanced.timezone??Do,colorScheme:i.advanced.colorScheme,deviceScaleFactor:r},iconKnowledgeBase:y}),A=new wi({browser:x,generator:l,logger:p,orgId:c,options:{scratchPadId:void 0,slowMoMs:w.slowMoMs,autoFollowNewTabs:w.autoFollowNewTabs,useMemory:g.useMemory,aiPageFiltering:g.aiPageFiltering??S.isBooleanFlagEnabled("rag_v2")},storage:a,flagStore:S,localCodeEvalTools:s,visualDiffScreenshotStorage:f}),k=new Ot({baseUrl:n,currentUrl:A.browser.url(),variablesFromEnvironment:d,envName:e,testName:t});return i.parameters&&await Promise.all(i.parameters.map(async L=>{let{name:W,defaultValue:q,required:M}=L,D=m?.[W];M&&D===void 0&&(b.error(`Required parameter '${W}' is required by test '${i.name}' but not provided`),process.exit(1));let O=await $t({orgId:c,s:D??q,localTools:s,logger:p,context:Ot.dummyContext(k.getEnvName()),flagStore:S});k.setMomenticSystemVariable(W,O)})),{controller:A,context:k}}import{randomUUID as m_}from"crypto";async function NT({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")?Ga?!0:(o.warn("The CLI is not running in a CI environment and therefore ineligible for failure recovery"),b.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 kT({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:u,debugDataStorage:m,logger:h,apiClient:g,billingReporter:f,tracer:S}=e,{test:w,orgSettings:T}=n;h.info(`Running test '${w.name}' locally (run link: https://app.momentic.ai/runs/${i})`);let y={controller:s,storage:u,debugDataStorage:m,billingReporter:f,analytics:d,context:l,logger:h,codeEvalTools:p},E={orgId:o,runId:i||m_(),runAttemptId:a,testMetadata:w,steps:w.steps,beforeSteps:w.beforeSteps,afterSteps:w.afterSteps},x={collectDebugData:!0,reinitializeBrowser:!0,disableHealing:!await NT({currentAttempt:r,testId:w.id,flagStore:c,apiClient:g,testAdvancedSettings:w.advanced,aiSettingsFromEnv:T.ai,logger:h})};return await Ml({fixtures:y,inputs:E,options:x,callbacks:{step:{},test:{onTestComplete:async()=>{await s.browser.cleanup()},onProposedTestSteps:async L=>g.uploadProposedSteps(L,h)}},testParams:{tracer:S}})}async function _T(n){let{testDefinition:e,logger:t}=n,r=new Date;try{return await h_(n)}catch(o){let i="Fatal error running test";return b.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 h_(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,u=new ci(r,o),m=mi({orgId:o,client:r,gitMetadata:c,alwaysSaveCache:d,noCache:p}),h=Ii(e.steps),g=Ii(e.beforeSteps)??void 0,f=Ii(e.afterSteps)??void 0;try{await m.resolveStepCacheEntries({testId:e.id,stepLists:{steps:h,beforeSteps:g,afterSteps:f},schemaVersion:e.schemaVersion,logger:l})}catch(A){throw l.error({err:A},"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: ${A}`)}let S=n.envName??f_(e),w,T={};if(S){try{w=ga(S,t,l)}catch(A){let k=`Failed to resolve environment ${S} for test ${e.name}: ${A}`;throw new Error(k)}T=w.variables}let y=e.baseUrl;if(i)y=i;else if(!y){let A=T[We];typeof A=="string"&&(y=A)}if(!y){let A=`Cannot run test with no base URL and no ${We} variable defined in its environment`;throw new Error(A)}let E=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:y,environmentName:S,schemaVersion:e.schemaVersion}),x=l.child(E.loggerBindings||{});Object.entries(E.envVarBindings||{}).forEach(([A,k])=>{T[A]=k});try{let A=await g_({...n,variables:T,envName:S,resolvedEnv:w,baseUrl:y,storageClient:u,tracer:E,logger:x,cacheStorage:m,stepsWithCaches:h,beforeStepsWithCaches:g,afterStepsWithCaches:f});return await E.finish({logger:l,status:A.status,finishedAt:A.finishedAt,failureDetails:A.failureDetails,failureReason:A.failureReason,isFlake:A.isFlake}),{runId:E.runId,...A}}finally{a?.pop()}}async function g_(n){let{testDefinition:e,stepsWithCaches:t,beforeStepsWithCaches:r,afterStepsWithCaches:o,project:i,regenerateGoldenFiles:a,apiClient:s,generator:l,baseUrl:c,storageClient:d,orgId:p,envName:u,urlOverride:m,customHeaders:h,testInputs:g,variables:f,resolvedEnv:S,retriesOverride:w,devicePixelRatio:T,logUpdate:y,tracer:E,logger:x,flagStore:A,cacheStorage:k}=n,L=new Date,W=new ii(i,a),q={ai:i.config.ai},M={envName:u,urlOverride:m,customHeaders:h,testInputs:g},D,O=Math.abs(w??i.config.retries??e.retries??0),Y=[];x.info({labels:e.labels,name:e.name,cwd:process.cwd()},"Starting test run using CLI");for(let U=0;U<=O;U++){let re=await E.startAttempt(),oe=x.child(re.loggerBindings||{}),de={...e,steps:Ii(t),beforeSteps:Ii(r),afterSteps:Ii(o)};U!==0&&y("RETRY",`attempt ${U+1}/${O+1}`);let K=new Date,De=new fr({httpClient:new Dt({baseUrl:s.baseUrl,apiKey:s.apiKey,logger:oe}),fakerSeed:A.isBooleanFlagEnabled("faker_constant_seed")?Bh:void 0});try{let{controller:pe,context:At}=await MT({baseUrl:c,envName:u,testName:de.name,apiClient:s,devicePixelRatio:T,logger:oe,storageClient:d,codeEvalTools:De,test:de,generator:l,orgId:p,variables:f,customHeaders:h,testInputs:g,localBrowserConfig:{...i.config.browser||{},...S?.browser||{},...de.advanced},aiSettings:{...i.config.ai||{},...de.advanced||{}},visualDiffScreenshotStorage:W,flagStore:A});D=await kT({attemptMetadata:{attemptNumber:U+1,orgId:p,runId:E.runId,runAttemptId:re.runAttemptId},attemptFixtures:{logger:oe,storageClient:d,billingReporter:new zo,analytics:new ec,debugDataStorage:new Hr,codeEvalTools:De,flagStore:A,apiClient:s,context:At,controller:pe,tracer:re},attemptInputs:{test:de,orgSettings:q}});let wt=new Date;D?.status==="PASSED"&&await Ws({logger:x,cacheStorage:k,orgId:p,testId:e.id,originalSteps:{steps:e.steps,beforeSteps:e.beforeSteps,afterSteps:e.afterSteps},updatedSteps:{steps:de.steps,beforeSteps:de.beforeSteps,afterSteps:de.afterSteps}}),await re.finish({logger:oe,result:D}),Y.unshift(D.status);let Tn=await OT({orgId:p,codeEvalTools:De,logger:oe,outputDefinitions:e.outputs??[],testContext:At,flagStore:A}),go=fh(Y),fo=U+1;if(D.status!=="FAILED")return{...D,parameters:M,test:de,filePath:de.relativeFilePath,startedAt:L,lastAttemptStartedAt:K,finishedAt:wt,attempts:fo,baseUrl:c,outputs:Tn,isFlake:go};let tr=D.failedStepResult,ln=tr?.message||"Unknown failure",H=tr?.failureReason??Yh(ln)??"UnknownError",Li=oe.child({errResult:tr,failureReason:H,errorMessage:ln,numAttempts:O+1,name:de.name});if(U<O){Li.warn(`Retrying failed execution attempt for run: ${ln}`);continue}return Li.error(`Test failed after all exhausting attempts: ${ln}`),{...D,parameters:M,failureDetails:{errorMessage:ln},failureReason:H,test:de,filePath:de.relativeFilePath,startedAt:L,lastAttemptStartedAt:K,finishedAt:wt,attempts:U+1,baseUrl:c,outputs:Tn}}catch(pe){Mi(pe);let At=`Encountered fatal platform error while running test '${de.name}': ${pe}`,wt=new Date,Tn=U+1;oe.error({err:pe},At),b.error(At);let go={errorMessage:pe.message,errStack:pe.stack},fo={status:"FAILED",failureDetails:go,failureReason:"InternalPlatformError",finishedAt:wt};return await re.finish({logger:oe,result:{status:"FAILED",results:[]}}),{...fo,parameters:M,test:de,filePath:de.relativeFilePath,startedAt:L,lastAttemptStartedAt:K,finishedAt:new Date,attempts:Tn,baseUrl:c,outputs:{}}}}throw new Error("This code should not be reachable")}function f_(n){for(let e of n.envs??[])if(e.default)return e.name}import{randomUUID as $u}from"crypto";import S_ from"adm-zip";import Zn from"fs";import mo from"path";var Ya=class n{constructor(e){this.filePath=e;Zn.rmSync(this.filePath,{recursive:!0,force:!0}),Zn.mkdirSync(this.filePath,{recursive:!0})}cd(e){return new n(mo.join(this.filePath,e))}storeFile(e){let{name:t,contents:r}=e,o=mo.join(this.filePath,t);try{Zn.writeFileSync(o,r)}catch{}}createRunArchive(e){return new ju(mo.join(this.filePath,"runs"),e)}},ju=class{constructor(e,t){this.filePath=e;this.tempPath=mo.join(e,`.${t}`),this.finalPath=mo.join(e,`${t}.zip`),Zn.rmSync(this.tempPath,{recursive:!0,force:!0}),Zn.rmSync(this.finalPath,{recursive:!0,force:!0}),Zn.mkdirSync(this.tempPath,{recursive:!0})}tempPath;finalPath;cd(e){return new Ya(mo.join(this.tempPath,e))}storeFile(e){let{name:t,contents:r}=e,o=mo.join(this.tempPath,t);Zn.writeFileSync(o,r)}close(){let e=new S_;e.addLocalFolder(this.tempPath,void 0,r=>r!==".DS_Store");let t=e.toBuffer();Zn.writeFileSync(this.finalPath,t),Zn.rmSync(this.tempPath,{recursive:!0,force:!0})}};async function DT(n,e,t,r,o){let i=na(o.type);if(i&&await e.reportCreditsUsed(n,o.type,i,{testId:t,testName:r}),"command"in o){let a=ra(o.command);a&&await e.reportCreditsUsed(n,o.command.type,a,{testId:t,testName:r})}}function y_(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 b_(n){switch(n){case"SUCCESS":return"PASSED";case"FAILED":return"FAILED";case"CANCELLED":return"CANCELLED";case"RUNNING":return"RUNNING";case"IDLE":return"PENDING"}}var Gu=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:b_(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 fc(this.testId,this.testName,e,this.billingReporter,this.asyncWork);return this.children.push(t),t}},fc=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(DT(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 Gu(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:y_(e.status),finishedAt:e.finishedAt}))))}},Wu=class{constructor(e,t,r,o,i,a,s){this.testId=e;this.testName=t;this.runAttemptId=r;this.metadata=o;this.diskStorage=i;this.billingReporter=a;this.asyncWork=s}finished=!1;children=[];get loggerBindings(){return{runAttemptId:this.runAttemptId}}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:qs(r.results,t),beforeResults:r.beforeResults?qs(r.beforeResults,t):void 0,afterResults:r.afterResults?qs(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 fc(this.testId,this.testName,e,this.billingReporter,this.asyncWork);return this.children.push(t),t}},Vu=class{constructor(e,t,r,o,i,a,s){this.testId=e;this.testName=t;this.runId=r;this.metadata=o;this.diskStorage=i;this.billingReporter=a;this.asyncWork=s}children=[];finished=!1;get loggerBindings(){return{runId:this.runId}}get envVarBindings(){return{[Yy]: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=$u(),r={id:t,schemaVersion:Oe,startedAt:new Date,status:"RUNNING"};e.storeFile({name:"metadata.json",contents:JSON.stringify(r,null,2)});let o=new Wu(this.testId,this.testName,t,r,e,this.billingReporter,this.asyncWork);return this.children.push(o),o}},Sc=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=$u(),l={...a,id:s,trigger:Kt.CLI,startedAt:new Date,status:"RUNNING",cliVersion:wn},c=new Ya(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=$u(),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:wn,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 Vu(e.testId,e.testName,t,o,r,this.billingReporter,this.asyncWork);return this.children.push(i),i}};import FT from"adm-zip";import qu from"fs";import yc from"path";function w_(n){let e=new FT,t=yc.join(n,"metadata.json"),r=ca.parse(JSON.parse(qu.readFileSync(t,"utf-8")));e.addLocalFile(t);for(let o of qu.readdirSync(yc.join(n,"runs"))){if(!o.endsWith(".zip"))continue;let i=o.replace(/\.zip$/,""),a=new FT(yc.join(n,"runs",o));for(let s of a.getEntries())s.isDirectory||e.addFile(yc.join("runs",i,s.entryName),s.getData())}return{runGroupId:r.id,buffer:e.toBuffer()}}async function bc(n){let{client:e,consoleLogger:t,resultsPath:r}=n;if(!qu.existsSync(r)){t.warn("Results path does not exist, skipping upload.");return}let o=new Cl(e);try{let{runGroupId:i,buffer:a}=w_(r),s=await o.uploadResultsArchive(i,a),l=`${e.getAppUrl()}/run-groups/${s}`;t.success(`Successfully uploaded test results. Once processed, your results can be found at ${l}`);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 UT(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:u,envName:m,orgId:h,devicePixelRatio:g,customHeaders:f,testInputMatrix:S,reporter:w,include:T,exclude:y,labels:E,reporterDir:x=hy,outputDir:A=gy,uploadResults:k=!1,waitOnTimeout:L=60,parallel:W,shardIndex:q=1,shardCount:M=1,regenerateGoldenFiles:D,gitMetadata:O,alwaysSaveCache:Y,noCache:U}=n;o&&(e.info({orgId:h},`Executing start command: ${o}`),await kv(o,!1)),i&&(e.info({orgId:h},`Waiting for url: ${i} with timeout: ${L} seconds.`),await E_({resources:[i],interval:2500,timeout:L*1e3,headers:{Accept:"*/*"},followRedirect:!0,verbose:!1,log:!0,strictSSL:!1}));let re=new pi(d.config.ai?.agentConfig,{baseUrl:a.baseUrl,apiKey:a.apiKey,logger:e}),oe=Se(d,b),de=await gc({tests:t,momenticFiles:oe,yes:r,project:d,include:T,exclude:y,labels:E,logger:e}),K=de.filter(Fe=>!Fe.disabled),De=de.filter(Fe=>Fe.disabled),pe=[];K.forEach((Fe,Rr)=>{S?S.forEach((yo,vt)=>{pe.push({testIndex:Rr,inputs:yo,inputIndex:vt})}):pe.push({testIndex:Rr,inputs:void 0,inputIndex:void 0})}),M&&M>1&&(pe=x_(pe,q,M));let At=`Running ${pe.length} tests with ${W} workers:`;e.info({allTestsToRunWithInputs:pe,shardCount:M,shardIndex:q,orgId:h},At),b.info(At),pe.forEach(Fe=>{b.info(`${Ut}- ${[K[Fe.testIndex].relativeFilePath]}${typeof Fe.inputIndex=="number"?` with input set ${Fe.inputIndex}`:""}`)}),b.log("");let wt=[],Tn=new Date,go=new Set,fo=async()=>{let Fe=a.getAppUrl(),Rr=Ri({results:wt,startTime:Tn.getTime(),onFailed:vt=>{pc(vt,vt.filePath)},getDisplayLine:vt=>{let Ar=`${Ut}- ${vt.filePath}${vt.proposedTest?" [AUTO-HEALED] ":""}`;return vt.runId&&(Ar+=` ( link when uploaded: ${Fe}/runs/${vt.runId} )`),Ar},entity:"test"}),yo=wt.filter(vt=>!!vt.proposedTest);return yo.length>0&&b.warn(`${yo.length} tests passed with auto-healing. Please use the run links printed above to review proposed changes and apply them locally.`),b.log(""),k?(b.success(`Test results have been saved to the folder ${A}. Uploading to Momentic cloud.`),await bc({client:a,consoleLogger:b,resultsPath:A})):b.success(`Test results have been saved to the folder ${A}. Upload them to Momentic cloud by running 'npx momentic results upload ${A}'.`),Rr};T_.existsSync(A)&&b.warn(`Output directory ${A} already exists, removing before test execution...`);let tr=await Sc.start(e,h,A,a,l,O),ln=e.child(tr.loggerBindings||{}),H=[],Li=async()=>{b.warn("SIGINT received. Stopping tests and printing latest results..."),await tr.finish({logger:ln,status:"CANCELLED"}),await fo(),await Promise.allSettled(H.map(Fe=>Fe())),process.exit(1)};process.once("SIGINT",Li);let So={};for(let Fe=0;Fe<pe.length;Fe++){let Rr=Object.values(So);Rr.length===W&&await Promise.race(Rr.map(Ar=>Ar.promise));let yo=pe[Fe],vt=`test-${Fe}`;So[vt]={done:!1,promise:(async({testIndex:Ar,inputs:Xu})=>{let bo=K[Ar];go.add({testIndex:Ar,inputs:Xu});let KT=bo.relativeFilePath.includes("..")?bo.fullFilePath:bo.relativeFilePath,Ja=(dt,Oi)=>{dt=dt.toUpperCase();let Fn=dt,nr;dt.includes("FAIL")?(Fn=Pi.bgRed.white("FAIL"),nr=3):dt.includes("PASS")?(Fn=Pi.bgGreen.white("PASS"),nr=3):dt.includes("START")?(Fn=Pi.bgBlue.white("START"),nr=2):dt.includes("CANCEL")?(Fn=Pi.bgRgb(191,68,11).white("CANCEL"),nr=1):dt.includes("RETRY")?(Fn=Pi.bgRgb(191,68,11).white("RETRY"),nr=2):dt.includes("RUN")||dt.includes("PROG")?(Fn=Pi.bgMagenta.white("RUNNING"),nr=0):(ln.warn(`Unknown status tried to be logged in run test locally: ${dt}`),nr=0),v_||(Fn=`${Fn}`),b.log(`${Fn}${" ".repeat(nr)} ${KT} ${Oi?`${Oi} `:""}(${go.size}/${pe.length})`)};Ja("START");let YT=setInterval(()=>Ja("RUN"),5*60*1e3),Qu=ln.child({testId:bo.id});try{let dt=await _T({testDefinition:bo,project:d,testInputs:Xu,orgId:h,devicePixelRatio:g,apiClient:a,runGroupTracer:tr,generator:re,retriesOverride:p,urlOverride:u,envName:m,customHeaders:f,regenerateGoldenFiles:D,logUpdate:Ja,runSigIntHandlers:H,logger:Qu,flagStore:c,gitMetadata:O,alwaysSaveCache:Y,noCache:U});Ja(dt.status),wt.push(dt)}catch(dt){let Oi=`Encountered unexpected fatal error when running test '${bo.name}': ${dt.message}`;b.error(Oi),Qu.error(Oi)}finally{clearInterval(YT),So[vt].done=!0,delete So[vt]}})(yo)}}await Promise.allSettled(Object.values(So).map(Fe=>Fe.promise));let Ju="PASSED";return wt.some(Fe=>Fe.status==="FAILED")&&(Ju="FAILED"),await tr.finish({logger:ln,status:Ju}),process.off("SIGINT",Li),w&&await LT(ln,s,w,{projectConfigPath:d.configFilePath,suiteName:d.config.name,startedAt:Tn,finishedAt:new Date,runs:wt,skippedTests:De},x),fo()}function x_(n,e,t){if(t>n.length&&(b.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{randomUUID as C_}from"crypto";import er from"fs";import ho from"path";var BT={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 zT(n,e){let t=n[e];if(!t)throw new Error(`No metadata value found for key: ${e}`);return t}function R_(n,e,t){if(BT[t]){let i=BT[t];return i(n,e)}let r=zT(n,t),o=zT(e,t);if(r!==o)throw new Error(`Metadata values for key "${t}" do not match: "${r}" vs "${o}"`);return r}var HT=new Set([".DS_Store","__MACOSX"]);function jT(n,e,t){let r=C_(),o=n.child({runGroupId:r});er.rmSync(e,{recursive:!0,force:!0});let i=er.readdirSync(t).filter(c=>!HT.has(c)).map(c=>ho.join(t,c));er.mkdirSync(e,{recursive:!0});let a=ho.join(i[0],"metadata.json"),s={...ca.parse(JSON.parse(er.readFileSync(a,"utf-8"))),id:r};for(let c of i){let d=ho.join(c,"runs");if(!er.existsSync(d))continue;let p=er.readdirSync(d);for(let h of p){if(HT.has(h))continue;let g=ho.join(d,h),f=ho.join(e,"runs",h);er.cpSync(g,f,{recursive:!0})}let u=ho.join(c,"metadata.json"),m=ca.parse(JSON.parse(er.readFileSync(u,"utf-8")));o.info({oldRunGroupId:m.id},"Merging metadata from run groups");for(let h in m){if(h==="id")continue;let g=h;s[g]=R_(s,m,g)}}let l=ho.join(e,"metadata.json");er.writeFileSync(l,JSON.stringify(s,null,2))}var $T=new Ei({platform:"cli"},{flushAt:1,flushInterval:0});Tc||ee.warn("Sentry is not enabled in this environment due to unsupported node version");var M_=process.argv.some(n=>n.includes("--log-level"))&&process.argv.some(n=>n.includes("debug")),Ku=n=>{M_&&b.dimmed(n)},Rt=new A_;Rt.name("momentic").description("CLI").version(wn);Rt.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: ${_u.join(", ")}.`).action(async(n,e)=>{!e.all&&n.length===0&&(b.error("No browsers specified"),process.exit(1)),await yT({rawBrowsers:n,force:e.force,all:e.all})});Rt.addOption(new Bt("--log-level <level>").choices(["debug","info","warn","error"]).default("info")).on("option:log-level",n=>{n==="debug"&&b.info("Enabling debug logging"),b.setMinLevel(n.toLowerCase())});Rt.addOption(new Bt("--verbose","enable verbose logging")).on("option:verbose",()=>{ee.enableConsoleLogs(),b.setMinLevel(0)});var Yu=Rt.command("checks").alias("check").description("Perform various project checks");Yu.command("config").addOption(vn).action(async n=>{jt({configFilePath:n.config})});Yu.command("duplicate-ids").description("Checks if any steps in your entire Momentic test repository share the same ID.").addOption(vn).addOption(Jv).action(async n=>{let e=jt({configFilePath:n.config});await aT({project:e,fix:n.fix})});Yu.command("duplicate-names").description("Checks if tests or modules with duplicate names or ids exist").addOption(vn).action(async n=>{let e=jt({configFilePath:n.config});await sT({project:e})});var WT=Rt.command("migrate").description("Migrate and upgrade tooling");WT.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(vn).action(async n=>{let e=jt({configFilePath:n.config});await bT(e)});WT.command("v1-v2").description("Migrate from v1 of the Momentic CLI to v2").addOption(Qn).addOption(vn).addOption(Xn).addOption(Cr).action(async n=>{!n.yes&&!await bt("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 e=jt({configFilePath:n.config}),t=new ct({baseUrl:n.server,apiKey:n.apiKey,logger:ee}),{orgId:r}=await t.getAuthInfo();await vT({project:e,orgId:r,apiClient:t}),process.exit(0)});Rt.command("import").addOption(Xn).addOption(Qn).addOption(vn).addOption(Cr).addArgument(Qv).action(async(n,e)=>{let{apiKey:t,server:r,config:o,yes:i}=e,a=jt({configFilePath:o}),s=new ct({baseUrl:r,apiKey:t,logger:ee});!n||n.length===0?await uT({client:s,project:a,skipPrompts:i}):await mT({client:s,project:a,paths:n,skipPrompts:i}),process.exit(0)});Rt.command("init").description("Initialize an empty Momentic project in the current working directory").addOption(new Bt("--name <name>","Name of the project")).action(async n=>{b.info(`Welcome to the Momentic project setup wizard! \u{1F680}
3935
- `),b.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."),vc.existsSync(ni)&&(b.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 zv("Choose an identifier for your project, such as a service, product, or team name (default: 'app'):","app"),include:sp};ri(t,ni),b.success(`Initialized Momentic project file at ${wc.resolve(ni)}`)});Rt.command("app").addOption(Xn).addOption(Qn).addOption(Cr).addOption(Ru).addOption(qv).addOption(vn).addOption(Iu).addOption(Pu).action(async n=>{let{apiKey:e,port:t,yes:r,server:o,pixelRatio:i,disableCache:a,saveCache:s}=n,l=new ct({baseUrl:o,apiKey:e,logger:ee});await Ou({client:l,skipPrompts:r});let c=O_(import.meta.url),d=wc.dirname(c),p=wc.resolve(d,"..","static"),u=wc.resolve(d,"..","assets"),m=i??fu();Su(m),await Ov({momenticServerUrl:o,apiKey:e,serverPort:t,appPort:t,staticDir:p,assetsDir:u,devicePixelRatio:m,version:wn,noCache:a,alwaysSaveCache:s});let h=`http://localhost:${t}`;await L_(h)});var VT=Rt.command("queue").description("Queue tests or suites to run on Momentic Cloud");VT.command("suites").description("Run one or more suites on Momentic Cloud").addOption(Xn).addOption(Qn).addOption(vu).addOption(Tu).addOption(Cr).addArgument(Zv).addOption(sc).addOption(ac).addOption(ic).action(async(n,e)=>{let{apiKey:t,server:r,wait:o,waitTimeout:i,env:a,urlOverride:s}=e,l=oc(e.customHeaders),c=new ct({baseUrl:r,apiKey:t,logger:ee});(!n||!Array.isArray(n)||!n.length)&&(b.error("Must pass at least one suite to run."),process.exit(1));let{orgId:d}=await c.getAuthInfo();await ET({client:c,orgId:d,wait:o,suitePaths:n,waitTimeout:i,env:a,urlOverride:s,customHeaders:l})});VT.command("tests").description("Run one or more tests on Momentic Cloud").addOption(Xn).addOption(Qn).addOption(Cr).addOption(ic).addOption(Au).addOption(sc).addOption(ac).addOption(new Bt("--all","Run all tests.").default(!1)).addOption(vu).addOption(Tu).addArgument(Xv).action(async(n,e)=>{let{all:t,apiKey:r,env:o,server:i,inputCsv:a,urlOverride:s,wait:l,waitTimeout:c,yes:d}=e,p=oc(e.customHeaders);for(let g of n)(g.endsWith(".yaml")||vc.existsSync(g))&&b.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 u=new ct({baseUrl:i,apiKey:r,logger:ee}),{orgId:m}=await u.getAuthInfo(),h;a&&(h=await yu(a)),await xT({client:u,orgId:m,tests:n,all:t,customHeaders:p,env:o,urlOverride:s,wait:l,waitTimeout:c,testInputMatrix:h,yes:d}),process.exit(0)});var N_=Rt.command("list").description("List test paths");N_.addOption(vn).addOption(lc).addOption(xu).addOption(Cu).addOption(new Bt("--labels <labels...>","Only run tests with the specified label(s).")).addArgument(Lu).action(async(n,e)=>{let t=jt({configFilePath:e.config,nameFilter:e.filter}),r=Se(t,b),o=await gc({tests:n,momenticFiles:r,yes:!0,project:t,include:e.include,exclude:e.exclude,labels:e.labels,logger:gg});b.info(o.map(i=>i.relativeFilePath).join(`
3936
- `)),process.exit(0)});var k_=Rt.command("run").alias("test").description("Run tests on the local machine");k_.addOption(Xn).addOption(Qn).addOption(vn).addOption(lc).addOption(Cr).addOption(ic).addOption(Au).addOption(Iu).addOption(Pu).addOption(ac).addOption(sc).addOption(Ru).addOption(new Bt("--start <start>","Arbitrary setup command that will run before Momentic steps begin.")).addOption(new Bt("--wait-on <waitOn>","URL to wait to become accessible before Momentic tests begin.")).addOption(new Bt("--wait-on-timeout <waitOnTimeout>","Max time in seconds to wait for the --wait-on URL to become accessible.").default(60).argParser(Jn)).addOption(new Bt("--retries <retries>","Number of retries to attempt when running tests locally. Defaults to each test's own retry configuration.").argParser(Jn)).addOption(new Bt("-p, --parallel <parallel>","When running with the --local flag, the number of tests to run in parallel. Defaults to 1.").argParser(Jn)).addOption(new Bt("--labels <labels...>","Only run tests with the specified label(s).")).addOption(new Bt("--update-golden-files","Update locally stored golden files for steps that this is enabled for.").default(!1)).addOption(Gv).addOption(Wv).addOption(Eu).addOption(Vv).addOption(Yv).addOption(Kv).addOption(xu).addOption(Cu).addArgument(Lu).action(async(n,e)=>{if(e.shardIndex>e.shardCount)throw new Error("Shard index cannot be greater than shard count");let t=oc(e.customHeaders),r=jt({configFilePath:e.config,nameFilter:e.filter}),o=r.config.parallel??e.parallel??1;GT().length<o*2&&b.warn(`You requested to run tests in parallel ${o} at a time on a machine with ${GT().length} cores. This may cause performance issues and test failures as Chrome requires at least 2 cores per browser instance.`),b.debug({projectName:r.config.name},"Identified project config");let{errors:i}=await Nu({project:r,fix:!1});i>0&&(b.error(`Found errors in ${i} steps`),b.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 ct({baseUrl:e.server,apiKey:e.apiKey,logger:ee});b.debug("Checking API key and dependencies");let{orgId:s,userId:l}=await Ou({client:a,skipPrompts:e.yes});b.debug("API key check and browser installation complete");let c=new El(a),d=new xl(a),p=e.outputDir??r.config.outputDir,u=e.reporterDir??r.config.reporterDir,m=ee.child({orgId:s,userId:l,cliVersion:wn,trigger:"CLI"}),h=await si(ee,a,r);m.debug(h,"Got local git metadata");let g=new ai(r.config),f=$T.child({org_id:s,user_id:l,cli_version:wn,trigger:"CLI"}),S;e.inputCsv&&(S=await yu(e.inputCsv));let w=e.pixelRatio??fu();Su(w);try{(await UT({...e,parallel:o,retriesOverride:e.retries,devicePixelRatio:w,tests:n,project:r,client:a,debugDataStorage:d,billingReporter:c,analytics:f,flagStore:g,outputDir:p,uploadResults:e.uploadResults,reporterDir:u,customHeaders:t,envName:e.env,orgId:s,testInputMatrix:S,logger:m,regenerateGoldenFiles:e.updateGoldenFiles,gitMetadata:h,alwaysSaveCache:e.saveCache,noCache:e.disableCache})).failed>0?process.exit(1):process.exit(0)}catch(T){b.error("Failed to run tests locally. Please check the error message below or run with the --verbose flag."),b.error(T),process.exit(1)}});var __=Rt.command("apply").description("Apply an operation to local resources");__.command("patch").addOption(Xn).addOption(Qn).addOption(vn).addOption(lc).addOption(Cr).addOption(new Bt("--from <from>","Name or ID of the patch to apply").makeOptionMandatory()).addOption(new Bt("--to <to>","Name or ID of the test to apply the patch to").makeOptionMandatory()).action(async n=>{let{apiKey:e,server:t,config:r,yes:o}=n,i=jt({configFilePath:r}),a=ee,s=new ct({baseUrl:t,apiKey:e,logger:a}),l=Se(i,b),c=l.tests[n.to]??Object.values(l.tests).find(p=>Ie(p.name)===n.to.trim());c||(b.error(`No test matching '${n.to}' could be found in the current project.`),process.exit(1));let d=await s.fetchTestFragment(n.from);await Hv({client:s,test:c,fragment:d,yes:o,entities:l,logger:ee}),process.exit(0)});var qT=Rt.command("results").description("Merge and upload test results.");qT.command("merge").description("Merge test results files.").addOption(Eu).addArgument(eT).action(async(n,e)=>{let{outputDir:t}=e;t||(b.error("Output directory is required."),process.exit(1)),vc.existsSync(n)||(b.warn("Results path does not exist, skipping merge."),process.exit(0)),vc.existsSync(t)&&b.warn(`Output directory ${t} already exists, removing before merging...`),jT(ee,t,n)});qT.command("upload").description("Upload test results to Momentic cloud.").addOption(Xn).addOption(Qn).addArgument(tT).action(async(n,e)=>{let{apiKey:t,server:r}=e,o=ee,i=new ct({baseUrl:r,apiKey:t,logger:o});await bc({consoleLogger:b,resultsPath:n,client:i}),process.exit(0)});async function D_(){Ku("Main program started"),await Dv(ee),Ku("CLI version check complete");try{await Rt.parseAsync(process.argv)}catch(n){let e={};try{e.playwrightVersion=I_("npx playwright --version").toString()}catch(t){ee.error({err:t},"Error fetching debug information")}ee.error({err:n,debugInfo:e},"Uncaught error in CLI"),ee.flush(),Mi(n,e),b.error(n),process.exit(1)}}P_.setMaxListeners(50);process.on("warning",n=>{ee.warn({err:n},`Node warning received on CLI: ${n.message}`)});Ku("CLI parsing setup complete");D_();
3944
+ `)}`),Object.values(e.tests).forEach(u=>{n.some(m=>u.relativePath.includes(m))&&l.add(u.fullFilePath)}))}else{!r&&!await bt("No test paths or substrings were provided. Do you want to run all tests?")&&(s.error("Cancelled by user."),process.exit(1));let d=Object.values(e.tests);s.info(`Reading all ${d.length} tests in the project from local disk.`),d.forEach(p=>{l.add(p.fullFilePath)})}for(let d of l){let p=ju.relative(t.rootDir,d);o&&!o.some(u=>new RegExp(u).test(p))&&l.delete(d),i&&i.some(u=>new RegExp(u).test(p))&&l.delete(d)}let c=Array.from(l).map(async d=>{try{let p=await ha(d,te,e);if(g_.gt(p.schemaVersion,Oe)&&s.warn(`Test ${d} has schema version ${p.schemaVersion}, which is greater than what is currently supported by this SDK. Please update your momentic package version to avoid unexpected behavior.`),a&&a.length>0){let u=p.labels||[];if(!a.some(h=>u.includes(h)))return null}return{...p,fullFilePath:d,relativeFilePath:ju.relative(t.rootDir,d)}}catch(p){s.error(`Failed to read and resolve test at '${d}': ${p}`),process.exit(1)}});return Promise.all(c).then(m_)}import{cloneDeep as Ii}from"lodash-es";async function kE({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 $t({orgId:n,s:c,localTools:e,logger:t,context:o,flagStore:i})}return a}async function _E({baseUrl:n,envName:e,testName:t,devicePixelRatio:r,apiClient:o,test:i,storageClient:a,codeEvalTools:s,generator:l,orgId:c,variables:d,logger:p,customHeaders:u,testInputs:m,localBrowserConfig:h,aiSettings:g,visualDiffScreenshotStorage:f,flagStore:S}){let w=await _l({settings:h,customHeaders:u,envVariables:d,envName:e,testName:t,baseUrl:n,logger:p,localTools:s,orgId:c,flagStore:S}),E={baseUrl:o.baseUrl,apiKey:o.apiKey,logger:te},y=S.isBooleanFlagEnabled("icon_knowledge_base")?await a.fetchIconKnowledgeBase(p):null,x=w.browserType??"Chromium";if(!wE(x)){let L=`Browser ${x} is required by the test named ${i.name} but does not appear to be installed on this machine. Please install it using 'momentic install-browser' before running tests. Attempting to continue...`;b.warn(L),te.warn(L)}let T=await Fn.init({baseUrl:n,logger:p,userBrowserSettings:w,storage:a,flagStore:S,enricher:new ui(E,l),contextArgs:{viewport:i.advanced.viewport??qt,locale:i.advanced.locale??_o,geolocation:i.advanced.geolocation??Fo,timezoneId:i.advanced.timezone??Do,colorScheme:i.advanced.colorScheme,deviceScaleFactor:r},iconKnowledgeBase:y}),A=new wi({browser:T,generator:l,logger:p,orgId:c,options:{scratchPadId:void 0,slowMoMs:w.slowMoMs,autoFollowNewTabs:w.autoFollowNewTabs,useMemory:g.useMemory,aiPageFiltering:g.aiPageFiltering??S.isBooleanFlagEnabled("rag_v2")},storage:a,flagStore:S,localCodeEvalTools:s,visualDiffScreenshotStorage:f}),D=new Ot({baseUrl:n,currentUrl:A.browser.url(),variablesFromEnvironment:d,envName:e,testName:t});return i.parameters&&await Promise.all(i.parameters.map(async L=>{let{name:j,defaultValue:V,required:k}=L,N=m?.[j];k&&N===void 0&&(b.error(`Required parameter '${j}' is required by test '${i.name}' but not provided`),process.exit(1));let O=await $t({orgId:c,s:N??V,localTools:s,logger:p,context:Ot.dummyContext(D.getEnvName()),flagStore:S});D.setMomenticSystemVariable(j,O)})),{controller:A,context:D}}import{randomUUID as f_}from"crypto";async function DE({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")?Ga?!0:(o.warn("The CLI is not running in a CI environment and therefore ineligible for failure recovery"),b.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 FE({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:u,debugDataStorage:m,logger:h,apiClient:g,billingReporter:f,tracer:S}=e,{test:w,orgSettings:E}=n;h.info(`Running test '${w.name}' locally (run link: https://app.momentic.ai/runs/${i})`);let y={controller:s,storage:u,debugDataStorage:m,billingReporter:f,analytics:d,context:l,logger:h,codeEvalTools:p},x={orgId:o,runId:i||f_(),runAttemptId:a,testMetadata:w,steps:w.steps,beforeSteps:w.beforeSteps,afterSteps:w.afterSteps},T={collectDebugData:!0,reinitializeBrowser:!0,disableHealing:!await DE({currentAttempt:r,testId:w.id,flagStore:c,apiClient:g,testAdvancedSettings:w.advanced,aiSettingsFromEnv:E.ai,logger:h})};return await kl({fixtures:y,inputs:x,options:T,callbacks:{step:{},test:{onTestComplete:async()=>{await s.browser.cleanup()},onProposedTestSteps:async L=>g.uploadProposedSteps(L,h)}},testParams:{tracer:S}})}async function UE(n){let{testDefinition:e,logger:t}=n,r=new Date;try{return await S_(n)}catch(o){let i="Fatal error running test";return b.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 S_(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,u=new ci(r,o),m=mi({orgId:o,client:r,gitMetadata:c,alwaysSaveCache:d,noCache:p}),h=Ii(e.steps),g=Ii(e.beforeSteps)??void 0,f=Ii(e.afterSteps)??void 0;try{await m.resolveStepCacheEntries({testId:e.id,stepLists:{steps:h,beforeSteps:g,afterSteps:f},schemaVersion:e.schemaVersion,logger:l})}catch(A){throw l.error({err:A},"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: ${A}`)}let S=n.envName??b_(e),w,E={};if(S){try{w=ga(S,t,l)}catch(A){let D=`Failed to resolve environment ${S} for test ${e.name}: ${A}`;throw new Error(D)}E=w.variables}let y=e.baseUrl;if(i)y=i;else if(!y){let A=E[We];typeof A=="string"&&(y=A)}if(!y){let A=`Cannot run test with no base URL and no ${We} variable defined in its environment`;throw new Error(A)}let x=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:y,environmentName:S,schemaVersion:e.schemaVersion}),T=l.child(x.loggerBindings||{});Object.entries(x.envVarBindings||{}).forEach(([A,D])=>{E[A]=D});try{let A=await y_({...n,variables:E,envName:S,resolvedEnv:w,baseUrl:y,storageClient:u,tracer:x,logger:T,cacheStorage:m,stepsWithCaches:h,beforeStepsWithCaches:g,afterStepsWithCaches:f});return await x.finish({logger:l,status:A.status,finishedAt:A.finishedAt,failureDetails:A.failureDetails,failureReason:A.failureReason,isFlake:A.isFlake}),{runId:x.runId,...A}}finally{a?.pop()}}async function y_(n){let{testDefinition:e,stepsWithCaches:t,beforeStepsWithCaches:r,afterStepsWithCaches:o,project:i,regenerateGoldenFiles:a,apiClient:s,generator:l,baseUrl:c,storageClient:d,orgId:p,envName:u,urlOverride:m,customHeaders:h,testInputs:g,variables:f,resolvedEnv:S,retriesOverride:w,devicePixelRatio:E,logUpdate:y,tracer:x,logger:T,flagStore:A,cacheStorage:D}=n,L=new Date,j=new ii(i,a),V={ai:i.config.ai},k={envName:u,urlOverride:m,customHeaders:h,testInputs:g},N,O=Math.abs(w??i.config.retries??e.retries??0),q=[];T.info({labels:e.labels,name:e.name,cwd:process.cwd()},"Starting test run using CLI");for(let F=0;F<=O;F++){let ie=await x.startAttempt(),oe=T.child(ie.loggerBindings||{}),pe={...e,steps:Ii(t),beforeSteps:Ii(r),afterSteps:Ii(o)};F!==0&&y("RETRY",`attempt ${F+1}/${O+1}`);let K=new Date,De=new Sr({httpClient:new Dt({baseUrl:s.baseUrl,apiKey:s.apiKey,logger:oe}),fakerSeed:A.isBooleanFlagEnabled("faker_constant_seed")?zh:void 0});try{let{controller:ue,context:At}=await _E({baseUrl:c,envName:u,testName:pe.name,apiClient:s,devicePixelRatio:E,logger:oe,storageClient:d,codeEvalTools:De,test:pe,generator:l,orgId:p,variables:f,customHeaders:h,testInputs:g,localBrowserConfig:{...i.config.browser||{},...S?.browser||{},...pe.advanced},aiSettings:{...i.config.ai||{},...pe.advanced||{}},visualDiffScreenshotStorage:j,flagStore:A});N=await FE({attemptMetadata:{attemptNumber:F+1,orgId:p,runId:x.runId,runAttemptId:ie.runAttemptId},attemptFixtures:{logger:oe,storageClient:d,billingReporter:new zo,analytics:new nc,debugDataStorage:new Hr,codeEvalTools:De,flagStore:A,apiClient:s,context:At,controller:ue,tracer:ie},attemptInputs:{test:pe,orgSettings:V}});let wt=new Date;N?.status==="PASSED"&&await qs({logger:T,cacheStorage:D,orgId:p,testId:e.id,originalSteps:{steps:e.steps,beforeSteps:e.beforeSteps,afterSteps:e.afterSteps},updatedSteps:{steps:pe.steps,beforeSteps:pe.beforeSteps,afterSteps:pe.afterSteps}}),await ie.finish({logger:oe,result:N}),q.unshift(N.status);let En=await kE({orgId:p,codeEvalTools:De,logger:oe,outputDefinitions:e.outputs??[],testContext:At,flagStore:A}),go=Sh(q),fo=F+1;if(N.status!=="FAILED")return{...N,parameters:k,test:pe,filePath:pe.relativeFilePath,startedAt:L,lastAttemptStartedAt:K,finishedAt:wt,attempts:fo,baseUrl:c,outputs:En,isFlake:go};let nr=N.failedStepResult,ln=nr?.message||"Unknown failure",H=nr?.failureReason??Jh(ln)??"UnknownError",Li=oe.child({errResult:nr,failureReason:H,errorMessage:ln,numAttempts:O+1,name:pe.name});if(F<O){Li.warn(`Retrying failed execution attempt for run: ${ln}`);continue}return Li.error(`Test failed after all exhausting attempts: ${ln}`),{...N,parameters:k,failureDetails:{errorMessage:ln},failureReason:H,test:pe,filePath:pe.relativeFilePath,startedAt:L,lastAttemptStartedAt:K,finishedAt:wt,attempts:F+1,baseUrl:c,outputs:En}}catch(ue){Mi(ue);let At=`Encountered fatal platform error while running test '${pe.name}': ${ue}`,wt=new Date,En=F+1;oe.error({err:ue},At),b.error(At);let go={errorMessage:ue.message,errStack:ue.stack},fo={status:"FAILED",failureDetails:go,failureReason:"InternalPlatformError",finishedAt:wt};return await ie.finish({logger:oe,result:{status:"FAILED",results:[]}}),{...fo,parameters:k,test:pe,filePath:pe.relativeFilePath,startedAt:L,lastAttemptStartedAt:K,finishedAt:new Date,attempts:En,baseUrl:c,outputs:{}}}}throw new Error("This code should not be reachable")}function b_(n){for(let e of n.envs??[])if(e.default)return e.name}import{randomUUID as Gu}from"crypto";import w_ from"adm-zip";import er from"fs";import mo from"path";var Ya=class n{constructor(e){this.filePath=e;er.rmSync(this.filePath,{recursive:!0,force:!0}),er.mkdirSync(this.filePath,{recursive:!0})}cd(e){return new n(mo.join(this.filePath,e))}storeFile(e){let{name:t,contents:r}=e,o=mo.join(this.filePath,t);try{er.writeFileSync(o,r)}catch{}}createRunArchive(e){return new $u(mo.join(this.filePath,"runs"),e)}},$u=class{constructor(e,t){this.filePath=e;this.tempPath=mo.join(e,`.${t}`),this.finalPath=mo.join(e,`${t}.zip`),er.rmSync(this.tempPath,{recursive:!0,force:!0}),er.rmSync(this.finalPath,{recursive:!0,force:!0}),er.mkdirSync(this.tempPath,{recursive:!0})}tempPath;finalPath;cd(e){return new Ya(mo.join(this.tempPath,e))}storeFile(e){let{name:t,contents:r}=e,o=mo.join(this.tempPath,t);er.writeFileSync(o,r)}close(){let e=new w_;e.addLocalFolder(this.tempPath,void 0,r=>r!==".DS_Store");let t=e.toBuffer();er.writeFileSync(this.finalPath,t),er.rmSync(this.tempPath,{recursive:!0,force:!0})}};async function BE(n,e,t,r,o){let i=na(o.type);if(i&&await e.reportCreditsUsed(n,o.type,i,{testId:t,testName:r}),"command"in o){let a=ra(o.command);a&&await e.reportCreditsUsed(n,o.command.type,a,{testId:t,testName:r})}}function v_(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 E_(n){switch(n){case"SUCCESS":return"PASSED";case"FAILED":return"FAILED";case"CANCELLED":return"CANCELLED";case"RUNNING":return"RUNNING";case"IDLE":return"PENDING"}}var Wu=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:E_(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 yc(this.testId,this.testName,e,this.billingReporter,this.asyncWork);return this.children.push(t),t}},yc=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(BE(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 Wu(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:v_(e.status),finishedAt:e.finishedAt}))))}},Vu=class{constructor(e,t,r,o,i,a,s){this.testId=e;this.testName=t;this.runAttemptId=r;this.metadata=o;this.diskStorage=i;this.billingReporter=a;this.asyncWork=s}finished=!1;children=[];get loggerBindings(){return{runAttemptId:this.runAttemptId}}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:Ys(r.results,t),beforeResults:r.beforeResults?Ys(r.beforeResults,t):void 0,afterResults:r.afterResults?Ys(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 yc(this.testId,this.testName,e,this.billingReporter,this.asyncWork);return this.children.push(t),t}},qu=class{constructor(e,t,r,o,i,a,s){this.testId=e;this.testName=t;this.runId=r;this.metadata=o;this.diskStorage=i;this.billingReporter=a;this.asyncWork=s}children=[];finished=!1;get loggerBindings(){return{runId:this.runId}}get envVarBindings(){return{[Jy]: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=Gu(),r={id:t,schemaVersion:Oe,startedAt:new Date,status:"RUNNING"};e.storeFile({name:"metadata.json",contents:JSON.stringify(r,null,2)});let o=new Vu(this.testId,this.testName,t,r,e,this.billingReporter,this.asyncWork);return this.children.push(o),o}},bc=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=Gu(),l={...a,id:s,trigger:Kt.CLI,startedAt:new Date,status:"RUNNING",cliVersion:wn},c=new Ya(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=Gu(),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:wn,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 qu(e.testId,e.testName,t,o,r,this.billingReporter,this.asyncWork);return this.children.push(i),i}};import zE from"adm-zip";import Ku from"fs";import wc from"path";function T_(n){let e=new zE,t=wc.join(n,"metadata.json"),r=ca.parse(JSON.parse(Ku.readFileSync(t,"utf-8")));e.addLocalFile(t);for(let o of Ku.readdirSync(wc.join(n,"runs"))){if(!o.endsWith(".zip"))continue;let i=o.replace(/\.zip$/,""),a=new zE(wc.join(n,"runs",o));for(let s of a.getEntries())s.isDirectory||e.addFile(wc.join("runs",i,s.entryName),s.getData())}return{runGroupId:r.id,buffer:e.toBuffer()}}async function vc(n){let{client:e,consoleLogger:t,resultsPath:r}=n;if(!Ku.existsSync(r)){t.warn("Results path does not exist, skipping upload.");return}let o=new Al(e);try{let{runGroupId:i,buffer:a}=T_(r),s=await o.uploadResultsArchive(i,a),l=`${e.getAppUrl()}/run-groups/${s}`;t.success(`Successfully uploaded test results. Once processed, your results can be found at ${l}`);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 HE(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:u,envName:m,orgId:h,devicePixelRatio:g,customHeaders:f,testInputMatrix:S,reporter:w,include:E,exclude:y,labels:x,reporterDir:T=gy,outputDir:A=fy,uploadResults:D=!1,waitOnTimeout:L=60,parallel:j,shardIndex:V=1,shardCount:k=1,regenerateGoldenFiles:N,gitMetadata:O,alwaysSaveCache:q,noCache:F}=n;o&&(e.info({orgId:h},`Executing start command: ${o}`),await Fv(o,!1)),i&&(e.info({orgId:h},`Waiting for url: ${i} with timeout: ${L} seconds.`),await R_({resources:[i],interval:2500,timeout:L*1e3,headers:{Accept:"*/*"},followRedirect:!0,verbose:!1,log:!0,strictSSL:!1}));let ie=new pi(d.config.ai?.agentConfig,{baseUrl:a.baseUrl,apiKey:a.apiKey,logger:e}),oe=ye(d,b),pe=await Sc({tests:t,momenticFiles:oe,yes:r,project:d,include:E,exclude:y,labels:x,logger:e}),K=pe.filter(Fe=>!Fe.disabled),De=pe.filter(Fe=>Fe.disabled),ue=[];K.forEach((Fe,Rr)=>{S?S.forEach((yo,vt)=>{ue.push({testIndex:Rr,inputs:yo,inputIndex:vt})}):ue.push({testIndex:Rr,inputs:void 0,inputIndex:void 0})}),k&&k>1&&(ue=A_(ue,V,k));let At=`Running ${ue.length} tests with ${j} workers:`;e.info({allTestsToRunWithInputs:ue,shardCount:k,shardIndex:V,orgId:h},At),b.info(At),ue.forEach(Fe=>{b.info(`${Ut}- ${[K[Fe.testIndex].relativeFilePath]}${typeof Fe.inputIndex=="number"?` with input set ${Fe.inputIndex}`:""}`)}),b.log("");let wt=[],En=new Date,go=new Set,fo=async()=>{let Fe=a.getAppUrl(),Rr=Ri({results:wt,startTime:En.getTime(),onFailed:vt=>{mc(vt,vt.filePath)},getDisplayLine:vt=>{let Ar=`${Ut}- ${vt.filePath}${vt.proposedTest?" [AUTO-HEALED] ":""}`;return vt.runId&&(Ar+=` ( link when uploaded: ${Fe}/runs/${vt.runId} )`),Ar},entity:"test"}),yo=wt.filter(vt=>!!vt.proposedTest);return yo.length>0&&b.warn(`${yo.length} tests passed with auto-healing. Please use the run links printed above to review proposed changes and apply them locally.`),b.log(""),D?(b.success(`Test results have been saved to the folder ${A}. Uploading to Momentic cloud.`),await vc({client:a,consoleLogger:b,resultsPath:A})):b.success(`Test results have been saved to the folder ${A}. Upload them to Momentic cloud by running 'npx momentic results upload ${A}'.`),Rr};C_.existsSync(A)&&b.warn(`Output directory ${A} already exists, removing before test execution...`);let nr=await bc.start(e,h,A,a,l,O),ln=e.child(nr.loggerBindings||{}),H=[],Li=async()=>{b.warn("SIGINT received. Stopping tests and printing latest results..."),await nr.finish({logger:ln,status:"CANCELLED"}),await fo(),await Promise.allSettled(H.map(Fe=>Fe())),process.exit(1)};process.once("SIGINT",Li);let So={};for(let Fe=0;Fe<ue.length;Fe++){let Rr=Object.values(So);Rr.length===j&&await Promise.race(Rr.map(Ar=>Ar.promise));let yo=ue[Fe],vt=`test-${Fe}`;So[vt]={done:!1,promise:(async({testIndex:Ar,inputs:Zu})=>{let bo=K[Ar];go.add({testIndex:Ar,inputs:Zu});let XE=bo.relativeFilePath.includes("..")?bo.fullFilePath:bo.relativeFilePath,Ja=(dt,Oi)=>{dt=dt.toUpperCase();let Un=dt,rr;dt.includes("FAIL")?(Un=Pi.bgRed.white("FAIL"),rr=3):dt.includes("PASS")?(Un=Pi.bgGreen.white("PASS"),rr=3):dt.includes("START")?(Un=Pi.bgBlue.white("START"),rr=2):dt.includes("CANCEL")?(Un=Pi.bgRgb(191,68,11).white("CANCEL"),rr=1):dt.includes("RETRY")?(Un=Pi.bgRgb(191,68,11).white("RETRY"),rr=2):dt.includes("RUN")||dt.includes("PROG")?(Un=Pi.bgMagenta.white("RUNNING"),rr=0):(ln.warn(`Unknown status tried to be logged in run test locally: ${dt}`),rr=0),x_||(Un=`${Un}`),b.log(`${Un}${" ".repeat(rr)} ${XE} ${Oi?`${Oi} `:""}(${go.size}/${ue.length})`)};Ja("START");let ZE=setInterval(()=>Ja("RUN"),5*60*1e3),Qu=ln.child({testId:bo.id});try{let dt=await UE({testDefinition:bo,project:d,testInputs:Zu,orgId:h,devicePixelRatio:g,apiClient:a,runGroupTracer:nr,generator:ie,retriesOverride:p,urlOverride:u,envName:m,customHeaders:f,regenerateGoldenFiles:N,logUpdate:Ja,runSigIntHandlers:H,logger:Qu,flagStore:c,gitMetadata:O,alwaysSaveCache:q,noCache:F});Ja(dt.status),wt.push(dt)}catch(dt){let Oi=`Encountered unexpected fatal error when running test '${bo.name}': ${dt.message}`;b.error(Oi),Qu.error(Oi)}finally{clearInterval(ZE),So[vt].done=!0,delete So[vt]}})(yo)}}await Promise.allSettled(Object.values(So).map(Fe=>Fe.promise));let Xu="PASSED";return wt.some(Fe=>Fe.status==="FAILED")&&(Xu="FAILED"),await nr.finish({logger:ln,status:Xu}),process.off("SIGINT",Li),w&&await NE(ln,s,w,{projectConfigPath:d.configFilePath,suiteName:d.config.name,startedAt:En,finishedAt:new Date,runs:wt,skippedTests:De},T),fo()}function A_(n,e,t){if(t>n.length&&(b.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{randomUUID as I_}from"crypto";import tr from"fs";import ho from"path";var jE={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 $E(n,e){let t=n[e];if(!t)throw new Error(`No metadata value found for key: ${e}`);return t}function P_(n,e,t){if(jE[t]){let i=jE[t];return i(n,e)}let r=$E(n,t),o=$E(e,t);if(r!==o)throw new Error(`Metadata values for key "${t}" do not match: "${r}" vs "${o}"`);return r}var GE=new Set([".DS_Store","__MACOSX"]);function WE(n,e,t){let r=I_(),o=n.child({runGroupId:r});tr.rmSync(e,{recursive:!0,force:!0});let i=tr.readdirSync(t).filter(c=>!GE.has(c)).map(c=>ho.join(t,c));tr.mkdirSync(e,{recursive:!0});let a=ho.join(i[0],"metadata.json"),s={...ca.parse(JSON.parse(tr.readFileSync(a,"utf-8"))),id:r};for(let c of i){let d=ho.join(c,"runs");if(!tr.existsSync(d))continue;let p=tr.readdirSync(d);for(let h of p){if(GE.has(h))continue;let g=ho.join(d,h),f=ho.join(e,"runs",h);tr.cpSync(g,f,{recursive:!0})}let u=ho.join(c,"metadata.json"),m=ca.parse(JSON.parse(tr.readFileSync(u,"utf-8")));o.info({oldRunGroupId:m.id},"Merging metadata from run groups");for(let h in m){if(h==="id")continue;let g=h;s[g]=P_(s,m,g)}}let l=ho.join(e,"metadata.json");tr.writeFileSync(l,JSON.stringify(s,null,2))}var VE=new Ti({platform:"cli"},{flushAt:1,flushInterval:0});xc||te.warn("Sentry is not enabled in this environment due to unsupported node version");var __=process.argv.some(n=>n.includes("--log-level"))&&process.argv.some(n=>n.includes("debug")),Yu=n=>{__&&b.dimmed(n)},Rt=new L_;Rt.name("momentic").description("CLI").version(wn);Rt.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: ${Du.join(", ")}.`).action(async(n,e)=>{!e.all&&n.length===0&&(b.error("No browsers specified"),process.exit(1)),await vE({rawBrowsers:n,force:e.force,all:e.all})});Rt.addOption(new Bt("--log-level <level>").choices(["debug","info","warn","error"]).default("info")).on("option:log-level",n=>{n==="debug"&&b.info("Enabling debug logging"),b.setMinLevel(n.toLowerCase())});Rt.addOption(new Bt("--verbose","enable verbose logging")).on("option:verbose",()=>{te.enableConsoleLogs(),b.setMinLevel(0)});var Ju=Rt.command("checks").alias("check").description("Perform various project checks");Ju.command("config").addOption(vn).action(async n=>{jt({configFilePath:n.config})});Ju.command("duplicate-ids").description("Checks if any steps in your entire Momentic test repository share the same ID.").addOption(vn).addOption(Qv).action(async n=>{let e=jt({configFilePath:n.config});await cE({project:e,fix:n.fix})});Ju.command("duplicate-names").description("Checks if tests or modules with duplicate names or ids exist").addOption(vn).action(async n=>{let e=jt({configFilePath:n.config});await dE({project:e})});var KE=Rt.command("migrate").description("Migrate and upgrade tooling");KE.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(vn).action(async n=>{let e=jt({configFilePath:n.config});await EE(e)});KE.command("v1-v2").description("Migrate from v1 of the Momentic CLI to v2").addOption(Qn).addOption(vn).addOption(Zn).addOption(Cr).action(async n=>{!n.yes&&!await bt("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 e=jt({configFilePath:n.config}),t=new ct({baseUrl:n.server,apiKey:n.apiKey,logger:te}),{orgId:r}=await t.getAuthInfo();await xE({project:e,orgId:r,apiClient:t}),process.exit(0)});Rt.command("import").addOption(Zn).addOption(Qn).addOption(vn).addOption(Cr).addArgument(tE).action(async(n,e)=>{let{apiKey:t,server:r,config:o,yes:i}=e,a=jt({configFilePath:o}),s=new ct({baseUrl:r,apiKey:t,logger:te});!n||n.length===0?await gE({client:s,project:a,skipPrompts:i}):await fE({client:s,project:a,paths:n,skipPrompts:i}),process.exit(0)});Rt.command("init").description("Initialize an empty Momentic project in the current working directory").addOption(new Bt("--name <name>","Name of the project")).action(async n=>{b.info(`Welcome to the Momentic project setup wizard! \u{1F680}
3945
+ `),b.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."),Tc.existsSync(ni)&&(b.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 $v("Choose an identifier for your project, such as a service, product, or team name (default: 'app'):","app"),include:cp};ri(t,ni),b.success(`Initialized Momentic project file at ${Ec.resolve(ni)}`)});Rt.command("app").addOption(Zn).addOption(Qn).addOption(Cr).addOption(Au).addOption(Jv).addOption(vn).addOption(Pu).addOption(Lu).action(async n=>{let{apiKey:e,port:t,yes:r,server:o,pixelRatio:i,disableCache:a,saveCache:s}=n,l=new ct({baseUrl:o,apiKey:e,logger:te});await Mu({client:l,skipPrompts:r});let c=k_(import.meta.url),d=Ec.dirname(c),p=Ec.resolve(d,"..","static"),u=Ec.resolve(d,"..","assets"),m=i??Su();yu(m),await kv({momenticServerUrl:o,apiKey:e,serverPort:t,appPort:t,staticDir:p,assetsDir:u,devicePixelRatio:m,version:wn,noCache:a,alwaysSaveCache:s});let h=`http://localhost:${t}`;await N_(h)});var YE=Rt.command("queue").description("Queue tests or suites to run on Momentic Cloud");YE.command("suites").description("Run one or more suites on Momentic Cloud").addOption(Zn).addOption(Qn).addOption(Eu).addOption(Tu).addOption(Cr).addArgument(nE).addOption(cc).addOption(lc).addOption(sc).action(async(n,e)=>{let{apiKey:t,server:r,wait:o,waitTimeout:i,env:a,urlOverride:s}=e,l=ac(e.customHeaders),c=new ct({baseUrl:r,apiKey:t,logger:te});(!n||!Array.isArray(n)||!n.length)&&(b.error("Must pass at least one suite to run."),process.exit(1));let{orgId:d}=await c.getAuthInfo();await RE({client:c,orgId:d,wait:o,suitePaths:n,waitTimeout:i,env:a,urlOverride:s,customHeaders:l})});YE.command("tests").description("Run one or more tests on Momentic Cloud").addOption(Zn).addOption(Qn).addOption(Cr).addOption(sc).addOption(Iu).addOption(cc).addOption(lc).addOption(new Bt("--all","Run all tests.").default(!1)).addOption(Eu).addOption(Tu).addArgument(eE).action(async(n,e)=>{let{all:t,apiKey:r,env:o,server:i,inputCsv:a,urlOverride:s,wait:l,waitTimeout:c,yes:d}=e,p=ac(e.customHeaders);for(let g of n)(g.endsWith(".yaml")||Tc.existsSync(g))&&b.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 u=new ct({baseUrl:i,apiKey:r,logger:te}),{orgId:m}=await u.getAuthInfo(),h;a&&(h=await bu(a)),await AE({client:u,orgId:m,tests:n,all:t,customHeaders:p,env:o,urlOverride:s,wait:l,waitTimeout:c,testInputMatrix:h,yes:d}),process.exit(0)});var D_=Rt.command("list").description("List test paths");D_.addOption(vn).addOption(dc).addOption(Cu).addOption(Ru).addOption(new Bt("--labels <labels...>","Only run tests with the specified label(s).")).addArgument(Ou).action(async(n,e)=>{let t=jt({configFilePath:e.config,nameFilter:e.filter}),r=ye(t,b),o=await Sc({tests:n,momenticFiles:r,yes:!0,project:t,include:e.include,exclude:e.exclude,labels:e.labels,logger:fg});b.info(o.map(i=>i.relativeFilePath).join(`
3946
+ `)),process.exit(0)});var F_=Rt.command("run").alias("test").description("Run tests on the local machine");F_.addOption(Zn).addOption(Qn).addOption(vn).addOption(dc).addOption(Cr).addOption(sc).addOption(Iu).addOption(Pu).addOption(Lu).addOption(lc).addOption(cc).addOption(Au).addOption(new Bt("--start <start>","Arbitrary setup command that will run before Momentic steps begin.")).addOption(new Bt("--wait-on <waitOn>","URL to wait to become accessible before Momentic tests begin.")).addOption(new Bt("--wait-on-timeout <waitOnTimeout>","Max time in seconds to wait for the --wait-on URL to become accessible.").default(60).argParser(Xn)).addOption(new Bt("--retries <retries>","Number of retries to attempt when running tests locally. Defaults to each test's own retry configuration.").argParser(Xn)).addOption(new Bt("-p, --parallel <parallel>","When running with the --local flag, the number of tests to run in parallel. Defaults to 1.").argParser(Xn)).addOption(new Bt("--labels <labels...>","Only run tests with the specified label(s).")).addOption(new Bt("--update-golden-files","Update locally stored golden files for steps that this is enabled for.").default(!1)).addOption(qv).addOption(Kv).addOption(xu).addOption(Yv).addOption(Zv).addOption(Xv).addOption(Cu).addOption(Ru).addArgument(Ou).action(async(n,e)=>{if(e.shardIndex>e.shardCount)throw new Error("Shard index cannot be greater than shard count");let t=ac(e.customHeaders),r=jt({configFilePath:e.config,nameFilter:e.filter}),o=r.config.parallel??e.parallel??1;qE().length<o*2&&b.warn(`You requested to run tests in parallel ${o} at a time on a machine with ${qE().length} cores. This may cause performance issues and test failures as Chrome requires at least 2 cores per browser instance.`),b.debug({projectName:r.config.name},"Identified project config");let{errors:i}=await ku({project:r,fix:!1});i>0&&(b.error(`Found errors in ${i} steps`),b.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 ct({baseUrl:e.server,apiKey:e.apiKey,logger:te});b.debug("Checking API key and dependencies");let{orgId:s,userId:l}=await Mu({client:a,skipPrompts:e.yes});b.debug("API key check and browser installation complete");let c=new Cl(a),d=new Rl(a),p=e.outputDir??r.config.outputDir,u=e.reporterDir??r.config.reporterDir,m=te.child({orgId:s,userId:l,cliVersion:wn,trigger:"CLI"}),h=await si(te,a,r);m.info(h,"Got local git metadata");let g=new ai(r.config),f=VE.child({org_id:s,user_id:l,cli_version:wn,trigger:"CLI"}),S;e.inputCsv&&(S=await bu(e.inputCsv));let w=e.pixelRatio??Su();yu(w);try{(await HE({...e,parallel:o,retriesOverride:e.retries,devicePixelRatio:w,tests:n,project:r,client:a,debugDataStorage:d,billingReporter:c,analytics:f,flagStore:g,outputDir:p,uploadResults:e.uploadResults,reporterDir:u,customHeaders:t,envName:e.env,orgId:s,testInputMatrix:S,logger:m,regenerateGoldenFiles:e.updateGoldenFiles,gitMetadata:h,alwaysSaveCache:e.saveCache,noCache:e.disableCache})).failed>0?process.exit(1):process.exit(0)}catch(E){b.error("Failed to run tests locally. Please check the error message below or run with the --verbose flag."),b.error(E),process.exit(1)}});var U_=Rt.command("apply").description("Apply an operation to local resources");U_.command("patch").addOption(Zn).addOption(Qn).addOption(vn).addOption(dc).addOption(Cr).addOption(new Bt("--from <from>","Name or ID of the patch to apply").makeOptionMandatory()).addOption(new Bt("--to <to>","Name or ID of the test to apply the patch to").makeOptionMandatory()).action(async n=>{let{apiKey:e,server:t,config:r,yes:o}=n,i=jt({configFilePath:r}),a=te,s=new ct({baseUrl:t,apiKey:e,logger:a}),l=ye(i,b),c=l.tests[n.to]??Object.values(l.tests).find(p=>Ie(p.name)===n.to.trim());c||(b.error(`No test matching '${n.to}' could be found in the current project.`),process.exit(1));let d=await s.fetchTestFragment(n.from);await Gv({client:s,test:c,fragment:d,yes:o,entities:l,logger:te}),process.exit(0)});var JE=Rt.command("results").description("Merge and upload test results.");JE.command("merge").description("Merge test results files.").addOption(xu).addArgument(rE).action(async(n,e)=>{let{outputDir:t}=e;t||(b.error("Output directory is required."),process.exit(1)),Tc.existsSync(n)||(b.warn("Results path does not exist, skipping merge."),process.exit(0)),Tc.existsSync(t)&&b.warn(`Output directory ${t} already exists, removing before merging...`),WE(te,t,n)});JE.command("upload").description("Upload test results to Momentic cloud.").addOption(Zn).addOption(Qn).addArgument(oE).action(async(n,e)=>{let{apiKey:t,server:r}=e,o=te,i=new ct({baseUrl:r,apiKey:t,logger:o});await vc({consoleLogger:b,resultsPath:n,client:i}),process.exit(0)});async function B_(){Yu("Main program started"),await Bv(te),Yu("CLI version check complete");try{await Rt.parseAsync(process.argv)}catch(n){let e={};try{e.playwrightVersion=O_("npx playwright --version").toString()}catch(t){te.error({err:t},"Error fetching debug information")}te.error({err:n,debugInfo:e},"Uncaught error in CLI"),te.flush(),Mi(n,e),b.error(n),process.exit(1)}}M_.setMaxListeners(50);process.on("warning",n=>{te.warn({err:n},`Node warning received on CLI: ${n.message}`)});Yu("CLI parsing setup complete");B_();
3937
3947
  //# sourceMappingURL=cli.js.map
3938
- //# debugId=0ba158ab-7de7-5b11-865d-75f20a411592
3948
+ //# debugId=79926f15-e6af-58e9-89ff-23dbe00e65ff