momentic 2.6.3 → 2.6.5
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 +221 -169
- package/npm-shrinkwrap.json +2 -2
- package/package.json +1 -1
- package/static/assets/{index-SDfEQJhR.js → index-NnzsaO4F.js} +243 -243
- package/static/index.html +1 -1
package/bin/cli.js
CHANGED
|
@@ -1,60 +1,211 @@
|
|
|
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]="
|
|
4
|
-
var Vx=Object.create;var Zu=Object.defineProperty;var qx=Object.getOwnPropertyDescriptor;var Kx=Object.getOwnPropertyNames;var Yx=Object.getPrototypeOf,Jx=Object.prototype.hasOwnProperty;var Qu=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports);var Xx=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Kx(e))!Jx.call(n,o)&&o!==t&&Zu(n,o,{get:()=>e[o],enumerable:!(r=qx(e,o))||r.enumerable});return n};var Zx=(n,e,t)=>(t=n!=null?Vx(Yx(n)):{},Xx(e||!n||!n.__esModule?Zu(t,"default",{value:n,enumerable:!0}):t,n));var mS=Qu((x3,uS)=>{"use strict";uS.exports=dS;function dS(n,e,t){n instanceof RegExp&&(n=cS(n,t)),e instanceof RegExp&&(e=cS(e,t));var r=pS(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 cS(n,e){var t=e.match(n);return t?t[0]:null}dS.range=pS;function pS(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 vS=Qu((E3,wS)=>{"use strict";var hS=mS();wS.exports=KA;var gS="\0SLASH"+Math.random()+"\0",fS="\0OPEN"+Math.random()+"\0",Ud="\0CLOSE"+Math.random()+"\0",SS="\0COMMA"+Math.random()+"\0",yS="\0PERIOD"+Math.random()+"\0";function Fd(n){return parseInt(n,10)==n?parseInt(n,10):n.charCodeAt(0)}function VA(n){return n.split("\\\\").join(gS).split("\\{").join(fS).split("\\}").join(Ud).split("\\,").join(SS).split("\\.").join(yS)}function qA(n){return n.split(gS).join("\\").split(fS).join("{").split(Ud).join("}").split(SS).join(",").split(yS).join(".")}function bS(n){if(!n)return[""];var e=[],t=hS("{","}",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=bS(i);return i.length&&(a[a.length-1]+=s.shift(),a.push.apply(a,s)),e.push.apply(e,a),e}function KA(n){return n?(n.substr(0,2)==="{}"&&(n="\\{\\}"+n.substr(2)),ya(VA(n),!0).map(qA)):[]}function YA(n){return"{"+n+"}"}function JA(n){return/^-?0\d/.test(n)}function XA(n,e){return n<=e}function ZA(n,e){return n>=e}function ya(n,e){var t=[],r=hS("{","}",n);if(!r)return[n];var o=r.pre,i=r.post.length?ya(r.post,!1):[""];if(/\$$/.test(r.pre))for(var a=0;a<i.length;a++){var s=o+"{"+r.body+"}"+i[a];t.push(s)}else{var l=/^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(r.body),c=/^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(r.body),d=l||c,p=r.body.indexOf(",")>=0;if(!d&&!p)return r.post.match(/,.*\}/)?(n=r.pre+"{"+r.body+Ud+r.post,ya(n)):[n];var u;if(d)u=r.body.split(/\.\./);else if(u=bS(r.body),u.length===1&&(u=ya(u[0],!1).map(YA),u.length===1))return i.map(function(H){return r.pre+u[0]+H});var m;if(d){var h=Fd(u[0]),g=Fd(u[1]),f=Math.max(u[0].length,u[1].length),S=u.length==3?Math.abs(Fd(u[2])):1,w=XA,x=g<h;x&&(S*=-1,w=ZA);var y=u.some(JA);m=[];for(var T=h;w(T,g);T+=S){var C;if(c)C=String.fromCharCode(T),C==="\\"&&(C="");else if(C=String(T),y){var R=f-C.length;if(R>0){var L=new Array(R+1).join("0");T<0?C="-"+L+C.slice(1):C=L+C}}m.push(C)}}else{m=[];for(var N=0;N<u.length;N++)m.push.apply(m,ya(u[N],!1))}for(var N=0;N<m.length;N++)for(var a=0;a<i.length;a++){var s=o+m[N]+i[a];(!e||d||s)&&t.push(s)}}return t}});var _i=(n,e)=>{},bc=!1;try{let n=await import("@sentry/node");_i=n.captureException,n.init({dsn:"https://89e980855f7b9c6e56fc6c7e7143888b@o4506426201800704.ingest.us.sentry.io/4508343221354497",environment:"production",release:process.env.SENTRY_RELEASE_NAME,tracesSampleRate:0}),bc=!0}catch{}import{Command as S_,Option as Vt}from"@commander-js/extra-typings";import{execSync as y_}from"child_process";import Tv from"body-parser";import ZN from"cors";import QN from"dedent";import ek from"events";import Cv,{Router as tk}from"express";import{diff as $A}from"deep-object-diff";import hn from"fs";import Zr from"path";import{diff as gA}from"deep-object-diff";import{z as em}from"zod";var L_=em.object({input:em.string()});import{z as Ke}from"zod";var N_=Ke.object({srcs:Ke.array(Ke.string()),urls:Ke.array(Ke.string()),desiredSrc:Ke.string().optional(),desiredUrl:Ke.string().optional()}),tm=Ke.object({srcRegex:Ke.string().optional(),urlRegex:Ke.string().optional()}),nm=Ke.object({x:Ke.number(),y:Ke.number(),correlation:Ke.number()}),k_=Ke.object({searchImageBase64String:Ke.string(),pageImageBase64String:Ke.string(),id:Ke.string().uuid(),timeoutMs:Ke.number().max(1e4).min(0).optional()});import{z as D}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 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||{}),Qx=F.object({mPathSelectorTokens:F.string().array(),frameSrcRegex:F.string().optional(),frameUrlRegex:F.string().optional(),indices:F.number().array()}),wc=F.object({result:F.number(),traceId:F.string()}).array(),Di=F.object({type:F.literal("GCS_TRACES"),traces:wc}),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:Qx.optional(),inputDescription:F.string().optional().describe("the description that generated this cache"),targetSource:F.nativeEnum(or).optional(),targetUpdateTime:F.string().optional(),targetUpdateLoggerTags:F.record(F.string(),F.string()).optional(),memory:Di.optional()}).openapi({ref:"ElementTargetCache"});function rm(n){return!!(n.name||n.role||n.content||n.serializedForm||n.serializedHtml||n.screenshotUrl)}var eE=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"}),tE=F.object({x:F.number(),y:F.number()}),nE=F.object({type:F.literal("coordinates"),pixels:tE}).openapi({ref:"CoordinatesTarget"});function ir(n){return n.type==="description"}function Tn(n){return n.type==="coordinates"}var pt=F.discriminatedUnion("type",[eE,nE]).openapi({ref:"ElementTarget"});function vc(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 ye}from"zod";import{z as vo}from"zod";var xc=vo.object({result:vo.boolean(),traceId:vo.string()}).array(),Ec=vo.object({type:vo.literal("GCS_TRACES"),traces:xc}),om=vo.object({memory:Ec.optional()});var Ja=class{async resolveStepCacheEntries(){}async saveStepCacheEntries(){}};Ce(ye);var im=ye.object({plan:ye.string().optional(),evidence:ye.string().optional(),thoughts:ye.string(),result:ye.boolean(),relevantElements:ye.array(ye.number()).optional(),updatedMemory:xc.optional()}),xo=(o=>(o.CONTAINS="CONTAINS",o.STARTS_WITH="STARTS_WITH",o.EQUALS="EQUALS",o.EXISTS="EXISTS",o))(xo||{});var rE=ye.object({type:ye.literal("ELEMENT_CONTENT"),negated:ye.boolean().optional(),operation:ye.nativeEnum(xo),value:ye.string()}).openapi({ref:"ElementContentAssertion"}),oE=ye.object({type:ye.literal("ELEMENT_ATTRIBUTE"),negated:ye.boolean().optional(),operation:ye.nativeEnum(xo),attr:ye.string(),value:ye.string()}).openapi({ref:"ElementAttributeValueAssertion"}),Eo=(o=>(o.EXISTS="EXISTS",o.VISIBLE="VISIBLE",o.ENABLED="ENABLED",o.EDITABLE="EDITABLE",o))(Eo||{}),iE=ye.object({type:ye.literal("ELEMENT_EXISTENCE"),negated:ye.boolean().optional(),condition:ye.nativeEnum(Eo).describe("Treated as the element exists AND is also ...")}).openapi({ref:"ElementExistenceAssertion"}),am=ye.discriminatedUnion("type",[rE,oE,iE]).openapi({ref:"ManualElementAssertion"});var aE=ye.object({type:ye.literal("CONTENT"),negated:ye.boolean().optional(),value:ye.string()}).openapi({ref:"PageContentAssertion"}),sm=ye.discriminatedUnion("type",[aE]).openapi({ref:"ManualPageAssertion"});import{z as ie}from"zod";var Xa=ie.object({url:ie.string(),method:ie.union([ie.literal("GET"),ie.literal("POST"),ie.literal("PUT"),ie.literal("DELETE"),ie.literal("PATCH")]),headers:ie.record(ie.string(),ie.string()).optional(),params:ie.record(ie.string(),ie.string()).optional(),body:ie.string().optional(),timeout:ie.number().int().optional().describe("Max seconds to wait for the request to complete")}),lm=ie.object({url:ie.string(),headers:ie.record(ie.string(),ie.string()).optional(),query:ie.string(),variables:ie.record(ie.string(),ie.string()).optional(),timeout:ie.number().int().optional().describe("Max seconds to wait for the request to complete")}),Za=ie.object({code:ie.string(),fragment:ie.boolean().optional(),environment:ie.union([ie.literal("NODE"),ie.literal("BROWSER")]).optional().describe("default NODE"),timeout:ie.number().int().max(60).optional().describe("Max seconds for the code to complete")});var Ue=(j=>(j.AI_EXTRACT="AI_EXTRACT",j.AI_ASSERTION="AI_ASSERTION",j.AUTH_LOAD="AUTH_LOAD",j.AUTH_SAVE="AUTH_SAVE",j.BLUR="BLUR",j.CAPTCHA="CAPTCHA",j.CLICK="CLICK",j.COOKIE="COOKIE",j.COPY="COPY",j.DIALOG="DIALOG",j.DRAG="DRAG",j.ELEMENT_CHECK="ELEMENT_CHECK",j.FILE_UPLOAD="FILE_UPLOAD",j.FOCUS="FOCUS",j.GO_BACK="GO_BACK",j.GO_FORWARD="GO_FORWARD",j.HOVER="HOVER",j.JAVASCRIPT="JAVASCRIPT",j.LOCAL_STORAGE="LOCAL_STORAGE",j.MOUSE_DRAG="MOUSE_DRAG",j.NAVIGATE="NAVIGATE",j.NEW_TAB="NEW_TAB",j.PAGE_CHECK="PAGE_CHECK",j.PASTE="PASTE",j.PRESS="PRESS",j.KEY_DOWN="KEY_DOWN",j.KEY_UP="KEY_UP",j.REFRESH="REFRESH",j.REQUEST="REQUEST",j.GRAPHQL_REQUEST="GRAPHQL_REQUEST",j.SCROLL_DOWN="SCROLL_DOWN",j.SCROLL_UP="SCROLL_UP",j.SCROLL_LEFT="SCROLL_LEFT",j.SCROLL_RIGHT="SCROLL_RIGHT",j.SELECT_OPTION="SELECT_OPTION",j.SWITCH_TAB="TAB",j.TYPE="TYPE",j.VISUAL_DIFF="VISUAL_DIFF",j.WAIT="WAIT",j.WAIT_FOR_URL="WAIT_FOR_URL",j.REGISTER_REQUEST_LISTENER="REGISTER_REQUEST_LISTENER",j.AWAIT_LISTENER="AWAIT_LISTENER",j.RECORD_REQUESTS="RECORD_REQUESTS",j.GET_RECORDED_REQUESTS="GET_RECORDED_REQUESTS",j.SET_HEADER="SET_HEADER",j.SUCCESS="SUCCESS",j))(Ue||{});Ce(v);var Y=v.object({thoughts:v.string().optional(),id:v.string().uuid().describe("unique identifier to this step, used for step cache")}),qt=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"}),Cn=v.object({target:Ir}).optional().openapi({ref:"SingleTargetCache"}),Qa=v.object({loadTimeout:v.number().int().max(60).optional().describe("Max seconds for the page to load")}),sE=Y.merge(Qa).merge(v.object({type:v.literal("NAVIGATE"),url:v.string()})).openapi({ref:"NavigateCommand"}),es=qt.merge(v.object({cache:Cn})),To=Y.merge(es.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_UP"),deltaY:v.number().optional()}))).openapi({ref:"ScrollUpCommand"}),Co=Y.merge(es.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_DOWN"),deltaY:v.number().optional()}))).openapi({ref:"ScrollDownCommand"}),Ro=Y.merge(es.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_LEFT"),deltaX:v.number().optional()}))).openapi({ref:"ScrollLeftCommand"}),Ao=Y.merge(es.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_RIGHT"),deltaX:v.number().optional()}))).openapi({ref:"ScrollRightCommand"}),iD=v.discriminatedUnion("type",[To,Co,Ro,Ao]).openapi({ref:"AllScrollCommands"}),lE=Y.merge(v.object({type:v.literal("DIALOG"),action:v.union([v.literal("ACCEPT"),v.literal("DISMISS")])})).openapi({ref:"DialogCommand"}),cE=Y.merge(v.object({type:v.literal("WAIT"),delay:v.number()})).openapi({ref:"WaitCommand"}),dE=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()})]),pE=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")}),uE=Y.extend({type:v.literal("WAIT_FOR_URL"),matcher:dE}).merge(pE).openapi({ref:"WaitUrlCommand"}),mE=Y.merge(Qa).merge(v.object({type:v.literal("REFRESH")})).openapi({ref:"RefreshCommand"}),hE=Y.merge(v.object({type:v.literal("GO_BACK")})).openapi({ref:"GoBackCommand"}),gE=Y.merge(v.object({type:v.literal("GO_FORWARD")})).openapi({ref:"GoForwardCommand"}),fE=Y.extend({type:v.literal("AUTH_SAVE")}).openapi({ref:"AuthSaveCommand"}),SE=Y.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"}),Cc=Y.merge(qt).extend({type:v.literal("CAPTCHA")}).openapi({ref:"CaptchaCommand"}),yE=Y.extend({type:v.literal("COPY"),value:v.string()}).openapi({ref:"CopyCommand"}),bE=Y.extend({type:v.literal("PASTE")}).openapi({ref:"PasteCommand"}),wE=Y.merge(Za).extend({type:v.literal("JAVASCRIPT")}).openapi({ref:"JavaScriptCommand"}),Ui=Y.merge(qt).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:Cn,relativePosition:v.object({x:v.number(),y:v.number()}).optional()}).openapi({ref:"ClickCommand"}),Bi=Y.merge(qt).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"}),zi=Y.merge(qt).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:Cn})).openapi({ref:"MouseDragCommand"}),Hi=Y.merge(qt).merge(v.object({type:v.literal("HOVER"),target:pt,cache:Cn})).openapi({ref:"HoverCommand"}),ji=Y.merge(qt).merge(v.object({type:v.literal("FOCUS"),target:pt,cache:Cn})).openapi({ref:"FocusCommand"}),$i=Y.merge(qt).extend({type:v.literal("BLUR"),target:pt.optional(),cache:Cn}).openapi({ref:"BlurCommand"}),vE=v.object({type:v.literal("URL"),url:v.string()}).describe("Accessible link to the file, either public http or local file://").openapi({ref:"UrlSource"}),xE=v.object({type:v.literal("USER_FILE"),name:v.string()}).describe("Accessible link to the file, references the google cloud file").openapi({ref:"UploadedFileSource"}),EE=Y.extend({type:v.literal("FILE_UPLOAD"),fileSource:v.discriminatedUnion("type",[vE,xE]),filename:v.string().optional()}).openapi({ref:"FileUploadCommand"}),TE=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()})]),Gi=Y.merge(qt).extend({type:v.literal("SELECT_OPTION"),target:pt,cache:Cn,choice:TE.describe("new field for selecting options, optional for backcompat")}).openapi({ref:"SelectOptionCommand"}),Rc=v.union([v.literal("MULTIMODAL"),v.literal("VISION_ONLY")]),ts=Y.merge(v.object({type:v.literal("AI_ASSERTION"),assertion:v.string(),disableCache:v.boolean().optional(),iframeUrl:v.string().optional(),contextChoice:Rc.optional(),timeout:v.number().int().optional().describe("Max seconds to wait for assertion to be true"),cache:om.optional()})).openapi({ref:"AIAssertionCommand"}),Rn=5,Ac=600,Wi=Y.merge(qt).extend({type:v.literal("ELEMENT_CHECK"),target:pt,assertion:am,cache:Cn,timeout:v.number().int().min(0).max(Ac).optional().describe("max seconds to wait for the assertion to be true")}).openapi({ref:"ElementAssertionCommand"}),CE=Y.extend({type:v.literal("PAGE_CHECK"),assertion:sm,iframeUrl:v.string().optional().describe("url or url regex for the iframe"),timeout:v.number().int().min(0).max(Ac).optional().describe("max seconds to wait for the assertion to be true")}).openapi({ref:"PageAssertionCommand"}),RE=Y.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"}),AE=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()}),cm=25,Vi=Y.merge(qt).merge(AE).extend({type:v.literal("TYPE"),target:pt.optional(),value:v.string(),cache:Cn}).openapi({ref:"TypeCommand"}),IE=Y.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"}),PE=Y.merge(v.object({type:v.literal("KEY_DOWN"),value:v.string(),convertMeta:v.boolean().optional()})).openapi({ref:"KeyDownCommand"}),LE=Y.merge(v.object({type:v.literal("KEY_UP"),value:v.string(),convertMeta:v.boolean().optional()})).openapi({ref:"KeyUpCommand"}),OE=v.object({type:v.literal("SUBSTRING"),substring:v.string()}),ME=v.object({type:v.literal("REGEX"),pattern:v.string()}),NE=v.object({type:v.literal("INDEX"),index:v.coerce.string()}),kE=v.discriminatedUnion("type",[OE,ME,NE]),_E=Y.merge(Qa).merge(v.object({type:v.literal("TAB"),action:kE})).openapi({ref:"TabCommand"}),DE=Y.merge(Qa).merge(v.object({type:v.literal("NEW_TAB"),url:v.string()})).openapi({ref:"NewTabCommand"}),FE=Y.merge(v.object({type:v.literal("COOKIE"),value:v.string()})).openapi({ref:"CookieCommand"}),UE=Y.merge(v.object({type:v.literal("LOCAL_STORAGE"),key:v.string(),value:v.string()})).openapi({ref:"LocalStorageCommand"}),BE=Y.extend({type:v.literal("REQUEST")}).merge(Xa).openapi({ref:"RequestCommand"}),zE=Y.extend({type:v.literal("GRAPHQL_REQUEST")}).merge(lm).openapi({ref:"GraphQLRequestCommand"}),HE=Y.merge(v.object({type:v.literal("SUCCESS"),condition:ts.optional()})).openapi({ref:"SuccessCommand"}),jE=Y.merge(v.object({type:v.literal("FAILURE")})).openapi({ref:"FailureCommand"}),$E=v.object({data:v.string().describe("location at which to find a jpg"),width:v.number(),height:v.number()}),qi=Y.merge(qt).merge(v.object({type:v.literal("VISUAL_DIFF"),threshold:v.number().optional().describe("default 0.1"),target:pt.optional(),screenshot:$E.optional(),cache:Cn})).openapi({ref:"VisualDiffCommand"}),GE=Y.merge(v.object({type:v.literal("REGISTER_REQUEST_LISTENER"),pattern:v.string(),key:v.string()})).openapi({ref:"RegisterRequestListenerCommand"}),WE=Y.merge(v.object({type:v.literal("AWAIT_LISTENER"),key:v.string(),timeout:v.number().optional().describe("timeout")})).openapi({ref:"WaitForListenerCommand"}),VE=Y.merge(v.object({type:v.literal("RECORD_REQUESTS"),pattern:v.string(),key:v.string()})).openapi({ref:"RecordRequestsCommand"}),qE=Y.merge(v.object({type:v.literal("GET_RECORDED_REQUESTS"),key:v.string()})).openapi({ref:"GetRecordedRequestsCommand"}),KE=Y.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"}),dm=v.discriminatedUnion("type",[Ui,Vi,IE,PE,LE,Gi,sE,Co,To,ts,Hi,cE,HE]),YE=v.discriminatedUnion("type",[RE,SE,fE,Cc,FE,yE,lE,Bi,Wi,EE,hE,gE,wE,UE,zi,DE,CE,bE,mE,BE,zE,Ro,Ao,_E,qi,ji,$i,uE,GE,WE,VE,qE,KE]),Io=v.discriminatedUnion("type",[...dm.options,...YE.options]).openapi({ref:"Command"}),ns=v.discriminatedUnion("type",[...dm.options,jE]);function zn(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 pm(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 JE}from"zod";var dD=JE.discriminatedUnion("type",[$i,Cc,Ui,Bi,ji,Hi,zi,To,Co,Ro,Ao,Gi,Vi,qi,Wi]);function um(n){return["AI_ASSERTION","ELEMENT_CHECK","PAGE_CHECK"].includes(n)}import{z as XE}from"zod";var wt={type:!0,cache:!0},Pr=XE.discriminatedUnion("type",[ts.pick(wt),$i.pick(wt),Ui.pick(wt),Bi.pick(wt),Wi.pick(wt),ji.pick(wt),Hi.pick(wt),zi.pick(wt),To.pick(wt),Co.pick(wt),Ro.pick(wt),Ao.pick(wt),Gi.pick(wt),Vi.pick(wt),qi.pick(wt)]),Ic=Object.values(Ue).filter(n=>Pr.options.some(e=>e.shape.type.safeParse(n).success));Io.options.forEach(n=>{if("target"in n.shape&&!Ic.includes(n.shape.type.value))throw new Error(`Command ${n.shape.type.value} has a target but no cache`)});import{z as Lc}from"zod";import{z as Pc}from"zod";import{z as Po}from"zod";var It=Po.object({index:Po.number().optional().describe("global index within a test (in-order traversal)"),id:Po.string(),skipped:Po.boolean().optional(),envKey:Po.string().optional().describe("key in the environment to save the result of this step to"),aiSuggested:Po.boolean().optional()});Ce(Pc);var Pt=It.extend({type:Pc.literal("PRESET_ACTION"),command:Io,skipped:Pc.boolean().optional()}).openapi({ref:"PresetAction"});Ce(Lc);var Lr=It.extend({type:Lc.literal("AI_ACTION"),text:Lc.string(),steps:Pt.array().optional()}).openapi({ref:"AIAction"});import{z as de}from"zod";var ZE=de.object({cacheKey:de.string(),cacheExpiryMs:de.number()}),Oc=It.extend({id:de.string().uuid().describe("ID of the module step itself. Used to 'namespace' step cache entries."),inputs:de.record(de.string()).optional(),cacheConfig:ZE.optional()}),Hn=Oc.extend({type:de.literal("MODULE"),moduleId:de.string().uuid()}),QE=de.union([Hn.pick({type:!0,moduleId:!0}),de.record(de.unknown())]),eT=de.object({type:de.literal("URL_REGEX"),regex:de.string()}),tT=de.object({type:de.literal("PAGE_CHECK"),substring:de.string()}),Mc=de.object({cacheInvalidation:de.discriminatedUnion("type",[tT,eT]).optional()}),Lt=de.object({moduleId:de.string().uuid(),name:de.string(),description:de.string().nullish(),enabled:de.boolean().nullish(),parameters:de.string().array().nullish(),defaultParameters:de.record(de.string(),de.string()).nullish(),defaultCacheKey:de.string().nullish(),defaultCacheTtl:de.number().nullish(),defaultCacheAllInvocations:de.boolean().nullish(),autoAuth:de.boolean().nullish(),advanced:Mc.nullish()});import{z as at}from"zod";import{z as Nc}from"zod";Ce(Nc);var Lo=It.extend({type:Nc.literal("AI_ACTION_DYNAMIC"),text:Nc.string()}).openapi({ref:"AIActionDynamic"});import{z as mm}from"zod";var kc=It.extend({type:mm.literal("CONDITIONAL"),skipped:mm.boolean().optional()});import{z as rs}from"zod";var nT=rs.object({type:rs.literal("url"),url:rs.string()}),Ki=It.extend({type:rs.literal("IFRAME"),identifier:nT});import{z as Kt}from"zod";var _c=(r=>(r.ALWAYS="ALWAYS",r.ON_FAILURE="ON_FAILURE",r.ON_ACTION_FAILURE="ON_ACTION_FAILURE",r))(_c||{});var rT=Kt.discriminatedUnion("type",[Kt.object({type:Kt.literal("NAVIGATE_URL"),url:Kt.string().url()}),Kt.object({type:Kt.literal("GO_TO_SECTION_START")})]),oT=Kt.object({trigger:Kt.nativeEnum(_c).optional(),attempts:Kt.number().int().optional(),restartBehavior:rT}),Yi=It.extend({type:Kt.literal("SECTION"),description:Kt.string().describe("user provided goal of what the section should accomplish"),plan:Kt.string().array().optional(),autohealingConfig:oT.optional()});var hm=Lt.merge(Oc).extend({type:at.literal("RESOLVED_MODULE"),steps:at.lazy(()=>Pe.array())}),Dc=Lt.extend({steps:at.lazy(()=>Pe.array())}),Fc=Ki.extend({steps:at.lazy(()=>xe.array())}),iT=Ki.extend({steps:at.lazy(()=>Pe.array())}),Uc=Yi.extend({steps:at.lazy(()=>xe.array())}),aT=Yi.extend({steps:at.lazy(()=>Pe.array())}),Or=kc.extend({blocks:at.object({assertion:at.lazy(()=>Pt),steps:at.lazy(()=>xe.array())}).array(),elseSteps:at.lazy(()=>xe.array().optional())}),sT=kc.extend({blocks:at.object({assertion:at.lazy(()=>Pt),steps:at.lazy(()=>Pe.array())}).array(),elseSteps:at.lazy(()=>Pe.array().optional())}),xe=at.discriminatedUnion("type",[Pt,Lr,Lo,Hn,Or,Fc,Uc]),Pe=at.discriminatedUnion("type",[Pt,Lr,Lo,hm,sT,iT,aT]);import{z as Yt}from"zod";var lT=Yt.object({steps:xe.array(),beforeSteps:xe.array().nullish(),afterSteps:xe.array().nullish()}),Oo=Yt.object({steps:Pe.array(),beforeSteps:Pe.array().nullish(),afterSteps:Pe.array().nullish()}),Mr=Yt.object({steps:Yt.record(Yt.string(),Yt.unknown()).array(),beforeSteps:Yt.record(Yt.string(),Yt.unknown()).array().nullish(),afterSteps:Yt.record(Yt.string(),Yt.unknown()).array().nullish()});var De="1.0.20";import{z as ar}from"zod";var Bc=ar.object({key:ar.string(),testId:ar.string().optional(),moduleId:ar.string().optional(),organizationId:ar.string(),value:Pr}),cT=Bc.extend({uniqueKey:ar.string()}),gm=ar.record(ar.string(),cT);var fm=D.object({phrase:D.string()}),zc=D.object({thoughts:D.string().optional(),result:D.union([D.literal("NOT_FOUND"),D.string(),D.number(),D.array(D.unknown()),D.record(D.unknown(),D.unknown()),D.unknown()])}),d0=D.object({text:D.string()}),Sm=D.object({thoughts:D.string(),review:D.string().optional(),id:D.number().int(),updatedMemory:wc.optional()}),os=(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))(os||{});var ym=D.object({thoughts:D.string(),category:D.nativeEnum(os)}),dT=D.discriminatedUnion("op",[D.object({op:D.literal("replace"),path:D.string(),value:D.string()}),D.object({op:D.literal("add"),path:D.string(),value:D.string()}),D.object({op:D.literal("remove"),path:D.string()})]),p0=D.object({thoughts:D.string(),patches:dT.array()}),bm=[D.literal("add"),D.literal("replace"),D.literal("remove")],pT=D.object({op:D.union(bm),path:D.string(),value:Pe.optional()}),wm=D.object({patches:pT.array(),thoughts:D.string()});var uT=D.object({thoughts:D.string(),op:D.union(bm),value:D.union([D.null(),Pe])}),vm=D.object({reasoning:D.string(),scenario:D.string(),patch:uT.or(D.null())}),u0=D.object({thoughts:D.string(),evaluation:D.number().min(1).max(10)}),m0=D.object({observations:D.string(),reasoning:D.string(),command:ns});var Hc=D.object({summary:D.string(),reasoning:D.string(),evaluation:D.discriminatedUnion("type",[D.object({type:D.literal("DONE")}),D.object({type:D.literal("RIGHT_TRACK")}),D.object({type:D.literal("WRONG_TRACK"),feedback:D.string()}),D.object({type:D.literal("IMPOSSIBLE")})])});import{z as M}from"zod";import*as Q from"zod";var b0=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")}),is=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 Ji=(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))(Ji||{}),Mo=Q.object({matched:Q.boolean(),reason:Q.string().optional().describe("Human understandable description"),logs:Q.string().array().optional().describe("Logs for debugging")}),mT=Mo.extend({type:Q.literal("USER_SELECTOR")}),hT=Mo.extend({type:Q.literal("CSS_SELECTOR"),selectors:Q.string().array()}),gT=Mo.extend({type:Q.literal("HYBRID_SELECTOR")}),fT=Mo.extend({type:Q.literal("HTML_DISTANCE"),distance:Q.number().optional(),closestElement:Q.string().optional(),savedElement:Q.string().optional()}),ST=Mo.extend({type:Q.literal("TEMPLATE_MATCHING"),elementImageUrl:Q.string().url()}),yT=Mo.extend({type:Q.literal("AUTO_FRAME"),logs:Q.string().array().optional()}),xm=Q.discriminatedUnion("type",[mT,hT,gT,fT,ST,yT]);import{z as na}from"zod";import{z as zC}from"zod";import*as X from"zod";import{cloneDeep as Qi}from"lodash-es";var bT=n=>{let e=Em(n,0);if(e===void 0||!vT(n[e]))return;let t=Em(n,e+1);if(t!==void 0)return xT(n,e,t)},Tm=bT,Em=(n,e)=>{for(let t=e;t<n.length;t+=1){let r=n[t];if(!wT(r))return t}},wT=n=>n===" "||n===" "||n===`
|
|
5
|
-
`||n==="\r",
|
|
6
|
-
`)return
|
|
7
|
-
${e.message}`)}},LC=({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 pn}from"zod";import{z as vt}from"zod";var Zc=vt.object({autoFollowNewTabs:vt.boolean().optional().describe("Deprecated: Auto-follow new tabs that are opened."),showZeroOpacityElements:vt.boolean().optional(),ignoreHrefForCaching:vt.boolean().optional(),hybridSelectorMode:vt.enum(["test","prefer"]).optional()});var nh=1e4,rh=6e4,kr=Zc.extend({pageLoadTimeoutMs:vt.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:vt.number().optional().refine(n=>n===void 0||n<=nh&&n>=-1,{message:`Smart waiting timeout must be between 0 and ${nh/1e3} seconds`}),localChromeExtensionPaths:vt.string().array().optional(),extraHeaders:vt.record(vt.string(),vt.string()).optional().describe("HTTP headers to be sent on every request"),userAgent:vt.string().optional(),disableGpu:vt.boolean().optional(),bustCacheOnBoundingBoxChange:vt.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:vt.boolean().optional().describe("Allow fetching the partial accessibility tree if the full tree takes too long.")});var Ve="BASE_URL",gs="CURRENT_URL",ko="ENV_NAME",Zi="TEST_NAME",LU={[Ve]:"https://www.google.com"},oh=pn.string().describe("Name of the fixture (must be available locally in the fixtures directory)."),ih=pn.object({name:pn.string(),variables:pn.record(pn.string().describe("variable name"),pn.string().describe("variable value"))}),ah=pn.object({name:pn.string(),variables:pn.record(pn.string().describe("variable name"),pn.unknown().describe("variable value")),browser:kr.optional()});Ce(_r);var ea=_r.object({env:_r.record(_r.unknown())}).openapi({ref:"TestContextSnapshot"}),OC="\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022",MC=[Ve,ko,Zi],sh=[gs,Ve,ko,Zi],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[Ve]??"about:blank",o=e.env[gs]??"about:blank",i=e.env[ko],a=e.env[Zi],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=Qi(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){MC.includes(e)||(this.env[e]=t)}getEnvName(){return this.env[ko]}toObjectCopy(){let e={env:Object.assign({},this.env,this.varsFromMomenticEnvironment)};return Qi(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,OC]));for(let[r,o]of Object.entries(e.env)){if(!o){e.env[r]=o;continue}let{jsonString:i}=No(JSON.stringify(o),1e3);try{e.env[r]=JSON.parse(i)}catch{e.env[r]=void 0}}let{jsonString:t}=No(JSON.stringify(e.env),5e3);try{e.env=JSON.parse(t)}catch{e.env={}}return e}setCurrentUrl(e){this.env[gs]=e}reset(e){this.env={},this.varsFromMomenticEnvironment={},this.setEnvVariables(e.dynamicVariables??{}),this.setCurrentUrl(e.currentUrl),this.varsFromMomenticEnvironment=Qi(e.variablesFromEnvironment),this.setMomenticSystemVariable(Ve,e.baseUrl),e.envName&&this.setMomenticSystemVariable(ko,e.envName),e.testName&&this.setMomenticSystemVariable(Zi,e.testName)}getDynamicVariablesCopy(){return Qi(this.env)}getVariablesFromEnvironmentCopy(){return Qi(this.varsFromMomenticEnvironment)}};import{z as Dr}from"zod";Ce(Dr);var pe=(c=>(c.AI_PROVIDER="AIProviderError",c.USER_INFRA="UserInfrastructureError",c.ACTION_FAILURE="ActionFailureError",c.ASSERTION_FAILURE="AssertionFailureError",c.CONFIG_ERROR="UserConfigurationError",c.WEB_AGENT_PLATFORM="InternalWebAgentError",c.UNKNOWN_PLATFORM="InternalPlatformError",c.JOB_TIMEOUT="JobTimeoutError",c.UNKNOWN="UnknownError",c))(pe||{});var lh=["JobTimeoutError","UserConfigurationError","UserInfrastructureError"],fs={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"},_o={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."},Qc=Dr.object({reason:Dr.nativeEnum(pe),summary:Dr.string()}).openapi({ref:"TestResultClassification"}),Ss=Dr.object({errorMessage:Dr.string(),errorStack:Dr.string().optional(),classification:Qc.optional()}).openapi({ref:"TestFailureDetails"});Ce(X);var Re=(i=>(i.SUCCESS="SUCCESS",i.FAILED="FAILED",i.RUNNING="RUNNING",i.IDLE="IDLE",i.CANCELLED="CANCELLED",i))(Re||{}),ed=(r=>(r.SUCCESS="SUCCESS",r.FAILED="FAILED",r.CANCELLED="CANCELLED",r))(ed||{}),td=X.object({beforeUrl:X.string().optional(),afterUrl:X.string().optional(),message:X.string().optional(),beforeScreenshot:X.string().optional(),afterScreenshot:X.string().optional(),beforeSnapshot:X.string().optional(),afterSnapshot:X.string().optional(),startedAt:X.coerce.date(),finishedAt:X.coerce.date()}),NC=td.extend({viewport:X.object({height:X.number(),width:X.number()}),status:X.nativeEnum(ed),message:X.string().optional(),elementInteracted:X.string().optional()}),sr=td.extend({status:X.nativeEnum(Re),message:X.string().optional(),data:X.unknown().optional(),beforeTestContext:ea.optional(),afterTestContext:ea.optional(),failureReason:X.nativeEnum(pe).optional(),details:X.unknown().describe("Parse using StepExecutionLogSchema.array() to get type safety. We don't explicitly type it because it's non-critical information.")}).openapi({ref:"StepResultMetadata"}),ys=sr.merge(Pt).extend({results:NC.array(),proposedStep:Pt.optional()}),kC=sr.merge(Lr).extend({results:X.lazy(()=>ys.array())}),_C=sr.merge(Lo).extend({results:X.lazy(()=>ys.array())}),DC=sr.merge(Hn).extend({moduleName:X.string().optional(),results:X.lazy(()=>Mt.array())}),FC=sr.merge(Or).extend({assertion:ys.optional(),results:X.lazy(()=>Mt.array()).describe("results for the block actually executed")}),UC=sr.merge(Ki).extend({results:X.lazy(()=>Mt.array())}),BC=sr.merge(Yi).extend({results:X.lazy(()=>Mt.array()),healingAttempts:X.lazy(()=>Mt.array().array()).optional()}),Mt=X.discriminatedUnion("type",[kC,_C,ys,DC,FC,UC,BC]),bs=sr.pick({startedAt:!0,finishedAt:!0,status:!0,message:!0,data:!0}),ws=td.extend({index:X.number().optional(),description:X.string(),pageState:X.string().optional()});var nd=zC.object({results:Mt.array().describe("main results"),beforeResults:Mt.array().optional(),afterResults:Mt.array().optional()}),vs=nd.partial();import{z as W}from"zod";import{z as Ae}from"zod";var HC=Ae.object({type:Ae.literal("FAILURE_RECOVERY"),thoughts:Ae.string()}),jC=Ae.object({type:Ae.literal("DESCRIPTION_UPDATE"),thoughts:Ae.string()}),xs=Ae.discriminatedUnion("type",[jC,HC]),Es=(e=>(e.AUTO_HEALING="AUTO_HEALING",e))(Es||{}),$C=Ae.object({testId:Ae.string(),name:Ae.string(),orgId:Ae.string(),runId:Ae.string(),purpose:Ae.nativeEnum(Es).catch("AUTO_HEALING"),steps:Pe.array(),details:xs.or(xs.array()).optional()}),nB=$C.pick({name:!0,orgId:!0}),rd=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(Es).catch("AUTO_HEALING"),runId:Ae.string().nullish(),details:xs.or(xs.array()).nullish(),applied:Ae.boolean().nullish(),appliedAt:Ae.coerce.date().nullish()}),ch=rd.extend({steps:Pe.array()});import{isValidCron as GC}from"cron-validator";import{z as ne}from"zod";import{z as od}from"zod";var jn=(r=>(r.CHROMIUM="Chromium",r.GOOGLE_CHROME="Google Chrome",r.CHROME_FOR_TESTING="Chrome for Testing",r))(jn||{});var Ts=od.object({width:od.number().min(200).max(1e4),height:od.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}},iB=Object.keys(dh);var Jt=dh["Desktop Large"],Do="en-us",Fo="America/Los_Angeles";var Uo={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,Cs=kr.extend({browserType:ne.nativeEnum(jn).optional(),slowMoMs:ne.number().optional().refine(n=>n===void 0||n<=uh&&n>=-1,{message:`Slow motion must be between 0 and ${uh} 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(ph).optional(),colorScheme:ne.enum(["light","dark"]).optional()}),mh=["extraHeaders","basicAuthorization","localChromeExtensionPaths"],WC=ne.object({disableAICaching:ne.boolean().optional(),useMemory:ne.boolean().optional(),failureRecovery:ne.boolean().optional().describe("undefined means inherit org settings")});var VC=ne.object({viewport:Ts.optional()}),Bo=VC.merge(WC).merge(Cs),zo=ne.object({cron:ne.string().refine(n=>GC(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()}),Ho=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")}),Rs=qC.array(),KC=ne.object({name:ne.string(),value:ne.string()}),hh=KC.array(),As=ne.object({name:ne.string(),default:ne.boolean().optional(),fixtures:oh.array().optional()});Ce(W);var Xt={WEBHOOK:"WEBHOOK",CRON:"CRON",MANUAL:"MANUAL",CLI:"CLI"},oe=(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))(oe||{}),Is=(t=>(t.BEFORE_ALL="BEFORE_ALL",t.AFTER_ALL="AFTER_ALL",t))(Is||{});var qe=W.string().pipe(W.coerce.date()).or(W.date()),ta=W.object({id:W.string(),runKey:W.string(),organizationId:W.string(),createdAt:qe,createdBy:W.string(),flake:W.boolean().nullish(),scheduledAt:qe.or(W.null()),startedAt:qe.or(W.null()),updatedAt:qe.nullish(),finishedAt:qe.or(W.null()),resolvedBaseUrl:W.string().nullish(),environmentName:W.string().nullish(),labels:W.array(W.string()).optional(),cliVersion:W.string().nullish(),section:W.nativeEnum(Is).nullish(),status:W.nativeEnum(oe),trigger:W.nativeEnum(Xt),attempts:W.number(),runAttempts:W.array(W.object({id:W.string(),status:W.nativeEnum(oe),startedAt:qe.or(W.null()),finishedAt:qe.or(W.null())})).optional(),videos:W.array(W.string()).optional(),failureReason:W.nativeEnum(pe).nullish(),failureDetails:Ss.nullish(),testFragments:W.array(rd).nullish(),localTestId:W.string().nullish(),testId:W.string().nullish(),testName:W.string().nullish(),test:W.object({name:W.string(),id:W.string()}).nullish().default(null),suiteId:W.string().nullish()}).openapi({ref:"RunMetadata"}),YC={id:!0,status:!0,testName:!0,localTestId:!0,testId:!0,test:{select:{name:!0,id:!0}},finishedAt:!0,failureReason:!0,failureDetails:!0},Ps=ta.pick({...YC,test:!0}),gh=ta.omit({failureReason:!0,failureDetails:!0,test:!0}),id=ta.extend({stepsSnapshot:W.array(W.record(W.unknown())).nullish(),resolvedInputs:W.record(W.string(),W.string()).nullish(),test:W.object({name:W.string(),id:W.string(),description:W.string().nullish(),baseUrl:W.string().nullish(),advanced:Bo.nullish()}).nullish()}).merge(nd),fh=n=>n.includes("PASSED")&&n.includes("FAILED");var JC=na.object({id:na.string().uuid(),startedAt:qe.or(na.null()),finishedAt:qe.or(na.null()),status:na.nativeEnum(oe)}).merge(vs),AB=JC.array();var ra=(o=>(o.JUNIT="junit",o.ALLURE="allure",o.ALLURE_JSON="allure-json",o.PLAYWRIGHT_JSON="playwright-json",o))(ra||{});import{z as Ye}from"zod";var XC=Ye.object({id:Ye.string(),status:Ye.nativeEnum(oe),trigger:Ye.nativeEnum(Xt),createdAt:qe,startedAt:qe.nullish(),finishedAt:qe.nullish(),gitCommitSha:Ye.string().nullish(),gitCommitShaShort:Ye.string().nullish(),gitCommitTimestamp:qe.nullish(),gitBranchName:Ye.string().nullish(),gitOriginUrl:Ye.string().nullish(),gitCommitMessage:Ye.string().nullish(),gitCommitAuthorName:Ye.string().nullish(),githubRepository:Ye.string().nullish(),gitlabProjectPath:Ye.string().nullish(),pipelineId:Ye.string().nullish(),cliVersion:Ye.string().nullish(),suite:Ye.object({id:Ye.string(),name:Ye.string()}).nullish(),runs:Ye.object({status:Ye.nativeEnum(oe)}).array()}).openapi({ref:"RunGroup"}),Sh=XC.pick({id:!0,createdAt:!0,startedAt:!0,finishedAt:!0,status:!0,trigger:!0,suite:!0}).extend({runs:Ps.array()});import{z as et}from"zod";var ZC=et.object({type:et.literal("TARGETING"),name:et.string().optional().describe("Target name to disambiguate for steps with multiple targets"),elementLocationDecisions:xm.array(),pageState:et.string().optional(),targetSource:et.nativeEnum(or).optional(),targetUpdateTime:et.string().optional()}),QC=et.object({type:et.literal("AI_LOCATION"),matched:et.boolean(),pageState:et.string().optional(),ragUsed:et.boolean().optional(),thoughts:et.string().optional()}),eR=et.object({type:et.literal("ASSERTION"),relevantElementsSerialized:et.string().array().optional(),pageState:et.string().optional(),ragUsed:et.boolean().optional()}),yh=et.discriminatedUnion("type",[ZC,QC,eR]);function Ls(){return{details:[]}}import{z as Be}from"zod";var tR=Be.object({id:Be.string(),name:Be.string()}),HB=tR.merge(Be.object({createdAt:qe,createdBy:Be.string(),schedule:zo,notification:Ho,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:qe,startedAt:qe.or(Be.null()),finishedAt:qe.or(Be.null()),status:Be.nativeEnum(oe),trigger:Be.nativeEnum(Xt),suite:Be.object({id:Be.string(),name:Be.string()}).nullish(),runs:ta.array()}),jB=bh.pick({id:!0,createdAt:!0,startedAt:!0,finishedAt:!0,status:!0,trigger:!0,suite:!0}),wh=bh.extend({runs:Ps.array()});import{z as Zt}from"zod";import{cloneDeep as VB}from"lodash-es";import{z as ge}from"zod";var XB=ge.object({thoughts:ge.string(),subGoals:ge.object({instruction:ge.string()}).array()}),ZB=ge.object({thoughts:ge.string(),newPlanMarkdown:ge.string()}),QB=ge.object({thoughts:ge.string(),correct:ge.boolean(),failedActionIndex:ge.number().optional()}),nR=ge.object({type:ge.literal("PLANNING"),beforePlan:ge.string(),goalDecision:ge.string(),thoughts:ge.string()}),rR=ge.object({type:ge.literal("RUNNING"),stepDisplayName:ge.string(),status:ge.nativeEnum(Re),results:Mt.array()}),oR=ge.object({type:ge.literal("REVISING"),beforePlan:ge.string(),afterPlan:ge.string(),errString:ge.string(),diffs:ge.string(),thoughts:ge.string()}),iR=ge.object({type:ge.literal("SYSTEM"),message:ge.string()}),aR=ge.discriminatedUnion("type",[nR,rR,oR,iR]),vh=aR.array();var o1=Zt.object({id:Zt.string(),scheduledAt:Zt.coerce.date().nullable(),startedAt:Zt.coerce.date().nullable(),finishedAt:Zt.coerce.date().nullable(),status:Zt.nativeEnum(oe),history:vh.nullable(),testPlan:Zt.object({id:Zt.string(),name:Zt.string()}).nullable(),test:Zt.object({id:Zt.string(),name:Zt.string()}).nullable()});import{z as xt}from"zod";var ad=xt.object({content:xt.string(),ids:xt.string().array(),tokenLength:xt.number()}),sR=xt.object({chunks:ad.array()}),v1=xt.object({ids:xt.string().array(),score:xt.number(),tokenLength:xt.number()}),x1=sR.extend({description:xt.string().describe("Input to pass to RAG engine"),tokenLimit:xt.number()}),xh=xt.object({ids:xt.number().array()}),Eh=xt.object({indices:xt.number().array()});var Qt=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()}),L1=Qt.extend({chunks:ad.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()}),lR=M.object({screenshotBase64AfterCommand:M.string(),urlAfterCommand:M.string(),serializedCommand:M.string(),elementInteracted:M.string().optional(),thoughts:M.string().optional()}),Th=M.object({goal:M.string(),browserState:M.string(),screenshot:M.string(),source:is.optional().catch(void 0),memory:M.discriminatedUnion("type",[Di,M.object({type:M.literal("RESOLVED_TRACES"),traces:M.unknown().array()})]).optional()}),Ch=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()}),Rh=M.object({goal:M.string(),browserState:M.string(),screenshot:M.string().optional(),returnSchema:M.string().optional()}),Ah=M.object({goal:M.string(),browserState:M.string(),screenshot:M.string(),url:M.string(),contextChoice:Rc.optional(),memory:M.discriminatedUnion("type",[Ec,M.object({type:M.literal("RESOLVED_TRACES"),traces:M.unknown().array()})]).optional()}),Ih=M.object({command:Io}),sd=M.object({goal:M.string(),browserState:M.string(),startingScreenshot:M.string().optional(),screenshot:M.string(),url:M.string(),history:lR.array(),actionHint:M.string().optional(),lastError:M.string().optional()}),Ph=M.object({results:ws.array(),errorMessage:M.string(),errorStack:M.string().optional()}),Lh=M.object({results:ws.array(),goal:M.string(),errorMessage:M.string()}),Oh=M.object({failedResults:ws.array(),nextStepsSerialized:M.string().array(),currentUrl:M.string(),currentPageState:M.string(),currentScreenshot:M.string()}),O1=M.object({description:M.string(),type:M.union([M.literal("locator"),M.literal("assertion"),M.literal("ai-action")]),excerpt:M.string()});import{z as oa}from"zod";var k1=oa.object({goal:oa.string()}),Mh=oa.object({keywords:oa.array(oa.string())});import{z as ld}from"zod";var cd=(t=>(t.LOCATOR="locator",t.ASSERTION="assertion",t))(cd||{}),F1=ld.nativeEnum(cd),cR=ld.enum(["v1","v2"]),U1=cR.or(ld.string().describe("for people with special configurations"));var Nh=n=>!(!n.org_id||!n.user_id||!n.platform);import{z as Fr}from"zod";var kh=Fr.object({id:Fr.string().uuid(),skipped:Fr.boolean().optional(),envKey:Fr.string().optional().describe("key in the environment to save the result of this step to")}),dd=kh.merge(Xa).extend({type:Fr.literal("REQUEST")}),pd=kh.merge(Za).extend({type:Fr.literal("JAVASCRIPT")}),ud=Fr.discriminatedUnion("type",[pd,dd]);import{z as en}from"zod";import{z as Ur}from"zod";var dR=/^[a-f0-9]{8}-[a-f0-9]{4}-[1-5][a-f0-9]{3}-[89ab][a-f0-9]{3}-[a-f0-9]{12}$/,Ne=n=>{let e=n.trim().toLowerCase().replace(/[^a-z0-9]/g,"-");for(;e.includes("--");)e=e.replaceAll("--","-");return e.startsWith("-")&&(e=e.slice(1)),e.endsWith("-")&&(e=e.slice(0,e.length-1)),e};var Os=Ur.string().min(1).max(255).superRefine((n,e)=>{try{jo(n)}catch(t){return e.addIssue({code:Ur.ZodIssueCode.custom,message:t.message,fatal:!0}),Ur.NEVER}});function jo(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(dR))throw new Error("Name cannot be a UUID. Please choose a different name.")}var Ms=Ur.preprocess(n=>n===null?"":n,Ur.union([Ur.string().url(),Ur.literal("")])).optional();var _h=en.object({id:en.string(),name:Os,description:en.string().optional().nullish(),baseUrl:Ms.nullish(),schemaVersion:en.string(),advanced:en.unknown().optional(),retries:en.number(),envs:en.array(As).nullish(),parameters:Rs.nullish()}),pR=en.object({createdAt:en.coerce.date(),updatedAt:en.coerce.date(),schedule:zo.nullish(),notification:Ho.nullish(),createdBy:en.string(),organizationId:en.string()}),uR=_h.merge(pR),sz=uR.extend({steps:ud.array()}),lz=_h.extend({steps:ud.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()}),hR=Dh.merge(pd).extend({type:Nt.literal("JAVASCRIPT")}),gR=Dh.merge(dd).extend({type:Nt.literal("REQUEST")}),fR=Nt.discriminatedUnion("type",[hR,gR]),Fh=Nt.object({startedAt:Nt.coerce.date(),finishedAt:Nt.coerce.date().nullish(),status:Nt.nativeEnum(oe),results:fR.array(),failureReason:Nt.string().nullish(),failureDetails:Ss.nullish()});import{z as kt}from"zod";var SR=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(oe),trigger:kt.nativeEnum(Xt),results:Fh.array().nullish(),apiTestName:kt.string().nullish(),apiTestPath:kt.string().nullish(),apiTestId:kt.string().nullish()}),Sz=SR.pick({status:!0,startedAt:!0,finishedAt:!0});var ia=(t=>(t.TestRun="test-run",t.CreditsUsed="credits-used",t))(ia||{}),Uh=3;function yR(n){return n==="MODULE"||n==="IFRAME"||n==="CONDITIONAL"||n==="SECTION"||n==="RESOLVED_MODULE"}function aa(n){if(!yR(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 sa(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 $o=class{async reportBillableEvent(e,t,r){}async reportCreditsUsed(e,t,r,o){}};function md(n,e){return{...n,testId:e?.testId??"",testName:e?.testName??"",suiteId:e?.suiteId??"",suiteName:e?.suiteName??""}}import{parseString as bR,splitCookiesString as wR}from"set-cookie-parser";import{z as Se}from"zod";var hd=Se.object({name:Se.string(),value:Se.string(),url:Se.string().optional(),domain:Se.string().optional(),path:Se.string().optional(),expires:Se.number().default(Date.now()/1e3+60*60*24*365),httpOnly:Se.boolean().optional(),secure:Se.boolean().default(!0),sameSite:Se.union([Se.literal("Strict"),Se.literal("Lax"),Se.literal("None")]).default("None")});function Ns(n,e){let t=[],r=wR(n);for(let o of r){let i=bR(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=hd.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 vR=Se.object({origin:Se.string(),localStorage:Se.array(Se.object({name:Se.string(),value:Se.string()}))}),xR=Se.object({entries:Se.record(Se.string(),Se.array(Se.tuple([Se.unknown(),Se.unknown()]))),version:Se.number().optional()}),ks=Se.object({cookies:hd.array().optional(),origins:vR.array().optional(),idb:Se.record(Se.string(),xR).optional().describe("key is db name")});function _s(n,e){let t=[];return n.cloneSync()?.serializeSync()?.cookies.forEach(r=>{let o=hd.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 Bz=new Set(Object.values(Ue));var ER={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:[]},Hz={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 Gz,en as Wz}from"@faker-js/faker";import{z as V}from"zod";var Bh=55555,Yz=V.object({body:V.string(),to:V.string(),from:V.string()}),Jz=V.object({from:V.string().optional(),to:V.string(),timeout:V.number().optional(),beforeDate:V.string().pipe(V.coerce.date()).or(V.date()).optional(),afterDate:V.string().pipe(V.coerce.date()).or(V.date()).optional()}),Xz=V.object({to:V.string(),from:V.string(),subject:V.string(),body:V.string()}),Zz=V.object({inbox:V.string(),afterDate:V.string().pipe(V.coerce.date()).or(V.date()).optional(),timeout:V.number().optional(),trimWhitespace:V.boolean().optional()}),Qz=V.object({inbox:V.string(),limit:V.number().optional(),afterDate:V.string().pipe(V.coerce.date()).or(V.date()).optional(),trimWhitespace:V.boolean().optional()});var zh=V.object({result:V.unknown(),variableUpdates:V.record(V.string(),V.unknown()).optional(),persistentVariableUpdates:V.record(V.string(),V.unknown()).optional(),error:V.string().optional(),success:V.boolean()}),eH=V.object({id:V.string().optional(),orgId:V.string(),momenticLambdaAuthHash:V.string(),code:V.string(),fragment:V.boolean(),state:ea,timeoutMs:V.number().optional()}),lr=15e3;import*as mt from"zod";Ce(mt);var TR=mt.object({url:mt.string(),lineNumber:mt.number(),columnNumber:mt.number()}).openapi({ref:"CodeLocation"}),Ds=mt.object({timestamp:mt.number(),text:mt.string(),type:mt.string(),tabIndex:mt.number(),args:mt.unknown().array().optional(),url:mt.string().optional(),location:TR.optional()}).openapi({ref:"ConsoleLog"}),Hh=Ds.array(),CR=Hh.array();import*as fd from"zod";import{z as I}from"zod";var RR=I.object({name:I.string(),version:I.string(),comment:I.string().optional()}),AR=I.object({name:I.string(),version:I.string(),comment:I.string().optional()}),IR=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:IR,comment:I.string().optional()}),PR=I.array($h),LR=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(LR),OR=I.object({name:I.string(),value:I.string(),comment:I.string().optional()}),Wh=I.array(OR),MR=I.object({name:I.string(),value:I.string(),comment:I.string().optional()}),NR=I.array(MR),kR=I.object({name:I.string(),value:I.string().optional(),fileName:I.string().optional(),contentType:I.string().optional(),comment:I.string().optional()}),_R=I.array(kR),DR=I.object({mimeType:I.string(),params:_R,text:I.string(),comment:I.string().optional()}),FR=I.object({method:I.string(),url:I.string(),httpVersion:I.string().optional(),cookies:Gh,headers:Wh,queryString:NR,postData:DR.optional(),headersSize:I.number().optional(),bodySize:I.number().optional(),comment:I.string().optional()}),UR=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()}),BR=I.object({status:I.number(),statusText:I.string(),httpVersion:I.string().optional(),cookies:Gh,headers:Wh,content:UR,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()}),zR=I.object({beforeRequest:jh.optional(),afterRequest:jh.optional(),comment:I.string().optional()}),HR=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:FR,response:BR.optional(),cache:zR.optional(),timings:HR,serverIPAddress:I.string().optional(),connection:I.string().optional(),comment:I.string().optional(),_resourceType:I.string().optional()}),jR=I.array(Vh),$R=I.object({version:I.string().default("1.1"),creator:RR.optional(),browser:AR.optional(),pages:PR.optional(),entries:jR,comment:I.string().optional()}),GR=I.object({log:$R}),qh=I.record(I.string(),$h),Kh=I.record(I.string(),Vh);function gd(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(fd);var WR=fd.object({logsPerPage:Ds.array().array(),harPages:qh.optional(),harEntries:Kh.optional()}).openapi({ref:"DebugData"});var Br=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 Fs=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(pe))if(n.includes(e))return e}var A=class extends Error{reason;constructor(e,t,r){let o=!1;for(let i of Object.values(pe))if(t.startsWith(i)){o=!0,e=i;break}if(r?.errOptions?.cause)super(o?t:`${e}: ${t}`,r?.errOptions);else{let i=o?t:`${e}${t?`: ${t}`:""}`;super(i,r?.errOptions)}this.name="TestFailureError",this.stack=this.stack?.slice(this.name.length+2),this.reason=e,Object.defineProperty(this,"lastScreenshotBuffer",{value:r?.lastScreenshotBuffer,enumerable:!1})}getLastScreenshotBuffer(){return"lastScreenshotBuffer"in this?this.lastScreenshotBuffer:void 0}toString(){return this.message}toJSON(){return{message:this.message}}},An=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]="6256feb0-d23a-52f4-bf58-990004f6ae2f")}catch(e){}}();
|
|
4
|
+
var qE=Object.create;var Xu=Object.defineProperty;var KE=Object.getOwnPropertyDescriptor;var YE=Object.getOwnPropertyNames;var JE=Object.getPrototypeOf,XE=Object.prototype.hasOwnProperty;var Zu=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports);var ZE=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of YE(e))!XE.call(n,o)&&o!==t&&Xu(n,o,{get:()=>e[o],enumerable:!(r=KE(e,o))||r.enumerable});return n};var QE=(n,e,t)=>(t=n!=null?qE(JE(n)):{},ZE(e||!n||!n.__esModule?Xu(t,"default",{value:n,enumerable:!0}):t,n));var uS=Zu((x3,pS)=>{"use strict";pS.exports=cS;function cS(n,e,t){n instanceof RegExp&&(n=lS(n,t)),e instanceof RegExp&&(e=lS(e,t));var r=dS(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 lS(n,e){var t=e.match(n);return t?t[0]:null}cS.range=dS;function dS(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 wS=Zu((T3,bS)=>{"use strict";var mS=uS();bS.exports=YA;var hS="\0SLASH"+Math.random()+"\0",gS="\0OPEN"+Math.random()+"\0",Ud="\0CLOSE"+Math.random()+"\0",fS="\0COMMA"+Math.random()+"\0",SS="\0PERIOD"+Math.random()+"\0";function Fd(n){return parseInt(n,10)==n?parseInt(n,10):n.charCodeAt(0)}function qA(n){return n.split("\\\\").join(hS).split("\\{").join(gS).split("\\}").join(Ud).split("\\,").join(fS).split("\\.").join(SS)}function KA(n){return n.split(hS).join("\\").split(gS).join("{").split(Ud).join("}").split(fS).join(",").split(SS).join(".")}function yS(n){if(!n)return[""];var e=[],t=mS("{","}",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=yS(i);return i.length&&(a[a.length-1]+=s.shift(),a.push.apply(a,s)),e.push.apply(e,a),e}function YA(n){return n?(n.substr(0,2)==="{}"&&(n="\\{\\}"+n.substr(2)),ya(qA(n),!0).map(KA)):[]}function JA(n){return"{"+n+"}"}function XA(n){return/^-?0\d/.test(n)}function ZA(n,e){return n<=e}function QA(n,e){return n>=e}function ya(n,e){var t=[],r=mS("{","}",n);if(!r)return[n];var o=r.pre,i=r.post.length?ya(r.post,!1):[""];if(/\$$/.test(r.pre))for(var a=0;a<i.length;a++){var s=o+"{"+r.body+"}"+i[a];t.push(s)}else{var l=/^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(r.body),c=/^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(r.body),d=l||c,p=r.body.indexOf(",")>=0;if(!d&&!p)return r.post.match(/,.*\}/)?(n=r.pre+"{"+r.body+Ud+r.post,ya(n)):[n];var u;if(d)u=r.body.split(/\.\./);else if(u=yS(r.body),u.length===1&&(u=ya(u[0],!1).map(JA),u.length===1))return i.map(function(H){return r.pre+u[0]+H});var m;if(d){var h=Fd(u[0]),g=Fd(u[1]),f=Math.max(u[0].length,u[1].length),S=u.length==3?Math.abs(Fd(u[2])):1,w=ZA,E=g<h;E&&(S*=-1,w=QA);var y=u.some(XA);m=[];for(var T=h;w(T,g);T+=S){var C;if(c)C=String.fromCharCode(T),C==="\\"&&(C="");else if(C=String(T),y){var R=f-C.length;if(R>0){var L=new Array(R+1).join("0");T<0?C="-"+L+C.slice(1):C=L+C}}m.push(C)}}else{m=[];for(var M=0;M<u.length;M++)m.push.apply(m,ya(u[M],!1))}for(var M=0;M<m.length;M++)for(var a=0;a<i.length;a++){var s=o+m[M]+i[a];(!e||d||s)&&t.push(s)}}return t}});var ki=(n,e)=>{},bc=!1;try{let n=await import("@sentry/node");ki=n.captureException,n.init({dsn:"https://89e980855f7b9c6e56fc6c7e7143888b@o4506426201800704.ingest.us.sentry.io/4508343221354497",environment:"production",release:process.env.SENTRY_RELEASE_NAME,tracesSampleRate:0}),bc=!0}catch{}import{Command as y_,Option as Vt}from"@commander-js/extra-typings";import{execSync as b_}from"child_process";import Cv from"body-parser";import QM from"cors";import ek from"dedent";import tk from"events";import Rv,{Router as nk}from"express";import{diff as GA}from"deep-object-diff";import hn from"fs";import Xr from"path";import{diff as fA}from"deep-object-diff";import{z as Qu}from"zod";var O_=Qu.object({input:Qu.string()});import{z as Ke}from"zod";var k_=Ke.object({srcs:Ke.array(Ke.string()),urls:Ke.array(Ke.string()),desiredSrc:Ke.string().optional(),desiredUrl:Ke.string().optional()}),em=Ke.object({srcRegex:Ke.string().optional(),urlRegex:Ke.string().optional()}),tm=Ke.object({x:Ke.number(),y:Ke.number(),correlation:Ke.number()}),__=Ke.object({searchImageBase64String:Ke.string(),pageImageBase64String:Ke.string(),id:Ke.string().uuid(),timeoutMs:Ke.number().max(1e4).min(0).optional()});import{z as D}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 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||{}),ex=F.object({mPathSelectorTokens:F.string().array(),frameSrcRegex:F.string().optional(),frameUrlRegex:F.string().optional(),indices:F.number().array()}),wc=F.object({result:F.number(),traceId:F.string()}).array(),_i=F.object({type:F.literal("GCS_TRACES"),traces:wc}),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:ex.optional(),inputDescription:F.string().optional().describe("the description that generated this cache"),targetSource:F.nativeEnum(or).optional(),targetUpdateTime:F.string().optional(),targetUpdateLoggerTags:F.record(F.string(),F.string()).optional(),memory:_i.optional()}).openapi({ref:"ElementTargetCache"});function nm(n){return!!(n.name||n.role||n.content||n.serializedForm||n.serializedHtml||n.screenshotUrl)}var tx=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"}),nx=F.object({x:F.number(),y:F.number()}),rx=F.object({type:F.literal("coordinates"),pixels:nx}).openapi({ref:"CoordinatesTarget"});function ir(n){return n.type==="description"}function Tn(n){return n.type==="coordinates"}var pt=F.discriminatedUnion("type",[tx,rx]).openapi({ref:"ElementTarget"});function vc(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 we}from"uuid";import*as v from"zod";import{z as ye}from"zod";import{z as wo}from"zod";var Ec=wo.object({result:wo.boolean(),traceId:wo.string()}).array(),xc=wo.object({type:wo.literal("GCS_TRACES"),traces:Ec}),rm=wo.object({memory:xc.optional()});var Ja=class{async resolveStepCacheEntries(){}async saveStepCacheEntries(){}};Ce(ye);var om=ye.object({plan:ye.string().optional(),evidence:ye.string().optional(),thoughts:ye.string(),result:ye.boolean(),relevantElements:ye.array(ye.number()).optional(),updatedMemory:Ec.optional()}),vo=(o=>(o.CONTAINS="CONTAINS",o.STARTS_WITH="STARTS_WITH",o.EQUALS="EQUALS",o.EXISTS="EXISTS",o))(vo||{});var ox=ye.object({type:ye.literal("ELEMENT_CONTENT"),negated:ye.boolean().optional(),operation:ye.nativeEnum(vo),value:ye.string()}).openapi({ref:"ElementContentAssertion"}),ix=ye.object({type:ye.literal("ELEMENT_ATTRIBUTE"),negated:ye.boolean().optional(),operation:ye.nativeEnum(vo),attr:ye.string(),value:ye.string()}).openapi({ref:"ElementAttributeValueAssertion"}),Eo=(o=>(o.EXISTS="EXISTS",o.VISIBLE="VISIBLE",o.ENABLED="ENABLED",o.EDITABLE="EDITABLE",o))(Eo||{}),ax=ye.object({type:ye.literal("ELEMENT_EXISTENCE"),negated:ye.boolean().optional(),condition:ye.nativeEnum(Eo).describe("Treated as the element exists AND is also ...")}).openapi({ref:"ElementExistenceAssertion"}),im=ye.discriminatedUnion("type",[ox,ix,ax]).openapi({ref:"ManualElementAssertion"});var sx=ye.object({type:ye.literal("CONTENT"),negated:ye.boolean().optional(),value:ye.string()}).openapi({ref:"PageContentAssertion"}),am=ye.discriminatedUnion("type",[sx]).openapi({ref:"ManualPageAssertion"});import{z as ie}from"zod";var Xa=ie.object({url:ie.string(),method:ie.union([ie.literal("GET"),ie.literal("POST"),ie.literal("PUT"),ie.literal("DELETE"),ie.literal("PATCH")]),headers:ie.record(ie.string(),ie.string()).optional(),params:ie.record(ie.string(),ie.string()).optional(),body:ie.string().optional(),timeout:ie.number().int().optional().describe("Max seconds to wait for the request to complete")}),sm=ie.object({url:ie.string(),headers:ie.record(ie.string(),ie.string()).optional(),query:ie.string(),variables:ie.record(ie.string(),ie.string()).optional(),timeout:ie.number().int().optional().describe("Max seconds to wait for the request to complete")}),Za=ie.object({code:ie.string(),fragment:ie.boolean().optional(),environment:ie.union([ie.literal("NODE"),ie.literal("BROWSER")]).optional().describe("default NODE"),timeout:ie.number().int().max(60).optional().describe("Max seconds for the code to complete")});var Ue=(j=>(j.AI_EXTRACT="AI_EXTRACT",j.AI_ASSERTION="AI_ASSERTION",j.AUTH_LOAD="AUTH_LOAD",j.AUTH_SAVE="AUTH_SAVE",j.BLUR="BLUR",j.CAPTCHA="CAPTCHA",j.CLICK="CLICK",j.COOKIE="COOKIE",j.COPY="COPY",j.DIALOG="DIALOG",j.DRAG="DRAG",j.ELEMENT_CHECK="ELEMENT_CHECK",j.FILE_UPLOAD="FILE_UPLOAD",j.FOCUS="FOCUS",j.GO_BACK="GO_BACK",j.GO_FORWARD="GO_FORWARD",j.HOVER="HOVER",j.JAVASCRIPT="JAVASCRIPT",j.LOCAL_STORAGE="LOCAL_STORAGE",j.MOUSE_DRAG="MOUSE_DRAG",j.NAVIGATE="NAVIGATE",j.NEW_TAB="NEW_TAB",j.PAGE_CHECK="PAGE_CHECK",j.PASTE="PASTE",j.PRESS="PRESS",j.KEY_DOWN="KEY_DOWN",j.KEY_UP="KEY_UP",j.REFRESH="REFRESH",j.REQUEST="REQUEST",j.GRAPHQL_REQUEST="GRAPHQL_REQUEST",j.SCROLL_DOWN="SCROLL_DOWN",j.SCROLL_UP="SCROLL_UP",j.SCROLL_LEFT="SCROLL_LEFT",j.SCROLL_RIGHT="SCROLL_RIGHT",j.SELECT_OPTION="SELECT_OPTION",j.SWITCH_TAB="TAB",j.TYPE="TYPE",j.VISUAL_DIFF="VISUAL_DIFF",j.WAIT="WAIT",j.WAIT_FOR_URL="WAIT_FOR_URL",j.REGISTER_REQUEST_LISTENER="REGISTER_REQUEST_LISTENER",j.AWAIT_LISTENER="AWAIT_LISTENER",j.RECORD_REQUESTS="RECORD_REQUESTS",j.GET_RECORDED_REQUESTS="GET_RECORDED_REQUESTS",j.SET_HEADER="SET_HEADER",j.SUCCESS="SUCCESS",j))(Ue||{});Ce(v);var Y=v.object({thoughts:v.string().optional(),id:v.string().uuid().describe("unique identifier to this step, used for step cache")}),qt=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"}),Cn=v.object({target:Ir}).optional().openapi({ref:"SingleTargetCache"}),Qa=v.object({loadTimeout:v.number().int().max(60).optional().describe("Max seconds for the page to load")}),lx=Y.merge(Qa).merge(v.object({type:v.literal("NAVIGATE"),url:v.string()})).openapi({ref:"NavigateCommand"}),es=qt.merge(v.object({cache:Cn})),xo=Y.merge(es.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_UP"),deltaY:v.number().optional()}))).openapi({ref:"ScrollUpCommand"}),To=Y.merge(es.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_DOWN"),deltaY:v.number().optional()}))).openapi({ref:"ScrollDownCommand"}),Co=Y.merge(es.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_LEFT"),deltaX:v.number().optional()}))).openapi({ref:"ScrollLeftCommand"}),Ro=Y.merge(es.merge(v.object({target:pt.optional(),type:v.literal("SCROLL_RIGHT"),deltaX:v.number().optional()}))).openapi({ref:"ScrollRightCommand"}),aD=v.discriminatedUnion("type",[xo,To,Co,Ro]).openapi({ref:"AllScrollCommands"}),cx=Y.merge(v.object({type:v.literal("DIALOG"),action:v.union([v.literal("ACCEPT"),v.literal("DISMISS")])})).openapi({ref:"DialogCommand"}),dx=Y.merge(v.object({type:v.literal("WAIT"),delay:v.number()})).openapi({ref:"WaitCommand"}),px=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()})]),ux=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")}),mx=Y.extend({type:v.literal("WAIT_FOR_URL"),matcher:px}).merge(ux).openapi({ref:"WaitUrlCommand"}),hx=Y.merge(Qa).merge(v.object({type:v.literal("REFRESH")})).openapi({ref:"RefreshCommand"}),gx=Y.merge(v.object({type:v.literal("GO_BACK")})).openapi({ref:"GoBackCommand"}),fx=Y.merge(v.object({type:v.literal("GO_FORWARD")})).openapi({ref:"GoForwardCommand"}),Sx=Y.extend({type:v.literal("AUTH_SAVE")}).openapi({ref:"AuthSaveCommand"}),yx=Y.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"}),Cc=Y.merge(qt).extend({type:v.literal("CAPTCHA")}).openapi({ref:"CaptchaCommand"}),bx=Y.extend({type:v.literal("COPY"),value:v.string()}).openapi({ref:"CopyCommand"}),wx=Y.extend({type:v.literal("PASTE")}).openapi({ref:"PasteCommand"}),vx=Y.merge(Za).extend({type:v.literal("JAVASCRIPT")}).openapi({ref:"JavaScriptCommand"}),Fi=Y.merge(qt).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:Cn,relativePosition:v.object({x:v.number(),y:v.number()}).optional()}).openapi({ref:"ClickCommand"}),Ui=Y.merge(qt).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"}),Bi=Y.merge(qt).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:Cn})).openapi({ref:"MouseDragCommand"}),zi=Y.merge(qt).merge(v.object({type:v.literal("HOVER"),target:pt,cache:Cn})).openapi({ref:"HoverCommand"}),Hi=Y.merge(qt).merge(v.object({type:v.literal("FOCUS"),target:pt,cache:Cn})).openapi({ref:"FocusCommand"}),ji=Y.merge(qt).extend({type:v.literal("BLUR"),target:pt.optional(),cache:Cn}).openapi({ref:"BlurCommand"}),Ex=v.object({type:v.literal("URL"),url:v.string()}).describe("Accessible link to the file, either public http or local file://").openapi({ref:"UrlSource"}),xx=v.object({type:v.literal("USER_FILE"),name:v.string()}).describe("Accessible link to the file, references the google cloud file").openapi({ref:"UploadedFileSource"}),Tx=Y.extend({type:v.literal("FILE_UPLOAD"),fileSource:v.discriminatedUnion("type",[Ex,xx]),filename:v.string().optional()}).openapi({ref:"FileUploadCommand"}),Cx=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()})]),$i=Y.merge(qt).extend({type:v.literal("SELECT_OPTION"),target:pt,cache:Cn,choice:Cx.describe("new field for selecting options, optional for backcompat")}).openapi({ref:"SelectOptionCommand"}),Rc=v.union([v.literal("MULTIMODAL"),v.literal("VISION_ONLY")]),ts=Y.merge(v.object({type:v.literal("AI_ASSERTION"),assertion:v.string(),disableCache:v.boolean().optional(),iframeUrl:v.string().optional(),contextChoice:Rc.optional(),timeout:v.number().int().optional().describe("Max seconds to wait for assertion to be true"),cache:rm.optional()})).openapi({ref:"AIAssertionCommand"}),Rn=5,Ac=600,Gi=Y.merge(qt).extend({type:v.literal("ELEMENT_CHECK"),target:pt,assertion:im,cache:Cn,timeout:v.number().int().min(0).max(Ac).optional().describe("max seconds to wait for the assertion to be true")}).openapi({ref:"ElementAssertionCommand"}),Rx=Y.extend({type:v.literal("PAGE_CHECK"),assertion:am,iframeUrl:v.string().optional().describe("url or url regex for the iframe"),timeout:v.number().int().min(0).max(Ac).optional().describe("max seconds to wait for the assertion to be true")}).openapi({ref:"PageAssertionCommand"}),Ax=Y.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"}),Ix=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()}),lm=25,Wi=Y.merge(qt).merge(Ix).extend({type:v.literal("TYPE"),target:pt.optional(),value:v.string(),cache:Cn}).openapi({ref:"TypeCommand"}),Px=Y.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"}),Lx=Y.merge(v.object({type:v.literal("KEY_DOWN"),value:v.string(),convertMeta:v.boolean().optional()})).openapi({ref:"KeyDownCommand"}),Ox=Y.merge(v.object({type:v.literal("KEY_UP"),value:v.string(),convertMeta:v.boolean().optional()})).openapi({ref:"KeyUpCommand"}),Nx=v.object({type:v.literal("SUBSTRING"),substring:v.string()}),Mx=v.object({type:v.literal("REGEX"),pattern:v.string()}),kx=v.object({type:v.literal("INDEX"),index:v.coerce.string()}),_x=v.discriminatedUnion("type",[Nx,Mx,kx]),Dx=Y.merge(Qa).merge(v.object({type:v.literal("TAB"),action:_x})).openapi({ref:"TabCommand"}),Fx=Y.merge(Qa).merge(v.object({type:v.literal("NEW_TAB"),url:v.string()})).openapi({ref:"NewTabCommand"}),Ux=Y.merge(v.object({type:v.literal("COOKIE"),value:v.string()})).openapi({ref:"CookieCommand"}),Bx=Y.merge(v.object({type:v.literal("LOCAL_STORAGE"),key:v.string(),value:v.string()})).openapi({ref:"LocalStorageCommand"}),zx=Y.extend({type:v.literal("REQUEST")}).merge(Xa).openapi({ref:"RequestCommand"}),Hx=Y.extend({type:v.literal("GRAPHQL_REQUEST")}).merge(sm).openapi({ref:"GraphQLRequestCommand"}),jx=Y.merge(v.object({type:v.literal("SUCCESS"),condition:ts.optional()})).openapi({ref:"SuccessCommand"}),$x=Y.merge(v.object({type:v.literal("FAILURE")})).openapi({ref:"FailureCommand"}),Gx=v.object({data:v.string().describe("location at which to find a jpg"),width:v.number(),height:v.number()}),Vi=Y.merge(qt).merge(v.object({type:v.literal("VISUAL_DIFF"),threshold:v.number().optional().describe("default 0.1"),target:pt.optional(),screenshot:Gx.optional(),cache:Cn})).openapi({ref:"VisualDiffCommand"}),Wx=Y.merge(v.object({type:v.literal("REGISTER_REQUEST_LISTENER"),pattern:v.string(),key:v.string()})).openapi({ref:"RegisterRequestListenerCommand"}),Vx=Y.merge(v.object({type:v.literal("AWAIT_LISTENER"),key:v.string(),timeout:v.number().optional().describe("timeout")})).openapi({ref:"WaitForListenerCommand"}),qx=Y.merge(v.object({type:v.literal("RECORD_REQUESTS"),pattern:v.string(),key:v.string()})).openapi({ref:"RecordRequestsCommand"}),Kx=Y.merge(v.object({type:v.literal("GET_RECORDED_REQUESTS"),key:v.string()})).openapi({ref:"GetRecordedRequestsCommand"}),Yx=Y.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"}),cm=v.discriminatedUnion("type",[Fi,Wi,Px,Lx,Ox,$i,lx,To,xo,ts,zi,dx,jx]),Jx=v.discriminatedUnion("type",[Ax,yx,Sx,Cc,Ux,bx,cx,Ui,Gi,Tx,gx,fx,vx,Bx,Bi,Fx,Rx,wx,hx,zx,Hx,Co,Ro,Dx,Vi,Hi,ji,mx,Wx,Vx,qx,Kx,Yx]),Ao=v.discriminatedUnion("type",[...cm.options,...Jx.options]).openapi({ref:"Command"}),ns=v.discriminatedUnion("type",[...cm.options,$x]);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:we(),type:n};break;case"AUTH_LOAD":{e={id:we(),type:n,storageState:""};break}case"AI_EXTRACT":e={id:we(),type:n,goal:""};break;case"DIALOG":e={id:we(),type:n,action:"DISMISS"};break;case"DRAG":e={id:we(),type:n,fromTarget:{type:"description",elementDescriptor:""},toTarget:{type:"description",elementDescriptor:""}};break;case"MOUSE_DRAG":e={id:we(),type:n,deltaX:"0",deltaY:"0",steps:1};break;case"WAIT_FOR_URL":e={id:we(),type:n,matcher:{type:"SUBSTRING",url:""}};break;case"WAIT":e={id:we(),type:n,delay:1};break;case"BLUR":e={id:we(),type:n};break;case"HOVER":case"FOCUS":case"CLICK":e={id:we(),type:n,target:{type:"description",elementDescriptor:""}};break;case"COOKIE":case"PRESS":case"COPY":case"TYPE":e={id:we(),type:n,value:"",clearContent:!0};break;case"KEY_DOWN":case"KEY_UP":e={id:we(),type:n,value:""};break;case"SELECT_OPTION":e={id:we(),type:n,target:{type:"description",elementDescriptor:""},choice:{type:"VALUE",value:""}};break;case"NAVIGATE":case"NEW_TAB":return{id:we(),type:n,url:""};case"TAB":e={id:we(),type:n,action:{type:"SUBSTRING",substring:""}};break;case"REQUEST":e={id:we(),type:n,url:"",method:"GET"};break;case"GRAPHQL_REQUEST":e={id:we(),type:n,url:"",query:""};break;case"LOCAL_STORAGE":e={id:we(),type:n,key:"",value:""};break;case"JAVASCRIPT":e={id:we(),type:n,code:""};break;case"AI_ASSERTION":e={id:we(),type:n,assertion:""};break;case"FILE_UPLOAD":{e={id:we(),type:n,fileSource:{type:"URL",url:""}};break}case"ELEMENT_CHECK":{e={id:we(),type:n,target:{type:"description",elementDescriptor:""},assertion:{type:"ELEMENT_EXISTENCE",condition:"EXISTS"}};break}case"PAGE_CHECK":{e={id:we(),type:n,assertion:{type:"CONTENT",value:""}};break}case"REGISTER_REQUEST_LISTENER":{e={id:we(),type:n,pattern:"",key:""};break}case"AWAIT_LISTENER":{e={id:we(),type:n,key:""};break}case"RECORD_REQUESTS":{e={id:we(),type:n,pattern:"",key:""};break}case"GET_RECORDED_REQUESTS":{e={id:we(),type:n,key:""};break}case"SET_HEADER":{e={id:we(),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 dm(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 Xx}from"zod";var pD=Xx.discriminatedUnion("type",[ji,Cc,Fi,Ui,Hi,zi,Bi,xo,To,Co,Ro,$i,Wi,Vi,Gi]);function pm(n){return["AI_ASSERTION","ELEMENT_CHECK","PAGE_CHECK"].includes(n)}import{z as Zx}from"zod";var wt={type:!0,cache:!0},Pr=Zx.discriminatedUnion("type",[ts.pick(wt),ji.pick(wt),Fi.pick(wt),Ui.pick(wt),Gi.pick(wt),Hi.pick(wt),zi.pick(wt),Bi.pick(wt),xo.pick(wt),To.pick(wt),Co.pick(wt),Ro.pick(wt),$i.pick(wt),Wi.pick(wt),Vi.pick(wt)]),Ic=Object.values(Ue).filter(n=>Pr.options.some(e=>e.shape.type.safeParse(n).success));Ao.options.forEach(n=>{if("target"in n.shape&&!Ic.includes(n.shape.type.value))throw new Error(`Command ${n.shape.type.value} has a target but no cache`)});import{z as Lc}from"zod";import{z as Pc}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(Pc);var Pt=It.extend({type:Pc.literal("PRESET_ACTION"),command:Ao,skipped:Pc.boolean().optional()}).openapi({ref:"PresetAction"});Ce(Lc);var Lr=It.extend({type:Lc.literal("AI_ACTION"),text:Lc.string(),steps:Pt.array().optional()}).openapi({ref:"AIAction"});import{z as ce}from"zod";var Qx=ce.object({cacheKey:ce.string(),cacheExpiryMs:ce.number()}),Oc=It.extend({id:ce.string().uuid().describe("ID of the module step itself. Used to 'namespace' step cache entries."),inputs:ce.record(ce.string()).optional(),cacheConfig:Qx.optional()}),zn=Oc.extend({type:ce.literal("MODULE"),moduleId:ce.string().uuid()}),eT=ce.union([zn.pick({type:!0,moduleId:!0}),ce.record(ce.unknown())]),tT=ce.object({type:ce.literal("URL_REGEX"),regex:ce.string()}),nT=ce.object({type:ce.literal("PAGE_CHECK"),substring:ce.string()}),Nc=ce.object({cacheInvalidation:ce.discriminatedUnion("type",[nT,tT]).optional()}),Lt=ce.object({moduleId:ce.string().uuid(),name:ce.string(),description:ce.string().nullish(),enabled:ce.boolean().nullish(),parameters:ce.string().array().nullish(),defaultParameters:ce.record(ce.string(),ce.string()).nullish(),defaultCacheKey:ce.string().nullish(),defaultCacheTtl:ce.number().nullish(),defaultCacheAllInvocations:ce.boolean().nullish(),autoAuth:ce.boolean().nullish(),advanced:Nc.nullish()});import{z as at}from"zod";import{z as Mc}from"zod";Ce(Mc);var Po=It.extend({type:Mc.literal("AI_ACTION_DYNAMIC"),text:Mc.string()}).openapi({ref:"AIActionDynamic"});import{z as um}from"zod";var kc=It.extend({type:um.literal("CONDITIONAL"),skipped:um.boolean().optional()});import{z as rs}from"zod";var rT=rs.object({type:rs.literal("url"),url:rs.string()}),qi=It.extend({type:rs.literal("IFRAME"),identifier:rT});import{z as Kt}from"zod";var _c=(r=>(r.ALWAYS="ALWAYS",r.ON_FAILURE="ON_FAILURE",r.ON_ACTION_FAILURE="ON_ACTION_FAILURE",r))(_c||{});var oT=Kt.discriminatedUnion("type",[Kt.object({type:Kt.literal("NAVIGATE_URL"),url:Kt.string().url()}),Kt.object({type:Kt.literal("GO_TO_SECTION_START")})]),iT=Kt.object({trigger:Kt.nativeEnum(_c).optional(),attempts:Kt.number().int().optional(),restartBehavior:oT}),Ki=It.extend({type:Kt.literal("SECTION"),description:Kt.string().describe("user provided goal of what the section should accomplish"),plan:Kt.string().array().optional(),autohealingConfig:iT.optional()});var mm=Lt.merge(Oc).extend({type:at.literal("RESOLVED_MODULE"),steps:at.lazy(()=>Pe.array())}),Dc=Lt.extend({steps:at.lazy(()=>Pe.array())}),Fc=qi.extend({steps:at.lazy(()=>Ee.array())}),aT=qi.extend({steps:at.lazy(()=>Pe.array())}),Uc=Ki.extend({steps:at.lazy(()=>Ee.array())}),sT=Ki.extend({steps:at.lazy(()=>Pe.array())}),Or=kc.extend({blocks:at.object({assertion:at.lazy(()=>Pt),steps:at.lazy(()=>Ee.array())}).array(),elseSteps:at.lazy(()=>Ee.array().optional())}),lT=kc.extend({blocks:at.object({assertion:at.lazy(()=>Pt),steps:at.lazy(()=>Pe.array())}).array(),elseSteps:at.lazy(()=>Pe.array().optional())}),Ee=at.discriminatedUnion("type",[Pt,Lr,Po,zn,Or,Fc,Uc]),Pe=at.discriminatedUnion("type",[Pt,Lr,Po,mm,lT,aT,sT]);import{z as Yt}from"zod";var cT=Yt.object({steps:Ee.array(),beforeSteps:Ee.array().nullish(),afterSteps:Ee.array().nullish()}),Lo=Yt.object({steps:Pe.array(),beforeSteps:Pe.array().nullish(),afterSteps:Pe.array().nullish()}),Nr=Yt.object({steps:Yt.record(Yt.string(),Yt.unknown()).array(),beforeSteps:Yt.record(Yt.string(),Yt.unknown()).array().nullish(),afterSteps:Yt.record(Yt.string(),Yt.unknown()).array().nullish()});var De="1.0.20";import{z as ar}from"zod";var Bc=ar.object({key:ar.string(),testId:ar.string().optional(),moduleId:ar.string().optional(),organizationId:ar.string(),value:Pr}),dT=Bc.extend({uniqueKey:ar.string()}),hm=ar.record(ar.string(),dT);var gm=D.object({phrase:D.string()}),zc=D.object({thoughts:D.string().optional(),result:D.union([D.literal("NOT_FOUND"),D.string(),D.number(),D.array(D.unknown()),D.record(D.unknown(),D.unknown()),D.unknown()])}),p0=D.object({text:D.string()}),fm=D.object({thoughts:D.string(),review:D.string().optional(),id:D.number().int(),updatedMemory:wc.optional()}),os=(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))(os||{});var Sm=D.object({thoughts:D.string(),category:D.nativeEnum(os)}),pT=D.discriminatedUnion("op",[D.object({op:D.literal("replace"),path:D.string(),value:D.string()}),D.object({op:D.literal("add"),path:D.string(),value:D.string()}),D.object({op:D.literal("remove"),path:D.string()})]),u0=D.object({thoughts:D.string(),patches:pT.array()}),ym=[D.literal("add"),D.literal("replace"),D.literal("remove")],uT=D.object({op:D.union(ym),path:D.string(),value:Pe.optional()}),bm=D.object({patches:uT.array(),thoughts:D.string()});var mT=D.object({thoughts:D.string(),op:D.union(ym),value:D.union([D.null(),Pe])}),wm=D.object({reasoning:D.string(),scenario:D.string(),patch:mT.or(D.null())}),m0=D.object({thoughts:D.string(),evaluation:D.number().min(1).max(10)}),h0=D.object({observations:D.string(),reasoning:D.string(),command:ns});var Hc=D.object({summary:D.string(),reasoning:D.string(),evaluation:D.discriminatedUnion("type",[D.object({type:D.literal("DONE")}),D.object({type:D.literal("RIGHT_TRACK")}),D.object({type:D.literal("WRONG_TRACK"),feedback:D.string()}),D.object({type:D.literal("IMPOSSIBLE")})])});import{z as N}from"zod";import*as Q from"zod";var w0=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")}),is=Q.union([Q.literal("ELEMENT_CHECK"),Q.literal("NEGATED_CHECK"),Q.literal("NEGATED_ELEMENT_VISIBLE_CHECK"),Q.literal("SELECT_OPTION"),Q.literal("TYPE")]);function Mr(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 Yi=(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))(Yi||{}),Oo=Q.object({matched:Q.boolean(),reason:Q.string().optional().describe("Human understandable description"),logs:Q.string().array().optional().describe("Logs for debugging")}),hT=Oo.extend({type:Q.literal("USER_SELECTOR")}),gT=Oo.extend({type:Q.literal("CSS_SELECTOR"),selectors:Q.string().array()}),fT=Oo.extend({type:Q.literal("HYBRID_SELECTOR")}),ST=Oo.extend({type:Q.literal("HTML_DISTANCE"),distance:Q.number().optional(),closestElement:Q.string().optional(),savedElement:Q.string().optional()}),yT=Oo.extend({type:Q.literal("TEMPLATE_MATCHING"),elementImageUrl:Q.string().url()}),bT=Oo.extend({type:Q.literal("AUTO_FRAME"),logs:Q.string().array().optional()}),vm=Q.discriminatedUnion("type",[hT,gT,fT,ST,yT,bT]);import{z as ta}from"zod";import{z as HC}from"zod";import*as X from"zod";import{cloneDeep as Zi}from"lodash-es";var wT=n=>{let e=Em(n,0);if(e===void 0||!ET(n[e]))return;let t=Em(n,e+1);if(t!==void 0)return xT(n,e,t)},xm=wT,Em=(n,e)=>{for(let t=e;t<n.length;t+=1){let r=n[t];if(!vT(r))return t}},vT=n=>n===" "||n===" "||n===`
|
|
5
|
+
`||n==="\r",ET=n=>n==="{"||n==="[",xT=(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 TT(r);if(r===void 0)r=i;else if(r[0]===i)r+=i;else return}},TT=n=>n===void 0?0:n[0]===" "?n.length:n;var Tm=(n,e)=>{let t=jc(n,"toPrecision",e,e);return t===void 0?jc(n,"toExponential",e,e):t},jc=(n,e,t,r)=>{let i=n[e](r).replace(CT,"$1").replace(RT,"$1");return i.length<=t?i:r===1?void 0:jc(n,e,t,r-1)},CT=/(e)\+/iu,RT=/\.?0*($|e)/iu;var Rm=(n,e)=>{if(typeof n!="string")throw new TypeError(`Input must be a JSON string: ${n}`);AT(e)},AT=n=>{if(IT(n),n<0)throw new TypeError(`"maxSize" argument must be positive: ${n}`);if(n<Cm)throw new TypeError(`"maxSize" argument must be at least ${Cm}: ${n}`)},IT=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}`)},Cm=7;var as=(n,e,t)=>{let r=Im(e,t);return Am(n,e,r)},Am=(n,e,t)=>{if(t>=e)return t;let r=n[t];return r>=FT&&r<=UT?Am(n,e,t+1):t},ss=(n,e,t)=>{if(t===void 0)return t;let r=Im(e,t);return PT(n,r)},PT=(n,e)=>LT(n,e)?e-3:OT(n,e)?e-2:NT(n,e)?e-1:e,LT=(n,e)=>e>=3&&n[e-3]>=MT&&n[e-3]<=kT,OT=(n,e)=>e>=2&&n[e-2]>=_T,NT=(n,e)=>e>=1&&n[e-1]>=DT,Im=(n,e)=>e<0||Object.is(e,-0)?Math.max(n+e,0):e,MT=240,kT=244,_T=224,DT=194,FT=128,UT=191;var Pm=(n,e,t)=>{let r=globalThis.Buffer.from(n),o=as(r,r.length,e),i=ss(r,r.length,t);return o===0&&i>=r.length?r.toString():r.toString("utf8",o,i)};var Lm=/[\uD800-\uDFFF]/gu,Om="\uFFFD";var ls=n=>BT(n)?n.replace(Lm,Om):n,BT=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 Wc=({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 Vc=(n,e,t)=>e<0||Object.is(e,-0)?WT(n,e,t):GT(n,e,t),GT=(n,e,t)=>Wc({input:n,targetByteCount:e,firstStartSurrogate:55296,lastStartSurrogate:56319,firstEndSurrogate:56320,lastEndSurrogate:57343,increment:1,canBacktrack:t,shift:0,charIndexInit:0}),WT=(n,e,t)=>Wc({input:n,targetByteCount:-e,firstStartSurrogate:56320,lastStartSurrogate:57343,firstEndSurrogate:55296,lastEndSurrogate:56319,increment:-1,canBacktrack:!t,shift:1,charIndexInit:n.length-1});var cs=(n,e,t)=>{let r=Vc(n,e,!1),o=VT(n,t),i=r===0&&o===void 0?n:n.slice(r,o);return ls(i)},VT=(n,e)=>{if(e===void 0)return e;let t=Vc(n,e,!0);return t===n.length?void 0:t};var Mm=(n,e,t)=>{let{textEncoder:r,textDecoder:o}=qT(),i=KT(n),{written:a}=r.encodeInto(n,i),s=as(i,a,e),l=ss(i,a,t),c=l===void 0?a:Math.min(l,a),d=i.subarray(s,c);return o.decode(d)},qT=()=>(qc===void 0&&(qc=new globalThis.TextEncoder,Nm=new globalThis.TextDecoder("utf8",{fatal:!1})),{textEncoder:qc,textDecoder:Nm}),qc,Nm,KT=n=>{let e=n.length*3;return e>YT?new Uint8Array(e):((ds===void 0||ds.length<e)&&(ds=new Uint8Array(e)),ds)},YT=1e5,ds;var km=(n,e)=>{if(e===void 0)return e;let t=Kc(n,e);return t>=n.length*_m?void 0:t},Kc=(n,e)=>e<=n.length*-_m?0:e,_m=4;var Dm=(n,e,t)=>{if(typeof n!="string")throw new TypeError(`First argument must be a string: ${n}`);JT(e),XT(t)},JT=n=>{if(n===void 0)throw new TypeError("Second argument is required.");Fm("Second",n)},XT=n=>{n!==void 0&&Fm("Third",n)},Fm=(n,e)=>{if(!Number.isInteger(e))throw new TypeError(`${n} argument must be an integer: ${e}`)};var Um=n=>{let e=!0,t=0;for(let r=0;r<Yc;r+=1){let o=ZT(n,r);o<=127||(e&&(e=!1),o>2047&&(t+=1))}return{asciiOnly:e,longCharsPercentage:t/Yc}},ZT=(n,e)=>{let t=Yc-1,r=1-(t-e)/t,o=Math.round(r*(n.length-1));return n.charCodeAt(o)},Yc=50;var QT=(n,e,t)=>{if(Dm(n,e,t),n==="")return n;let r=Kc(n,e),o=km(n,t);return o===void 0&&Object.is(r,0)?ls(n):eC(n,r,o)},Bm=QT,eC=(n,e,t)=>{if(n.length<=tC)return cs(n,e,t);let{asciiOnly:r,longCharsPercentage:o}=Um(n);return r?rC(n,e,t):o>=nC?cs(n,e,t):zm(n,e,t)},tC=200,nC=.4,rC=(n,e,t)=>"Buffer"in globalThis&&"from"in globalThis.Buffer?Pm(n,e,t):zm(n,e,t),zm=(n,e,t)=>"TextEncoder"in globalThis?Mm(n,e,t):cs(n,e,t);var jm=(n,e)=>{let t=JSON.stringify(n),r=aC(t),o=Bm(r,0,e-Hm.length-Ji.length*2),a=`${oC(o)}${Hm}`;return sC(a)},oC=n=>n.replace(iC,""),iC=/(\\|\\u[0-9a-fA-F]{0,3})$/u,aC=n=>n.slice(Ji.length,-Ji.length),sC=n=>`${Ji}${n}${Ji}`,Ji='"',Hm="...";var $m=n=>globalThis.Buffer.byteLength(n);var Jc=n=>{let e=n.length,t=e;for(let r=0;r<e;r+=1){let o=n.charCodeAt(r);if(o<=lC)continue;if(o<=cC){t+=1;continue}if(t+=2,o<dC||o>pC)continue;let i=n.charCodeAt(r+1);i<uC||i>mC||(r+=1)}return t},lC=127,cC=2047,dC=55296,pC=56319,uC=56320,mC=57343;var Gm=()=>hC.bind(void 0,new TextEncoder),hC=(n,e)=>{let t=gC(e);return n.encodeInto(e,t).written},gC=n=>{let e=n.length*3;return e>fC?new Uint8Array(e):((ps===void 0||ps.length<e)&&(ps=new Uint8Array(e)),ps)},fC=1e5,ps;var yC=()=>"Buffer"in globalThis&&"byteLength"in globalThis.Buffer?$m:"TextEncoder"in globalThis?bC.bind(void 0,Gm()):Jc,bC=(n,e)=>e.length<100?Jc(e):n(e),Wm=yC();var Vm=n=>{if(n===null)return wC;if(n===!0)return vC;if(n===!1)return EC;let e=typeof n;return e==="object"?xC:e==="number"?JSON.stringify(n).length:Xc(n)},wC=4,vC=4,EC=5,xC=2,Xc=n=>Wm(JSON.stringify(n));var us=({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}},Km=n=>Vm(n),Ym=(n,e,t)=>{let r=Xm({empty:n,indent:e,depth:t,keySpaceSize:0}),o=Zm(n);return r+o},Jm=({key:n,empty:e,indent:t,depth:r})=>{let o=Xm({empty:e,indent:t,depth:r,keySpaceSize:1}),i=Xc(n),a=Zm(e);return o+i+TC+a},TC=1,Xm=({empty:n,indent:e,depth:t,keySpaceSize:r})=>{if(e===void 0)return 0;let o=qm+e*(t+1),i=n?qm+e*t:0;return r+o+i},qm=1,Zm=n=>n?0:CC,CC=1;var ms=({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}=us({size:s,increment:r,maxSize:o,truncatedProps:e,path:u,value:p});return h?{empty:a,size:m,truncatedProps:g}:RC({value:p,truncatedProps:e,path:u,maxSize:o,empty:a,size:s,newSize:m,truncateValue:l,indent:c,depth:d})},RC=({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 Qm=({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=Ym(c.empty,a,s);c=ms({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 eh=({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=Jm({key:d,empty:c.empty,indent:a,depth:s});c=ms({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 hs=({value:n,truncatedProps:e,path:t,size:r,maxSize:o,indent:i,depth:a})=>{let s=Km(n),{size:l,stop:c,truncatedProps:d}=us({size:r,increment:s,maxSize:o,truncatedProps:e,path:t,value:n});return c?{value:void 0,size:l,truncatedProps:d}:AC({value:n,truncatedProps:d,path:t,size:l,maxSize:o,indent:i,depth:a})},AC=({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)?Qm({array:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:hs,indent:i,depth:a}):eh({object:n,truncatedProps:e,path:t,size:r,maxSize:o,truncateValue:hs,indent:i,depth:a});var IC=(n,e)=>{Rm(n,e);let t=PC(n),r=LC(n),{value:o,truncatedProps:i}=hs({value:r,truncatedProps:[],path:[],size:0,maxSize:e,indent:t,depth:0});return{jsonString:OC({newValue:o,value:r,maxSize:e,indent:t}),truncatedProps:i}},No=IC,PC=n=>{let e=xm(n);return typeof e=="string"?e.length:e},LC=n=>{try{return JSON.parse(n)}catch(e){throw new TypeError(`Invalid JSON string: "${n}"
|
|
7
|
+
${e.message}`)}},OC=({newValue:n,value:e,maxSize:t,indent:r})=>n!==void 0?JSON.stringify(n,void 0,r):typeof e=="number"?Tm(e,t):jm(e,t);import*as _r from"zod";import{z as pn}from"zod";import{z as vt}from"zod";var Zc=vt.object({autoFollowNewTabs:vt.boolean().optional().describe("Deprecated: Auto-follow new tabs that are opened."),showZeroOpacityElements:vt.boolean().optional(),ignoreHrefForCaching:vt.boolean().optional(),hybridSelectorMode:vt.enum(["test","prefer"]).optional()});var th=1e4,nh=6e4,kr=Zc.extend({pageLoadTimeoutMs:vt.number().optional().refine(n=>n===void 0||n<=nh&&n>=-1,{message:`Page load timeout must be between 0 and ${nh/1e3} seconds`}).describe("global page load timeout default for all tests in ms, can still be overridden by individual tests"),smartWaitingTimeoutMs:vt.number().optional().refine(n=>n===void 0||n<=th&&n>=-1,{message:`Smart waiting timeout must be between 0 and ${th/1e3} seconds`}),localChromeExtensionPaths:vt.string().array().optional(),extraHeaders:vt.record(vt.string(),vt.string()).optional().describe("HTTP headers to be sent on every request"),userAgent:vt.string().optional(),disableGpu:vt.boolean().optional(),bustCacheOnBoundingBoxChange:vt.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:vt.boolean().optional().describe("Allow fetching the partial accessibility tree if the full tree takes too long.")});var We="BASE_URL",gs="CURRENT_URL",Mo="ENV_NAME",Xi="TEST_NAME",OU={[We]:"https://www.google.com"},rh=pn.string().describe("Name of the fixture (must be available locally in the fixtures directory)."),oh=pn.object({name:pn.string(),variables:pn.record(pn.string().describe("variable name"),pn.string().describe("variable value"))}),ih=pn.object({name:pn.string(),variables:pn.record(pn.string().describe("variable name"),pn.unknown().describe("variable value")),browser:kr.optional()});Ce(_r);var Qi=_r.object({env:_r.record(_r.unknown())}).openapi({ref:"TestContextSnapshot"}),NC="\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022",MC=[We,Mo,Xi],ah=[gs,We,Mo,Xi],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[gs]??"about:blank",i=e.env[Mo],a=e.env[Xi],s={};for(let[c,d]of Object.entries(e.env))ah.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=Zi(e);this.env=Object.assign(this.env,t)}setInputs(e){e&&this.setEnvVariables(e)}setMomenticSystemVariable(e,t){this.varsFromMomenticEnvironment[e]=t}getVariable(e){return this.env[e]}setVariable(e,t){MC.includes(e)||(this.env[e]=t)}getEnvName(){return this.env[Mo]}toObjectCopy(){let e={env:Object.assign({},this.env,this.varsFromMomenticEnvironment)};return Zi(e)}toEditorDisplayCopy(){return this.toObjectCopy()}toRedactedDisplayCopy(){let e=this.toObjectCopy();e.env=Object.fromEntries(Object.entries(e.env).map(([r,o])=>ah.includes(r)||this.varsFromMomenticEnvironment[r]===void 0?[r,o]:[r,NC]));for(let[r,o]of Object.entries(e.env)){if(!o){e.env[r]=o;continue}let{jsonString:i}=No(JSON.stringify(o),1e3);try{e.env[r]=JSON.parse(i)}catch{e.env[r]=void 0}}let{jsonString:t}=No(JSON.stringify(e.env),5e3);try{e.env=JSON.parse(t)}catch{e.env={}}return e}setCurrentUrl(e){this.env[gs]=e}reset(e){this.env={},this.varsFromMomenticEnvironment={},this.setEnvVariables(e.dynamicVariables??{}),this.setCurrentUrl(e.currentUrl),this.varsFromMomenticEnvironment=Zi(e.variablesFromEnvironment),this.setMomenticSystemVariable(We,e.baseUrl),e.envName&&this.setMomenticSystemVariable(Mo,e.envName),e.testName&&this.setMomenticSystemVariable(Xi,e.testName)}getDynamicVariablesCopy(){return Zi(this.env)}getVariablesFromEnvironmentCopy(){return Zi(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 sh=["JobTimeoutError","UserConfigurationError","UserInfrastructureError"],fs={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."},Qc=Dr.object({reason:Dr.nativeEnum(de),summary:Dr.string()}).openapi({ref:"TestResultClassification"}),Ss=Dr.object({errorMessage:Dr.string(),errorStack:Dr.string().optional(),classification:Qc.optional()}).openapi({ref:"TestFailureDetails"});Ce(X);var Re=(i=>(i.SUCCESS="SUCCESS",i.FAILED="FAILED",i.RUNNING="RUNNING",i.IDLE="IDLE",i.CANCELLED="CANCELLED",i))(Re||{}),ed=(r=>(r.SUCCESS="SUCCESS",r.FAILED="FAILED",r.CANCELLED="CANCELLED",r))(ed||{}),td=X.object({beforeUrl:X.string().optional(),afterUrl:X.string().optional(),message:X.string().optional(),beforeScreenshot:X.string().optional(),afterScreenshot:X.string().optional(),beforeSnapshot:X.string().optional(),afterSnapshot:X.string().optional(),startedAt:X.coerce.date(),finishedAt:X.coerce.date()}),kC=td.extend({viewport:X.object({height:X.number(),width:X.number()}),status:X.nativeEnum(ed),message:X.string().optional(),elementInteracted:X.string().optional()}),sr=td.extend({status:X.nativeEnum(Re),message:X.string().optional(),data:X.unknown().optional(),beforeTestContext:Qi.optional(),afterTestContext:Qi.optional(),failureReason:X.nativeEnum(de).optional(),details:X.unknown().describe("Parse using StepExecutionLogSchema.array() to get type safety. We don't explicitly type it because it's non-critical information.")}).openapi({ref:"StepResultMetadata"}),ys=sr.merge(Pt).extend({results:kC.array(),proposedStep:Pt.optional()}),_C=sr.merge(Lr).extend({results:X.lazy(()=>ys.array())}),DC=sr.merge(Po).extend({results:X.lazy(()=>ys.array())}),FC=sr.merge(zn).extend({moduleName:X.string().optional(),results:X.lazy(()=>Nt.array())}),UC=sr.merge(Or).extend({assertion:ys.optional(),results:X.lazy(()=>Nt.array()).describe("results for the block actually executed")}),BC=sr.merge(qi).extend({results:X.lazy(()=>Nt.array())}),zC=sr.merge(Ki).extend({results:X.lazy(()=>Nt.array()),healingAttempts:X.lazy(()=>Nt.array().array()).optional()}),Nt=X.discriminatedUnion("type",[_C,DC,ys,FC,UC,BC,zC]),bs=sr.pick({startedAt:!0,finishedAt:!0,status:!0,message:!0,data:!0}),ws=td.extend({index:X.number().optional(),description:X.string(),pageState:X.string().optional()});var nd=HC.object({results:Nt.array().describe("main results"),beforeResults:Nt.array().optional(),afterResults:Nt.array().optional()}),vs=nd.partial();import{z as W}from"zod";import{z as Ae}from"zod";var jC=Ae.object({type:Ae.literal("FAILURE_RECOVERY"),thoughts:Ae.string()}),$C=Ae.object({type:Ae.literal("DESCRIPTION_UPDATE"),thoughts:Ae.string()}),Es=Ae.discriminatedUnion("type",[$C,jC]),xs=(e=>(e.AUTO_HEALING="AUTO_HEALING",e))(xs||{}),GC=Ae.object({testId:Ae.string(),name:Ae.string(),orgId:Ae.string(),runId:Ae.string(),purpose:Ae.nativeEnum(xs).catch("AUTO_HEALING"),steps:Pe.array(),details:Es.or(Es.array()).optional()}),rB=GC.pick({name:!0,orgId:!0}),rd=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()}),lh=rd.extend({steps:Pe.array()});import{isValidCron as WC}from"cron-validator";import{z as ne}from"zod";import{z as od}from"zod";var Hn=(r=>(r.CHROMIUM="Chromium",r.GOOGLE_CHROME="Google Chrome",r.CHROME_FOR_TESTING="Chrome for Testing",r))(Hn||{});var Ts=od.object({width:od.number().min(200).max(1e4),height:od.number().min(200).max(1e4)}),ch={"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}},aB=Object.keys(ch);var Jt=ch["Desktop Large"],_o="en-us",Do="America/Los_Angeles";var Fo={latitude:37.7749,longitude:-122.4194};var dh=["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 ph=2e3,Cs=kr.extend({browserType:ne.nativeEnum(Hn).optional(),slowMoMs:ne.number().optional().refine(n=>n===void 0||n<=ph&&n>=-1,{message:`Slow motion must be between 0 and ${ph} 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(dh).optional(),colorScheme:ne.enum(["light","dark"]).optional()}),uh=["extraHeaders","basicAuthorization","localChromeExtensionPaths"],VC=ne.object({disableAICaching:ne.boolean().optional(),useMemory:ne.boolean().optional(),failureRecovery:ne.boolean().optional().describe("undefined means inherit org settings")});var qC=ne.object({viewport:Ts.optional()}),Uo=qC.merge(VC).merge(Cs),Bo=ne.object({cron:ne.string().refine(n=>WC(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()}),zo=ne.object({onSuccess:ne.boolean().default(!1),failureMessage:ne.string().optional(),onFailure:ne.boolean().default(!0),successMessage:ne.string().optional()}),KC=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")}),Rs=KC.array(),YC=ne.object({name:ne.string(),value:ne.string()}),mh=YC.array(),As=ne.object({name:ne.string(),default:ne.boolean().optional(),fixtures:rh.array().optional()});Ce(W);var Xt={WEBHOOK:"WEBHOOK",CRON:"CRON",MANUAL:"MANUAL",CLI:"CLI"},oe=(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))(oe||{}),Is=(t=>(t.BEFORE_ALL="BEFORE_ALL",t.AFTER_ALL="AFTER_ALL",t))(Is||{});var Ve=W.string().pipe(W.coerce.date()).or(W.date()),ea=W.object({id:W.string(),runKey:W.string(),organizationId:W.string(),createdAt:Ve,createdBy:W.string(),flake:W.boolean().nullish(),scheduledAt:Ve.or(W.null()),startedAt:Ve.or(W.null()),updatedAt:Ve.nullish(),finishedAt:Ve.or(W.null()),resolvedBaseUrl:W.string().nullish(),environmentName:W.string().nullish(),labels:W.array(W.string()).optional(),cliVersion:W.string().nullish(),section:W.nativeEnum(Is).nullish(),status:W.nativeEnum(oe),trigger:W.nativeEnum(Xt),attempts:W.number(),runAttempts:W.array(W.object({id:W.string(),status:W.nativeEnum(oe),startedAt:Ve.or(W.null()),finishedAt:Ve.or(W.null())})).optional(),videos:W.array(W.string()).optional(),failureReason:W.nativeEnum(de).nullish(),failureDetails:Ss.nullish(),testFragments:W.array(rd).nullish(),localTestId:W.string().nullish(),testId:W.string().nullish(),testName:W.string().nullish(),test:W.object({name:W.string(),id:W.string()}).nullish().default(null),suiteId:W.string().nullish()}).openapi({ref:"RunMetadata"}),JC={id:!0,status:!0,testName:!0,localTestId:!0,testId:!0,test:{select:{name:!0,id:!0}},finishedAt:!0,failureReason:!0,failureDetails:!0},Ps=ea.pick({...JC,test:!0}),hh=ea.omit({failureReason:!0,failureDetails:!0,test:!0}),id=ea.extend({stepsSnapshot:W.array(W.record(W.unknown())).nullish(),resolvedInputs:W.record(W.string(),W.string()).nullish(),test:W.object({name:W.string(),id:W.string(),description:W.string().nullish(),baseUrl:W.string().nullish(),advanced:Uo.nullish()}).nullish()}).merge(nd),gh=n=>n.includes("PASSED")&&n.includes("FAILED");var XC=ta.object({id:ta.string().uuid(),startedAt:Ve.or(ta.null()),finishedAt:Ve.or(ta.null()),status:ta.nativeEnum(oe)}).merge(vs),IB=XC.array();var na=(o=>(o.JUNIT="junit",o.ALLURE="allure",o.ALLURE_JSON="allure-json",o.PLAYWRIGHT_JSON="playwright-json",o))(na||{});import{z as Ye}from"zod";var ZC=Ye.object({id:Ye.string(),status:Ye.nativeEnum(oe),trigger:Ye.nativeEnum(Xt),createdAt:Ve,startedAt:Ve.nullish(),finishedAt:Ve.nullish(),gitCommitSha:Ye.string().nullish(),gitCommitShaShort:Ye.string().nullish(),gitCommitTimestamp:Ve.nullish(),gitBranchName:Ye.string().nullish(),gitOriginUrl:Ye.string().nullish(),gitCommitMessage:Ye.string().nullish(),gitCommitAuthorName:Ye.string().nullish(),githubRepository:Ye.string().nullish(),gitlabProjectPath:Ye.string().nullish(),pipelineId:Ye.string().nullish(),cliVersion:Ye.string().nullish(),suite:Ye.object({id:Ye.string(),name:Ye.string()}).nullish(),runs:Ye.object({status:Ye.nativeEnum(oe)}).array()}).openapi({ref:"RunGroup"}),fh=ZC.pick({id:!0,createdAt:!0,startedAt:!0,finishedAt:!0,status:!0,trigger:!0,suite:!0}).extend({runs:Ps.array()});import{z as et}from"zod";var QC=et.object({type:et.literal("TARGETING"),name:et.string().optional().describe("Target name to disambiguate for steps with multiple targets"),elementLocationDecisions:vm.array(),pageState:et.string().optional(),targetSource:et.nativeEnum(or).optional(),targetUpdateTime:et.string().optional()}),eR=et.object({type:et.literal("AI_LOCATION"),matched:et.boolean(),pageState:et.string().optional(),ragUsed:et.boolean().optional(),thoughts:et.string().optional()}),tR=et.object({type:et.literal("ASSERTION"),relevantElementsSerialized:et.string().array().optional(),pageState:et.string().optional(),ragUsed:et.boolean().optional()}),Sh=et.discriminatedUnion("type",[QC,eR,tR]);function Ls(){return{details:[]}}import{z as Be}from"zod";var nR=Be.object({id:Be.string(),name:Be.string()}),jB=nR.merge(Be.object({createdAt:Ve,createdBy:Be.string(),schedule:Bo,notification:zo,environment:Be.object({name:Be.string()}).nullish(),beforeTests:Be.object({id:Be.string()}).array().nullish(),afterTests:Be.object({id:Be.string()}).array().nullish()})),yh=Be.object({id:Be.string().uuid(),orgId:Be.string(),createdAt:Ve,startedAt:Ve.or(Be.null()),finishedAt:Ve.or(Be.null()),status:Be.nativeEnum(oe),trigger:Be.nativeEnum(Xt),suite:Be.object({id:Be.string(),name:Be.string()}).nullish(),runs:ea.array()}),$B=yh.pick({id:!0,createdAt:!0,startedAt:!0,finishedAt:!0,status:!0,trigger:!0,suite:!0}),bh=yh.extend({runs:Ps.array()});import{z as Zt}from"zod";import{cloneDeep as qB}from"lodash-es";import{z as he}from"zod";var ZB=he.object({thoughts:he.string(),subGoals:he.object({instruction:he.string()}).array()}),QB=he.object({thoughts:he.string(),newPlanMarkdown:he.string()}),e1=he.object({thoughts:he.string(),correct:he.boolean(),failedActionIndex:he.number().optional()}),rR=he.object({type:he.literal("PLANNING"),beforePlan:he.string(),goalDecision:he.string(),thoughts:he.string()}),oR=he.object({type:he.literal("RUNNING"),stepDisplayName:he.string(),status:he.nativeEnum(Re),results:Nt.array()}),iR=he.object({type:he.literal("REVISING"),beforePlan:he.string(),afterPlan:he.string(),errString:he.string(),diffs:he.string(),thoughts:he.string()}),aR=he.object({type:he.literal("SYSTEM"),message:he.string()}),sR=he.discriminatedUnion("type",[rR,oR,iR,aR]),wh=sR.array();var i1=Zt.object({id:Zt.string(),scheduledAt:Zt.coerce.date().nullable(),startedAt:Zt.coerce.date().nullable(),finishedAt:Zt.coerce.date().nullable(),status:Zt.nativeEnum(oe),history:wh.nullable(),testPlan:Zt.object({id:Zt.string(),name:Zt.string()}).nullable(),test:Zt.object({id:Zt.string(),name:Zt.string()}).nullable()});import{z as Et}from"zod";var ad=Et.object({content:Et.string(),ids:Et.string().array(),tokenLength:Et.number()}),lR=Et.object({chunks:ad.array()}),E1=Et.object({ids:Et.string().array(),score:Et.number(),tokenLength:Et.number()}),x1=lR.extend({description:Et.string().describe("Input to pass to RAG engine"),tokenLimit:Et.number()}),vh=Et.object({ids:Et.number().array()}),Eh=Et.object({indices:Et.number().array()});var Qt=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()}),O1=Qt.extend({chunks:ad.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()}),cR=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:is.optional().catch(void 0),memory:N.discriminatedUnion("type",[_i,N.object({type:N.literal("RESOLVED_TRACES"),traces:N.unknown().array()})]).optional()}),Th=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()}),Ch=N.object({goal:N.string(),browserState:N.string(),screenshot:N.string().optional(),returnSchema:N.string().optional()}),Rh=N.object({goal:N.string(),browserState:N.string(),screenshot:N.string(),url:N.string(),contextChoice:Rc.optional(),memory:N.discriminatedUnion("type",[xc,N.object({type:N.literal("RESOLVED_TRACES"),traces:N.unknown().array()})]).optional()}),Ah=N.object({command:Ao}),sd=N.object({goal:N.string(),browserState:N.string(),startingScreenshot:N.string().optional(),screenshot:N.string(),url:N.string(),history:cR.array(),actionHint:N.string().optional(),lastError:N.string().optional()}),Ih=N.object({results:ws.array(),errorMessage:N.string(),errorStack:N.string().optional()}),Ph=N.object({results:ws.array(),goal:N.string(),errorMessage:N.string()}),Lh=N.object({failedResults:ws.array(),nextStepsSerialized:N.string().array(),currentUrl:N.string(),currentPageState:N.string(),currentScreenshot:N.string()}),N1=N.object({description:N.string(),type:N.union([N.literal("locator"),N.literal("assertion"),N.literal("ai-action")]),excerpt:N.string()});import{z as ra}from"zod";var _1=ra.object({goal:ra.string()}),Oh=ra.object({keywords:ra.array(ra.string())});import{z as ld}from"zod";var cd=(t=>(t.LOCATOR="locator",t.ASSERTION="assertion",t))(cd||{}),U1=ld.nativeEnum(cd),dR=ld.enum(["v1","v2"]),B1=dR.or(ld.string().describe("for people with special configurations"));var Nh=n=>!(!n.org_id||!n.user_id||!n.platform);import{z as Fr}from"zod";var Mh=Fr.object({id:Fr.string().uuid(),skipped:Fr.boolean().optional(),envKey:Fr.string().optional().describe("key in the environment to save the result of this step to")}),dd=Mh.merge(Xa).extend({type:Fr.literal("REQUEST")}),pd=Mh.merge(Za).extend({type:Fr.literal("JAVASCRIPT")}),ud=Fr.discriminatedUnion("type",[pd,dd]);import{z as en}from"zod";import{z as Ur}from"zod";var pR=/^[a-f0-9]{8}-[a-f0-9]{4}-[1-5][a-f0-9]{3}-[89ab][a-f0-9]{3}-[a-f0-9]{12}$/,Me=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 Os=Ur.string().min(1).max(255).superRefine((n,e)=>{try{Ho(n)}catch(t){return e.addIssue({code:Ur.ZodIssueCode.custom,message:t.message,fatal:!0}),Ur.NEVER}});function Ho(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(pR))throw new Error("Name cannot be a UUID. Please choose a different name.")}var Ns=Ur.preprocess(n=>n===null?"":n,Ur.union([Ur.string().url(),Ur.literal("")])).optional();var kh=en.object({id:en.string(),name:Os,description:en.string().optional().nullish(),baseUrl:Ns.nullish(),schemaVersion:en.string(),advanced:en.unknown().optional(),retries:en.number(),envs:en.array(As).nullish(),parameters:Rs.nullish()}),uR=en.object({createdAt:en.coerce.date(),updatedAt:en.coerce.date(),schedule:Bo.nullish(),notification:zo.nullish(),createdBy:en.string(),organizationId:en.string()}),mR=kh.merge(uR),lz=mR.extend({steps:ud.array()}),cz=kh.extend({steps:ud.array()});import{z as Mt}from"zod";var _h=Mt.object({startedAt:Mt.coerce.date(),finishedAt:Mt.coerce.date(),status:Mt.nativeEnum(Re),message:Mt.string().optional(),data:Mt.unknown().optional()}),gR=_h.merge(pd).extend({type:Mt.literal("JAVASCRIPT")}),fR=_h.merge(dd).extend({type:Mt.literal("REQUEST")}),SR=Mt.discriminatedUnion("type",[gR,fR]),Dh=Mt.object({startedAt:Mt.coerce.date(),finishedAt:Mt.coerce.date().nullish(),status:Mt.nativeEnum(oe),results:SR.array(),failureReason:Mt.string().nullish(),failureDetails:Ss.nullish()});import{z as kt}from"zod";var yR=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(oe),trigger:kt.nativeEnum(Xt),results:Dh.array().nullish(),apiTestName:kt.string().nullish(),apiTestPath:kt.string().nullish(),apiTestId:kt.string().nullish()}),yz=yR.pick({status:!0,startedAt:!0,finishedAt:!0});var oa=(t=>(t.TestRun="test-run",t.CreditsUsed="credits-used",t))(oa||{}),Fh=3;function bR(n){return n==="MODULE"||n==="IFRAME"||n==="CONDITIONAL"||n==="SECTION"||n==="RESOLVED_MODULE"}function ia(n){if(!bR(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 aa(n){switch(n.type){case"AI_EXTRACT":case"AI_ASSERTION":return Fh;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 jo=class{async reportBillableEvent(e,t,r){}async reportCreditsUsed(e,t,r,o){}};function md(n,e){return{...n,testId:e?.testId??"",testName:e?.testName??"",suiteId:e?.suiteId??"",suiteName:e?.suiteName??""}}import{parseString as wR,splitCookiesString as vR}from"set-cookie-parser";import{z as Se}from"zod";var hd=Se.object({name:Se.string(),value:Se.string(),url:Se.string().optional(),domain:Se.string().optional(),path:Se.string().optional(),expires:Se.number().default(Date.now()/1e3+60*60*24*365),httpOnly:Se.boolean().optional(),secure:Se.boolean().default(!0),sameSite:Se.union([Se.literal("Strict"),Se.literal("Lax"),Se.literal("None")]).default("None")});function Ms(n,e){let t=[],r=vR(n);for(let o of r){let i=wR(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=hd.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 ER=Se.object({origin:Se.string(),localStorage:Se.array(Se.object({name:Se.string(),value:Se.string()}))}),xR=Se.object({entries:Se.record(Se.string(),Se.array(Se.tuple([Se.unknown(),Se.unknown()]))),version:Se.number().optional()}),ks=Se.object({cookies:hd.array().optional(),origins:ER.array().optional(),idb:Se.record(Se.string(),xR).optional().describe("key is db name")});function _s(n,e){let t=[];return n.cloneSync()?.serializeSync()?.cookies.forEach(r=>{let o=hd.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 zz=new Set(Object.values(Ue));var TR={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"},Hz={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:[]},jz={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 Wz,en as Vz}from"@faker-js/faker";import{z as V}from"zod";var Uh=55555,Jz=V.object({body:V.string(),to:V.string(),from:V.string()}),Xz=V.object({from:V.string().optional(),to:V.string(),timeout:V.number().optional(),beforeDate:V.string().pipe(V.coerce.date()).or(V.date()).optional(),afterDate:V.string().pipe(V.coerce.date()).or(V.date()).optional()}),Zz=V.object({to:V.string(),from:V.string(),subject:V.string(),body:V.string()}),Qz=V.object({inbox:V.string(),afterDate:V.string().pipe(V.coerce.date()).or(V.date()).optional(),timeout:V.number().optional(),trimWhitespace:V.boolean().optional()}),eH=V.object({inbox:V.string(),limit:V.number().optional(),afterDate:V.string().pipe(V.coerce.date()).or(V.date()).optional(),trimWhitespace:V.boolean().optional()});var Bh=V.object({result:V.unknown(),variableUpdates:V.record(V.string(),V.unknown()).optional(),persistentVariableUpdates:V.record(V.string(),V.unknown()).optional(),error:V.string().optional(),success:V.boolean()}),tH=V.object({id:V.string().optional(),orgId:V.string(),momenticLambdaAuthHash:V.string(),code:V.string(),fragment:V.boolean(),state:Qi,timeoutMs:V.number().optional()}),lr=15e3;import*as mt from"zod";Ce(mt);var CR=mt.object({url:mt.string(),lineNumber:mt.number(),columnNumber:mt.number()}).openapi({ref:"CodeLocation"}),Ds=mt.object({timestamp:mt.number(),text:mt.string(),type:mt.string(),tabIndex:mt.number(),args:mt.unknown().array().optional(),url:mt.string().optional(),location:CR.optional()}).openapi({ref:"ConsoleLog"}),zh=Ds.array(),RR=zh.array();import*as fd from"zod";import{z as I}from"zod";var AR=I.object({name:I.string(),version:I.string(),comment:I.string().optional()}),IR=I.object({name:I.string(),version:I.string(),comment:I.string().optional()}),PR=I.object({onContentLoad:I.number().optional(),onLoad:I.number().optional(),comment:I.string().optional()}),jh=I.object({startedDateTime:I.string(),id:I.string(),title:I.string().optional(),pageTimings:PR,comment:I.string().optional()}),LR=I.array(jh),OR=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()}),$h=I.array(OR),NR=I.object({name:I.string(),value:I.string(),comment:I.string().optional()}),Gh=I.array(NR),MR=I.object({name:I.string(),value:I.string(),comment:I.string().optional()}),kR=I.array(MR),_R=I.object({name:I.string(),value:I.string().optional(),fileName:I.string().optional(),contentType:I.string().optional(),comment:I.string().optional()}),DR=I.array(_R),FR=I.object({mimeType:I.string(),params:DR,text:I.string(),comment:I.string().optional()}),UR=I.object({method:I.string(),url:I.string(),httpVersion:I.string().optional(),cookies:$h,headers:Gh,queryString:kR,postData:FR.optional(),headersSize:I.number().optional(),bodySize:I.number().optional(),comment:I.string().optional()}),BR=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()}),zR=I.object({status:I.number(),statusText:I.string(),httpVersion:I.string().optional(),cookies:$h,headers:Gh,content:BR,redirectURL:I.string().optional(),headersSize:I.number().optional(),bodySize:I.number().optional(),comment:I.string().optional()}),Hh=I.object({expires:I.string().optional(),lastAccess:I.string(),eTag:I.string(),hitCount:I.number(),comment:I.string().optional()}),HR=I.object({beforeRequest:Hh.optional(),afterRequest:Hh.optional(),comment:I.string().optional()}),jR=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()}),Wh=I.object({pageref:I.string().optional(),startedDateTime:I.string(),time:I.number().optional(),request:UR,response:zR.optional(),cache:HR.optional(),timings:jR,serverIPAddress:I.string().optional(),connection:I.string().optional(),comment:I.string().optional(),_resourceType:I.string().optional()}),$R=I.array(Wh),GR=I.object({version:I.string().default("1.1"),creator:AR.optional(),browser:IR.optional(),pages:LR.optional(),entries:$R,comment:I.string().optional()}),WR=I.object({log:GR}),Vh=I.record(I.string(),jh),qh=I.record(I.string(),Wh);function gd(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(fd);var VR=fd.object({logsPerPage:Ds.array().array(),harPages:Vh.optional(),harEntries:qh.optional()}).openapi({ref:"DebugData"});var Br=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 Fs=class extends Error{constructor(e,t,r,o={}){super(`The ${r} with id ${t} is invalid: ${e}`,o),this.name="InvalidEntityError"}};function Kh(n){for(let e of Object.values(de))if(n.includes(e))return e}var A=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 Sd(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 $n=class extends Error{constructor(e,t={}){super(e,t),this.name="BoundingBoxMovedError"}};function la(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 zr=class extends Error{constructor(e,t={}){super(e,t),this.name="InsufficientCacheDataError"}};import{cloneDeep as VR}from"lodash-es";import{z as In}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 Xh=In.union([In.string(),In.number(),In.boolean(),In.null(),In.record(In.string(),In.lazy(()=>Xh)),In.array(In.lazy(()=>Xh))]),ca=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=VR(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")}},jH=new ca({},{});var yd={".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"},Zh=[".sh",".exe",".app",".bat",".cmd",".msi",".apk",".jar",".py",".js",".cron",".php",".asp"],GH=Object.keys(yd);import*as Qh from"zod";var VH=Qh.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 YH=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 Je}from"zod";var Et=Je.object({id:Je.string(),name:Os,baseUrl:Ms,description:Je.string().optional().nullish(),schemaVersion:Je.string(),advanced:Bo,retries:Je.number(),envs:Je.array(As).nullish(),parameters:Rs.nullish(),disabled:Je.boolean().optional(),labels:Je.array(Je.string()).optional().catch([])}),nj=Et.pick({name:!0,description:!0,baseUrl:!0,retries:!0,disabled:!0,advanced:!0,parameters:!0}),qR=Je.object({labels:Je.array(Je.string()).optional(),outputs:hh.nullish()}),tn=Et.merge(qR),KR=Je.object({createdAt:Je.coerce.date(),updatedAt:Je.coerce.date(),updatedBy:Je.string().nullable(),schedule:zo,notification:Ho,createdBy:Je.string(),organizationId:Je.string(),folderId:Je.string().nullable().optional()}),YR=Et.merge(KR),rj=YR.merge(Oo),Us=Et.merge(Oo),oj=Et.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()}),JR=P.array(eg.extend({id:P.string(),name:P.string(),description:P.string().optional(),labels:P.string().array().optional()})),XR=P.array(eg.extend({id:P.string(),name:P.string(),description:P.string().optional(),content:Dc})),uj=P.object({tests:JR,modules:XR,labels:P.string().array()}),mj=Us.merge(tn),tg=P.object({schemaVersion:P.string(),stepLists:Oo}),ng=tn.partial().merge(Et.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(jn).optional(),viewport:Ts.optional(),pathSegments:P.string().array().optional()}),hj=Us.merge(P.object({relativeFilePath:P.string().describe("relative to project root")})),og=P.object({name:P.string()}),gj=P.object({relativeFilePath:P.string()}),ig=P.object({name:P.string(),description:P.string(),enabled:P.boolean(),steps:P.lazy(()=>Pe.array()),testFilePath:P.string().describe("relative to the project root"),folderPath:P.string().optional().describe("user selected folder path")}),ag=P.object({description:P.string(),enabled:P.boolean()}).partial();var fj=P.array(ah),sg=P.object({defaultEnv:P.string().optional().describe("name of the default env, or undefined to unset")}),lg=P.object({configFilePath:P.string().describe("full path on disk")}),Sj=P.string().array(),yj=P.object({message:P.string(),newRelativeTestPath:P.string().optional()}),bd=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()}),cg=P.object({pathSegments:P.array(P.string())}),bj=P.object({absolutePath:P.string(),pathSegments:P.array(P.string()),contents:P.array(bd)}),dg=P.object({pathSegments:P.array(P.string())}),pg=P.object({pathSegments:P.array(P.string()),newPathSegments:P.array(P.string())}),ug=P.object({pathSegments:P.array(P.string()),recursive:P.boolean().optional()}),wj=P.object({success:P.boolean(),message:P.string(),pathSegments:P.array(P.string()).optional()});var Bs=["node_modules","dist","bin",".git",".npm",".next","out",".yarn","__pycache__","build",".env",".venv","venv","env","wheels"],mg=Bs.map(n=>`**/${n}/**`);import Pn from"chalk";var ZR=["app","version","env","namespace","host"];function ze(n){let e=n.bindings()??{},t={};for(let r of Object.keys(e)){let o=e[r];!ZR.includes(r)&&typeof o=="string"&&(t[r]=o)}return t}var wd=class n{minLogLevel;logBindings;constructor(e,t){this.minLogLevel=e,this.logBindings=t}logWithLevel(e,t,...r){if(e<this.minLogLevel)return;let o;Array.isArray(r[0])?(o=r[0],r=r.slice(1)):typeof r[0]=="object"&&!(r[0]instanceof Error)&&Object.entries(r[0]).length&&(o={...r[0],...this.logBindings},r=r.slice(1));let i=[];if(i.push(...r),console.log(t(...i)),o&&!Array.isArray(o)){let a=Object.entries(o);for(let[s,l]of a){let c=l;l instanceof Error?c=l.message:typeof l=="object"&&(c=JSON.stringify(l,void 0,2),c=c.split(`
|
|
10
|
+
`)}`}};function Yh(n){return n instanceof Error?n.message.includes("Timeout")&&n.message.includes("exceeded")&&n.message.includes("waiting for locator"):!1}function Sd(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 $n=class extends Error{constructor(e,t={}){super(e,t),this.name="BoundingBoxMovedError"}};function la(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 sa=class extends Error{constructor(e,t={}){super(e,t),this.name="InsufficientCacheDataError"}};import{cloneDeep as qR}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 Jh=An.union([An.string(),An.number(),An.boolean(),An.null(),An.record(An.string(),An.lazy(()=>Jh)),An.array(An.lazy(()=>Jh))]),ca=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=qR(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")}},$H=new ca({},{});var yd={".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"},Xh=[".sh",".exe",".app",".bat",".cmd",".msi",".apk",".jar",".py",".js",".cron",".php",".asp"],WH=Object.keys(yd);import*as Zh from"zod";var qH=Zh.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 JH=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 Je}from"zod";var xt=Je.object({id:Je.string(),name:Os,baseUrl:Ns,description:Je.string().optional().nullish(),schemaVersion:Je.string(),advanced:Uo,retries:Je.number(),envs:Je.array(As).nullish(),parameters:Rs.nullish(),disabled:Je.boolean().optional(),labels:Je.array(Je.string()).optional().catch([])}),rj=xt.pick({name:!0,description:!0,baseUrl:!0,retries:!0,disabled:!0,advanced:!0,parameters:!0}),KR=Je.object({labels:Je.array(Je.string()).optional(),outputs:mh.nullish()}),tn=xt.merge(KR),YR=Je.object({createdAt:Je.coerce.date(),updatedAt:Je.coerce.date(),updatedBy:Je.string().nullable(),schedule:Bo,notification:zo,createdBy:Je.string(),organizationId:Je.string(),folderId:Je.string().nullable().optional()}),JR=xt.merge(YR),oj=JR.merge(Lo),Us=xt.merge(Lo),ij=xt.merge(Nr);var Qh=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()}),XR=P.array(Qh.extend({id:P.string(),name:P.string(),description:P.string().optional(),labels:P.string().array().optional()})),ZR=P.array(Qh.extend({id:P.string(),name:P.string(),description:P.string().optional(),content:Dc})),mj=P.object({tests:XR,modules:ZR,labels:P.string().array()}),hj=Us.merge(tn),eg=P.object({schemaVersion:P.string(),stepLists:Lo}),tg=tn.partial().merge(xt.pick({id:!0})),ng=P.object({name:P.string(),description:P.string().optional(),baseUrl:P.string().url().optional(),environment:P.string().optional(),browserType:P.nativeEnum(Hn).optional(),viewport:Ts.optional(),pathSegments:P.string().array().optional()}),gj=Us.merge(P.object({relativeFilePath:P.string().describe("relative to project root")})),rg=P.object({name:P.string()}),fj=P.object({relativeFilePath:P.string()}),og=P.object({name:P.string(),description:P.string(),enabled:P.boolean(),steps:P.lazy(()=>Pe.array()),testFilePath:P.string().describe("relative to the project root"),folderPath:P.string().optional().describe("user selected folder path")}),ig=P.object({description:P.string(),enabled:P.boolean()}).partial();var Sj=P.array(ih),ag=P.object({defaultEnv:P.string().optional().describe("name of the default env, or undefined to unset")}),sg=P.object({configFilePath:P.string().describe("full path on disk")}),yj=P.string().array(),bj=P.object({message:P.string(),newRelativeTestPath:P.string().optional()}),bd=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()}),lg=P.object({pathSegments:P.array(P.string())}),wj=P.object({absolutePath:P.string(),pathSegments:P.array(P.string()),contents:P.array(bd)}),cg=P.object({pathSegments:P.array(P.string())}),dg=P.object({pathSegments:P.array(P.string()),newPathSegments:P.array(P.string())}),pg=P.object({pathSegments:P.array(P.string()),recursive:P.boolean().optional()}),vj=P.object({success:P.boolean(),message:P.string(),pathSegments:P.array(P.string()).optional()});var Bs=["node_modules","dist","bin",".git",".npm",".next","out",".yarn","__pycache__","build",".env",".venv","venv","env","wheels"],ug=Bs.map(n=>`**/${n}/**`);import In from"chalk";var QR=["app","version","env","namespace","host"];function ze(n){let e=n.bindings()??{},t={};for(let r of Object.keys(e)){let o=e[r];!QR.includes(r)&&typeof o=="string"&&(t[r]=o)}return t}var wd=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,Pn.reset,...e)}info(...e){this.logWithLevel(1,Pn.white,...e)}debug(...e){this.logWithLevel(0,Pn.dim,...e)}warn(...e){this.logWithLevel(2,Pn.yellow,...e)}error(...e){this.logWithLevel(3,Pn.red,...e)}success(...e){this.logWithLevel(4,Pn.green,...e)}dimmed(...e){this.logWithLevel(1,Pn.dim,...e)}underline(...e){this.logWithLevel(2,Pn.underline,...e)}bold(...e){this.logWithLevel(2,Pn.bold,...e)}grey(...e){this.logWithLevel(0,Pn.grey,...e)}child(e){return new n(this.minLogLevel,{...this.logBindings,...e})}flush(){}bindings(){return this.logBindings}},vd=class{debug(){}info(){}warn(){}error(){}success(){}dimmed(){}underline(){}bold(){}grey(){}child(){return this}flush(){}bindings(){return{}}},hg=new vd,b=new wd(1,{}),Hr={info:()=>{},error:()=>{},debug:()=>{},warn:()=>{},child:()=>Hr,flush:()=>{},bindings:()=>({})},zs={},jr=({logger:n,logKey:e,maxCount:t,intervalMs:r},o,i,...a)=>{let s=zs[e];s?clearTimeout(s.timer):(s={count:0,totalCount:0},zs[e]=s),s.totalCount++,s.count<t&&(s.count++,n.debug(o,i,...a)),s.timer=setTimeout(()=>{let l=zs[e];l?.totalCount!==l?.count&&n.debug({logKey:e,totalCount:l?.totalCount,count:l?.count},`Debug logs were rate-limited for ${e}`),delete zs[e]},r)};import{z as tt}from"zod";var gg=tt.object({id:tt.string(),createdAt:tt.coerce.date(),createdBy:tt.string(),organizationId:tt.string(),name:tt.string(),description:tt.string().nullish(),enabled:tt.boolean(),schemaVersion:tt.string().describe("Schema version for steps"),parameters:tt.string().array().nullish().describe("Parameter list"),defaultParameters:tt.record(tt.string(),tt.string()).nullish(),defaultCacheKey:tt.string().nullish(),defaultCacheTtl:tt.number().nullish(),defaultCacheAllInvocations:tt.boolean().nullish(),autoAuth:tt.boolean().nullish(),advanced:Mc.nullish()}),Nj=gg.extend({steps:tt.lazy(()=>xe.array())}),fg=5*60*1e3,xd=Lt.merge(gg.omit({id:!0,createdAt:!0,createdBy:!0,organizationId:!0,enabled:!0}));import{formatInTimeZone as Dj}from"date-fns-tz";import{z as He}from"zod";var Ed=He.object({failureRecovery:He.boolean().optional(),aiAction:He.boolean().optional(),stepLintSuggestions:He.boolean().optional(),agentConfig:He.record(He.string(),He.string()).optional()}),Sg=He.object({fakerConstantSeed:He.boolean().optional()}),zj=He.object({ai:Ed.optional(),githubAppInstallationId:He.number().nullish(),githubReleaseAppInstallationId:He.number().nullish(),gitlabAppAccessToken:He.string().nullish().optional(),gitlabAppBaseUrl:He.string().nullish().optional(),qaseAccessToken:He.string().nullish().optional(),browser:Zc.optional()}),Hj=He.object({globalOverrides:He.record(He.string()).optional(),agentConfig:He.record(He.string(),He.string()).optional()});import*as E from"zod";var yg="x-momentic-cli-version",bg="x-momentic-main-branch-name",wg="x-momentic-branch-name",vg="x-momentic-commit-timestamp",xg="x-momentic-last-commit-on-main",Eg="x-momentic-last-commit-on-main-timestamp",t$=E.object({error:E.boolean(),reason:E.string(),message:E.string()}),n$=Qt.merge(sd),Tg=ns,r$=Qt.merge(sd);var o$=Qt.merge(Ah).extend({useConsensus:E.boolean().optional(),attemptNumber:E.number().optional()}),Td=im,i$=Qt.merge(Ih),Cg=ym,a$=Qt.merge(Th),Rg=Sm,s$=Qt.merge(Ch),Ag=fm,l$=Qt.merge(Rh);var c$=E.object({testPaths:E.string().array().describe("can be either hyphenated, lowercase test names or UUIDs"),env:E.string().optional(),all:E.boolean().optional(),urlOverride:E.string().optional(),customHeaders:E.record(E.string(),E.string()).optional(),testInputMatrix:E.record(E.string(),E.string()).array().optional()}),Ig=E.object({queuedTests:E.unknown().array(),runIds:E.string().uuid().array(),runGroupId:E.string().optional()});var d$=E.string().array(),p$=E.union([E.object({paths:E.string().array().describe("run specific test paths (e.g. todo-test)"),all:E.boolean().describe("run all tests").optional()}),E.object({path:E.string().describe("deprecated; present for backcompat")})]),Pg=E.object({tests:E.record(E.string().describe("Test name"),E.string().describe("Test YAML")),modules:E.record(E.string().describe("Module name"),E.string().describe("Module YAML"))}),QR=E.object({test:E.string().describe("test YAML"),modules:E.record(E.string().describe("moduleId"),E.string().describe("module YAML"))}),u$=QR.array(),m$=E.object({testId:E.string(),schemaVersion:E.string()}).merge(Mr),h$=E.object({entries:E.array(Bc),testId:E.string()}),g$=E.object({testId:E.string(),uniqueKeys:E.string().array()}),f$=E.object({steps:E.array(E.record(E.unknown())),testId:E.string(),schemaVersion:E.string()}),Lg=gm,Og=E.object({trigger:E.nativeEnum(Xt),status:E.nativeEnum(oe),startedAt:E.coerce.date().optional(),gitCommitSha:E.string().optional(),gitCommitShaShort:E.string().optional(),gitCommitTimestamp:E.coerce.date().optional(),gitBranchName:E.string().optional(),gitOriginUrl:E.string().optional(),gitCommitMessage:E.string().optional(),gitCommitAuthorName:E.string().optional(),githubRepository:E.string().optional(),gitlabProjectPath:E.string().optional(),pipelineId:E.string().optional(),cliVersion:E.string().optional()}),S$=E.object({id:E.string()}),Mg=E.object({status:E.nativeEnum(oe),updatedAt:E.coerce.date().optional(),finishedAt:E.coerce.date().optional()}),Ng=E.object({stepsSnapshot:E.array(E.record(E.unknown())).optional(),runGroupId:E.string().optional(),testId:E.string(),testName:E.string(),resolvedBaseUrl:E.string().optional(),environmentName:E.string().optional(),labels:E.array(E.string()).optional(),cliVersion:E.string().optional(),trigger:E.nativeEnum(Xt),schemaVersion:E.string().optional(),section:E.nativeEnum(Is).optional()}),y$=E.object({id:E.string()}),eA=id.pick({id:!0,status:!0,testName:!0,testId:!0,test:!0,failureReason:!0,failureDetails:!0}),kg=eA.array(),_g=id.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(),b$=E.object({id:E.string()}),Dg=E.object({status:E.nativeEnum(oe),finishedAt:E.coerce.date().optional(),schemaVersion:E.string().optional().default("1.0.19"),results:E.record(E.string(),E.unknown()).array().optional(),beforeResults:E.record(E.string(),E.unknown()).array().optional(),afterResults:E.record(E.string(),E.unknown()).array().optional()}),w$=E.object({screenshot:E.string()}),Fg=E.object({key:E.string()}),Ug=E.object({orgId:E.string(),userId:E.string()}),Bg=E.array(ih),v$=E.record(E.string(),E.union([E.string(),E.boolean()])),x$=E.object({paths:E.string().array(),env:E.string().optional(),urlOverride:E.string().optional(),customHeaders:E.record(E.string(),E.string()).optional()}),zg=E.object({suiteRunIds:E.string().array(),runGroupIds:E.string().array()}),E$=E.object({suiteRunIds:E.string().array()}),T$=wh.array(),C$=E.object({runGroupIds:E.string().array()}),da=E.object({uploadUrl:E.string()}),R$=Qt.merge(Ph),A$=Qt.merge(Oh),I$=Qt.merge(Lh),tA=E.object({testId:E.string().optional().default(""),testName:E.string().optional().default(""),suiteId:E.string().optional().default(""),suiteName:E.string().optional().default(""),creditsUsed:E.number().optional(),usedBy:E.string().optional()}),nA=E.object({transactionId:E.string(),timestamp:E.string(),event:E.nativeEnum(ia),properties:tA}),P$=nA.array(),Hg=ch.omit({steps:!0}).extend({steps:E.array(E.record(E.string(),E.unknown())).describe("unparsed ResolvedStep[]")}),L$=E.object({limit:E.number().max(10).optional(),afterTime:E.number().optional()}),jg=gh.array(),O$=E.object({applied:E.boolean().optional(),appliedAt:E.coerce.date().optional()}),$g=da.extend({id:E.string()}),M$=E.object({runGroupId:E.string().uuid().optional()}),Gg=E.object({runGroupId:E.string().uuid()});import{z as Le}from"zod";var Wg=Le.object({orgId:Le.string(),cacheKeys:Le.string().array()}),_$=Le.object({keyParams:Wg,clientMetadata:Le.string(),lockAcquisitionTimeoutMs:Le.number().optional()}),Vg=Le.object({acquired:Le.boolean(),acquiredByMetadata:Le.string(),keyPrefix:Le.string()}),D$=Le.object({keyPrefix:Le.string(),result:Le.string(),ttlMs:Le.number()}),F$=Le.union([Le.object({keyPrefix:Le.string()}),Wg]),rA=Le.object({remainingTtlMs:Le.number(),value:Le.string().nullish()}),U$=Le.object({results:Le.record(Le.string(),rA),activeLocks:Le.string().array()}),qg=0,Kg=5*60*1e3;import{z as un}from"zod";var Yg="test",Jg="module",_t=(t=>(t.TEST=`${Yg}.yaml`,t.MODULE=`${Jg}.yaml`,t))(_t||{}),Ie=(t=>(t.TEST=`momentic/${Yg}`,t.MODULE=`momentic/${Jg}`,t))(Ie||{}),W$=Et.merge(Mr),Cd=Lt.extend({steps:un.array(un.record(un.string(),un.unknown())),schemaVersion:un.string()}),V$=Cd.extend({fileType:un.literal(Ie.MODULE)}),q$=un.object({test:un.string().describe("YAML for the test, including metadata and steps"),modules:un.record(un.string(),un.string()).describe("Map of module name to YAML for the module")});import{z as st}from"zod";var oA=st.object({version:st.string(),json:st.record(st.unknown()),hash:st.string()}),Xg=st.record(st.unknown()),X$=st.object({newSvgs:st.array(oA),metadata:Xg.optional()}),iA=st.object({version:st.string(),json:st.record(st.unknown()).nullish(),hash:st.string(),description:st.string().nullish(),metadata:Xg.nullish()}),Zg=st.record(st.string().describe("icon hash"),iA);import{validator as nG}from"@exodus/schemasafe";var Qg=n=>{n.extraHeaders&&(n.extraHeaders=Object.fromEntries(Object.entries(n.extraHeaders).filter(([e,t])=>e.trim()&&t.trim())))};import{z as hG}from"zod";import{z as Xe}from"zod";var SG=Xe.object({repositoriesIndexed:Xe.boolean(),indexingInProgress:Xe.boolean(),indexesOutdated:Xe.boolean()}),ef=(a=>(a.Queued="queued",a.InProgress="in_progress",a.Completed="completed",a.Waiting="waiting",a.Requested="requested",a.Pending="pending",a))(ef||{}),tf=(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))(tf||{}),yG=Xe.object({name:Xe.string(),status:Xe.nativeEnum(ef),conclusion:Xe.nativeEnum(tf).nullable()}),Rd=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 ke}from"zod";var Ad=ke.object({assertion:ke.string().describe("A human readable assertion that evaluates to either true or false depending on the state of the system.")}),aA=ke.object({instruction:ke.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:Ad.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.")}),nf=aA.extend({subSteps:ke.lazy(()=>nf.array().optional()).describe("More granular steps to be take to achieve the current step's higher level objective.")}),rf=ke.object({name:ke.string().describe("Short name describing the test plan"),description:ke.string().nullish().transform(n=>n??void 0).describe("Longer form description of the high level goal of the test plan")}),of=rf.extend({id:ke.string(),createdAt:ke.coerce.date(),updatedAt:ke.coerce.date(),updatedBy:ke.string(),createdBy:ke.string(),test:ke.object({id:ke.string(),name:ke.string()}).nullish().transform(n=>n??void 0)}),xG=of.extend({testGenRuns:ke.tuple([]).or(ke.tuple([ke.object({id:ke.string(),startedAt:ke.coerce.date(),status:ke.nativeEnum(oe)})]))}),af=ke.object({preConditions:Ad.array().nullish().transform(n=>n??[]),postConditions:Ad.array().nullish().transform(n=>n??[]),steps:nf.array().nullish().transform(n=>n??[])}),EG=of.extend({plan:af.nullish().transform(n=>n??{preConditions:[],postConditions:[],steps:[]})}),sA=rf.extend({plan:af.nullish().transform(n=>n??{preConditions:[],postConditions:[],steps:[]})}),TG=sA.array().nullish().transform(n=>n??[]);var PG=90*24*60*60*1e3,LG=14*24*60*60*1e3,OG=7*24*60*60*1e3;import{z as Oe}from"zod";var lA=Oe.object({step:Pe,status:Oe.nativeEnum(Re),startedAt:Oe.coerce.date(),finishedAt:Oe.coerce.date().optional(),healMetadata:Oe.object({healType:Oe.nativeEnum(Ji).or(Oe.literal("AI")),healedAt:Oe.coerce.date()}).optional(),beforeSnapshotId:Oe.string().uuid().optional(),afterSnapshotId:Oe.string().uuid().optional(),message:Oe.string().optional()}),UG=lA.extend({finishedAt:Oe.coerce.date().optional().transform(n=>n??new Date)}),cA=Oe.object({startedAt:Oe.coerce.date()}).merge(Dg).merge(vs),BG=cA.extend({finishedAt:Oe.coerce.date().optional().transform(n=>n??new Date)}),dA=_g.merge(Ng).extend({status:Oe.nativeEnum(oe),startedAt:Oe.coerce.date(),attempts:Oe.number()}),zG=dA.extend({finishedAt:Oe.coerce.date().optional().transform(n=>n??new Date)}),pA=Og.merge(Mg).extend({id:Oe.string().uuid().optional(),startedAt:Oe.coerce.date(),cliVersion:Oe.string()}),pa=pA.extend({updatedAt:Oe.coerce.date().optional().transform(n=>n??new Date),finishedAt:Oe.coerce.date().optional().transform(n=>n??new Date)});import uA from"semver";import{z as mA}from"zod";var GG=mA.string().refine(n=>uA.valid(n),{message:"must be a valid semver string"});function Id(n){let e={parentChain:[]};return Hs(n,e),e}function Hs(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||Hs({...n,steps:l.steps},e)&&i)return!0;if(Hs({...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),Hs({...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 sf(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!!hA([n],t,i).result}function hA(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 Id({steps:n,earlyStop:!0,onPresetAction:i,onConditional:i,onSimpleStepContainer:i}),{result:r,parentChain:o}}function lf(n,e){e(n);for(let t in n){let r=n[t];r&&(Array.isArray(r)?js(r,e):typeof r=="object"&&lf(r,e))}}function js(n,e){for(let t of n)t&&(Array.isArray(t)?js(t,e):typeof t=="object"&&lf(t,e))}import{cloneDeep as cf}from"lodash-es";import{v4 as Pd}from"uuid";async function Dt(n){let e=new Map,t=new Set,r=cf(n.stepLists.steps),o=await $r({...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=cf(n.stepLists[a]);if(!s)continue;let l=await $r({...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 $r({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?Pd():d.id,d.type){case"PRESET_ACTION":{let u=d.command;u.id=l?Pd():u.id,pf(u),"cache"in u&&u.cache&&(r&&(c.cachesToSave=c.cachesToSave.concat(df({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?Pd():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 $r({...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:xe.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 $r({...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 $r({...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 $r({...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 $r({...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 Go({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=fA(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}=Go({...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}=Go({...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(!Ic.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}=Go({...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}=Go({...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 uf(n,e){return e?`${e}:${n}`:n}function fA(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 df(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:uf(n.id,a),moduleId:i,organizationId:n.orgId,value:n.value})}return r.push({key:uf(n.id,e.join(":")),organizationId:n.orgId,value:n.value,testId:n.testId}),r}function pf(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 mf(n){let e=new Set;return js(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 hf(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 $s({logger:n,cacheStorage:e,orgId:t,testId:r,originalSteps:o,updatedSteps:i}){let a=gA(o,i);if(Object.keys(a).length>0){n.info({changes:a},"Updating steps caches post-run success");try{let{cachesToSave:s}=await Dt({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"},Ld={EXISTS:"exists",VISIBLE:"is visible",ENABLED:"is enabled",EDITABLE:"is editable"},Od={EXISTS:"does not exist",VISIBLE:"is not visible",ENABLED:"is disabled",EDITABLE:"is not editable"};function SA(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?Od[n.condition]:Ld[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 WV={CONTENT:"The page"};function yA(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 Md(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 bA(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 Gr(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=yA(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)} ${SA(n.assertion)}`;case"PAGE_CHECK":return`Check the page ${bA(n.assertion)}`;case"WAIT_FOR_URL":return`Wait for page URL to ${Md(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 gf(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 wA}from"lodash-es";import{cloneDeep as YV,unset as JV}from"lodash-es";function mn(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 Gr(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 ff=1e3,Sf=3e6,vA="[FAILED]";async function yf(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 Gs(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?Wr(p):mn(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=`${vA} ${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 yf(n,e,p.afterScreenshot,p.afterSnapshot),i&&(m.beforeScreenshot=await yf(n,e,p.beforeScreenshot,p.beforeSnapshot))),l.push(m)}return{results:l,failureIndex:c}}function Wr(n){let e=mn(n);switch(n.type){case"AI_ACTION":case"AI_ACTION_DYNAMIC":e+=`
|
|
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}},vd=class{debug(){}info(){}warn(){}error(){}success(){}dimmed(){}underline(){}bold(){}grey(){}child(){return this}flush(){}bindings(){return{}}},mg=new vd,b=new wd(1,{}),zr={info:()=>{},error:()=>{},debug:()=>{},warn:()=>{},child:()=>zr,flush:()=>{},bindings:()=>({})},zs={},Hr=({logger:n,logKey:e,maxCount:t,intervalMs:r},o,i,...a)=>{let s=zs[e];s?clearTimeout(s.timer):(s={count:0,totalCount:0},zs[e]=s),s.totalCount++,s.count<t&&(s.count++,n.debug(o,i,...a)),s.timer=setTimeout(()=>{let l=zs[e];l?.totalCount!==l?.count&&n.debug({logKey:e,totalCount:l?.totalCount,count:l?.count},`Debug logs were rate-limited for ${e}`),delete zs[e]},r)};import{z as tt}from"zod";var hg=tt.object({id:tt.string(),createdAt:tt.coerce.date(),createdBy:tt.string(),organizationId:tt.string(),name:tt.string(),description:tt.string().nullish(),enabled:tt.boolean(),schemaVersion:tt.string().describe("Schema version for steps"),parameters:tt.string().array().nullish().describe("Parameter list"),defaultParameters:tt.record(tt.string(),tt.string()).nullish(),defaultCacheKey:tt.string().nullish(),defaultCacheTtl:tt.number().nullish(),defaultCacheAllInvocations:tt.boolean().nullish(),autoAuth:tt.boolean().nullish(),advanced:Nc.nullish()}),kj=hg.extend({steps:tt.lazy(()=>Ee.array())}),gg=5*60*1e3,Ed=Lt.merge(hg.omit({id:!0,createdAt:!0,createdBy:!0,organizationId:!0,enabled:!0}));import{formatInTimeZone as Fj}from"date-fns-tz";import{z as He}from"zod";var xd=He.object({failureRecovery:He.boolean().optional(),aiAction:He.boolean().optional(),stepLintSuggestions:He.boolean().optional(),agentConfig:He.record(He.string(),He.string()).optional()}),fg=He.object({fakerConstantSeed:He.boolean().optional()}),Hj=He.object({ai:xd.optional(),githubAppInstallationId:He.number().nullish(),githubReleaseAppInstallationId:He.number().nullish(),gitlabAppAccessToken:He.string().nullish().optional(),gitlabAppBaseUrl:He.string().nullish().optional(),qaseAccessToken:He.string().nullish().optional(),browser:Zc.optional()}),jj=He.object({globalOverrides:He.record(He.string()).optional(),agentConfig:He.record(He.string(),He.string()).optional()});import*as x from"zod";var Sg="x-momentic-cli-version",yg="x-momentic-main-branch-name",bg="x-momentic-branch-name",wg="x-momentic-commit-timestamp",vg="x-momentic-last-commit-on-main",Eg="x-momentic-last-commit-on-main-timestamp",n$=x.object({error:x.boolean(),reason:x.string(),message:x.string()}),r$=Qt.merge(sd),xg=ns,o$=Qt.merge(sd);var i$=Qt.merge(Rh).extend({useConsensus:x.boolean().optional(),attemptNumber:x.number().optional()}),Td=om,a$=Qt.merge(Ah),Tg=Sm,s$=Qt.merge(xh),Cg=fm,l$=Qt.merge(Th),Rg=gm,c$=Qt.merge(Ch);var d$=x.object({testPaths:x.string().array().describe("can be either hyphenated, lowercase test names or UUIDs"),env:x.string().optional(),all:x.boolean().optional(),urlOverride:x.string().optional(),customHeaders:x.record(x.string(),x.string()).optional(),testInputMatrix:x.record(x.string(),x.string()).array().optional()}),Ag=x.object({queuedTests:x.unknown().array(),runIds:x.string().uuid().array(),runGroupId:x.string().optional()});var p$=x.string().array(),u$=x.union([x.object({paths:x.string().array().describe("run specific test paths (e.g. todo-test)"),all:x.boolean().describe("run all tests").optional()}),x.object({path:x.string().describe("deprecated; present for backcompat")})]),Ig=x.object({tests:x.record(x.string().describe("Test name"),x.string().describe("Test YAML")),modules:x.record(x.string().describe("Module name"),x.string().describe("Module YAML"))}),eA=x.object({test:x.string().describe("test YAML"),modules:x.record(x.string().describe("moduleId"),x.string().describe("module YAML"))}),m$=eA.array(),h$=x.object({testId:x.string(),schemaVersion:x.string()}).merge(Nr),g$=x.object({entries:x.array(Bc),testId:x.string()}),f$=x.object({testId:x.string(),uniqueKeys:x.string().array()}),S$=x.object({steps:x.array(x.record(x.unknown())),testId:x.string(),schemaVersion:x.string()}),Pg=hm,Lg=x.object({trigger:x.nativeEnum(Xt),status:x.nativeEnum(oe),startedAt:x.coerce.date().optional(),gitCommitSha:x.string().optional(),gitCommitShaShort:x.string().optional(),gitCommitTimestamp:x.coerce.date().optional(),gitBranchName:x.string().optional(),gitOriginUrl:x.string().optional(),gitCommitMessage:x.string().optional(),gitCommitAuthorName:x.string().optional(),githubRepository:x.string().optional(),gitlabProjectPath:x.string().optional(),pipelineId:x.string().optional(),cliVersion:x.string().optional()}),y$=x.object({id:x.string()}),Og=x.object({status:x.nativeEnum(oe),updatedAt:x.coerce.date().optional(),finishedAt:x.coerce.date().optional()}),Ng=x.object({stepsSnapshot:x.array(x.record(x.unknown())).optional(),runGroupId:x.string().optional(),testId:x.string(),testName:x.string(),resolvedBaseUrl:x.string().optional(),environmentName:x.string().optional(),labels:x.array(x.string()).optional(),cliVersion:x.string().optional(),trigger:x.nativeEnum(Xt),schemaVersion:x.string().optional(),section:x.nativeEnum(Is).optional()}),b$=x.object({id:x.string()}),tA=id.pick({id:!0,status:!0,testName:!0,testId:!0,test:!0,failureReason:!0,failureDetails:!0}),Mg=tA.array(),kg=id.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(),w$=x.object({id:x.string()}),_g=x.object({status:x.nativeEnum(oe),finishedAt:x.coerce.date().optional(),schemaVersion:x.string().optional().default("1.0.19"),results:x.record(x.string(),x.unknown()).array().optional(),beforeResults:x.record(x.string(),x.unknown()).array().optional(),afterResults:x.record(x.string(),x.unknown()).array().optional()}),v$=x.object({screenshot:x.string()}),Dg=x.object({key:x.string()}),Fg=x.object({orgId:x.string(),userId:x.string()}),Ug=x.array(oh),E$=x.record(x.string(),x.union([x.string(),x.boolean()])),x$=x.object({paths:x.string().array(),env:x.string().optional(),urlOverride:x.string().optional(),customHeaders:x.record(x.string(),x.string()).optional()}),Bg=x.object({suiteRunIds:x.string().array(),runGroupIds:x.string().array()}),T$=x.object({suiteRunIds:x.string().array()}),C$=bh.array(),R$=x.object({runGroupIds:x.string().array()}),da=x.object({uploadUrl:x.string()}),A$=Qt.merge(Ih),I$=Qt.merge(Lh),P$=Qt.merge(Ph),nA=x.object({testId:x.string().optional().default(""),testName:x.string().optional().default(""),suiteId:x.string().optional().default(""),suiteName:x.string().optional().default(""),creditsUsed:x.number().optional(),usedBy:x.string().optional()}),rA=x.object({transactionId:x.string(),timestamp:x.string(),event:x.nativeEnum(oa),properties:nA}),L$=rA.array(),zg=lh.omit({steps:!0}).extend({steps:x.array(x.record(x.string(),x.unknown())).describe("unparsed ResolvedStep[]")}),O$=x.object({limit:x.number().max(10).optional(),afterTime:x.number().optional()}),Hg=hh.array(),N$=x.object({applied:x.boolean().optional(),appliedAt:x.coerce.date().optional()}),jg=da.extend({id:x.string()}),M$=x.object({runGroupId:x.string().uuid().optional()}),$g=x.object({runGroupId:x.string().uuid()});import{z as Le}from"zod";var Gg=Le.object({orgId:Le.string(),cacheKeys:Le.string().array()}),D$=Le.object({keyParams:Gg,clientMetadata:Le.string(),lockAcquisitionTimeoutMs:Le.number().optional()}),Wg=Le.object({acquired:Le.boolean(),acquiredByMetadata:Le.string(),keyPrefix:Le.string()}),F$=Le.object({keyPrefix:Le.string(),result:Le.string(),ttlMs:Le.number()}),U$=Le.union([Le.object({keyPrefix:Le.string()}),Gg]),oA=Le.object({remainingTtlMs:Le.number(),value:Le.string().nullish()}),B$=Le.object({results:Le.record(Le.string(),oA),activeLocks:Le.string().array()}),Vg=0,qg=5*60*1e3;import{z as un}from"zod";var Kg="test",Yg="module",_t=(t=>(t.TEST=`${Kg}.yaml`,t.MODULE=`${Yg}.yaml`,t))(_t||{}),Ie=(t=>(t.TEST=`momentic/${Kg}`,t.MODULE=`momentic/${Yg}`,t))(Ie||{}),V$=xt.merge(Nr),Cd=Lt.extend({steps:un.array(un.record(un.string(),un.unknown())),schemaVersion:un.string()}),q$=Cd.extend({fileType:un.literal(Ie.MODULE)}),K$=un.object({test:un.string().describe("YAML for the test, including metadata and steps"),modules:un.record(un.string(),un.string()).describe("Map of module name to YAML for the module")});import{z as st}from"zod";var iA=st.object({version:st.string(),json:st.record(st.unknown()),hash:st.string()}),Jg=st.record(st.unknown()),Z$=st.object({newSvgs:st.array(iA),metadata:Jg.optional()}),aA=st.object({version:st.string(),json:st.record(st.unknown()).nullish(),hash:st.string(),description:st.string().nullish(),metadata:Jg.nullish()}),Xg=st.record(st.string().describe("icon hash"),aA);import{validator as rG}from"@exodus/schemasafe";var Zg=n=>{n.extraHeaders&&(n.extraHeaders=Object.fromEntries(Object.entries(n.extraHeaders).filter(([e,t])=>e.trim()&&t.trim())))};import{z as gG}from"zod";import{z as Xe}from"zod";var yG=Xe.object({repositoriesIndexed:Xe.boolean(),indexingInProgress:Xe.boolean(),indexesOutdated:Xe.boolean()}),Qg=(a=>(a.Queued="queued",a.InProgress="in_progress",a.Completed="completed",a.Waiting="waiting",a.Requested="requested",a.Pending="pending",a))(Qg||{}),ef=(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))(ef||{}),bG=Xe.object({name:Xe.string(),status:Xe.nativeEnum(Qg),conclusion:Xe.nativeEnum(ef).nullable()}),Rd=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 ke}from"zod";var Ad=ke.object({assertion:ke.string().describe("A human readable assertion that evaluates to either true or false depending on the state of the system.")}),sA=ke.object({instruction:ke.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:Ad.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.")}),tf=sA.extend({subSteps:ke.lazy(()=>tf.array().optional()).describe("More granular steps to be take to achieve the current step's higher level objective.")}),nf=ke.object({name:ke.string().describe("Short name describing the test plan"),description:ke.string().nullish().transform(n=>n??void 0).describe("Longer form description of the high level goal of the test plan")}),rf=nf.extend({id:ke.string(),createdAt:ke.coerce.date(),updatedAt:ke.coerce.date(),updatedBy:ke.string(),createdBy:ke.string(),test:ke.object({id:ke.string(),name:ke.string()}).nullish().transform(n=>n??void 0)}),xG=rf.extend({testGenRuns:ke.tuple([]).or(ke.tuple([ke.object({id:ke.string(),startedAt:ke.coerce.date(),status:ke.nativeEnum(oe)})]))}),of=ke.object({preConditions:Ad.array().nullish().transform(n=>n??[]),postConditions:Ad.array().nullish().transform(n=>n??[]),steps:tf.array().nullish().transform(n=>n??[])}),TG=rf.extend({plan:of.nullish().transform(n=>n??{preConditions:[],postConditions:[],steps:[]})}),lA=nf.extend({plan:of.nullish().transform(n=>n??{preConditions:[],postConditions:[],steps:[]})}),CG=lA.array().nullish().transform(n=>n??[]);var LG=90*24*60*60*1e3,OG=14*24*60*60*1e3,NG=7*24*60*60*1e3;import{z as Oe}from"zod";var cA=Oe.object({step:Pe,status:Oe.nativeEnum(Re),startedAt:Oe.coerce.date(),finishedAt:Oe.coerce.date().optional(),healMetadata:Oe.object({healType:Oe.nativeEnum(Yi).or(Oe.literal("AI")),healedAt:Oe.coerce.date()}).optional(),beforeSnapshotId:Oe.string().uuid().optional(),afterSnapshotId:Oe.string().uuid().optional(),message:Oe.string().optional()}),BG=cA.extend({finishedAt:Oe.coerce.date().optional().transform(n=>n??new Date)}),dA=Oe.object({startedAt:Oe.coerce.date()}).merge(_g).merge(vs),zG=dA.extend({finishedAt:Oe.coerce.date().optional().transform(n=>n??new Date)}),pA=kg.merge(Ng).extend({status:Oe.nativeEnum(oe),startedAt:Oe.coerce.date(),attempts:Oe.number()}),HG=pA.extend({finishedAt:Oe.coerce.date().optional().transform(n=>n??new Date)}),uA=Lg.merge(Og).extend({id:Oe.string().uuid().optional(),startedAt:Oe.coerce.date(),cliVersion:Oe.string()}),pa=uA.extend({updatedAt:Oe.coerce.date().optional().transform(n=>n??new Date),finishedAt:Oe.coerce.date().optional().transform(n=>n??new Date)});import mA from"semver";import{z as hA}from"zod";var WG=hA.string().refine(n=>mA.valid(n),{message:"must be a valid semver string"});function Id(n){let e={parentChain:[]};return Hs(n,e),e}function Hs(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||Hs({...n,steps:l.steps},e)&&i)return!0;if(Hs({...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),Hs({...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 af(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!!gA([n],t,i).result}function gA(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 Id({steps:n,earlyStop:!0,onPresetAction:i,onConditional:i,onSimpleStepContainer:i}),{result:r,parentChain:o}}function sf(n,e){e(n);for(let t in n){let r=n[t];r&&(Array.isArray(r)?js(r,e):typeof r=="object"&&sf(r,e))}}function js(n,e){for(let t of n)t&&(Array.isArray(t)?js(t,e):typeof t=="object"&&sf(t,e))}import{cloneDeep as lf}from"lodash-es";import{v4 as Pd}from"uuid";async function Dt(n){let e=new Map,t=new Set,r=lf(n.stepLists.steps),o=await jr({...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=lf(n.stepLists[a]);if(!s)continue;let l=await jr({...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 jr({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?Pd():d.id,d.type){case"PRESET_ACTION":{let u=d.command;u.id=l?Pd():u.id,df(u),"cache"in u&&u.cache&&(r&&(c.cachesToSave=c.cachesToSave.concat(cf({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?Pd():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 jr({...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:Ee.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 jr({...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 jr({...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 jr({...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 jr({...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 $o({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=SA(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}=$o({...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}=$o({...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(!Ic.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}=$o({...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}=$o({...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 pf(n,e){return e?`${e}:${n}`:n}function SA(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 cf(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:pf(n.id,a),moduleId:i,organizationId:n.orgId,value:n.value})}return r.push({key:pf(n.id,e.join(":")),organizationId:n.orgId,value:n.value,testId:n.testId}),r}function df(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 uf(n){let e=new Set;return js(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 mf(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 $s({logger:n,cacheStorage:e,orgId:t,testId:r,originalSteps:o,updatedSteps:i}){let a=fA(o,i);if(Object.keys(a).length>0){n.info({changes:a},"Updating steps caches post-run success");try{let{cachesToSave:s}=await Dt({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"},Ld={EXISTS:"exists",VISIBLE:"is visible",ENABLED:"is enabled",EDITABLE:"is editable"},Od={EXISTS:"does not exist",VISIBLE:"is not visible",ENABLED:"is disabled",EDITABLE:"is not editable"};function yA(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?Od[n.condition]:Ld[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 VV={CONTENT:"The page"};function bA(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 Nd(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 wA(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 $r(n){switch(n.type){case"SUCCESS":return n.condition?.assertion?`Check success condition: ${n.condition.assertion}`:"All commands completed";case"AI_EXTRACT":return`Extract data from page: ${n.goal}`;case"NAVIGATE":return`Go to URL: ${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=bA(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)} ${yA(n.assertion)}`;case"PAGE_CHECK":return`Check the page ${wA(n.assertion)}`;case"WAIT_FOR_URL":return`Wait for page URL to ${Nd(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 hf(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 vA}from"lodash-es";import{cloneDeep as JV,unset as XV}from"lodash-es";function mn(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 $r(n.command);case"MODULE":return`Module: ${n.id}`;case"RESOLVED_MODULE":return`Module: ${n.name}`;case"CONDITIONAL":return"Conditional step";case"IFRAME":return"Frame step";case"SECTION":return`Section${n.description?`with goal: ${je(n.description,100)}`:""}`;default:return(t=>{throw new Error("You missed a case in the switch above")})(n)}}var gf=1e3,ff=3e6,EA="[FAILED]";async function Sf(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 Gs(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?Gr(p):mn(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=`${EA} ${m.description}`,o&&(c=d);try{let h=Sh.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 Sf(n,e,p.afterScreenshot,p.afterSnapshot),i&&(m.beforeScreenshot=await Sf(n,e,p.beforeScreenshot,p.beforeSnapshot))),l.push(m)}return{results:l,failureIndex:c}}function Gr(n){let e=mn(n);switch(n.type){case"AI_ACTION":case"AI_ACTION_DYNAMIC":e+=`
|
|
16
16
|
`;for(let t=0;t<n.results.length;t++)e+=Ze(`Sub-step ${t} in AI action:
|
|
17
|
-
`,2),e+=`${Ze(
|
|
17
|
+
`,2),e+=`${Ze(Gr(n.results[t]),2)}
|
|
18
18
|
`,e+=Ze(`${"=".repeat(10)}
|
|
19
19
|
`,2);return e;case"PRESET_ACTION":return e;case"MODULE":{e+=`
|
|
20
20
|
`;for(let t=0;t<n.results.length;t++)e+=Ze(`Sub-step ${t} in module:
|
|
21
|
-
`,2),e+=`${Ze(
|
|
21
|
+
`,2),e+=`${Ze(Gr(n.results[t]),2)}
|
|
22
22
|
`,e+=Ze(`${"=".repeat(10)}
|
|
23
23
|
`,2);return e}case"CONDITIONAL":{e+=`
|
|
24
24
|
`,n.assertion&&(e+=Ze(`Conditional check:
|
|
25
|
-
`,2),e+=`${Ze(
|
|
25
|
+
`,2),e+=`${Ze(Gr(n.assertion),2)}
|
|
26
26
|
`,e+=Ze(`${"=".repeat(10)}
|
|
27
27
|
`,2)),e+=Ze(`${n.assertion?"Branch steps":"Else branch steps"}
|
|
28
28
|
`,2);for(let t=0;t<n.results.length;t++)e+=Ze(`Sub-step ${t} in conditional branch:
|
|
29
|
-
`,2),e+=`${Ze(
|
|
29
|
+
`,2),e+=`${Ze(Gr(n.results[t]),2)}
|
|
30
30
|
`,e+=Ze(`${"=".repeat(10)}
|
|
31
31
|
`,2);return e}case"IFRAME":{e+=`
|
|
32
32
|
`;for(let t=0;t<n.results.length;t++)e+=Ze(`Sub-step ${t} in frame step:
|
|
33
|
-
`,2),e+=`${Ze(
|
|
33
|
+
`,2),e+=`${Ze(Gr(n.results[t]),2)}
|
|
34
34
|
`,e+=Ze(`${"=".repeat(10)}
|
|
35
35
|
`,2);return e}case"SECTION":{e+=`
|
|
36
36
|
`;for(let t=0;t<n.results.length;t++)e+=Ze(`Sub-step ${t} in section:
|
|
37
|
-
`,2),e+=`${Ze(
|
|
37
|
+
`,2),e+=`${Ze(Gr(n.results[t]),2)}
|
|
38
38
|
`,e+=Ze(`${"=".repeat(10)}
|
|
39
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 vf(n,e){try{if(!n)return n;if(typeof n=="string")return je(n,3e4);if(typeof n=="object"){let{jsonString:t}=No(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 Nd(n,e){for(let t=0;t<n.length;t++){let r=n[t];try{if(r.data){let{jsonString:o}=No(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":bf(r);break;case"CONDITIONAL":r.assertion&&bf(r.assertion),Nd(r.results,e);break;case"AI_ACTION_DYNAMIC":case"AI_ACTION":case"IFRAME":case"MODULE":case"SECTION":{Nd(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 bf(n){let e=n.command;"cache"in e&&e.cache&&(e.cache=void 0)}function wf(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 Ws(n,e){let t=wA(n);if(Nd(t,e),t.length>ff)return e.error("Database content violation: results too long, truncating before insertion"),t.slice(0,ff);let r=wf(t,e);if(r.length>Sf)for(e.error({serializedLength:r.length,resultsArrayLength:t.length},"Database content violation: results too large, truncating before insertion");r.length>Sf;)t.pop(),r=wf(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 gq}from"lodash-es";var xA=/^(?!.*\S+\s+\S+).*$/,EA=/^[a-zA-Z0-9\s.,;:'"!?()\- \u00C0-\u00FF]+$/,TA=/style="([^"]*)/g,CA=/data-[\w-]+/g,RA=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=RA(n),t=e.type==="AI_ASSERTION"?e.assertion:e.description;return!t||t==="NONE"?{thoughts:"NONE",category:"NO_DESCRIPTION_PROVIDED"}:xA.test(t)&&EA.test(t)?{thoughts:"The target description is too short. Please provide more details.",category:"FEW_WORDS"}:TA.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"}:CA.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 Ef(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 Yf}from"lodash-es";import OA from"diff-lines";import qs,{gte as MA}from"semver";var Tf={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 Cf={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 AA=["target","fromTarget","toTarget"];function Rf(n){for(let e of AA){if(n[e]===void 0)continue;let t=n[e];t.elementDescriptor!==void 0?t.type="description":n[e]={type:"description",elementDescriptor:""}}}var Af={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 Rf(e.command),e;case"AI_ACTION":{let t=e.commands;for(let r of t??[])Rf(r);return e}default:return e}})};import{v4 as IA}from"uuid";var If={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=IA()),e;default:return e}})};import{v4 as Pf}from"uuid";var Lf={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??Pf(),e}case"AI_ACTION":return e.commands&&(e.steps=e.commands.map(t=>({type:"PRESET_ACTION",command:{...t,id:t.id??Pf()}})),delete e.commands),e;default:return e}})};var Of={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 PA}from"uuid";var Mf={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=PA()),e))};import{v4 as Nf}from"uuid";var kf={name:"Add ids to all steps",fromVersion:"1.0.11",toVersion:"1.0.12",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if("id"in e&&typeof e.id=="string")return e;if("condition"in e&&typeof e.condition=="object"&&e.condition){let t=e.condition;t.id||(t.id=Nf())}return e.id=Nf(),e})};var _f={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 LA}from"uuid";var Df={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=LA()),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 Ff={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 Uf={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&&Bf(t),e})};function Bf(n){n&&Object.keys(n).forEach(e=>{if(typeof n[e]=="object"&&n[e]){Bf(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 zf={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 Hf={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 jf={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 $f={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 Gf={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 Vs=new Set(["CLICK","TYPE","SELECT_OPTION"]),Wf={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||Vs.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||Vs.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||Vs.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||Vs.has(m))&&(p.target={elementDescriptor:u??""})})}),e}),stopOnFailure:!0};var Vf={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 qf={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 Vr=[Gf,Vf,qf,Wf,Tf,Cf,Af,If,Lf,Of,Mf,kf,_f,Df,Ff,Uf,zf,Hf,jf,$f];if(De!==Vr[Vr.length-1].toVersion)throw new Error("Please bump LATEST_SCHEMA_VERSION in types package after adding a migration");Vr.forEach((n,e)=>{if(!qs.valid(n.toVersion)||!qs.valid(n.fromVersion))throw new Error(`Migration '${n.name}' has invalid version`);if(!qs.gt(n.toVersion,n.fromVersion))throw new Error(`Migration '${n.name}' has toVersion <= fromVersion`);if(e===0)return;if(Vr[e-1].toVersion!==n.fromVersion)throw new Error(`Migration '${n.name}' at index ${e} is not contiguous with previous migration`)});function NA(n){return n.every(e=>e&&typeof e=="object"&&!Array.isArray(e))}var ua=async({metadata:n,steps:e,logger:t,toVersion:r})=>{let o=e,{schemaVersion:i,id:a}=n,s=Vr.findIndex(d=>qs.gt(d.toVersion,i));if(s===-1)return{steps:o,newVersion:i};let l=i;for(let d=s;d<Vr.length;d++){if(r&&MA(l,r)){t.debug("Stopping migration early because toVersion was reached");break}let p=Vr[d],u={id:a,migration:p.name,toVersion:p.toVersion};try{o=await Kf(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=OA(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 Kf(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)||NA(i)&&(r[o]=await Kf(i,e))}return t}async function Jf({rawSteps:n,metadata:e,logger:t,callbacks:r}){Ef(e,"defaultOnCloud");let o={},{resolvedSteps:i,newSchemaVersion:a}=await Ks({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 Ks({rawSteps:c,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o});s[l]=d}return{resolvedTest:s,moduleIds:Array.from(Object.keys(o))}}async function qr(n,e,t){let{newVersion:r,steps:o}=await ua({metadata:n,steps:e,logger:t});try{return{steps:xe.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 Fs(`Failed to parse test steps while migrating test: ${i}`,n.id,"entity",{cause:i})}}async function Ks({rawSteps:n,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o={}}){let{newVersion:i,steps:a}=await qr(e,n,t),s=[];for(let l of a)s.push(await ma({step:l,callbacks:r,logger:t,resolvedModuleCache:o}));return{resolvedSteps:s,newSchemaVersion:i}}async function ma({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{...Yf(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 ua({metadata:{id:l,schemaVersion:d.schemaVersion},steps:d.steps,logger:t}),m;try{m=xe.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=>ma({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]=Yf(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 ma({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 ma({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 ma({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 kA(n){return typeof n=="object"&&n!==null}function Gn(n){if(Array.isArray(n))return n.map(Gn);if(kA(n)){let e={};return Object.entries(n).forEach(([t,r])=>{r!==void 0&&(e[t]=Gn(r))}),e}return n}import{cloneDeep as _A}from"lodash-es";import{stringify as Xf}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 DA({originalStepLists:{steps:n.steps,beforeSteps:n.beforeSteps,afterSteps:n.afterSteps},modules:o,processedModuleNames:e,createNewCacheIds:t}),a={fileType:Ie.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:Xf(a),modules:o}}async function DA({originalStepLists:n,modules:e,processedModuleNames:t,createNewCacheIds:r}){let o=_A(n);Object.values(o).forEach(s=>{FA(s??[])});let{stepsToSave:i,moduleUpdates:a}=await Dt({stepLists:o,createNewCacheIds:r});for(let s of a)t.has(s.name)||(e[s.name]=UA(s),t.add(s.name));return i}function FA(n){Id({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 UA(n){let e=Lt.parse(n),t={fileType:Ie.MODULE,...e,schemaVersion:De,steps:n.steps};return Xf(t)}async function ee(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 ha({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 Kr({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 ha({promiseGenerator:n,signal:a.signal,codePath:t,logger:r})}finally{i=!0,o?.removeEventListener("abort",s),clearTimeout(l)}}function Ys(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(Hn.parse(r));break}case"IFRAME":case"SECTION":{let r={...t,steps:Ys(t.steps)};e.push(xe.parse(r));break}case"CONDITIONAL":{let r={...t,blocks:t.blocks.map(o=>({assertion:o.assertion,steps:Ys(o.steps)})),elseSteps:t.elseSteps?Ys(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 Js(n){return Ys([n])[0]}import BA from"picomatch";var Qf=(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||BA(o)(n);break}case"REGEX":{r=new RegExp(e.regex).test(n);break}}return t?.negated?!r:r},Xs=(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}},Wo=n=>{try{return new URL(n),!0}catch{return!1}},eS=n=>!n.toLowerCase().startsWith("http"),Vo=(n,e)=>{try{return new URL(n,e),!0}catch{return!1}};function Yr(n,e){try{return!!new URL(n).origin.trim()}catch(t){return e?.error({url:n,err:t},"Invalid URL in check"),!1}}import qo from"yaml";import{z as oS}from"zod";import{execSync as zA}from"child_process";function Jr(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{zA(r,{encoding:"utf-8"})}catch(o){b.warn({err:o,postSaveCommand:r},"Failed to execute post-save hook command, continuing...")}}import{diff as tS}from"deep-object-diff";import ur from"fs";import{cloneDeep as HA}from"lodash-es";import kd from"path";import{v4 as jA}from"uuid";import ga from"yaml";function Xr({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=ga.parse(a),l;if(n.name&&n.name!==s.name){let m=`${Ne(n.name)}.${_t.MODULE}`;if(l=kd.join(kd.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=Gn({fileType:Ie.MODULE,...xd.parse(c),steps:xe.array().parse(n.steps)}),p=tS(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=ga.stringify(d);ur.writeFileSync(i,u,"utf-8"),l&&ur.renameSync(i,l),Jr(l||i,r.config)}function nS({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=Wn(i,o),s={...a,...e},l=Gn({fileType:Ie.MODULE,...xd.parse(s),steps:a.steps}),c=tS(l,a);if(c&&Object.keys(c).length===0){b.debug(`Skipping save for module ${n} since there are no changes`);return}let d=ga.stringify(l);ur.writeFileSync(i,d,"utf-8"),Jr(i,r.config)}async function rS({name:n,description:e,enabled:t,steps:r,folder:o,project:i}){let a=Ne(n),s=kd.join(o,`${a}.module.yaml`),l=jA(),{stepsToSave:c}=await Dt({stepLists:{steps:r}}),d={fileType:Ie.MODULE,schemaVersion:De,moduleId:l,name:n,description:e,enabled:t,steps:c.steps},p=ga.stringify(d);return ur.writeFileSync(s,p,"utf-8"),Jr(s,i.config),{moduleId:l,name:n,description:e,enabled:t,steps:r}}function Wn(n,e){let t=ur.readFileSync(n,"utf-8"),r=ga.parse(t);try{return Cd.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 _d(n,e,t,r){let o=Wn(n.fullFilePath,t),{resolvedSteps:i}=await Ks({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 Wn(l,t)}}}),a={...o,steps:i};return r&&(r[n.id]=HA(a)),a}async function Zs(n,e){let t={};return await Promise.all(Object.values(n.modules).map(async r=>{await _d(r,n,e,t)})),Array.from(Object.values(t))}async function iS({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=`${Ne(e)}.${_t.TEST}`,a=Zr.join(t,i);return hn.writeFileSync(a,r.test,"utf-8"),a}function Dd(n,e,t){let r=Zr.join(t.rootDir,n);if(!hn.existsSync(r))throw new Error(`Test not found at path '${n}' in project '${t.rootDir}'`);let o=hn.readFileSync(r,"utf-8"),i=qo.parse(o),a,s;if(e.name&&e.name!==i.name){let u=`${Ne(e.name)}.${_t.TEST}`;if(a=Zr.join(Zr.dirname(n),u),s=Zr.join(t.rootDir,a),hn.existsSync(s))throw new Error(`Test with name '${e.name}' already exists at path '${s}'`)}let l={...i,...e},c=tn.parse(l),d={fileType:Ie.TEST,...tn.parse(c),beforeSteps:i.beforeSteps??void 0,steps:i.steps,afterSteps:i.afterSteps??void 0},p=qo.stringify(d);return hn.writeFileSync(r,p,"utf-8"),s&&hn.renameSync(r,s),Jr(r,t.config),{newRelativeTestPath:a}}function Vn({relativeTestPath:n,steps:e,schemaVersion:t,project:r,forceSaveOnNoDiffs:o}){let i=Zr.join(r.rootDir,n);if(!hn.existsSync(i))throw new Error(`Test not found at path '${n}' in project '${r.rootDir}'`);let a=hn.readFileSync(i,"utf-8"),s=qo.parse(a),l=tn.parse({...s,schemaVersion:t}),c=Gn({fileType:Ie.TEST,...l,beforeSteps:xe.array().or(oS.undefined()).parse(e.beforeSteps),steps:xe.array().parse(e.steps),afterSteps:xe.array().or(oS.undefined()).parse(e.afterSteps)}),d=$A(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=qo.stringify(c);hn.writeFileSync(i,p,"utf-8"),b.debug(`Saving test ${l.name} to ${i}`),Jr(i,r.config)}function Qs(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=hn.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=qo.parse(r)}catch(i){throw new Error(`Could not parse test file ${t} as YAML: ${i}`)}return Et.parse(o)}function Qr(n,e,t){let r=t.project.rootDir,o;try{o=hn.readFileSync(n,"utf-8")}catch(a){throw e.error({err:a,projectRoot:r},a.message),new Error(a.message)}let i=qo.parse(o);if(!i.steps||!Array.isArray(i.steps))throw new Error(`Test ${n} is missing steps`);return i}async function fa(n,e,t){let r=Qr(n,e,t),o;try{o=tn.parse(r)}catch(a){throw new Error(`Test ${n} is missing metadata or has invalid metadata: ${a}`)}let{resolvedTest:i}=await Jf({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 Wn(l,s)}}});return i}import GA from"@dotenvx/dotenvx";import WA from"fs";import aS from"path";function lS(n,e){return(n.config.environments??[]).map(t=>Sa(t.name,n,e))}function sS(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 Sa(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={[Ve]:sS(r.baseUrl)};if(r.envVariables){let a={};for(let[s,l]of Object.entries(r.envVariables))if(typeof l=="string"){let c=sS(l);c&&(a[s]=c)}else{let c=l.fromFile,d;try{d=WA.readFileSync(aS.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=GA.config({path:aS.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 xP,readFileSync as EP,readdirSync as TP,writeFileSync as CP}from"fs";var PS=Zx(vS(),1);var ba=n=>{if(typeof n!="string")throw new TypeError("invalid pattern");if(n.length>65536)throw new TypeError("pattern is too long")};var QA={"[: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]},wa=n=>n.replace(/[[\]\\-]/g,"\\$&"),eI=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),xS=n=>n.join(""),ES=(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,x]]of Object.entries(QA))if(n.startsWith(f,i)){if(p)return["$.",!1,n.length-t,!0];i+=f.length,x?o.push(S):r.push(S),s=s||w;continue e}}if(l=!1,p){g>p?r.push(wa(p)+"-"+wa(g)):g===p&&r.push(wa(g)),p="",i++;continue}if(n.startsWith("-]",i+1)){r.push(wa(g+"-")),i+=2;continue}if(n.startsWith("-",i+1)){p=g,i+=2;continue}r.push(wa(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[eI(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 gn=(n,{windowsPathsNoEscape:e=!1}={})=>e?n.replace(/\[([^\/\\])\]/g,"$1"):n.replace(/((?!\\).|^)\[([^\/\\])\]/g,"$1$2").replace(/\\([^\/])/g,"$1");var tI=new Set(["!","?","+","*","@"]),TS=n=>tI.has(n),nI="(?!(?:^|/)\\.\\.?(?:$|/))",el="(?!\\.)",rI=new Set(["[","."]),oI=new Set(["..","."]),iI=new Set("().*{}+?[]^$\\!"),aI=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),Bd="[^/]",CS=Bd+"*?",RS=Bd+"+?",Ko=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&&TS(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(TS(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&&oI.has(this.#r[0]))){let h=rI,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?nI:f?el:""}let p="";return this.isEnd()&&this.#e.#p&&this.#a?.type==="!"&&(p="(?:$|\\/)"),[d+c+p,gn(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,gn(this.toString()),!1,!1]}let a=!r||e||t||!el?"":this.#m(!0);a===i&&(a=""),a&&(i=`(?:${i})(?:${a})*?`);let s="";if(this.type==="!"&&this.#o)s=(this.isStart()&&!t?el:"")+RS;else{let l=this.type==="!"?"))"+(this.isStart()&&!t&&!e?el:"")+CS+")":this.type==="@"?")":this.type==="?"?")?":this.type==="+"&&a?")":this.type==="*"&&a?")?":`)${this.type}`;s=o+i+l}return[s,gn(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+=(iI.has(l)?"\\":"")+l;continue}if(l==="\\"){s===e.length-1?i+="\\\\":o=!0;continue}if(l==="["){let[c,d,p,u]=ES(e,s);if(p){i+=c,a=a||d,s+=p-1,t=t||u;continue}}if(l==="*"){r&&e==="*"?i+=RS:i+=CS,t=!0;continue}if(l==="?"){i+=Bd,t=!0;continue}i+=aI(l)}return[i,gn(e),!!t,a]}};var Yo=(n,{windowsPathsNoEscape:e=!1}={})=>e?n.replace(/[?*()[\]]/g,"[$&]"):n.replace(/[?*()[\]\\]/g,"\\$&");var Tt=(n,e,t={})=>(ba(e),!t.nocomment&&e.charAt(0)==="#"?!1:new Ht(e,t).match(n)),sI=/^\*+([^+@!?\*\[\(]*)$/,lI=n=>e=>!e.startsWith(".")&&e.endsWith(n),cI=n=>e=>e.endsWith(n),dI=n=>(n=n.toLowerCase(),e=>!e.startsWith(".")&&e.toLowerCase().endsWith(n)),pI=n=>(n=n.toLowerCase(),e=>e.toLowerCase().endsWith(n)),uI=/^\*+\.\*+$/,mI=n=>!n.startsWith(".")&&n.includes("."),hI=n=>n!=="."&&n!==".."&&n.includes("."),gI=/^\.\*+$/,fI=n=>n!=="."&&n!==".."&&n.startsWith("."),SI=/^\*+$/,yI=n=>n.length!==0&&!n.startsWith("."),bI=n=>n.length!==0&&n!=="."&&n!=="..",wI=/^\?+([^+@!?\*\[\(]*)?$/,vI=([n,e=""])=>{let t=LS([n]);return e?(e=e.toLowerCase(),r=>t(r)&&r.toLowerCase().endsWith(e)):t},xI=([n,e=""])=>{let t=OS([n]);return e?(e=e.toLowerCase(),r=>t(r)&&r.toLowerCase().endsWith(e)):t},EI=([n,e=""])=>{let t=OS([n]);return e?r=>t(r)&&r.endsWith(e):t},TI=([n,e=""])=>{let t=LS([n]);return e?r=>t(r)&&r.endsWith(e):t},LS=([n])=>{let e=n.length;return t=>t.length===e&&!t.startsWith(".")},OS=([n])=>{let e=n.length;return t=>t.length===e&&t!=="."&&t!==".."},MS=typeof process=="object"&&process?typeof process.env=="object"&&process.env&&process.env.__MINIMATCH_TESTING_PLATFORM__||process.platform:"posix",AS={win32:{sep:"\\"},posix:{sep:"/"}},CI=MS==="win32"?AS.win32.sep:AS.posix.sep;Tt.sep=CI;var lt=Symbol("globstar **");Tt.GLOBSTAR=lt;var RI="[^/]",AI=RI+"*?",II="(?:(?!(?:\\/|^)(?:\\.{1,2})($|\\/)).)*?",PI="(?:(?!(?:\\/|^)\\.).)*?",LI=(n,e={})=>t=>Tt(t,n,e);Tt.filter=LI;var nn=(n,e={})=>Object.assign({},n,e),OI=n=>{if(!n||typeof n!="object"||!Object.keys(n).length)return Tt;let e=Tt;return Object.assign((r,o,i={})=>e(r,o,nn(n,i)),{Minimatch:class extends e.Minimatch{constructor(o,i={}){super(o,nn(n,i))}static defaults(o){return e.defaults(nn(n,o)).Minimatch}},AST:class extends e.AST{constructor(o,i,a={}){super(o,i,nn(n,a))}static fromGlob(o,i={}){return e.AST.fromGlob(o,nn(n,i))}},unescape:(r,o={})=>e.unescape(r,nn(n,o)),escape:(r,o={})=>e.escape(r,nn(n,o)),filter:(r,o={})=>e.filter(r,nn(n,o)),defaults:r=>e.defaults(nn(n,r)),makeRe:(r,o={})=>e.makeRe(r,nn(n,o)),braceExpand:(r,o={})=>e.braceExpand(r,nn(n,o)),match:(r,o,i={})=>e.match(r,o,nn(n,i)),sep:e.sep,GLOBSTAR:lt})};Tt.defaults=OI;var NS=(n,e={})=>(ba(n),e.nobrace||!/\{(?:(?!\{).)*\}/.test(n)?[n]:(0,PS.default)(n));Tt.braceExpand=NS;var MI=(n,e={})=>new Ht(n,e).makeRe();Tt.makeRe=MI;var NI=(n,e,t={})=>{let r=new Ht(e,t);return n=n.filter(o=>r.match(o)),r.options.nonull&&!n.length&&n.push(e),n};Tt.match=NI;var IS=/[?*]|[+@!]\(.*?\)|\[|\]/,kI=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),Ht=class{options;set;pattern;windowsPathsNoEscape;nonegate;negate;comment;empty;preserveMultipleSlashes;partial;globSet;globParts;nocase;isWindows;platform;windowsNoMagicRoot;regexp;constructor(e,t={}){ba(e),t=t||{},this.options=t,this.pattern=e,this.platform=t.platform||MS,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]==="?"||!IS.test(i[2]))&&!IS.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]),x=f?3:g?0:void 0,y=w?3:S?0:void 0;if(typeof x=="number"&&typeof y=="number"){let[T,C]=[e[x],t[y]];T.toLowerCase()===C.toLowerCase()&&(t[y]=T,y>x?t=t.slice(y):x>y&&(e=e.slice(x)))}}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 wf(n,e){try{if(!n)return n;if(typeof n=="string")return je(n,3e4);if(typeof n=="object"){let{jsonString:t}=No(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 Md(n,e){for(let t=0;t<n.length;t++){let r=n[t];try{if(r.data){let{jsonString:o}=No(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":yf(r);break;case"CONDITIONAL":r.assertion&&yf(r.assertion),Md(r.results,e);break;case"AI_ACTION_DYNAMIC":case"AI_ACTION":case"IFRAME":case"MODULE":case"SECTION":{Md(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 yf(n){let e=n.command;"cache"in e&&e.cache&&(e.cache=void 0)}function bf(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 Ws(n,e){let t=vA(n);if(Md(t,e),t.length>gf)return e.error("Database content violation: results too long, truncating before insertion"),t.slice(0,gf);let r=bf(t,e);if(r.length>ff)for(e.error({serializedLength:r.length,resultsArrayLength:t.length},"Database content violation: results too large, truncating before insertion");r.length>ff;)t.pop(),r=bf(t,e);try{return Nt.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 fq}from"lodash-es";var xA=/^(?!.*\S+\s+\S+).*$/,TA=/^[a-zA-Z0-9\s.,;:'"!?()\- \u00C0-\u00FF]+$/,CA=/style="([^"]*)/g,RA=/data-[\w-]+/g,AA=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 vf(n){let e=AA(n),t=e.type==="AI_ASSERTION"?e.assertion:e.description;return!t||t==="NONE"?{thoughts:"NONE",category:"NO_DESCRIPTION_PROVIDED"}:xA.test(t)&&TA.test(t)?{thoughts:"The target description is too short. Please provide more details.",category:"FEW_WORDS"}:CA.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"}:RA.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 Ef(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 Kf}from"lodash-es";import NA from"diff-lines";import qs,{gte as MA}from"semver";var xf={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 Tf={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 IA=["target","fromTarget","toTarget"];function Cf(n){for(let e of IA){if(n[e]===void 0)continue;let t=n[e];t.elementDescriptor!==void 0?t.type="description":n[e]={type:"description",elementDescriptor:""}}}var Rf={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 Cf(e.command),e;case"AI_ACTION":{let t=e.commands;for(let r of t??[])Cf(r);return e}default:return e}})};import{v4 as PA}from"uuid";var Af={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=PA()),e;default:return e}})};import{v4 as If}from"uuid";var Pf={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??If(),e}case"AI_ACTION":return e.commands&&(e.steps=e.commands.map(t=>({type:"PRESET_ACTION",command:{...t,id:t.id??If()}})),delete e.commands),e;default:return e}})};var Lf={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 LA}from"uuid";var Of={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=LA()),e))};import{v4 as Nf}from"uuid";var Mf={name:"Add ids to all steps",fromVersion:"1.0.11",toVersion:"1.0.12",recursiveKeys:new Set(["results","steps","blocks","elseSteps"]),stopOnFailure:!0,execute:async n=>n.map(e=>{if("id"in e&&typeof e.id=="string")return e;if("condition"in e&&typeof e.condition=="object"&&e.condition){let t=e.condition;t.id||(t.id=Nf())}return e.id=Nf(),e})};var kf={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 OA}from"uuid";var _f={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=OA()),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 Df={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 Ff={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&&Uf(t),e})};function Uf(n){n&&Object.keys(n).forEach(e=>{if(typeof n[e]=="object"&&n[e]){Uf(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 Bf={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 zf={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 Hf={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 jf={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 $f={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 Vs=new Set(["CLICK","TYPE","SELECT_OPTION"]),Gf={name:"Migrate element descriptor to live in a target object",fromVersion:"1.0.3",toVersion:"1.0.4",recursiveKeys:new Set,execute:async n=>n.map(e=>{let t=e.command,r=t?.type,o=t?.elementDescriptor;return(o!==void 0||Vs.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||Vs.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||Vs.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||Vs.has(m))&&(p.target={elementDescriptor:u??""})})}),e}),stopOnFailure:!0};var Wf={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 Vf={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 Wr=[$f,Wf,Vf,Gf,xf,Tf,Rf,Af,Pf,Lf,Of,Mf,kf,_f,Df,Ff,Bf,zf,Hf,jf];if(De!==Wr[Wr.length-1].toVersion)throw new Error("Please bump LATEST_SCHEMA_VERSION in types package after adding a migration");Wr.forEach((n,e)=>{if(!qs.valid(n.toVersion)||!qs.valid(n.fromVersion))throw new Error(`Migration '${n.name}' has invalid version`);if(!qs.gt(n.toVersion,n.fromVersion))throw new Error(`Migration '${n.name}' has toVersion <= fromVersion`);if(e===0)return;if(Wr[e-1].toVersion!==n.fromVersion)throw new Error(`Migration '${n.name}' at index ${e} is not contiguous with previous migration`)});function kA(n){return n.every(e=>e&&typeof e=="object"&&!Array.isArray(e))}var ua=async({metadata:n,steps:e,logger:t,toVersion:r})=>{let o=e,{schemaVersion:i,id:a}=n,s=Wr.findIndex(d=>qs.gt(d.toVersion,i));if(s===-1)return{steps:o,newVersion:i};let l=i;for(let d=s;d<Wr.length;d++){if(r&&MA(l,r)){t.debug("Stopping migration early because toVersion was reached");break}let p=Wr[d],u={id:a,migration:p.name,toVersion:p.toVersion};try{o=await qf(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=NA(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 qf(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)||kA(i)&&(r[o]=await qf(i,e))}return t}async function Yf({rawSteps:n,metadata:e,logger:t,callbacks:r}){Ef(e,"defaultOnCloud");let o={},{resolvedSteps:i,newSchemaVersion:a}=await Ks({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 Ks({rawSteps:c,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o});s[l]=d}return{resolvedTest:s,moduleIds:Array.from(Object.keys(o))}}async function Vr(n,e,t){let{newVersion:r,steps:o}=await ua({metadata:n,steps:e,logger:t});try{return{steps:Ee.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 Fs(`Failed to parse test steps while migrating test: ${i}`,n.id,"entity",{cause:i})}}async function Ks({rawSteps:n,migrationMetadata:e,logger:t,callbacks:r,resolvedModuleCache:o={}}){let{newVersion:i,steps:a}=await Vr(e,n,t),s=[];for(let l of a)s.push(await ma({step:l,callbacks:r,logger:t,resolvedModuleCache:o}));return{resolvedSteps:s,newSchemaVersion:i}}async function ma({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{...Kf(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 ua({metadata:{id:l,schemaVersion:d.schemaVersion},steps:d.steps,logger:t}),m;try{m=Ee.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=>ma({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]=Kf(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 ma({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 ma({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 ma({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 _A(n){return typeof n=="object"&&n!==null}function Gn(n){if(Array.isArray(n))return n.map(Gn);if(_A(n)){let e={};return Object.entries(n).forEach(([t,r])=>{r!==void 0&&(e[t]=Gn(r))}),e}return n}import{cloneDeep as DA}from"lodash-es";import{stringify as Jf}from"yaml";async function Xf({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 FA({originalStepLists:{steps:n.steps,beforeSteps:n.beforeSteps,afterSteps:n.afterSteps},modules:o,processedModuleNames:e,createNewCacheIds:t}),a={fileType:Ie.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:Jf(a),modules:o}}async function FA({originalStepLists:n,modules:e,processedModuleNames:t,createNewCacheIds:r}){let o=DA(n);Object.values(o).forEach(s=>{UA(s??[])});let{stepsToSave:i,moduleUpdates:a}=await Dt({stepLists:o,createNewCacheIds:r});for(let s of a)t.has(s.name)||(e[s.name]=BA(s),t.add(s.name));return i}function UA(n){Id({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 BA(n){let e=Lt.parse(n),t={fileType:Ie.MODULE,...e,schemaVersion:De,steps:n.steps};return Jf(t)}async function ee(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 ha({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 qr({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 ha({promiseGenerator:n,signal:a.signal,codePath:t,logger:r})}finally{i=!0,o?.removeEventListener("abort",s),clearTimeout(l)}}function Ys(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:Ys(t.steps)};e.push(Ee.parse(r));break}case"CONDITIONAL":{let r={...t,blocks:t.blocks.map(o=>({assertion:o.assertion,steps:Ys(o.steps)})),elseSteps:t.elseSteps?Ys(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 Js(n){return Ys([n])[0]}import zA from"picomatch";var Zf=(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||zA(o)(n);break}case"REGEX":{r=new RegExp(e.regex).test(n);break}}return t?.negated?!r:r},Xs=(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}},Go=n=>{try{return new URL(n),!0}catch{return!1}},Qf=n=>!n.toLowerCase().startsWith("http"),Wo=(n,e)=>{try{return new URL(n,e),!0}catch{return!1}};function Kr(n,e){try{return!!new URL(n).origin.trim()}catch(t){return e?.error({url:n,err:t},"Invalid URL in check"),!1}}import Vo from"yaml";import{z as rS}from"zod";import{execSync as HA}from"child_process";function Yr(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{HA(r,{encoding:"utf-8"})}catch(o){b.warn({err:o,postSaveCommand:r},"Failed to execute post-save hook command, continuing...")}}import{diff as eS}from"deep-object-diff";import ur from"fs";import{cloneDeep as jA}from"lodash-es";import kd from"path";import{v4 as $A}from"uuid";import ga from"yaml";function Jr({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=ga.parse(a),l;if(n.name&&n.name!==s.name){let m=`${Me(n.name)}.${_t.MODULE}`;if(l=kd.join(kd.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=Gn({fileType:Ie.MODULE,...Ed.parse(c),steps:Ee.array().parse(n.steps)}),p=eS(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=ga.stringify(d);ur.writeFileSync(i,u,"utf-8"),l&&ur.renameSync(i,l),Yr(l||i,r.config)}function tS({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=Wn(i,o),s={...a,...e},l=Gn({fileType:Ie.MODULE,...Ed.parse(s),steps:a.steps}),c=eS(l,a);if(c&&Object.keys(c).length===0){b.debug(`Skipping save for module ${n} since there are no changes`);return}let d=ga.stringify(l);ur.writeFileSync(i,d,"utf-8"),Yr(i,r.config)}async function nS({name:n,description:e,enabled:t,steps:r,folder:o,project:i}){let a=Me(n),s=kd.join(o,`${a}.module.yaml`),l=$A(),{stepsToSave:c}=await Dt({stepLists:{steps:r}}),d={fileType:Ie.MODULE,schemaVersion:De,moduleId:l,name:n,description:e,enabled:t,steps:c.steps},p=ga.stringify(d);return ur.writeFileSync(s,p,"utf-8"),Yr(s,i.config),{moduleId:l,name:n,description:e,enabled:t,steps:r}}function Wn(n,e){let t=ur.readFileSync(n,"utf-8"),r=ga.parse(t);try{return Cd.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 _d(n,e,t,r){let o=Wn(n.fullFilePath,t),{resolvedSteps:i}=await Ks({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 Wn(l,t)}}}),a={...o,steps:i};return r&&(r[n.id]=jA(a)),a}async function Zs(n,e){let t={};return await Promise.all(Object.values(n.modules).map(async r=>{await _d(r,n,e,t)})),Array.from(Object.values(t))}async function oS({test:n,name:e,folder:t}){let r=await Xf({test:n});if(Object.keys(r.modules).length)throw new Error("A brand new test should not contain any modules in it");let i=`${Me(e)}.${_t.TEST}`,a=Xr.join(t,i);return hn.writeFileSync(a,r.test,"utf-8"),a}function Dd(n,e,t){let r=Xr.join(t.rootDir,n);if(!hn.existsSync(r))throw new Error(`Test not found at path '${n}' in project '${t.rootDir}'`);let o=hn.readFileSync(r,"utf-8"),i=Vo.parse(o),a,s;if(e.name&&e.name!==i.name){let u=`${Me(e.name)}.${_t.TEST}`;if(a=Xr.join(Xr.dirname(n),u),s=Xr.join(t.rootDir,a),hn.existsSync(s))throw new Error(`Test with name '${e.name}' already exists at path '${s}'`)}let l={...i,...e},c=tn.parse(l),d={fileType:Ie.TEST,...tn.parse(c),beforeSteps:i.beforeSteps??void 0,steps:i.steps,afterSteps:i.afterSteps??void 0},p=Vo.stringify(d);return hn.writeFileSync(r,p,"utf-8"),s&&hn.renameSync(r,s),Yr(r,t.config),{newRelativeTestPath:a}}function Vn({relativeTestPath:n,steps:e,schemaVersion:t,project:r,forceSaveOnNoDiffs:o}){let i=Xr.join(r.rootDir,n);if(!hn.existsSync(i))throw new Error(`Test not found at path '${n}' in project '${r.rootDir}'`);let a=hn.readFileSync(i,"utf-8"),s=Vo.parse(a),l=tn.parse({...s,schemaVersion:t}),c=Gn({fileType:Ie.TEST,...l,beforeSteps:Ee.array().or(rS.undefined()).parse(e.beforeSteps),steps:Ee.array().parse(e.steps),afterSteps:Ee.array().or(rS.undefined()).parse(e.afterSteps)}),d=GA(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=Vo.stringify(c);hn.writeFileSync(i,p,"utf-8"),b.debug(`Saving test ${l.name} to ${i}`),Yr(i,r.config)}function Qs(n,e){let t=Xr.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=hn.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=Vo.parse(r)}catch(i){throw new Error(`Could not parse test file ${t} as YAML: ${i}`)}return xt.parse(o)}function Zr(n,e,t){let r=t.project.rootDir,o;try{o=hn.readFileSync(n,"utf-8")}catch(a){throw e.error({err:a,projectRoot:r},a.message),new Error(a.message)}let i=Vo.parse(o);if(!i.steps||!Array.isArray(i.steps))throw new Error(`Test ${n} is missing steps`);return i}async function fa(n,e,t){let r=Zr(n,e,t),o;try{o=tn.parse(r)}catch(a){throw new Error(`Test ${n} is missing metadata or has invalid metadata: ${a}`)}let{resolvedTest:i}=await Yf({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 Wn(l,s)}}});return i}import WA from"@dotenvx/dotenvx";import VA from"fs";import iS from"path";function sS(n,e){return(n.config.environments??[]).map(t=>Sa(t.name,n,e))}function aS(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 Sa(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]:aS(r.baseUrl)};if(r.envVariables){let a={};for(let[s,l]of Object.entries(r.envVariables))if(typeof l=="string"){let c=aS(l);c&&(a[s]=c)}else{let c=l.fromFile,d;try{d=VA.readFileSync(iS.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=WA.config({path:iS.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 xP,readFileSync as TP,readdirSync as CP,writeFileSync as RP}from"fs";var IS=QE(wS(),1);var ba=n=>{if(typeof n!="string")throw new TypeError("invalid pattern");if(n.length>65536)throw new TypeError("pattern is too long")};var eI={"[: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]},wa=n=>n.replace(/[[\]\\-]/g,"\\$&"),tI=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),vS=n=>n.join(""),ES=(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(eI))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(wa(p)+"-"+wa(g)):g===p&&r.push(wa(g)),p="",i++;continue}if(n.startsWith("-]",i+1)){r.push(wa(g+"-")),i+=2;continue}if(n.startsWith("-",i+1)){p=g,i+=2;continue}r.push(wa(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[tI(g),!1,d-t,!1]}let u="["+(c?"^":"")+vS(r)+"]",m="["+(c?"":"^")+vS(o)+"]";return[r.length&&o.length?"("+u+"|"+m+")":r.length?u:m,s,d-t,!0]};var gn=(n,{windowsPathsNoEscape:e=!1}={})=>e?n.replace(/\[([^\/\\])\]/g,"$1"):n.replace(/((?!\\).|^)\[([^\/\\])\]/g,"$1$2").replace(/\\([^\/])/g,"$1");var nI=new Set(["!","?","+","*","@"]),xS=n=>nI.has(n),rI="(?!(?:^|/)\\.\\.?(?:$|/))",el="(?!\\.)",oI=new Set(["[","."]),iI=new Set(["..","."]),aI=new Set("().*{}+?[]^$\\!"),sI=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),Bd="[^/]",TS=Bd+"*?",CS=Bd+"+?",qo=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&&xS(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(xS(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&&iI.has(this.#r[0]))){let h=oI,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?rI:f?el:""}let p="";return this.isEnd()&&this.#e.#p&&this.#a?.type==="!"&&(p="(?:$|\\/)"),[d+c+p,gn(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,gn(this.toString()),!1,!1]}let a=!r||e||t||!el?"":this.#m(!0);a===i&&(a=""),a&&(i=`(?:${i})(?:${a})*?`);let s="";if(this.type==="!"&&this.#o)s=(this.isStart()&&!t?el:"")+CS;else{let l=this.type==="!"?"))"+(this.isStart()&&!t&&!e?el:"")+TS+")":this.type==="@"?")":this.type==="?"?")?":this.type==="+"&&a?")":this.type==="*"&&a?")?":`)${this.type}`;s=o+i+l}return[s,gn(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+=(aI.has(l)?"\\":"")+l;continue}if(l==="\\"){s===e.length-1?i+="\\\\":o=!0;continue}if(l==="["){let[c,d,p,u]=ES(e,s);if(p){i+=c,a=a||d,s+=p-1,t=t||u;continue}}if(l==="*"){r&&e==="*"?i+=CS:i+=TS,t=!0;continue}if(l==="?"){i+=Bd,t=!0;continue}i+=sI(l)}return[i,gn(e),!!t,a]}};var Ko=(n,{windowsPathsNoEscape:e=!1}={})=>e?n.replace(/[?*()[\]]/g,"[$&]"):n.replace(/[?*()[\]\\]/g,"\\$&");var Tt=(n,e,t={})=>(ba(e),!t.nocomment&&e.charAt(0)==="#"?!1:new Ht(e,t).match(n)),lI=/^\*+([^+@!?\*\[\(]*)$/,cI=n=>e=>!e.startsWith(".")&&e.endsWith(n),dI=n=>e=>e.endsWith(n),pI=n=>(n=n.toLowerCase(),e=>!e.startsWith(".")&&e.toLowerCase().endsWith(n)),uI=n=>(n=n.toLowerCase(),e=>e.toLowerCase().endsWith(n)),mI=/^\*+\.\*+$/,hI=n=>!n.startsWith(".")&&n.includes("."),gI=n=>n!=="."&&n!==".."&&n.includes("."),fI=/^\.\*+$/,SI=n=>n!=="."&&n!==".."&&n.startsWith("."),yI=/^\*+$/,bI=n=>n.length!==0&&!n.startsWith("."),wI=n=>n.length!==0&&n!=="."&&n!=="..",vI=/^\?+([^+@!?\*\[\(]*)?$/,EI=([n,e=""])=>{let t=PS([n]);return e?(e=e.toLowerCase(),r=>t(r)&&r.toLowerCase().endsWith(e)):t},xI=([n,e=""])=>{let t=LS([n]);return e?(e=e.toLowerCase(),r=>t(r)&&r.toLowerCase().endsWith(e)):t},TI=([n,e=""])=>{let t=LS([n]);return e?r=>t(r)&&r.endsWith(e):t},CI=([n,e=""])=>{let t=PS([n]);return e?r=>t(r)&&r.endsWith(e):t},PS=([n])=>{let e=n.length;return t=>t.length===e&&!t.startsWith(".")},LS=([n])=>{let e=n.length;return t=>t.length===e&&t!=="."&&t!==".."},OS=typeof process=="object"&&process?typeof process.env=="object"&&process.env&&process.env.__MINIMATCH_TESTING_PLATFORM__||process.platform:"posix",RS={win32:{sep:"\\"},posix:{sep:"/"}},RI=OS==="win32"?RS.win32.sep:RS.posix.sep;Tt.sep=RI;var lt=Symbol("globstar **");Tt.GLOBSTAR=lt;var AI="[^/]",II=AI+"*?",PI="(?:(?!(?:\\/|^)(?:\\.{1,2})($|\\/)).)*?",LI="(?:(?!(?:\\/|^)\\.).)*?",OI=(n,e={})=>t=>Tt(t,n,e);Tt.filter=OI;var nn=(n,e={})=>Object.assign({},n,e),NI=n=>{if(!n||typeof n!="object"||!Object.keys(n).length)return Tt;let e=Tt;return Object.assign((r,o,i={})=>e(r,o,nn(n,i)),{Minimatch:class extends e.Minimatch{constructor(o,i={}){super(o,nn(n,i))}static defaults(o){return e.defaults(nn(n,o)).Minimatch}},AST:class extends e.AST{constructor(o,i,a={}){super(o,i,nn(n,a))}static fromGlob(o,i={}){return e.AST.fromGlob(o,nn(n,i))}},unescape:(r,o={})=>e.unescape(r,nn(n,o)),escape:(r,o={})=>e.escape(r,nn(n,o)),filter:(r,o={})=>e.filter(r,nn(n,o)),defaults:r=>e.defaults(nn(n,r)),makeRe:(r,o={})=>e.makeRe(r,nn(n,o)),braceExpand:(r,o={})=>e.braceExpand(r,nn(n,o)),match:(r,o,i={})=>e.match(r,o,nn(n,i)),sep:e.sep,GLOBSTAR:lt})};Tt.defaults=NI;var NS=(n,e={})=>(ba(n),e.nobrace||!/\{(?:(?!\{).)*\}/.test(n)?[n]:(0,IS.default)(n));Tt.braceExpand=NS;var MI=(n,e={})=>new Ht(n,e).makeRe();Tt.makeRe=MI;var kI=(n,e,t={})=>{let r=new Ht(e,t);return n=n.filter(o=>r.match(o)),r.options.nonull&&!n.length&&n.push(e),n};Tt.match=kI;var AS=/[?*]|[+@!]\(.*?\)|\[|\]/,_I=n=>n.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),Ht=class{options;set;pattern;windowsPathsNoEscape;nonegate;negate;comment;empty;preserveMultipleSlashes;partial;globSet;globParts;nocase;isWindows;platform;windowsNoMagicRoot;regexp;constructor(e,t={}){ba(e),t=t||{},this.options=t,this.pattern=e,this.platform=t.platform||OS,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]==="?"||!AS.test(i[2]))&&!AS.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[T,C]=[e[E],t[y]];T.toLowerCase()===C.toLowerCase()&&(t[y]=T,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 NS(this.pattern,this.options)}parse(e){ba(e);let t=this.options;if(e==="**")return lt;if(e==="")return"";let r,o=null;(r=e.match(SI))?o=t.dot?bI:yI:(r=e.match(sI))?o=(t.nocase?t.dot?pI:dI:t.dot?cI:lI)(r[1]):(r=e.match(wI))?o=(t.nocase?t.dot?xI:vI:t.dot?EI:TI)(r):(r=e.match(uI))?o=t.dot?hI:mI:(r=e.match(gI))&&(o=fI);let i=Ko.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?AI:t.dot?II:PI,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"?kI(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 Tt.defaults(e).Minimatch}};Tt.AST=Ko;Tt.Minimatch=Ht;Tt.escape=Yo;Tt.unescape=gn;import{fileURLToPath as uP}from"node:url";var Jo=typeof performance=="object"&&performance&&typeof performance.now=="function"?performance:Date,_S=new Set,zd=typeof process=="object"&&process?process:{},DS=(n,e,t,r)=>{typeof zd.emitWarning=="function"?zd.emitWarning(n,e,t,r):console.error(`[${t}] ${e}: ${n}`)},tl=globalThis.AbortController,kS=globalThis.AbortSignal;if(typeof tl>"u"){kS=class{onabort;_onabort=[];reason;aborted=!1;addEventListener(r,o){this._onabort.push(o)}},tl=class{constructor(){e()}signal=new kS;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=zd.env?.LRU_CACHE_IGNORE_AC_WARNING!=="1",e=()=>{n&&(n=!1,DS("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=>!_S.has(n),$3=Symbol("type"),mr=n=>n&&n===Math.floor(n)&&n>0&&isFinite(n),FS=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?Xo:null:null,Xo=class extends Array{constructor(e){super(e),this.fill(0)}},Hd=class n{heap;length;static#e=!1;static create(e){let t=FS(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]}},va=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;#T;#C;#b;#v;#x;#h;static unsafeExposeInternals(e){return{starts:e.#C,ttls:e.#b,sizes:e.#T,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:x,allowStaleOnFetchRejection:y,allowStaleOnFetchAbort:T,ignoreFetchAbort:C}=e;if(t!==0&&!mr(t))throw new TypeError("max option must be a nonnegative integer");let R=t?FS(t):Array;if(!R)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.#x=!!f,this.#s=new Map,this.#l=new Array(t).fill(void 0),this.#o=new Array(t).fill(void 0),this.#f=new R(t),this.#S=new R(t),this.#m=0,this.#u=0,this.#E=Hd.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=!!T,this.ignoreFetchAbort=!!C,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=!!x,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 L="LRU_CACHE_UNBOUNDED";_I(L)&&(_S.add(L),DS("TTL caching without ttlAutopurge, max, or maxSize can result in unbounded memory consumption.","UnboundedCacheWarning",L,n))}}getRemainingTTL(e){return this.#s.has(e)?1/0:0}#P(){let e=new Xo(this.#e),t=new Xo(this.#e);this.#b=e,this.#C=t,this.#M=(i,a,s=Jo.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?Jo.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=Jo.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 Xo(this.#e);this.#p=0,this.#T=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-(Jo.now()-s);i.ttl=l,i.start=Date.now()}}return this.#T&&(i.size=this.#T[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=Jo.now()-this.#C[t];a.start=Math.floor(Date.now()-s)}this.#T&&(a.size=this.#T[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=Jo.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.#x&&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.#x&&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 tl,{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 x=m;return this.#o[t]===m&&(g===void 0?x.__staleWhileFetching?this.#o[t]=x.__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,x=w||r.noDeleteOnFetchRejection,y=m;if(this.#o[t]===m&&(!x||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.#x)return!1;let t=e;return!!t&&t instanceof Promise&&t.hasOwnProperty("__staleWhileFetching")&&t.__abortController instanceof tl}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.#x)return S&&(S.fetch="get"),this.get(e,{allowStale:r,updateAgeOnGet:o,noDeleteOnStaleGet:i,status:S});let x={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 T=this.#U(e,y,x,g);return T.__returned=T}else{let T=this.#o[y];if(this.#d(T)){let H=r&&T.__staleWhileFetching!==void 0;return S&&(S.fetch="inflight",H&&(S.returnedStale=!0)),H?T.__staleWhileFetching:T.__returned=T}let C=this.#y(y);if(!f&&!C)return S&&(S.fetch="hit"),this.#z(y),o&&this.#R(y),S&&this.#n(S,y),T;let R=this.#U(e,y,x,g),N=R.__staleWhileFetching!==void 0&&r;return S&&(S.fetch=C?"stale":"refresh",N&&C&&(S.returnedStale=!0)),N?R.__staleWhileFetching:R.__returned=R}}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.#T&&this.#T.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 VI,win32 as Xd}from"node:path";import{fileURLToPath as qI}from"node:url";import{lstatSync as KI,readdir as YI,readdirSync as JI,readlinkSync as XI,realpathSync as ZI}from"fs";import*as QI from"node:fs";import{lstat as tP,readdir as nP,readlink as rP,realpath as oP}from"node:fs/promises";import{EventEmitter as Kd}from"node:events";import jS from"node:stream";import{StringDecoder as DI}from"node:string_decoder";var US=typeof process=="object"&&process?process:{stdout:null,stderr:null},FI=n=>!!n&&typeof n=="object"&&(n instanceof gr||n instanceof jS||UI(n)||BI(n)),UI=n=>!!n&&typeof n=="object"&&n instanceof Kd&&typeof n.pipe=="function"&&n.pipe!==jS.Writable.prototype.pipe,BI=n=>!!n&&typeof n=="object"&&n instanceof Kd&&typeof n.write=="function"&&typeof n.end=="function",qn=Symbol("EOF"),Kn=Symbol("maybeEmitEnd"),hr=Symbol("emittedEnd"),nl=Symbol("emittingEnd"),xa=Symbol("emittedError"),rl=Symbol("closed"),BS=Symbol("read"),ol=Symbol("flush"),zS=Symbol("flushChunk"),fn=Symbol("encoding"),Zo=Symbol("decoder"),nt=Symbol("flowing"),Ea=Symbol("paused"),Qo=Symbol("resume"),rt=Symbol("buffer"),Ct=Symbol("pipes"),ot=Symbol("bufferLength"),jd=Symbol("bufferPush"),il=Symbol("bufferShift"),ht=Symbol("objectMode"),$e=Symbol("destroyed"),$d=Symbol("error"),Gd=Symbol("emitData"),HS=Symbol("emitEnd"),Wd=Symbol("emitEnd2"),Ln=Symbol("async"),Vd=Symbol("abort"),al=Symbol("aborted"),Ta=Symbol("signal"),eo=Symbol("dataListeners"),jt=Symbol("discarded"),Ca=n=>Promise.resolve().then(n),zI=n=>n(),HI=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,$I=n=>!Buffer.isBuffer(n)&&ArrayBuffer.isView(n),sl=class{src;dest;opts;ondrain;constructor(e,t,r){this.src=e,this.dest=t,this.opts=r,this.ondrain=()=>e[Qo](),this.dest.on("drain",this.ondrain)}unpipe(){this.dest.removeListener("drain",this.ondrain)}proxyErrors(e){}end(){this.unpipe(),this.opts.end&&this.dest.end()}},qd=class extends sl{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)}},GI=n=>!!n.objectMode,WI=n=>!n.objectMode&&!!n.encoding&&n.encoding!=="buffer",gr=class extends Kd{[nt]=!1;[Ea]=!1;[Ct]=[];[rt]=[];[ht];[fn];[Ln];[Zo];[qn]=!1;[hr]=!1;[nl]=!1;[rl]=!1;[xa]=null;[ot]=0;[$e]=!1;[Ta];[al]=!1;[eo]=0;[jt]=!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");GI(t)?(this[ht]=!0,this[fn]=null):WI(t)?(this[fn]=t.encoding,this[ht]=!1):(this[ht]=!1,this[fn]=null),this[Ln]=!!t.async,this[Zo]=this[fn]?new DI(this[fn]):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[Vd]():r.addEventListener("abort",()=>this[Vd]()))}get bufferLength(){return this[ot]}get encoding(){return this[fn]}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[ht]}set objectMode(e){throw new Error("objectMode must be set at instantiation time")}get async(){return this[Ln]}set async(e){this[Ln]=this[Ln]||!!e}[Vd](){this[al]=!0,this.emit("abort",this[Ta]?.reason),this.destroy(this[Ta]?.reason)}get aborted(){return this[al]}set aborted(e){}write(e,t,r){if(this[al])return!1;if(this[qn])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[Ln]?Ca:zI;if(!this[ht]&&!Buffer.isBuffer(e)){if($I(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[ht]?(this[nt]&&this[ot]!==0&&this[ol](!0),this[nt]?this.emit("data",e):this[jd](e),this[ot]!==0&&this.emit("readable"),r&&o(r),this[nt]):e.length?(typeof e=="string"&&!(t===this[fn]&&!this[Zo]?.lastNeed)&&(e=Buffer.from(e,t)),Buffer.isBuffer(e)&&this[fn]&&(e=this[Zo].write(e)),this[nt]&&this[ot]!==0&&this[ol](!0),this[nt]?this.emit("data",e):this[jd](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[jt]=!1,this[ot]===0||e===0||e&&e>this[ot])return this[Kn](),null;this[ht]&&(e=null),this[rt].length>1&&!this[ht]&&(this[rt]=[this[fn]?this[rt].join(""):Buffer.concat(this[rt],this[ot])]);let t=this[BS](e||null,this[rt][0]);return this[Kn](),t}[BS](e,t){if(this[ht])this[il]();else{let r=t;e===r.length||e===null?this[il]():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[qn]&&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[qn]=!0,this.writable=!1,(this[nt]||!this[Ea])&&this[Kn](),this}[Qo](){this[$e]||(!this[eo]&&!this[Ct].length&&(this[jt]=!0),this[Ea]=!1,this[nt]=!0,this.emit("resume"),this[rt].length?this[ol]():this[qn]?this[Kn]():this.emit("drain"))}resume(){return this[Qo]()}pause(){this[nt]=!1,this[Ea]=!0,this[jt]=!1}get destroyed(){return this[$e]}get flowing(){return this[nt]}get paused(){return this[Ea]}[jd](e){this[ht]?this[ot]+=1:this[ot]+=e.length,this[rt].push(e)}[il](){return this[ht]?this[ot]-=1:this[ot]-=this[rt][0].length,this[rt].shift()}[ol](e=!1){do;while(this[zS](this[il]())&&this[rt].length);!e&&!this[rt].length&&!this[qn]&&this.emit("drain")}[zS](e){return this.emit("data",e),this[nt]}pipe(e,t){if(this[$e])return e;this[jt]=!1;let r=this[hr];return t=t||{},e===US.stdout||e===US.stderr?t.end=!1:t.end=t.end!==!1,t.proxyErrors=!!t.proxyErrors,r?t.end&&e.end():(this[Ct].push(t.proxyErrors?new qd(this,e,t):new sl(this,e,t)),this[Ln]?Ca(()=>this[Qo]()):this[Qo]()),e}unpipe(e){let t=this[Ct].find(r=>r.dest===e);t&&(this[Ct].length===1?(this[nt]&&this[eo]===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[jt]=!1,this[eo]++,!this[Ct].length&&!this[nt]&&this[Qo]();else if(e==="readable"&&this[ot]!==0)super.emit("readable");else if(HI(e)&&this[hr])super.emit(e),this.removeAllListeners(e);else if(e==="error"&&this[xa]){let o=t;this[Ln]?Ca(()=>o.call(this,this[xa])):o.call(this,this[xa])}return r}removeListener(e,t){return this.off(e,t)}off(e,t){let r=super.off(e,t);return e==="data"&&(this[eo]=this.listeners("data").length,this[eo]===0&&!this[jt]&&!this[Ct].length&&(this[nt]=!1)),r}removeAllListeners(e){let t=super.removeAllListeners(e);return(e==="data"||e===void 0)&&(this[eo]=0,!this[jt]&&!this[Ct].length&&(this[nt]=!1)),t}get emittedEnd(){return this[hr]}[Kn](){!this[nl]&&!this[hr]&&!this[$e]&&this[rt].length===0&&this[qn]&&(this[nl]=!0,this.emit("end"),this.emit("prefinish"),this.emit("finish"),this[rl]&&this.emit("close"),this[nl]=!1)}emit(e,...t){let r=t[0];if(e!=="error"&&e!=="close"&&e!==$e&&this[$e])return!1;if(e==="data")return!this[ht]&&!r?!1:this[Ln]?(Ca(()=>this[Gd](r)),!0):this[Gd](r);if(e==="end")return this[HS]();if(e==="close"){if(this[rl]=!0,!this[hr]&&!this[$e])return!1;let i=super.emit("close");return this.removeAllListeners("close"),i}else if(e==="error"){this[xa]=r,super.emit($d,r);let i=!this[Ta]||this.listeners("error").length?super.emit("error",r):!1;return this[Kn](),i}else if(e==="resume"){let i=super.emit("resume");return this[Kn](),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[Kn](),o}[Gd](e){for(let r of this[Ct])r.dest.write(e)===!1&&this.pause();let t=this[jt]?!1:super.emit("data",e);return this[Kn](),t}[HS](){return this[hr]?!1:(this[hr]=!0,this.readable=!1,this[Ln]?(Ca(()=>this[Wd]()),!0):this[Wd]())}[Wd](){if(this[Zo]){let t=this[Zo].end();if(t){for(let r of this[Ct])r.dest.write(t);this[jt]||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[ht]||(e.dataLength=0);let t=this.promise();return this.on("data",r=>{e.push(r),this[ht]||(e.dataLength+=r.length)}),await t,e}async concat(){if(this[ht])throw new Error("cannot concat in objectMode");let e=await this.collect();return this[fn]?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[jt]=!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[qn])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[qn]})},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[jt]=!1;let e=!1,t=()=>(this.pause(),this.off($d,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($d,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[jt]=!0,this[rt].length=0,this[ot]=0;let t=this;return typeof t.close=="function"&&!this[rl]&&t.close(),e?this.emit("error",e):this.emit($e),this}static get isStream(){return FI}};var eP=ZI.native,Aa={lstatSync:KI,readdir:YI,readdirSync:JI,readlinkSync:XI,realpathSync:eP,promises:{lstat:tP,readdir:nP,readlink:rP,realpath:oP}},qS=n=>!n||n===Aa||n===QI?Aa:{...Aa,...n,promises:{...Aa.promises,...n.promises||{}}},KS=/^\\\\\?\\([a-z]:)\\?$/i,iP=n=>n.replace(/\//g,"\\").replace(KS,"$1\\"),aP=/[\\\/]/,on=0,YS=1,JS=2,On=4,XS=6,ZS=8,to=10,QS=12,rn=15,Ra=~rn,Yd=16,$S=32,Ia=64,Sn=128,ll=256,dl=512,GS=Ia|Sn|dl,sP=1023,Jd=n=>n.isFile()?ZS:n.isDirectory()?On:n.isSymbolicLink()?to:n.isCharacterDevice()?JS:n.isBlockDevice()?XS:n.isSocket()?QS:n.isFIFO()?YS:on,WS=new Map,Pa=n=>{let e=WS.get(n);if(e)return e;let t=n.normalize("NFKD");return WS.set(n,t),t},VS=new Map,cl=n=>{let e=VS.get(n);if(e)return e;let t=Pa(n.toLowerCase());return VS.set(n,t),t},pl=class extends va{constructor(){super({max:256})}},Zd=class extends va{constructor(e=16*1024){super({maxSize:e,sizeCalculation:t=>t.length+1})}},ey=Symbol("PathScurry setAsCwd"),gt=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}#T;get ctime(){return this.#T}#C;get birthtime(){return this.#C}#b;#v;#x;#h;#P;#R;#n;#M;#y;#L;get parentPath(){return(this.parent||this).fullpath()}get path(){return this.parentPath}constructor(e,t=on,r,o,i,a,s){this.name=e,this.#b=i?cl(e):Pa(e),this.#n=t&sP,this.nocase=i,this.roots=o,this.root=r||this,this.#M=a,this.#x=s.fullpath,this.#P=s.relative,this.#R=s.relativePosix,this.parent=s.parent,this.parent?this.#e=this.parent.#e:this.#e=qS(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&=~Yd,t}child(e,t){if(e===""||e===".")return this;if(e==="..")return this.parent||this;let r=this.children(),o=this.nocase?cl(e):Pa(e);for(let l of r)if(l.#b===o)return l;let i=this.parent?this.sep:"",a=this.#x?this.#x+i+e:void 0,s=this.newChild(e,on,{...t,parent:this,fullpath:a});return this.canReaddir()||(s.#n|=Sn),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.#x!==void 0)return this.#x;let e=this.name,t=this.parent;if(!t)return this.#x=this.name;let o=t.fullpath()+(t.parent?this.sep:"")+e;return this.#x=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&rn)===on}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&rn)===ZS}isDirectory(){return(this.#n&rn)===On}isCharacterDevice(){return(this.#n&rn)===JS}isBlockDevice(){return(this.#n&rn)===XS}isFIFO(){return(this.#n&rn)===YS}isSocket(){return(this.#n&rn)===QS}isSymbolicLink(){return(this.#n&to)===to}lstatCached(){return this.#n&$S?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&rn;return!(e!==on&&e!==to||this.#n&ll||this.#n&Sn)}calledReaddir(){return!!(this.#n&Yd)}isENOENT(){return!!(this.#n&Sn)}isNamed(e){return this.nocase?this.#b===cl(e):this.#b===Pa(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|=Yd;for(let t=e.provisional;t<e.length;t++){let r=e[t];r&&r.#_()}}#_(){this.#n&Sn||(this.#n=(this.#n|Sn)&Ra,this.#A())}#A(){let e=this.children();e.provisional=0;for(let t of e)t.#_()}#I(){this.#n|=dl,this.#D()}#D(){if(this.#n&Ia)return;let e=this.#n;(e&rn)===On&&(e&=Ra),this.#n=e|Ia,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|=ll,e==="ENOENT"&&(t|=Sn),(e==="EINVAL"||e==="UNKNOWN")&&(t&=Ra),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=Jd(e),o=this.newChild(e.name,r,{parent:this}),i=o.#n&rn;return i!==On&&i!==to&&i!==on&&(o.#n|=Ia),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?cl(e.name):Pa(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&Ra|Jd(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&Sn))try{return this.#W(await this.#e.promises.lstat(this.fullpath())),this}catch(e){this.#U(e.code)}}lstatSync(){if(!(this.#n&Sn))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:x}=e;this.#E=t,this.#f=r,this.#C=o,this.#u=i,this.#p=a,this.#o=s,this.#T=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=x;let y=Jd(e);this.#n=this.#n&Ra|y|$S,y!==on&&y!==On&&y!==to&&(this.#n|=Ia)}#$=[];#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&GS)return!1;let e=rn&this.#n;return e===on||e===On||e===to}shouldWalk(e,t){return(this.#n&On)===On&&!(this.#n&GS)&&!e.has(this)&&(!t||t(this))}async realpath(){if(this.#L)return this.#L;if(!((dl|ll|Sn)&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(!((dl|ll|Sn)&this.#n))try{let e=this.#e.realpathSync(this.fullpath());return this.#L=this.resolve(e)}catch{this.#I()}}[ey](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}},ul=class n extends gt{sep="\\";splitSep=aP;constructor(e,t=on,r,o,i,a,s){super(e,t,r,o,i,a,s)}newChild(e,t=on,r={}){return new n(e,t,this.root,this.roots,this.nocase,this.childrenCache(),r)}getRootString(e){return Xd.parse(e).root}getRoot(e){if(e=iP(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 ei(e,this).root}sameRoot(e,t=this.root.name){return e=e.toUpperCase().replace(/\//g,"\\").replace(KS,"$1\\"),e===t}},ml=class n extends gt{splitSep="/";sep="/";constructor(e,t=on,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=on,r={}){return new n(e,t,this.root,this.roots,this.nocase,this.childrenCache(),r)}},hl=class{root;rootPath;roots;cwd;#e;#t;#i;nocase;#r;constructor(e=process.cwd(),t,r,{nocase:o,childrenCacheSize:i=16*1024,fs:a=Aa}={}){this.#r=qS(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 pl,this.#t=new pl,this.#i=new Zd(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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 x=[];for(let y of S)y.isSymbolicLink()&&x.push(y.realpath().then(T=>T?.isUnknown()?T.lstat():T));if(x.length){Promise.all(x).then(()=>h(null,S,!0));return}}for(let x of S)x&&(!i||i(x))&&(s.write(r?x:x.fullpath())||(u=!0));d--;for(let x of S){let y=x.realpathCached()||x;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 gt||(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[ey](t)}},ei=class extends hl{sep="\\";constructor(e=process.cwd(),t={}){let{nocase:r=!0}=t;super(e,Xd,"\\",{...t,nocase:r}),this.nocase=r;for(let o=this.cwd;o;o=o.parent)o.nocase=this.nocase}parseRootPath(e){return Xd.parse(e).root.toUpperCase()}newRoot(e){return new ul(this.rootPath,On,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")||e.startsWith("\\")||/^[a-z]:(\/|\\)/i.test(e)}},ti=class extends hl{sep="/";constructor(e=process.cwd(),t={}){let{nocase:r=!1}=t;super(e,VI,"/",{...t,nocase:r}),this.nocase=r}parseRootPath(e){return"/"}newRoot(e){return new ml(this.rootPath,On,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")}},La=class extends ti{constructor(e=process.cwd(),t={}){let{nocase:r=!0}=t;super(e,{...t,nocase:r})}},t4=process.platform==="win32"?ul:ml,ty=process.platform==="win32"?ei:process.platform==="darwin"?La:ti;var lP=n=>n.length>=1,cP=n=>n.length>=1,ni=class n{#e;#t;#i;length;#r;#a;#w;#c;#p;#s;#l=!0;constructor(e,t,r,o){if(!lP(e))throw new TypeError("empty pattern list");if(!cP(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 dP=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",ri=class{relative;relativeChildren;absolute;absoluteChildren;platform;mmopts;constructor(e,{nobrace:t,nocase:r,noext:o,noglobstar:i,platform:a=dP}){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 Ht(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 ni(o,i,0,this.platform),s=new Ht(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 Qd=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()]))}},ep=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)])}},tp=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())}},Oa=class n{hasWalkedCache;matches=new ep;subwalks=new tp;patterns;follow;dot;opts;constructor(e,t){this.opts=e,this.follow=!!e.follow,this.dot=!!e.dot,this.hasWalkedCache=t?t.copy():new Qd}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 pP=(n,e)=>typeof n=="string"?new ri([n],e):Array.isArray(n)?new ri(n,e):n,gl=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=pP(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 Oa(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 Oa(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()}},Ma=class extends gl{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}},Na=class extends gl{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 mP=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",yn=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=uP(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||mP,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"?ei:t.platform==="darwin"?La:t.platform?ti:ty;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 Ht(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 ni(l,d,0,this.platform)})}async walk(){return[...await new Ma(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 Ma(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 Na(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 Na(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 np=(n,e={})=>{Array.isArray(n)||(n=[n]);for(let t of n)if(new Ht(t,e).hasMagic())return!0;return!1};function fl(n,e={}){return new yn(n,e).streamSync()}function oy(n,e={}){return new yn(n,e).stream()}function oi(n,e={}){return new yn(n,e).walkSync()}async function ny(n,e={}){return new yn(n,e).walk()}function Sl(n,e={}){return new yn(n,e).iterateSync()}function iy(n,e={}){return new yn(n,e).iterate()}var hP=fl,gP=Object.assign(oy,{sync:fl}),fP=Sl,SP=Object.assign(iy,{sync:Sl}),yP=Object.assign(oi,{stream:fl,iterate:Sl}),ry=Object.assign(ny,{glob:ny,globSync:oi,sync:yP,globStream:oy,stream:gP,globStreamSync:fl,streamSync:hP,globIterate:iy,iterate:SP,globIterateSync:Sl,iterateSync:fP,Glob:yn,hasMagic:np,escape:Yo,unescape:gn});ry.glob=ry;import no,{dirname as cy}from"path";import{cwd as sp}from"process";import dy from"yaml";import{z as ue}from"zod";import ay from"fs";import ka from"path";import bP from"yaml";import{z as rp}from"zod";var sy=!1,op=[`**/*.${_t.TEST}`,`**/*.${_t.MODULE}`],ip=rp.string().refine(n=>/^[a-zA-Z0-9-]+$/.test(n)),ap=50,wP=rp.object({fileType:rp.nativeEnum(Ie)});function we(n,e){let t={project:n,tests:{},modules:{}},r=n.config.include??op,o=Array.from(n.config.exclude??[]).concat(mg),i=oi(r,{absolute:!1,cwd:n.rootDir,ignore:o,dotRelative:!1,maxDepth:ap,nodir:!0});for(let a of i)vP(n.rootDir,a,t,e);return sy=!0,t}function vP(n,e,t,r){let o=ka.join(n,e),i;try{i=ay.readFileSync(o,"utf-8")}catch(p){r.warn(`Could not read possible Momentic file at ${o}, skipping: ${p}`);return}let a;try{if(a=bP.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=wP.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=ay.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:ka.sep,fullPathSegments:o.split(ka.sep),relativePathSegments:e.split(ka.sep),fileName:ka.basename(o),lastModified:c.mtime,createdAt:c.birthtime};switch(l){case Ie.TEST:try{let p=tn.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 NS(this.pattern,this.options)}parse(e){ba(e);let t=this.options;if(e==="**")return lt;if(e==="")return"";let r,o=null;(r=e.match(yI))?o=t.dot?wI:bI:(r=e.match(lI))?o=(t.nocase?t.dot?uI:pI:t.dot?dI:cI)(r[1]):(r=e.match(vI))?o=(t.nocase?t.dot?xI:EI:t.dot?TI:CI)(r):(r=e.match(mI))?o=t.dot?gI:hI:(r=e.match(fI))&&(o=SI);let i=qo.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?II:t.dot?PI:LI,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"?_I(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 Tt.defaults(e).Minimatch}};Tt.AST=qo;Tt.Minimatch=Ht;Tt.escape=Ko;Tt.unescape=gn;import{fileURLToPath as mP}from"node:url";var Yo=typeof performance=="object"&&performance&&typeof performance.now=="function"?performance:Date,kS=new Set,zd=typeof process=="object"&&process?process:{},_S=(n,e,t,r)=>{typeof zd.emitWarning=="function"?zd.emitWarning(n,e,t,r):console.error(`[${t}] ${e}: ${n}`)},tl=globalThis.AbortController,MS=globalThis.AbortSignal;if(typeof tl>"u"){MS=class{onabort;_onabort=[];reason;aborted=!1;addEventListener(r,o){this._onabort.push(o)}},tl=class{constructor(){e()}signal=new MS;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=zd.env?.LRU_CACHE_IGNORE_AC_WARNING!=="1",e=()=>{n&&(n=!1,_S("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 DI=n=>!kS.has(n),G3=Symbol("type"),mr=n=>n&&n===Math.floor(n)&&n>0&&isFinite(n),DS=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?Jo:null:null,Jo=class extends Array{constructor(e){super(e),this.fill(0)}},Hd=class n{heap;length;static#e=!1;static create(e){let t=DS(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]}},va=class n{#e;#t;#i;#r;#a;#w;ttl;ttlResolution;ttlAutopurge;updateAgeOnGet;updateAgeOnHas;allowStale;noDisposeOnSet;noUpdateTTL;maxEntrySize;sizeCalculation;noDeleteOnFetchRejection;noDeleteOnStaleGet;allowStaleOnFetchAbort;allowStaleOnFetchRejection;ignoreFetchAbort;#c;#p;#s;#l;#o;#f;#S;#m;#u;#x;#g;#T;#C;#b;#v;#E;#h;static unsafeExposeInternals(e){return{starts:e.#C,ttls:e.#b,sizes:e.#T,keyMap:e.#s,keyList:e.#l,valList:e.#o,next:e.#f,prev:e.#S,get head(){return e.#m},get tail(){return e.#u},free:e.#x,isBackgroundFetch:t=>e.#d(t),backgroundFetch:(t,r,o,i)=>e.#U(t,r,o,i),moveToTail:t=>e.#z(t),indexes:t=>e.#A(t),rindexes:t=>e.#I(t),isStale:t=>e.#y(t)}}get max(){return this.#e}get maxSize(){return this.#t}get calculatedSize(){return this.#p}get size(){return this.#c}get fetchMethod(){return this.#a}get memoMethod(){return this.#w}get dispose(){return this.#i}get disposeAfter(){return this.#r}constructor(e){let{max:t=0,ttl:r,ttlResolution:o=1,ttlAutopurge:i,updateAgeOnGet:a,updateAgeOnHas:s,allowStale:l,dispose:c,disposeAfter:d,noDisposeOnSet:p,noUpdateTTL:u,maxSize:m=0,maxEntrySize:h=0,sizeCalculation:g,fetchMethod:f,memoMethod:S,noDeleteOnFetchRejection:w,noDeleteOnStaleGet:E,allowStaleOnFetchRejection:y,allowStaleOnFetchAbort:T,ignoreFetchAbort:C}=e;if(t!==0&&!mr(t))throw new TypeError("max option must be a nonnegative integer");let R=t?DS(t):Array;if(!R)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 R(t),this.#S=new R(t),this.#m=0,this.#u=0,this.#x=Hd.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=!!T,this.ignoreFetchAbort=!!C,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 L="LRU_CACHE_UNBOUNDED";DI(L)&&(kS.add(L),_S("TTL caching without ttlAutopurge, max, or maxSize can result in unbounded memory consumption.","UnboundedCacheWarning",L,n))}}getRemainingTTL(e){return this.#s.has(e)?1/0:0}#P(){let e=new Jo(this.#e),t=new Jo(this.#e);this.#b=e,this.#C=t,this.#N=(i,a,s=Yo.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?Yo.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=Yo.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=()=>{};#N=()=>{};#y=()=>!1;#L(){let e=new Jo(this.#e);this.#p=0,this.#T=e,this.#M=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)}}#M=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-(Yo.now()-s);i.ttl=l,i.start=Date.now()}}return this.#T&&(i.size=this.#T[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=Yo.now()-this.#C[t];a.start=Math.floor(Date.now()-s)}this.#T&&(a.size=this.#T[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=Yo.now()-o}this.set(t,r.value,r)}}set(e,t,r={}){if(t===void 0)return this.delete(e),this;let{ttl:o=this.ttl,start:i,noDisposeOnSet:a=this.noDisposeOnSet,sizeCalculation:s=this.sizeCalculation,status:l}=r,{noUpdateTTL:c=this.noUpdateTTL}=r,d=this.#_(e,t,r.size||0,s);if(this.maxEntrySize&&d>this.maxEntrySize)return l&&(l.set="miss",l.maxEntrySizeExceeded=!0),this.#O(e,"set"),this;let p=this.#c===0?void 0:this.#s.get(e);if(p===void 0)p=this.#c===0?this.#u:this.#x.length!==0?this.#x.pop():this.#c===this.#e?this.#F(!1):this.#c,this.#l[p]=e,this.#o[p]=t,this.#s.set(e,p),this.#f[this.#u]=p,this.#S[p]=this.#u,this.#u=p,this.#c++,this.#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.#M(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.#N(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.#M(t),e&&(this.#l[t]=void 0,this.#o[t]=void 0,this.#x.push(t)),this.#c===1?(this.#m=this.#u=0,this.#x.length=0):this.#m=this.#f[t],this.#s.delete(r),this.#c--,t}has(e,t={}){let{updateAgeOnHas:r=this.updateAgeOnHas,status:o}=t,i=this.#s.get(e);if(i!==void 0){let a=this.#o[i];if(this.#d(a)&&a.__staleWhileFetching===void 0)return!1;if(this.#y(i))o&&(o.has="stale",this.#n(o,i));else return r&&this.#R(i),o&&(o.has="hit",this.#n(o,i)),!0}else o&&(o.has="miss");return!1}peek(e,t={}){let{allowStale:r=this.allowStale}=t,o=this.#s.get(e);if(o===void 0||!r&&this.#y(o))return;let i=this.#o[o];return this.#d(i)?i.__staleWhileFetching:i}#U(e,t,r,o){let i=t===void 0?void 0:this.#o[t];if(this.#d(i))return i;let a=new tl,{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 tl}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 T=this.#U(e,y,E,g);return T.__returned=T}else{let T=this.#o[y];if(this.#d(T)){let H=r&&T.__staleWhileFetching!==void 0;return S&&(S.fetch="inflight",H&&(S.returnedStale=!0)),H?T.__staleWhileFetching:T.__returned=T}let C=this.#y(y);if(!f&&!C)return S&&(S.fetch="hit"),this.#z(y),o&&this.#R(y),S&&this.#n(S,y),T;let R=this.#U(e,y,E,g),M=R.__staleWhileFetching!==void 0&&r;return S&&(S.fetch=C?"stale":"refresh",M&&C&&(S.returnedStale=!0)),M?R.__staleWhileFetching:R.__returned=R}}async forceFetch(e,t={}){let r=await this.fetch(e,t);if(r===void 0)throw new Error("fetch() returned undefined");return r}memo(e,t={}){let r=this.#w;if(!r)throw new Error("no memoMethod provided to constructor");let{context:o,forceRefresh:i,...a}=t,s=this.get(e,a);if(!i&&s!==void 0)return s;let l=r(e,s,{options:a,context:o});return this.set(e,l,a),l}get(e,t={}){let{allowStale:r=this.allowStale,updateAgeOnGet:o=this.updateAgeOnGet,noDeleteOnStaleGet:i=this.noDeleteOnStaleGet,status:a}=t,s=this.#s.get(e);if(s!==void 0){let l=this.#o[s],c=this.#d(l);return a&&this.#n(a,s),this.#y(s)?(a&&(a.get="stale"),c?(a&&r&&l.__staleWhileFetching!==void 0&&(a.returnedStale=!0),r?l.__staleWhileFetching:void 0):(i||this.#O(e,"expire"),a&&r&&(a.returnedStale=!0),r?l:void 0)):(a&&(a.get="hit"),c?l.__staleWhileFetching:(this.#z(s),o&&this.#R(s),l))}else a&&(a.get="miss")}#B(e,t){this.#S[t]=e,this.#f[e]=t}#z(e){e!==this.#u&&(e===this.#m?this.#m=this.#f[e]:this.#B(this.#S[e],this.#f[e]),this.#B(this.#u,e),this.#u=e)}delete(e){return this.#O(e,"delete")}#O(e,t){let r=!1;if(this.#c!==0){let o=this.#s.get(e);if(o!==void 0)if(r=!0,this.#c===1)this.#H(t);else{this.#M(o);let i=this.#o[o];if(this.#d(i)?i.__abortController.abort(new Error("deleted")):(this.#v||this.#h)&&(this.#v&&this.#i?.(i,e,t),this.#h&&this.#g?.push([i,e,t])),this.#s.delete(e),this.#l[o]=void 0,this.#o[o]=void 0,o===this.#u)this.#u=this.#S[o];else if(o===this.#m)this.#m=this.#f[o];else{let a=this.#S[o];this.#f[a]=this.#f[o];let s=this.#f[o];this.#S[s]=this.#S[o]}this.#c--,this.#x.push(o)}}if(this.#h&&this.#g?.length){let o=this.#g,i;for(;i=o?.shift();)this.#r?.(...i)}return r}clear(){return this.#H("delete")}#H(e){for(let t of this.#I({allowStale:!0})){let r=this.#o[t];if(this.#d(r))r.__abortController.abort(new Error("deleted"));else{let o=this.#l[t];this.#v&&this.#i?.(r,o,e),this.#h&&this.#g?.push([r,o,e])}}if(this.#s.clear(),this.#o.fill(void 0),this.#l.fill(void 0),this.#b&&this.#C&&(this.#b.fill(0),this.#C.fill(0)),this.#T&&this.#T.fill(0),this.#m=0,this.#u=0,this.#x.length=0,this.#p=0,this.#c=0,this.#h&&this.#g){let t=this.#g,r;for(;r=t?.shift();)this.#r?.(...r)}}};import{posix as qI,win32 as Xd}from"node:path";import{fileURLToPath as KI}from"node:url";import{lstatSync as YI,readdir as JI,readdirSync as XI,readlinkSync as ZI,realpathSync as QI}from"fs";import*as eP from"node:fs";import{lstat as nP,readdir as rP,readlink as oP,realpath as iP}from"node:fs/promises";import{EventEmitter as Kd}from"node:events";import HS from"node:stream";import{StringDecoder as FI}from"node:string_decoder";var FS=typeof process=="object"&&process?process:{stdout:null,stderr:null},UI=n=>!!n&&typeof n=="object"&&(n instanceof gr||n instanceof HS||BI(n)||zI(n)),BI=n=>!!n&&typeof n=="object"&&n instanceof Kd&&typeof n.pipe=="function"&&n.pipe!==HS.Writable.prototype.pipe,zI=n=>!!n&&typeof n=="object"&&n instanceof Kd&&typeof n.write=="function"&&typeof n.end=="function",qn=Symbol("EOF"),Kn=Symbol("maybeEmitEnd"),hr=Symbol("emittedEnd"),nl=Symbol("emittingEnd"),Ea=Symbol("emittedError"),rl=Symbol("closed"),US=Symbol("read"),ol=Symbol("flush"),BS=Symbol("flushChunk"),fn=Symbol("encoding"),Xo=Symbol("decoder"),nt=Symbol("flowing"),xa=Symbol("paused"),Zo=Symbol("resume"),rt=Symbol("buffer"),Ct=Symbol("pipes"),ot=Symbol("bufferLength"),jd=Symbol("bufferPush"),il=Symbol("bufferShift"),ht=Symbol("objectMode"),$e=Symbol("destroyed"),$d=Symbol("error"),Gd=Symbol("emitData"),zS=Symbol("emitEnd"),Wd=Symbol("emitEnd2"),Pn=Symbol("async"),Vd=Symbol("abort"),al=Symbol("aborted"),Ta=Symbol("signal"),Qr=Symbol("dataListeners"),jt=Symbol("discarded"),Ca=n=>Promise.resolve().then(n),HI=n=>n(),jI=n=>n==="end"||n==="finish"||n==="prefinish",$I=n=>n instanceof ArrayBuffer||!!n&&typeof n=="object"&&n.constructor&&n.constructor.name==="ArrayBuffer"&&n.byteLength>=0,GI=n=>!Buffer.isBuffer(n)&&ArrayBuffer.isView(n),sl=class{src;dest;opts;ondrain;constructor(e,t,r){this.src=e,this.dest=t,this.opts=r,this.ondrain=()=>e[Zo](),this.dest.on("drain",this.ondrain)}unpipe(){this.dest.removeListener("drain",this.ondrain)}proxyErrors(e){}end(){this.unpipe(),this.opts.end&&this.dest.end()}},qd=class extends sl{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)}},WI=n=>!!n.objectMode,VI=n=>!n.objectMode&&!!n.encoding&&n.encoding!=="buffer",gr=class extends Kd{[nt]=!1;[xa]=!1;[Ct]=[];[rt]=[];[ht];[fn];[Pn];[Xo];[qn]=!1;[hr]=!1;[nl]=!1;[rl]=!1;[Ea]=null;[ot]=0;[$e]=!1;[Ta];[al]=!1;[Qr]=0;[jt]=!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");WI(t)?(this[ht]=!0,this[fn]=null):VI(t)?(this[fn]=t.encoding,this[ht]=!1):(this[ht]=!1,this[fn]=null),this[Pn]=!!t.async,this[Xo]=this[fn]?new FI(this[fn]):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[Vd]():r.addEventListener("abort",()=>this[Vd]()))}get bufferLength(){return this[ot]}get encoding(){return this[fn]}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[ht]}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}[Vd](){this[al]=!0,this.emit("abort",this[Ta]?.reason),this.destroy(this[Ta]?.reason)}get aborted(){return this[al]}set aborted(e){}write(e,t,r){if(this[al])return!1;if(this[qn])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]?Ca:HI;if(!this[ht]&&!Buffer.isBuffer(e)){if(GI(e))e=Buffer.from(e.buffer,e.byteOffset,e.byteLength);else if($I(e))e=Buffer.from(e);else if(typeof e!="string")throw new Error("Non-contiguous data written to non-objectMode stream")}return this[ht]?(this[nt]&&this[ot]!==0&&this[ol](!0),this[nt]?this.emit("data",e):this[jd](e),this[ot]!==0&&this.emit("readable"),r&&o(r),this[nt]):e.length?(typeof e=="string"&&!(t===this[fn]&&!this[Xo]?.lastNeed)&&(e=Buffer.from(e,t)),Buffer.isBuffer(e)&&this[fn]&&(e=this[Xo].write(e)),this[nt]&&this[ot]!==0&&this[ol](!0),this[nt]?this.emit("data",e):this[jd](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[jt]=!1,this[ot]===0||e===0||e&&e>this[ot])return this[Kn](),null;this[ht]&&(e=null),this[rt].length>1&&!this[ht]&&(this[rt]=[this[fn]?this[rt].join(""):Buffer.concat(this[rt],this[ot])]);let t=this[US](e||null,this[rt][0]);return this[Kn](),t}[US](e,t){if(this[ht])this[il]();else{let r=t;e===r.length||e===null?this[il]():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[qn]&&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[qn]=!0,this.writable=!1,(this[nt]||!this[xa])&&this[Kn](),this}[Zo](){this[$e]||(!this[Qr]&&!this[Ct].length&&(this[jt]=!0),this[xa]=!1,this[nt]=!0,this.emit("resume"),this[rt].length?this[ol]():this[qn]?this[Kn]():this.emit("drain"))}resume(){return this[Zo]()}pause(){this[nt]=!1,this[xa]=!0,this[jt]=!1}get destroyed(){return this[$e]}get flowing(){return this[nt]}get paused(){return this[xa]}[jd](e){this[ht]?this[ot]+=1:this[ot]+=e.length,this[rt].push(e)}[il](){return this[ht]?this[ot]-=1:this[ot]-=this[rt][0].length,this[rt].shift()}[ol](e=!1){do;while(this[BS](this[il]())&&this[rt].length);!e&&!this[rt].length&&!this[qn]&&this.emit("drain")}[BS](e){return this.emit("data",e),this[nt]}pipe(e,t){if(this[$e])return e;this[jt]=!1;let r=this[hr];return t=t||{},e===FS.stdout||e===FS.stderr?t.end=!1:t.end=t.end!==!1,t.proxyErrors=!!t.proxyErrors,r?t.end&&e.end():(this[Ct].push(t.proxyErrors?new qd(this,e,t):new sl(this,e,t)),this[Pn]?Ca(()=>this[Zo]()):this[Zo]()),e}unpipe(e){let t=this[Ct].find(r=>r.dest===e);t&&(this[Ct].length===1?(this[nt]&&this[Qr]===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[jt]=!1,this[Qr]++,!this[Ct].length&&!this[nt]&&this[Zo]();else if(e==="readable"&&this[ot]!==0)super.emit("readable");else if(jI(e)&&this[hr])super.emit(e),this.removeAllListeners(e);else if(e==="error"&&this[Ea]){let o=t;this[Pn]?Ca(()=>o.call(this,this[Ea])):o.call(this,this[Ea])}return r}removeListener(e,t){return this.off(e,t)}off(e,t){let r=super.off(e,t);return e==="data"&&(this[Qr]=this.listeners("data").length,this[Qr]===0&&!this[jt]&&!this[Ct].length&&(this[nt]=!1)),r}removeAllListeners(e){let t=super.removeAllListeners(e);return(e==="data"||e===void 0)&&(this[Qr]=0,!this[jt]&&!this[Ct].length&&(this[nt]=!1)),t}get emittedEnd(){return this[hr]}[Kn](){!this[nl]&&!this[hr]&&!this[$e]&&this[rt].length===0&&this[qn]&&(this[nl]=!0,this.emit("end"),this.emit("prefinish"),this.emit("finish"),this[rl]&&this.emit("close"),this[nl]=!1)}emit(e,...t){let r=t[0];if(e!=="error"&&e!=="close"&&e!==$e&&this[$e])return!1;if(e==="data")return!this[ht]&&!r?!1:this[Pn]?(Ca(()=>this[Gd](r)),!0):this[Gd](r);if(e==="end")return this[zS]();if(e==="close"){if(this[rl]=!0,!this[hr]&&!this[$e])return!1;let i=super.emit("close");return this.removeAllListeners("close"),i}else if(e==="error"){this[Ea]=r,super.emit($d,r);let i=!this[Ta]||this.listeners("error").length?super.emit("error",r):!1;return this[Kn](),i}else if(e==="resume"){let i=super.emit("resume");return this[Kn](),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[Kn](),o}[Gd](e){for(let r of this[Ct])r.dest.write(e)===!1&&this.pause();let t=this[jt]?!1:super.emit("data",e);return this[Kn](),t}[zS](){return this[hr]?!1:(this[hr]=!0,this.readable=!1,this[Pn]?(Ca(()=>this[Wd]()),!0):this[Wd]())}[Wd](){if(this[Xo]){let t=this[Xo].end();if(t){for(let r of this[Ct])r.dest.write(t);this[jt]||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[ht]||(e.dataLength=0);let t=this.promise();return this.on("data",r=>{e.push(r),this[ht]||(e.dataLength+=r.length)}),await t,e}async concat(){if(this[ht])throw new Error("cannot concat in objectMode");let e=await this.collect();return this[fn]?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[jt]=!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[qn])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[qn]})},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[jt]=!1;let e=!1,t=()=>(this.pause(),this.off($d,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($d,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[jt]=!0,this[rt].length=0,this[ot]=0;let t=this;return typeof t.close=="function"&&!this[rl]&&t.close(),e?this.emit("error",e):this.emit($e),this}static get isStream(){return UI}};var tP=QI.native,Aa={lstatSync:YI,readdir:JI,readdirSync:XI,readlinkSync:ZI,realpathSync:tP,promises:{lstat:nP,readdir:rP,readlink:oP,realpath:iP}},VS=n=>!n||n===Aa||n===eP?Aa:{...Aa,...n,promises:{...Aa.promises,...n.promises||{}}},qS=/^\\\\\?\\([a-z]:)\\?$/i,aP=n=>n.replace(/\//g,"\\").replace(qS,"$1\\"),sP=/[\\\/]/,on=0,KS=1,YS=2,Ln=4,JS=6,XS=8,eo=10,ZS=12,rn=15,Ra=~rn,Yd=16,jS=32,Ia=64,Sn=128,ll=256,dl=512,$S=Ia|Sn|dl,lP=1023,Jd=n=>n.isFile()?XS:n.isDirectory()?Ln:n.isSymbolicLink()?eo:n.isCharacterDevice()?YS:n.isBlockDevice()?JS:n.isSocket()?ZS:n.isFIFO()?KS:on,GS=new Map,Pa=n=>{let e=GS.get(n);if(e)return e;let t=n.normalize("NFKD");return GS.set(n,t),t},WS=new Map,cl=n=>{let e=WS.get(n);if(e)return e;let t=Pa(n.toLowerCase());return WS.set(n,t),t},pl=class extends va{constructor(){super({max:256})}},Zd=class extends va{constructor(e=16*1024){super({maxSize:e,sizeCalculation:t=>t.length+1})}},QS=Symbol("PathScurry setAsCwd"),gt=class{name;root;roots;parent;nocase;isCWD=!1;#e;#t;get dev(){return this.#t}#i;get mode(){return this.#i}#r;get nlink(){return this.#r}#a;get uid(){return this.#a}#w;get gid(){return this.#w}#c;get rdev(){return this.#c}#p;get blksize(){return this.#p}#s;get ino(){return this.#s}#l;get size(){return this.#l}#o;get blocks(){return this.#o}#f;get atimeMs(){return this.#f}#S;get mtimeMs(){return this.#S}#m;get ctimeMs(){return this.#m}#u;get birthtimeMs(){return this.#u}#x;get atime(){return this.#x}#g;get mtime(){return this.#g}#T;get ctime(){return this.#T}#C;get birthtime(){return this.#C}#b;#v;#E;#h;#P;#R;#n;#N;#y;#L;get parentPath(){return(this.parent||this).fullpath()}get path(){return this.parentPath}constructor(e,t=on,r,o,i,a,s){this.name=e,this.#b=i?cl(e):Pa(e),this.#n=t&lP,this.nocase=i,this.roots=o,this.root=r||this,this.#N=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=VS(s.fs)}depth(){return this.#v!==void 0?this.#v:this.parent?this.#v=this.parent.depth()+1:this.#v=0}childrenCache(){return this.#N}resolve(e){if(!e)return this;let t=this.getRootString(e),o=e.substring(t.length).split(this.splitSep);return t?this.getRoot(t).#M(o):this.#M(o)}#M(e){let t=this;for(let r of e)t=t.child(r);return t}children(){let e=this.#N.get(this);if(e)return e;let t=Object.assign([],{provisional:0});return this.#N.set(this,t),this.#n&=~Yd,t}child(e,t){if(e===""||e===".")return this;if(e==="..")return this.parent||this;let r=this.children(),o=this.nocase?cl(e):Pa(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,on,{...t,parent:this,fullpath:a});return this.canReaddir()||(s.#n|=Sn),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&rn)===on}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&rn)===XS}isDirectory(){return(this.#n&rn)===Ln}isCharacterDevice(){return(this.#n&rn)===YS}isBlockDevice(){return(this.#n&rn)===JS}isFIFO(){return(this.#n&rn)===KS}isSocket(){return(this.#n&rn)===ZS}isSymbolicLink(){return(this.#n&eo)===eo}lstatCached(){return this.#n&jS?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&rn;return!(e!==on&&e!==eo||this.#n&ll||this.#n&Sn)}calledReaddir(){return!!(this.#n&Yd)}isENOENT(){return!!(this.#n&Sn)}isNamed(e){return this.nocase?this.#b===cl(e):this.#b===Pa(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|=Yd;for(let t=e.provisional;t<e.length;t++){let r=e[t];r&&r.#_()}}#_(){this.#n&Sn||(this.#n=(this.#n|Sn)&Ra,this.#A())}#A(){let e=this.children();e.provisional=0;for(let t of e)t.#_()}#I(){this.#n|=dl,this.#D()}#D(){if(this.#n&Ia)return;let e=this.#n;(e&rn)===Ln&&(e&=Ra),this.#n=e|Ia,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|=ll,e==="ENOENT"&&(t|=Sn),(e==="EINVAL"||e==="UNKNOWN")&&(t&=Ra),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=Jd(e),o=this.newChild(e.name,r,{parent:this}),i=o.#n&rn;return i!==Ln&&i!==eo&&i!==on&&(o.#n|=Ia),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?cl(e.name):Pa(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&Ra|Jd(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&Sn))try{return this.#W(await this.#e.promises.lstat(this.fullpath())),this}catch(e){this.#U(e.code)}}lstatSync(){if(!(this.#n&Sn))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.#x=t,this.#f=r,this.#C=o,this.#u=i,this.#p=a,this.#o=s,this.#T=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=Jd(e);this.#n=this.#n&Ra|y|jS,y!==on&&y!==Ln&&y!==eo&&(this.#n|=Ia)}#$=[];#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&$S)return!1;let e=rn&this.#n;return e===on||e===Ln||e===eo}shouldWalk(e,t){return(this.#n&Ln)===Ln&&!(this.#n&$S)&&!e.has(this)&&(!t||t(this))}async realpath(){if(this.#L)return this.#L;if(!((dl|ll|Sn)&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(!((dl|ll|Sn)&this.#n))try{let e=this.#e.realpathSync(this.fullpath());return this.#L=this.resolve(e)}catch{this.#I()}}[QS](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}},ul=class n extends gt{sep="\\";splitSep=sP;constructor(e,t=on,r,o,i,a,s){super(e,t,r,o,i,a,s)}newChild(e,t=on,r={}){return new n(e,t,this.root,this.roots,this.nocase,this.childrenCache(),r)}getRootString(e){return Xd.parse(e).root}getRoot(e){if(e=aP(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 Qo(e,this).root}sameRoot(e,t=this.root.name){return e=e.toUpperCase().replace(/\//g,"\\").replace(qS,"$1\\"),e===t}},ml=class n extends gt{splitSep="/";sep="/";constructor(e,t=on,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=on,r={}){return new n(e,t,this.root,this.roots,this.nocase,this.childrenCache(),r)}},hl=class{root;rootPath;roots;cwd;#e;#t;#i;nocase;#r;constructor(e=process.cwd(),t,r,{nocase:o,childrenCacheSize:i=16*1024,fs:a=Aa}={}){this.#r=VS(a),(e instanceof URL||e.startsWith("file://"))&&(e=KI(e));let s=t.resolve(e);this.roots=Object.create(null),this.rootPath=this.parseRootPath(s),this.#e=new pl,this.#t=new pl,this.#i=new Zd(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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 gt||(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(T=>T?.isUnknown()?T.lstat():T));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 gt||(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[QS](t)}},Qo=class extends hl{sep="\\";constructor(e=process.cwd(),t={}){let{nocase:r=!0}=t;super(e,Xd,"\\",{...t,nocase:r}),this.nocase=r;for(let o=this.cwd;o;o=o.parent)o.nocase=this.nocase}parseRootPath(e){return Xd.parse(e).root.toUpperCase()}newRoot(e){return new ul(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)}},ei=class extends hl{sep="/";constructor(e=process.cwd(),t={}){let{nocase:r=!1}=t;super(e,qI,"/",{...t,nocase:r}),this.nocase=r}parseRootPath(e){return"/"}newRoot(e){return new ml(this.rootPath,Ln,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")}},La=class extends ei{constructor(e=process.cwd(),t={}){let{nocase:r=!0}=t;super(e,{...t,nocase:r})}},n4=process.platform==="win32"?ul:ml,ey=process.platform==="win32"?Qo:process.platform==="darwin"?La:ei;var cP=n=>n.length>=1,dP=n=>n.length>=1,ti=class n{#e;#t;#i;length;#r;#a;#w;#c;#p;#s;#l=!0;constructor(e,t,r,o){if(!cP(e))throw new TypeError("empty pattern list");if(!dP(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 pP=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",ni=class{relative;relativeChildren;absolute;absoluteChildren;platform;mmopts;constructor(e,{nobrace:t,nocase:r,noext:o,noglobstar:i,platform:a=pP}){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 Ht(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 ti(o,i,0,this.platform),s=new Ht(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 Qd=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()]))}},ep=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)])}},tp=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())}},Oa=class n{hasWalkedCache;matches=new ep;subwalks=new tp;patterns;follow;dot;opts;constructor(e,t){this.opts=e,this.follow=!!e.follow,this.dot=!!e.dot,this.hasWalkedCache=t?t.copy():new Qd}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 uP=(n,e)=>typeof n=="string"?new ni([n],e):Array.isArray(n)?new ni(n,e):n,gl=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=uP(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 Oa(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 Oa(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()}},Na=class extends gl{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}},Ma=class extends gl{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 hP=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",yn=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=mP(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||hP,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"?Qo:t.platform==="darwin"?La:t.platform?ei:ey;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 Ht(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 ti(l,d,0,this.platform)})}async walk(){return[...await new Na(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 Na(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 Ma(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 Ma(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 np=(n,e={})=>{Array.isArray(n)||(n=[n]);for(let t of n)if(new Ht(t,e).hasMagic())return!0;return!1};function fl(n,e={}){return new yn(n,e).streamSync()}function ry(n,e={}){return new yn(n,e).stream()}function ri(n,e={}){return new yn(n,e).walkSync()}async function ty(n,e={}){return new yn(n,e).walk()}function Sl(n,e={}){return new yn(n,e).iterateSync()}function oy(n,e={}){return new yn(n,e).iterate()}var gP=fl,fP=Object.assign(ry,{sync:fl}),SP=Sl,yP=Object.assign(oy,{sync:Sl}),bP=Object.assign(ri,{stream:fl,iterate:Sl}),ny=Object.assign(ty,{glob:ty,globSync:ri,sync:bP,globStream:ry,stream:fP,globStreamSync:fl,streamSync:gP,globIterate:oy,iterate:yP,globIterateSync:Sl,iterateSync:SP,Glob:yn,hasMagic:np,escape:Ko,unescape:gn});ny.glob=ny;import to,{dirname as ly}from"path";import{cwd as sp}from"process";import cy from"yaml";import{z as pe}from"zod";import iy from"fs";import ka from"path";import wP from"yaml";import{z as rp}from"zod";var ay=!1,op=[`**/*.${_t.TEST}`,`**/*.${_t.MODULE}`],ip=rp.string().refine(n=>/^[a-zA-Z0-9-]+$/.test(n)),ap=50,vP=rp.object({fileType:rp.nativeEnum(Ie)});function ve(n,e){let t={project:n,tests:{},modules:{}},r=n.config.include??op,o=Array.from(n.config.exclude??[]).concat(ug),i=ri(r,{absolute:!1,cwd:n.rootDir,ignore:o,dotRelative:!1,maxDepth:ap,nodir:!0});for(let a of i)EP(n.rootDir,a,t,e);return ay=!0,t}function EP(n,e,t,r){let o=ka.join(n,e),i;try{i=iy.readFileSync(o,"utf-8")}catch(p){r.warn(`Could not read possible Momentic file at ${o}, skipping: ${p}`);return}let a;try{if(a=wP.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=vP.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=iy.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:ka.sep,fullPathSegments:o.split(ka.sep),relativePathSegments:e.split(ka.sep),fileName:ka.basename(o),lastModified:c.mtime,createdAt:c.birthtime};switch(l){case Ie.TEST:try{let p=tn.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:Ie.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 Ie.MODULE:try{let p=Lt.parse(a);t.modules[p.moduleId]={type:Ie.MODULE,name:p.name,id:p.moduleId,description:p.description??void 0,...d};let u=d.fileName.replace(".module.yaml","");!
|
|
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 NP(n){let e=OP(n);if(!e||!e.projects||!e.projects.length)return;let t=e.projects.map(i=>(i.endsWith("/")||(i+="/"),`${i}*${ii}`)),r=oi(t,{absolute:!1,cwd:sp(),dotRelative:!1,maxDepth:ap,nodir:!0}),o=[];for(let i of r){let a=no.join(sp(),i),s=lp(a);s&&o.push({configFilePath:a,config:s,rootDir:cy(a)})}return o}function cp(n){if(n){n=no.resolve(n);let t=lp(n);return t||(console.error(`No valid Momentic project file found at ${n}.`),process.exit(1)),[{config:t,configFilePath:n,rootDir:no.dirname(n)}]}if(xP(ly)){let t=NP(ly);if(t)return t}return MP()}function ai(n,e){let t=dy.stringify(n);CP(e,t)}import si from"fs";import dp from"path";import{z as pp}from"zod";var uy="golden/visual-diff",my="reports",hy="test-results";var kP=pp.object({width:pp.number(),height:pp.number()}),li=class{defaultGoldenScreenshotDir;regenerateGoldenFiles;constructor(e,t){let r=dp.join(e.rootDir,e.config.goldenFileDir??uy);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=dp.join(this.defaultGoldenScreenshotDir,`${t.id}.jpg`));let i=`${o}.metadata.json`;if(this.regenerateGoldenFiles)return si.mkdirSync(dp.dirname(o),{recursive:!0}),si.writeFileSync(o,r.buffer),si.writeFileSync(i,JSON.stringify({width:r.width,height:r.height})),{buffer:Buffer.from(r.buffer),width:r.width,height:r.height};if(si.existsSync(o)){let a=si.readFileSync(o),s=kP.parse(JSON.parse(si.readFileSync(i,"utf-8")));return{buffer:a,width:s.width,height:s.height}}else throw new A("UserConfigurationError",`Cannot execute visual diff without a saved baseline screenshot at ${o}`)}};var ci=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 Ee=_P();function yl(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 Te(n,e){try{return(await e).trim()}catch(t){n.error({err:t},"Failed to run git command");return}}function DP(){if(process.env.GITHUB_ACTION)return"GithubActions";if(process.env.GITLAB_CI)return"GitlabCI";if(process.env.CIRCLECI)return"CircleCI";if(process.env.BUILDKITE)return"Buildkite";if(process.env["System.CollectionUri"]?.includes("azure"))return"AzureDevOps"}async function FP(n){let[e,t,r,o]=await Promise.all([Te(n,Ee.show(["--no-patch","--format=%ci"])),Te(n,Ee.listRemote(["--get-url","origin"])),Te(n,Ee.show(["-s","--pretty=%B"])),Te(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 UP(n){let[e,t,r]=await Promise.all([Te(n,Ee.listRemote(["--get-url","origin"])),Te(n,Ee.show(["-s","--pretty=%B"])),Te(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_SERVER_HOST,pipelineId:`${process.env.CI_PIPELINE_ID}:${process.env.CI_JOB_ID}`}}async function BP(n){let[e,t,r,o]=await Promise.all([Te(n,Ee.show(["--no-patch","--format=%ci"])),Te(n,Ee.listRemote(["--get-url","origin"])),Te(n,Ee.show(["-s","--pretty=%B"])),Te(n,Ee.show(["-s","--pretty=%an"]))]),i=t?.includes("github.com"),a=t?.includes("gitlab.com"),s=t?yl(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 zP(n){let[e,t,r]=await Promise.all([Te(n,Ee.show(["--no-patch","--format=%ci"])),Te(n,Ee.show(["-s","--pretty=%B"])),Te(n,Ee.show(["-s","--pretty=%an"]))]),o=process.env.BUILDKITE_REPO,i=o?.includes("github.com"),a=o?.includes("gitlab.com"),s=o?yl(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 HP(n){let[e,t,r]=await Promise.all([Te(n,Ee.show(["--no-patch","--format=%ci"])),Te(n,Ee.show(["-s","--pretty=%B"])),Te(n,Ee.show(["-s","--pretty=%an"]))]),o=process.env["Build.Repository.Uri"],i=o?.includes("github.com"),a=o?.includes("gitlab.com"),s=o?yl(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([Te(n,Ee.revparse(["HEAD"])),Te(n,Ee.revparse(["--short","HEAD"])),Te(n,Ee.revparse(["--abbrev-ref","HEAD"])),Te(n,Ee.listRemote(["--get-url","origin"])),Te(n,Ee.show(["--no-patch","--format=%ci"])),Te(n,Ee.show(["-s","--pretty=%B"])),Te(n,Ee.show(["-s","--pretty=%an"])),e?Te(n,Ee.raw(["merge-base","--fork-point",e])):Promise.resolve(void 0)]),d=c?await Te(n,Ee.show(["--no-patch","--format=%ci",c])):void 0,p=i?.includes("github.com"),u=i?.includes("gitlab.com"),m=i?yl(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 $P(n){let e=n.config.gitProtectedBranches??[];return n.config.gitMainBranch&&e.push(n.config.gitMainBranch),{gitMainBranch:n.config.gitMainBranch,gitProtectedBranches:e}}async function GP(n,e){let t=DP();if(!t)return jP(n,e);switch(t){case"GithubActions":return FP(n);case"GitlabCI":return UP(n);case"CircleCI":return BP(n);case"Buildkite":return zP(n);case"AzureDevOps":return HP(n)}}async function WP(n,e,t){if(t.lastCommitOnMainSha&&t.lastCommitOnMainTimestamp)return{};if(t.gitlabProjectPath){if(!t.gitMainBranch||!t.gitCommitSha)return{};try{let r=await e.getMergeBaseCommitFromGitlab(t.gitlabProjectPath,t.gitMainBranch,t.gitCommitSha);return{lastCommitOnMainSha:r.sha,lastCommitOnMainTimestamp:r.committer.date}}catch(r){return n.warn({err:r},"Failed to get remote metadata from Gitlab"),{}}}if(t.githubRepository){if(!t.gitMainBranch||!t.gitCommitSha)return{};try{let[r,o]=t.githubRepository.split("/"),i=await e.getMergeBaseCommitFromGithub(r,o,t.gitMainBranch,t.gitCommitSha);return{lastCommitOnMainSha:i.sha,lastCommitOnMainTimestamp:i.committer.date}}catch(r){return n.warn({err:r},"Failed to get remote metadata from Github"),{}}}return{}}async function di(n,e,t){let r=await $P(t),o=await GP(n,r.gitMainBranch),i={...r,...o},a=await WP(n,e,i);return{...r,...o,...a}}import nk from"http";import{z as hp}from"zod";var $="v1",_a="2.6.3";var fr=class extends Error{constructor(e){super(e),this.name="TimeoutError"}};var gy=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 U(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(gy(p));s=()=>c(gy(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 bl=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 up=["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 fy(n){return new Array(n).fill(0).map(()=>up[Math.floor(Math.random()*up.length)]).join("-")}var VP=9e4,qP=15e3,bn=class extends Error{status;rawError;constructor(e,t,r,o={}){super(r,o),this.status=e,this.rawError=t}};async function KP(n){return n.text().then(e=>{try{return JSON.parse(e).error}catch{return e}})}var mp=class{baseUrl;logger;constructor(e){this.baseUrl=e.baseUrl,this.logger=e.logger}getHeaders(){let e={"Content-Type":"application/json"};return _a&&(e[yg]=_a),e}async sendRequest(e,t,r=3,o=VP){let i=r,a,s={path:e,baseUrl:this.baseUrl,method:t.method};for(;r>0;)try{return r--,await this.sendSingleRequestHelper(e,t,o)}catch(l){if(a=l,l instanceof bn&&l.status>=400&&l.status<500)throw l;if(l instanceof Error&&l.name==="AbortError"&&(a=new fr),r===0)throw a;let c=1500,d=i-r,p=Math.min(c*Math.pow(2,d-1),qP);await new Promise(u=>setTimeout(u,p))}throw this.logger.warn({...s,err:a},"Got fatal error response from Momentic server"),a}async sendSingleRequestHelper(e,t,r){let o={path:e,baseUrl:this.baseUrl,method:t.method},i=new AbortController,a=setTimeout(()=>i.abort(),r),s=()=>i.abort();t.signal&&t.signal.addEventListener("abort",s);let l={...this.getHeaders(),...t.extraHeaders};try{let c=await fetch(`${this.baseUrl}${e}`,{method:t.method,body:t.body?JSON.stringify(t.body):void 0,headers:l,signal:i.signal});if(!c.ok){let p=await KP(c);throw new bn(c.status,p,`Request to ${e} failed with status ${c.status}: ${p}`)}let d;if(c.status===204)d={};else{let p=await c.text();try{d=JSON.parse(p)}catch{d=p}}return this.logger&&!t.noLog&&d&&this.logger.debug({result:d,status:c.status,...o},"Got response from Momentic server"),d}finally{clearTimeout(a),t.signal&&t.signal.removeEventListener("abort",s)}}},Ft=class extends mp{apiKey;constructor(e){super(e),this.apiKey=e.apiKey}getHeaders(){return{...super.getHeaders(),Authorization:`Bearer ${this.apiKey}`}}};var ct=class extends Ft{constructor(e){super(e)}getAppUrl(){return this.baseUrl.replace(/\/\/api/,"//app")}async getAuthInfo(){let e=await this.sendRequest(`/${$}/auth/check`,{method:"GET",noLog:!0},10,5e3);return Ug.parse(e)}async bulkGetRunStatus(e){let t=await this.sendRequest(`/${$}/runs/status`,{method:"POST",body:e,noLog:!0},3,1e4);return kg.parse(t)}async getTestYAMLExport(e){let t=await this.sendRequest(`/${$}/tests/export`,{method:"POST",body:e},3,3e4);return Pg.parse(t)}async updateStepCaches(e,t){await this.sendRequest(`/${$}/cache`,{method:"PATCH",body:e,extraHeaders:t},3,1e4)}async getStepCacheForTest(e,t){let r=await this.sendRequest(`/${$}/cache`,{method:"POST",body:e,extraHeaders:t},10,3e4);return Lg.parse(r)}async queueTests(e){let t=await this.sendRequest(`/${$}/tests/queue`,{method:"POST",body:e},3,1e4);return Ig.parse(t)}async uploadScreenshot(e){let t=await this.sendRequest(`/${$}/screenshots`,{method:"POST",body:e,noLog:!0},3,5e3);return Fg.parse(t)}async getAllEnvironments(){let e=await this.sendRequest(`/${$}/environments`,{method:"GET"},3,5e3);return Bg.parse(e)}async acquireCacheLock(e,t){let r=await this.sendRequest(`/${$}/result-cache/lock`,{method:"POST",body:e,signal:t},3,3e4);return Vg.parse(r)}async releaseCacheLock(e){await this.sendRequest(`/${$}/result-cache/lock`,{method:"DELETE",body:{key:e}},3,5e3)}async deleteCacheResult(e){await this.sendRequest(`/${$}/result-cache/entry`,{method:"DELETE",body:e},3,5e3)}async setCacheResult(e){await this.sendRequest(`/${$}/result-cache/entry`,{method:"PATCH",body:e},3,5e3)}async getCacheResult(e){try{return await this.sendRequest(`/${$}/result-cache/entry`,{method:"POST",body:e},3,5e3)}catch(t){if(t instanceof Error&&t.message.includes("404"))return null;throw t}}async queueSuiteRuns(e){let t=await this.sendRequest(`/${$}/suites/queue`,{method:"POST",body:e},3,5e3);return zg.parse(t)}async bulkGetRunGroupStatus(e){let t={runGroupIds:e},r=await this.sendRequest(`/${$}/run-groups/status`,{method:"POST",body:t,noLog:!0},3,5e3);return Sh.array().parse(r)}async uploadProposedSteps(e,t){try{await this.sendRequest(`/${$}/test-fragments/`,{method:"POST",body:e},3,1e4)}catch(r){t.error({err:r},"Failed to upload proposed steps")}}async uploadSnapshotScreenshot(e,t,r){try{await this.sendRequest(`/${$}/snapshots/${t}/screenshot`,{method:"POST",body:r,noLog:!0},3,1e4)}catch(o){e.error({err:o},"Failed to upload screenshot")}}async generateConsoleLogsForRunAttemptUploadUrl(e,t,r){let o=await this.sendRequest(`/${$}/runs/${t}/attempts/${r}/console-logs`,{method:"POST",noLog:!0},3,5e3);return da.parse(o)}async generateNetworkLogsForRunAttemptUploadUrl(e,t,r){let o=await this.sendRequest(`/${$}/runs/${t}/attempts/${r}/network-logs`,{method:"POST",noLog:!0},3,1e4);return da.parse(o)}async generateHtmlSnapshotUploadUrl(e,t){let r=await this.sendRequest(`/${$}/snapshots/${t}/html`,{method:"POST",noLog:!0},3,1e4);return da.parse(r)}async reportBillableEvents(e,t){try{await this.sendRequest(`/${$}/billing/events`,{method:"POST",body:t,noLog:!0},10,1e4)}catch(r){e.error({err:r},"Failed to report billable event")}}async fetchTestFragment(e){let t=await this.sendRequest(`/${$}/test-fragments/${e}`,{method:"GET",noLog:!0},3,1e4);return Hg.parse(t)}async patchTestFragment(e,t){await this.sendRequest(`/${$}/test-fragments/${e}`,{method:"PATCH",body:t},3,1e4)}async getPastTestResults(e,t){let r=await this.sendRequest(`/${$}/results/tests/${e}`,{method:"POST",body:t},3,1e4);return jg.parse(r)}async generateTestResultsUploadUrl(){let e=await this.sendRequest(`/${$}/results/uploads`,{method:"POST",noLog:!0},3,1e4);return $g.parse(e)}async startProcessingResultsUpload(e,t){let r=await this.sendRequest(`/${$}/results/uploads/${e}/process`,{method:"POST",noLog:!0,body:t},3,1e4);return Gg.parse(r)}async fetchIconKnowledgeBase(e){try{let t=await this.sendRequest(`/${$}/knowledge-base/icons`,{method:"GET",noLog:!0},3,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(`/${$}/knowledge-base/icons`,{method:"POST",body:e,noLog:!0},3,5e3)}catch(r){t.error({err:r},"Failed to save new icons to icon knowledge base")}}async getMergeBaseCommitFromGithub(e,t,r,o){let i=new URLSearchParams;i.set("base",r),i.set("head",o);let a=await this.sendRequest(`/${$}/git/github/${e}/${t}/merge-base-commit?${i.toString()}`,{method:"GET",noLog:!0},3,1e4);return Rd.parse(a)}async getMergeBaseCommitFromGitlab(e,t,r){let o=new URLSearchParams;o.set("base",t),o.set("head",r);let i=await this.sendRequest(`/${$}/git/gitlab/${e}/merge-base-commit?${o.toString()}`,{method:"GET",noLog:!0},3,5e3);return Rd.parse(i)}async getAgentConfig(){let e=await this.sendRequest(`/${$}/web-agent/agent-config`,{method:"GET",noLog:!0},3,5e3);return hp.record(hp.string(),hp.string()).parse(e)}};import{randomUUID as Sy}from"crypto";var wl=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??Sy(),properties:md({},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??Sy(),properties:md({creditsUsed:r,usedBy:t},o)}])}catch(i){e.error({err:i},"Failed to report credits used")}}};function pi(n,e,t){return fetch(n,{method:"PUT",body:t,headers:{"Content-Type":e}})}var vl=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 pi(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 pi(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 pi(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 ui=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 YP,en as JP}from"@faker-js/faker";var mi="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 YP({locale:JP}),this.fakerInstance.seed(e.fakerSeed))}async sendAiGenerate(e){let t=typeof e=="string"?{input:e}:e;return this.httpClient.sendRequest(`/${mi}/tools/ai/generate`,{method:"POST",body:t}).catch(r=>{throw r instanceof bn?new Error(r.rawError):new Error(`Failed to send AI generation: ${r.message}`)})}async sendSms(e){return this.httpClient.sendRequest(`/${mi}/tools/sms/send`,{method:"POST",body:e}).then(()=>{}).catch(t=>{throw t instanceof bn?new Error(t.rawError):new Error(`Failed to send sms: ${t.message}`)})}async fetchLatestSms(e){return this.httpClient.sendRequest(`/${mi}/tools/sms/fetchLatest`,{method:"POST",body:e}).catch(t=>{throw t instanceof bn?new Error(t.rawError):t})}async sendEmail(e){return this.httpClient.sendRequest(`/${mi}/tools/email/send`,{method:"POST",body:e}).then(()=>{}).catch(t=>{throw t instanceof bn?new Error(t.rawError):new Error(`Failed to send email: ${t.message}`)})}async fetchAllEmails(e){return this.httpClient.sendRequest(`/${mi}/tools/email/fetchAll`,{method:"POST",body:e}).catch(t=>{throw t instanceof bn?new Error(t.rawError):new Error(`Failed to fetch all emails: ${t.message}`)})}async fetchLatestEmail(e){return this.httpClient.sendRequest(`/${mi}/tools/email/fetchLatest`,{method:"POST",body:e}).catch(t=>{throw t instanceof bn?new Error(t.rawError):new Error(`Failed to fetch latest emails: ${t.message}`)})}};import{z as XP}from"zod";var hi=class extends Ft{agentConfig;constructor(e,t){super(t),this.agentConfig=e}async rankChunksWithAi(e,t){let r={...e,loggerTags:t.loggerTags},o=await this.sendRequest(`/${$}/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(`/${$}/web-agent/recommend-chunks`,{method:"POST",body:{cliVersion:_a,...e},signal:t.abortSignal});return xh.parse(r)}async getScreenshotFromS3(e){let t=await this.sendRequest(`/${$}/s3/visual-diff-screenshot`,{method:"POST",body:{url:e}});return XP.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(`/${$}/web-agent/locate-element`,{method:"POST",body:r,signal:t.abortSignal});return Rg.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(`/${$}/web-agent/assertion`,{method:"POST",body:r,signal:t.abortSignal});return Td.parse(o)}async getLintStepResult(e,t){let r={...e,disableCache:!!t.disableCache,loggerTags:t.loggerTags},o=await this.sendRequest(`/${$}/web-agent/lint/step`,{method:"POST",body:r,signal:t.abortSignal});return Cg.parse(o)}async getVisualAssertionResult(e,t){let r={...e,disableCache:!!t.disableCache,useConsensus:!!t.useConsensus,loggerTags:t.loggerTags},o=await this.sendRequest(`/${$}/web-agent/visual-assertion`,{method:"POST",body:r,signal:t.abortSignal});return Td.parse(o)}async getAiActionCommand(e,t){let r=await this.sendRequest(`/${$}/web-agent/next-command-dynamic`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Tg.parse(r)}async getMultiturnAiActionCommand(e,t){return await this.sendRequest(`/${$}/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(`/${$}/web-agent/ai-action/evaluate`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Hc.parse(r)}async getReverseMappedDescription(e,t){let r=await this.sendRequest(`/${$}/web-agent/reverse-mapped-description`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Ag.parse(r)}async getTextExtraction(e,t){let r={...e,disableCache:t.disableCache,loggerTags:t.loggerTags},o=await this.sendRequest(`/${$}/web-agent/text-extraction`,{method:"POST",body:r,signal:t.abortSignal});return zc.parse(o)}async getTestResultClassification(e,t){let r=await this.sendRequest(`/${$}/web-agent/result-classification`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return Qc.parse(r)}async getExtractedKeywords(e,t){let r=await this.sendRequest(`/${$}/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(`/${$}/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(`/${$}/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(`/${$}/web-agent/iframe-regex`,{method:"POST",body:e,signal:t.abortSignal});return tm.parse(r)}};var gi=class extends Ft{generator;constructor(e,t){super(e),this.generator=t}async runTemplateMatching(e,t={}){let r=await this.sendRequest(`/${$}/web-agent/template-matching`,{method:"POST",body:e,signal:t?.signal});return nm.parse(r)}async constructIframeRegex(e,t={}){return this.generator.getIframeRegex(e,{abortSignal:t.signal})}};var xl=class{constructor(e){this.client=e}async uploadResultsArchive(e,t){let{uploadUrl:r,id:o}=await this.client.generateTestResultsUploadUrl(),i=await pi(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 fi({orgId:n,client:e,gitMetadata:t,alwaysSaveCache:r,noCache:o}){return o?new Ja:new gp(n,e,t,r)}var gp=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[bg]=r),o&&(this.cacheHeaders[wg]=o),a&&(this.cacheHeaders[vg]=a.toISOString()),s&&(this.cacheHeaders[xg]=s),l&&(this.cacheHeaders[Eg]=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&&Go({steps:s,stepCacheEntries:i,logger:e.logger});let{cachesToSave:a}=await Dt({stepLists:e.stepLists,cacheCreationParams:{testId:e.testId,orgId:this.orgId}});this.client.updateStepCaches({entries:a,testId:e.testId},this.cacheHeaders)}};import rk from"path";import{Server as IN}from"socket.io";import{cloneDeep as ZP}from"lodash-es";var QP={showOverlay:!1},fp=class{sessions=new Map;sessionCountByIp=new Map;getCurrentConnectionsByIp(e){return this.sessionCountByIp.get(e)??0}getCurrentSessionsByIp(){return Object.fromEntries(this.sessionCountByIp)}reserveCapacityByIp(e){e&&this.sessionCountByIp.set(e,(this.sessionCountByIp.get(e)??0)+1)}releaseCapacityByIp(e){e&&this.sessionCountByIp.set(e,Math.max(this.getCurrentConnectionsByIp(e)-1,0))}registerSession({controller:e,context:t,cleanup:r,clientIp:o,sessionId:i,browserbaseSessionId:a}){return this.sessions.set(i,{controller:e,context:t,cleanup:r,clientIp:o,browserbaseSessionId:a,browserBehavior:ZP(QP)}),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)}},Z=new fp;function yy(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=Z.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=Z.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 eL=n=>()=>{let{sessionId:e}=n.metadata;yr[e]?.abort?.abort()},by={event:"cancelApiTest",createHandler:eL};import{CookieJar as bL}from"tough-cookie";import{randomUUID as lL}from"crypto";import{faker as tL}from"@faker-js/faker";import nL from"assert";import rL from"axios";import oL from"moment";import*as iL from"otpauth";import aL from"pg";async function wy(n){let e;try{e=new URL(n.url).hostname}catch{}let t=[];return n.headers.getSetCookie()?.forEach(r=>{let o=Ns(r,e);t.push(...o)}),t}var sL=Object.getPrototypeOf(async function(){}).constructor;async function vy(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)(rL,oL,i.fakerInstance??tL,nL,aL,d,p,iL,wy,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 U(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=lL(),l=await vy(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 cL,randomUUID as dL}from"crypto";import pL from"fetch-retry";var uL=pL(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}}),Ey=process.env.GCP_JS_EVAL_FUNCTION_ENDPOINT,Ty=process.env.MOMENTIC_LAMBDA_AUTH_SECRET;async function Cy({orgId:n,code:e,fragment:t,context:r,timeoutMs:o=lr,retries:i=2,signal:a,logger:s}){if(!Ey)throw new Error("GCP_JS_EVAL_FUNCTION_ENDPOINT environment variable not set");let l,c,d=0;if(!Ty)throw new Error("Missing lambda auth secret.");let p=cL("sha256",Ty).update(n).digest("hex");for(;d<=i;){d++,a?.throwIfAborted();let m={id:dL(),orgId:n,momenticLambdaAuthHash:p,code:e,fragment:t,state:r.toObjectCopy(),timeoutMs:o};try{if(l=await U(uL(Ey,{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 Yn(n){let e;if(process.env.GCP_JS_EVAL_FUNCTION_ENDPOINT)e=await Cy(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:
|
|
48
|
+
Second test path: ${o}`)}t.tests[p.id]={type:Ie.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 Ie.MODULE:try{let p=Lt.parse(a);t.modules[p.moduleId]={type:Ie.MODULE,name:p.name,id:p.moduleId,description:p.description??void 0,...d};let u=d.fileName.replace(".module.yaml","");!ay&&Me(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 oi="momentic.config.yaml",sy="momentic.workspace.yaml",AP=pe.object({projects:pe.string().array().describe("list of glob patterns to find project (momentic.config.yaml) files")}),IP=pe.union([pe.string(),pe.object({fromFile:pe.string(),json:pe.boolean().optional()})]),PP=pe.object({name:ip,baseUrl:pe.string(),envFile:pe.string().optional().describe("path to a file on disk to read environment variables from. can be relative to project root or absolute."),envVariables:pe.record(pe.string(),IP).optional(),inheritFromShell:pe.boolean().optional().describe("inherit all environment variables from the shell - might be noisy"),browser:kr.optional()}),LP=pe.object({postSave:pe.string().optional()}),OP=pe.object({name:ip,include:pe.string().array().optional().describe("list of glob patterns that match momentic files (optional)"),exclude:pe.string().array().optional().describe("opposite of include, takes precedence over include"),goldenFileDir:pe.string().optional(),reporterDir:pe.string().optional(),outputDir:pe.string().optional(),retries:pe.number().optional().describe("number of retries per test"),parallel:pe.number().optional().describe("degree of parallelism"),environments:pe.array(PP).optional(),gitMainBranch:pe.string().optional(),gitProtectedBranches:pe.string().array().optional(),ai:xd.extend({aiPageFiltering:pe.boolean().optional().describe("rag v2 flag")}).optional(),browser:kr.extend({autoExpandIframes:pe.boolean().optional(),disableSecondaryCacheResolution:pe.boolean().optional(),showZeroOpacityElements:pe.boolean().optional(),globalLocatorRedirect:pe.boolean().optional(),visualActions:pe.boolean().optional()}).optional(),advanced:fg.optional(),hooks:LP.optional()});function dy(n,e){let t;try{t=TP(n,"utf-8")}catch(o){b.warn(`Could not read possible Momentic ${e} file at ${n}: ${o}`);return}let r;try{if(r=cy.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 lp(n){let e=dy(n,"project configuration");if(e!==void 0)try{return OP.parse(e)}catch(t){b.warn(`Possible Momentic project configuration file at ${n} does not adhere to the required schema: ${t}`);return}}function NP(n){let e=dy(n,"workspace configuration");if(e!==void 0)try{return AP.parse(e)}catch(t){b.warn(`Possible Momentic workspace configuration file at ${n} does not adhere to the required schema: ${t}`);return}}function MP(){let n=[],e=sp(),t=to.parse(e).root,r=15,o=0;for(;o<r;){o++;let i=to.basename(e);if(Bs.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 CP(e))if(a.endsWith(oi)){let s=to.join(e,a),l=lp(s);l&&n.push({configFilePath:s,config:l,rootDir:ly(s)})}if(n.length)return n;if(e=to.dirname(e),e===t)break}return n}function $t(n={}){let{configFilePath:e,nameFilter:t}=n,r=cp(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 kP(n){let e=NP(n);if(!e||!e.projects||!e.projects.length)return;let t=e.projects.map(i=>(i.endsWith("/")||(i+="/"),`${i}*${oi}`)),r=ri(t,{absolute:!1,cwd:sp(),dotRelative:!1,maxDepth:ap,nodir:!0}),o=[];for(let i of r){let a=to.join(sp(),i),s=lp(a);s&&o.push({configFilePath:a,config:s,rootDir:ly(a)})}return o}function cp(n){if(n){n=to.resolve(n);let t=lp(n);return t||(console.error(`No valid Momentic project file found at ${n}.`),process.exit(1)),[{config:t,configFilePath:n,rootDir:to.dirname(n)}]}if(xP(sy)){let t=kP(sy);if(t)return t}return MP()}function ii(n,e){let t=cy.stringify(n);RP(e,t)}import ai from"fs";import dp from"path";import{z as pp}from"zod";var py="golden/visual-diff",uy="reports",my="test-results";var _P=pp.object({width:pp.number(),height:pp.number()}),si=class{defaultGoldenScreenshotDir;regenerateGoldenFiles;constructor(e,t){let r=dp.join(e.rootDir,e.config.goldenFileDir??py);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=dp.join(this.defaultGoldenScreenshotDir,`${t.id}.jpg`));let i=`${o}.metadata.json`;if(this.regenerateGoldenFiles)return ai.mkdirSync(dp.dirname(o),{recursive:!0}),ai.writeFileSync(o,r.buffer),ai.writeFileSync(i,JSON.stringify({width:r.width,height:r.height})),{buffer:Buffer.from(r.buffer),width:r.width,height:r.height};if(ai.existsSync(o)){let a=ai.readFileSync(o),s=_P.parse(JSON.parse(ai.readFileSync(i,"utf-8")));return{buffer:a,width:s.width,height:s.height}}else throw new A("UserConfigurationError",`Cannot execute visual diff without a saved baseline screenshot at ${o}`)}};var li=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 DP from"simple-git";var xe=DP();function yl(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 Te(n,e){try{return(await e).trim()}catch(t){n.error({err:t},"Failed to run git command");return}}function FP(){if(process.env.GITHUB_ACTION)return"GithubActions";if(process.env.GITLAB_CI)return"GitlabCI";if(process.env.CIRCLECI)return"CircleCI";if(process.env.BUILDKITE)return"Buildkite";if(process.env["System.CollectionUri"]?.includes("azure"))return"AzureDevOps"}async function UP(n){let[e,t,r,o]=await Promise.all([Te(n,xe.show(["--no-patch","--format=%ci"])),Te(n,xe.listRemote(["--get-url","origin"])),Te(n,xe.show(["-s","--pretty=%B"])),Te(n,xe.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 BP(n){let[e,t,r]=await Promise.all([Te(n,xe.listRemote(["--get-url","origin"])),Te(n,xe.show(["-s","--pretty=%B"])),Te(n,xe.show(["-s","--pretty=%an"]))]);return{gitCommitSha:process.env.CI_COMMIT_SHA,gitCommitShaShort:process.env.CI_COMMIT_SHORT_SHA,gitCommitTimestamp:process.env.CI_COMMIT_TIMESTAMP?new Date(process.env.CI_COMMIT_TIMESTAMP):void 0,gitBranchName:process.env.CI_COMMIT_BRANCH||process.env.CI_COMMIT_REF_NAME,gitOriginUrl:e,gitCommitMessage:t,gitCommitAuthorName:r,gitlabProjectPath:process.env.CI_SERVER_HOST,pipelineId:`${process.env.CI_PIPELINE_ID}:${process.env.CI_JOB_ID}`}}async function zP(n){let[e,t,r,o]=await Promise.all([Te(n,xe.show(["--no-patch","--format=%ci"])),Te(n,xe.listRemote(["--get-url","origin"])),Te(n,xe.show(["-s","--pretty=%B"])),Te(n,xe.show(["-s","--pretty=%an"]))]),i=t?.includes("github.com"),a=t?.includes("gitlab.com"),s=t?yl(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 HP(n){let[e,t,r]=await Promise.all([Te(n,xe.show(["--no-patch","--format=%ci"])),Te(n,xe.show(["-s","--pretty=%B"])),Te(n,xe.show(["-s","--pretty=%an"]))]),o=process.env.BUILDKITE_REPO,i=o?.includes("github.com"),a=o?.includes("gitlab.com"),s=o?yl(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 jP(n){let[e,t,r]=await Promise.all([Te(n,xe.show(["--no-patch","--format=%ci"])),Te(n,xe.show(["-s","--pretty=%B"])),Te(n,xe.show(["-s","--pretty=%an"]))]),o=process.env["Build.Repository.Uri"],i=o?.includes("github.com"),a=o?.includes("gitlab.com"),s=o?yl(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 $P(n,e){let[t,r,o,i,a,s,l,c]=await Promise.all([Te(n,xe.revparse(["HEAD"])),Te(n,xe.revparse(["--short","HEAD"])),Te(n,xe.revparse(["--abbrev-ref","HEAD"])),Te(n,xe.listRemote(["--get-url","origin"])),Te(n,xe.show(["--no-patch","--format=%ci"])),Te(n,xe.show(["-s","--pretty=%B"])),Te(n,xe.show(["-s","--pretty=%an"])),e?Te(n,xe.raw(["merge-base","--fork-point",e])):Promise.resolve(void 0)]),d=c?await Te(n,xe.show(["--no-patch","--format=%ci",c])):void 0,p=i?.includes("github.com"),u=i?.includes("gitlab.com"),m=i?yl(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 GP(n){let e=n.config.gitProtectedBranches??[];return n.config.gitMainBranch&&e.push(n.config.gitMainBranch),{gitMainBranch:n.config.gitMainBranch,gitProtectedBranches:e}}async function WP(n,e){let t=FP();if(!t)return $P(n,e);switch(t){case"GithubActions":return UP(n);case"GitlabCI":return BP(n);case"CircleCI":return zP(n);case"Buildkite":return HP(n);case"AzureDevOps":return jP(n)}}async function VP(n,e,t){if(t.lastCommitOnMainSha&&t.lastCommitOnMainTimestamp)return{};if(t.gitlabProjectPath){if(!t.gitMainBranch||!t.gitCommitSha)return{};try{let r=await e.getMergeBaseCommitFromGitlab(t.gitlabProjectPath,t.gitMainBranch,t.gitCommitSha);return{lastCommitOnMainSha:r.sha,lastCommitOnMainTimestamp:r.committer.date}}catch(r){return n.warn({err:r},"Failed to get remote metadata from Gitlab"),{}}}if(t.githubRepository){if(!t.gitMainBranch||!t.gitCommitSha)return{};try{let[r,o]=t.githubRepository.split("/"),i=await e.getMergeBaseCommitFromGithub(r,o,t.gitMainBranch,t.gitCommitSha);return{lastCommitOnMainSha:i.sha,lastCommitOnMainTimestamp:i.committer.date}}catch(r){return n.warn({err:r},"Failed to get remote metadata from Github"),{}}}return{}}async function ci(n,e,t){let r=await GP(t),o=await WP(n,r.gitMainBranch),i={...r,...o},a=await VP(n,e,i);return{...r,...o,...a}}import rk from"http";import{z as hp}from"zod";var $="v1",_a="2.6.5";var fr=class extends Error{constructor(e){super(e),this.name="TimeoutError"}};var hy=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 U(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(hy(p));s=()=>c(hy(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 bl=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 up=["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 gy(n){return new Array(n).fill(0).map(()=>up[Math.floor(Math.random()*up.length)]).join("-")}var qP=9e4,KP=15e3,bn=class extends Error{status;rawError;constructor(e,t,r,o={}){super(r,o),this.status=e,this.rawError=t}};async function YP(n){return n.text().then(e=>{try{return JSON.parse(e).error}catch{return e}})}var mp=class{baseUrl;logger;constructor(e){this.baseUrl=e.baseUrl,this.logger=e.logger}getHeaders(){let e={"Content-Type":"application/json"};return _a&&(e[Sg]=_a),e}async sendRequest(e,t,r=3,o=qP){let i=r,a,s={path:e,baseUrl:this.baseUrl,method:t.method};for(;r>0;)try{return r--,await this.sendSingleRequestHelper(e,t,o)}catch(l){if(a=l,l instanceof bn&&l.status>=400&&l.status<500)throw l;if(l instanceof Error&&l.name==="AbortError"&&(a=new fr),r===0)throw a;let c=1500,d=i-r,p=Math.min(c*Math.pow(2,d-1),KP);await new Promise(u=>setTimeout(u,p))}throw this.logger.warn({...s,err:a},"Got fatal error response from Momentic server"),a}async sendSingleRequestHelper(e,t,r){let o={path:e,baseUrl:this.baseUrl,method:t.method},i=new AbortController,a=setTimeout(()=>i.abort(),r),s=()=>i.abort();t.signal&&t.signal.addEventListener("abort",s);let l={...this.getHeaders(),...t.extraHeaders};try{let c=await fetch(`${this.baseUrl}${e}`,{method:t.method,body:t.body?JSON.stringify(t.body):void 0,headers:l,signal:i.signal});if(!c.ok){let p=await YP(c);throw new bn(c.status,p,`Request to ${e} failed with status ${c.status}: ${p}`)}let d;if(c.status===204)d={};else{let p=await c.text();try{d=JSON.parse(p)}catch{d=p}}return this.logger&&!t.noLog&&d&&this.logger.debug({result:d,status:c.status,...o},"Got response from Momentic server"),d}finally{clearTimeout(a),t.signal&&t.signal.removeEventListener("abort",s)}}},Ft=class extends mp{apiKey;constructor(e){super(e),this.apiKey=e.apiKey}getHeaders(){return{...super.getHeaders(),Authorization:`Bearer ${this.apiKey}`}}};var ct=class extends Ft{constructor(e){super(e)}getAppUrl(){return this.baseUrl.replace(/\/\/api/,"//app")}async getAuthInfo(){let e=await this.sendRequest(`/${$}/auth/check`,{method:"GET",noLog:!0},10,5e3);return Fg.parse(e)}async bulkGetRunStatus(e){let t=await this.sendRequest(`/${$}/runs/status`,{method:"POST",body:e,noLog:!0},3,1e4);return Mg.parse(t)}async getTestYAMLExport(e){let t=await this.sendRequest(`/${$}/tests/export`,{method:"POST",body:e},3,3e4);return Ig.parse(t)}async updateStepCaches(e,t){await this.sendRequest(`/${$}/cache`,{method:"PATCH",body:e,extraHeaders:t},3,1e4)}async getStepCacheForTest(e,t){let r=await this.sendRequest(`/${$}/cache`,{method:"POST",body:e,extraHeaders:t},10,3e4);return Pg.parse(r)}async queueTests(e){let t=await this.sendRequest(`/${$}/tests/queue`,{method:"POST",body:e},3,1e4);return Ag.parse(t)}async uploadScreenshot(e){let t=await this.sendRequest(`/${$}/screenshots`,{method:"POST",body:e,noLog:!0},3,5e3);return Dg.parse(t)}async getAllEnvironments(){let e=await this.sendRequest(`/${$}/environments`,{method:"GET"},3,5e3);return Ug.parse(e)}async acquireCacheLock(e,t){let r=await this.sendRequest(`/${$}/result-cache/lock`,{method:"POST",body:e,signal:t},3,3e4);return Wg.parse(r)}async releaseCacheLock(e){await this.sendRequest(`/${$}/result-cache/lock`,{method:"DELETE",body:{key:e}},3,5e3)}async deleteCacheResult(e){await this.sendRequest(`/${$}/result-cache/entry`,{method:"DELETE",body:e},3,5e3)}async setCacheResult(e){await this.sendRequest(`/${$}/result-cache/entry`,{method:"PATCH",body:e},3,5e3)}async getCacheResult(e){try{return await this.sendRequest(`/${$}/result-cache/entry`,{method:"POST",body:e},3,5e3)}catch(t){if(t instanceof Error&&t.message.includes("404"))return null;throw t}}async queueSuiteRuns(e){let t=await this.sendRequest(`/${$}/suites/queue`,{method:"POST",body:e},3,5e3);return Bg.parse(t)}async bulkGetRunGroupStatus(e){let t={runGroupIds:e},r=await this.sendRequest(`/${$}/run-groups/status`,{method:"POST",body:t,noLog:!0},3,5e3);return fh.array().parse(r)}async uploadProposedSteps(e,t){try{await this.sendRequest(`/${$}/test-fragments/`,{method:"POST",body:e},3,1e4)}catch(r){t.error({err:r},"Failed to upload proposed steps")}}async uploadSnapshotScreenshot(e,t,r){try{await this.sendRequest(`/${$}/snapshots/${t}/screenshot`,{method:"POST",body:r,noLog:!0},3,1e4)}catch(o){e.error({err:o},"Failed to upload screenshot")}}async generateConsoleLogsForRunAttemptUploadUrl(e,t,r){let o=await this.sendRequest(`/${$}/runs/${t}/attempts/${r}/console-logs`,{method:"POST",noLog:!0},3,5e3);return da.parse(o)}async generateNetworkLogsForRunAttemptUploadUrl(e,t,r){let o=await this.sendRequest(`/${$}/runs/${t}/attempts/${r}/network-logs`,{method:"POST",noLog:!0},3,1e4);return da.parse(o)}async generateHtmlSnapshotUploadUrl(e,t){let r=await this.sendRequest(`/${$}/snapshots/${t}/html`,{method:"POST",noLog:!0},3,1e4);return da.parse(r)}async reportBillableEvents(e,t){try{await this.sendRequest(`/${$}/billing/events`,{method:"POST",body:t,noLog:!0},10,1e4)}catch(r){e.error({err:r},"Failed to report billable event")}}async fetchTestFragment(e){let t=await this.sendRequest(`/${$}/test-fragments/${e}`,{method:"GET",noLog:!0},3,1e4);return zg.parse(t)}async patchTestFragment(e,t){await this.sendRequest(`/${$}/test-fragments/${e}`,{method:"PATCH",body:t},3,1e4)}async getPastTestResults(e,t){let r=await this.sendRequest(`/${$}/results/tests/${e}`,{method:"POST",body:t},3,1e4);return Hg.parse(r)}async generateTestResultsUploadUrl(){let e=await this.sendRequest(`/${$}/results/uploads`,{method:"POST",noLog:!0},3,1e4);return jg.parse(e)}async startProcessingResultsUpload(e,t){let r=await this.sendRequest(`/${$}/results/uploads/${e}/process`,{method:"POST",noLog:!0,body:t},3,1e4);return $g.parse(r)}async fetchIconKnowledgeBase(e){try{let t=await this.sendRequest(`/${$}/knowledge-base/icons`,{method:"GET",noLog:!0},3,5e3);return Xg.parse(t)}catch(t){return e.error({err:t},"Failed to fetch icon knowledge base"),null}}async saveNewIcons(e,t){try{await this.sendRequest(`/${$}/knowledge-base/icons`,{method:"POST",body:e,noLog:!0},3,5e3)}catch(r){t.error({err:r},"Failed to save new icons to icon knowledge base")}}async getMergeBaseCommitFromGithub(e,t,r,o){let i=new URLSearchParams;i.set("base",r),i.set("head",o);let a=await this.sendRequest(`/${$}/git/github/${e}/${t}/merge-base-commit?${i.toString()}`,{method:"GET",noLog:!0},3,1e4);return Rd.parse(a)}async getMergeBaseCommitFromGitlab(e,t,r){let o=new URLSearchParams;o.set("base",t),o.set("head",r);let i=await this.sendRequest(`/${$}/git/gitlab/${e}/merge-base-commit?${o.toString()}`,{method:"GET",noLog:!0},3,5e3);return Rd.parse(i)}async getAgentConfig(){let e=await this.sendRequest(`/${$}/web-agent/agent-config`,{method:"GET",noLog:!0},3,5e3);return hp.record(hp.string(),hp.string()).parse(e)}};import{randomUUID as fy}from"crypto";var wl=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??fy(),properties:md({},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??fy(),properties:md({creditsUsed:r,usedBy:t},o)}])}catch(i){e.error({err:i},"Failed to report credits used")}}};function di(n,e,t){return fetch(n,{method:"PUT",body:t,headers:{"Content-Type":e}})}var vl=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 di(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 di(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 di(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 pi=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 JP,en as XP}from"@faker-js/faker";var ui="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 JP({locale:XP}),this.fakerInstance.seed(e.fakerSeed))}async sendAiGenerate(e){let t=typeof e=="string"?{input:e}:e;return this.httpClient.sendRequest(`/${ui}/tools/ai/generate`,{method:"POST",body:t}).catch(r=>{throw r instanceof bn?new Error(r.rawError):new Error(`Failed to send AI generation: ${r.message}`)})}async sendSms(e){return this.httpClient.sendRequest(`/${ui}/tools/sms/send`,{method:"POST",body:e}).then(()=>{}).catch(t=>{throw t instanceof bn?new Error(t.rawError):new Error(`Failed to send sms: ${t.message}`)})}async fetchLatestSms(e){return this.httpClient.sendRequest(`/${ui}/tools/sms/fetchLatest`,{method:"POST",body:e}).catch(t=>{throw t instanceof bn?new Error(t.rawError):t})}async sendEmail(e){return this.httpClient.sendRequest(`/${ui}/tools/email/send`,{method:"POST",body:e}).then(()=>{}).catch(t=>{throw t instanceof bn?new Error(t.rawError):new Error(`Failed to send email: ${t.message}`)})}async fetchAllEmails(e){return this.httpClient.sendRequest(`/${ui}/tools/email/fetchAll`,{method:"POST",body:e}).catch(t=>{throw t instanceof bn?new Error(t.rawError):new Error(`Failed to fetch all emails: ${t.message}`)})}async fetchLatestEmail(e){return this.httpClient.sendRequest(`/${ui}/tools/email/fetchLatest`,{method:"POST",body:e}).catch(t=>{throw t instanceof bn?new Error(t.rawError):new Error(`Failed to fetch latest emails: ${t.message}`)})}};import{z as ZP}from"zod";var mi=class extends Ft{agentConfig;constructor(e,t){super(t),this.agentConfig=e}async rankChunksWithAi(e,t){let r={...e,loggerTags:t.loggerTags},o=await this.sendRequest(`/${$}/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(`/${$}/web-agent/recommend-chunks`,{method:"POST",body:{cliVersion:_a,...e},signal:t.abortSignal});return vh.parse(r)}async getScreenshotFromS3(e){let t=await this.sendRequest(`/${$}/s3/visual-diff-screenshot`,{method:"POST",body:{url:e}});return ZP.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(`/${$}/web-agent/locate-element`,{method:"POST",body:r,signal:t.abortSignal});return Cg.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(`/${$}/web-agent/assertion`,{method:"POST",body:r,signal:t.abortSignal});return Td.parse(o)}async getLintStepResult(e,t){let r={...e,disableCache:!!t.disableCache,loggerTags:t.loggerTags},o=await this.sendRequest(`/${$}/web-agent/lint/step`,{method:"POST",body:r,signal:t.abortSignal});return Tg.parse(o)}async getVisualAssertionResult(e,t){let r={...e,disableCache:!!t.disableCache,useConsensus:!!t.useConsensus,loggerTags:t.loggerTags},o=await this.sendRequest(`/${$}/web-agent/visual-assertion`,{method:"POST",body:r,signal:t.abortSignal});return Td.parse(o)}async getAiActionCommand(e,t){let r=await this.sendRequest(`/${$}/web-agent/next-command-dynamic`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return xg.parse(r)}async getMultiturnAiActionCommand(e,t){return await this.sendRequest(`/${$}/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(`/${$}/web-agent/ai-action/evaluate`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Hc.parse(r)}async getReverseMappedDescription(e,t){let r=await this.sendRequest(`/${$}/web-agent/reverse-mapped-description`,{method:"POST",body:{...e,disableCache:t.disableCache,loggerTags:t.loggerTags},signal:t.abortSignal});return Rg.parse(r)}async getTextExtraction(e,t){let r={...e,disableCache:t.disableCache,loggerTags:t.loggerTags},o=await this.sendRequest(`/${$}/web-agent/text-extraction`,{method:"POST",body:r,signal:t.abortSignal});return zc.parse(o)}async getTestResultClassification(e,t){let r=await this.sendRequest(`/${$}/web-agent/result-classification`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return Qc.parse(r)}async getExtractedKeywords(e,t){let r=await this.sendRequest(`/${$}/web-agent/extract-keywords`,{method:"POST",body:{goal:e,disableCache:t.disableCache,context:e},signal:t.abortSignal});return Oh.parse(r)}async getAutohealingProposal(e,t){let r=await this.sendRequest(`/${$}/web-agent/autoheal-section`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return bm.parse(r)}async getFailureRecoveryProposal(e,t){let r=await this.sendRequest(`/${$}/web-agent/failure-recovery`,{method:"POST",body:{...e,loggerTags:t.loggerTags},signal:t.abortSignal});return wm.parse(r)}async getIframeRegex(e,t){let r=await this.sendRequest(`/${$}/web-agent/iframe-regex`,{method:"POST",body:e,signal:t.abortSignal});return em.parse(r)}};var hi=class extends Ft{generator;constructor(e,t){super(e),this.generator=t}async runTemplateMatching(e,t={}){let r=await this.sendRequest(`/${$}/web-agent/template-matching`,{method:"POST",body:e,signal:t?.signal});return tm.parse(r)}async constructIframeRegex(e,t={}){return this.generator.getIframeRegex(e,{abortSignal:t.signal})}};var El=class{constructor(e){this.client=e}async uploadResultsArchive(e,t){let{uploadUrl:r,id:o}=await this.client.generateTestResultsUploadUrl(),i=await di(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 gi({orgId:n,client:e,gitMetadata:t,alwaysSaveCache:r,noCache:o}){return o?new Ja:new gp(n,e,t,r)}var gp=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[yg]=r),o&&(this.cacheHeaders[bg]=o),a&&(this.cacheHeaders[wg]=a.toISOString()),s&&(this.cacheHeaders[vg]=s),l&&(this.cacheHeaders[Eg]=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&&$o({steps:s,stepCacheEntries:i,logger:e.logger});let{cachesToSave:a}=await Dt({stepLists:e.stepLists,cacheCreationParams:{testId:e.testId,orgId:this.orgId}});this.client.updateStepCaches({entries:a,testId:e.testId},this.cacheHeaders)}};import ok from"path";import{Server as PM}from"socket.io";import{cloneDeep as QP}from"lodash-es";var eL={showOverlay:!1},fp=class{sessions=new Map;sessionCountByIp=new Map;getCurrentConnectionsByIp(e){return this.sessionCountByIp.get(e)??0}getCurrentSessionsByIp(){return Object.fromEntries(this.sessionCountByIp)}reserveCapacityByIp(e){e&&this.sessionCountByIp.set(e,(this.sessionCountByIp.get(e)??0)+1)}releaseCapacityByIp(e){e&&this.sessionCountByIp.set(e,Math.max(this.getCurrentConnectionsByIp(e)-1,0))}registerSession({controller:e,context:t,cleanup:r,clientIp:o,sessionId:i,browserbaseSessionId:a}){return this.sessions.set(i,{controller:e,context:t,cleanup:r,clientIp:o,browserbaseSessionId:a,browserBehavior:QP(eL)}),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)}},Z=new fp;function Sy(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=Z.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=Z.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 tL=n=>()=>{let{sessionId:e}=n.metadata;yr[e]?.abort?.abort()},yy={event:"cancelApiTest",createHandler:tL};import{CookieJar as wL}from"tough-cookie";import{randomUUID as cL}from"crypto";import{faker as nL}from"@faker-js/faker";import rL from"assert";import oL from"axios";import iL from"moment";import*as aL from"otpauth";import sL from"pg";async function by(n){let e;try{e=new URL(n.url).hostname}catch{}let t=[];return n.headers.getSetCookie()?.forEach(r=>{let o=Ms(r,e);t.push(...o)}),t}var lL=Object.getPrototypeOf(async function(){}).constructor;async function wy(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 lL("axios","moment","faker","assert","pg","Octokit","createAppAuth","OTPAuth","extractCookiesFromResponse","env","setVariable","setPersistentVariable","sendSms","waitForLatestSms","email","sms","ai",r)(oL,iL,i.fakerInstance??nL,rL,sL,d,p,aL,by,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 U(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 vy({code:n,fragment:e,context:t,localTools:r,logger:o,signal:i,timeoutMs:a=lr}){let s=cL(),l=await wy(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 dL,randomUUID as pL}from"crypto";import uL from"fetch-retry";var mL=uL(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}}),Ey=process.env.GCP_JS_EVAL_FUNCTION_ENDPOINT,xy=process.env.MOMENTIC_LAMBDA_AUTH_SECRET;async function Ty({orgId:n,code:e,fragment:t,context:r,timeoutMs:o=lr,retries:i=2,signal:a,logger:s}){if(!Ey)throw new Error("GCP_JS_EVAL_FUNCTION_ENDPOINT environment variable not set");let l,c,d=0;if(!xy)throw new Error("Missing lambda auth secret.");let p=dL("sha256",xy).update(n).digest("hex");for(;d<=i;){d++,a?.throwIfAborted();let m={id:pL(),orgId:n,momenticLambdaAuthHash:p,code:e,fragment:t,state:r.toObjectCopy(),timeoutMs:o};try{if(l=await U(mL(Ey,{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=Bh.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 Yn(n){let e;if(process.env.GCP_JS_EVAL_FUNCTION_ENDPOINT)e=await Ty(n);else if(n.localTools)e=await vy({...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 mL}from"lodash-es";async function Gt(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 Yn({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 A("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 Si(n){return Ry(n)}async function Ry({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 Gt({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 Ry({obj:c,bannedKeys:e,context:r,prefixPath:d,replacements:i,allowList:l?void 0:t,...a})}return i}function Ay(n,e){for(let{path:t,original:r}of e)mL(n,t,r)}import hL from"fetch-retry";var g6=process.env.MAILINATOR_API_KEY,f6=hL(global.fetch,{retryOn:function(n,e,t){return n>3?!1:!!(e!==null||t&&t.status>=400)},retryDelay:function(n){return 500}});import fL from"fetch-cookie";import{cloneDeep as SL}from"lodash-es";var gL=3e4;async function El({command:n,logger:e,baseUrl:t,fetchImplementation:r=fetch}){let o=n.timeout??gL/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(Wo(n.url)&&(l=n.url),t&&Vo(n.url,t)&&(l=new URL(n.url,t).toString()),!l)throw new A("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 U((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 A("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 A("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 Iy(n){let{fixtures:e,inputs:t}=n,{context:r}=e,{orgId:o,step:i}=t,a=SL(i);await Si({obj:a,orgId:o,bannedKeys:["code"],...e});let s=await yL(n);return a.envKey&&s.data&&r.setVariable(a.envKey,s.data),s}async function yL(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 Yn({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=fL(fetch,a),d=await El({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 Py(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 bL,m={cookieJar:u,...t};for(let h of i){let g=new Date;c.onStarted?.(h.id);let f;try{o?.throwIfAborted(),f=await Iy({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:_s(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 Ly(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 Sp({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 Sp({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 Ft({...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?.[Ve];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 wL=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:x}=await Sp({testId:p,orgId:d,logger:m,storage:S,authorization:o}),y={context:f,logger:m,localTools:w,signal:g.signal,flagStore:await l(d)},R=await Py({inputs:{steps:r,orgId:d,baseUrl:x},fixtures:y,callbacks:{test:{onFinished:()=>{a.emit("apiTestFinished")}},step:{onStarted:L=>{a.emit("apiStepStarted",L)},onFinished:L=>{a.emit("apiStepFinished",L)}}}});t({result:R})},Oy={event:"executeApiTest",createHandler:wL};var vL=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async()=>{e.info({sessionId:t},"Cancel event received");let r=Z.getSession(t);if(!r)throw new Error("No active session found");try{r.controller.setClosed()}catch{}}},My={event:"cancel",createHandler:vL};var xL=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async(r,o)=>{let i=Z.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})}}},Ny={event:"fetchA11yTree",createHandler:xL};var EL=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async(r,o)=>{let i=Z.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})}}},ky={event:"fetchDom",createHandler:EL};var TL=({metadata:n,logger:e})=>{let{sessionId:t,type:r}=n;return o=>{e.info({sessionId:t,reason:o},`Disconnect event received (${o})`),r==="e2e"?Z.removeSession(t,e):r==="api-test"&&delete yr[t]}},_y={event:"disconnect",createHandler:TL};function an(n){let{result:e,nestedResults:t}=n;if(!n.nestedResults.length)return;let{firstMetadata:r,lastMetadata:o}=CL(t);RL(e,r,o);let i=[...n.asyncTasks];n.asyncTasks.push((async()=>{try{await AL(i,e,r,o)}catch(a){n.logger.error({result:n.result,err:a},"Error hoisting scalar result metadata")}})())}function CL(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 RL(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 AL(n,e,t,r){await Promise.allSettled(n),t&&(e.beforeSnapshot=t.beforeSnapshot),r&&(e.afterSnapshot=r.afterSnapshot)}import Da from"os";import IL from"v8";var Dy,Mn,PL=Da.platform(),LL=Da.cpus().map(n=>({model:n.model,speed:n.speed}));function Fy(n){let e=()=>{try{let t=!1,r=OL(),o=ML();r.freeMemory<1e6&&(t=!0);let i=IL.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:LL,platform:PL}}function OL(){let n=Da.totalmem(),e=Da.freemem(),t=n-e;return{totalMemory:n,freeMemory:e,usedMemory:t}}function ML(){let n=Da.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,!Mn)return Mn=t,null;let r={user:t.user-Mn.user,nice:t.nice-Mn.nice,sys:t.sys-Mn.sys,idle:t.idle-Mn.idle,irq:t.irq-Mn.irq,total:t.total-Mn.total};return Dy={measurementTime:e,intervalMs:e-Mn.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},Mn=t,Dy}import{hostname as FL}from"os";async function By(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 ee(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=>NL(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 A)||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 NL(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)},!Uy(s,r.value,r.operation,!!r.negated)){let l=r.negated?dr[r.operation]:pr[r.operation];o=!1,i=new A("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 A("AssertionFailureError",`The element does not have an attribute named ${r.attr}: ${l}`),o=!1;break}if(!Uy(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 A("AssertionFailureError",`The attribute ${r.attr} ${l}: ${s}`):new A("AssertionFailureError",`The attribute ${r.attr} ${l}`):i=new A("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},Rn*1e3);break}case"EDITABLE":{o=await n.isEditable({timeout:Rn*1e3});break}case"EXISTS":{o=!0;break}case"ENABLED":{o=await n.isEnabled({timeout:Rn*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?Ld[r.condition]:Od[r.condition];i=new A("AssertionFailureError",`The element ${s}`)}break}}return{success:o,data:a,err:i}}function Uy(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 kL}from"jimp";async function Fa(n,e){let t=await n.screenshot(e),r=await kL.fromBuffer(t);return{buffer:t,width:Math.ceil(r.bitmap.width??0),height:Math.ceil(r.bitmap.height??0)}}import{Jimp as zy}from"jimp";import yp from"jpeg-js";import _L from"pixelmatch";async function Hy({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 z=>Fa(o,{locator:z.locator,...l}),options:{...t,disableCache:r,disableGlobalLocatorRedirect:!0}})).result:c=await Fa(o,l);let d=await s.prepareGoldenScreenshotForComparison(a,t,c);if((c.height!==d.height||c.width!==d.width)&&a.debug({currHeight:c.height,currWidth:c.width,savedHeight:d.height,savedWidth:d.width},"Mismatched before and after visual diff screenshot sizes"),Math.abs(c.height-d.height)>10||Math.abs(c.width-d.width)>10){let H=`${c.width}x${c.height}`,z=`${d.width}x${d.height}`;return{fail:!0,thoughts:`Current screenshot (${H}) does not match saved screenshot dimensions (${z}) - 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 zy.fromBuffer(c.buffer),u={width:c.width,height:c.height},m=await zy.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),x=Math.abs(u.width-h.width);if(f>S){let H=p.cover({w:h.width,h:h.height});c.buffer=await H.getBuffer("image/jpeg"),g="current",c.width=h.width,c.height=h.height}else if(S>f){let H=m.cover({w:u.width,h:u.height});d.buffer=await H.getBuffer("image/jpeg"),g="saved"}let y={data:Buffer.alloc(c.width*c.height*4),width:c.width,height:c.height},T=t.threshold??.1,R=_L(yp.decode(d.buffer).data,yp.decode(c.buffer).data,y.data,c.width,c.height,{threshold:T,diffColorAlt:[0,255,0]})/(c.width*c.height)*100,L=R>T*100,N=`Visual diff of ${R.toFixed(2)}% detected, which is ${L?"over":"under"} the threshold of ${T*100}%.`;if(g&&(N+=` The ${g} screenshot was cropped since it was taller by ${w} pixels and wider by ${x} pixels.`),L)throw new A("ActionFailureError",N);return{fail:L,thoughts:N,beforeScreenshotOverride:c.buffer,afterScreenshotOverride:yp.encode(y,75).data,succeedImmediately:!1,urlAfterCommand:o.url()}}var DL=5e3;async function Tl({timeout:n=Rn,...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 jy(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 ee(s,e.signal),s=Math.min(Math.floor(s*1.5),DL);else return i}return i=await jy(e),i}async function jy({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($y,{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($y,{value:n.value,negated:!!n.negated,returnHtml:!0},"checking page content"));if(!i){let l=n.negated?dr.CONTAINS:pr.CONTAINS;a=new A("AssertionFailureError",`The page ${l} '${n.value}'.`),o=s}}catch(s){a=new A("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 $y({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 bp=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 Gt({orgId:c,s:f,context:o,logger:r,localTools:a,signal:p,flagStore:s.flagStore});g={orgId:c,cacheKeys:[S,...Object.entries(t).map(([x,y])=>`${x}:${y}`)]},r.debug({original:f,keyParams:g},"Module cache key params");let w=Date.now();for(;Date.now()-w<fg;){p?.throwIfAborted();let x=await i.getCacheResult(g);if(x){r.debug({cacheResult:x},"Got result from module execution cache"),u=Cl(e,t,"SUCCESS"),u.message="Used cached module result.",u.data=JSON.parse(x),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:${FL()};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 ee(2500+Math.random()*1e4,p)}}try{if(!u)u=await UL(n);else if(e.autoAuth){let f=ks.safeParse(u.data);if(!f.success)throw new A("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 x={type:"CONTENT",value:w.substring},y=await Tl({timeout:Rn,assertion:x,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),bp(n)}}finally{try{h!==void 0&&!m&&u?.status==="SUCCESS"&&await BL({step:e,result:u,browser:s.browser,cacheKeyPrefix:h,logger:r,storage:i})}finally{h!==void 0&&await i.releaseCacheLock(h)}}return u},UL=async n=>{let{step:e,tracer:t}=n.moduleParams,r=Cl(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,an({asyncTasks:n.work.asyncTasks,nestedResults:a,result:r,logger:n.fixtures.logger}),r};function Cl(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 Gy({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 Yn({orgId:n,code:c,fragment:!0,context:t,logger:r,localTools:i,signal:a,flagStore:o})}return s}catch(l){throw a?.throwIfAborted(),new A("UserConfigurationError",`Failed to evaluate module inputs: ${l}`)}}async function BL({step:n,result:e,browser:t,cacheKeyPrefix:r,logger:o,storage:i}){let a=n.cacheConfig?.cacheExpiryMs;(!a||a===qg)&&(a=n.defaultCacheTtl??Kg);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:vf(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 A?s=`${o}`:s=`An unexpected error occurred: ${o.message}`,n.type==="RESOLVED_MODULE"){let l=Cl(n,{},"FAILED");return l.message=s,l.startedAt=r,l.finishedAt=i,l}return{...Js(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 Wy}from"crypto";import{cloneDeep as HL}from"lodash-es";function Rl(n,e){n.state.healingDetails?n.state.healingDetails.push(e):n.state.healingDetails=[e]}var Al=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=sa(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=Wy(),S=Wy();if(s)try{g=await o.browser.screenshot({retries:1,clearHighlights:!0,quality:75});let C=await o.browser.getRawCondensedHtml();t.attachBeforeHtmlSnapshot({logger:p,snapshotId:f,html:C}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeHtmlSnapshot(p,f,C))}catch(C){p.debug({err:C},"Failed to take screenshot before step, likely because the page is still loading. This is non-fatal and does not affect the test.")}let w,x,y,T=Ls();try{let C=await o.executePresetCommand(T,t,e.command,i,l?.advanced.disableAICaching??!1);C.beforeScreenshotOverride&&(g=C.beforeScreenshotOverride),y=C.afterScreenshotOverride;let{proposedStep:R}=jL({work:n.work,step:e,newTargets:C.newTargets,logger:p}),L=new Date,N=o.browser.url();x={beforeUrl:m,afterUrl:N,startedAt:h,finishedAt:L,viewport:o.browser.getViewport(),status:C.fail?"FAILED":"SUCCESS",elementInteracted:C.elementInteracted},w={...e,message:C.thoughts??$L(C.newTargets)??"Successfully executed preset action.",beforeUrl:m,afterUrl:N,finishedAt:L,startedAt:h,status:C.fail?"FAILED":"SUCCESS",data:C.data,results:[x],details:T.details,proposedStep:R},"assertion"in e.command&&(w.message=C.thoughts||"Assertion passed.")}catch(C){p.error({message:C.message,stack:C.stack},`Failed executing preset step ${Gr(e.command)}`);let R=o.browser.url(),L=new Date,N=C instanceof Error?C.message:`${C}`;C instanceof A&&C.getLastScreenshotBuffer()&&(y=C.getLastScreenshotBuffer()),x={beforeUrl:m,afterUrl:R,startedAt:h,finishedAt:L,viewport:o.browser.getViewport(),status:C instanceof DOMException&&C.name==="AbortError"?"CANCELLED":"FAILED",message:N},w={...e,startedAt:h,finishedAt:L,beforeUrl:m,afterUrl:R,status:C instanceof DOMException&&C.name==="AbortError"?"CANCELLED":"FAILED",message:N,failureReason:C instanceof A?C.reason:void 0,results:[x],details:T.details}}if(s)try{y||(y=await o.browser.screenshot({retries:1,quality:75}));let C=await o.browser.getRawCondensedHtml();t.attachAfterHtmlSnapshot({logger:p,snapshotId:S,html:C}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeHtmlSnapshot(p,S,C))}catch(C){p.debug({err:C},"Failed store debug data after step, likely because the page is still loading. This is non-fatal and does not affect the test.")}return x.beforeSnapshot=f,w.beforeSnapshot=f,x.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 jL({work:n,step:e,newTargets:t,logger:r}){if(!t?.length)return{proposedStep:void 0};let o=e.command;hf(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={...HL(e),command:a};return Rl(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 $L(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
|
|
54
|
-
${R}`}),u;case"RIGHT_TRACK":{
|
|
55
|
-
${C.feedback}`,w++,w>=
|
|
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 hL}from"lodash-es";async function Gt(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 Yn({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 A("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 fi(n){return Cy(n)}async function Cy({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 Gt({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 Cy({obj:c,bannedKeys:e,context:r,prefixPath:d,replacements:i,allowList:l?void 0:t,...a})}return i}function Ry(n,e){for(let{path:t,original:r}of e)hL(n,t,r)}import gL from"fetch-retry";var f6=process.env.MAILINATOR_API_KEY,S6=gL(global.fetch,{retryOn:function(n,e,t){return n>3?!1:!!(e!==null||t&&t.status>=400)},retryDelay:function(n){return 500}});import SL from"fetch-cookie";import{cloneDeep as yL}from"lodash-es";var fL=3e4;async function xl({command:n,logger:e,baseUrl:t,fetchImplementation:r=fetch}){let o=n.timeout??fL/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(Go(n.url)&&(l=n.url),t&&Wo(n.url,t)&&(l=new URL(n.url,t).toString()),!l)throw new A("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 U((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 A("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 A("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 Ay(n){let{fixtures:e,inputs:t}=n,{context:r}=e,{orgId:o,step:i}=t,a=yL(i);await fi({obj:a,orgId:o,bannedKeys:["code"],...e});let s=await bL(n);return a.envKey&&s.data&&r.setVariable(a.envKey,s.data),s}async function bL(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 Yn({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=SL(fetch,a),d=await xl({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 Iy(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 wL,m={cookieJar:u,...t};for(let h of i){let g=new Date;c.onStarted?.(h.id);let f;try{o?.throwIfAborted(),f=await Ay({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:_s(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 Py(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 Sp({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 Sp({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 Ft({...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 vL=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 Sp({testId:p,orgId:d,logger:m,storage:S,authorization:o}),y={context:f,logger:m,localTools:w,signal:g.signal,flagStore:await l(d)},R=await Iy({inputs:{steps:r,orgId:d,baseUrl:E},fixtures:y,callbacks:{test:{onFinished:()=>{a.emit("apiTestFinished")}},step:{onStarted:L=>{a.emit("apiStepStarted",L)},onFinished:L=>{a.emit("apiStepFinished",L)}}}});t({result:R})},Ly={event:"executeApiTest",createHandler:vL};var EL=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async()=>{e.info({sessionId:t},"Cancel event received");let r=Z.getSession(t);if(!r)throw new Error("No active session found");try{r.controller.setClosed()}catch{}}},Oy={event:"cancel",createHandler:EL};var xL=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async(r,o)=>{let i=Z.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})}}},Ny={event:"fetchA11yTree",createHandler:xL};var TL=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async(r,o)=>{let i=Z.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})}}},My={event:"fetchDom",createHandler:TL};var CL=({metadata:n,logger:e})=>{let{sessionId:t,type:r}=n;return o=>{e.info({sessionId:t,reason:o},`Disconnect event received (${o})`),r==="e2e"?Z.removeSession(t,e):r==="api-test"&&delete yr[t]}},ky={event:"disconnect",createHandler:CL};function an(n){let{result:e,nestedResults:t}=n;if(!n.nestedResults.length)return;let{firstMetadata:r,lastMetadata:o}=RL(t);AL(e,r,o);let i=[...n.asyncTasks];n.asyncTasks.push((async()=>{try{await IL(i,e,r,o)}catch(a){n.logger.error({result:n.result,err:a},"Error hoisting scalar result metadata")}})())}function RL(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 AL(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 IL(n,e,t,r){await Promise.allSettled(n),t&&(e.beforeSnapshot=t.beforeSnapshot),r&&(e.afterSnapshot=r.afterSnapshot)}import Da from"os";import PL from"v8";var _y,On,LL=Da.platform(),OL=Da.cpus().map(n=>({model:n.model,speed:n.speed}));function Dy(n){let e=()=>{try{let t=!1,r=NL(),o=ML();r.freeMemory<1e6&&(t=!0);let i=PL.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:OL,platform:LL}}function NL(){let n=Da.totalmem(),e=Da.freemem(),t=n-e;return{totalMemory:n,freeMemory:e,usedMemory:t}}function ML(){let n=Da.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 _y={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,_y}import{hostname as UL}from"os";async function Uy(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 ee(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=>kL(S.locator,n),options:{...e,disableCache:i,disableGlobalLocatorRedirect:!0,source:Mr(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 A)||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 kL(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)},!Fy(s,r.value,r.operation,!!r.negated)){let l=r.negated?dr[r.operation]:pr[r.operation];o=!1,i=new A("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 A("AssertionFailureError",`The element does not have an attribute named ${r.attr}: ${l}`),o=!1;break}if(!Fy(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 A("AssertionFailureError",`The attribute ${r.attr} ${l}: ${s}`):new A("AssertionFailureError",`The attribute ${r.attr} ${l}`):i=new A("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},Rn*1e3);break}case"EDITABLE":{o=await n.isEditable({timeout:Rn*1e3});break}case"EXISTS":{o=!0;break}case"ENABLED":{o=await n.isEnabled({timeout:Rn*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?Ld[r.condition]:Od[r.condition];i=new A("AssertionFailureError",`The element ${s}`)}break}}return{success:o,data:a,err:i}}function Fy(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 _L}from"jimp";async function Fa(n,e){let t=await n.screenshot(e),r=await _L.fromBuffer(t);return{buffer:t,width:Math.ceil(r.bitmap.width??0),height:Math.ceil(r.bitmap.height??0)}}import{Jimp as By}from"jimp";import yp from"jpeg-js";import DL from"pixelmatch";async function zy({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 z=>Fa(o,{locator:z.locator,...l}),options:{...t,disableCache:r,disableGlobalLocatorRedirect:!0}})).result:c=await Fa(o,l);let d=await s.prepareGoldenScreenshotForComparison(a,t,c);if((c.height!==d.height||c.width!==d.width)&&a.debug({currHeight:c.height,currWidth:c.width,savedHeight:d.height,savedWidth:d.width},"Mismatched before and after visual diff screenshot sizes"),Math.abs(c.height-d.height)>10||Math.abs(c.width-d.width)>10){let H=`${c.width}x${c.height}`,z=`${d.width}x${d.height}`;return{fail:!0,thoughts:`Current screenshot (${H}) does not match saved screenshot dimensions (${z}) - 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 By.fromBuffer(c.buffer),u={width:c.width,height:c.height},m=await By.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 H=p.cover({w:h.width,h:h.height});c.buffer=await H.getBuffer("image/jpeg"),g="current",c.width=h.width,c.height=h.height}else if(S>f){let H=m.cover({w:u.width,h:u.height});d.buffer=await H.getBuffer("image/jpeg"),g="saved"}let y={data:Buffer.alloc(c.width*c.height*4),width:c.width,height:c.height},T=t.threshold??.1,R=DL(yp.decode(d.buffer).data,yp.decode(c.buffer).data,y.data,c.width,c.height,{threshold:T,diffColorAlt:[0,255,0]})/(c.width*c.height)*100,L=R>T*100,M=`Visual diff of ${R.toFixed(2)}% detected, which is ${L?"over":"under"} the threshold of ${T*100}%.`;if(g&&(M+=` The ${g} screenshot was cropped since it was taller by ${w} pixels and wider by ${E} pixels.`),L)throw new A("ActionFailureError",M);return{fail:L,thoughts:M,beforeScreenshotOverride:c.buffer,afterScreenshotOverride:yp.encode(y,75).data,succeedImmediately:!1,urlAfterCommand:o.url()}}var FL=5e3;async function Tl({timeout:n=Rn,...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 Hy(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 ee(s,e.signal),s=Math.min(Math.floor(s*1.5),FL);else return i}return i=await Hy(e),i}async function Hy({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(jy,{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(jy,{value:n.value,negated:!!n.negated,returnHtml:!0},"checking page content"));if(!i){let l=n.negated?dr.CONTAINS:pr.CONTAINS;a=new A("AssertionFailureError",`The page ${l} '${n.value}'.`),o=s}}catch(s){a=new A("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 jy({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 bp=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 Gt({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<gg;){p?.throwIfAborted();let E=await i.getCacheResult(g);if(E){r.debug({cacheResult:E},"Got result from module execution cache"),u=Cl(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:${UL()};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 ee(2500+Math.random()*1e4,p)}}try{if(!u)u=await BL(n);else if(e.autoAuth){let f=ks.safeParse(u.data);if(!f.success)throw new A("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 Tl({timeout:Rn,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),bp(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},BL=async n=>{let{step:e,tracer:t}=n.moduleParams,r=Cl(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,an({asyncTasks:n.work.asyncTasks,nestedResults:a,result:r,logger:n.fixtures.logger}),r};function Cl(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 $y({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 Yn({orgId:n,code:c,fragment:!0,context:t,logger:r,localTools:i,signal:a,flagStore:o})}return s}catch(l){throw a?.throwIfAborted(),new A("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===Vg)&&(a=n.defaultCacheTtl??qg);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:wf(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 A?s=`${o}`:s=`An unexpected error occurred: ${o.message}`,n.type==="RESOLVED_MODULE"){let l=Cl(n,{},"FAILED");return l.message=s,l.startedAt=r,l.finishedAt=i,l}return{...Js(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 Gy}from"crypto";import{cloneDeep as jL}from"lodash-es";function Rl(n,e){n.state.healingDetails?n.state.healingDetails.push(e):n.state.healingDetails=[e]}var Al=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=aa(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=Gy(),S=Gy();if(s)try{g=await o.browser.screenshot({retries:1,clearHighlights:!0,quality:75});let C=await o.browser.getRawCondensedHtml();t.attachBeforeHtmlSnapshot({logger:p,snapshotId:f,html:C}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeHtmlSnapshot(p,f,C))}catch(C){p.debug({err:C},"Failed to take screenshot before step, likely because the page is still loading. This is non-fatal and does not affect the test.")}let w,E,y,T=Ls();try{let C=await o.executePresetCommand(T,t,e.command,i,l?.advanced.disableAICaching??!1);C.beforeScreenshotOverride&&(g=C.beforeScreenshotOverride),y=C.afterScreenshotOverride;let{proposedStep:R}=$L({work:n.work,step:e,newTargets:C.newTargets,logger:p}),L=new Date,M=o.browser.url();E={beforeUrl:m,afterUrl:M,startedAt:h,finishedAt:L,viewport:o.browser.getViewport(),status:C.fail?"FAILED":"SUCCESS",elementInteracted:C.elementInteracted},w={...e,message:C.thoughts??GL(C.newTargets)??"Successfully executed preset action.",beforeUrl:m,afterUrl:M,finishedAt:L,startedAt:h,status:C.fail?"FAILED":"SUCCESS",data:C.data,results:[E],details:T.details,proposedStep:R},"assertion"in e.command&&(w.message=C.thoughts||"Assertion passed.")}catch(C){p.error({message:C.message,stack:C.stack},`Failed executing preset step ${$r(e.command)}`);let R=o.browser.url(),L=new Date,M=C instanceof Error?C.message:`${C}`;C instanceof A&&C.getLastScreenshotBuffer()&&(y=C.getLastScreenshotBuffer()),E={beforeUrl:m,afterUrl:R,startedAt:h,finishedAt:L,viewport:o.browser.getViewport(),status:C instanceof DOMException&&C.name==="AbortError"?"CANCELLED":"FAILED",message:M},w={...e,startedAt:h,finishedAt:L,beforeUrl:m,afterUrl:R,status:C instanceof DOMException&&C.name==="AbortError"?"CANCELLED":"FAILED",message:M,failureReason:C instanceof A?C.reason:void 0,results:[E],details:T.details}}if(s)try{y||(y=await o.browser.screenshot({retries:1,quality:75}));let C=await o.browser.getRawCondensedHtml();t.attachAfterHtmlSnapshot({logger:p,snapshotId:S,html:C}),n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeHtmlSnapshot(p,S,C))}catch(C){p.debug({err:C},"Failed store debug data after step, likely because the page is still loading. This is non-fatal and does not affect the test.")}return 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 $L({work:n,step:e,newTargets:t,logger:r}){if(!t?.length)return{proposedStep:void 0};let o=e.command;mf(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={...jL(e),command:a};return Rl(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 GL(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 Wy({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 Nn({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 WL=["NAVIGATE","NEW_TAB","TAB","REFRESH","WAIT_FOR_URL"];async function Vy({beforeUrl:n,beforePages:e,browser:t,command:r,logger:o}){if(WL.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 ee(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(Kr(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 qy="MOMENTIC_RUN_ID",Ky="FINAL_SCREENSHOT_URL";import{cloneDeep as eO}from"lodash-es";async function Yy(n){let{step:e,tracer:t}=n.conditionalParams,{logger:r,controller:o}=n.fixtures,i=new Date,a=Js(e),s=e.elseSteps,l=!0,c=[],d,p=Ls();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 Al({...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 an({asyncTasks:n.work.asyncTasks,nestedResults:[...c,...m.results],result:g,logger:r}),g}import{randomUUID as Jy}from"crypto";var Xy=async n=>{let{controller:e}=n.fixtures;await e.browser.waitForDOMStability();let t=await e.browser.screenshot({}),r=await VL(n);r.finishedAt=new Date,an({asyncTasks:n.work.asyncTasks,result:r,nestedResults:r.results,logger:n.fixtures.logger});let o=await e.browser.screenshot({}),i=Jy();r.beforeSnapshot=i,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,i,t));let a=Jy();return r.afterSnapshot=a,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,a,o)),r},VL=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 A("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 wp}from"crypto";var Zy=15,qL=7,Qy=async n=>{let{controller:e}=n.fixtures;await e.browser.waitForDOMStability();let t=await e.browser.screenshot({quality:75}),r=await KL(n);r.finishedAt=new Date,an({asyncTasks:n.work.asyncTasks,result:r,nestedResults:r.results,logger:n.fixtures.logger});let o=await e.browser.screenshot({quality:75}),i=wp();r.beforeSnapshot=i,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,i,t));let a=wp();return r.afterSnapshot=a,n.work.asyncTasks.push(n.fixtures.debugDataStorage.storeScreenshot(n.fixtures.logger,a,o)),r},KL=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 Gt({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>Zy)return u.message=`Exceeded the maximum number of commands allowed per AI step (${Zy})`,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 T=await i.evaluateAiAction({goal:m,startingScreenshot:S===0?void 0:g,history:f,logger:p,langfuseSessionId:d,lastError:y}),{evaluation:C,reasoning:R,summary:L}=T;p.info(T,"Got AI evaluation");let M=u.results[S-1]?.id;switch(C.type){case"DONE":return u.message=`Our AI evaluator confirmed all tasks are complete: ${R}`,u.status="SUCCESS",M&&c.onDynamicAIActionEvaluatingEvent?.({stepId:M,status:"SUCCESS",message:`${L}
|
|
54
|
+
${R}`}),u;case"RIGHT_TRACK":{E=void 0,S===0?c.onDynamicAIActionEvaluatingEvent?.({stepId:e.id,status:"RUNNING",message:R}):M&&c.onDynamicAIActionEvaluatingEvent?.({stepId:M,status:"SUCCESS",message:R});break}case"WRONG_TRACK":{if(E=`${R}
|
|
55
|
+
${C.feedback}`,w++,w>=qL)return u.message=`Our AI agent requires additional information to achieve this goal:
|
|
56
56
|
${R}
|
|
57
|
-
${C.feedback}`,u.status="FAILED",c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,status:"FAILED",message:u.message}),u;N&&c.onDynamicAIActionEvaluatingEvent?.({stepId:N,status:"FAILED",message:C.feedback});break}case"IMPOSSIBLE":return u.message=`Our AI evaluator determined this task cannot be achieved: ${R}`,u.status="FAILED",c.onDynamicAIActionEvaluatingEvent?.({stepId:N??e.id,status:"FAILED",message:u.message}),u}let H=setTimeout(()=>{c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Deciding what to do next..."})},1500);p.info({commandIndex:S,lastActionHint:x},`Generating new sub-command ${S} within AI action`);let z,k;try{({command:z,reasoning:k}=await i.promptToCommand({goal:m,history:f,startingScreenshot:g,disableCache:r?.advanced.disableAICaching??!1,logger:p,actionHint:x,langfuseSessionId:d})),p.info({command:z,reasoning:k},"Got proposed command")}finally{clearTimeout(H)}if(z.type==="FAILURE")return clearTimeout(H),u.status="FAILED",u.message=`Our AI agent determined that no supported actions can fulfill the goals: ${k}`,u;let _={id:wp(),type:"PRESET_ACTION",command:z},O={substepIndex:S+1,message:k||"Generated new command."};c.onDynamicCommandGenerated?.({...O,step:_,parentStepId:e.id}),p.info({commandId:z.id},`Executing sub-command ${S} within AI step: ${Gr(z)}`);let K=await t.startSubSteps(),le=(await n.executeStepList({...n,options:{...n.options,disableHealing:!0},listParams:{containerName:"AI action newly generated step",steps:[_],tracer:K}})).results[0];c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Waiting for page to stabilize before next action..."}),await i.browser.waitForDOMStability({logger:p});let ce=await i.browser.screenshot({clearHighlights:!0,retries:1});u.results.push(le),f.push({screenshotBase64AfterCommand:`data:image/jpeg;base64,${ce.toString("base64")}`,urlAfterCommand:i.browser.url(),serializedCommand:Gr(z),elementInteracted:le.results[0]?.elementInteracted,thoughts:k});let fe={substepIndex:S,output:{...le,message:le.message??"Successfully executed preset action."},step:_,parentStepId:e.id};if(c.onDynamicCommandExecuted?.(fe),await t.finish({output:bs.parse(le),step:le,message:le.message}),le.status==="FAILED")if(u.status="FAILED",u.message=le.message,w<3)w++,y=`The last attempted action resulted in a Momentic error. A different element may need to be targeted. Error: ${le.message}`;else return u;else if(le.status==="CANCELLED")return u.status="CANCELLED",u.message=le.message,u;S++}};async function nb(n){let{results:e}=n.failureRecoveryParams,t=e[e.length-1],r=YL(t);if(r)return n.fixtures.logger.info({failedResult:t,isNotEligible:r},"Skipping failure recovery because of ineligible failure"),null;try{return await KL(n)}catch(o){return n.fixtures.logger.error({err:o},"Error during failure recovery attempt"),null}}async function tb({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 KL(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 Gs(i,e.debugDataStorage,a,{numScreenshots:3,addIndices:!0}),h=l.map(x=>mn(x)),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 x=g.patch.value;if(!x)throw new Error("No value in add patch in failure recovery");await tb({screenshot:p,controller:o,currentPageState:u,newStep:x,patch:g.patch,logger:i}),f=[x,s]}else if(g.patch.op==="replace"){let x=g.patch.value;if(!x)throw new Error("No value in replace patch in failure recovery");await tb({screenshot:p,controller:o,currentPageState:u,newStep:x,patch:g.patch,logger:i}),f=[x]}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 x of w.results)x.aiSuggested&&x.type==="PRESET_ACTION"&&(x.message=`AI suggested step: ${x.command.thoughts}`)}else w={status:"SUCCESS",results:[],proposedSteps:[]};return Rl(t,{type:"FAILURE_RECOVERY",thoughts:g.reasoning}),t.state.failureRecoveryDisabled=!0,w}function YL(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 rb(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 an({asyncTasks:n.work.asyncTasks,nestedResults:s.results,result:c,logger:r}),c}import{randomUUID as Il}from"crypto";import JL from"fast-json-patch";import{cloneDeep as XL}from"lodash-es";async function ob(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=XL(c.steps);await Promise.allSettled(i.asyncTasks??[]);let{results:w}=await Gs(p,u,e.results,{numScreenshots:4}),x=await d.runSectionAutohealing({results:w,errorMessage:e.terminalResult?.message,goal:c.description});S=JL.applyPatch(S,x.patches).newDocument;let y=Ot.fromSnapshot({snapshot:s,environmentVariables:o.context.getVariablesFromEnvironmentCopy()});await ZL({logger:p,controller:d,tracer:l,context:y,restartConfig:h,startingUrl:a});let T=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(T.results),T.status==="SUCCESS")return{successfulHealing:{proposedStep:{...c,steps:S},listResult:T,context:y},healingAttempts:t};e=T}return{healingAttempts:t}}async function ZL({logger:n,controller:e,tracer:t,restartConfig:r,context:o,startingUrl:i}){switch(r.type){case"NAVIGATE_URL":{let a={id:Il(),type:"PRESET_ACTION",command:{id:Il(),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:Il(),type:"PRESET_ACTION",command:{id:Il(),type:"NAVIGATE",url:i}},s=await t.startStep({logger:n,step:a});await e.executePresetCommand(null,s,a.command,o,!1);break}}}function ib(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"&&um(e.command.type))}}async function ab(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&&ib(e.autohealingConfig.trigger,p.terminalResult)){let g=await t.startSubSteps(),f=await ob({...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 an({asyncTasks:n.work.asyncTasks,nestedResults:p.results,result:h,logger:r}),h}async function kn(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,x=0;for(x;x<r.length;x++){let y=r[x],T,C=mn(y);if(y.skipped)continue;if(g.fastForwardingToStep&&m){let J=JSON.stringify(p);if(y.id===m.fromStepId&&J===JSON.stringify(m.parentStepIdChain))g.fastForwardingToStep=!1;else if(!sf(y,p,m.fromStepId,m.parentStepIdChain))continue}let R=new Date,L=d.child({step_id:y.id});L.track({type:"execution:step_start",step_type:y.type==="RESOLVED_MODULE"?"MODULE":y.type,command_type:"command"in y?y.command.type:void 0}),i.info({step:y},`Executing step ${x+1}/${r.length} in ${t}: ${C}`);let N=await o.startStep({logger:i,step:y}),H=QL(y),z=a.toRedactedDisplayCopy(),k=s.browser.url(),_=s.executeAbortController.signal,O=aa(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 K,B;switch(y.type){case"PRESET_ACTION":{K="Preset action",B=await wr(y,async()=>await Al({...n,presetParams:{tracer:N,step:y}}),_),"proposedStep"in B&&B.proposedStep&&(T=B.proposedStep,B.proposedStep=void 0);break}case"AI_ACTION":{K="AI action",B=await wr(y,()=>Zy({...n,aiStepParams:{step:y,tracer:N},executeStepList:kn}),_);break}case"AI_ACTION_DYNAMIC":{K="AI action",B=await wr(y,()=>eb({...n,aiStepParams:{step:y,tracer:N},executeStepList:kn}),_);break}case"RESOLVED_MODULE":{K=`Module (${y.name})`,B=await wr(y,async()=>{let J=await Gy({orgId:u,step:y,context:a,logger:i,flagStore:s.flagStore,codeEvalTools:l,signal:_});return bp({...n,executeStepList:kn,moduleParams:{step:y,resolvedInputs:J,tracer:N}})},_);break}case"CONDITIONAL":{K="Conditional step",B=await wr(y,()=>Jy({...n,conditionalParams:{step:y,tracer:N},executeStepList:kn}),_);break}case"IFRAME":{K="Frame step",B=await wr(y,()=>rb({...n,frameParams:{step:y,tracer:N},executeStepList:kn}),_);break}case"SECTION":{K="Section";let J=await wr(y,()=>ab({...n,sectionParams:{step:y,tracer:N},executeStepList:kn}),_);"proposedStep"in J&&J.proposedStep&&(T=J.proposedStep,J.proposedStep=void 0),B=J;break}default:return(_e=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(y)}B.beforeUrl=B.beforeUrl??k,B.beforeTestContext=z,y.envKey&&a.setVariable(y.envKey,B.data);let le=s.browser.url();a.setCurrentUrl(le),B.afterUrl=B.afterUrl??le,B.afterTestContext=a.toRedactedDisplayCopy(),e.push(B),await eO({startedAt:R,stepTypeName:K,result:B,callbacks:n.callbacks,analytics:L,globalWorkRef:n.work,tracer:N});let ce;if(B.status==="FAILED"&&!g.state.failureRecoveryDisabled&&m?.fromStepId===void 0&&h?.toStepId===void 0){let J=await nb({...n,executeStepList:kn,failureRecoveryParams:{failedStep:H,nextSteps:r.slice(x+1),results:e,tracer:N}});J&&J.status==="SUCCESS"&&(ce=J.proposedSteps,e.push(...J.results))}if(ce?f.push(...ce):T?f.push(T):f.push(y),g.fastForwardingToStep&&m&&m.fromStepId===y.id&&JSON.stringify(p)===JSON.stringify(m.parentStepIdChain)&&(g.fastForwardingToStep=!1),B.status!=="SUCCESS"&&!ce||s.closed){S=B.status,w=B;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 eO({startedAt:n,stepTypeName:e,result:t,analytics:r,tracer:o}){let i=e.toLowerCase(),a=e.charAt(0).toUpperCase()+e.slice(1),s=new Date,l="";switch(t.status){case"SUCCESS":l=t.message??`${a} executed successfully.`,r.track({type:"execution:step_success",step_type:t.type,command_type:"command"in t?t.command.type:void 0,duration_ms:s.getTime()-n.getTime()});break;case"FAILED":l=t.message??`${a} failed.`,r.track({type:"execution:step_fail",step_type:t.type,command_type:"command"in t?t.command.type:void 0,duration_ms:s.getTime()-n.getTime(),fail_reason:t.message??`${a} failed.`});break;case"CANCELLED":l=t.message??`${a} cancelled.`,r.track({type:"execution:step_cancel",step_type:t.type,command_type:"command"in t?t.command.type:void 0,duration_ms:s.getTime()-n.getTime()});break;default:throw new Error(`Unexpected ${i} status: ${t.status}`)}await o.finish({step:t,message:l,output:bs.parse(t)})}import{randomUUID as sb}from"crypto";async function lb({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:sb(),type:"PRESET_ACTION",status:e.aborted||r.name==="AbortError"?"CANCELLED":"FAILED",failureReason:"UserInfrastructureError",message:r.message,startedAt:t,finishedAt:new Date,results:[],command:{id:sb(),type:"NAVIGATE",url:n.baseUrl}};return{status:e.aborted||r.name==="AbortError"?"CANCELLED":"FAILED",results:[],failedStepResult:o}}}var Pl=async n=>{let{orgId:e,runId:t,runAttemptId:r,testMetadata:o,steps:i,beforeSteps:a,afterSteps:s}=n.inputs;n.fixtures.logger=n.fixtures.logger.child({orgId:e,runId:t,runAttemptId:r,testId:o?.id}),n.fixtures.analytics=n.fixtures.analytics.child({run_id:t,test_id:o?.id,test_name:o?.name});let{logger:l,controller:c}=n.fixtures,{onTestComplete:d,onTestSuccess:p}=n.callbacks.test,u=Fy(l);if(n.options.reinitializeBrowser){let h=await lb({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},`Starting run for Momentic test '${o?.name??"Unnamed test"}'`),m=await tO(n),m}finally{if(l.info({status:m?.status},"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...")}}},tO=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=[],x=g||i!==void 0||a!==void 0||void 0,y={results:w,state:{failureRecoveryDisabled:x,autoHealingDisabled:x},asyncTasks:[]},T=!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",T=!0);let C;if(T&&l&&l.length>0){let{status:_,results:O}=await cb(l,"beforeSteps",n);if(C=O,_!=="PASSED")return h&&db({tracer:e,debugDataStorage:n.fixtures.debugDataStorage,work:y,controller:p,storage:m,context:u,runId:t,runAttemptId:r,logger:d,status:_}),y.asyncTasks.push(Promise.resolve(n.callbacks.test.onSaveFinalRunResults?.({beforeResults:C,results:[]}))),{status:_,beforeResults:C,results:[]}}d.debug({stepsToExecute:S,fromStep:i,toStep:a},`Starting step execution for ${f}`);let R=await e.startStepList(),{status:L,terminalResult:N,proposedSteps:H}=await kn({...n,work:y,listParams:{steps:S,containerName:f,results:w,tracer:R}}),z;if(T&&c&&c.length>0){d.debug("Starting step execution for after step list");try{let{results:_}=await cb(c,"afterSteps",n);z=_}catch(_){d.error({err:_},"Failed to execute after steps list, continuing...")}}if(h&&db({tracer:e,debugDataStorage:n.fixtures.debugDataStorage,work:y,controller:p,storage:m,context:u,runId:t,runAttemptId:r,logger:d,status:L}),await Promise.allSettled(y.asyncTasks),y.asyncTasks.push(Promise.resolve(n.callbacks.test.onSaveFinalRunResults?.({results:w,beforeResults:C,afterResults:z}))),L==="FAILED")return{status:"FAILED",results:w,beforeResults:C,afterResults:z,failedStepResult:N};if(L==="CANCELLED")return{status:"CANCELLED",results:w,beforeResults:C,afterResults:z};let k;if(H&&y.state.healingDetails&&o){let _=fy(3);await n.callbacks.test.onProposedTestSteps?.({name:_,testId:o.id,orgId:n.inputs.orgId,runId:n.inputs.runId,steps:H,details:y.state.healingDetails,purpose:"AUTO_HEALING"}),k={orgId:n.inputs.orgId,name:_}}return{proposedTest:k,status:"PASSED",results:w,beforeResults:C,afterResults:z}};async function cb(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 kn({...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 db({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=gf(d.logsPerPage),u=gd(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 Vy({codePath:"test-complete-final",storage:o,screenshotBuff:m,logger:i}),g=await U(r.browser.html(),{milliseconds:2e3});a.setVariable(Yy,h),c!=="PASSED"&&c!=="SUCCESS"&&(i.debug({finalPageHtml:g},"Final page state HTML"),i.debug({finalScreenshotUrl:h},"Uploaded final screenshot URL"))}catch{}})(),l?e.storeConsoleLogsForRunAttempt(i,s,l,p):Promise.resolve(null),l?e.storeNetworkLogsForRunAttempt(i,s,l,u):Promise.resolve(null))}async function Ll({settings:n,customHeaders:e,envVariables:t,envName:r,testName:o,baseUrl:i,logger:a,localTools:s,orgId:l,flagStore:c}){let d=Cs.parse(n);e&&(d.extraHeaders={...d.extraHeaders,...e});let p=new Ot({baseUrl:i,envName:r,testName:o,variablesFromEnvironment:t,currentUrl:i});await Si({obj:d,context:p,bannedKeys:[],allowList:mh,localTools:s,logger:a,orgId:l,flagStore:c});try{return Cs.parse(d)}catch(u){throw new A("UserConfigurationError",`The templated browser settings configured by the user are invalid: ${u.message}`)}}import{cloneDeep as uN}from"lodash-es";var pb={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/constants.ts
|
|
57
|
+
${C.feedback}`,u.status="FAILED",c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,status:"FAILED",message:u.message}),u;M&&c.onDynamicAIActionEvaluatingEvent?.({stepId:M,status:"FAILED",message:C.feedback});break}case"IMPOSSIBLE":return u.message=`Our AI evaluator determined this task cannot be achieved: ${R}`,u.status="FAILED",c.onDynamicAIActionEvaluatingEvent?.({stepId:M??e.id,status:"FAILED",message:u.message}),u}let H=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 z,k;try{({command:z,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:z,reasoning:k},"Got proposed command")}finally{clearTimeout(H)}if(z.type==="FAILURE")return clearTimeout(H),u.status="FAILED",u.message=`Our AI agent determined that no supported actions can fulfill the goals: ${k}`,u;let _={id:wp(),type:"PRESET_ACTION",command:z},O={substepIndex:S+1,message:k||"Generated new command."};c.onDynamicCommandGenerated?.({...O,step:_,parentStepId:e.id}),p.info({commandId:z.id},`Executing sub-command ${S} within AI step: ${$r(z)}`);let K=await t.startSubSteps(),se=(await n.executeStepList({...n,options:{...n.options,disableHealing:!0},listParams:{containerName:"AI action newly generated step",steps:[_],tracer:K}})).results[0];c.onDynamicAIActionStatusUpdateEvent?.({parentStepId:e.id,message:"Waiting for page to stabilize before next action..."}),await i.browser.waitForDOMStability({logger:p});let le=await i.browser.screenshot({clearHighlights:!0,retries:1});u.results.push(se),f.push({screenshotBase64AfterCommand:`data:image/jpeg;base64,${le.toString("base64")}`,urlAfterCommand:i.browser.url(),serializedCommand:$r(z),elementInteracted:se.results[0]?.elementInteracted,thoughts:k});let fe={substepIndex:S,output:{...se,message:se.message??"Successfully executed preset action."},step:_,parentStepId:e.id};if(c.onDynamicCommandExecuted?.(fe),await t.finish({output:bs.parse(se),step:se,message:se.message}),se.status==="FAILED")if(u.status="FAILED",u.message=se.message,w<3)w++,y=`The last attempted action resulted in a Momentic error. A different element may need to be targeted. Error: ${se.message}`;else return u;else if(se.status==="CANCELLED")return u.status="CANCELLED",u.message=se.message,u;S++}};async function tb(n){let{results:e}=n.failureRecoveryParams,t=e[e.length-1],r=JL(t);if(r)return n.fixtures.logger.info({failedResult:t,isNotEligible:r},"Skipping failure recovery because of ineligible failure"),null;try{return await YL(n)}catch(o){return n.fixtures.logger.error({err:o},"Error during failure recovery attempt"),null}}async function eb({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 YL(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 Gs(i,e.debugDataStorage,a,{numScreenshots:3,addIndices:!0}),h=l.map(E=>mn(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 eb({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 eb({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 Rl(t,{type:"FAILURE_RECOVERY",thoughts:g.reasoning}),t.state.failureRecoveryDisabled=!0,w}function JL(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":sh.some(t=>e.includes(t))?"User fault and likely irrecoverable":"":"No error message available"}async function nb(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 an({asyncTasks:n.work.asyncTasks,nestedResults:s.results,result:c,logger:r}),c}import{randomUUID as Il}from"crypto";import XL from"fast-json-patch";import{cloneDeep as ZL}from"lodash-es";async function rb(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=ZL(c.steps);await Promise.allSettled(i.asyncTasks??[]);let{results:w}=await Gs(p,u,e.results,{numScreenshots:4}),E=await d.runSectionAutohealing({results:w,errorMessage:e.terminalResult?.message,goal:c.description});S=XL.applyPatch(S,E.patches).newDocument;let y=Ot.fromSnapshot({snapshot:s,environmentVariables:o.context.getVariablesFromEnvironmentCopy()});await QL({logger:p,controller:d,tracer:l,context:y,restartConfig:h,startingUrl:a});let T=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(T.results),T.status==="SUCCESS")return{successfulHealing:{proposedStep:{...c,steps:S},listResult:T,context:y},healingAttempts:t};e=T}return{healingAttempts:t}}async function QL({logger:n,controller:e,tracer:t,restartConfig:r,context:o,startingUrl:i}){switch(r.type){case"NAVIGATE_URL":{let a={id:Il(),type:"PRESET_ACTION",command:{id:Il(),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:Il(),type:"PRESET_ACTION",command:{id:Il(),type:"NAVIGATE",url:i}},s=await t.startStep({logger:n,step:a});await e.executePresetCommand(null,s,a.command,o,!1);break}}}function ob(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"&&pm(e.command.type))}}async function ib(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&&ob(e.autohealingConfig.trigger,p.terminalResult)){let g=await t.startSubSteps(),f=await rb({...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 an({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,E=0;for(E;E<r.length;E++){let y=r[E],T,C=mn(y);if(y.skipped)continue;if(g.fastForwardingToStep&&m){let J=JSON.stringify(p);if(y.id===m.fromStepId&&J===JSON.stringify(m.parentStepIdChain))g.fastForwardingToStep=!1;else if(!af(y,p,m.fromStepId,m.parentStepIdChain))continue}let R=new Date,L=d.child({step_id:y.id});L.track({type:"execution:step_start",step_type:y.type==="RESOLVED_MODULE"?"MODULE":y.type,command_type:"command"in y?y.command.type:void 0}),i.info({step:y},`Executing step ${E+1}/${r.length} in ${t}: ${C}`);let M=await o.startStep({logger:i,step:y}),H=eO(y),z=a.toRedactedDisplayCopy(),k=s.browser.url(),_=s.executeAbortController.signal,O=ia(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 K,B;switch(y.type){case"PRESET_ACTION":{K="Preset action",B=await wr(y,async()=>await Al({...n,presetParams:{tracer:M,step:y}}),_),"proposedStep"in B&&B.proposedStep&&(T=B.proposedStep,B.proposedStep=void 0);break}case"AI_ACTION":{K="AI action",B=await wr(y,()=>Xy({...n,aiStepParams:{step:y,tracer:M},executeStepList:Mn}),_);break}case"AI_ACTION_DYNAMIC":{K="AI action",B=await wr(y,()=>Qy({...n,aiStepParams:{step:y,tracer:M},executeStepList:Mn}),_);break}case"RESOLVED_MODULE":{K=`Module (${y.name})`,B=await wr(y,async()=>{let J=await $y({orgId:u,step:y,context:a,logger:i,flagStore:s.flagStore,codeEvalTools:l,signal:_});return bp({...n,executeStepList:Mn,moduleParams:{step:y,resolvedInputs:J,tracer:M}})},_);break}case"CONDITIONAL":{K="Conditional step",B=await wr(y,()=>Yy({...n,conditionalParams:{step:y,tracer:M},executeStepList:Mn}),_);break}case"IFRAME":{K="Frame step",B=await wr(y,()=>nb({...n,frameParams:{step:y,tracer:M},executeStepList:Mn}),_);break}case"SECTION":{K="Section";let J=await wr(y,()=>ib({...n,sectionParams:{step:y,tracer:M},executeStepList:Mn}),_);"proposedStep"in J&&J.proposedStep&&(T=J.proposedStep,J.proposedStep=void 0),B=J;break}default:return(_e=>{throw"If Typescript complains about the line below, you missed a case or break in the switch above"})(y)}B.beforeUrl=B.beforeUrl??k,B.beforeTestContext=z,y.envKey&&a.setVariable(y.envKey,B.data);let se=s.browser.url();a.setCurrentUrl(se),B.afterUrl=B.afterUrl??se,B.afterTestContext=a.toRedactedDisplayCopy(),e.push(B),await tO({startedAt:R,stepTypeName:K,result:B,callbacks:n.callbacks,analytics:L,globalWorkRef:n.work,tracer:M});let le;if(B.status==="FAILED"&&!g.state.failureRecoveryDisabled&&m?.fromStepId===void 0&&h?.toStepId===void 0){let J=await tb({...n,executeStepList:Mn,failureRecoveryParams:{failedStep:H,nextSteps:r.slice(E+1),results:e,tracer:M}});J&&J.status==="SUCCESS"&&(le=J.proposedSteps,e.push(...J.results))}if(le?f.push(...le):T?f.push(T):f.push(y),g.fastForwardingToStep&&m&&m.fromStepId===y.id&&JSON.stringify(p)===JSON.stringify(m.parentStepIdChain)&&(g.fastForwardingToStep=!1),B.status!=="SUCCESS"&&!le||s.closed){S=B.status,w=B;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 tO({startedAt:n,stepTypeName:e,result:t,analytics:r,tracer:o}){let i=e.toLowerCase(),a=e.charAt(0).toUpperCase()+e.slice(1),s=new Date,l="";switch(t.status){case"SUCCESS":l=t.message??`${a} executed successfully.`,r.track({type:"execution:step_success",step_type:t.type,command_type:"command"in t?t.command.type:void 0,duration_ms:s.getTime()-n.getTime()});break;case"FAILED":l=t.message??`${a} failed.`,r.track({type:"execution:step_fail",step_type:t.type,command_type:"command"in t?t.command.type:void 0,duration_ms:s.getTime()-n.getTime(),fail_reason:t.message??`${a} failed.`});break;case"CANCELLED":l=t.message??`${a} cancelled.`,r.track({type:"execution:step_cancel",step_type:t.type,command_type:"command"in t?t.command.type:void 0,duration_ms:s.getTime()-n.getTime()});break;default:throw new Error(`Unexpected ${i} status: ${t.status}`)}await o.finish({step:t,message:l,output:bs.parse(t)})}import{randomUUID as ab}from"crypto";async function sb({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:ab(),type:"PRESET_ACTION",status:e.aborted||r.name==="AbortError"?"CANCELLED":"FAILED",failureReason:"UserInfrastructureError",message:r.message,startedAt:t,finishedAt:new Date,results:[],command:{id:ab(),type:"NAVIGATE",url:n.baseUrl}};return{status:e.aborted||r.name==="AbortError"?"CANCELLED":"FAILED",results:[],failedStepResult:o}}}var Pl=async n=>{let{orgId:e,runId:t,runAttemptId:r,testMetadata:o,steps:i,beforeSteps:a,afterSteps:s}=n.inputs;n.fixtures.logger=n.fixtures.logger.child({orgId:e,runId:t,runAttemptId:r,testId:o?.id}),n.fixtures.analytics=n.fixtures.analytics.child({run_id:t,test_id:o?.id,test_name:o?.name});let{logger:l,controller:c}=n.fixtures,{onTestComplete:d,onTestSuccess:p}=n.callbacks.test,u=Dy(l);if(n.options.reinitializeBrowser){let h=await sb({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},`Starting run for Momentic test '${o?.name??"Unnamed test"}'`),m=await nO(n),m}finally{if(l.info({status:m?.status},"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...")}}},nO=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:[]},T=!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",T=!0);let C;if(T&&l&&l.length>0){let{status:_,results:O}=await lb(l,"beforeSteps",n);if(C=O,_!=="PASSED")return h&&cb({tracer:e,debugDataStorage:n.fixtures.debugDataStorage,work:y,controller:p,storage:m,context:u,runId:t,runAttemptId:r,logger:d,status:_}),y.asyncTasks.push(Promise.resolve(n.callbacks.test.onSaveFinalRunResults?.({beforeResults:C,results:[]}))),{status:_,beforeResults:C,results:[]}}d.debug({stepsToExecute:S,fromStep:i,toStep:a},`Starting step execution for ${f}`);let R=await e.startStepList(),{status:L,terminalResult:M,proposedSteps:H}=await Mn({...n,work:y,listParams:{steps:S,containerName:f,results:w,tracer:R}}),z;if(T&&c&&c.length>0){d.debug("Starting step execution for after step list");try{let{results:_}=await lb(c,"afterSteps",n);z=_}catch(_){d.error({err:_},"Failed to execute after steps list, continuing...")}}if(h&&cb({tracer:e,debugDataStorage:n.fixtures.debugDataStorage,work:y,controller:p,storage:m,context:u,runId:t,runAttemptId:r,logger:d,status:L}),await Promise.allSettled(y.asyncTasks),y.asyncTasks.push(Promise.resolve(n.callbacks.test.onSaveFinalRunResults?.({results:w,beforeResults:C,afterResults:z}))),L==="FAILED")return{status:"FAILED",results:w,beforeResults:C,afterResults:z,failedStepResult:M};if(L==="CANCELLED")return{status:"CANCELLED",results:w,beforeResults:C,afterResults:z};let k;if(H&&y.state.healingDetails&&o){let _=gy(3);await n.callbacks.test.onProposedTestSteps?.({name:_,testId:o.id,orgId:n.inputs.orgId,runId:n.inputs.runId,steps:H,details:y.state.healingDetails,purpose:"AUTO_HEALING"}),k={orgId:n.inputs.orgId,name:_}}return{proposedTest:k,status:"PASSED",results:w,beforeResults:C,afterResults:z}};async function lb(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 cb({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=hf(d.logsPerPage),u=gd(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 Wy({codePath:"test-complete-final",storage:o,screenshotBuff:m,logger:i}),g=await U(r.browser.html(),{milliseconds:2e3});a.setVariable(Ky,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 Ll({settings:n,customHeaders:e,envVariables:t,envName:r,testName:o,baseUrl:i,logger:a,localTools:s,orgId:l,flagStore:c}){let d=Cs.parse(n);e&&(d.extraHeaders={...d.extraHeaders,...e});let p=new Ot({baseUrl:i,envName:r,testName:o,variablesFromEnvironment:t,currentUrl:i});await fi({obj:d,context:p,bannedKeys:[],allowList:uh,localTools:s,logger:a,orgId:l,flagStore:c});try{return Cs.parse(d)}catch(u){throw new A("UserConfigurationError",`The templated browser settings configured by the user are invalid: ${u.message}`)}}import{cloneDeep as mM}from"lodash-es";var db={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
|
+
function isEligibleForAttrRemoval(bestCandidate, attrToRemove) {
|
|
59
|
+
const customWindow = window;
|
|
60
|
+
if (bestCandidate.textContent?.trim()) {
|
|
61
|
+
return true;
|
|
62
|
+
}
|
|
63
|
+
for (const attrName of customWindow.momenticConstants?.stronglyIdentifyingAttributes ?? []) {
|
|
64
|
+
if (attrName === attrToRemove) {
|
|
65
|
+
continue;
|
|
66
|
+
}
|
|
67
|
+
if (bestCandidate.getAttribute(attrName)) {
|
|
68
|
+
return true;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
return false;
|
|
72
|
+
}
|
|
73
|
+
function evaluateCachedElementMatch(params) {
|
|
74
|
+
const { bestElement, cachedElementSerialized, opts, logs } = params;
|
|
75
|
+
const {
|
|
76
|
+
requireBoundingBox,
|
|
77
|
+
requireMatchingBoundingBox,
|
|
78
|
+
ldistThreshold,
|
|
79
|
+
ignoreHrefForCaching
|
|
80
|
+
} = opts;
|
|
81
|
+
const customWindow = window;
|
|
82
|
+
const elmBoundingBox = bestElement.getBoundingClientRect();
|
|
83
|
+
if (requireBoundingBox) {
|
|
84
|
+
if (!elmBoundingBox.height || !elmBoundingBox.width) {
|
|
85
|
+
logs.push(
|
|
86
|
+
\`Refusing to choose candidate matched because it has no bounding box\`
|
|
87
|
+
);
|
|
88
|
+
return false;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
if (requireMatchingBoundingBox) {
|
|
92
|
+
if (elmBoundingBox.x !== requireMatchingBoundingBox.x || elmBoundingBox.y !== requireMatchingBoundingBox.y || elmBoundingBox.width !== requireMatchingBoundingBox.width || elmBoundingBox.height !== requireMatchingBoundingBox.height) {
|
|
93
|
+
logs.push(
|
|
94
|
+
\`Refusing to choose candidate matched by selector because bounding box was not the same as the original\`
|
|
95
|
+
);
|
|
96
|
+
return false;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
const serializedCandidate = customWindow.serializeElementOnlyWithText(bestElement);
|
|
100
|
+
const ratioThreshold = ldistThreshold;
|
|
101
|
+
const lRatio = customWindow.ldist(serializedCandidate, cachedElementSerialized) / Math.min(serializedCandidate.length, cachedElementSerialized.length);
|
|
102
|
+
let lRatioWithoutClass;
|
|
103
|
+
let serializedCandidateWithoutClass;
|
|
104
|
+
if (serializedCandidate.includes("class") && isEligibleForAttrRemoval(bestElement, "class") && bestElement.tagName.toLowerCase() !== "svg") {
|
|
105
|
+
const serializedCachedNodeWithoutClass = cachedElementSerialized.replace(
|
|
106
|
+
/ class="[^"]+"/g,
|
|
107
|
+
""
|
|
108
|
+
);
|
|
109
|
+
serializedCandidateWithoutClass = customWindow.serializeElementOnlyWithText(bestElement, {
|
|
110
|
+
removeClassName: true
|
|
111
|
+
});
|
|
112
|
+
lRatioWithoutClass = customWindow.ldist(
|
|
113
|
+
serializedCandidateWithoutClass,
|
|
114
|
+
serializedCachedNodeWithoutClass
|
|
115
|
+
) / Math.min(
|
|
116
|
+
serializedCandidateWithoutClass.length,
|
|
117
|
+
serializedCachedNodeWithoutClass.length
|
|
118
|
+
);
|
|
119
|
+
}
|
|
120
|
+
let lRatioWithoutHref;
|
|
121
|
+
let serializedCandidateWithoutHref;
|
|
122
|
+
if (ignoreHrefForCaching && serializedCandidate.includes("href") && isEligibleForAttrRemoval(bestElement, "href")) {
|
|
123
|
+
serializedCandidateWithoutHref = serializedCandidate.replace(
|
|
124
|
+
/ href="[^"]+"/g,
|
|
125
|
+
""
|
|
126
|
+
);
|
|
127
|
+
const serializedNodeWithTextWithoutHref = cachedElementSerialized.replace(
|
|
128
|
+
/ href="[^"]+"/g,
|
|
129
|
+
""
|
|
130
|
+
);
|
|
131
|
+
lRatioWithoutHref = customWindow.ldist(
|
|
132
|
+
serializedCandidateWithoutHref,
|
|
133
|
+
serializedNodeWithTextWithoutHref
|
|
134
|
+
) / Math.min(
|
|
135
|
+
serializedCandidateWithoutHref.length,
|
|
136
|
+
serializedNodeWithTextWithoutHref.length
|
|
137
|
+
);
|
|
138
|
+
}
|
|
139
|
+
logs.push(
|
|
140
|
+
\`Evaluating best candidate:
|
|
141
|
+
|
|
142
|
+
Original: \${cachedElementSerialized.slice(0, 300)}
|
|
143
|
+
|
|
144
|
+
Candidate: \${serializedCandidate.slice(0, 300)}
|
|
145
|
+
|
|
146
|
+
\${lRatioWithoutClass && serializedCandidateWithoutClass ? \`Candidate (without class): \${serializedCandidateWithoutClass.slice(0, 300)}
|
|
147
|
+
\` : ""}
|
|
148
|
+
\${lRatioWithoutHref && serializedCandidateWithoutHref ? \`Candidate (without href): \${serializedCandidateWithoutHref.slice(0, 300)}
|
|
149
|
+
\` : ""}
|
|
150
|
+
\`
|
|
151
|
+
);
|
|
152
|
+
const finalLDistRatio = Math.min(
|
|
153
|
+
lRatio,
|
|
154
|
+
lRatioWithoutClass ?? Infinity,
|
|
155
|
+
lRatioWithoutHref ?? Infinity
|
|
156
|
+
);
|
|
157
|
+
if (finalLDistRatio > ratioThreshold) {
|
|
158
|
+
logs.push(\`Best candidate has failing l-dist ratio of \${finalLDistRatio}\`);
|
|
159
|
+
return false;
|
|
160
|
+
} else {
|
|
161
|
+
logs.push(\`Best candidate has passing l-dist ratio of \${finalLDistRatio}\`);
|
|
162
|
+
return true;
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
function addPrimaryCacheEvaluationScript() {
|
|
166
|
+
const customWindow = window;
|
|
167
|
+
if (customWindow.evaluatePrimaryCaches) {
|
|
168
|
+
return;
|
|
169
|
+
}
|
|
170
|
+
customWindow.evaluatePrimaryCaches = (params) => {
|
|
171
|
+
let cssResult;
|
|
172
|
+
const cssStartTime = Date.now();
|
|
173
|
+
try {
|
|
174
|
+
cssResult = customWindow.evaluateCssSelectors(params.cssParams);
|
|
175
|
+
} catch (err) {
|
|
176
|
+
cssResult = {
|
|
177
|
+
logs: [\`[ERROR] CSS selector evaluation failed: \${err}\`]
|
|
178
|
+
};
|
|
179
|
+
} finally {
|
|
180
|
+
cssResult?.logs.push(
|
|
181
|
+
\`[DURATION] CSS selector evaluation took \${Date.now() - cssStartTime}ms\`
|
|
182
|
+
);
|
|
183
|
+
}
|
|
184
|
+
let hybridResult;
|
|
185
|
+
const hybridStartTime = Date.now();
|
|
186
|
+
try {
|
|
187
|
+
if (params.hybridParams) {
|
|
188
|
+
hybridResult = customWindow.evaluateHybridSelector(
|
|
189
|
+
params.hybridParams
|
|
190
|
+
);
|
|
191
|
+
}
|
|
192
|
+
} catch (err) {
|
|
193
|
+
hybridResult = {
|
|
194
|
+
logs: [\`[ERROR] Hybrid selector evaluation failed: \${err}\`]
|
|
195
|
+
};
|
|
196
|
+
} finally {
|
|
197
|
+
hybridResult?.logs.push(
|
|
198
|
+
\`[DURATION] Hybrid selector evaluation took \${Date.now() - hybridStartTime}ms\`
|
|
199
|
+
);
|
|
200
|
+
}
|
|
201
|
+
return {
|
|
202
|
+
css: cssResult,
|
|
203
|
+
hybrid: hybridResult
|
|
204
|
+
};
|
|
205
|
+
};
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
// src/html/constants.ts
|
|
58
209
|
var momenticConstants = {
|
|
59
210
|
bannedClassSubstrings: [
|
|
60
211
|
"relative",
|
|
@@ -335,115 +486,6 @@ function addGenerateHtmlCacheAttributesScript() {
|
|
|
335
486
|
customWindow.generateHtmlCacheAttributes = generateHtmlCacheAttributes;
|
|
336
487
|
}
|
|
337
488
|
|
|
338
|
-
// src/html/cache-evaluation.ts
|
|
339
|
-
function isEligibleForAttrRemoval(bestCandidate, attrToRemove) {
|
|
340
|
-
const customWindow = window;
|
|
341
|
-
if (bestCandidate.textContent?.trim()) {
|
|
342
|
-
return true;
|
|
343
|
-
}
|
|
344
|
-
for (const attrName of customWindow.momenticConstants?.stronglyIdentifyingAttributes ?? []) {
|
|
345
|
-
if (attrName === attrToRemove) {
|
|
346
|
-
continue;
|
|
347
|
-
}
|
|
348
|
-
if (bestCandidate.getAttribute(attrName)) {
|
|
349
|
-
return true;
|
|
350
|
-
}
|
|
351
|
-
}
|
|
352
|
-
return false;
|
|
353
|
-
}
|
|
354
|
-
function evaluateCachedElementMatch(params) {
|
|
355
|
-
const { bestElement, cachedElementSerialized, opts, logs } = params;
|
|
356
|
-
const {
|
|
357
|
-
requireBoundingBox,
|
|
358
|
-
requireMatchingBoundingBox,
|
|
359
|
-
ldistThreshold,
|
|
360
|
-
ignoreHrefForCaching
|
|
361
|
-
} = opts;
|
|
362
|
-
const customWindow = window;
|
|
363
|
-
const elmBoundingBox = bestElement.getBoundingClientRect();
|
|
364
|
-
if (requireBoundingBox) {
|
|
365
|
-
if (!elmBoundingBox.height || !elmBoundingBox.width) {
|
|
366
|
-
logs.push(
|
|
367
|
-
\`Refusing to choose candidate matched because it has no bounding box\`
|
|
368
|
-
);
|
|
369
|
-
return false;
|
|
370
|
-
}
|
|
371
|
-
}
|
|
372
|
-
if (requireMatchingBoundingBox) {
|
|
373
|
-
if (elmBoundingBox.x !== requireMatchingBoundingBox.x || elmBoundingBox.y !== requireMatchingBoundingBox.y || elmBoundingBox.width !== requireMatchingBoundingBox.width || elmBoundingBox.height !== requireMatchingBoundingBox.height) {
|
|
374
|
-
logs.push(
|
|
375
|
-
\`Refusing to choose candidate matched by selector because bounding box was not the same as the original\`
|
|
376
|
-
);
|
|
377
|
-
return false;
|
|
378
|
-
}
|
|
379
|
-
}
|
|
380
|
-
const serializedCandidate = customWindow.serializeElementOnlyWithText(bestElement);
|
|
381
|
-
const ratioThreshold = ldistThreshold;
|
|
382
|
-
const lRatio = customWindow.ldist(serializedCandidate, cachedElementSerialized) / Math.min(serializedCandidate.length, cachedElementSerialized.length);
|
|
383
|
-
let lRatioWithoutClass;
|
|
384
|
-
let serializedCandidateWithoutClass;
|
|
385
|
-
if (serializedCandidate.includes("class") && isEligibleForAttrRemoval(bestElement, "class") && bestElement.tagName.toLowerCase() !== "svg") {
|
|
386
|
-
const serializedCachedNodeWithoutClass = cachedElementSerialized.replace(
|
|
387
|
-
/ class="[^"]+"/g,
|
|
388
|
-
""
|
|
389
|
-
);
|
|
390
|
-
serializedCandidateWithoutClass = customWindow.serializeElementOnlyWithText(bestElement, {
|
|
391
|
-
removeClassName: true
|
|
392
|
-
});
|
|
393
|
-
lRatioWithoutClass = customWindow.ldist(
|
|
394
|
-
serializedCandidateWithoutClass,
|
|
395
|
-
serializedCachedNodeWithoutClass
|
|
396
|
-
) / Math.min(
|
|
397
|
-
serializedCandidateWithoutClass.length,
|
|
398
|
-
serializedCachedNodeWithoutClass.length
|
|
399
|
-
);
|
|
400
|
-
}
|
|
401
|
-
let lRatioWithoutHref;
|
|
402
|
-
let serializedCandidateWithoutHref;
|
|
403
|
-
if (ignoreHrefForCaching && serializedCandidate.includes("href") && isEligibleForAttrRemoval(bestElement, "href")) {
|
|
404
|
-
serializedCandidateWithoutHref = serializedCandidate.replace(
|
|
405
|
-
/ href="[^"]+"/g,
|
|
406
|
-
""
|
|
407
|
-
);
|
|
408
|
-
const serializedNodeWithTextWithoutHref = cachedElementSerialized.replace(
|
|
409
|
-
/ href="[^"]+"/g,
|
|
410
|
-
""
|
|
411
|
-
);
|
|
412
|
-
lRatioWithoutHref = customWindow.ldist(
|
|
413
|
-
serializedCandidateWithoutHref,
|
|
414
|
-
serializedNodeWithTextWithoutHref
|
|
415
|
-
) / Math.min(
|
|
416
|
-
serializedCandidateWithoutHref.length,
|
|
417
|
-
serializedNodeWithTextWithoutHref.length
|
|
418
|
-
);
|
|
419
|
-
}
|
|
420
|
-
logs.push(
|
|
421
|
-
\`Evaluating best candidate:
|
|
422
|
-
|
|
423
|
-
Original: \${cachedElementSerialized.slice(0, 300)}
|
|
424
|
-
|
|
425
|
-
Candidate: \${serializedCandidate.slice(0, 300)}
|
|
426
|
-
|
|
427
|
-
\${lRatioWithoutClass && serializedCandidateWithoutClass ? \`Candidate (without class): \${serializedCandidateWithoutClass.slice(0, 300)}
|
|
428
|
-
\` : ""}
|
|
429
|
-
\${lRatioWithoutHref && serializedCandidateWithoutHref ? \`Candidate (without href): \${serializedCandidateWithoutHref.slice(0, 300)}
|
|
430
|
-
\` : ""}
|
|
431
|
-
\`
|
|
432
|
-
);
|
|
433
|
-
const finalLDistRatio = Math.min(
|
|
434
|
-
lRatio,
|
|
435
|
-
lRatioWithoutClass ?? Infinity,
|
|
436
|
-
lRatioWithoutHref ?? Infinity
|
|
437
|
-
);
|
|
438
|
-
if (finalLDistRatio > ratioThreshold) {
|
|
439
|
-
logs.push(\`Best candidate has failing l-dist ratio of \${finalLDistRatio}\`);
|
|
440
|
-
return false;
|
|
441
|
-
} else {
|
|
442
|
-
logs.push(\`Best candidate has passing l-dist ratio of \${finalLDistRatio}\`);
|
|
443
|
-
return true;
|
|
444
|
-
}
|
|
445
|
-
}
|
|
446
|
-
|
|
447
489
|
// src/html/css-evaluation.ts
|
|
448
490
|
function addEvaluateCssSelectorsScript() {
|
|
449
491
|
const customWindow = window;
|
|
@@ -460,6 +502,12 @@ function addEvaluateCssSelectorsScript() {
|
|
|
460
502
|
const logs = [];
|
|
461
503
|
const { selectors, cachedElementSerialized, opts } = params;
|
|
462
504
|
const matchResultMap = /* @__PURE__ */ new Map();
|
|
505
|
+
if (selectors.length < 2) {
|
|
506
|
+
logs.push("Not enough selectors to evaluate");
|
|
507
|
+
return {
|
|
508
|
+
logs
|
|
509
|
+
};
|
|
510
|
+
}
|
|
463
511
|
for (const selector of selectors) {
|
|
464
512
|
const matchingElements = document.querySelectorAll(selector);
|
|
465
513
|
if (!matchingElements.length) {
|
|
@@ -2199,15 +2247,14 @@ function addEvaluateHybridSelectorScript() {
|
|
|
2199
2247
|
const matchesPerElement = /* @__PURE__ */ new Map();
|
|
2200
2248
|
const queue = new MaxPriorityQueue([]);
|
|
2201
2249
|
let totalMatches = 0;
|
|
2202
|
-
let totalMatchScore = 0;
|
|
2203
2250
|
const isDone = () => {
|
|
2204
|
-
if (Date.now() - startTime >
|
|
2251
|
+
if (Date.now() - startTime > 1500) {
|
|
2205
2252
|
logs.push(
|
|
2206
|
-
"[STOP] Discontinuing hybrid selector resolution after
|
|
2253
|
+
"[STOP] Discontinuing hybrid selector resolution after 1500ms elapsed"
|
|
2207
2254
|
);
|
|
2208
2255
|
return true;
|
|
2209
2256
|
}
|
|
2210
|
-
if (totalMatches >
|
|
2257
|
+
if (totalMatches > 7) {
|
|
2211
2258
|
return true;
|
|
2212
2259
|
}
|
|
2213
2260
|
return false;
|
|
@@ -2220,7 +2267,6 @@ function addEvaluateHybridSelectorScript() {
|
|
|
2220
2267
|
});
|
|
2221
2268
|
matchesPerElement.set(element, elementMatches);
|
|
2222
2269
|
totalMatches++;
|
|
2223
|
-
totalMatchScore += strength;
|
|
2224
2270
|
};
|
|
2225
2271
|
for (let i = 0; i < nodes.length; i++) {
|
|
2226
2272
|
const possibleDestNode = nodes[i];
|
|
@@ -2237,6 +2283,9 @@ function addEvaluateHybridSelectorScript() {
|
|
|
2237
2283
|
continue;
|
|
2238
2284
|
}
|
|
2239
2285
|
if (i === nodes.length - 1) {
|
|
2286
|
+
logs.push(
|
|
2287
|
+
\`[MATCH] Recording match, strength \${hopResult.strength}, ele: \${hopResult.element.outerHTML.slice(0, 100)}\`
|
|
2288
|
+
);
|
|
2240
2289
|
recordMatch(hopResult.element, hopResult.strength, 1);
|
|
2241
2290
|
} else {
|
|
2242
2291
|
queue.add(
|
|
@@ -2296,6 +2345,9 @@ function addEvaluateHybridSelectorScript() {
|
|
|
2296
2345
|
if (hopAttempt) {
|
|
2297
2346
|
const newStrength = strength + hopAttempt.strength;
|
|
2298
2347
|
if (nextDestNodeIndex === nodes.length - 1) {
|
|
2348
|
+
logs.push(
|
|
2349
|
+
\`[MATCH] Recording match, strength \${newStrength}, ele: \${hopAttempt.element.outerHTML.slice(0, 100)}\`
|
|
2350
|
+
);
|
|
2299
2351
|
recordMatch(hopAttempt.element, newStrength, previousHops + 1);
|
|
2300
2352
|
} else {
|
|
2301
2353
|
let xPathSep = nextDestNodeIndex - 1 === selectorNodeIndex ? "/" : "//";
|
|
@@ -2313,6 +2365,7 @@ function addEvaluateHybridSelectorScript() {
|
|
|
2313
2365
|
newStrength
|
|
2314
2366
|
);
|
|
2315
2367
|
}
|
|
2368
|
+
break;
|
|
2316
2369
|
}
|
|
2317
2370
|
if (nextDestNode.expandShadowRoot) {
|
|
2318
2371
|
break;
|
|
@@ -3819,6 +3872,7 @@ function registerAllMomenticListeners() {
|
|
|
3819
3872
|
addEvaluateCssSelectorsScript();
|
|
3820
3873
|
addHybridSelectorGenerationScript();
|
|
3821
3874
|
addEvaluateHybridSelectorScript();
|
|
3875
|
+
addPrimaryCacheEvaluationScript();
|
|
3822
3876
|
addHtmlTreeSerializationFunctions();
|
|
3823
3877
|
addElementSerializationScripts();
|
|
3824
3878
|
addGenerateHtmlCacheAttributesScript();
|
|
@@ -3828,61 +3882,59 @@ function registerAllMomenticListeners() {
|
|
|
3828
3882
|
|
|
3829
3883
|
// src/html/index.ts
|
|
3830
3884
|
registerAllMomenticListeners();
|
|
3831
|
-
`};var Jn={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 vp="ElementMovedError";import{execSync as PM}from"child_process";import{randomUUID as fw}from"crypto";import{existsSync as jl,mkdirSync as LM,readFileSync as OM,writeFileSync as MM}from"fs";import{Jimp as Sw}from"jimp";import NM from"js-beautify";import{cloneDeep as kM}from"lodash-es";var ub={"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(ub);var mb=ub;var hb={"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(hb);var gb=hb;var sn=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)},yi,Ua,ro,xp=class{constructor(...e){yi.set(this,new Map),Ua.set(this,new Map),ro.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()),sn(this,ro,"f").has(r)||sn(this,ro,"f").set(r,new Set);let i=sn(this,ro,"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&&sn(this,Ua,"f").set(r,s),a=!1,l)continue;let c=sn(this,yi,"f").get(s);if(c&&c!=r&&!t)throw new Error(`"${r} -> ${s}" conflicts with "${c} -> ${s}". Pass \`force=true\` to override this definition.`);sn(this,yi,"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:sn(this,yi,"f").get(r)??null}getExtension(e){return typeof e!="string"?null:(e=e?.split?.(";")[0],(e&&sn(this,Ua,"f").get(e.trim().toLowerCase()))??null)}getAllExtensions(e){return typeof e!="string"?null:sn(this,ro,"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 sn(this,ro,"f").values())Object.freeze(e);return this}_getTestState(){return{types:sn(this,yi,"f"),extensions:sn(this,Ua,"f")}}};yi=new WeakMap,Ua=new WeakMap,ro=new WeakMap;var Ep=xp;var fb=new Ep(gb,mb)._freeze();import{homedir as Yp,hostname as _M,platform as DM}from"os";import{basename as FM,extname as UM,join as vi,resolve as BM}from"path";import{chromium as bw,devices as zM}from"playwright";import{addExtra as HM}from"playwright-extra";import jM from"puppeteer-extra-plugin-recaptcha";import{v4 as $M}from"uuid";import{rmSync as rw}from"fs";import{basename as nM,join as rM}from"path";import{errors as oM}from"playwright-core";var rO=new Set(["b","c","d","f","g","h","j","k","l","m","n","p","q","r","s","t","v","w","x","y","z"]),oO=new Set(["a","e","i","o","u","y"]);function Sb(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())rO.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"&&!oO.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 yb(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(`
|
|
3885
|
+
`};var Jn={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 vp="ElementMovedError";import{execSync as LN}from"child_process";import{randomUUID as fw}from"crypto";import{diff as ON}from"deep-object-diff";import{existsSync as jl,mkdirSync as NN,readFileSync as MN,writeFileSync as kN}from"fs";import{Jimp as Sw}from"jimp";import _N from"js-beautify";import{cloneDeep as yw}from"lodash-es";var pb={"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(pb);var ub=pb;var mb={"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(mb);var hb=mb;var sn=function(n,e,t,r){if(t==="a"&&!r)throw new TypeError("Private accessor was defined without a getter");if(typeof e=="function"?n!==e||!r:!e.has(n))throw new TypeError("Cannot read private member from an object whose class did not declare it");return t==="m"?r:t==="a"?r.call(n):r?r.value:e.get(n)},Si,Ua,no,Ep=class{constructor(...e){Si.set(this,new Map),Ua.set(this,new Map),no.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()),sn(this,no,"f").has(r)||sn(this,no,"f").set(r,new Set);let i=sn(this,no,"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&&sn(this,Ua,"f").set(r,s),a=!1,l)continue;let c=sn(this,Si,"f").get(s);if(c&&c!=r&&!t)throw new Error(`"${r} -> ${s}" conflicts with "${c} -> ${s}". Pass \`force=true\` to override this definition.`);sn(this,Si,"f").set(s,r)}}return this}getType(e){if(typeof e!="string")return null;let t=e.replace(/^.*[/\\]/,"").toLowerCase(),r=t.replace(/^.*\./,"").toLowerCase(),o=t.length<e.length;return!(r.length<t.length-1)&&o?null:sn(this,Si,"f").get(r)??null}getExtension(e){return typeof e!="string"?null:(e=e?.split?.(";")[0],(e&&sn(this,Ua,"f").get(e.trim().toLowerCase()))??null)}getAllExtensions(e){return typeof e!="string"?null:sn(this,no,"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 sn(this,no,"f").values())Object.freeze(e);return this}_getTestState(){return{types:sn(this,Si,"f"),extensions:sn(this,Ua,"f")}}};Si=new WeakMap,Ua=new WeakMap,no=new WeakMap;var xp=Ep;var gb=new xp(hb,ub)._freeze();import{homedir as Kp,hostname as DN,platform as FN}from"os";import{basename as UN,extname as BN,join as wi,resolve as zN}from"path";import{chromium as ww,devices as HN}from"playwright";import{addExtra as jN}from"playwright-extra";import $N from"puppeteer-extra-plugin-recaptcha";import{v4 as GN}from"uuid";import{rmSync as nw}from"fs";import{basename as rN,join as oN}from"path";import{errors as iN}from"playwright-core";var oO=new Set(["b","c","d","f","g","h","j","k","l","m","n","p","q","r","s","t","v","w","x","y","z"]),iO=new Set(["a","e","i","o","u","y"]);function fb(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())oO.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"&&!iO.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 Sb(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(`
|
|
3832
3886
|
`,o);a>0&&a<r&&(o=a);let s=i,l=0;for(;l<1e3&&s>r&&n[s]!==`
|
|
3833
3887
|
`;)l++,s--;return s>r&&n[s]===`
|
|
3834
|
-
`&&(i=s),n.slice(o,i)}import{randomUUID as hO}from"crypto";import{cloneDeep as Ip}from"lodash-es";import{randomUUID as dO}from"crypto";var bb=new Set(["about:blank","chrome-error://chromewebdata/"]);var Ut="data-momentic-id";var Tp=["button","image","generic","graphics-symbol","tab","link","menuitem","group"],Cp=1e4,Ba=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 iO}from"crypto";var aO="v1";function Ol(n,e){if(n.tagName.toLowerCase()==="svg"&&!lO(n))try{let t=wb(n,e),r=sO(JSON.stringify(t));return{version:aO,json:t,hash:r}}catch{return}}function sO(n){return iO("md5").update(n).digest("hex")}function wb(n,e){let t=n.tagName.toLowerCase(),r=cO(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=wb(a,e);s&&o.children.push(s)}}return o}function lO(n){let e=n.computedStyles.display,t=n.computedStyles.visibility,r=n.computedStyles.opacity;return e==="none"||t==="hidden"||r==="0"}function cO(n){let e={},t=n.attributes;for(let r of Object.keys(t))Jn.visualAttributesForSvgSerialization.includes(r)&&(e[r]=t[r]);return t.id&&n.tagName.toLowerCase()!=="svg"&&(e.id=t.id),e}var oo={r:147,g:196,b:125,a:.55},Eb={showRulers:!1,showStyles:!1,showExtensionLines:!1,contrastAlgorithm:"aa",contentColor:oo,paddingColor:oo,borderColor:oo,marginColor:oo,eventTargetColor:oo,shapeColor:oo,shapeMarginColor:oo,showInfo:!0,showAccessibilityInfo:!0},Ml=["display","opacity","visibility","height","position"];function Tb({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=pO({allDocuments:o,stringConstants:r,frameIndex:c,devicePixelRatio:e,backendIdToNode:i,frameIndexToIframeNode:a,logger:t});s.roots.push(d)}),s}function pO({allDocuments:n,stringConstants:e,devicePixelRatio:t,frameIndex:r,frameIndexToIframeNode:o,backendIdToNode:i,logger:a}){let s=n[r],l=s.layout,c={};l.nodeIndex.forEach((C,R)=>{c[C]=R});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??[],x=u.pseudoType??{index:[],value:[]},y=u.inputChecked??{index:[]},T=e[s.frameId];for(let C=0;C<h.length;C++){let R=h[C],L=w[C],N=g[C]??[],H=f[C]!==void 0&&f[C]>=0?f[C]:void 0,z=H!==void 0?h[H]:void 0,k=z!==void 0?i[z]:void 0,_=x.index.indexOf(C),O=_!==-1?e[x.value[_]]:void 0,K=c[C],B;K?B=p[K]??[]:B=[];let le=S[C]!==void 0?e[S[C]]?.toLowerCase():void 0;if(!le){a.warn({backendNodeId:R,frameId:T,frameIndex:r,nodeBounds:B},"DOM node has no tag name");continue}let ce={backendNodeId:R,psuedoType:O,nodeType:L,frameIndex:r,parentFrameId:T,ownedFrameId:void 0,bounds:{x:B[0]??null,y:B[1]??null,width:B[2]??null,height:B[3]??null},computedStyles:{},attributes:{},parentBackendNodeId:z??null,tagName:le,parent:k??void 0,childrenBackendIds:[],momenticIgnored:void 0,mPathSelector:void 0};k&&k.childrenBackendIds.push(R);let fe=m.index.indexOf(C);if(fe!==-1){let _e=m.value[fe];o[_e]=ce;let me=n[_e]?.frameId;ce.ownedFrameId=me!==void 0?e[me]:void 0}for(let _e of Object.keys(ce.bounds)){let me=_e;ce.bounds[me]!==null&&(ce.bounds[me]/=t)}let J=K!==void 0?d[K]??[]:[];for(let _e=0;_e<J.length&&!(_e>=Ml.length);_e++){let me=J[_e];if(me===void 0||isNaN(me))continue;let At=e[me];if(At===void 0)continue;let yt=Ml[_e];ce.computedStyles[yt]=At}for(let _e=0;_e<N.length;_e+=2){let me=N[_e],At=N[_e+1];if(!me||!At)continue;let yt=e[me],En=e[At];!yt||!En||(ce.attributes[yt]=En)}y.index.includes(C)&&(ce.attributes.checked="true"),i[ce.backendNodeId]=ce}return i[h[0]]}function Ap(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=`${Ap(t,e)}${a}`}return n.mPathSelector=r,r}function vb({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:(jr({logger:r,logKey:t,maxCount:5,intervalMs:3e3},{candidate:e,originalNode:n},"Filtering out click candidate since it has a significantly different area"),!1):(jr({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 Nl(n,e,t){let r=Object.values(e.backendIdToNode),o,i=dO();for(let c of r)if(c.attributes?.[Ut]===n){o=c;break}if(!o)return[];let a=[],s=e.backendIdToNode[o.parentBackendNodeId??-1];for(;s&&(s?.momenticIgnored||!vb({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&&vb({originalNode:o,candidate:p,logKey:i,logger:t})?a.push(p):p&&l.push(p)}}return a}function xb(n,e){return n.parentBackendNodeId!==null?e.backendIdToNode[n.parentBackendNodeId]:n.frameIndex===0?void 0:e.frameIndexToIframeNode[n.frameIndex]}var uO=["html","#document","#document-fragment"];function Cb({node:n,domGraph:e}){let t=[],r=n,o=xb(n,e);if(!o)return[n.tagName];let i=()=>{if(r=o,o=xb(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++,uO.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 Rb(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 Ab(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,Ut);if(!i)throw new Error(`Could not find attribute ${Ut} for object ${e}`);return i}function Ib(n){let e=[];for(let t=0;t<n.domGraph.roots.length;t++){let r=n.domGraph.roots[t],o=mO({root:r,domGraph:n.domGraph,existingHashes:n.existingHashes,flagStore:n.flagStore,logger:n.logger});e=e.concat(o)}return e}function mO(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=Ol(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 gO=["focusable","keyshortcuts","controls","live","relevant","orientation"],fO=["selected","readonly","modal","required","invalid"],SO=["id","name","role","content"],Pb=["absolute","fixed","sticky"],yO=["path"],bO=["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"],Mb=["ariaHiddenElement","ariaHiddenSubtree","hiddenByChildTree","inertElement","inertSubtree","notRendered","notVisible"],Nb=["activeAriaModalDialog","activeFullscreenElement","activeModalDialog"],wO=["menulistpopup","statictext","inlinetextbox"],vO=80,Lb=100,kl=["StaticText","ListMarker","RootWebArea","LineBreak","emphasis","::before","::after"],xO=["cite"],EO={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"]},TO={name:!0,value:!0,title:!0,alt:!0,placeholder:!0,checked:!0,selected:!0,contenteditable:!0},Ob={indentLevel:0},Pp=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&&!Sb(t)?t:""),this.role=this.role||(e.domNode.attributes.role??""),IO(this.properties,e.domNode)}LO(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&&yO.includes(this.domNode.tagName))return!1;if(bO.includes(this.role.toLowerCase()))return!0;if(this.domNode?.computedStyles.display==="contents"||this.ignoredReasons.some(t=>Nb.includes(t)))return!1;if(this.role.toLowerCase()==="inlinetextbox"&&this.tagName||!this.properties.hidden&&(this.properties.focusable||this.properties.settable)||Jn.alwaysInterestingTruthyPropertyNames.some(t=>!!this.properties[t]))return!0;let e=this.properties.class;return typeof e=="string"&&e.split(" ").some(t=>Fb(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=Ob){let t=Object.assign({},Ob,e),{indentLevel:r,noChildren:o,noProperties:i,noId:a,noContent:s,condensedMode:l}=t,c=Ip(this.properties),d=" ".repeat(r),p=this.role||"",u=this.tagName??"unknown",m=this.name;p==="heading"&&m==="heading"&&(m=""),this.nameSources?.find(T=>!T.superseded&&T.type==="contents")&&this.children.length>0&&(m="");let g=this.nameSources?.find(T=>!T.superseded);if(g&&!g.nativeSource&&g.type==="relatedElement"){let T=g.attributeValue?.relatedNodes??[];T.length===1&&T[0].text&&T[0].text===m&&(m="")}let f=kl.includes(this.role)||xO.includes(this.tagName||"");if(this.role==="StaticText"||this.role==="ListMarker")return`${d}${m}
|
|
3835
|
-
`;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&&!(
|
|
3836
|
-
`;else{let T="";for(let R of this.children)T+=R.serialize({...e,indentLevel:r+2,neighbors:0});let C=T.trim();C.length<=
|
|
3888
|
+
`&&(i=s),n.slice(o,i)}import{randomUUID as gO}from"crypto";import{cloneDeep as Ip}from"lodash-es";import{randomUUID as pO}from"crypto";var yb=new Set(["about:blank","chrome-error://chromewebdata/"]);var Ut="data-momentic-id";var Tp=["button","image","generic","graphics-symbol","tab","link","menuitem","group"],Cp=1e4,Ba=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 aO}from"crypto";var sO="v1";function Ol(n,e){if(n.tagName.toLowerCase()==="svg"&&!cO(n))try{let t=bb(n,e),r=lO(JSON.stringify(t));return{version:sO,json:t,hash:r}}catch{return}}function lO(n){return aO("md5").update(n).digest("hex")}function bb(n,e){let t=n.tagName.toLowerCase(),r=dO(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=bb(a,e);s&&o.children.push(s)}}return o}function cO(n){let e=n.computedStyles.display,t=n.computedStyles.visibility,r=n.computedStyles.opacity;return e==="none"||t==="hidden"||r==="0"}function dO(n){let e={},t=n.attributes;for(let r of Object.keys(t))Jn.visualAttributesForSvgSerialization.includes(r)&&(e[r]=t[r]);return t.id&&n.tagName.toLowerCase()!=="svg"&&(e.id=t.id),e}var ro={r:147,g:196,b:125,a:.55},Eb={showRulers:!1,showStyles:!1,showExtensionLines:!1,contrastAlgorithm:"aa",contentColor:ro,paddingColor:ro,borderColor:ro,marginColor:ro,eventTargetColor:ro,shapeColor:ro,shapeMarginColor:ro,showInfo:!0,showAccessibilityInfo:!0},Nl=["display","opacity","visibility","height","position"];function xb({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=uO({allDocuments:o,stringConstants:r,frameIndex:c,devicePixelRatio:e,backendIdToNode:i,frameIndexToIframeNode:a,logger:t});s.roots.push(d)}),s}function uO({allDocuments:n,stringConstants:e,devicePixelRatio:t,frameIndex:r,frameIndexToIframeNode:o,backendIdToNode:i,logger:a}){let s=n[r],l=s.layout,c={};l.nodeIndex.forEach((C,R)=>{c[C]=R});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:[]},T=e[s.frameId];for(let C=0;C<h.length;C++){let R=h[C],L=w[C],M=g[C]??[],H=f[C]!==void 0&&f[C]>=0?f[C]:void 0,z=H!==void 0?h[H]:void 0,k=z!==void 0?i[z]:void 0,_=E.index.indexOf(C),O=_!==-1?e[E.value[_]]:void 0,K=c[C],B;K?B=p[K]??[]:B=[];let se=S[C]!==void 0?e[S[C]]?.toLowerCase():void 0;if(!se){a.warn({backendNodeId:R,frameId:T,frameIndex:r,nodeBounds:B},"DOM node has no tag name");continue}let le={backendNodeId:R,psuedoType:O,nodeType:L,frameIndex:r,parentFrameId:T,ownedFrameId:void 0,bounds:{x:B[0]??null,y:B[1]??null,width:B[2]??null,height:B[3]??null},computedStyles:{},attributes:{},parentBackendNodeId:z??null,tagName:se,parent:k??void 0,childrenBackendIds:[],momenticIgnored:void 0,mPathSelector:void 0};k&&k.childrenBackendIds.push(R);let fe=m.index.indexOf(C);if(fe!==-1){let _e=m.value[fe];o[_e]=le;let ue=n[_e]?.frameId;le.ownedFrameId=ue!==void 0?e[ue]:void 0}for(let _e of Object.keys(le.bounds)){let ue=_e;le.bounds[ue]!==null&&(le.bounds[ue]/=t)}let J=K!==void 0?d[K]??[]:[];for(let _e=0;_e<J.length&&!(_e>=Nl.length);_e++){let ue=J[_e];if(ue===void 0||isNaN(ue))continue;let At=e[ue];if(At===void 0)continue;let yt=Nl[_e];le.computedStyles[yt]=At}for(let _e=0;_e<M.length;_e+=2){let ue=M[_e],At=M[_e+1];if(!ue||!At)continue;let yt=e[ue],xn=e[At];!yt||!xn||(le.attributes[yt]=xn)}y.index.includes(C)&&(le.attributes.checked="true"),i[le.backendNodeId]=le}return i[h[0]]}function Ap(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=`${Ap(t,e)}${a}`}return n.mPathSelector=r,r}function wb({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:(Hr({logger:r,logKey:t,maxCount:5,intervalMs:3e3},{candidate:e,originalNode:n},"Filtering out click candidate since it has a significantly different area"),!1):(Hr({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 Ml(n,e,t){let r=Object.values(e.backendIdToNode),o,i=pO();for(let c of r)if(c.attributes?.[Ut]===n){o=c;break}if(!o)return[];let a=[],s=e.backendIdToNode[o.parentBackendNodeId??-1];for(;s&&(s?.momenticIgnored||!wb({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&&wb({originalNode:o,candidate:p,logKey:i,logger:t})?a.push(p):p&&l.push(p)}}return a}function vb(n,e){return n.parentBackendNodeId!==null?e.backendIdToNode[n.parentBackendNodeId]:n.frameIndex===0?void 0:e.frameIndexToIframeNode[n.frameIndex]}var mO=["html","#document","#document-fragment"];function Tb({node:n,domGraph:e}){let t=[],r=n,o=vb(n,e);if(!o)return[n.tagName];let i=()=>{if(r=o,o=vb(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++,mO.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 Cb(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 Rb(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,Ut);if(!i)throw new Error(`Could not find attribute ${Ut} for object ${e}`);return i}function Ab(n){let e=[];for(let t=0;t<n.domGraph.roots.length;t++){let r=n.domGraph.roots[t],o=hO({root:r,domGraph:n.domGraph,existingHashes:n.existingHashes,flagStore:n.flagStore,logger:n.logger});e=e.concat(o)}return e}function hO(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=Ol(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 fO=["focusable","keyshortcuts","controls","live","relevant","orientation"],SO=["selected","readonly","modal","required","invalid"],yO=["id","name","role","content"],Ib=["absolute","fixed","sticky"],bO=["path"],wO=["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"],Ob=["ariaHiddenElement","ariaHiddenSubtree","hiddenByChildTree","inertElement","inertSubtree","notRendered","notVisible"],Nb=["activeAriaModalDialog","activeFullscreenElement","activeModalDialog"],vO=["menulistpopup","statictext","inlinetextbox"],EO=80,Pb=100,kl=["StaticText","ListMarker","RootWebArea","LineBreak","emphasis","::before","::after"],xO=["cite"],TO={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"]},CO={name:!0,value:!0,title:!0,alt:!0,placeholder:!0,checked:!0,selected:!0,contenteditable:!0},Lb={indentLevel:0},Pp=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&&!fb(t)?t:""),this.role=this.role||(e.domNode.attributes.role??""),PO(this.properties,e.domNode)}OO(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&&bO.includes(this.domNode.tagName))return!1;if(wO.includes(this.role.toLowerCase()))return!0;if(this.domNode?.computedStyles.display==="contents"||this.ignoredReasons.some(t=>Nb.includes(t)))return!1;if(this.role.toLowerCase()==="inlinetextbox"&&this.tagName||!this.properties.hidden&&(this.properties.focusable||this.properties.settable)||Jn.alwaysInterestingTruthyPropertyNames.some(t=>!!this.properties[t]))return!0;let e=this.properties.class;return typeof e=="string"&&e.split(" ").some(t=>Db(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=Lb){let t=Object.assign({},Lb,e),{indentLevel:r,noChildren:o,noProperties:i,noId:a,noContent:s,condensedMode:l}=t,c=Ip(this.properties),d=" ".repeat(r),p=this.role||"",u=this.tagName??"unknown",m=this.name;p==="heading"&&m==="heading"&&(m=""),this.nameSources?.find(T=>!T.superseded&&T.type==="contents")&&this.children.length>0&&(m="");let g=this.nameSources?.find(T=>!T.superseded);if(g&&!g.nativeSource&&g.type==="relatedElement"){let T=g.attributeValue?.relatedNodes??[];T.length===1&&T[0].text&&T[0].text===m&&(m="")}let f=kl.includes(this.role)||xO.includes(this.tagName||"");if(this.role==="StaticText"||this.role==="ListMarker")return`${d}${m}
|
|
3889
|
+
`;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&&!(TO[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(([T,C])=>{if(!fO.includes(T)){{if(SO.includes(T)&&(!C||C==="false"))return;if(T==="value"&&w&&(c.type==="text"||this.role==="textbox"))return;if(T==="level"&&`${C}`=="1")return;if(T==="url"&&c.src&&u==="img")return;if(T==="url"&&c.href&&u==="a")return;if(T==="editable"&&C==="plaintext")return;if(T==="type"&&C===u)return;if(l&&!CO[T])return}typeof C=="string"?S+=` ${T}="${je(C,Pb,!0)}"`:typeof C=="boolean"?C?S+=` ${T}`:S+=` ${T}={false}`:typeof C<"u"&&(S+=` ${T}={${je(JSON.stringify(C),Pb,!0)}}`)}})}if(u==="::before"||u==="::after"){let T="";for(let C of this.children)T+=C.serialize({...e,indentLevel:r,neighbors:0});return T}let y=e.maxLevel!==void 0&&r/2>=e.maxLevel;if(this.children.length===0||o||y)S+=` />
|
|
3890
|
+
`;else{let T="";for(let R of this.children)T+=R.serialize({...e,indentLevel:r+2,neighbors:0});let C=T.trim();C.length<=EO&&!C.includes(`
|
|
3837
3891
|
`)?S+=`>${C}</${u}>
|
|
3838
3892
|
`:S+=`>
|
|
3839
3893
|
${T}${d}</${u}>
|
|
3840
3894
|
`}if(e.neighbors!==void 0&&e.neighbors>0&&this.parent){let T=this.parent.children.findIndex(L=>L.id===this.id),C=T>0?this.parent.children[T-1]?.serialize({...e,neighbors:0}):"",R=T<this.parent.children.length-1?this.parent.children[T+1]?.serialize({...e,neighbors:0}):"";return`${C||""}
|
|
3841
3895
|
${S}
|
|
3842
|
-
${R||""}`}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:Ip(this.internalProperties),parentFrame:this.parentFrame});return e.tagName=this.tagName,e.dataMomenticId=this.dataMomenticId,e.properties=Ip(this.properties),e}},Lp=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(kl.includes(i.role)&&a)return l}let o=r(t);return new n(o,this.a11yIdNodeMap,this.dataMomenticIdMap,this.selectorToNodeMap)}};function CO(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 RO(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?(jr({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?(jr({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 kb({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,_={})=>{},g=n.backendDOMNodeId,f=wO.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 U(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&&!RO(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 jr({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}`:"",x=n.value?.value?typeof n.value.value=="string"?n.value.value:`${n.value.value}`:"",y=new Pp({domNode:S,id:parseInt(n.nodeId),role:n.role?.value||"",name:w,nameSources:n.name?.sources,content:x,properties:n.properties,children:[],ignoredReasons:n.ignoredReasons?.filter(k=>Mb.includes(k.name)||Nb.includes(k.name))??[],pathFromRoot:(e?`${e.pathFromRoot} `:"")+CO(n),backendNodeID:n.backendDOMNodeId,ignoredByCDP:n.ignored,internalProperties:{inCodeMirrorEditor:e?.internalProperties?.inCodeMirrorEditor},parentFrame:r.type==="root"?void 0:r}),T=r,C=a[t],R=t;if(S?.tagName.toLowerCase()==="iframe"&&S.ownedFrameId){let k=r.childFrames.find(K=>K.frameId===S.ownedFrameId),_=o[k?.frameId??""]?.root,O=a[k?.frameId??""];if(k&&_&&O){n.childIds&&n.childIds.length>0&&u.debug("Replacing existing node's children with children from the iframe");let K=_;n.childIds=K.childIds,T=k,C=O,R=k.frameId}}let L=S?.childrenBackendIds?.length??0,N=n.childIds?.length??0;if(L>N){let k=n.childIds?.map(O=>C.get(parseInt(O))).filter(Boolean).map(O=>O?.backendDOMNodeId).filter(O=>O!==void 0)??[],_=0;for(let O of S?.childrenBackendIds??[]){if(k.includes(O)){_=(n.childIds?.findIndex(fe=>C.get(parseInt(fe))?.backendDOMNodeId===O)??0)+1;continue}let K=i.backendIdToNode[O];if(!K||K?.tagName.toLowerCase()!=="svg")continue;let B=Math.floor(-1*Math.random()*1e7),le={nodeId:B.toString(),parentId:n.nodeId,ignored:!1,backendDOMNodeId:O,frameId:R,role:{type:"string",value:"graphics-symbol"}};C.set(B,le),n.childIds||(n.childIds=[]),n.childIds.splice(_,0,B.toString()),_++}}for(let k of n.childIds??[]){if(!k)continue;let _=C.get(parseInt(k));if(!_)continue;let O=await kb({node:_,parent:y,domGraph:i,axGraph:o,frameId:R,frameContext:T,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,_=y.children[0]?.name;(k===_||!_)&&(y.children=[])}let H=[];for(let k=y.children.length-1;k>=0;k--){let _=y.children[k];if(_.role!=="StaticText"){H.push(_);continue}if(k===0||y.children[k-1].role!=="StaticText"){H.push(_);continue}y.children[k-1].name+=_.name}if(y.children=H.reverse(),y.role==="generic"&&y.children.length===1){let k=y.children[0];if(y.name&&!kl.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 PO(y),S&&d&&Ap(S,i),[y]}function _b({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:kl.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=Ol(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=_b({node:u,a11yIdNodeMap:e,dataMomenticIdMap:t,logger:r,callId:o,startId:c,useMPaths:a,domGraph:i,selectorToNodeMap:s,iconKnowledgeBase:l});return c}async function Db({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=hO(),h=y=>{let T=y.allNodes.filter(R=>!R.ignoredReasons?.find(N=>Mb.includes(N.name))),C=new Map;return T.forEach(R=>{C.set(parseInt(R.nodeId),R)}),C},g={};Object.entries(n).forEach(([y,T])=>{g[y]=h(T)});let f=await kb({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={},x={};return _b({node:f[0],a11yIdNodeMap:S,dataMomenticIdMap:w,selectorToNodeMap:x,domGraph:e,logger:r,callId:m,useMPaths:l,iconKnowledgeBase:d}),new Lp(f[0],S,w,x)}function AO(n,e,t){if(n==="class"){if(t.tagName?.toLowerCase()==="svg")return e.split(" ").filter(i=>i.length<50&&!Jn.bannedClassSubstrings.some(a=>i.includes(a))).slice(0,3).join(" ");let r=e.split(" "),o=[];for(let i of r)if(Fb(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 IO(n,e){if(!e)return;Object.entries(e.attributes).forEach(([i,a])=>{if(Jn.relevantElementAttributes.includes(i)&&!SO.includes(i)&&!n[i]&&!i.startsWith("aria")){let s=AO(i,a,e);s!==null&&(n[i]=s)}});let t,r=[];if(e.computedStyles.position&&Pb.includes(e.computedStyles.position))t=e.computedStyles.position;else if(e.attributes.style){for(let i of Pb)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 PO(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 LO(n){let e=n.properties.class,t=typeof e=="string"&&e.includes("cm-content");n.internalProperties.inCodeMirrorEditor=n.internalProperties?.inCodeMirrorEditor||t}function Fb(n){if(Jn.bannedClassSubstrings.some(e=>n.includes(e)))return!1;if(Jn.alwaysInterestingClassNames.includes(n))return!0;for(let e of Jn.alwaysInterestingClassPrefixes)if(n.startsWith(e))return!0;return!1}var _l=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 U(i.newCDPSession(a),{milliseconds:o*d,fallback:()=>{throw new A("UserInfrastructureError",`Failed to initialize Chrome session within the page load timeout (${a.url()})`)}});break}catch(p){await ee(500),l=p}if(!s)throw l;let c=new n(s,e,t,r,o);try{await U(c.registerHandlers(s),{milliseconds:o,message:`CDP handler registration timed out after ${o}ms`})}catch(d){throw c.cdpFullyDead=!0,new A("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 U(this.cdpInitializingPromise,{milliseconds:r});if(this.cdpCrashDetails){if(this.cdpFullyDead)throw new A("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 U(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 U(this.contextGetter().newCDPSession(r),{milliseconds:t,fallback:()=>{throw this.logger.error(`Failed to initialize CDP session within the page load timeout (${r.url()})`),new A("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 U(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 U(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 OO,rmSync as Ub,statSync as MO}from"fs";import*as Np from"node:fs";import NO from"nodejs-file-downloader";import{tmpdir as kO}from"os";import xr,{basename as _O,dirname as DO}from"path";var kp="file://",Mp=xr.join(kO(),"momentic","downloads"),Op=1e4,FO=50*1024*1024;async function Bb(n){let{uri:e}=n;return e.startsWith(kp)?BO(n):e.startsWith("http")?HO(n):zO(n)}function UO(n,e){let t=xr.join(Mp,n,e.slice(kp.length)),r=xr.join(Mp,n),o=t.startsWith(r);if(!Np.existsSync(t)||!o)throw new A("UserConfigurationError",`The referenced file (${e}) does not exist. Please make sure that it has been downloaded successfully.`);return t}async function BO({uri:n,orgId:e}){let t=UO(e,n);return{filePath:t,cleanup:()=>{Ub(DO(t),{recursive:!0,force:!0})}}}async function zO({uri:n}){let e=xr.resolve(n);if(!Np.existsSync(e))throw new A("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 HO({uri:n,logger:e,orgId:t}){let r=new URL(n);r.search&&(r.search="");let o=_O(r.href),i=Dp(o),a=xr.extname(i);if(Zh.includes(a))throw new Error(`Downloading files with extension ${a} is not allowed.`);let s=_p(t),l=new NO({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:Op}),{downloadStatus:c,filePath:d}=await U(l.download(),{milliseconds:Op,message:`Download timed out after ${Op}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=MO(d).size;if(u>FO)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(()=>Ub(s,{recursive:!0,force:!0}),10*60*1e3)}}}function zb(n,e){return`${kp}${n}/${e}`}function _p(n){let e=Math.random().toString(36).substring(4),t=xr.join(Mp,n,e);return OO(t,{recursive:!0}),t}function Dp(n){let e=xr.extname(n),t=xr.basename(n,e);return n=(t.length>100?t.slice(t.length-100):t)+e,n=n.trim().replaceAll(" ","_"),n}async function wn(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 Hb(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 U(t,{milliseconds:3e3});return o&&e.warn({err:o},"Failed to fetch indexedDB data"),r}async function jb(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 U(r,{milliseconds:3e3})}catch(r){t.warn({err:r},"Failed to import indexedDB data")}}}async function $b(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 U(t,{milliseconds:3e3})}catch(t){e.debug({err:t},"Failed clearing index db data, continuing...")}}async function Gb(n,e,t,r,o){try{await jO(n,e,t,r)}catch(i){o.error({err:i,tabIndex:e},"Error handling new console log")}}async function jO(n,e,t,r){let o=r.text();o.length>Ba&&(o=o.slice(0,Ba)+"...(TRUNCATED)");let i=[];for(let a of r.args())try{let s=await a.jsonValue(),l=JSON.stringify(s);l.length>Ba?i.push(l.slice(0,Ba)+"...(TRUNCATED)"):(typeof s!="object"||Object.keys(s).length>0)&&i.push(s)}catch{}Fp(n,t,e,{url:n.url(),location:r.location(),type:r.type(),text:r.text(),args:i})}function Fp(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>Cp&&(i[t]=i[t].slice(Math.floor(Cp/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 ln({fn:n,codePath:e,logObject:t,signal:r,logger:o}){r?.throwIfAborted();let i=Date.now(),a=await ha({promiseGenerator:n,signal:r,codePath:e,logger:o}),s=Date.now();return t[e]=s-i,a}import{randomUUID as $O}from"crypto";var GO="[redacted due to size]",WO=1e4;async function Yb(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 Jb(n,e,t,r){try{await VO(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 io(n){return n<0?0:n}function Wb(n){return{timings:{blocked:io(n.domainLookupStart),dns:io(n.domainLookupEnd-n.domainLookupStart),connect:io(n.connectEnd-n.connectStart),send:io(n.responseStart-n.requestStart),wait:0,receive:io(n.responseEnd-n.responseStart),ssl:io(n.connectEnd-n.secureConnectionStart)},total:io(n.responseEnd)}}async function VO(n,e,t){let r=$O(),o=t.timing(),i=new URL(t.url()),a=[...i.searchParams.entries()].map(([h,g])=>({name:h,value:g})),s={...await Kb(t),url:i.toString(),method:t.method(),queryString:a,postData:await KO(t)},l={pageref:n,_resourceType:t.resourceType(),startedDateTime:new Date(o.startTime).toISOString(),request:s,timings:Wb(o).timings};Vb(e,l,r);let c=await t.response();if(c){await c.finished();let h={};try{h=await YO(c)}catch{}let g={...await Kb(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}=Wb(p);l.time=m,l.timings=u,Vb(e,l,r)}function Vb(n,e,t){n.harEntries||(n.harEntries={}),n.harEntries[t]=e}function qb(n){try{return new Date(n).toISOString()}catch{return}}function qO(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=_n(i),e.value=_n(a);continue}i==="Domain"&&(e.domain=_n(a)),i==="Expires"&&(e.expires=qb(a)),i==="HttpOnly"&&(e.httpOnly=!0),i==="Max-Age"&&(e.expires=qb(Date.now()+ +a*1e3)),i==="Path"&&(e.path=_n(a)),i==="Secure"&&(e.secure=!0)}return e}async function Kb(n){let e=await n.allHeaders(),t=e.cookie?.split(";").map(qO)??[];return{headers:Object.entries(e).map(([r,o])=>({name:_n(r),value:_n(o)})),cookies:t}}async function KO(n){let e=n.postData();if(!e)return;let t=await n.headerValue("content-type"),r={mimeType:t??"application/octet-stream",text:_n(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:_n(i),value:a?_n(a):void 0})}return r}async function YO(n){return{mimeType:await n.headerValue("content-type")??void 0,text:_n(await n.text()),encoding:await n.headerValue("content-encoding")??void 0}}function _n(n){return n.length>WO?GO:n}function Xb(){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 Ge({root:n,fn:e,arg:t,timeout:r,waitForPageLoad:o,codePath:i}){return await o(),await U(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 Up(){return window.lastCursorPos}import{errors as JO}from"playwright-core";async function ao({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(la(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 JO.TimeoutError)t.warn({err:c,rootUrl:(await r.state.getRoot()).url()},`Encountered Playwright error while performing ${e}`),s=await XO(c,i.locator,r,t);else throw c}throw s instanceof A?s:new A("ActionFailureError",`Failed to interact with targeted element. Error: ${s.message}`,{errOptions:{cause:s}})}async function XO(n,e,t,r){return n.message.includes("attempt #")?ZO(n,e,t,r):QO(n)}async function ZO(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(`
|
|
3896
|
+
${R||""}`}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:Ip(this.internalProperties),parentFrame:this.parentFrame});return e.tagName=this.tagName,e.dataMomenticId=this.dataMomenticId,e.properties=Ip(this.properties),e}},Lp=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(kl.includes(i.role)&&a)return l}let o=r(t);return new n(o,this.a11yIdNodeMap,this.dataMomenticIdMap,this.selectorToNodeMap)}};function RO(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 AO(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?(Hr({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?(Hr({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 Mb({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,_={})=>{},g=n.backendDOMNodeId,f=vO.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 U(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&&!AO(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 Hr({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 Pp({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=>Ob.includes(k.name)||Nb.includes(k.name))??[],pathFromRoot:(e?`${e.pathFromRoot} `:"")+RO(n),backendNodeID:n.backendDOMNodeId,ignoredByCDP:n.ignored,internalProperties:{inCodeMirrorEditor:e?.internalProperties?.inCodeMirrorEditor},parentFrame:r.type==="root"?void 0:r}),T=r,C=a[t],R=t;if(S?.tagName.toLowerCase()==="iframe"&&S.ownedFrameId){let k=r.childFrames.find(K=>K.frameId===S.ownedFrameId),_=o[k?.frameId??""]?.root,O=a[k?.frameId??""];if(k&&_&&O){n.childIds&&n.childIds.length>0&&u.debug("Replacing existing node's children with children from the iframe");let K=_;n.childIds=K.childIds,T=k,C=O,R=k.frameId}}let L=S?.childrenBackendIds?.length??0,M=n.childIds?.length??0;if(L>M){let k=n.childIds?.map(O=>C.get(parseInt(O))).filter(Boolean).map(O=>O?.backendDOMNodeId).filter(O=>O!==void 0)??[],_=0;for(let O of S?.childrenBackendIds??[]){if(k.includes(O)){_=(n.childIds?.findIndex(fe=>C.get(parseInt(fe))?.backendDOMNodeId===O)??0)+1;continue}let K=i.backendIdToNode[O];if(!K||K?.tagName.toLowerCase()!=="svg")continue;let B=Math.floor(-1*Math.random()*1e7),se={nodeId:B.toString(),parentId:n.nodeId,ignored:!1,backendDOMNodeId:O,frameId:R,role:{type:"string",value:"graphics-symbol"}};C.set(B,se),n.childIds||(n.childIds=[]),n.childIds.splice(_,0,B.toString()),_++}}for(let k of n.childIds??[]){if(!k)continue;let _=C.get(parseInt(k));if(!_)continue;let O=await Mb({node:_,parent:y,domGraph:i,axGraph:o,frameId:R,frameContext:T,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,_=y.children[0]?.name;(k===_||!_)&&(y.children=[])}let H=[];for(let k=y.children.length-1;k>=0;k--){let _=y.children[k];if(_.role!=="StaticText"){H.push(_);continue}if(k===0||y.children[k-1].role!=="StaticText"){H.push(_);continue}y.children[k-1].name+=_.name}if(y.children=H.reverse(),y.role==="generic"&&y.children.length===1){let k=y.children[0];if(y.name&&!kl.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 LO(y),S&&d&&Ap(S,i),[y]}function kb({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:kl.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=Ol(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=kb({node:u,a11yIdNodeMap:e,dataMomenticIdMap:t,logger:r,callId:o,startId:c,useMPaths:a,domGraph:i,selectorToNodeMap:s,iconKnowledgeBase:l});return c}async function _b({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=gO(),h=y=>{let T=y.allNodes.filter(R=>!R.ignoredReasons?.find(M=>Ob.includes(M.name))),C=new Map;return T.forEach(R=>{C.set(parseInt(R.nodeId),R)}),C},g={};Object.entries(n).forEach(([y,T])=>{g[y]=h(T)});let f=await Mb({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 kb({node:f[0],a11yIdNodeMap:S,dataMomenticIdMap:w,selectorToNodeMap:E,domGraph:e,logger:r,callId:m,useMPaths:l,iconKnowledgeBase:d}),new Lp(f[0],S,w,E)}function IO(n,e,t){if(n==="class"){if(t.tagName?.toLowerCase()==="svg")return e.split(" ").filter(i=>i.length<50&&!Jn.bannedClassSubstrings.some(a=>i.includes(a))).slice(0,3).join(" ");let r=e.split(" "),o=[];for(let i of r)if(Db(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 PO(n,e){if(!e)return;Object.entries(e.attributes).forEach(([i,a])=>{if(Jn.relevantElementAttributes.includes(i)&&!yO.includes(i)&&!n[i]&&!i.startsWith("aria")){let s=IO(i,a,e);s!==null&&(n[i]=s)}});let t,r=[];if(e.computedStyles.position&&Ib.includes(e.computedStyles.position))t=e.computedStyles.position;else if(e.attributes.style){for(let i of Ib)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 LO(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 OO(n){let e=n.properties.class,t=typeof e=="string"&&e.includes("cm-content");n.internalProperties.inCodeMirrorEditor=n.internalProperties?.inCodeMirrorEditor||t}function Db(n){if(Jn.bannedClassSubstrings.some(e=>n.includes(e)))return!1;if(Jn.alwaysInterestingClassNames.includes(n))return!0;for(let e of Jn.alwaysInterestingClassPrefixes)if(n.startsWith(e))return!0;return!1}var _l=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 U(i.newCDPSession(a),{milliseconds:o*d,fallback:()=>{throw new A("UserInfrastructureError",`Failed to initialize Chrome session within the page load timeout (${a.url()})`)}});break}catch(p){await ee(500),l=p}if(!s)throw l;let c=new n(s,e,t,r,o);try{await U(c.registerHandlers(s),{milliseconds:o,message:`CDP handler registration timed out after ${o}ms`})}catch(d){throw c.cdpFullyDead=!0,new A("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 U(this.cdpInitializingPromise,{milliseconds:r});if(this.cdpCrashDetails){if(this.cdpFullyDead)throw new A("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 U(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 U(this.contextGetter().newCDPSession(r),{milliseconds:t,fallback:()=>{throw this.logger.error(`Failed to initialize CDP session within the page load timeout (${r.url()})`),new A("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 U(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 U(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 NO,rmSync as Fb,statSync as MO}from"fs";import*as Mp from"node:fs";import kO from"nodejs-file-downloader";import{tmpdir as _O}from"os";import Er,{basename as DO,dirname as FO}from"path";var kp="file://",Np=Er.join(_O(),"momentic","downloads"),Op=1e4,UO=50*1024*1024;async function Ub(n){let{uri:e}=n;return e.startsWith(kp)?zO(n):e.startsWith("http")?jO(n):HO(n)}function BO(n,e){let t=Er.join(Np,n,e.slice(kp.length)),r=Er.join(Np,n),o=t.startsWith(r);if(!Mp.existsSync(t)||!o)throw new A("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=BO(e,n);return{filePath:t,cleanup:()=>{Fb(FO(t),{recursive:!0,force:!0})}}}async function HO({uri:n}){let e=Er.resolve(n);if(!Mp.existsSync(e))throw new A("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 jO({uri:n,logger:e,orgId:t}){let r=new URL(n);r.search&&(r.search="");let o=DO(r.href),i=Dp(o),a=Er.extname(i);if(Xh.includes(a))throw new Error(`Downloading files with extension ${a} is not allowed.`);let s=_p(t),l=new kO({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:Op}),{downloadStatus:c,filePath:d}=await U(l.download(),{milliseconds:Op,message:`Download timed out after ${Op}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=MO(d).size;if(u>UO)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(()=>Fb(s,{recursive:!0,force:!0}),10*60*1e3)}}}function Bb(n,e){return`${kp}${n}/${e}`}function _p(n){let e=Math.random().toString(36).substring(4),t=Er.join(Np,n,e);return NO(t,{recursive:!0}),t}function Dp(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 wn(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 zb(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 U(t,{milliseconds:3e3});return o&&e.warn({err:o},"Failed to fetch indexedDB data"),r}async function Hb(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 U(r,{milliseconds:3e3})}catch(r){t.warn({err:r},"Failed to import indexedDB data")}}}async function jb(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 U(t,{milliseconds:3e3})}catch(t){e.debug({err:t},"Failed clearing index db data, continuing...")}}async function $b(n,e,t,r,o){try{await $O(n,e,t,r)}catch(i){o.error({err:i,tabIndex:e},"Error handling new console log")}}async function $O(n,e,t,r){let o=r.text();o.length>Ba&&(o=o.slice(0,Ba)+"...(TRUNCATED)");let i=[];for(let a of r.args())try{let s=await a.jsonValue(),l=JSON.stringify(s);l.length>Ba?i.push(l.slice(0,Ba)+"...(TRUNCATED)"):(typeof s!="object"||Object.keys(s).length>0)&&i.push(s)}catch{}Fp(n,t,e,{url:n.url(),location:r.location(),type:r.type(),text:r.text(),args:i})}function Fp(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>Cp&&(i[t]=i[t].slice(Math.floor(Cp/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 ln({fn:n,codePath:e,logObject:t,signal:r,logger:o}){r?.throwIfAborted();let i=Date.now(),a=await ha({promiseGenerator:n,signal:r,codePath:e,logger:o}),s=Date.now();return t[e]=s-i,a}import{randomUUID as GO}from"crypto";var WO="[redacted due to size]",VO=1e4;async function Kb(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 Yb(n,e,t,r){try{await qO(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 oo(n){return n<0?0:n}function Gb(n){return{timings:{blocked:oo(n.domainLookupStart),dns:oo(n.domainLookupEnd-n.domainLookupStart),connect:oo(n.connectEnd-n.connectStart),send:oo(n.responseStart-n.requestStart),wait:0,receive:oo(n.responseEnd-n.responseStart),ssl:oo(n.connectEnd-n.secureConnectionStart)},total:oo(n.responseEnd)}}async function qO(n,e,t){let r=GO(),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 YO(t)},l={pageref:n,_resourceType:t.resourceType(),startedDateTime:new Date(o.startTime).toISOString(),request:s,timings:Gb(o).timings};Wb(e,l,r);let c=await t.response();if(c){await c.finished();let h={};try{h=await JO(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}=Gb(p);l.time=m,l.timings=u,Wb(e,l,r)}function Wb(n,e,t){n.harEntries||(n.harEntries={}),n.harEntries[t]=e}function Vb(n){try{return new Date(n).toISOString()}catch{return}}function KO(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=Vb(a)),i==="HttpOnly"&&(e.httpOnly=!0),i==="Max-Age"&&(e.expires=Vb(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(KO)??[];return{headers:Object.entries(e).map(([r,o])=>({name:kn(r),value:kn(o)})),cookies:t}}async function YO(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 JO(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>VO?WO:n}function Jb(){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 qe({root:n,fn:e,arg:t,timeout:r,waitForPageLoad:o,codePath:i}){return await o(),await U(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 Up(){return window.lastCursorPos}import{errors as XO}from"playwright-core";async function io({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(la(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 XO.TimeoutError)t.warn({err:c,rootUrl:(await r.state.getRoot()).url()},`Encountered Playwright error while performing ${e}`),s=await ZO(c,i.locator,r,t);else throw c}throw s instanceof A?s:new A("ActionFailureError",`Failed to interact with targeted element. Error: ${s.message}`,{errOptions:{cause:s}})}async function ZO(n,e,t,r){return n.message.includes("attempt #")?QO(n,e,t,r):eN(n)}async function QO(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(`
|
|
3843
3897
|
`,";").replace(/\s+/g," ");let a="",s=await wn(e,r);if(s&&(a=`Target element HTML: ${je(s,100,!0)}`),i.includes("element is not enabled"))return new A("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 wn(d,r);p&&(l=`Covering element HTML: ${je(p,100,!0)}`)}return new A("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}
|
|
3844
|
-
${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 A("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 A("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 QO(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 A("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 Zb(n){try{return await eM(n)}catch(e){n.logger.warn({err:e},"Failed to transform locator for Chakra click, continuing...");return}}async function eM({locator:n,logger:e}){let[t,r]=await n.evaluate(l=>[l.id,l.tagName.toLowerCase()],{timeout:1e3}),o=await wn(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?`[data-momentic-id=${JSON.stringify(l.getAttribute("data-momentic-id"))}]`:c.getMPath?.(l)?.join(" >");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 ew=["date","datetime-local","month","time","week"],Qb={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 tw(n){try{await U(tM(n),{milliseconds:3e3})}catch(e){n.logger.warn({err:e},"Failed to transform native datetime input, continuing...")}}async function tM({root:n,text:e,options:t,logger:r,callbacks:o}){let i=(await Ge({root:n,fn:()=>document.activeElement?.getAttribute("type")??"",timeout:1e3,arg:void 0,waitForPageLoad:o.waitForPageLoad,codePath:"transforming native datetime input"})).toLowerCase();if(!Qb[i])return;Qb[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 Dl({locator:n,callbacks:e,logger:t,timeoutMs:r=1e3}){try{await Bp(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 U(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 Bp(n,e=1e3){let t=await n.state.getRoot();await Ge({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 Hp(n){let e=n.flagStore.isBooleanFlagEnabled("visual_actions");return ao({action:"clicking element",targetingResult:n.targetingResult,logger:n.logger,retryTimeoutMs:n.retryTimeoutMs,callbacks:n.browserCallbacks,func:async t=>zp({...n,targetingResult:t,useVisualClick:e})})}async function iM(n,e){let{redirectionAttempts:t=0}=e;if(t>=2)throw n;try{return await aM(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 aM(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"),zp({...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 pM(a,s,t);if(l)return zp({...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 Kr({promiseGenerator:async()=>s.boundingBox(),timeoutMs:3e3,logger:t}):null}catch(m){throw new A("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 dM({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 lM(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 Zb({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(mM(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..."),iM(c,{...n,targetingResult:{...i,locator:i}})}}async function zp(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 oM.TimeoutError?new A("ActionFailureError",`Download did not complete in ${l}ms`):new A("ActionFailureError",`Download failed: ${c.message}`)}})());try{await Dl({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 lM(n),e?.waitForDownload)if(s){if(!o?.createIsolatedFolder)throw new A("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 U(s,{milliseconds:e.downloadTimeoutMs??3e4});if(l instanceof Error)throw l;return{downloadedFile:await uM(l,o.createIsolatedFolder,t)}}else throw new Error("No download promise or error but the step requested to wait for a download")}async function cM(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 A("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 dM({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 cM(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 pM(n,e,t){let r=await n.evaluate(s=>s.getAttribute("data-momentic-id"));if(!r)return;let o=Nl(r,e,t);if(!o.length){t.error("No candidates found for parent-based locator redirection");return}let i=parseInt(o[0].attributes?.[Ut]??"");if(isNaN(i))return;n=n.page().locator(`[data-momentic-id="${i}"]`);let a=await wn(n,t);return t.warn({candidateMomenticId:i,serializedHtml:a},"Trying new locator based on parent-direction after covering error"),n}async function uM(n,e,t){t.info("Download detected, saving file to disk");let r=await n.path(),o=Dp(n.suggestedFilename()),i=e();await n.saveAs(rM(i,o)),rw(r,{force:!0}),setTimeout(()=>{rw(i,{recursive:!0,force:!0})},5*60*1e3);let a=zb(nM(i),o);return t.debug({uri:a,downloadFolder:i},"Saved download to isolated folder"),a}function mM(n){return n.message.includes("locator.click: Timeout")&&n.message.includes("click action done")}import{platform as hM}from"os";var gM={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 fM(){let n=hM();return n==="win32"?"win32":n==="darwin"?"darwin":"linux"}function ow(n){return JSON.stringify(n.split("+").sort())}function Fl(n){let e=fM(),t=ow(n);for(let r of Object.values(gM))if(Object.values(r).some(o=>ow(o)===t))return r[e];return process.platform==="darwin"?n=n.replaceAll("Control","Meta"):n=n.replaceAll("Meta","Control"),n}async function jp({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 Ge({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()||Jt,u=await Ge({root:e,fn:()=>document.body.scrollHeight,arg:void 0,waitForPageLoad:s.waitForPageLoad,timeout:2e3,codePath:"computing page height"}),[m,h,g]=await Ge({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 U(e.evaluate(()=>document.body.scrollHeight),{milliseconds:1e3}),[w,x,y]=await U(e.evaluate(()=>{let T=document.activeElement;if(!T)return[void 0,void 0,void 0];let C=T.getBoundingClientRect();return[T.scrollTop,C.x,C.y]}),{milliseconds:1e3});if(S===u&&w===m&&x===h&&y===g)break;u=S,m=w,h=x,g=y,await ee(500)}}catch(f){l.warn({err:f},"Failed to wait for scroll to complete, continuing...")}}}async function $p(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 ee(500)}throw new Error(`Failed to get tab titles after all retries: ${r?.message}`)}var bi="<empty>";function SM(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 aw(n){let e=n.adFrameStatus?.adFrameType;return e==="child"||e==="root"||SM(n.url)}async function yM(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 wi({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(aw(p.frame))return null;try{return await sw({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 sw({cdpClient:n,rawFrameTree:e,indices:t,parent:r,warnings:o,logger:i}){let a=e.frame.id,s=await yM(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(aw(h.frame))return null;try{return await sw({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 bM(n){try{return await n.owner().count()===1}catch{return!1}}async function wM(n){try{return await n.count()===1}catch{return!1}}async function Dn(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,bi]){let u=o.frameLocator(p===bi?"iframe":`iframe[${p}]`);if(await bM(u)){d=!0,o=u,i.push(p);break}}if(!d)throw new A("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,bi]){let d=o.locator(c===bi?"iframe":`iframe[${c}]`);if(await wM(d)){a=d,i.push(c);break}}if(!a)throw new A("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 A("InternalWebAgentError",`Failed to load Playwright Frame for iframe with url '${n.url}'`);return await s.dispose(),{frame:l,mPathSelectorTokens:i}}function iw(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 lw({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===bi?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===bi?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 Dn(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=iw(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 Dn(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=iw(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 Dn(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 Dn(r,n)).frame,handle:r,mPathSelectorTokens:t.mPathSelectorTokens,frameTree:e},logs:i};throw i.push(`Found ${a.length} frames with indices ${t.indices}`),new An("Failed to find the iframe that previously contained this element",[{type:"AUTO_FRAME",matched:!1,logs:i}])}function Ul(n){return n.type==="auto"?JSON.stringify({type:"auto",frameId:n.handle.frameId}):JSON.stringify(n)}function Gp(n){for(;n.parent.type==="frame";)n=n.parent;return n.parent}function cw(n){let e=Gp(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 dw(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 pw({frame:n,logger:e,signal:t}){let r;try{r=await n.frameElement(),await vM({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 vM({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 Kr({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 uw({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 U(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 Fn}from"crypto";import xM from"js-beautify";var EM=["Dead"],Bl=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:Fn(),type:"PRESET_ACTION",command:zn(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=zn(i);a={id:Fn(),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=zn(i);a={id:Fn(),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=zn(i);a={id:Fn(),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=xM.html(p,{indent_size:1,indent_with_tabs:!1,preserve_newlines:!1}),p=yb(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(EM.includes(t)||this.signal.aborted)return;let o="normal";t.length>1&&(o="special");let i;if(o==="normal"){let p=zn("TYPE");i={id:Fn(),type:"PRESET_ACTION",command:{...p,target:void 0,value:t,clearContent:!1}}}else{let p=zn("PRESS");i={id:Fn(),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:Fn(),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:Fn(),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=zn(c);d.deltaY=Math.abs(i);let p={id:Fn(),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=zn(c);d.deltaX=Math.abs(i);let p={id:Fn(),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 zl=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=Gp(e),{frame:o,mPathSelectorTokens:i}=await Dn(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 wi({cdpClient:this.cdpClient,page:t,logger:this.logger}),{resolution:o,logs:i}=await lw({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(Ul(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:Ul(this.frameConfig),cacheTime:Date.now(),frameTree:this.frameConfig.frameTree,mPathSelectorTokens:this.frameConfig.mPathSelectorTokens},await pw({frame:r.frame,logger:e,signal:t}),this.activeFrameCache=r,r}async executeFunctionInAllFrames(e,t){let r=this.pageGetter(),o=await wi({cdpClient:this.cdpClient,page:r,logger:this.logger}),i=[U(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(Dn(l,r).then(({frame:d})=>U(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 wi({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 ln({fn:()=>this.resolveActiveFrameConfig({logger:r,signal:o}),codePath:"getActiveFrameDetails",logObject:t,signal:o,logger:r})??void 0,!a)throw new A("ActionFailureError","Got null frame details despite active frame config");s=a.handle,l=s.frameId}else this.flagStore.isBooleanFlagEnabled("auto_expand_iframes")?(s=await ln({fn:()=>wi({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 ln({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 ln({fn:()=>this.getDOMTree({devicePixelRatio:e.devicePixelRatio??1,signal:o,logger:r}),codePath:"domFetch",logObject:t,signal:o,logger:r}),d=await ln({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 ln({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:Hr,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=Cb({node:o,domGraph:this.domGraph});return Rb(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 Ab(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(`[${Ut}="${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 wi({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 A&&c.reason==="UserInfrastructureError")throw c;l%3===0&&this.logger.debug({attempt:l,err:c},"Failed to resolve active frame, retrying..."),await ee(500,t)}finally{l++}if(a)return{source:"url",frame:a.frame,handle:a.handle,frameIdentifierStringified:Ul(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 Dn(s,o)});break}}else if(r.trim()===p.trim()){a.push({handle:s,matchType:"url",...await Dn(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 A("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 Db({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 Dn(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 Ge({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 ln({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 ln({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 ln({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 ln({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 ln({fn:()=>this.cdpClient.send({method:"Accessibility.queryAXTree",params:{backendNodeId:a},timeout:t,timeoutMsg:`Fetching the document tree took over ${t}ms. This usually indicates that the current page is too large to be loaded at once, or your machine is severely resource constrained.`}),codePath:"cdp-query-ax-tree",logObject:r,signal:this.abortSignalGetter(),logger:this.logger})).nodes}if(!o||o.length<=1)throw new Error("Document is entirely empty");return{root:o[0],allNodes:o}}async getDOMTree({devicePixelRatio:e,signal:t,logger:r}){let o,i=0;for(;!o&&i<3;)try{if(o=await this.cdpClient.send({method:"DOMSnapshot.captureSnapshot",params:{computedStyles:Ml},timeout:3e3}),!o||!o.documents.length)throw new Error("Got empty DOM tree")}catch(a){await ee(500,t),r.debug({err:a},"Error fetching DOM tree"),i++}if(!o||!o.documents.length)throw new A("InternalWebAgentError","Got empty DOM snapshot with no documents");return Tb({snapshot:o,devicePixelRatio:e,logger:r})}constructIframeRegexAsync(e,t){if(t.frameSrcRegex||t.frameUrlRegex)return;let r=cw(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 Wp(n){let e=[],t="";for(let r of n)r==="+"&&t?(e.push(t),t=""):t+=r;return e.push(t),e}function mw(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 qp=vi(Yp(),"momentic","chromium"),GM=vi(Yp(),"video"),$l=process.env.TWO_CAPTCHA_KEY,Kp=HM(bw);Kp.use(jM({provider:{id:"2captcha",token:$l},visualFeedback:!0}));var Un=class n{static USER_AGENT=zM["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(Qg(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||Jt,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:pb.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("**/*",mw(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"&&DM()==="darwin"&&PM("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 _l.init({logger:this.logger,contextGetter:()=>this.context,pageGetter:()=>this.page,defaultTimeoutMs:this.pageLoadTimeout}),await this.initializeScreencast(),this.stateManager=new zl({smartWaitingTimeoutMs:this.smartWaitingTimeout,pageLoadTimeoutMs:this.pageLoadTimeout,allowPartialAccessibilityTree:this.userControlledBrowserSettings.allowPartialAccessibilityTree??!1,logger:this.logger,cdpClient:this.cdpClient,pageGetter:()=>this.page,flagStore:this.flagStore,abortSignalGetter:()=>this.abortSignal,enricher:this.enricher,showZeroOpacityElements:this.userControlledBrowserSettings.showZeroOpacityElements??!1,iconKnowledgeBase:this.iconKnowledgeBase}),this.contextInitialized=!0}async fixViewportForNewHeadless(){this.properties.isNewHeadless&&await this.cdpClient.send({method:"Emulation.setDeviceMetricsOverride",params:{width:this.viewport.width,height:this.viewport.height,deviceScaleFactor:0,mobile:this.viewport.width<1e3}})}async initializeScreencast(){await this.fixViewportForNewHeadless(),this.clientCallbacks?.onScreencastFrame&&(await this.cdpClient.send({method:"Page.startScreencast",params:{format:"jpeg",quality:75,maxWidth:this.viewport.width,maxHeight:this.viewport.height}}),this.cdpClient.on("Page.screencastFrame",e=>{let t=e.sessionId,r=Buffer.from(e.data,"base64");this.lastScreenshotForRecording=r,this.clientCallbacks?.onScreencastFrame?.(r,()=>{(async()=>{try{await this.cdpClient.send({method:"Page.screencastFrameAck",params:{sessionId:t}})}catch{}})()})}))}static async init({baseUrl:e,logger:t,storage:r,flagStore:o,enricher:i,mockedServices:a,userBrowserSettings:s,contextArgs:l,browserbaseConnectUrl:c,recordVideo:d,iconKnowledgeBase:p,callbacks:u}){process.env.PW_TEST_SCREENSHOT_NO_FONTS_READY="1";let m;switch(s.browserType){case"Google Chrome":m="chrome";break;case"Chrome for Testing":m=void 0;break;case"Chromium":m="chromium";break;default:m="chromium";break}let h={headless:process.env.MOMENTIC_HEADFUL_BROWSER!=="true",handleSIGTERM:!1,chromiumSandbox:!1,channel:m},g={...l??{},geolocation:l?.geolocation||Uo,locale:l?.locale||Do,timezoneId:l?.timezoneId||Fo,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??Jt},f=["--disable-dev-shm-usage","--no-first-run","--renderer-process-limit=3","--browser-test","--disable-site-isolation-for-policy","--disable-site-isolation-trials","--disable-backgrounding-occluded-windows","--disable-background-timer-throttling","--disable-renderer-backgrounding","--autoplay-policy=user-gesture-required","--disable-add-to-shelf","--disable-desktop-notifications","--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"],S=null,w,x,y={systemDevicePixelRatio:l?.deviceScaleFactor,recordVideo:d,isNewHeadless:!1};(s.browserType==="Chromium"||s.browserType==="Google Chrome")&&(y.isNewHeadless=!0,h.headless&&f.push("--headless=new")),process.env.BROWSER_MEMORY_MB&&f.push(`--js-flags=--max_old_space_size=${process.env.BROWSER_MEMORY_MB}`),s.disableGpu&&f.push("--disable-3d-apis","--disable-gpu","--disable-software-rasterizer","--disable-accelerated-2d-canvas","--disable-accelerated-mjpeg-decode","--disable-accelerated-video-decode","--disable-accelerated-video-encode","--disable-gl-drawing-for-tests","--disable-webgl","--disable-audio-input","--disable-audio-output");let T=s.localChromeExtensionPaths?.map(R=>R.startsWith("~")?vi(Yp(),R.slice(1)):R);if(T?.length){if(s.browserType==="Chrome for Testing")throw new A("UserConfigurationError","Chrome extensions are only supported on Chromium and Google Chrome.");for(let H of T){let z=vi(H,"manifest.json");if(!jl(z))throw new A("UserConfigurationError",`Chrome extension path ${z} does not exist.`)}let R=vi(qp,`momentic-session-${Date.now()}`);if(!jl(R))try{LM(R,{recursive:!0})}catch(H){throw new A("UserConfigurationError",`Failed to create browser cache directory. Please make sure you have sufficient permissions to create the ${qp} folder: ${H}`)}let L=[...f],N=T.map(H=>BM(H)).join(",");L.push(`--disable-extensions-except=${N}`),g?.deviceScaleFactor&&L.push(`--force-device-scale-factor=${g.deviceScaleFactor}`,`--device-scale-factor=${g.deviceScaleFactor}`),g.viewport&&L.push(`--window-size=${g.viewport.width},${g.viewport.height}`),w=await bw.launchPersistentContext(vi(qp,`momentic-session-${Date.now()}`),{...h,...g,ignoreDefaultArgs:["--disable-extensions","--disable-component-extensions-with-background-pages"],args:L,baseURL:e}),t.debug({sharedContextOptions:g,sharedBrowserOptions:h,userBrowserSettings:s,chromeArgs:L,flags:o.getAllFlags()},"Browser initialization context args (persistent)"),x=w.pages()[0]}else if(c){S=await Kp.connectOverCDP(c);let R=S.contexts()[0];if(!R)throw new Error("Failed to get browserbase default context");let L=R.pages()[0];if(!L)throw new Error("Failed to get browserbase default page");w=R,x=L}else{S=await Kp.launch({...h,args:f});let R={...g,baseURL:e,recordVideo:d?{dir:GM}:void 0};w=await S.newContext(R),t.debug({contextArgs:R,sharedBrowserOptions:h,chromeArgs:f,userBrowserSettings:s,flags:o.getAllFlags()},"Browser initialization context args (standard)"),x=await w.newPage()}let C=new n({browser:S,context:w,page:x,baseUrl:e,logger:t,storage:r,flagStore:o,mockedServices:a||{},enricher:i,userBrowserSettings:s,viewport:g.viewport||Jt,properties:y,clientCallbacks:u,iconKnowledgeBase:p});return await C.initialize(),C}async handleAvailableTabsChangeHelper(){try{let e=await $p(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=fw(),o=`${e}-${r}`,i=Date.now(),a=!1,s=async()=>{try{await U(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()||!Yr(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=fw(),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=>{Gb(e,o,this.debugData,a,this.logger)}),e.on("request",a=>{Jb(t,this.debugData,a,this.logger),this.recordRequest(a)});let i=async()=>{await Yb(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=Ib({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:_M()};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"||!Yr(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 U(Bp(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 Ge({fn:()=>{let l=window;return!!(l.generateCssSelectors&&l.evaluateCssSelectors&&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 ee(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),Ge({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 ee(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 Sw.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&&MM(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 Sw.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}){eS(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 ee(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 A("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(bb.has(s))throw new A("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 Ge({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 tw({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 ee(250),this.abortSignal?.throwIfAborted(),i=await this.getActiveElement(o);i||this.logger.warn("No active element found to type into, attempting anyways")}t.clearContent&&(t.forceClearContent||i?.tag==="input"||i?.tag==="textarea"?(process.platform==="darwin"?await this.page.keyboard.press("Meta+A"):await this.page.keyboard.press("Control+A"),await this.page.keyboard.press("Backspace"),await this.page.waitForTimeout(25)):this.logger.warn({activeElementDetails:i},"Currently active element is not eligible for replace content, skipping...")),await this.page.keyboard.type(e,{delay:t.delay??cm}),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 Dl({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 $b(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 jb(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 Hb(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 A("ActionFailureError",`Failed to save auth state: ${r?.message}`)}async getOpenPages(e){return $p(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 $n)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(!Tp.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 resolveTargetWithHybridSelector({root:e,target:t}){if(!t.hybridSelector||!t.nodeOnlySerializedHtml)throw new zr("Insufficient data to resolve target using hybrid selector");return await Ge({fn:r=>window.evaluateHybridSelector(r),arg:{nodes:t.hybridSelector,cachedElementSerialized:t.nodeOnlySerializedHtml,opts:{ldistThreshold:.05,requireBoundingBox:!0,ignoreHrefForCaching:this.userControlledBrowserSettings.ignoreHrefForCaching,requireMatchingBoundingBox:this.userControlledBrowserSettings.bustCacheOnBoundingBoxChange?t.boundingBox:void 0}},root:e,timeout:2e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"evaluating Momentic cache"})}async resolveTargetWithCssSelectors({root:e,target:t}){if(!t.generatedSelectors||t.generatedSelectors.length<2||!t.nodeOnlySerializedHtml)throw new zr("Insufficient data to resolve target using CSS selectors");return Ge({fn:r=>window.evaluateCssSelectors(r),arg:{selectors:t.generatedSelectors,cachedElementSerialized:t.nodeOnlySerializedHtml,opts:{ldistThreshold:.05,requireBoundingBox:!0,ignoreHrefForCaching:this.userControlledBrowserSettings.ignoreHrefForCaching,requireMatchingBoundingBox:this.userControlledBrowserSettings.bustCacheOnBoundingBoxChange?t.boundingBox:void 0}},root:e,timeout:2e3,waitForPageLoad:()=>this.waitForPageLoad(),codePath:"evaluateCssSelectors"})}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 A("InternalWebAgentError","Only positive IDs should be passed to resolveAllyIdToTarget");let a=this.stateManager.a11yIdToNodeMap[e];if(!a)throw new A("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:dw(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 ee(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:Hr,signal:a});break}catch(m){if(m instanceof zr)break;if(m instanceof $n){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 ee(500,a)}a?.throwIfAborted(),u&&i.debug({err:m},`Could not resolve target through CSS selectors only (x${c})`),await ee(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 zr("Insufficient data to resolve target using primary methods (missing node HTML)");let o=this.userControlledBrowserSettings.hybridSelectorMode,i=async()=>{if(t.hybridSelector&&o)return this.resolveTargetWithHybridSelector({root:e,target:t,logger:r})},a=async()=>{if(t.generatedSelectors)return this.resolveTargetWithCssSelectors({root:e,target:t,logger:r})},[s,l]=await Promise.allSettled([i(),a()]),c,d=[];if(s.status==="fulfilled"&&o==="prefer"&&s.value?.result){c=s.value;let f={type:"HYBRID_SELECTOR",matched:!0,logs:c.logs,reason:"Discovered a match using Momentic's hybrid text and CSS selector approach"};d.push(f),r.debug({evaluationDecision:f},"Hybrid selector evaluation succeeded")}else if(l.status==="fulfilled")if(l.value?.result){c=l.value;let f=l.value.result;d.push({type:"CSS_SELECTOR",matched:!0,logs:c.logs,reason:`${f.workingSelectors.length} CSS selectors matched the following element: ${f.serializedElement}`,selectors:f.workingSelectors.slice(0,5)})}else throw new An(`CSS selector evaluation returned no eligible elements:
|
|
3845
|
-
${l.value?.logs.join(`
|
|
3846
|
-
`)}`,[]);else throw new An(`CSS selector evaluation encountered an error: ${l.reason}`,[]);let p=c.result,u,m,h,g=!1;if(this.flagStore.isBooleanFlagEnabled("visual_actions")){p.mPath||r.error({foundElement:p},"Found element did not have an mPath despite using visual actions");let S=p.mPath.join(" > ");u=e.locator(S),m=this.stateManager.getNodeUsingMPathSelector(S)}else if(p.dataMomenticId!==void 0)h=parseInt(p.dataMomenticId),m=this.stateManager.dataMomenticIdToNodeMap[h],"workingSelectors"in p?(u=e.locator(p.workingSelectors[0]),g=p.workingSelectors.length<5):u=e.locator(`[data-momentic-id=${JSON.stringify(h)}]`);else throw new A("InternalWebAgentError","Received an element resolution result with no identifying attributes");return o&&t.hybridSelector&&(s.status==="rejected"?r.warn({err:s.reason,cssResult:"value"in l?l.value:void 0,hybridMode:o},"Hybrid selector resolution rejected, continuing..."):s.value?.result?"value"in l&&l.value?.result&&s.value.result.serializedElement!==l.value.result.serializedElement&&(this.flagStore.isBooleanFlagEnabled("visual_actions")&&JSON.stringify(l.value.result.mPath)!==JSON.stringify(s.value.result.mPath)?r.warn({originalCache:t,hybridResult:s.value,cssResult:"value"in l?l.value:void 0,hybridMode:o,mode:"visualActions"},"Hybrid selector resolution returned a different element than CSS selector resolution, continuing..."):l.value.result.dataMomenticId!==s.value.result.dataMomenticId&&r.warn({originalCache:t,hybridResult:s.value,cssResult:"value"in l?l.value:void 0,hybridMode:o,mode:"dataMomenticId"},"Hybrid selector resolution returned a different element than CSS selector resolution, continuing...")):r.warn({originalCache:t,hybridResult:s.value,cssResult:"value"in l?l.value:void 0,hybridMode:o},"Hybrid selector resolution returned no eligible elements while CSS resolution did, continuing...")),await this.updateCacheWithNewNodeDetails({node:m,target:t,locator:u,logger:r,startingBoundingBox:c.result?.boundingBox,forceSaveNewCssSelectors:g}),{a11yNode:m,displayString:p.serializedElement,locator:u,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:kM(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 An(`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 wn(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 A("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 ee(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 Ge({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(`[${Ut}="${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 wn(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&&Tp.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=$M(),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=ew.some(a=>a===o.toLowerCase());return await Hp({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 Hp({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(),Qf(s,t,r)){a=!0;break}await ee(500,this.abortSignal)}if(!a)throw new A("ActionFailureError",`The active page URL ${r?.negated?"still does":"does not"} ${Md(t)} in ${o}ms.
|
|
3847
|
-
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 A("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 ee(r.hoverSeconds?Math.min(r.hoverSeconds*1e3,2e3):500),await this.page.mouse.up()}async mouseDrag(e,t,r,o){o&&await this.hover({locator:o});let i=await(await this.getActivePageOrFrame()).evaluate(Up);i||(this.logger.debug("Could not get current mouse position before mouse drag action, defaulting to 0,0"),i={left:0,top:0}),await this.page.mouse.down(),await this.page.mouse.move(e+i.left,t+i.top,{steps:r}),await ee(250),await this.page.mouse.up()}async hover(e){await this.highlight(e.locator),await ao({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 ao({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 Ge({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 ao({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 ao({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 A("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=Fl(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=Fl(e);r!==e&&(this.logger.debug({keyString:e,convertedKey:r},"Converted platform dependent keys"),e=r)}for(let r of Wp(e))await this.page.keyboard.down(r)}async keyUp(e,t){if(t.convertMeta){let r=Fl(e);r!==e&&(this.logger.debug({keyString:e,convertedKey:r},"Converted platform dependent keys"),e=r)}for(let r of Wp(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 U(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 A("ActionFailureError",`Getting page content failed after ${r} attempts. Error: ${s}`)}async getViewportOffsetDetails(e){let[t,r,o,i,a]=await Ge({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 ee(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.warn(p,"A11y wait phase completed due to timeout, continuing...")}async clickUsingVisualCoordinates(e,t){let{x:r,y:o}=e;this.logger.debug({x:r,y:o},"Executing mouse click with visual coordinates"),await this.waitForPageLoad(),await this.page.mouse.click(r,o,{button:t.rightClick?"right":"left",clickCount:t.doubleClick?2:1})}async dragAndDropUsingVisualCoordinates(e,t,r){await this.page.mouse.move(e.x,e.y,{steps:3}),await this.page.mouse.down(),await this.page.mouse.move(t.x,t.y,{steps:3}),await ee(r.hoverSeconds?Math.min(r.hoverSeconds*1e3,8e3):500),await this.page.mouse.up()}async hoverUsingVisualCoordinates(e){await this.page.mouse.move(e.x,e.y)}async mouseDragUsingVisualCoordinates(e,t,r,o){await this.hoverUsingVisualCoordinates(o);let i=await(await this.getActivePageOrFrame()).evaluate(Up);i||(this.logger.debug("Could not get current mouse position before mouse drag action, defaulting to 0,0"),i={left:0,top:0}),await this.page.mouse.down(),await this.page.mouse.move(e+i.left,t+i.top,{steps:r}),await ee(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 U(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 jp({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 jp({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 U(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 A("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 ee(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 A("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)}.
|
|
3848
|
-
Available pages:${JSON.stringify(r.map(i=>i.url))}`);if(!Yr(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=Ns(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:$l,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 ee(2500);let s=await fetch("https://api.2captcha.com/getTaskResult",{method:"POST",body:JSON.stringify({clientKey:$l,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&&uw({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];Yr(d,this.logger)&&d!==l&&this.logger.info({lastActivePages:r,currentUrl:l,newOpenPages:s},"Auto-following new tab during recording"),await this.switchToPage({type:"INDEX",index:String(c)});break}r=s};t=setInterval(async()=>{if(!i){i=!0;try{await a()}catch(s){this.logger.error({err:s},"Error while checking pages during recording")}finally{i=!1}}},500),e.addEventListener("abort",async()=>{clearInterval(t)})}async startRecording(e,t,r){this.logger.debug({isClickToRecord:r},"Starting recording mode in Chrome browser"),await this.startRecordingCrons(e),await this.page.evaluate(o=>{let i=window;i._MOMENTIC_RECORDING_ACTIVE=!0,i._MOMENTIC_CLICK_RECORD_ACTIVE=o},r),this.transformer=t,await this.injectKnowledgeBaseIntoBrowser(this.page),e.addEventListener("abort",async()=>{this.transformer=void 0,this.lastScreenshotForRecording=void 0;try{await this.page.evaluate(()=>{let o=window;o._MOMENTIC_RECORDING_ACTIVE=!1,o._MOMENTIC_CLICK_RECORD_ACTIVE=!1})}catch{}})}async getSelectOptions(e){return await e.evaluate(r=>Array.from(r.querySelectorAll("option")).map(i=>({value:i.value,label:i.label})),void 0,{timeout:1e3})}getActivePage(){return this.page}async getActivePageOrFrame(){let e=await this.stateManager.resolveActiveFrameConfig({});return e?(await this.loadFrameAndRecordUrl({root:e.frame,signal:this.abortSignal,codePath:"get-active-frame-locator"}),e.frame):this.page}async loadFrameAndRecordUrl({root:e,signal:t,codePath:r}){let o=this.pageLoadTimeout,i=e.url();if(i.includes("chrome-error://")){this.logger.warn({url:i,codePath:r},"Skipping load for chrome-error:// URL");return}try{await Kr({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 A("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 Kr({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 NM.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 Ge({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 A("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 Ge({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=Xb(),a={code:e,fragment:t,context:r},{result:s}=await U(this.page.evaluate(i,a),{milliseconds:o,fallback:()=>{throw this.abortSignal?.throwIfAborted(),new A("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 A("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:Eb,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,t=!0){let r=await this.getActivePageOrFrame(),o=await this.getDomNodeFromPositionPercentages(r,e);return this.getTargetFromBackendNodeId(r,o.backendNodeId,t)}async getTargetFromBackendNodeId(e,t,r){let o=this.stateManager.domGraph?.backendIdToNode[t];if(!o)throw new Error("No DOM node was found with the given backend ID");let i=o?.attributes[Ut],a=parseInt(i??"");if(!i||isNaN(a))throw new Error("No data-momentic-id was found on the DOM node");let s=e.locator(`[${Ut}="${i}"]`);if(r){for(let p of Object.values(this.stateManager.a11yIdToNodeMap)){if(p.backendNodeId!==t)continue;let u={id:p.id,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString()};return await this.updateCacheWithNewNodeDetails({node:p,target:u,locator:s,forceSaveNewCssSelectors:!0}),this.logger.debug({target:u},"Tied backend id to existing a11y node"),{target:u,locator:s}}let d=Nl(`${i}`,this.stateManager.domGraph,this.logger);for(let p of d){let u=parseInt(p.attributes?.[Ut]??"");if(isNaN(u))continue;let m=e.locator(`[${Ut}="${u}"]`),h=this.stateManager.dataMomenticIdToNodeMap[u],g=h?.id;if(!g)continue;let f={id:g,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString()};return await this.updateCacheWithNewNodeDetails({node:h,target:f,locator:m,forceSaveNewCssSelectors:!0}),this.logger.debug({target:f},"Tied backend id on non-accessible element to nearest a11y node"),{target:f,locator:m}}}let l=await this.fetchHtmlAttributes({locator:s,logger:this.logger}),c={id:-1,dataMomenticId:a,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString(),...l};return this.logger.debug({target:c},"Tied backend id to html node"),{target:c,locator:s}}async performTargetRedirection(e,t,r){try{return await this.scrollIntoViewIfNeeded(e),await U(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 wn(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 T=window;if(!T.performTargetRedirection)throw new Error("performTargetRedirection script is not defined");return T.performTargetRedirection(y)},void 0,{timeout:1e3}),x=Date.now()-o;if(h){t.warn({error:h,serializedElement:g,duration:x,force:S,logs:w},"Got error from target redirection with bounding box");return}else{if(u)return t.debug({newDataMomenticId:u,serializedElement:g,duration:x,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:x,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:x,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:x,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(vp)?new $n(o.error.slice(vp.length)):new Error(o.error);return o.warnings.length?t.warn(o,"Got warnings while generating HTML attributes for target"):t.debug(o,"Generated 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!!$l}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,Fp(e,this.debugData,i,{type:t,text:`[MOMENTIC] ${r}`,args:o})}async setFileChooserHandlerHelper({filePath:e,filename:t}){if(!jl(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()||FM(e),o=OM(e),i=UM(e),a=yd[i];this.page.once("filechooser",async l=>{this.logger.info({filePath:e,fileName:r},"File chooser triggered");try{if(!jl(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:fb.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 lN}from"lodash-es";import{CookieJar as cN}from"tough-cookie";import{z as Bt}from"zod";var Voe=Bt.object({doubleClick:Bt.boolean().optional(),rightClick:Bt.boolean().optional(),force:Bt.boolean().optional(),waitForDownload:Bt.boolean().optional(),delayMs:Bt.number().optional(),downloadTimeoutMs:Bt.number().optional(),relativePosition:Bt.object({x:Bt.number(),y:Bt.number()}).optional()}),qoe=Bt.object({repeat:Bt.number().optional(),convertMeta:Bt.boolean().optional().describe("misleading name due to backcompat. converts keyshortcuts + meta/control to platform-specific combos. defaults to true"),delayMs:Bt.number().optional()});async function Er(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 xi=3.1783027;function WM(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 za(n){return Math.ceil(Jp(n)/xi)}function Jp(n){let e=0;if(typeof n=="string"){let t=n;t=t.replaceAll(`
|
|
3849
|
-
`,""),t=t.replaceAll(" ","");let r=WM(t);return t.length-r+xi*r}if(typeof n>"u")return 0;if(typeof n=="number")return String(n).length;if(Array.isArray(n))return n.forEach(t=>{e+=Jp(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*xi:e+=85*xi:e+=Jp(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 vw={minChunkTokenCount:500,acceptableChunkTokenCount:3e3,maxChunkTokenCount:8e3,maxLineLength:4e3},xw={minChunkTokenCount:5e3,acceptableChunkTokenCount:1e4,maxChunkTokenCount:15e3,maxLineLength:500},ww=/<(\S+) id="(\d+)".*?>/g,VM=/(<\/(\S+)>)|(<(\S+).*?\/>)/g,Ew=["h1","h2","section","footer","nav","aside","form","label","dialog"],qM=[...Ew,"span","div","h3"],KM=["table","select","form","ul","ol","menu","pre","code","dialog"],YM=["table","form","dialog","nav","section","ul","select"];function Xp(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)),JM(n)}function JM({serializedTree:n,options:e,logger:t}){let{minChunkTokenCount:r,acceptableChunkTokenCount:o,maxChunkTokenCount:i,maxLineLength:a}=e,s=[],l=n.split(`
|
|
3898
|
+
${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 A("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 A("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 eN(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 A("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 Xb(n){try{return await tN(n)}catch(e){n.logger.warn({err:e},"Failed to transform locator for Chakra click, continuing...");return}}async function tN({locator:n,logger:e}){let[t,r]=await n.evaluate(l=>[l.id,l.tagName.toLowerCase()],{timeout:1e3}),o=await wn(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?`[data-momentic-id=${JSON.stringify(l.getAttribute("data-momentic-id"))}]`:c.getMPath?.(l)?.join(" >");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 Qb=["date","datetime-local","month","time","week"],Zb={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 ew(n){try{await U(nN(n),{milliseconds:3e3})}catch(e){n.logger.warn({err:e},"Failed to transform native datetime input, continuing...")}}async function nN({root:n,text:e,options:t,logger:r,callbacks:o}){let i=(await qe({root:n,fn:()=>document.activeElement?.getAttribute("type")??"",timeout:1e3,arg:void 0,waitForPageLoad:o.waitForPageLoad,codePath:"transforming native datetime input"})).toLowerCase();if(!Zb[i])return;Zb[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 Dl({locator:n,callbacks:e,logger:t,timeoutMs:r=1e3}){try{await Bp(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 U(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 Bp(n,e=1e3){let t=await n.state.getRoot();await qe({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 Hp(n){let e=n.flagStore.isBooleanFlagEnabled("visual_actions");return io({action:"clicking element",targetingResult:n.targetingResult,logger:n.logger,retryTimeoutMs:n.retryTimeoutMs,callbacks:n.browserCallbacks,func:async t=>zp({...n,targetingResult:t,useVisualClick:e})})}async function aN(n,e){let{redirectionAttempts:t=0}=e;if(t>=2)throw n;try{return await sN(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 sN(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"),zp({...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 uN(a,s,t);if(l)return zp({...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 lN(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 qr({promiseGenerator:async()=>s.boundingBox(),timeoutMs:3e3,logger:t}):null}catch(m){throw new A("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 pN({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 cN(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 Xb({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(hN(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..."),aN(c,{...n,targetingResult:{...i,locator:i}})}}async function zp(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 iN.TimeoutError?new A("ActionFailureError",`Download did not complete in ${l}ms`):new A("ActionFailureError",`Download failed: ${c.message}`)}})());try{await Dl({locator:a.locator,callbacks:r,logger:t,timeoutMs:1e3})}catch(l){t.warn({err:l},"Error highlighting locator in click, continuing...")}if(i?await lN(n):await cN(n),e?.waitForDownload)if(s){if(!o?.createIsolatedFolder)throw new A("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 U(s,{milliseconds:e.downloadTimeoutMs??3e4});if(l instanceof Error)throw l;return{downloadedFile:await mN(l,o.createIsolatedFolder,t)}}else throw new Error("No download promise or error but the step requested to wait for a download")}async function dN(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 A("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 pN({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 dN(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 uN(n,e,t){let r=await n.evaluate(s=>s.getAttribute("data-momentic-id"));if(!r)return;let o=Ml(r,e,t);if(!o.length){t.error("No candidates found for parent-based locator redirection");return}let i=parseInt(o[0].attributes?.[Ut]??"");if(isNaN(i))return;n=n.page().locator(`[data-momentic-id="${i}"]`);let a=await wn(n,t);return t.warn({candidateMomenticId:i,serializedHtml:a},"Trying new locator based on parent-direction after covering error"),n}async function mN(n,e,t){t.info("Download detected, saving file to disk");let r=await n.path(),o=Dp(n.suggestedFilename()),i=e();await n.saveAs(oN(i,o)),nw(r,{force:!0}),setTimeout(()=>{nw(i,{recursive:!0,force:!0})},5*60*1e3);let a=Bb(rN(i),o);return t.debug({uri:a,downloadFolder:i},"Saved download to isolated folder"),a}function hN(n){return n.message.includes("locator.click: Timeout")&&n.message.includes("click action done")}import{platform as gN}from"os";var fN={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 SN(){let n=gN();return n==="win32"?"win32":n==="darwin"?"darwin":"linux"}function rw(n){return JSON.stringify(n.split("+").sort())}function Fl(n){let e=SN(),t=rw(n);for(let r of Object.values(fN))if(Object.values(r).some(o=>rw(o)===t))return r[e];return process.platform==="darwin"?n=n.replaceAll("Control","Meta"):n=n.replaceAll("Meta","Control"),n}async function jp({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 qe({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()||Jt,u=await qe({root:e,fn:()=>document.body.scrollHeight,arg:void 0,waitForPageLoad:s.waitForPageLoad,timeout:2e3,codePath:"computing page height"}),[m,h,g]=await qe({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 U(e.evaluate(()=>document.body.scrollHeight),{milliseconds:1e3}),[w,E,y]=await U(e.evaluate(()=>{let T=document.activeElement;if(!T)return[void 0,void 0,void 0];let C=T.getBoundingClientRect();return[T.scrollTop,C.x,C.y]}),{milliseconds:1e3});if(S===u&&w===m&&E===h&&y===g)break;u=S,m=w,h=E,g=y,await ee(500)}}catch(f){l.warn({err:f},"Failed to wait for scroll to complete, continuing...")}}}async function $p(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 ee(500)}throw new Error(`Failed to get tab titles after all retries: ${r?.message}`)}var yi="<empty>";function yN(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 iw(n){let e=n.adFrameStatus?.adFrameType;return e==="child"||e==="root"||yN(n.url)}async function bN(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 bi({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(iw(p.frame))return null;try{return await aw({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 aw({cdpClient:n,rawFrameTree:e,indices:t,parent:r,warnings:o,logger:i}){let a=e.frame.id,s=await bN(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(iw(h.frame))return null;try{return await aw({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 wN(n){try{return await n.owner().count()===1}catch{return!1}}async function vN(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,yi]){let u=o.frameLocator(p===yi?"iframe":`iframe[${p}]`);if(await wN(u)){d=!0,o=u,i.push(p);break}}if(!d)throw new A("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,yi]){let d=o.locator(c===yi?"iframe":`iframe[${c}]`);if(await vN(d)){a=d,i.push(c);break}}if(!a)throw new A("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 A("InternalWebAgentError",`Failed to load Playwright Frame for iframe with url '${n.url}'`);return await s.dispose(),{frame:l,mPathSelectorTokens:i}}function ow(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 sw({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===yi?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===yi?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=ow(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=ow(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 Ul(n){return n.type==="auto"?JSON.stringify({type:"auto",frameId:n.handle.frameId}):JSON.stringify(n)}function Gp(n){for(;n.parent.type==="frame";)n=n.parent;return n.parent}function lw(n){let e=Gp(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 cw(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 dw({frame:n,logger:e,signal:t}){let r;try{r=await n.frameElement(),await EN({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 EN({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 qr({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 pw({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 U(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 Dn}from"crypto";import xN from"js-beautify";var TN=["Dead"],Bl=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=xN.html(p,{indent_size:1,indent_with_tabs:!1,preserve_newlines:!1}),p=Sb(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(TN.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 zl=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=Gp(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 bi({cdpClient:this.cdpClient,page:t,logger:this.logger}),{resolution:o,logs:i}=await sw({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(Ul(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:Ul(this.frameConfig),cacheTime:Date.now(),frameTree:this.frameConfig.frameTree,mPathSelectorTokens:this.frameConfig.mPathSelectorTokens},await dw({frame:r.frame,logger:e,signal:t}),this.activeFrameCache=r,r}async executeFunctionInAllFrames(e,t){let r=this.pageGetter(),o=await bi({cdpClient:this.cdpClient,page:r,logger:this.logger}),i=[U(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})=>U(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 bi({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 ln({fn:()=>this.resolveActiveFrameConfig({logger:r,signal:o}),codePath:"getActiveFrameDetails",logObject:t,signal:o,logger:r})??void 0,!a)throw new A("ActionFailureError","Got null frame details despite active frame config");s=a.handle,l=s.frameId}else this.flagStore.isBooleanFlagEnabled("auto_expand_iframes")?(s=await ln({fn:()=>bi({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 ln({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 ln({fn:()=>this.getDOMTree({devicePixelRatio:e.devicePixelRatio??1,signal:o,logger:r}),codePath:"domFetch",logObject:t,signal:o,logger:r}),d=await ln({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 ln({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:zr,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=Tb({node:o,domGraph:this.domGraph});return Cb(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 Rb(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(`[${Ut}="${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 bi({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 A&&c.reason==="UserInfrastructureError")throw c;l%3===0&&this.logger.debug({attempt:l,err:c},"Failed to resolve active frame, retrying..."),await ee(500,t)}finally{l++}if(a)return{source:"url",frame:a.frame,handle:a.handle,frameIdentifierStringified:Ul(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 A("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 _b({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 _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 qe({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 ln({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 ln({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 ln({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 ln({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 ln({fn:()=>this.cdpClient.send({method:"Accessibility.queryAXTree",params:{backendNodeId:a},timeout:t,timeoutMsg:`Fetching the document tree took over ${t}ms. This usually indicates that the current page is too large to be loaded at once, or your machine is severely resource constrained.`}),codePath:"cdp-query-ax-tree",logObject:r,signal:this.abortSignalGetter(),logger:this.logger})).nodes}if(!o||o.length<=1)throw new Error("Document is entirely empty");return{root:o[0],allNodes:o}}async getDOMTree({devicePixelRatio:e,signal:t,logger:r}){let o,i=0;for(;!o&&i<3;)try{if(o=await this.cdpClient.send({method:"DOMSnapshot.captureSnapshot",params:{computedStyles:Nl},timeout:3e3}),!o||!o.documents.length)throw new Error("Got empty DOM tree")}catch(a){await ee(500,t),r.debug({err:a},"Error fetching DOM tree"),i++}if(!o||!o.documents.length)throw new A("InternalWebAgentError","Got empty DOM snapshot with no documents");return xb({snapshot:o,devicePixelRatio:e,logger:r})}constructIframeRegexAsync(e,t){if(t.frameSrcRegex||t.frameUrlRegex)return;let r=lw(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 Wp(n){let e=[],t="";for(let r of n)r==="+"&&t?(e.push(t),t=""):t+=r;return e.push(t),e}function uw(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 Vp=wi(Kp(),"momentic","chromium"),WN=wi(Kp(),"video"),$l=process.env.TWO_CAPTCHA_KEY,qp=jN(ww);qp.use($N({provider:{id:"2captcha",token:$l},visualFeedback:!0}));var Fn=class n{static USER_AGENT=HN["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(Zg(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||Jt,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:db.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("**/*",uw(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"&&FN()==="darwin"&&LN("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 _l.init({logger:this.logger,contextGetter:()=>this.context,pageGetter:()=>this.page,defaultTimeoutMs:this.pageLoadTimeout}),await this.initializeScreencast(),this.stateManager=new zl({smartWaitingTimeoutMs:this.smartWaitingTimeout,pageLoadTimeoutMs:this.pageLoadTimeout,allowPartialAccessibilityTree:this.userControlledBrowserSettings.allowPartialAccessibilityTree??!1,logger:this.logger,cdpClient:this.cdpClient,pageGetter:()=>this.page,flagStore:this.flagStore,abortSignalGetter:()=>this.abortSignal,enricher:this.enricher,showZeroOpacityElements:this.userControlledBrowserSettings.showZeroOpacityElements??!1,iconKnowledgeBase:this.iconKnowledgeBase}),this.contextInitialized=!0}async fixViewportForNewHeadless(){this.properties.isNewHeadless&&await this.cdpClient.send({method:"Emulation.setDeviceMetricsOverride",params:{width:this.viewport.width,height:this.viewport.height,deviceScaleFactor:0,mobile:this.viewport.width<1e3}})}async initializeScreencast(){await this.fixViewportForNewHeadless(),this.clientCallbacks?.onScreencastFrame&&(await this.cdpClient.send({method:"Page.startScreencast",params:{format:"jpeg",quality:75,maxWidth:this.viewport.width,maxHeight:this.viewport.height}}),this.cdpClient.on("Page.screencastFrame",e=>{let t=e.sessionId,r=Buffer.from(e.data,"base64");this.lastScreenshotForRecording=r,this.clientCallbacks?.onScreencastFrame?.(r,()=>{(async()=>{try{await this.cdpClient.send({method:"Page.screencastFrameAck",params:{sessionId:t}})}catch{}})()})}))}static async init({baseUrl:e,logger:t,storage:r,flagStore:o,enricher:i,mockedServices:a,userBrowserSettings:s,contextArgs:l,browserbaseConnectUrl:c,recordVideo:d,iconKnowledgeBase:p,callbacks:u}){process.env.PW_TEST_SCREENSHOT_NO_FONTS_READY="1";let m;switch(s.browserType){case"Google Chrome":m="chrome";break;case"Chrome for Testing":m=void 0;break;case"Chromium":m="chromium";break;default:m="chromium";break}let h={headless:process.env.MOMENTIC_HEADFUL_BROWSER!=="true",handleSIGTERM:!1,chromiumSandbox:!1,channel:m},g={...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??Jt},f=["--disable-dev-shm-usage","--no-first-run","--renderer-process-limit=3","--browser-test","--disable-site-isolation-for-policy","--disable-site-isolation-trials","--disable-backgrounding-occluded-windows","--disable-background-timer-throttling","--disable-renderer-backgrounding","--autoplay-policy=user-gesture-required","--disable-add-to-shelf","--disable-desktop-notifications","--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"],S=null,w,E,y={systemDevicePixelRatio:l?.deviceScaleFactor,recordVideo:d,isNewHeadless:!1};(s.browserType==="Chromium"||s.browserType==="Google Chrome")&&(y.isNewHeadless=!0,h.headless&&f.push("--headless=new")),process.env.BROWSER_MEMORY_MB&&f.push(`--js-flags=--max_old_space_size=${process.env.BROWSER_MEMORY_MB}`),s.disableGpu&&f.push("--disable-3d-apis","--disable-gpu","--disable-software-rasterizer","--disable-accelerated-2d-canvas","--disable-accelerated-mjpeg-decode","--disable-accelerated-video-decode","--disable-accelerated-video-encode","--disable-gl-drawing-for-tests","--disable-webgl","--disable-audio-input","--disable-audio-output");let T=s.localChromeExtensionPaths?.map(R=>R.startsWith("~")?wi(Kp(),R.slice(1)):R);if(T?.length){if(s.browserType==="Chrome for Testing")throw new A("UserConfigurationError","Chrome extensions are only supported on Chromium and Google Chrome.");for(let H of T){let z=wi(H,"manifest.json");if(!jl(z))throw new A("UserConfigurationError",`Chrome extension path ${z} does not exist.`)}let R=wi(Vp,`momentic-session-${Date.now()}`);if(!jl(R))try{NN(R,{recursive:!0})}catch(H){throw new A("UserConfigurationError",`Failed to create browser cache directory. Please make sure you have sufficient permissions to create the ${Vp} folder: ${H}`)}let L=[...f],M=T.map(H=>zN(H)).join(",");L.push(`--disable-extensions-except=${M}`),g?.deviceScaleFactor&&L.push(`--force-device-scale-factor=${g.deviceScaleFactor}`,`--device-scale-factor=${g.deviceScaleFactor}`),g.viewport&&L.push(`--window-size=${g.viewport.width},${g.viewport.height}`),w=await ww.launchPersistentContext(wi(Vp,`momentic-session-${Date.now()}`),{...h,...g,ignoreDefaultArgs:["--disable-extensions","--disable-component-extensions-with-background-pages"],args:L,baseURL:e}),t.debug({sharedContextOptions:g,sharedBrowserOptions:h,userBrowserSettings:s,chromeArgs:L,flags:o.getAllFlags()},"Browser initialization context args (persistent)"),E=w.pages()[0]}else if(c){S=await qp.connectOverCDP(c);let R=S.contexts()[0];if(!R)throw new Error("Failed to get browserbase default context");let L=R.pages()[0];if(!L)throw new Error("Failed to get browserbase default page");w=R,E=L}else{S=await qp.launch({...h,args:f});let R={...g,baseURL:e,recordVideo:d?{dir:WN}:void 0};w=await S.newContext(R),t.debug({contextArgs:R,sharedBrowserOptions:h,chromeArgs:f,userBrowserSettings:s,flags:o.getAllFlags()},"Browser initialization context args (standard)"),E=await w.newPage()}let C=new n({browser:S,context:w,page:E,baseUrl:e,logger:t,storage:r,flagStore:o,mockedServices:a||{},enricher:i,userBrowserSettings:s,viewport:g.viewport||Jt,properties:y,clientCallbacks:u,iconKnowledgeBase:p});return await C.initialize(),C}async handleAvailableTabsChangeHelper(){try{let e=await $p(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=fw(),o=`${e}-${r}`,i=Date.now(),a=!1,s=async()=>{try{await U(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()||!Kr(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=fw(),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=>{$b(e,o,this.debugData,a,this.logger)}),e.on("request",a=>{Yb(t,this.debugData,a,this.logger),this.recordRequest(a)});let i=async()=>{await Kb(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=Ab({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:DN()};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"||!Kr(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 U(Bp(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 qe({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 ee(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),qe({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 ee(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 Sw.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&&kN(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 Sw.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}){Qf(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 ee(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 A("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(yb.has(s))throw new A("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 qe({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 ew({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 ee(250),this.abortSignal?.throwIfAborted(),i=await this.getActiveElement(o);i||this.logger.warn("No active element found to type into, attempting anyways")}t.clearContent&&(t.forceClearContent||i?.tag==="input"||i?.tag==="textarea"?(process.platform==="darwin"?await this.page.keyboard.press("Meta+A"):await this.page.keyboard.press("Control+A"),await this.page.keyboard.press("Backspace"),await this.page.waitForTimeout(25)):this.logger.warn({activeElementDetails:i},"Currently active element is not eligible for replace content, skipping...")),await this.page.keyboard.type(e,{delay:t.delay??lm}),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 Dl({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 jb(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 Hb(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 zb(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 A("ActionFailureError",`Failed to save auth state: ${r?.message}`)}async getOpenPages(e){return $p(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 $n)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(!Tp.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 A("InternalWebAgentError","Only positive IDs should be passed to resolveAllyIdToTarget");let a=this.stateManager.a11yIdToNodeMap[e];if(!a)throw new A("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:cw(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 ee(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:zr,signal:a});break}catch(m){if(m instanceof sa)break;if(m instanceof $n){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 ee(500,a)}a?.throwIfAborted(),u&&i.debug({err:m},`Could not resolve target through CSS selectors only (x${c})`),await ee(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 sa("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 qe({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 jn("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 A("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=yw(t);return await this.updateCacheWithNewNodeDetails({node:u,target:t,locator:p,logger:r,startingBoundingBox:c.boundingBox,forceSaveNewCssSelectors:h}),r.info({diffs:ON(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:yw(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 jn(`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 wn(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 A("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 ee(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 qe({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(`[${Ut}="${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 wn(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&&Tp.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=GN(),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=Qb.some(a=>a===o.toLowerCase());return await Hp({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 Hp({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(),Zf(s,t,r)){a=!0;break}await ee(500,this.abortSignal)}if(!a)throw new A("ActionFailureError",`The active page URL ${r?.negated?"still does":"does not"} ${Nd(t)} in ${o}ms.
|
|
3899
|
+
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 A("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 ee(r.hoverSeconds?Math.min(r.hoverSeconds*1e3,2e3):500),await this.page.mouse.up()}async mouseDrag(e,t,r,o){o&&await this.hover({locator:o});let i=await(await this.getActivePageOrFrame()).evaluate(Up);i||(this.logger.debug("Could not get current mouse position before mouse drag action, defaulting to 0,0"),i={left:0,top:0}),await this.page.mouse.down(),await this.page.mouse.move(e+i.left,t+i.top,{steps:r}),await ee(250),await this.page.mouse.up()}async hover(e){await this.highlight(e.locator),await io({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 io({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 qe({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 io({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 io({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 A("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=Fl(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=Fl(e);r!==e&&(this.logger.debug({keyString:e,convertedKey:r},"Converted platform dependent keys"),e=r)}for(let r of Wp(e))await this.page.keyboard.down(r)}async keyUp(e,t){if(t.convertMeta){let r=Fl(e);r!==e&&(this.logger.debug({keyString:e,convertedKey:r},"Converted platform dependent keys"),e=r)}for(let r of Wp(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 U(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 A("ActionFailureError",`Getting page content failed after ${r} attempts. Error: ${s}`)}async getViewportOffsetDetails(e){let[t,r,o,i,a]=await qe({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 ee(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.warn(p,"A11y wait phase completed due to timeout, continuing...")}async clickUsingVisualCoordinates(e,t){let{x:r,y:o}=e;this.logger.debug({x:r,y:o},"Executing mouse click with visual coordinates"),await this.waitForPageLoad(),await this.page.mouse.click(r,o,{button:t.rightClick?"right":"left",clickCount:t.doubleClick?2:1})}async dragAndDropUsingVisualCoordinates(e,t,r){await this.page.mouse.move(e.x,e.y,{steps:3}),await this.page.mouse.down(),await this.page.mouse.move(t.x,t.y,{steps:3}),await ee(r.hoverSeconds?Math.min(r.hoverSeconds*1e3,8e3):500),await this.page.mouse.up()}async hoverUsingVisualCoordinates(e){await this.page.mouse.move(e.x,e.y)}async mouseDragUsingVisualCoordinates(e,t,r,o){await this.hoverUsingVisualCoordinates(o);let i=await(await this.getActivePageOrFrame()).evaluate(Up);i||(this.logger.debug("Could not get current mouse position before mouse drag action, defaulting to 0,0"),i={left:0,top:0}),await this.page.mouse.down(),await this.page.mouse.move(e+i.left,t+i.top,{steps:r}),await ee(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 U(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 jp({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 jp({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 U(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 A("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 ee(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 A("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)}.
|
|
3900
|
+
Available pages:${JSON.stringify(r.map(i=>i.url))}`);if(!Kr(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=Ms(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:$l,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 ee(2500);let s=await fetch("https://api.2captcha.com/getTaskResult",{method:"POST",body:JSON.stringify({clientKey:$l,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&&pw({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];Kr(d,this.logger)&&d!==l&&this.logger.info({lastActivePages:r,currentUrl:l,newOpenPages:s},"Auto-following new tab during recording"),await this.switchToPage({type:"INDEX",index:String(c)});break}r=s};t=setInterval(async()=>{if(!i){i=!0;try{await a()}catch(s){this.logger.error({err:s},"Error while checking pages during recording")}finally{i=!1}}},500),e.addEventListener("abort",async()=>{clearInterval(t)})}async startRecording(e,t,r){this.logger.debug({isClickToRecord:r},"Starting recording mode in Chrome browser"),await this.startRecordingCrons(e),await this.page.evaluate(o=>{let i=window;i._MOMENTIC_RECORDING_ACTIVE=!0,i._MOMENTIC_CLICK_RECORD_ACTIVE=o},r),this.transformer=t,await this.injectKnowledgeBaseIntoBrowser(this.page),e.addEventListener("abort",async()=>{this.transformer=void 0,this.lastScreenshotForRecording=void 0;try{await this.page.evaluate(()=>{let o=window;o._MOMENTIC_RECORDING_ACTIVE=!1,o._MOMENTIC_CLICK_RECORD_ACTIVE=!1})}catch{}})}async getSelectOptions(e){return await e.evaluate(r=>Array.from(r.querySelectorAll("option")).map(i=>({value:i.value,label:i.label})),void 0,{timeout:1e3})}getActivePage(){return this.page}async getActivePageOrFrame(){let e=await this.stateManager.resolveActiveFrameConfig({});return e?(await this.loadFrameAndRecordUrl({root:e.frame,signal:this.abortSignal,codePath:"get-active-frame-locator"}),e.frame):this.page}async loadFrameAndRecordUrl({root:e,signal:t,codePath:r}){let o=this.pageLoadTimeout,i=e.url();if(i.includes("chrome-error://")){this.logger.warn({url:i,codePath:r},"Skipping load for chrome-error:// URL");return}try{await qr({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 A("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 qr({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 _N.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 qe({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 A("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 qe({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=Jb(),a={code:e,fragment:t,context:r},{result:s}=await U(this.page.evaluate(i,a),{milliseconds:o,fallback:()=>{throw this.abortSignal?.throwIfAborted(),new A("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 A("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:Eb,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,t=!0){let r=await this.getActivePageOrFrame(),o=await this.getDomNodeFromPositionPercentages(r,e);return this.getTargetFromBackendNodeId(r,o.backendNodeId,t)}async getTargetFromBackendNodeId(e,t,r){let o=this.stateManager.domGraph?.backendIdToNode[t];if(!o)throw new Error("No DOM node was found with the given backend ID");let i=o?.attributes[Ut],a=parseInt(i??"");if(!i||isNaN(a))throw new Error("No data-momentic-id was found on the DOM node");let s=e.locator(`[${Ut}="${i}"]`);if(r){for(let p of Object.values(this.stateManager.a11yIdToNodeMap)){if(p.backendNodeId!==t)continue;let u={id:p.id,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString()};return await this.updateCacheWithNewNodeDetails({node:p,target:u,locator:s,forceSaveNewCssSelectors:!0}),this.logger.debug({target:u},"Tied backend id to existing a11y node"),{target:u,locator:s}}let d=Ml(`${i}`,this.stateManager.domGraph,this.logger);for(let p of d){let u=parseInt(p.attributes?.[Ut]??"");if(isNaN(u))continue;let m=e.locator(`[${Ut}="${u}"]`),h=this.stateManager.dataMomenticIdToNodeMap[u],g=h?.id;if(!g)continue;let f={id:g,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString()};return await this.updateCacheWithNewNodeDetails({node:h,target:f,locator:m,forceSaveNewCssSelectors:!0}),this.logger.debug({target:f},"Tied backend id on non-accessible element to nearest a11y node"),{target:f,locator:m}}}let l=await this.fetchHtmlAttributes({locator:s,logger:this.logger}),c={id:-1,dataMomenticId:a,targetSource:"XY_PERCENT",targetUpdateTime:new Date().toUTCString(),...l};return this.logger.debug({target:c},"Tied backend id to html node"),{target:c,locator:s}}async performTargetRedirection(e,t,r){try{return await this.scrollIntoViewIfNeeded(e),await U(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 wn(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 T=window;if(!T.performTargetRedirection)throw new Error("performTargetRedirection script is not defined");return T.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}){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(vp)?new $n(o.error.slice(vp.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!!$l}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,Fp(e,this.debugData,i,{type:t,text:`[MOMENTIC] ${r}`,args:o})}async setFileChooserHandlerHelper({filePath:e,filename:t}){if(!jl(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()||UN(e),o=MN(e),i=BN(e),a=yd[i];this.page.once("filechooser",async l=>{this.logger.info({filePath:e,fileName:r},"File chooser triggered");try{if(!jl(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:gb.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 lM from"fetch-cookie";import{cloneDeep as cM}from"lodash-es";import{CookieJar as dM}from"tough-cookie";import{z as Bt}from"zod";var Koe=Bt.object({doubleClick:Bt.boolean().optional(),rightClick:Bt.boolean().optional(),force:Bt.boolean().optional(),waitForDownload:Bt.boolean().optional(),delayMs:Bt.number().optional(),downloadTimeoutMs:Bt.number().optional(),relativePosition:Bt.object({x:Bt.number(),y:Bt.number()}).optional()}),Yoe=Bt.object({repeat:Bt.number().optional(),convertMeta:Bt.boolean().optional().describe("misleading name due to backcompat. converts keyshortcuts + meta/control to platform-specific combos. defaults to true"),delayMs:Bt.number().optional()});async function xr(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 vi=3.1783027;function VN(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 za(n){return Math.ceil(Yp(n)/vi)}function Yp(n){let e=0;if(typeof n=="string"){let t=n;t=t.replaceAll(`
|
|
3901
|
+
`,""),t=t.replaceAll(" ","");let r=VN(t);return t.length-r+vi*r}if(typeof n>"u")return 0;if(typeof n=="number")return String(n).length;if(Array.isArray(n))return n.forEach(t=>{e+=Yp(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*vi:e+=85*vi:e+=Yp(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 Ew={minChunkTokenCount:500,acceptableChunkTokenCount:3e3,maxChunkTokenCount:8e3,maxLineLength:4e3},xw={minChunkTokenCount:5e3,acceptableChunkTokenCount:1e4,maxChunkTokenCount:15e3,maxLineLength:500},vw=/<(\S+) id="(\d+)".*?>/g,qN=/(<\/(\S+)>)|(<(\S+).*?\/>)/g,Tw=["h1","h2","section","footer","nav","aside","form","label","dialog"],KN=[...Tw,"span","div","h3"],YN=["table","select","form","ul","ol","menu","pre","code","dialog"],JN=["table","form","dialog","nav","section","ul","select"];function Jp(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)),XN(n)}function XN({serializedTree:n,options:e,logger:t}){let{minChunkTokenCount:r,acceptableChunkTokenCount:o,maxChunkTokenCount:i,maxLineLength:a}=e,s=[],l=n.split(`
|
|
3850
3902
|
`),c=0,d=[],p=0,u=[],m=[],h=!1;for(;c<l.length;){h&&(s.push({ids:u,content:d.join(`
|
|
3851
|
-
`),tokenLength:p}),d=[],p=0,u=m.length?[m[m.length-1].id]:[],h=!1);let g=l[c],f=za(g);p+=f,g.length>a&&(g=g.slice(0,a));let
|
|
3852
|
-
`),tokenLength:p}),s.forEach((g,f)=>{t.debug({chunk:g},`Chunk for page filtering (index ${f+1}/${s.length})`)}),{chunks:s}}var
|
|
3853
|
-
${n}`;case"NEGATED_ELEMENT_VISIBLE_CHECK":return`${
|
|
3854
|
-
${n}`;case"ELEMENT_CHECK":return`${
|
|
3855
|
-
${n}`;default:return n}}var rN=15;async function nu({command:n,logger:e,fixtures:t,useMemory:r}){if(!n.assertion.trim())throw new A("ActionFailureError","Assertion command is missing the assertion content");let{browser:o}=t,i=n.timeout?n.timeout*1e3:o.smartWaitingTimeout,a=oN(i),s=0,l=Date.now(),c,d,p;try{await Nn({action:()=>o.clearHighlights(),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,browser:o,logger:e})}catch(m){e.warn({err:m},"Failed to clear highlights before AI check, continuing...")}let u;for(;s<rN&&(!u||u-l<i);){t.abortSignal.throwIfAborted(),s!==0&&(e.info(`Waiting ${a}ms before retrying AI check`),await ee(a,t.abortSignal)),u=Date.now();try{let m=await Nn({action:async()=>{let h=await Lw(o,e,t.abortSignal);return d&&d.serializedTree===h.serializedTree&&d.screenshotBuff.equals(h.screenshotBuff)?!1:(d=h,Ow({command:n,state:h,fixtures:t,useMemory:r,useConsensus:!1,highlightElementsOnFailure:!1,attemptNumber:s,logger:e}))},frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,logger:e,browser:o});if(!m)continue;c=m;break}catch(m){t.abortSignal.throwIfAborted(),p=m instanceof Error?m:new Error(`${m}`),e.info({err:m},`AI check assert attempt ${s} failed, retrying...`)}finally{s++}}if(!c)try{c=await Nn({action:async()=>Ow({command:n,state:await Lw(o,e,t.abortSignal),fixtures:t,useMemory:r,useConsensus:!0,highlightElementsOnFailure:!0,attemptNumber:s,logger:e}),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,logger:e,browser:o})}catch(m){t.abortSignal.throwIfAborted(),p=m instanceof Error?m:new Error(`${m}`)}finally{s++}if(!c){let m=`AI check still failing after ${s} attempts.`;throw p&&(m+=` Latest result: ${p.message}`),new A("AssertionFailureError",m,{lastScreenshotBuffer:d?.screenshotBuff})}return c.updatedMemory&&(n.cache={...n.cache,memory:{type:"GCS_TRACES",traces:c.updatedMemory}}),c}async function Lw(n,e,t){let[r,o]=await Promise.all([Er(n,{abortSignal:t,skipWait:!0,skipWaitForPageLoad:!0,logger:e}),n.screenshot({retries:1,respectActiveFrame:!0})]);return{...r,screenshotBuff:o}}async function Ow({command:n,state:e,fixtures:t,useConsensus:r,useMemory:o,highlightElementsOnFailure:i,attemptNumber:a,logger:s}){let{browser:l,generator:c,abortSignal:d}=t,p={type:"ASSERTION"},{serializedTree:u,tree:m}=e,h=e.screenshotBuff,g=l.url(),f=u;f=await so({type:"assertion",serializedTree:u,description:n.assertion,flagStore:t.flagStore,tree:m,generator:c,logger:s,signal:d}),f!==u&&(p.ragUsed=!0),p.pageState=f;let S={goal:n.assertion,url:g,memory:o?n.cache?.memory:void 0,browserState:f,screenshot:h.toString("base64"),contextChoice:n.contextChoice},x=await(n.contextChoice==="VISION_ONLY"?(y,T)=>c.getVisualAssertionResult(y,T):(y,T)=>c.getAssertionResult(y,T))(S,{useConsensus:r,attemptNumber:a,useMemory:o,disableCache:!!n.disableCache,abortSignal:d,logger:s,loggerTags:ze(s)});if((x.result||i)&&x.relevantElements&&(p.relevantElementsSerialized=x.relevantElements.map(y=>l.getSerializedFormFromA11yId(y)).filter(y=>!!y),await iN(x.relevantElements,l,s)),!x.result)throw new A("AssertionFailureError",x.thoughts);return{succeedImmediately:!1,thoughts:x.thoughts,urlAfterCommand:g,afterScreenshotOverride:h,updatedMemory:o?x.updatedMemory:void 0}}function oN(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 iN(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 U(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 aN=3e4;async function Mw({command:n,logger:e,baseUrl:t,fetchImplementation:r=fetch}){let o=n.timeout??aN/1e3,i=new AbortController,a=Object.fromEntries(Object.entries(n.headers||{}).filter(([p,u])=>p&&u)),s;if(Wo(n.url)&&(s=n.url),t&&Vo(n.url,t)&&(s=new URL(n.url,t).toString()),!s)throw new A("ActionFailureError",`Invalid URL: ${n.url}`);let c=await U((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 A("ActionFailureError",`GraphQL request timed out after ${o} seconds`);if(!c.ok){let p;try{p=await c.json()}catch{throw new A("ActionFailureError",`GraphQL request failed with status ${c.status}: ${await c.text()}`)}throw p?.errors?.length&&p?.errors[0]?.message?new A("ActionFailureError",`GraphQL request failed with status ${c.status}: ${p.errors[0].message}`):new A("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 Gl(n){try{return new RegExp(n)}catch(e){throw new A("UserConfigurationError",`The provided regex expression was invalid: ${e}`)}}async function Nw(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 kw(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 Nw(n)}}}async function Dw(n,e){let t=await e.response();if(t)return n.response={status:t.status(),headers:await t.allHeaders(),...await kw(t)},n}async function Fw(n){let e=n.request(),t=n.status(),r=n.headers(),o=await kw(n);return{request:{url:e.url(),method:e.method(),headers:e.headers(),...await Nw(e)},response:{status:t,headers:r,...o},status:t,headers:r,...o}}var Ei=class{flagStore;orgId;options;storage;localCodeEvalTools;uploadedFileStorage;visualDiffScreenshotStorage;browser;generator;executeAbortController=new AbortController;logger;analytics;recordAbortController=null;registeredListeners={};recordedRequests={};constructor({browser:e,generator:t,logger:r,analytics:o,flagStore:i,storage:a,orgId:s,localCodeEvalTools:l,uploadedFileStorage:c,visualDiffScreenshotStorage:d,options:p}){this.orgId=s,this.options=p,this.browser=e,this.browser.registerAbortSignal(this.executeAbortController.signal),this.storage=a,this.uploadedFileStorage=c,this.visualDiffScreenshotStorage=d,this.localCodeEvalTools=l,this.generator=t,this.logger=r,this.analytics=o,this.flagStore=i}setOpen(){this.executeAbortController=new AbortController,this.browser.registerAbortSignal(this.executeAbortController.signal)}setClosed(){this.executeAbortController.abort()}throwIfClosed(){this.executeAbortController.signal.throwIfAborted()}get closed(){return this.executeAbortController.signal.aborted}async evaluateAiAction({goal:e,startingScreenshot:t,history:r,disableCache:o,langfuseSessionId:i,lastError:a,logger:s=this.logger}){let[l,c]=await Promise.all([Er(this.browser,{abortSignal:this.executeAbortController.signal,skipWait:!0,skipWaitForPageLoad:!0,logger:s}),this.browser.screenshot({retries:1,clearHighlights:!0})]),d=await so({type:"ai-action",description:e,serializedTree:l.serializedTree,tree:l.tree,logger:s,generator:this.generator,flagStore:this.flagStore,softTokenLimit:25e3,hardTokenLimit:5e4}),p=`data:image/jpeg;base64,${c.toString("base64")}`,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([Er(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 so({type:"ai-action",description:e,serializedTree:c.serializedTree,tree:c.tree,logger:a,generator:this.generator,flagStore:this.flagStore,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 A("InternalWebAgentError",`Error generating command: ${h instanceof Error?h.message:h}`,{errOptions:{cause:h}})}}async getBrowserState(e){return Er(this.browser,e)}async locateElement(e){return tu(e,this.getControllerFixtures())}async locateElementWithSelector(e,t){return Nn({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 A("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 Nn({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")&&Sd(i)){t.warn({err:i},"Invalid mpath error, retrying element targeting command");continue}if(!this.flagStore.isBooleanFlagEnabled("visual_actions")&&la(i)){t.warn({err:i},"Invalid momentic id error, retrying element targeting command");continue}if(i instanceof $n){t.warn({err:i},"Element bounding box moved error, retrying element targeting command");continue}throw i}throw r instanceof A?r:new A("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 A("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)&&!vc(o))throw new A("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&&!Pw(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&&rm(S);if(!S){let x=new Date;m.debug({targetHealingInProgress:p,cacheBustedBeforeAction:f,memory:a.memory,useMemory:h},"Prompting AI for an updated element location"),f&&await ee(this.browser.smartWaitingTimeout,this.executeAbortController.signal),g--;let y=await tu({description:o.elementDescriptor,disableCache:!!a.disableCache,iframeUrl:a.iframeUrl,source:u,useMemory:h,memory:h?a.memory:void 0,logger:m},this.getControllerFixtures(t));y.frameConfig&&this.browser.setActiveFrameConfig(y.frameConfig);let T=a.disableGlobalLocatorRedirect?{locator:y.resolution.locator}:await this.attemptLocatorRedirect(y.resolution.locator,m),C=await i(T);return p&&(r.heal({healType:"AI"}),this.analytics.track({type:"execution:step_heal",heal_type:"AI",step_type:"PRESET_ACTION",command_type:s.type,duration_ms:Date.now()-x.getTime()}),y.target.targetSource="AI_HEALED",y.target.targetUpdateTime=new Date().toUTCString(),y.target.targetUpdateLoggerTags=ze(m)),{result:C,elementInteractedDisplayString:y.resolution.displayString,newTarget:{cache:y.target,thoughts:y.thoughts}}}try{let x=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 T=a.disableGlobalLocatorRedirect?{locator:y.locator}:await this.attemptLocatorRedirect(y.locator,m),C=await i(T);if(w){let R=y.decisions.filter(L=>L.matched);if(R.length!==1)m.warn({decisions:y.decisions},"Expected exactly 1 matching method for element location, got more or less");else{let L=R[0].type;r.heal({healType:L}),this.analytics.track({type:"execution:step_heal",heal_type:L,step_type:"PRESET_ACTION",command_type:s.type,duration_ms:Date.now()-x.getTime()})}}return{result:C,elementInteractedDisplayString:y.displayString,newTarget:{cache:S}}}catch(x){this.throwIfClosed();let y=Jh(x)&&!Sd(x)&&!la(x)&&!(x instanceof $n);if(x instanceof A&&!y)throw x;if(g>0&&o)return m.debug({err:x,cache:S},"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 A("ActionFailureError",x.message,{errOptions:{cause:x}})}}async attemptLocatorRedirect(e,t){return this.flagStore.isBooleanFlagEnabled("global_locator_redirect")?this.browser.performTargetRedirection(e,t):{locator:e}}async screenshotWithDimensions(e){return Fa(this.browser,e)}async executePresetCommand(e,t,r,o,i){this.options?.slowMoMs&&await ee(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 A("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")&&pm(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 qy({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){Ay(e,t)}createCallbacksForBrowser(e){return{createIsolatedFolder:()=>_p(e)}}async resolveCommandTemplateStrings(e,t){return Si({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()?nu({command:s,fixtures:this.getControllerFixtures(e),useMemory:this.shouldUseMemory(),logger:a}):{succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"AI_ASSERTION":{if(!r.assertion.trim())throw new A("ActionFailureError","Missing assertion");if(r.timeout&&r.timeout>1800)throw new A("AssertionFailureError",`AI check timeout of ${r.timeout} exceeds the maximum allowed value of 30 minutes.`);return nu({command:r,fixtures:this.getControllerFixtures(e),useMemory:this.shouldUseMemory(),logger:a})}case"AI_EXTRACT":{if(!r.goal.trim())throw new A("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 A("ActionFailureError","No relevant data found for extraction goal on this page");if(f.thoughts?.includes("MaxGenerationLengthExceededError"))throw new A("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 A("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 A("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(!Wo(r.url)&&!Vo(r.url,this.browser.baseUrl))throw new A("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 A("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 A("UserConfigurationError",`Wait timeout of ${r.delay} seconds exceeds the maximum allowed value of 30 minutes`);let c=r.delay*1e3;await ee(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:x=>this.browser.click(x,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 Xs(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 A("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,x=[];if(r.target?.elementDescriptor){let{newTarget:y,elementInteractedDisplayString:T,result:C}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:async R=>R.locator,options:{disableCache:i,...r}});S=C,w=T,x.push(y)}return await this.browser.mouseDrag(h,g,f,S,{force:r.force}),{succeedImmediately:!1,urlAfterCommand:this.browser.url(),elementInteracted:w,newTargets:x}}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 Yn({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 A("ActionFailureError",g instanceof Error?g.message:`${g}`,{errOptions:{cause:g}})}try{JSON.stringify(h)}catch(g){throw new A("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=lN(r.target);if(S){let{elementInteractedDisplayString:x,newTarget:y}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:S,cache:r.cache?.target,action:T=>this.browser.typeIntoTarget(r.value,T,{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=x}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 Xs(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 Xs(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 cN,g=sN(fetch,h),f;try{f=new URL(r.url).hostname}catch{}return{data:{...await El({command:r,baseUrl:this.browser.baseUrl,logger:a,fetchImplementation:g}),cookies:_s(h,f)},succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"GRAPHQL_REQUEST":return{data:await Mw({command:r,baseUrl:this.browser.baseUrl,logger:a}),succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"VISUAL_DIFF":return Hy({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 Bb({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 A("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 Yn({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 A("ActionFailureError",`Credentials must evaluate to an object (received ${typeof h} instead)`);let g;try{g=ks.optional().parse(h)}catch(f){throw new A("ActionFailureError",`Credentials provided do not follow the required format: ${f}`)}await this.browser.loadAuthState(g);break}case"ELEMENT_CHECK":{let h=(r.timeout??Rn)*1e3,g=await By({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 Nn({action:async()=>Tl({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=Gl(r.pattern),g=this.browser.registerRequestListener(h);return this.registeredListeners[r.key]=g.then(async f=>await Fw(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 A("ActionFailureError",`No listener registered with key: ${r.key}`);let g=r.timeout??10;return{data:await U(h,{milliseconds:g*1e3,message:`Request listener timed out after ${g} seconds`}),succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"RECORD_REQUESTS":{let h=Gl(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 Dw(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 A("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=Gl(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 Bl({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 Tr}from"zod";var pse=Tr.object({useSelector:Tr.boolean().optional(),disableCache:Tr.boolean().optional(),iframeUrl:Tr.string().optional(),retriesWithAI:Tr.number().optional(),targetName:Tr.string().optional(),source:is.optional(),disableGlobalLocatorRedirect:Tr.boolean().optional(),targetHealingInProgress:Tr.boolean().optional(),memory:Di.optional()});var dN=4;async function Uw({socket:n,logger:e,analytics:t,storageFactory:r,uploadedFileStorage:o,visualDiffScreenshotStorage:i,serviceMocker:a,devicePixelRatio:s,generatorFactory:l,enricherFactory:c,browserbase:d,authorization:p,flagStoreFactory:u,settingsFactory:m,getOrgId:h}){let g=n.id,f=n.handshake.query.testId;if(!f)throw new Error("Socket connection request is missing testId");let S=await h({type:"e2e",testId:f});e=e.child({testId:f,orgId:S,sessionId:g});let w=await l(S,e),x=await c(S,e),y=await u(S),T=await m(S,e),C=await r(S),{testMetadata:R,baseUrl:L,envName:N,browserConfig:H,environmentVariables:z,localCodeEvalTools:k}=await lo({testId:f,orgId:S,logger:e,storage:C,authorization:p,flagStore:y,settings:T}),_=Z.getSession(g);if(_)return e.info("Associating connection with existing session (likely reconnect)"),await _.controller.browser.clearAllCdpHighlights(),{type:"e2e",sessionId:g,orgId:S,testId:f};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&&Z.getCurrentConnectionsByIp(O)>=dN)throw e.error({clientIp:O,sessions:Z.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.");Z.reserveCapacityByIp(O);try{await pN({socket:n,baseUrl:L,envName:N,testMetadata:R,orgId:S,sessionId:g,logger:e,analytics:t,environmentVariables:z,clientIp:O,devicePixelRatio:s,storage:C,uploadedFileStorage:o,visualDiffScreenshotStorage:i,serviceMocker:a,localCodeEvalTools:k,generator:w,enricher:x,browserbase:d,browserConfig:H,flagStore:y})}catch(K){throw e.warn({err:K},"Error setting up socket session, possibly due to client closing the connection"),Z.releaseCapacityByIp(O),K}return{type:"e2e",sessionId:g,testId:f,orgId:S}}async function pN({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,clientIp:S,enricher:w,flagStore:x}){let y={viewport:o.advanced?.viewport??Jt,locale:o.advanced?.locale??Do,timezoneId:o.advanced?.timezone??Fo,geolocation:o.advanced?.geolocation??Uo,colorScheme:o.advanced?.colorScheme};r&&(y.deviceScaleFactor=r);let T=o.id,C=await u?.initializeServicesForTest(i,T),R=await Ll({settings:f,orgId:i,baseUrl:e,envName:t,testName:o.name,localTools:m,envVariables:g,logger:s,customHeaders:void 0,flagStore:x});s=s.child({orgId:i,sessionId:a,testId:T});let L=!1,N=x.isBooleanFlagEnabled("icon_knowledge_base")?await c.fetchIconKnowledgeBase(s):null,H=await Un.init({baseUrl:e,userBrowserSettings:R,enricher:w,storage:c,flagStore:x,mockedServices:C,logger:s,contextArgs:y,iconKnowledgeBase:N,callbacks:{onTabsChange:(K,B)=>{n.emit("tabs",{tabs:K,activeTab:B})},onScreencastFrame:(K,B)=>{let le=n;L&&(le=n.compress(!0)),le.emit("screenshot",{buffer:K},()=>{B()})},onSvgsCollected:K=>{n.emit("newIconDetected",{numIcons:K.newSvgs.length}),c.saveNewIcons(K,s)}}});await H.navigate({url:e,initialNavigation:!0});let z=new Ei({browser:H,generator:h,logger:s,analytics:l,flagStore:x,orgId:i,options:{scratchPadId:void 0,slowMoMs:R.slowMoMs,autoFollowNewTabs:R.autoFollowNewTabs,useMemory:o.advanced.useMemory},storage:c,localCodeEvalTools:m,uploadedFileStorage:d,visualDiffScreenshotStorage:p}),k=yy(n,a,s),_=async()=>{k.timers.forEach(K=>clearInterval(K))},O=new Ot({baseUrl:e,testName:o.name,currentUrl:z.browser.url(),variablesFromEnvironment:g,envName:t});if(!n.connected)throw await H.cleanup(),new Error("Socket not connected anymore, not proceeding with session setup");n.emit("session",{url:e,userAgent:Un.USER_AGENT,viewport:z.browser.getViewport(),sessionId:a}),Z.registerSession({controller:z,context:O,sessionId:a,cleanup:_,clientIp:S})}async function lo({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 Ft({...o,logger:t}),fakerSeed:void 0}));let c=s.envs?.find(g=>g.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?.[Ve];if(!m)throw new Error("Base URL is empty in both test options and the configured environment");let h={...d?.variables};return await Promise.all((s.parameters??[]).map(async g=>{let f=await Gt({orgId:e,s:g.defaultValue,context:Ot.dummyContext(s.name,d?.name,h),logger:t,flagStore:i,localTools:l});h[g.name]=f})),{localCodeEvalTools:l,baseUrl:m,envName:d?.name,testName:s.name,browserConfig:u,environmentVariables:h,testMetadata:s}}var ru=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 Wl({parentStep:this.step,socket:this.socket,parentTracer:this})}},Wl=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 ru({step:e.step,parentTracer:this,socket:this.socket})}},Vl=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 Wl({parentStep:null,parentTracer:null,socket:this.socket})}};var ou={currentlyExecutingRequests:{}},mN=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 lo({testId:r,orgId:o,logger:n.logger,storage:s,authorization:n.authorization,flagStore:i,settings:a}),d=`${r}|${c.baseUrl}`;try{let p=ou.currentlyExecutingRequests[d]??0;ou.currentlyExecutingRequests[d]=p+1,l=await hN({...n,...e,...c,done:t})}finally{n.logger.info({result:l,sessionId:n.metadata.sessionId},"Test execution complete"),ou.currentlyExecutingRequests[d]--}},hN=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:x}=l,y=w,T=Z.getSession(w);if(!T)throw new Error("No active session found");let{controller:C,context:R}=T;C.setOpen(),c=c.child({testId:S,orgId:x,sessionId:w,runId:y}),c.info({steps:e.map(J=>`${J.type}${"command"in J?` - ${J.command.type}`:""}`),toStep:i,fromStep:a,reInitialize:o,envName:p,testName:u,baseUrl:t,context:R,flags:C.flagStore.getAllFlags()},"Socket execution parameters");let L=m??{},N=async()=>{o&&(await C.browser.reset({newUrl:t}),R.reset({baseUrl:t,currentUrl:C.browser.url(),variablesFromEnvironment:L,envName:p,testName:u}))},H=await s(x),z=await f(x),k=async()=>{try{await z.resolveStepCacheEntries({schemaVersion:r.schemaVersion,testId:S,stepLists:{steps:e},logger:c})}catch(J){c.error({err:J},"Failed to fetch step cache entries from Momentic server. This can drastically reduce test reliability and performance.")}};try{await ha({promiseGenerator:async()=>Promise.all([N(),k()]),signal:C.executeAbortController.signal,codePath:"resolveStepCacheAndInitBrowser"}),C.setOpen()}catch(J){if(n.emit("finished"),J.name!=="AbortError")throw new Error(`Failed to setup browser for execution: ${J}`)}let _=uN(e),O={collectDebugData:!1,reinitializeBrowser:!1,disableHealing:!0},K={orgId:x,runId:y,testMetadata:r,steps:e,fromStep:a,toStep:i},B={controller:C,context:R,storage:H,debugDataStorage:new Br,codeEvalTools:h,billingReporter:new $o,logger:c,analytics:d},le={test:{},step:{onDynamicAIActionStatusUpdateEvent:J=>{n.emit("dynamicCommandStatusUpdate",J)},onDynamicAIActionEvaluatingEvent:J=>{n.emit("dynamicCommandEvaluating",J)},onDynamicCommandGenerated:J=>{n.emit("dynamicCommandGenerated",J)},onDynamicCommandExecuted:J=>{n.emit("dynamicCommandExecuted",J)}}},ce=new Vl(n,H,x,S,_),fe=await Pl({fixtures:B,options:O,callbacks:le,inputs:K,testParams:{tracer:ce}});return fe?.status==="PASSED"&&await $s({logger:c,cacheStorage:z,orgId:x,testId:S,originalSteps:{steps:_},updatedSteps:{steps:e}}),await ce.finish(),g?.(fe),fe.status};var Bw={event:"execute",createHandler:mN};import{cloneDeep as gN}from"lodash-es";var fN=n=>async({command:e},t)=>{let{logger:r,generatorFactory:o,metadata:i}=n,a=gN(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})}}},zw={event:"lintStep",createHandler:fN};var SN=({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=Z.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=Bo.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 An?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 x=await u.browser.getCondensedHtml({skipWait:!0});e.warn({err:w,html:x.slice(0,1e5)},"Failed locating element with AI")}catch(x){e.warn({err:x},"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:x,height:y}=await u.screenshotWithDimensions({clearHighlights:!0,locator:S}),T=await h.uploadScreenshot(w);f.screenshot={data:T,width:x,height:y},e.info({width:x,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...")}}},Hw={event:"locate",createHandler:SN};var yN=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({event:r,percentX:o,percentY:i})=>{let a=Z.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:yN};var bN=({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=Z.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})}},$w={event:"recordTargetClick",createHandler:bN};var wN=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({key:r})=>{let o=Z.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}}},Gw={event:"keyDownEvent",createHandler:wN};var vN=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({key:r})=>{let o=Z.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}}},Ww={event:"keyUpEvent",createHandler:vN};var xN=({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=Z.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")}}},Vw={event:"mouseMoveEvent",createHandler:xN};var EN=({metadata:n,generatorFactory:e,socket:t,logger:r})=>{let{sessionId:o,orgId:i,testId:a}=n;return async({stepId:s})=>{let l=Z.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:EN};var TN=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async()=>{let r=Z.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}},Kw={event:"recordingStop",createHandler:TN};var CN=({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 lo({testId:c,orgId:p,logger:t,storage:h,authorization:o,flagStore:u,settings:m}),f=Z.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()},Yw={event:"refresh",createHandler:CN};var RN=({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 lo({testId:s,orgId:c,logger:t,storage:u,authorization:o,flagStore:d,settings:p}),S=Z.getSession(l);if(!S){n.emit("error",{message:"No session to reset"});return}let{controller:w,context:x}=S;await w.browser.reset({newUrl:m});let y=w.browser.baseUrl;x.reset({baseUrl:y,currentUrl:w.browser.url(),variablesFromEnvironment:f,envName:h,testName:g});let T=w.browser.getViewport(),C=Un.USER_AGENT;t.info({baseUrl:m,viewport:T},`Session reset for test ${s} at ${y}`),n.emit("session",{url:y,userAgent:C,viewport:T,sessionId:l})},Jw={event:"reset",createHandler:RN};var AN=({metadata:n})=>{let{sessionId:e}=n;return async({url:t})=>{let r=Z.getSession(e);if(!r)throw new Error("No active session found");await r.controller.browser.switchToPage({type:"SUBSTRING",substring:t})}},Xw={event:"switchTab",createHandler:AN};async function Zw(n){let{socket:e}=n;return e.handshake.query.type==="api-test"?Ly(n):Uw(n)}var Qw=[_y,Bw,Hw,Jw,Yw,My,Xw,zw,$w,qw,Kw,Vw,jw,Gw,Ww,Oy,by,ky,Ny];var ev=n=>{let{logger:e}=n,t=new IN(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 Zw({...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}Qw.forEach(i=>PN(i,{socket:r,metadata:o,...n,logger:e}))}),t},PN=(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 BN}from"express";import lu from"fs";import kN from"path";import nv,{multistream as LN}from"pino";import ON from"pino-pretty";var tv=["lastScreenshotBuffer"];var iu=new Map,MN=!0,au=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=MN?nv(i):nv(i,LN([{stream:ON({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))tv.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}},ql=({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 iu.has(n)||iu.set(n,new au({bindings:{app:n},hostname:t,clientToken:e||process.env.NEXT_PUBLIC_DD_CLIENT_TOKEN||process.env.DD_CLIENT_TOKEN,disableConsoleLogs:r})),iu.get(n)};import{hostname as NN}from"os";var We=ql({app:"desktop-server",clientToken:"pubcfd7516a5c0ba852b42675cd97bee027",hostname:NN(),disableConsoleLogs:!0}),rv=n=>{We.addBinding("version",n)};var _N=new bl(30,60*1e3),pu="https://api.momentic.ai",uu,su,ov=n=>{pu=n},Kl=()=>pu,iv=(n,e)=>{uu=n,su?.abort(),su=new AbortController;let t=su.signal,r=[n.configFilePath];n.config.environments?.forEach(o=>{if(!o.envFile)return;let i=kN.resolve(n.rootDir,o.envFile);try{if(lu.lstatSync(i).isSymbolicLink())return;lu.existsSync(i)&&r.push(i)}catch(a){We.warn({err:a},`Failed to check if env file ${i} exists`)}});try{DN({filesToWatch:r,revalidator:e,signal:t,project:n})}catch(o){We.error({err:o},"Failed to start config file watchers")}},re=()=>uu,Ti,cu,du,av=async n=>{if(Ti)return Ti;let e=new ct({baseUrl:pu,apiKey:n,logger:We});try{let t=await e.getAuthInfo();return Ti=t.orgId,cu=t.userId,du=n,Ti}catch(t){throw new Error(`Error checking API key against server: ${t}`)}},Xn=()=>{if(!Ti)throw new Error("Your organization ID is invalid.");return Ti},Yl=()=>{if(!cu)throw new Error("Your user ID is invalid.");return cu},sv=()=>{if(!du)throw new Error("Your API key is invalid.");return du};function DN({filesToWatch:n,revalidator:e,signal:t,project:r}){n.forEach(o=>{lu.watch(o,{signal:t,persistent:!1,recursive:!1},(i,a)=>{a&&(_N.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.`),uu=e(r.configFilePath))})})}var Jl=class extends ui{constructor(t,r){super(t,r);this.client=t;this.orgId=r}async fetchTestMetadata(t,r){let o=re(),a=we(o,r).tests[t];if(a)return Qs(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 Sa(t,o,Hr)}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 FN}from"express";import lv from"fs";import UN from"path";var Ha=FN();async function mu(n){return(await Zs(n,We)).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)}Ha.get("/",se(async(n,e)=>{let t=re(),r=we(t,b),o=await mu(r);e.status(200).json(o)}));Ha.post("/",se(async(n,e)=>{let t;try{t=ig.parse(n.body)}catch(s){e.status(400).json({error:`Invalid request body: ${s}`});return}try{jo(t.name)}catch(s){e.status(400).json({error:`Invalid module name: ${s}`});return}let r=re(),o=we(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=UN.join(r.rootDir,t.folderPath??"");if(!lv.existsSync(i)||!lv.statSync(i).isDirectory()){e.status(400).json({error:`The folder configured for module creation '${i}' does not exist.`});return}let a=await rS({...t,folder:i,project:r});e.status(201).json(a)}));Ha.get("/:moduleId",se(async(n,e)=>{if(!n.params.moduleId){e.status(400).json({error:"Missing moduleId in url path."});return}let t=we(re(),b),r=t.modules[n.params.moduleId];if(!r){e.status(404).json({error:"Module not found."});return}try{let o=await _d(r,t,b);e.json(o)}catch(o){e.status(400).json({err:o})}}));Ha.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=ag.parse(n.body)}catch(i){e.status(400).json({error:`Invalid request body: ${i}`});return}let r=re(),o=we(r,b);nS({moduleId:n.params.moduleId,content:t,momenticFiles:o,logger:b,project:r}),e.status(201).json({message:"ok"})}));var cv=Ha;var dv=BN();dv.get("/",se(async(n,e)=>{let t=re(),r=we(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 mu(r),l={labels:i,tests:a,modules:s};e.status(200).json(l)}));var pv=dv;import{Router as zN}from"express";var hu=zN();hu.get("/",se((n,e)=>{let t=lS(re(),We);e.status(200).json(t)}));hu.get("/names",se((n,e)=>{let r=re().config.environments?.map(o=>o.name)??[];e.status(200).json(r)}));var uv=hu;import{Router as HN}from"express";import ft from"fs";import it from"path";var $a=HN();function ja(n){let e=re(),t=it.dirname(e.configFilePath);return it.join(t,...n)}function jN(n){let e=re(),t=it.dirname(e.configFilePath),r=it.relative(t,n);return r?r.split(it.sep):[]}function $N(n,e){let t=ft.statSync(n),r=jN(n);return bd.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})}$a.post("/",se(async(n,e,t)=>{let r;try{r=cg.parse(n.body).pathSegments}catch(l){e.status(400).json({error:`Failed to parse folder read body: ${l}`});return}let o=ja(r);if(!ft.existsSync(o)){e.status(404).json({error:`Path not found: ${r.join(it.sep)}`});return}if(!ft.statSync(o).isDirectory()){e.status(400).json({error:`Path is not a directory: ${r.join(it.sep)}`});return}let a=ft.readdirSync(o).map(l=>{let c=it.join(o,l);return $N(c,l)}),s={absolutePath:o,pathSegments:r,contents:a};e.status(200).json(s)}));$a.put("/",se(async(n,e,t)=>{let r;try{r=dg.parse(n.body).pathSegments}catch(a){e.status(400).json({error:`Failed to parse folder create body: ${a}`});return}let o=ja(r);if(ft.existsSync(o)){e.status(200).json({success:!0,message:`Folder already exists: ${r.join(it.sep)}`,pathSegments:r});return}ft.mkdirSync(o,{recursive:!0});let i={success:!0,message:`Folder created: ${r.join(it.sep)}`,pathSegments:r};e.status(201).json(i)}));$a.patch("/",se(async(n,e,t)=>{let r,o;try{let c=pg.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=ja(r),a=ja(o);if(!ft.existsSync(i)){e.status(400).json({error:`Folder not found: ${r.join(it.sep)}`});return}if(ft.existsSync(a)){e.status(400).json({error:`Destination already exists: ${o.join(it.sep)}`});return}let s=it.dirname(a);ft.existsSync(s)||ft.mkdirSync(s,{recursive:!0}),ft.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)}));$a.delete("/",se(async(n,e,t)=>{let r,o=!0;try{let l=ug.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=ja(r);if(!ft.existsSync(i)){e.status(200).json({success:!0,message:`Folder not found: ${r.join(it.sep)}`,pathSegments:r});return}if(!ft.statSync(i).isDirectory()){e.status(400).json({error:`Path is not a directory: ${r.join(it.sep)}`});return}if(o)ft.rmSync(i,{recursive:!0,force:!0});else{if(ft.readdirSync(i).length>0){e.status(409).json({error:`Cannot delete non-empty directory without recursive flag: ${r.join("/")}`});return}ft.rmdirSync(i)}let s={success:!0,message:`Folder deleted: ${r.join("/")}`,pathSegments:r};e.status(200).json(s)}));var mv=$a;import{Router as GN}from"express";var hv=GN();hv.get("/",se((n,e)=>{e.status(200).json({userId:Yl(),orgId:Xn()})}));var gv=hv;import{Router as WN}from"express";var fv=WN();fv.get("/",se((n,e)=>{let t=re(),r=we(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 Sv=fv;import{Router as VN}from"express";var Xl=VN();Xl.get("/",se((n,e)=>{let t=cp().map(r=>({name:r.config.name,configFilePath:r.configFilePath}));e.status(200).json(t)}));Xl.get("/current",se((n,e)=>{let t=re(),r={name:t.config.name,configFilePath:t.configFilePath};e.status(200).json(r)}));Xl.post("/set",se((n,e)=>{let t;try{t=lg.parse(n.body)}catch(r){e.status(400).json({error:`Invalid request body: ${r}`});return}try{let r=$t({configFilePath:t.configFilePath});iv(r,o=>$t({configFilePath:o}))}catch(r){e.status(400).json({error:`Error setting project: ${r}`});return}e.sendStatus(204)}));var yv=Xl;import{Router as qN}from"express";var bv=qN();bv.get("/",se((n,e)=>{let r={ai:re().config.ai};e.status(200).json(r)}));var wv=bv;import{Router as JN}from"express";import vv from"fs";import co from"path";import{v4 as xv}from"uuid";import XN from"yaml";import{randomUUID as KN}from"node:crypto";import{PostHog as YN}from"posthog-node";var Ci=class{identify(){return this}child(){return this}track(){return this}async shutdown(){}},Ri=class n{bindings;client;options;constructor(e,t={}){this.bindings=e,this.options=t,this.client=new YN("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:KN(),event:r,timestamp:t?.timestamp,properties:{...this.bindings,...o}}),this}};var Ai=new Ri({platform:"local_app"},{flushAt:1,flushInterval:0});var Cr=JN();Cr.get("/",se((n,e)=>{let t=re(),r=we(t,b),o=Object.values(r.tests);e.status(200).json(o)}));Cr.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{jo(t.name)}catch(p){e.status(400).json({error:p.message});return}let o={id:xv(),name:t.name,description:t.description,baseUrl:t.baseUrl,schemaVersion:De,advanced:{disableAICaching:!1,browserType:t.browserType??"Chromium",viewport:t.viewport??Jt},retries:0,steps:[]};t.environment&&(o.envs=[{name:t.environment,default:!0}]);let i=re(),a=we(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=co.join(i.rootDir,...t.pathSegments||[]),c=await iS({test:o,name:t.name,folder:l}),d={...o,relativeFilePath:co.relative(i.rootDir,c)};Ai.track({type:"test_editor:test_create"}),e.status(201).json(d)}));Cr.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=re(),o=we(r,b),i;try{i=await fa(co.join(r.rootDir,t),We,o),e.status(200).json(i)}catch(a){e.status(400).send({error:a.message});return}(async()=>{try{let{stepsToSave:a,moduleUpdates:s}=await Dt({stepLists:{steps:i.steps,beforeSteps:i.beforeSteps,afterSteps:i.afterSteps}});s.forEach(l=>{Xr({content:l,schemaVersion:De,momenticFiles:o,project:r})}),Vn({relativeTestPath:t,steps:a,schemaVersion:De,project:r})}catch(a){We.error({err:a},"Failed to save migrated test to disk after initial fetch")}})()}));Cr.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:Dd(n.params.testPath,t,re()).newRelativeTestPath};e.status(200).json(o)}));Cr.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=re(),i=we(o,b),a;try{a=Qs(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 Dt({stepLists:r.stepLists,cacheCreationParams:{testId:a.id,orgId:Xn()}}),d=new ct({apiKey:sv(),baseUrl:Kl(),logger:We}),p=await di(We,d,o);await fi({orgId:Xn(),client:d,gitMetadata:p}).saveStepCacheEntries({logger:We,testId:a.id,entries:c}),l.forEach(m=>{Xr({content:m,schemaVersion:r.schemaVersion,momenticFiles:i,project:o})}),Vn({relativeTestPath:t,steps:s,schemaVersion:r.schemaVersion,project:o}),e.status(201).json({message:"ok"})}));Cr.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=sg.parse(n.body)}catch(o){e.status(400).json({error:`Invalid request body: ${o}`});return}Dd(t,{envs:r.defaultEnv?[{name:r.defaultEnv,default:!0}]:[]},re()),e.status(201).json({message:"ok"})}));Cr.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{jo(r.name)}catch(f){e.status(400).json({error:f.message});return}let o=re(),i=co.join(o.rootDir,t);if(!vv.existsSync(i)){e.status(404).json({error:"Test not found."});return}let a=we(o,b),s;try{s=await fa(i,We,a)}catch(f){e.status(400).send({error:f.message});return}let l=xv(),c=tn.parse({...s,name:r.name,id:l}),{stepsToSave:d}=await Dt({stepLists:{steps:s.steps,beforeSteps:s.beforeSteps,afterSteps:s.afterSteps},createNewCacheIds:!0,cacheCreationParams:{testId:l,orgId:Xn()}}),p=Gn({fileType:Ie.TEST,...c,beforeSteps:d.beforeSteps??void 0,steps:d.steps,afterSteps:d.afterSteps??void 0}),u=co.dirname(i),m=co.join(u,`${r.name}.${_t.TEST}`),h=XN.stringify(p);vv.writeFileSync(m,h,"utf-8");let g={relativeFilePath:co.relative(o.rootDir,m)};Ai.track({type:"test_editor:test_create"}),e.status(201).json(g)}));var Ev=Cr;var Ga=class{async prepareGoldenScreenshotForComparison(e,t,r){return await new li(re(),!1).prepareGoldenScreenshotForComparison(e,t,r)}};async function Av(n){let{momenticServerUrl:e,apiKey:t,serverPort:r,staticDir:o,devicePixelRatio:i,version:a,logger:s=We,alwaysSaveCache:l,noCache:c}=n;rv(a),e&&ov(e),await av(t);let d=Xn(),p=Yl();Ai.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=ok(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(T){T.message.includes("EADDRINUSE")?Iv(r):b.error(`An unexpected error occurred while starting the server: ${T.message}`),process.exit(1)}});let g={type:"API_KEY",baseUrl:Kl(),apiKey:t,logger:s},f=async()=>{let y=re();return new hi(y.config.ai?.agentConfig,g)},S=async()=>new gi(g,await f()),w=new ct(g),x=new Ga;ev({baseServer:u,getOrgId:async()=>Xn(),generatorFactory:f,enricherFactory:S,cacheStorageFactory:async y=>{let T=re(),C=await di(s,w,T);return fi({orgId:y,client:w,gitMetadata:C,alwaysSaveCache:l,noCache:c})},flagStoreFactory:async y=>{let T=re();return new ci(T.config)},settingsFactory:async()=>{let y=re();return{ai:{},browser:{},...y.config}},storageFactory:async y=>new Jl(w,y),logger:s,devicePixelRatio:i,authorization:g,visualDiffScreenshotStorage:x,analytics:Ai})}var Rv="25mb";function ok(n,e,t){let r=Cv();r.use(ZN()),r.use(Tv.json({limit:Rv})),r.use(Tv.urlencoded({extended:!1,limit:Rv}));let o=tk();if(o.use("/tests",Ev),o.use("/modules",cv),o.use("/environments",uv),o.use("/projects",yv),o.use("/labels",Sv),o.use("/folders",mv),o.use("/settings",wv),o.use("/identify",gv),o.use("/entities",pv),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}
|
|
3856
|
-
${a.stack}`),l.status(500).send("Internal Server Error")}),n){let a=
|
|
3903
|
+
`),tokenLength:p}),d=[],p=0,u=m.length?[m[m.length-1].id]:[],h=!1);let g=l[c],f=za(g);p+=f,g.length>a&&(g=g.slice(0,a));let E=Array.from(g.matchAll(vw)).map(O=>O&&O.length>=3?{tagName:O[1],id:O[2]}:void 0).filter(O=>!!O),T=Array.from(g.matchAll(qN)).map(O=>O&&(O[2]||O[4])).filter(O=>!!O);T.reverse();let C=g.replace(/ id="[0-9]+"/g,"");d.push(C);for(let O of E)u.push(O.id),m.push(O);for(let O of T){let K=m[m.length-1];K&&K.tagName===O&&m.pop()}let R=m.some(O=>YN.includes(O.tagName)),L=l[c+1]??"",M=za(L),z=Array.from(L.matchAll(vw)).map(O=>O&&O.length>2?O[1]:void 0).filter(O=>!!O),k=z.some(O=>Tw.includes(O)),_=z.some(O=>KN.includes(O));p+M>=i&&(h=!0),p>=r&&(k&&!R||T.some(O=>JN.includes(O)))&&(h=!0),p>=o&&_&&!R&&(h=!0),c++}return d.length&&s.push({ids:u,content:d.join(`
|
|
3904
|
+
`),tokenLength:p}),s.forEach((g,f)=>{t.debug({chunk:g},`Chunk for page filtering (index ${f+1}/${s.length})`)}),{chunks:s}}var Xp=4e4,Zp=8e4;async function ao(n){let{serializedTree:e,logger:t,flagStore:r,softTokenLimit:o=Xp}=n;if(za(e)<o)return e;let a=r.isBooleanFlagEnabled("rag_v2"),s;a?s=Jp({serializedTree:e,options:xw,logger:t,maxCharacterLength:1e6}):s=Jp({serializedTree:e,options:Ew,logger:t,maxCharacterLength:3e6});try{return a?await U(ZN({...n,chunks:s.chunks}),{milliseconds:2e4}):await U(eM({...n,chunkResult:s}),{milliseconds:15e3})}catch(l){t.warn({err:l},"Error executing page filtering, attempting AI keyword fallback");try{return await QN({...n,chunks:s.chunks})}catch(c){return t.warn({err:c},"Error executing page filtering using keyword matching, using naive truncation"),e.slice(0,Zp*vi)}}}async function ZN({chunks:n,generator:e,description:t,type:r,logger:o,signal:i,tree:a,softTokenLimit:s=Xp,hardTokenLimit:l=Zp}){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 QN(n){let{type:e,description:t,generator:r,tree:o,logger:i,hardTokenLimit:a=Zp}=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 eM(n){let{description:e,generator:t,tree:r,logger:o,signal:i,chunkResult:a,softTokenLimit:s=Xp}=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 eu(n,e){if(!n.description)throw new A("ActionFailureError","Cannot locate element with empty description");return Nn({action:async()=>tM(n,e),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,browser:e.browser,logger:n.logger})}async function tM(n,e){let{disableCache:t,testContext:r,filterByViewport:o,skipWait:i,source:a,memory:s,logger:l}=n,{ctx:c,orgId:d,browser:p,localCodeEvalTools:u,generator:m,abortSignal:h,flagStore:g}=e,f=n.description,S=n.useMemory&&!t;r&&(f=await Gt({orgId:d,s:f,context:r,localTools:u,signal:h,logger:l,flagStore:g})),a&&(f=rM(f,a));let{serializedTree:w,tree:E}=await xr(p,{filterByViewport:o,abortSignal:h,skipWait:i,logger:l}),y,T=Date.now(),C;for(;!y&&Date.now()-T<3e3;){h.throwIfAborted();try{y=await p.screenshot({clearHighlights:!0,respectActiveFrame:!0,retries:2})}catch(B){C=B}}if(!y)throw new A("ActionFailureError",`Failed to take screenshot of page to locate element. The page may be unresponsive, or your machine might be severely resource constrained. Error: ${C?.message}`);let R=w,L=!1;R=await ao({type:"locator",description:f,serializedTree:w,flagStore:e.flagStore,tree:E,logger:l,generator:m}),R!==w&&(L=!0);let H=`data:image/jpeg;base64,${y.toString("base64")}`,z=await m.getElementLocation({browserState:R,goal:f,screenshot:H,source:a,memory:S?s:void 0},{disableCache:t,abortSignal:h,loggerTags:ze(l),useMemory:S});l.debug({usedRag:L,result:z},"Got locator result");let k=z.id>0;if(c?.details?.push({type:"AI_LOCATION",matched:k,pageState:R,ragUsed:L,thoughts:z.thoughts}),!k)throw new A("ActionFailureError",`Could not find any relevant element: ${z.thoughts}`);let{resolution:_,target:O,frameConfig:K}=await p.createTargetFromA11yId({id:z.id,description:f,targetSource:"AI",logger:l});if(_.a11yNode?.properties?.hidden&&_.a11yNode?.properties?.hidden!=="false")throw new A("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: ${_.displayString}`);return S&&(z.updatedMemory?O.memory={type:"GCS_TRACES",traces:z.updatedMemory}:s&&(O.memory=s)),{thoughts:z.thoughts,target:O,resolution:_,frameConfig:K,screenshot:H}}var nM=["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:"],Cw="<select> element:",Rw="text input or contenteditable element:",Aw="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:",Iw="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:",Pw="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:",Qp=[Cw,Rw,Aw,Iw,Pw,...nM];function Lw(n,e){if(n===e)return!0;for(let t of Qp){if(!n.startsWith(t))continue;let r=n.slice(t.length).trim();if(Qp.some(o=>e.startsWith(o)&&e.slice(o.length).trim()===r)||r===e.trim())return!0}return!!Qp.some(t=>e.startsWith(t)&&e.slice(t.length).trim()===n.trim())}function rM(n,e){if(!n||!e)return n;switch(e){case"SELECT_OPTION":return`${Cw} ${n}`;case"TYPE":return`${Rw} ${n}`;case"NEGATED_CHECK":return`${Aw}
|
|
3905
|
+
${n}`;case"NEGATED_ELEMENT_VISIBLE_CHECK":return`${Iw}
|
|
3906
|
+
${n}`;case"ELEMENT_CHECK":return`${Pw}
|
|
3907
|
+
${n}`;default:return n}}var oM=15;async function tu({command:n,logger:e,fixtures:t,useMemory:r}){if(!n.assertion.trim())throw new A("ActionFailureError","Assertion command is missing the assertion content");let{browser:o}=t,i=n.timeout?n.timeout*1e3:o.smartWaitingTimeout,a=iM(i),s=0,l=Date.now(),c,d,p;try{await Nn({action:()=>o.clearHighlights(),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,browser:o,logger:e})}catch(m){e.warn({err:m},"Failed to clear highlights before AI check, continuing...")}let u;for(;s<oM&&(!u||u-l<i);){t.abortSignal.throwIfAborted(),s!==0&&(e.info(`Waiting ${a}ms before retrying AI check`),await ee(a,t.abortSignal)),u=Date.now();try{let m=await Nn({action:async()=>{let h=await Ow(o,e,t.abortSignal);return d&&d.serializedTree===h.serializedTree&&d.screenshotBuff.equals(h.screenshotBuff)?!1:(d=h,Nw({command:n,state:h,fixtures:t,useMemory:r,useConsensus:!1,highlightElementsOnFailure:!1,attemptNumber:s,logger:e}))},frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,logger:e,browser:o});if(!m)continue;c=m;break}catch(m){t.abortSignal.throwIfAborted(),p=m instanceof Error?m:new Error(`${m}`),e.info({err:m},`AI check assert attempt ${s} failed, retrying...`)}finally{s++}}if(!c)try{c=await Nn({action:async()=>Nw({command:n,state:await Ow(o,e,t.abortSignal),fixtures:t,useMemory:r,useConsensus:!0,highlightElementsOnFailure:!0,attemptNumber:s,logger:e}),frameConfig:n.iframeUrl?{type:"url",url:n.iframeUrl}:void 0,logger:e,browser:o})}catch(m){t.abortSignal.throwIfAborted(),p=m instanceof Error?m:new Error(`${m}`)}finally{s++}if(!c){let m=`AI check still failing after ${s} attempts.`;throw p&&(m+=` Latest result: ${p.message}`),new A("AssertionFailureError",m,{lastScreenshotBuffer:d?.screenshotBuff})}return c.updatedMemory&&(n.cache={...n.cache,memory:{type:"GCS_TRACES",traces:c.updatedMemory}}),c}async function Ow(n,e,t){let[r,o]=await Promise.all([xr(n,{abortSignal:t,skipWait:!0,skipWaitForPageLoad:!0,logger:e}),n.screenshot({retries:1,respectActiveFrame:!0})]);return{...r,screenshotBuff:o}}async function Nw({command:n,state:e,fixtures:t,useConsensus:r,useMemory:o,highlightElementsOnFailure:i,attemptNumber:a,logger:s}){let{browser:l,generator:c,abortSignal:d}=t,p={type:"ASSERTION"},{serializedTree:u,tree:m}=e,h=e.screenshotBuff,g=l.url(),f=u;f=await ao({type:"assertion",serializedTree:u,description:n.assertion,flagStore:t.flagStore,tree:m,generator:c,logger:s,signal:d}),f!==u&&(p.ragUsed=!0),p.pageState=f;let S={goal:n.assertion,url:g,memory:o?n.cache?.memory:void 0,browserState:f,screenshot:h.toString("base64"),contextChoice:n.contextChoice},E=await(n.contextChoice==="VISION_ONLY"?(y,T)=>c.getVisualAssertionResult(y,T):(y,T)=>c.getAssertionResult(y,T))(S,{useConsensus:r,attemptNumber:a,useMemory:o,disableCache:!!n.disableCache,abortSignal:d,logger:s,loggerTags:ze(s)});if((E.result||i)&&E.relevantElements&&(p.relevantElementsSerialized=E.relevantElements.map(y=>l.getSerializedFormFromA11yId(y)).filter(y=>!!y),await aM(E.relevantElements,l,s)),!E.result)throw new A("AssertionFailureError",E.thoughts);return{succeedImmediately:!1,thoughts:E.thoughts,urlAfterCommand:g,afterScreenshotOverride:h,updatedMemory:o?E.updatedMemory:void 0}}function iM(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 aM(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 U(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 sM=3e4;async function Mw({command:n,logger:e,baseUrl:t,fetchImplementation:r=fetch}){let o=n.timeout??sM/1e3,i=new AbortController,a=Object.fromEntries(Object.entries(n.headers||{}).filter(([p,u])=>p&&u)),s;if(Go(n.url)&&(s=n.url),t&&Wo(n.url,t)&&(s=new URL(n.url,t).toString()),!s)throw new A("ActionFailureError",`Invalid URL: ${n.url}`);let c=await U((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 A("ActionFailureError",`GraphQL request timed out after ${o} seconds`);if(!c.ok){let p;try{p=await c.json()}catch{throw new A("ActionFailureError",`GraphQL request failed with status ${c.status}: ${await c.text()}`)}throw p?.errors?.length&&p?.errors[0]?.message?new A("ActionFailureError",`GraphQL request failed with status ${c.status}: ${p.errors[0].message}`):new A("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 Gl(n){try{return new RegExp(n)}catch(e){throw new A("UserConfigurationError",`The provided regex expression was invalid: ${e}`)}}async function kw(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 _w(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 Dw(n){return{request:{url:n.url(),method:n.method(),headers:await n.allHeaders(),...await kw(n)}}}async function Fw(n,e){let t=await e.response();if(t)return n.response={status:t.status(),headers:await t.allHeaders(),...await _w(t)},n}async function Uw(n){let e=n.request(),t=n.status(),r=n.headers(),o=await _w(n);return{request:{url:e.url(),method:e.method(),headers:e.headers(),...await kw(e)},response:{status:t,headers:r,...o},status:t,headers:r,...o}}var Ei=class{flagStore;orgId;options;storage;localCodeEvalTools;uploadedFileStorage;visualDiffScreenshotStorage;browser;generator;executeAbortController=new AbortController;logger;analytics;recordAbortController=null;registeredListeners={};recordedRequests={};constructor({browser:e,generator:t,logger:r,analytics:o,flagStore:i,storage:a,orgId:s,localCodeEvalTools:l,uploadedFileStorage:c,visualDiffScreenshotStorage:d,options:p}){this.orgId=s,this.options=p,this.browser=e,this.browser.registerAbortSignal(this.executeAbortController.signal),this.storage=a,this.uploadedFileStorage=c,this.visualDiffScreenshotStorage=d,this.localCodeEvalTools=l,this.generator=t,this.logger=r,this.analytics=o,this.flagStore=i}setOpen(){this.executeAbortController=new AbortController,this.browser.registerAbortSignal(this.executeAbortController.signal)}setClosed(){this.executeAbortController.abort()}throwIfClosed(){this.executeAbortController.signal.throwIfAborted()}get closed(){return this.executeAbortController.signal.aborted}async evaluateAiAction({goal:e,startingScreenshot:t,history:r,disableCache:o,langfuseSessionId:i,lastError:a,logger:s=this.logger}){let[l,c]=await Promise.all([xr(this.browser,{abortSignal:this.executeAbortController.signal,skipWait:!0,skipWaitForPageLoad:!0,logger:s}),this.browser.screenshot({retries:1,clearHighlights:!0})]),d=await ao({type:"ai-action",description:e,serializedTree:l.serializedTree,tree:l.tree,logger:s,generator:this.generator,flagStore:this.flagStore,softTokenLimit:25e3,hardTokenLimit:5e4}),p=`data:image/jpeg;base64,${c.toString("base64")}`,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([xr(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 ao({type:"ai-action",description:e,serializedTree:c.serializedTree,tree:c.tree,logger:a,generator:this.generator,flagStore:this.flagStore,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 A("InternalWebAgentError",`Error generating command: ${h instanceof Error?h.message:h}`,{errOptions:{cause:h}})}}async getBrowserState(e){return xr(this.browser,e)}async locateElement(e){return eu(e,this.getControllerFixtures())}async locateElementWithSelector(e,t){return Nn({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 A("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 Nn({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")&&Sd(i)){t.warn({err:i},"Invalid mpath error, retrying element targeting command");continue}if(!this.flagStore.isBooleanFlagEnabled("visual_actions")&&la(i)){t.warn({err:i},"Invalid momentic id error, retrying element targeting command");continue}if(i instanceof $n){t.warn({err:i},"Element bounding box moved error, retrying element targeting command");continue}throw i}throw r instanceof A?r:new A("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 A("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)&&!vc(o))throw new A("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&&!Lw(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&&nm(S);if(!S){let E=new Date;m.debug({targetHealingInProgress:p,cacheBustedBeforeAction:f,memory:a.memory,useMemory:h},"Prompting AI for an updated element location"),f&&await ee(this.browser.smartWaitingTimeout,this.executeAbortController.signal),g--;let y=await eu({description:o.elementDescriptor,disableCache:!!a.disableCache,iframeUrl:a.iframeUrl,source:u,useMemory:h,memory:h?a.memory:void 0,logger:m},this.getControllerFixtures(t));y.frameConfig&&this.browser.setActiveFrameConfig(y.frameConfig);let T=a.disableGlobalLocatorRedirect?{locator:y.resolution.locator}:await this.attemptLocatorRedirect(y.resolution.locator,m),C=await i(T);return p&&(r.heal({healType:"AI"}),this.analytics.track({type:"execution:step_heal",heal_type:"AI",step_type:"PRESET_ACTION",command_type:s.type,duration_ms:Date.now()-E.getTime()}),y.target.targetSource="AI_HEALED",y.target.targetUpdateTime=new Date().toUTCString(),y.target.targetUpdateLoggerTags=ze(m)),{result:C,elementInteractedDisplayString:y.resolution.displayString,newTarget:{cache:y.target,thoughts:y.thoughts}}}try{let E=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 T=a.disableGlobalLocatorRedirect?{locator:y.locator}:await this.attemptLocatorRedirect(y.locator,m),C=await i(T);if(w){let R=y.decisions.filter(L=>L.matched);if(R.length!==1)m.warn({decisions:y.decisions},"Expected exactly 1 matching method for element location, got more or less");else{let L=R[0].type;r.heal({healType:L}),this.analytics.track({type:"execution:step_heal",heal_type:L,step_type:"PRESET_ACTION",command_type:s.type,duration_ms:Date.now()-E.getTime()})}}return{result:C,elementInteractedDisplayString:y.displayString,newTarget:{cache:S}}}catch(E){this.throwIfClosed();let y=Yh(E)&&!Sd(E)&&!la(E)&&!(E instanceof $n);if(E instanceof A&&!y)throw 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 A("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 Fa(this.browser,e)}async executePresetCommand(e,t,r,o,i){this.options?.slowMoMs&&await ee(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 A("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")&&dm(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 Vy({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){Ry(e,t)}createCallbacksForBrowser(e){return{createIsolatedFolder:()=>_p(e)}}async resolveCommandTemplateStrings(e,t){return fi({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()?tu({command:s,fixtures:this.getControllerFixtures(e),useMemory:this.shouldUseMemory(),logger:a}):{succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"AI_ASSERTION":{if(!r.assertion.trim())throw new A("ActionFailureError","Missing assertion");if(r.timeout&&r.timeout>1800)throw new A("AssertionFailureError",`AI check timeout of ${r.timeout} exceeds the maximum allowed value of 30 minutes.`);return tu({command:r,fixtures:this.getControllerFixtures(e),useMemory:this.shouldUseMemory(),logger:a})}case"AI_EXTRACT":{if(!r.goal.trim())throw new A("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 A("ActionFailureError","No relevant data found for extraction goal on this page");if(f.thoughts?.includes("MaxGenerationLengthExceededError"))throw new A("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 A("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 A("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(!Go(r.url)&&!Wo(r.url,this.browser.baseUrl))throw new A("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 A("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 A("UserConfigurationError",`Wait timeout of ${r.delay} seconds exceeds the maximum allowed value of 30 minutes`);let c=r.delay*1e3;await ee(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 Xs(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 A("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:T,result:C}=await this.wrapElementTargetingCommand({ctx:e,tracer:t,command:r,target:r.target,cache:r.cache?.target,action:async R=>R.locator,options:{disableCache:i,...r}});S=C,w=T,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:Mr(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 Yn({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 A("ActionFailureError",g instanceof Error?g.message:`${g}`,{errOptions:{cause:g}})}try{JSON.stringify(h)}catch(g){throw new A("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=cM(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:T=>this.browser.typeIntoTarget(r.value,T,{force:r.force,clearContent:r.clearContent,forceClearContent:r.forceClearContent,delay:r.delay,pressEnter:r.pressEnter}),options:{...r,disableCache:i,disableGlobalLocatorRedirect:!0,source:Mr(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 Xs(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 Xs(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 dM,g=lM(fetch,h),f;try{f=new URL(r.url).hostname}catch{}return{data:{...await xl({command:r,baseUrl:this.browser.baseUrl,logger:a,fetchImplementation:g}),cookies:_s(h,f)},succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"GRAPHQL_REQUEST":return{data:await Mw({command:r,baseUrl:this.browser.baseUrl,logger:a}),succeedImmediately:!1,urlAfterCommand:this.browser.url()};case"VISUAL_DIFF":return zy({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 Ub({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 A("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 Yn({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 A("ActionFailureError",`Credentials must evaluate to an object (received ${typeof h} instead)`);let g;try{g=ks.optional().parse(h)}catch(f){throw new A("ActionFailureError",`Credentials provided do not follow the required format: ${f}`)}await this.browser.loadAuthState(g);break}case"ELEMENT_CHECK":{let h=(r.timeout??Rn)*1e3,g=await Uy({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 Nn({action:async()=>Tl({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=Gl(r.pattern),g=this.browser.registerRequestListener(h);return this.registeredListeners[r.key]=g.then(async f=>await Uw(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 A("ActionFailureError",`No listener registered with key: ${r.key}`);let g=r.timeout??10;return{data:await U(h,{milliseconds:g*1e3,message:`Request listener timed out after ${g} seconds`}),succeedImmediately:!1,urlAfterCommand:this.browser.url()}}case"RECORD_REQUESTS":{let h=Gl(r.pattern);return this.recordedRequests[r.key]=[],this.browser.registerRequestRecorder(r.key,h,async g=>{try{let f=await Dw(g);this.recordedRequests[r.key]?.push(f),await Fw(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 A("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=Gl(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 Bl({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 Tr}from"zod";var mse=Tr.object({useSelector:Tr.boolean().optional(),disableCache:Tr.boolean().optional(),iframeUrl:Tr.string().optional(),retriesWithAI:Tr.number().optional(),targetName:Tr.string().optional(),source:is.optional(),disableGlobalLocatorRedirect:Tr.boolean().optional(),targetHealingInProgress:Tr.boolean().optional(),memory:_i.optional()});var pM=4;async function Bw({socket:n,logger:e,analytics:t,storageFactory:r,uploadedFileStorage:o,visualDiffScreenshotStorage:i,serviceMocker:a,devicePixelRatio:s,generatorFactory:l,enricherFactory:c,browserbase:d,authorization:p,flagStoreFactory:u,settingsFactory:m,getOrgId:h}){let g=n.id,f=n.handshake.query.testId;if(!f)throw new Error("Socket connection request is missing testId");let S=await h({type:"e2e",testId:f});e=e.child({testId:f,orgId:S,sessionId:g});let w=await l(S,e),E=await c(S,e),y=await u(S),T=await m(S,e),C=await r(S),{testMetadata:R,baseUrl:L,envName:M,browserConfig:H,environmentVariables:z,localCodeEvalTools:k}=await so({testId:f,orgId:S,logger:e,storage:C,authorization:p,flagStore:y,settings:T}),_=Z.getSession(g);if(_)return e.info("Associating connection with existing session (likely reconnect)"),await _.controller.browser.clearAllCdpHighlights(),{type:"e2e",sessionId:g,orgId:S,testId:f};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&&Z.getCurrentConnectionsByIp(O)>=pM)throw e.error({clientIp:O,sessions:Z.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.");Z.reserveCapacityByIp(O);try{await uM({socket:n,baseUrl:L,envName:M,testMetadata:R,orgId:S,sessionId:g,logger:e,analytics:t,environmentVariables:z,clientIp:O,devicePixelRatio:s,storage:C,uploadedFileStorage:o,visualDiffScreenshotStorage:i,serviceMocker:a,localCodeEvalTools:k,generator:w,enricher:E,browserbase:d,browserConfig:H,flagStore:y})}catch(K){throw e.warn({err:K},"Error setting up socket session, possibly due to client closing the connection"),Z.releaseCapacityByIp(O),K}return{type:"e2e",sessionId:g,testId:f,orgId:S}}async function uM({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,clientIp:S,enricher:w,flagStore:E}){let y={viewport:o.advanced?.viewport??Jt,locale:o.advanced?.locale??_o,timezoneId:o.advanced?.timezone??Do,geolocation:o.advanced?.geolocation??Fo,colorScheme:o.advanced?.colorScheme};r&&(y.deviceScaleFactor=r);let T=o.id,C=await u?.initializeServicesForTest(i,T),R=await Ll({settings:f,orgId:i,baseUrl:e,envName:t,testName:o.name,localTools:m,envVariables:g,logger:s,customHeaders:void 0,flagStore:E});s=s.child({orgId:i,sessionId:a,testId:T});let L=!1,M=E.isBooleanFlagEnabled("icon_knowledge_base")?await c.fetchIconKnowledgeBase(s):null,H=await Fn.init({baseUrl:e,userBrowserSettings:R,enricher:w,storage:c,flagStore:E,mockedServices:C,logger:s,contextArgs:y,iconKnowledgeBase:M,callbacks:{onTabsChange:(K,B)=>{n.emit("tabs",{tabs:K,activeTab:B})},onScreencastFrame:(K,B)=>{let se=n;L&&(se=n.compress(!0)),se.emit("screenshot",{buffer:K},()=>{B()})},onSvgsCollected:K=>{n.emit("newIconDetected",{numIcons:K.newSvgs.length}),c.saveNewIcons(K,s)}}});await H.navigate({url:e,initialNavigation:!0});let z=new Ei({browser:H,generator:h,logger:s,analytics:l,flagStore:E,orgId:i,options:{scratchPadId:void 0,slowMoMs:R.slowMoMs,autoFollowNewTabs:R.autoFollowNewTabs,useMemory:o.advanced.useMemory},storage:c,localCodeEvalTools:m,uploadedFileStorage:d,visualDiffScreenshotStorage:p}),k=Sy(n,a,s),_=async()=>{k.timers.forEach(K=>clearInterval(K))},O=new Ot({baseUrl:e,testName:o.name,currentUrl:z.browser.url(),variablesFromEnvironment:g,envName:t});if(!n.connected)throw await H.cleanup(),new Error("Socket not connected anymore, not proceeding with session setup");n.emit("session",{url:e,userAgent:Fn.USER_AGENT,viewport:z.browser.getViewport(),sessionId:a}),Z.registerSession({controller:z,context:O,sessionId:a,cleanup:_,clientIp:S})}async function so({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 Ft({...o,logger:t}),fakerSeed:void 0}));let c=s.envs?.find(g=>g.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};return await Promise.all((s.parameters??[]).map(async g=>{let f=await Gt({orgId:e,s:g.defaultValue,context:Ot.dummyContext(s.name,d?.name,h),logger:t,flagStore:i,localTools:l});h[g.name]=f})),{localCodeEvalTools:l,baseUrl:m,envName:d?.name,testName:s.name,browserConfig:u,environmentVariables:h,testMetadata:s}}var nu=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 Wl({parentStep:this.step,socket:this.socket,parentTracer:this})}},Wl=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 nu({step:e.step,parentTracer:this,socket:this.socket})}},Vl=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 Wl({parentStep:null,parentTracer:null,socket:this.socket})}};var ru={currentlyExecutingRequests:{}},hM=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 so({testId:r,orgId:o,logger:n.logger,storage:s,authorization:n.authorization,flagStore:i,settings:a}),d=`${r}|${c.baseUrl}`;try{let p=ru.currentlyExecutingRequests[d]??0;ru.currentlyExecutingRequests[d]=p+1,l=await gM({...n,...e,...c,done:t})}finally{n.logger.info({result:l,sessionId:n.metadata.sessionId},"Test execution complete"),ru.currentlyExecutingRequests[d]--}},gM=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,T=Z.getSession(w);if(!T)throw new Error("No active session found");let{controller:C,context:R}=T;C.setOpen(),c=c.child({testId:S,orgId:E,sessionId:w,runId:y}),c.info({steps:e.map(J=>`${J.type}${"command"in J?` - ${J.command.type}`:""}`),toStep:i,fromStep:a,reInitialize:o,envName:p,testName:u,baseUrl:t,context:R,flags:C.flagStore.getAllFlags()},"Socket execution parameters");let L=m??{},M=async()=>{o&&(await C.browser.reset({newUrl:t}),R.reset({baseUrl:t,currentUrl:C.browser.url(),variablesFromEnvironment:L,envName:p,testName:u}))},H=await s(E),z=await f(E),k=async()=>{try{await z.resolveStepCacheEntries({schemaVersion:r.schemaVersion,testId:S,stepLists:{steps:e},logger:c})}catch(J){c.error({err:J},"Failed to fetch step cache entries from Momentic server. This can drastically reduce test reliability and performance.")}};try{await ha({promiseGenerator:async()=>Promise.all([M(),k()]),signal:C.executeAbortController.signal,codePath:"resolveStepCacheAndInitBrowser"}),C.setOpen()}catch(J){if(n.emit("finished"),J.name!=="AbortError")throw new Error(`Failed to setup browser for execution: ${J}`)}let _=mM(e),O={collectDebugData:!1,reinitializeBrowser:!1,disableHealing:!0},K={orgId:E,runId:y,testMetadata:r,steps:e,fromStep:a,toStep:i},B={controller:C,context:R,storage:H,debugDataStorage:new Br,codeEvalTools:h,billingReporter:new jo,logger:c,analytics:d},se={test:{},step:{onDynamicAIActionStatusUpdateEvent:J=>{n.emit("dynamicCommandStatusUpdate",J)},onDynamicAIActionEvaluatingEvent:J=>{n.emit("dynamicCommandEvaluating",J)},onDynamicCommandGenerated:J=>{n.emit("dynamicCommandGenerated",J)},onDynamicCommandExecuted:J=>{n.emit("dynamicCommandExecuted",J)}}},le=new Vl(n,H,E,S,_),fe=await Pl({fixtures:B,options:O,callbacks:se,inputs:K,testParams:{tracer:le}});return fe?.status==="PASSED"&&await $s({logger:c,cacheStorage:z,orgId:E,testId:S,originalSteps:{steps:_},updatedSteps:{steps:e}}),await le.finish(),g?.(fe),fe.status};var zw={event:"execute",createHandler:hM};import{cloneDeep as fM}from"lodash-es";var SM=n=>async({command:e},t)=>{let{logger:r,generatorFactory:o,metadata:i}=n,a=fM(e),s=vf(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})}}},Hw={event:"lintStep",createHandler:SM};var yM=({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=Z.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=Uo.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:Mr(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}),T=await h.uploadScreenshot(w);f.screenshot={data:T,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...")}}},jw={event:"locate",createHandler:yM};var bM=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({event:r,percentX:o,percentY:i})=>{let a=Z.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")}}},$w={event:"mouseClickEvent",createHandler:bM};var wM=({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=Z.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})}},Gw={event:"recordTargetClick",createHandler:wM};var vM=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({key:r})=>{let o=Z.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}}},Ww={event:"keyDownEvent",createHandler:vM};var EM=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async({key:r})=>{let o=Z.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}}},Vw={event:"keyUpEvent",createHandler:EM};var xM=({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=Z.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")}}},qw={event:"mouseMoveEvent",createHandler:xM};var TM=({metadata:n,generatorFactory:e,socket:t,logger:r})=>{let{sessionId:o,orgId:i,testId:a}=n;return async({stepId:s})=>{let l=Z.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}}},Kw={event:"recordingStart",createHandler:TM};var CM=({metadata:n,logger:e})=>{let{sessionId:t}=n;return async()=>{let r=Z.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}},Yw={event:"recordingStop",createHandler:CM};var RM=({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 so({testId:c,orgId:p,logger:t,storage:h,authorization:o,flagStore:u,settings:m}),f=Z.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()},Jw={event:"refresh",createHandler:RM};var AM=({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 so({testId:s,orgId:c,logger:t,storage:u,authorization:o,flagStore:d,settings:p}),S=Z.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 T=w.browser.getViewport(),C=Fn.USER_AGENT;t.info({baseUrl:m,viewport:T},`Session reset for test ${s} at ${y}`),n.emit("session",{url:y,userAgent:C,viewport:T,sessionId:l})},Xw={event:"reset",createHandler:AM};var IM=({metadata:n})=>{let{sessionId:e}=n;return async({url:t})=>{let r=Z.getSession(e);if(!r)throw new Error("No active session found");await r.controller.browser.switchToPage({type:"SUBSTRING",substring:t})}},Zw={event:"switchTab",createHandler:IM};async function Qw(n){let{socket:e}=n;return e.handshake.query.type==="api-test"?Py(n):Bw(n)}var ev=[ky,zw,jw,Xw,Jw,Oy,Zw,Hw,Gw,Kw,Yw,qw,$w,Ww,Vw,Ly,yy,My,Ny];var tv=n=>{let{logger:e}=n,t=new PM(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 Qw({...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}ev.forEach(i=>LM(i,{socket:r,metadata:o,...n,logger:e}))}),t},LM=(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 zM}from"express";import su from"fs";import _M from"path";import rv,{multistream as OM}from"pino";import NM from"pino-pretty";var nv=["lastScreenshotBuffer"];var ou=new Map,MM=!0,iu=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=MM?rv(i):rv(i,OM([{stream:NM({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))nv.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}},ql=({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 ou.has(n)||ou.set(n,new iu({bindings:{app:n},hostname:t,clientToken:e||process.env.NEXT_PUBLIC_DD_CLIENT_TOKEN||process.env.DD_CLIENT_TOKEN,disableConsoleLogs:r})),ou.get(n)};import{hostname as kM}from"os";var Ge=ql({app:"desktop-server",clientToken:"pubcfd7516a5c0ba852b42675cd97bee027",hostname:kM(),disableConsoleLogs:!0}),ov=n=>{Ge.addBinding("version",n)};var DM=new bl(30,60*1e3),du="https://api.momentic.ai",pu,au,iv=n=>{du=n},Kl=()=>du,av=(n,e)=>{pu=n,au?.abort(),au=new AbortController;let t=au.signal,r=[n.configFilePath];n.config.environments?.forEach(o=>{if(!o.envFile)return;let i=_M.resolve(n.rootDir,o.envFile);try{if(su.lstatSync(i).isSymbolicLink())return;su.existsSync(i)&&r.push(i)}catch(a){Ge.warn({err:a},`Failed to check if env file ${i} exists`)}});try{FM({filesToWatch:r,revalidator:e,signal:t,project:n})}catch(o){Ge.error({err:o},"Failed to start config file watchers")}},re=()=>pu,xi,lu,cu,sv=async n=>{if(xi)return xi;let e=new ct({baseUrl:du,apiKey:n,logger:Ge});try{let t=await e.getAuthInfo();return xi=t.orgId,lu=t.userId,cu=n,xi}catch(t){throw new Error(`Error checking API key against server: ${t}`)}},Xn=()=>{if(!xi)throw new Error("Your organization ID is invalid.");return xi},Yl=()=>{if(!lu)throw new Error("Your user ID is invalid.");return lu},lv=()=>{if(!cu)throw new Error("Your API key is invalid.");return cu};function FM({filesToWatch:n,revalidator:e,signal:t,project:r}){n.forEach(o=>{su.watch(o,{signal:t,persistent:!1,recursive:!1},(i,a)=>{a&&(DM.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.`),pu=e(r.configFilePath))})})}var Jl=class extends pi{constructor(t,r){super(t,r);this.client=t;this.orgId=r}async fetchTestMetadata(t,r){let o=re(),a=ve(o,r).tests[t];if(a)return Qs(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 Sa(t,o,zr)}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 ae(n){return function(...e){let t=e[e.length-1],r=n(...e);Promise.resolve(r).catch(t)}}import{Router as UM}from"express";import cv from"fs";import BM from"path";var Ha=UM();async function uu(n){return(await Zs(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)}Ha.get("/",ae(async(n,e)=>{let t=re(),r=ve(t,b),o=await uu(r);e.status(200).json(o)}));Ha.post("/",ae(async(n,e)=>{let t;try{t=og.parse(n.body)}catch(s){e.status(400).json({error:`Invalid request body: ${s}`});return}try{Ho(t.name)}catch(s){e.status(400).json({error:`Invalid module name: ${s}`});return}let r=re(),o=ve(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=BM.join(r.rootDir,t.folderPath??"");if(!cv.existsSync(i)||!cv.statSync(i).isDirectory()){e.status(400).json({error:`The folder configured for module creation '${i}' does not exist.`});return}let a=await nS({...t,folder:i,project:r});e.status(201).json(a)}));Ha.get("/:moduleId",ae(async(n,e)=>{if(!n.params.moduleId){e.status(400).json({error:"Missing moduleId in url path."});return}let t=ve(re(),b),r=t.modules[n.params.moduleId];if(!r){e.status(404).json({error:"Module not found."});return}try{let o=await _d(r,t,b);e.json(o)}catch(o){e.status(400).json({err:o})}}));Ha.patch("/:moduleId/metadata",ae(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(i){e.status(400).json({error:`Invalid request body: ${i}`});return}let r=re(),o=ve(r,b);tS({moduleId:n.params.moduleId,content:t,momenticFiles:o,logger:b,project:r}),e.status(201).json({message:"ok"})}));var dv=Ha;var pv=zM();pv.get("/",ae(async(n,e)=>{let t=re(),r=ve(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 uu(r),l={labels:i,tests:a,modules:s};e.status(200).json(l)}));var uv=pv;import{Router as HM}from"express";var mu=HM();mu.get("/",ae((n,e)=>{let t=sS(re(),Ge);e.status(200).json(t)}));mu.get("/names",ae((n,e)=>{let r=re().config.environments?.map(o=>o.name)??[];e.status(200).json(r)}));var mv=mu;import{Router as jM}from"express";import ft from"fs";import it from"path";var $a=jM();function ja(n){let e=re(),t=it.dirname(e.configFilePath);return it.join(t,...n)}function $M(n){let e=re(),t=it.dirname(e.configFilePath),r=it.relative(t,n);return r?r.split(it.sep):[]}function GM(n,e){let t=ft.statSync(n),r=$M(n);return bd.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})}$a.post("/",ae(async(n,e,t)=>{let r;try{r=lg.parse(n.body).pathSegments}catch(l){e.status(400).json({error:`Failed to parse folder read body: ${l}`});return}let o=ja(r);if(!ft.existsSync(o)){e.status(404).json({error:`Path not found: ${r.join(it.sep)}`});return}if(!ft.statSync(o).isDirectory()){e.status(400).json({error:`Path is not a directory: ${r.join(it.sep)}`});return}let a=ft.readdirSync(o).map(l=>{let c=it.join(o,l);return GM(c,l)}),s={absolutePath:o,pathSegments:r,contents:a};e.status(200).json(s)}));$a.put("/",ae(async(n,e,t)=>{let r;try{r=cg.parse(n.body).pathSegments}catch(a){e.status(400).json({error:`Failed to parse folder create body: ${a}`});return}let o=ja(r);if(ft.existsSync(o)){e.status(200).json({success:!0,message:`Folder already exists: ${r.join(it.sep)}`,pathSegments:r});return}ft.mkdirSync(o,{recursive:!0});let i={success:!0,message:`Folder created: ${r.join(it.sep)}`,pathSegments:r};e.status(201).json(i)}));$a.patch("/",ae(async(n,e,t)=>{let r,o;try{let c=dg.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=ja(r),a=ja(o);if(!ft.existsSync(i)){e.status(400).json({error:`Folder not found: ${r.join(it.sep)}`});return}if(ft.existsSync(a)){e.status(400).json({error:`Destination already exists: ${o.join(it.sep)}`});return}let s=it.dirname(a);ft.existsSync(s)||ft.mkdirSync(s,{recursive:!0}),ft.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)}));$a.delete("/",ae(async(n,e,t)=>{let r,o=!0;try{let l=pg.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=ja(r);if(!ft.existsSync(i)){e.status(200).json({success:!0,message:`Folder not found: ${r.join(it.sep)}`,pathSegments:r});return}if(!ft.statSync(i).isDirectory()){e.status(400).json({error:`Path is not a directory: ${r.join(it.sep)}`});return}if(o)ft.rmSync(i,{recursive:!0,force:!0});else{if(ft.readdirSync(i).length>0){e.status(409).json({error:`Cannot delete non-empty directory without recursive flag: ${r.join("/")}`});return}ft.rmdirSync(i)}let s={success:!0,message:`Folder deleted: ${r.join("/")}`,pathSegments:r};e.status(200).json(s)}));var hv=$a;import{Router as WM}from"express";var gv=WM();gv.get("/",ae((n,e)=>{e.status(200).json({userId:Yl(),orgId:Xn()})}));var fv=gv;import{Router as VM}from"express";var Sv=VM();Sv.get("/",ae((n,e)=>{let t=re(),r=ve(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 yv=Sv;import{Router as qM}from"express";var Xl=qM();Xl.get("/",ae((n,e)=>{let t=cp().map(r=>({name:r.config.name,configFilePath:r.configFilePath}));e.status(200).json(t)}));Xl.get("/current",ae((n,e)=>{let t=re(),r={name:t.config.name,configFilePath:t.configFilePath};e.status(200).json(r)}));Xl.post("/set",ae((n,e)=>{let t;try{t=sg.parse(n.body)}catch(r){e.status(400).json({error:`Invalid request body: ${r}`});return}try{let r=$t({configFilePath:t.configFilePath});av(r,o=>$t({configFilePath:o}))}catch(r){e.status(400).json({error:`Error setting project: ${r}`});return}e.sendStatus(204)}));var bv=Xl;import{Router as KM}from"express";var wv=KM();wv.get("/",ae((n,e)=>{let r={ai:re().config.ai};e.status(200).json(r)}));var vv=wv;import{Router as XM}from"express";import Ev from"fs";import lo from"path";import{v4 as xv}from"uuid";import ZM from"yaml";import{randomUUID as YM}from"node:crypto";import{PostHog as JM}from"posthog-node";var Ti=class{identify(){return this}child(){return this}track(){return this}async shutdown(){}},Ci=class n{bindings;client;options;constructor(e,t={}){this.bindings=e,this.options=t,this.client=new JM("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:YM(),event:r,timestamp:t?.timestamp,properties:{...this.bindings,...o}}),this}};var Ri=new Ci({platform:"local_app"},{flushAt:1,flushInterval:0});var Cr=XM();Cr.get("/",ae((n,e)=>{let t=re(),r=ve(t,b),o=Object.values(r.tests);e.status(200).json(o)}));Cr.post("/",ae(async(n,e)=>{let t;try{t=ng.parse(n.body)}catch(p){e.status(400).json({error:`Invalid request body: ${p}`});return}try{Ho(t.name)}catch(p){e.status(400).json({error:p.message});return}let o={id:xv(),name:t.name,description:t.description,baseUrl:t.baseUrl,schemaVersion:De,advanced:{disableAICaching:!1,browserType:t.browserType??"Chromium",viewport:t.viewport??Jt},retries:0,steps:[]};t.environment&&(o.envs=[{name:t.environment,default:!0}]);let i=re(),a=ve(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=lo.join(i.rootDir,...t.pathSegments||[]),c=await oS({test:o,name:t.name,folder:l}),d={...o,relativeFilePath:lo.relative(i.rootDir,c)};Ri.track({type:"test_editor:test_create"}),e.status(201).json(d)}));Cr.get("/:testPath",ae(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=ve(r,b),i;try{i=await fa(lo.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 Dt({stepLists:{steps:i.steps,beforeSteps:i.beforeSteps,afterSteps:i.afterSteps}});s.forEach(l=>{Jr({content:l,schemaVersion:De,momenticFiles:o,project:r})}),Vn({relativeTestPath:t,steps:a,schemaVersion:De,project:r})}catch(a){Ge.error({err:a},"Failed to save migrated test to disk after initial fetch")}})()}));Cr.patch("/:testPath/metadata",ae(async(n,e)=>{if(!n.params.testPath){e.status(400).json({error:"Missing testPath in url path."});return}let t;try{t=tg.parse(n.body)}catch(i){e.status(400).json({error:`Invalid request body: ${i}`});return}let o={message:"ok",newRelativeTestPath:Dd(n.params.testPath,t,re()).newRelativeTestPath};e.status(200).json(o)}));Cr.patch("/:testPath",ae(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=eg.parse(n.body)}catch(m){e.status(400).json({error:`Invalid request body: ${m}`});return}let o=re(),i=ve(o,b),a;try{a=Qs(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 Dt({stepLists:r.stepLists,cacheCreationParams:{testId:a.id,orgId:Xn()}}),d=new ct({apiKey:lv(),baseUrl:Kl(),logger:Ge}),p=await ci(Ge,d,o);await gi({orgId:Xn(),client:d,gitMetadata:p}).saveStepCacheEntries({logger:Ge,testId:a.id,entries:c}),l.forEach(m=>{Jr({content:m,schemaVersion:r.schemaVersion,momenticFiles:i,project:o})}),Vn({relativeTestPath:t,steps:s,schemaVersion:r.schemaVersion,project:o}),e.status(201).json({message:"ok"})}));Cr.patch("/:testPath/environments",ae(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=ag.parse(n.body)}catch(o){e.status(400).json({error:`Invalid request body: ${o}`});return}Dd(t,{envs:r.defaultEnv?[{name:r.defaultEnv,default:!0}]:[]},re()),e.status(201).json({message:"ok"})}));Cr.post("/:testPath/duplicate",ae(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=rg.parse(n.body)}catch(f){e.status(400).json({error:`Invalid request body: ${f}`});return}try{Ho(r.name)}catch(f){e.status(400).json({error:f.message});return}let o=re(),i=lo.join(o.rootDir,t);if(!Ev.existsSync(i)){e.status(404).json({error:"Test not found."});return}let a=ve(o,b),s;try{s=await fa(i,Ge,a)}catch(f){e.status(400).send({error:f.message});return}let l=xv(),c=tn.parse({...s,name:r.name,id:l}),{stepsToSave:d}=await Dt({stepLists:{steps:s.steps,beforeSteps:s.beforeSteps,afterSteps:s.afterSteps},createNewCacheIds:!0,cacheCreationParams:{testId:l,orgId:Xn()}}),p=Gn({fileType:Ie.TEST,...c,beforeSteps:d.beforeSteps??void 0,steps:d.steps,afterSteps:d.afterSteps??void 0}),u=lo.dirname(i),m=lo.join(u,`${r.name}.${_t.TEST}`),h=ZM.stringify(p);Ev.writeFileSync(m,h,"utf-8");let g={relativeFilePath:lo.relative(o.rootDir,m)};Ri.track({type:"test_editor:test_create"}),e.status(201).json(g)}));var Tv=Cr;var Ga=class{async prepareGoldenScreenshotForComparison(e,t,r){return await new si(re(),!1).prepareGoldenScreenshotForComparison(e,t,r)}};async function Iv(n){let{momenticServerUrl:e,apiKey:t,serverPort:r,staticDir:o,devicePixelRatio:i,version:a,logger:s=Ge,alwaysSaveCache:l,noCache:c}=n;ov(a),e&&iv(e),await sv(t);let d=Xn(),p=Yl();Ri.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=ik(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(T){T.message.includes("EADDRINUSE")?Pv(r):b.error(`An unexpected error occurred while starting the server: ${T.message}`),process.exit(1)}});let g={type:"API_KEY",baseUrl:Kl(),apiKey:t,logger:s},f=async()=>{let y=re();return new mi(y.config.ai?.agentConfig,g)},S=async()=>new hi(g,await f()),w=new ct(g),E=new Ga;tv({baseServer:u,getOrgId:async()=>Xn(),generatorFactory:f,enricherFactory:S,cacheStorageFactory:async y=>{let T=re(),C=await ci(s,w,T);return gi({orgId:y,client:w,gitMetadata:C,alwaysSaveCache:l,noCache:c})},flagStoreFactory:async y=>{let T=re();return new li(T.config)},settingsFactory:async()=>{let y=re();return{ai:{},browser:{},...y.config}},storageFactory:async y=>new Jl(w,y),logger:s,devicePixelRatio:i,authorization:g,visualDiffScreenshotStorage:E,analytics:Ri})}var Av="25mb";function ik(n,e,t){let r=Rv();r.use(QM()),r.use(Cv.json({limit:Av})),r.use(Cv.urlencoded({extended:!1,limit:Av}));let o=nk();if(o.use("/tests",Tv),o.use("/modules",dv),o.use("/environments",mv),o.use("/projects",bv),o.use("/labels",yv),o.use("/folders",hv),o.use("/settings",vv),o.use("/identify",fv),o.use("/entities",uv),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}
|
|
3908
|
+
${a.stack}`),l.status(500).send("Internal Server Error")}),n){let a=Rv.static(n,{setHeaders:s=>{s.setHeader("Cache-Control","no-cache")},redirect:!1});r.use(a),r.use("*",(s,l)=>{l.sendFile(ok.join(n,"index.html"))})}let i=rk.createServer(r);return i.once("error",a=>{"code"in a&&a.code==="EADDRINUSE"?(Pv(e),process.exit(1)):console.error("An unexpected server error occurred:",a.message)}),i}tk.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 Pv(n){b.error(ek`Port ${n} is already in use by another process. Please close the other process and try again.
|
|
3857
3909
|
Using Bash on MacOS or Linux:
|
|
3858
3910
|
lsof -t -i :58888 | xargs kill -9
|
|
3859
3911
|
|
|
3860
3912
|
Using Command Prompt on Windows:
|
|
3861
3913
|
for /f "tokens=5" %a in ('netstat -ano ^| findstr :58888') do taskkill /PID %a /F
|
|
3862
|
-
`)}import
|
|
3914
|
+
`)}import w_ from"events";import yc from"fs";import v_ from"open";import Sc from"path";import{fileURLToPath as E_}from"url";import Tk from"diff-lines";import{gt as Ck}from"semver";import{execSync as ak}from"child_process";import{platform as sk}from"os";function hu(){return Lv()?(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.
|
|
3863
3915
|
`),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.
|
|
3864
|
-
l.`),1)}function Pv(){return ak()==="darwin"&&ik("system_profiler SPDisplaysDataType").toString().includes("Retina")}function fu(n){Pv()&&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 sk from"@actions/exec";import lk from"@actions/io";import ck from"quote";import dk from"string-argv";async function Lv(n,e=!0){let t=dk(n),r=await lk.which(t[0],!0),o=t.slice(1),i=sk.exec(ck(r),o,{delay:100});if(e)return i}import{existsSync as pk,statSync as uk}from"fs";var Ii=!!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 Ov(n){try{return pk(n)&&uk(n).isDirectory()}catch(e){return b.error({err:e},`Error reading path ${n} during directory existence check`),!1}}import mk from"csv-parser";import{createReadStream as hk}from"fs";function Su(n){return new Promise((e,t)=>{let r=[];hk(n).pipe(mk()).on("data",o=>r.push(o)).on("end",()=>e(r)).on("error",o=>t(o))})}import Zl from"semver";import{z as Ql}from"zod";var vn="2.6.3",gk="https://registry.npmjs.org/momentic",fk=Ql.object({versions:Ql.record(Ql.string(),Ql.unknown()).optional()});async function Mv(n){try{await Sk(n)}catch(e){b.warn({err:e},"Failed to check CLI version against NPM servers")}}async function Sk(n){if(!vn){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 U(fetch(gk),{milliseconds:5e3});if(!o.ok)throw new Error(`Got error status code ${o.statusText}`);let i=await o.json();e=fk.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))Zl.valid(r)&&(!t||Zl.gt(r,t))&&Zl.gt(r,vn)&&Zl.lt(r,"2.0.0")&&!r.includes("alpha")&&(t=r);t&&(b.warn(`Update available: v${vn} -> 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 bk,mkdirSync as wk,statSync as vk}from"fs";import{dirname as xk}from"path";import kv from"readline/promises";import{hostname as yk}from"os";var te=ql({app:"cli",clientToken:"pub7eb923f18fb3f1d42ac5eba8c5ea13a5",hostname:yk(),disableConsoleLogs:!0}).child({version:"2.6.3"});var yu=!1,_v=(()=>{try{return vk("/.dockerenv"),!0}catch{return!1}})();async function St(n,e){if(Ii||yu||_v)return!0;te.flush(),await new Promise(a=>setTimeout(a,500));let t=kv.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"?(yu=!0,setTimeout(()=>{yu=!1},3e3),!0):i.toLowerCase()==="y"}async function bu(n){let e=xk(n);return Ov(e)?bk(n)?St(`File '${Nv(n)}' already exists. Overwrite existing content?`,!0):!0:await St(`Directory '${Nv(e)}' doesn't exist. Create it now?`,!0)?(wk(e,{recursive:!0}),!0):!1}function Nv(n){return n.replace(/(\s+)/g,"\\$1")}async function Dv(n,e){if(Ii||_v)return e;let t=kv.createInterface({input:process.stdin,output:process.stdout}),r=await t.question(`${n} `);return t.close(),r.trim()||e}async function Fv({test:n,fragment:e,entities:t,client:r,logger:o,yes:i}){Tk(e.schemaVersion,De)&&(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)),mf(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 St("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 St("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=Qr(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!==De){let{steps:g,newVersion:f}=await ua({metadata:{id:e.id,schemaVersion:e.schemaVersion},steps:e.steps,logger:b});d=f,p=Pe.array().parse(g)}else p=Pe.array().parse(e.steps);let{stepsToSave:u,moduleUpdates:m}=await Dt({stepLists:{steps:p}});u.beforeSteps=l.beforeSteps??void 0,u.afterSteps=l.afterSteps??void 0;let h=Ek(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 St("Do you want to apply this patch?")&&(b.dimmed("Cancelled."),process.exit(1)),Vn({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 mo}from"crypto";import{z as tx}from"zod";var Wt=" ".repeat(6);import ex from"chalk";import{Argument as po,Option as Me}from"@commander-js/extra-typings";import{validateHeaderValue as Ck}from"http";import{cpus as Uv}from"os";import{parse as Phe}from"yaml";import{z as q}from"zod";var ec=58888,wu=30*60*1e3,Zn=new Me("--api-key <key>","API key for authentication. If not supplied, attempts to read the MOMENTIC_API_KEY env var."),Qn=new Me("--server <server>","Momentic server to use. Leave unchanged unless using Momentic on-premise."),uo=new Me("-y, --yes","Skip all confirmation prompts.").env("CI"),vu=new Me("-w, --wait","Wait for tests to finish running before exiting. Only applicable when running tests remotely").implies({remote:!0}),xu=new Me("--wait-timeout <waitTimeout>",`The maximum number of seconds to wait for tests to complete. Only applicable when the --wait option is specified. Defaults to ${wu/1e3} seconds.`),tc=new Me("--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."),zv=new Me("--reporter <reporter>","Output report files in a standardized format to a local directory. See the --reporter-dir flag for information on the output directory.").choices(Object.values(ra)),Hv=new Me("--reporter-dir <reporterDir>","Output directory to store report files. Relative paths are resolved relative to the project root, which is defined by the detected momentic.config.yaml. Defaults to 'reports' if unset."),Eu=new Me("--output-dir <outputDir>","[Alpha] Output directory to store run artifacts such as screenshots, results, and logs. Relative paths are resolved relative to the project root, which is defined by the detected momentic.config.yaml. This directory will be cleared at the start of execution."),jv=new Me("--upload-results","Upload test results to Momentic Cloud. By default, this option is disabled."),Tu=new Me("--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 Me("--exclude <excludePatterns...>","The inverted version of --include: a test that matches any of the provided exclusion patterns will be excluded from running."),Ru=new Me("--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."),$v=new Me("--port <port>",`Port to run the app on. Defaults to ${ec}.`),Au=new Me("--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."),nc=new Me("--env <env>","Name of the environment to use when running tests."),rc=new Me("--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."),Gv=new Me("--shard-index <shardIndex>","The index of the shard to run tests for. Defaults to 1.").default(1).argParser(n=>parseInt(n,10)),xn=new Me("-c, --config <configPath>","Absolute or relative path to a Momentic configuration file (*.momentic.config.yaml)"),oc=new Me("-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."),Wv=new Me("--shard-count <shardCount>","The number of shards that tests are being run on. Defaults to 1.").default(1).argParser(n=>parseInt(n,10)),Vv=new Me("--fix","Attempt to fix any issues found. This option will write changes to your local file system."),Iu=new Me("--save-cache","Always save updated step caches after successful test runs. By default, caches are not saved when running on the protected branches configured in the momentic.config.yaml.").env("CI"),Pu=new Me("--disable-cache","Disable caching of test results. This will cause all tests to be re-run every time."),qv=new po("<tests...>",`One or more test paths to queue on Momentic Cloud.
|
|
3916
|
+
l.`),1)}function Lv(){return sk()==="darwin"&&ak("system_profiler SPDisplaysDataType").toString().includes("Retina")}function gu(n){Lv()&&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 lk from"@actions/exec";import ck from"@actions/io";import dk from"quote";import pk from"string-argv";async function Ov(n,e=!0){let t=pk(n),r=await ck.which(t[0],!0),o=t.slice(1),i=lk.exec(dk(r),o,{delay:100});if(e)return i}import{existsSync as uk,statSync as mk}from"fs";var Ai=!!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 Nv(n){try{return uk(n)&&mk(n).isDirectory()}catch(e){return b.error({err:e},`Error reading path ${n} during directory existence check`),!1}}import hk from"csv-parser";import{createReadStream as gk}from"fs";function fu(n){return new Promise((e,t)=>{let r=[];gk(n).pipe(hk()).on("data",o=>r.push(o)).on("end",()=>e(r)).on("error",o=>t(o))})}import Zl from"semver";import{z as Ql}from"zod";var vn="2.6.5",fk="https://registry.npmjs.org/momentic",Sk=Ql.object({versions:Ql.record(Ql.string(),Ql.unknown()).optional()});async function Mv(n){try{await yk(n)}catch(e){b.warn({err:e},"Failed to check CLI version against NPM servers")}}async function yk(n){if(!vn){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 U(fetch(fk),{milliseconds:5e3});if(!o.ok)throw new Error(`Got error status code ${o.statusText}`);let i=await o.json();e=Sk.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))Zl.valid(r)&&(!t||Zl.gt(r,t))&&Zl.gt(r,vn)&&Zl.lt(r,"2.0.0")&&!r.includes("alpha")&&(t=r);t&&(b.warn(`Update available: v${vn} -> 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 wk,mkdirSync as vk,statSync as Ek}from"fs";import{dirname as xk}from"path";import _v from"readline/promises";import{hostname as bk}from"os";var te=ql({app:"cli",clientToken:"pub7eb923f18fb3f1d42ac5eba8c5ea13a5",hostname:bk(),disableConsoleLogs:!0}).child({version:"2.6.5"});var Su=!1,Dv=(()=>{try{return Ek("/.dockerenv"),!0}catch{return!1}})();async function St(n,e){if(Ai||Su||Dv)return!0;te.flush(),await new Promise(a=>setTimeout(a,500));let t=_v.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"?(Su=!0,setTimeout(()=>{Su=!1},3e3),!0):i.toLowerCase()==="y"}async function yu(n){let e=xk(n);return Nv(e)?wk(n)?St(`File '${kv(n)}' already exists. Overwrite existing content?`,!0):!0:await St(`Directory '${kv(e)}' doesn't exist. Create it now?`,!0)?(vk(e,{recursive:!0}),!0):!1}function kv(n){return n.replace(/(\s+)/g,"\\$1")}async function Fv(n,e){if(Ai||Dv)return e;let t=_v.createInterface({input:process.stdin,output:process.stdout}),r=await t.question(`${n} `);return t.close(),r.trim()||e}async function Uv({test:n,fragment:e,entities:t,client:r,logger:o,yes:i}){Ck(e.schemaVersion,De)&&(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)),uf(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 St("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 St("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=Zr(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!==De){let{steps:g,newVersion:f}=await ua({metadata:{id:e.id,schemaVersion:e.schemaVersion},steps:e.steps,logger:b});d=f,p=Pe.array().parse(g)}else p=Pe.array().parse(e.steps);let{stepsToSave:u,moduleUpdates:m}=await Dt({stepLists:{steps:p}});u.beforeSteps=l.beforeSteps??void 0,u.afterSteps=l.afterSteps??void 0;let h=Tk(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 St("Do you want to apply this patch?")&&(b.dimmed("Cancelled."),process.exit(1)),Vn({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 nE}from"zod";var Wt=" ".repeat(6);import tE from"chalk";import{Argument as co,Option as Ne}from"@commander-js/extra-typings";import{validateHeaderValue as Rk}from"http";import{cpus as Bv}from"os";import{parse as Ohe}from"yaml";import{z as q}from"zod";var ec=58888,bu=30*60*1e3,Zn=new Ne("--api-key <key>","API key for authentication. If not supplied, attempts to read the MOMENTIC_API_KEY env var."),Qn=new Ne("--server <server>","Momentic server to use. Leave unchanged unless using Momentic on-premise."),po=new Ne("-y, --yes","Skip all confirmation prompts.").env("CI"),wu=new Ne("-w, --wait","Wait for tests to finish running before exiting. Only applicable when running tests remotely").implies({remote:!0}),vu=new Ne("--wait-timeout <waitTimeout>",`The maximum number of seconds to wait for tests to complete. Only applicable when the --wait option is specified. Defaults to ${bu/1e3} seconds.`),tc=new Ne("--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."),Hv=new Ne("--reporter <reporter>","Output report files in a standardized format to a local directory. See the --reporter-dir flag for information on the output directory.").choices(Object.values(na)),jv=new Ne("--reporter-dir <reporterDir>","Output directory to store report files. Relative paths are resolved relative to the project root, which is defined by the detected momentic.config.yaml. Defaults to 'reports' if unset."),Eu=new Ne("--output-dir <outputDir>","[Alpha] Output directory to store run artifacts such as screenshots, results, and logs. Relative paths are resolved relative to the project root, which is defined by the detected momentic.config.yaml. This directory will be cleared at the start of execution."),$v=new Ne("--upload-results","Upload test results to Momentic Cloud. By default, this option is disabled."),xu=new Ne("--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."),Tu=new Ne("--exclude <excludePatterns...>","The inverted version of --include: a test that matches any of the provided exclusion patterns will be excluded from running."),Cu=new Ne("--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."),Gv=new Ne("--port <port>",`Port to run the app on. Defaults to ${ec}.`),Ru=new Ne("--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."),nc=new Ne("--env <env>","Name of the environment to use when running tests."),rc=new Ne("--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."),Wv=new Ne("--shard-index <shardIndex>","The index of the shard to run tests for. Defaults to 1.").default(1).argParser(n=>parseInt(n,10)),En=new Ne("-c, --config <configPath>","Absolute or relative path to a Momentic configuration file (*.momentic.config.yaml)"),oc=new Ne("-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."),Vv=new Ne("--shard-count <shardCount>","The number of shards that tests are being run on. Defaults to 1.").default(1).argParser(n=>parseInt(n,10)),qv=new Ne("--fix","Attempt to fix any issues found. This option will write changes to your local file system."),Au=new Ne("--save-cache","Always save updated step caches after successful test runs. By default, caches are not saved when running on the protected branches configured in the momentic.config.yaml.").env("CI"),Iu=new Ne("--disable-cache","Disable caching of test results. This will cause all tests to be re-run every time."),Kv=new co("<tests...>",`One or more test paths to queue on Momentic Cloud.
|
|
3865
3917
|
|
|
3866
|
-
A test path is a lowercased version of your test name where spaces are replaced with dashes: 'npx momentic pull hello-world'.`),
|
|
3918
|
+
A test path is a lowercased version of your test name where spaces are replaced with dashes: 'npx momentic pull hello-world'.`),Yv=new co("<tests...>",`One or more test paths to import from Momentic Cloud.
|
|
3867
3919
|
|
|
3868
|
-
A test path is a lowercased version of your test name where spaces are replaced with dashes: 'npx momentic import hello-world'.`).argOptional(),
|
|
3920
|
+
A test path is a lowercased version of your test name where spaces are replaced with dashes: 'npx momentic import hello-world'.`).argOptional(),Pu=new co("<tests...>","One or more test file path or folders that exist on the local machine: 'npx momentic run hello-world.test.yaml'.").argOptional(),Jv=new co("<suites...>",`One or more suite paths that exist on Momentic Cloud.
|
|
3869
3921
|
|
|
3870
|
-
The suite path is a lowercased version of your suite name where spaces and special characters are replaced with dashes, such as 'production-tests'.`),
|
|
3922
|
+
The suite path is a lowercased version of your suite name where spaces and special characters are replaced with dashes, such as 'production-tests'.`),_he=new co("<envs...>","One or more environment names to push").argOptional(),Xv=new co("<resultsPath>","Path to a directory that contains on or more test results archives.").argRequired(),Zv=new co("<results>","Path to the results archive.").argRequired(),zv=q.object({apiKey:q.preprocess(n=>n!==void 0?n:process.env.MOMENTIC_API_KEY,q.string()),server:q.string().default("https://api.momentic.ai"),config:q.string().optional(),filter:q.string().optional(),yes:q.boolean().optional(),fix:q.boolean().optional(),pixelRatio:q.coerce.number().optional(),port:q.coerce.number().default(ec).optional(),wait:q.preprocess(n=>!!n,q.boolean()).optional(),waitTimeout:q.coerce.number().optional(),start:q.string().optional(),waitOn:q.string().optional(),waitOnTimeout:q.coerce.number().default(60).optional(),customHeaders:q.string().array().optional(),env:q.string().optional(),urlOverride:q.string().url().optional(),all:q.boolean().optional(),parallel:q.coerce.number().optional(),retries:q.coerce.number().optional(),shardIndex:q.coerce.number().optional(),shardCount:q.coerce.number().optional(),inputCsv:q.string().optional(),updateGoldenFiles:q.boolean().optional().default(!1),tests:q.array(q.string()).optional(),suites:q.array(q.string()).optional(),paths:q.array(q.string()).optional(),envs:q.array(q.string()).optional(),include:q.array(q.string()).optional(),exclude:q.array(q.string()).optional(),labels:q.array(q.string()).optional(),reporter:q.nativeEnum(na).optional(),reporterDir:q.string().optional(),outputDir:q.string().optional(),uploadResults:q.boolean().optional(),saveCache:q.boolean().optional(),disableCache:q.boolean().optional()}),cn=async n=>{let e={},t;try{let r=Object.assign(e,zv.partial().parse(n));t=zv.parse(r)}catch(r){b.error(`Error parsing command line arguments: ${r.message}`),process.exit(1)}try{Ak(t)}catch(r){b.error(`Invalid command line arguments: ${r.message}`),process.exit(1)}return t};var Ak=n=>{for(let[e,t]of Object.entries(n))switch(e){case"shardIndex":if(!n.shardCount)throw new Error("The --shard-count flag must be provided alongside --shard-index");if(n.shardCount&&n.shardIndex&&n.shardIndex>n.shardCount)throw new Error("Shard index cannot be greater than shard count");if(n.shardIndex!==void 0&&n.shardIndex<1)throw new Error("Shard index must be greater than 0");break;case"waitTimeout":case"pixelRatio":try{n[e]=q.number().int().optional().parse(t)}catch{throw new Error(`Invalid ${e} provided does not parse a number: ${t}`)}break;case"urlOverride":if(t===void 0)break;try{q.string().url().parse(t)}catch(r){throw new Error(`Invalid URL provided for ${e}`,{cause:r})}break;case"server":if(typeof t!="string")throw new Error(`Expected a string for ${e}`);if(!t.startsWith("http"))throw new Error("--server option must be a fully qualified URL beginning with http");break;case"parallel":if(t===void 0)break;if(typeof t!="number"||isNaN(t))throw new Error(`Expected a number for ${e}`);Bv().length<t*2&&b.warn(`You requested to run tests in parallel ${t} at a time on a machine with ${Bv().length} cores. This may cause performance issues and test failures as Chrome requires at least 2 cores per browser instance.`);break;default:break}};function ic(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);Rk(o,i),e[o]=i}return e}async function Lu(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 Qv}from"console";import{format as Wa}from"util";var Ou=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}},ac=class n extends Qv{_buffer=[];_groupDepth=0;Console=Qv;constructor(){super({write:e=>(n.write(this._buffer,"log",e),!0)})}static write(e,t,r,o=2){let i=new Ou(void 0,n.write).stack;if(!i)return e;let a=i.split(`
|
|
3871
3923
|
`).slice(o).filter(Boolean).join(`
|
|
3872
|
-
`);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",Wa(e,...t))}error(e,...t){this._log("error",Wa(e,...t))}info(e,...t){this._log("info",Wa(e,...t))}log(e,...t){this._log("log",Wa(e,...t))}warn(e,...t){this._log("warn",Wa(e,...t))}getBuffer(){return this._buffer.length>0?this._buffer:void 0}};function
|
|
3924
|
+
`);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",Wa(e,...t))}error(e,...t){this._log("error",Wa(e,...t))}info(e,...t){this._log("info",Wa(e,...t))}log(e,...t){this._log("log",Wa(e,...t))}warn(e,...t){this._log("warn",Wa(e,...t))}getBuffer(){return this._buffer.length>0?this._buffer:void 0}};function eE(n){let e=globalThis.console,t=new ac;globalThis.console=t;try{n()}finally{let o=t.getBuffer()?.map(i=>i.message).join(`
|
|
3873
3925
|
`);process.stderr.write(`${o}
|
|
3874
|
-
`),globalThis.console=e}}var
|
|
3926
|
+
`),globalThis.console=e}}var Pk=5;async function sc({getResults:n,checkDone:e,name:t,timeoutMs:r=bu}){let o=Date.now(),i=0;for(;Date.now()-o<r;){let a;i>Pk&&(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 Ii({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 eE(()=>{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 lc=(n,e)=>{if(!n.failureDetails||!n.failureReason)return;let t=fs[n.failureDetails?.classification?.reason||n.failureReason],r=n.failureDetails?.classification?.summary||ko[n.failureReason];b.error(e),b.log(`${Wt}Reason: ${tE.red(t)}`),b.log(`${Wt}Description: ${tE.red(r)}`)};async function Nu({fix:n,project:e}){let t=ve(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=Zr(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=xt.parse(m),f=await Vr(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())),nE.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 T=o[E.id]?.testId,C=o[E.id]?.testRelativePath;if(T?(d++,w=!0,T===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 ${C}`),n&&(S=!0,E.id=uo())):o[E.id]={testId:u.id,testRelativePath:u.relativePath},E.type==="PRESET_ACTION"){let R=E.command.id,L=a[R]?.testId,M=a[R]?.testRelativePath;L?(d++,w=!0,L===u.id?b.error(`Multiple commands in the test '${u.name}' (${u.relativePath}) have the same ID '${R}'`):b.error(`Command ${y} in test '${u.name}' (${u.relativePath}) has the ID ${R} which is duplicated in test ${M}`),n&&(S=!0,E.command.id=uo())):a[R]={testId:u.id,testRelativePath:u.relativePath}}return Ee.parse(E)}),w&&b.dimmed("=".repeat(80)),S&&n&&(Vn({relativeTestPath:u.relativePath,steps:{beforeSteps:m.beforeSteps,steps:f.steps,afterSteps:m.afterSteps},schemaVersion:De,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=Wn(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 Vr({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,T)=>{if(nE.string().uuid().safeParse(y.id)||(b.error(`Step ${T} 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 R=o[y.id]?.testRelativePath;d++,w=!0,b.error(`Step ${T} in module '${u.name}' (${u.relativePath}) has the ID ${y.id} which is duplicated in test ${R}`),n&&(S=!0,y.id=uo())}if(y.type==="PRESET_ACTION"){let R=y.command.id,L=a[R],M=l[R];L||M?(d++,w=!0,M?.moduleId===u.id?b.error(`Multiple commands in module '${u.name}' (${u.relativePath}) have the same ID '${R}'`):L?b.error(`Command in module '${u.name}' (${u.relativePath}) has the ID ${R} which is duplicated in test ${L.testRelativePath}`):b.error(`Command ${T} in module '${u.name}' (${u.relativePath}) has the ID ${R} which is duplicated in module ${M.moduleRelativePath}`),n&&(S=!0,y.command.id=uo())):l[R]={moduleId:u.id,moduleRelativePath:u.relativePath}}return Ee.parse(y)});w&&b.dimmed("=".repeat(80)),S&&n&&(Jr({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 rE({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:
|
|
3875
3927
|
${[...r].map(i=>`${Wt}- ${i}`).join(`
|
|
3876
3928
|
`)}`),o.size>0&&b.warn(`Modified the following module files:
|
|
3877
3929
|
${[...o].map(i=>`${Wt}- ${i}`).join(`
|
|
3878
|
-
`)}`)):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
|
|
3879
|
-
${e}`)}}async function Sx({project:n,orgId:e,apiClient:t}){b.info("Pulling browser and AI configuration options from Cloud");let r=await cc.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=Uk(),ai(n.config,n.configFilePath),b.success("Migration complete!")}function yx(n){return n?Ne(n):"Unknown suite"}async function bx({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 complete.`);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 sc({name:"suites",getResults:async()=>{let f=s.filter(x=>!d.some(y=>y.id===x)),S=await n.bulkGetRunGroupStatus(f),w=[];for(let x of S)p(x)?d.push(x):w.push(x);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} ${yx(S.suite?.name)}`)))}),f.every(p))}),m=n.getAppUrl(),g=Pi({results:u,startTime:l,onFailed:f=>{let S=yx(f.suite?.name),w=f.runs.filter(y=>y.status==="FAILED").length,x=f.runs.length;b.error(`${S} (${w}/${x} tests failed):`);for(let y of f.runs)if(y.status==="FAILED"){let T=y.testName||y.test?.name;b.error(` ${T?Ne(T):"Unknown test"} (${m}/runs/${y.id})`)}},entity:"suite",getDisplayLine:f=>` ${f.suite?.name?Ne(f.suite.name):"Unknown suite name"} (${m}/run-groups/${f.id})`});process.exit(g.failed>0?1:0)}async function wx({tests:n,client:e,orgId:t,...r}){!r.yes&&!await St(`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 sc({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} ${Ne(g)}`)}}),m.every(l))}),u=Pi({results:p,startTime:d,onFailed:m=>{let h=m.testName||m.test?.name;lc(m,h?Ne(h):"Unknown test")},getDisplayLine:m=>{let h=m.testName||m.test?.name,g=` ${h?Ne(h):"Unknown test"}`;return m.id&&(g+=` (${c}/runs/${m.id})`),g},entity:"test"});process.exit(u.failed>0?1:0)}import Mi,{supportsColor as p_}from"chalk";import u_ from"fs";import{existsSync as Xk,mkdirSync as Zk,statSync as Qk}from"fs";import{randomUUID as Fu}from"crypto";import dc from"fs";import{hostname as Bk}from"os";import qa from"path";async function pc(n,e,t,r,o){if(r){let i=qa.extname(r),a=`${Fu()}-screenshot${i}`,s=qa.join(t,a),c=await(await fetch(r)).arrayBuffer();return dc.writeFileSync(s,Buffer.from(c)),a}if(o){let i=await e.getScreenshot(n,o);if(i){let a=`${o}-screenshot.jpeg`,s=qa.join(t,a);return dc.writeFileSync(s,i),a}}}async function zk(n,e,t,r){let o=r.runId??Fu(),i={uuid:o,historyId:o,testCaseId:r.test.id,fullName:r.test.name,name:Ne(r.test.name),status:r.status==="PASSED"?"passed":r.status==="CANCELLED"?"skipped":"failed",start:r.lastAttemptStartedAt.getTime(),stop:r.finishedAt.getTime(),parameters:[],labels:[{name:"suite",value:t.suiteName},{name:"host",value:Bk()},{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 Hk(n,e,t.folder,i.steps,r.results);let a=`${o}-result.json`;dc.writeFileSync(qa.join(t.folder,a),JSON.stringify(i,void 0,2))}async function Li(n,e,t,r){let o={name:mn(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 pc(n,e,t,r.beforeScreenshot,r.beforeSnapshot);i&&o.attachments.push({name:"Screenshot before step",source:i,type:"image/jpeg"});let a=await pc(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=qa.join(t,s);dc.writeFileSync(l,JSON.stringify(r.data,null,2)),o.attachments.push({name:"Step output data",source:s,type:"text/plain"})}return o}async function Hk(n,e,t,r,o){for(let i of o)switch(i.type){case"PRESET_ACTION":{r.push(await Li(n,e,t,i));break}case"CONDITIONAL":{let a=await Li(n,e,t,i);a.steps=[],i.assertion&&a.steps.push(await Li(n,e,t,i.assertion)),a.steps.push(...await Promise.all(i.results.map(s=>Li(n,e,t,s)))),r.push(a);break}case"AI_ACTION":case"IFRAME":case"SECTION":case"MODULE":{let a=await Li(n,e,t,i);if(a.steps=await Promise.all(i.results.map(s=>Li(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 vx(n,e,t,r){for(let o of r.runs)await zk(n,e,{folder:t,suiteName:r.suiteName},o)}import xx from"junit-report-builder";import Uu from"path";function jk(n,e){let t=e??xx.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=fs[n.failureDetails?.classification?.reason||n.failureReason],o=n.failureDetails?.classification?.summary||_o[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 $k(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();jk(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 Ex(n,e){let t=xx.newBuilder();$k(t,e),t.writeTo(Uu.join(n,`${e.suiteName}.xml`))}import Gk from"fs";import Wk from"path";function Tx(n){return{title:mn(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(Tx):[]}}async function Vk(n,e,t,r){if(r.results?.length){let o=await pc(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 qk(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||_o[r.failureReason]}:void 0,retry:r.attempts-1,steps:r.results?.map(Tx)||[],startTime:r.lastAttemptStartedAt.toISOString(),attachments:await Vk(n,e,t,r)}}async function Kk(n,e,t,r){return{expectedStatus:"passed",status:r.status==="PASSED"?"expected":"unexpected",results:[await qk(n,e,t,r)]}}async function Yk(n,e,t,r){return{tags:[],title:r.test.name,ok:r.status==="PASSED",tests:[await Kk(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 Jk(n,e,t,r){return{suites:[{title:r.suiteName,file:r.projectConfigPath,specs:await Promise.all(r.runs.map(o=>Yk(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 Cx(n,e,t,r){let o=await Jk(n,e,t,r);Gk.writeFileSync(Wk.join(t,`${r.suiteName}.json`),JSON.stringify(o,null,2))}async function Rx(n,e,t,r,o){switch(Xk(o)?Qk(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...`),Zk(o,{recursive:!0})),t){case"junit":Ex(o,r);return;case"allure":case"allure-json":await vx(n,e,o,r);return;case"playwright-json":await Cx(n,e,o,r);return;default:throw new Error(`Unknown reporter format requested: '${t}'`)}}import m_ from"wait-on";import zu from"fs";import{compact as e_}from"lodash-es";import Hu from"path";import{cwd as t_}from"process";import n_ from"semver";async function uc({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=t_();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
|
+
`)}`)):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 oE({project:n}){let e=ve(n,b),t=Object.values(e.tests),r=await Zs(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 Lk}from"lodash-es";async function iE({client:n,skipPrompts:e,project:t}){let r=await n.getAllEnvironments(),o=Lk(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 St(`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})}}ii(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 aE}from"crypto";import sE from"fs";async function Mu({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=lE(l,Ie.TEST);!r&&!await yu(d)||(a+=1,sE.writeFileSync(d,c,"utf-8"),te.info({checksum:aE("md5").update(c).digest("hex")},`Wrote '${d}'`))}let s=0;for(let[l,c]of Object.entries(i)){let d=lE(l,Ie.MODULE);!r&&!await yu(d)||(s+=1,sE.writeFileSync(d,c,"utf-8"),te.info({checksum:aE("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 lE(n,e){switch(e){case Ie.TEST:return`${Me(n)}.${_t.TEST}`;case Ie.MODULE:return`${Me(n)}.${_t.MODULE}`;default:throw new Error(`Unknown entity type ${e}`)}}async function cE(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 St("Are you sure you want to proceed?",!0)||(b.info("Aborting..."),process.exit(1)),await iE({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 Mu({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 dE(n){let{client:e,skipPrompts:t,paths:r}=n;await Mu({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 Ok from"fs";import{tmpdir as Nk}from"os";import Mk from"path";import{registry as Va}from"playwright-core/lib/server";import pE from"proper-lockfile";var uE=Mk.join(Nk(),"momenticBrowserInstallation");var ku=["chrome","chromium","chrome-for-testing"],kk={Chromium:"chromium","Google Chrome":"chrome","Chrome for Testing":"chrome-for-testing"},mE={chrome:"chrome",chromium:"chromium","chrome-for-testing":"chromium-headless-shell"};function hE(n){let e=mE[kk[n]??""]??"",t=Va.findExecutable(e);return!t||t.installType==="none"?!1:_u(t)}function _u(n){let e=n.executablePath();return Ok.existsSync(e)}function _k(n,e){let t=mE[n];if(!t)throw new Error(`Requested install of unknown browser type ${n}`);let r=Va.findExecutable(t);if(!r||r.installType==="none")throw new Error(`Requested install of unknown browser type ${n}`);if(!(!e&&_u(r)))return r}async function Dk({browser:n,force:e}){let t=_k(n,e);if(!t){b.info(`Browser '${n}' is already installed, skipping...`);return}b.info(`Installing browser '${n}'...`);try{await Va.installDeps([t],!1),await Va.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=Va.findExecutable(n),i=5*60*1e3,a=Date.now();for(;Date.now()-a<i&&!_u(o);)b.info("Waiting for browser to finish installing..."),await new Promise(s=>setTimeout(s,5e3))}else throw r}}async function gE({rawBrowsers:n,force:e=!1,all:t=!1}){let r=t?ku:Array.from(new Set(n));try{await pE.lock(uE,{stale:1e3*60*5,update:1e3*60,realpath:!1,retries:{retries:30,factor:2,maxTimeout:15e3,minTimeout:500}})}catch(o){b.warn(`Failed to acquire lock to install browsers. Please ensure that any other process installing browsers completes within 5 minutes: ${o}. Continuing without installation...`);return}try{for(let o of r)try{await Dk({browser:o,force:e})}catch(i){b.error(`Failed to install the ${o} browser: ${i}`)}}finally{await pE.unlock(uE,{realpath:!1})}}async function fE(n){let e=ve(n,b),t=Object.values(e.tests);for(let r of t)try{let o=Zr(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=xt.parse(o),s=await Vr(a,i,b);b.dimmed(`Updating ${r.relativePath}`),Vn({relativeTestPath:r.relativePath,steps:{beforeSteps:o.beforeSteps,steps:s.steps,afterSteps:o.afterSteps},schemaVersion:De,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=Wn(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 Vr({id:o.moduleId,schemaVersion:o.schemaVersion},i,b);Jr({content:{...o,steps:a.steps},schemaVersion:De,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 Uk}from"child_process";import{PostHog as Fk}from"posthog-node";async function SE(n,e){let t,r=0,o=3,i,a;for(;r<o;)try{let s=await U(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 cc=class n extends ca{constructor(t,r,o,i){super(o,i);this.client=t;this.orgId=r}static async init(t){let r=new Fk("phc_WRWd8LYIv6rolgDsyCdrPpxtZhsu6qXAkEwPicl44bI",{host:"https://us.i.posthog.com"}),{flags:o,payloads:i}=await SE(r,t);return new n(r,t,o,i)}async refresh(){let{flags:t,payloads:r}=await SE(this.client,this.orgId);this.flags=t,this.payloads=r}};function Bk(){try{let e=Uk("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:
|
|
3931
|
+
${e}`)}}async function yE({project:n,orgId:e,apiClient:t}){b.info("Pulling browser and AI configuration options from Cloud");let r=await cc.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=Bk(),ii(n.config,n.configFilePath),b.success("Migration complete!")}function bE(n){return n?Me(n):"Unknown suite"}async function wE({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 complete.`);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 sc({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} ${bE(S.suite?.name)}`)))}),f.every(p))}),m=n.getAppUrl(),g=Ii({results:u,startTime:l,onFailed:f=>{let S=bE(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 T=y.testName||y.test?.name;b.error(` ${T?Me(T):"Unknown test"} (${m}/runs/${y.id})`)}},entity:"suite",getDisplayLine:f=>` ${f.suite?.name?Me(f.suite.name):"Unknown suite name"} (${m}/run-groups/${f.id})`});process.exit(g.failed>0?1:0)}async function vE({tests:n,client:e,orgId:t,...r}){!r.yes&&!await St(`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 sc({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} ${Me(g)}`)}}),m.every(l))}),u=Ii({results:p,startTime:d,onFailed:m=>{let h=m.testName||m.test?.name;lc(m,h?Me(h):"Unknown test")},getDisplayLine:m=>{let h=m.testName||m.test?.name,g=` ${h?Me(h):"Unknown test"}`;return m.id&&(g+=` (${c}/runs/${m.id})`),g},entity:"test"});process.exit(u.failed>0?1:0)}import Oi,{supportsColor as u_}from"chalk";import m_ from"fs";import{existsSync as Zk,mkdirSync as Qk,statSync as e_}from"fs";import{randomUUID as Du}from"crypto";import dc from"fs";import{hostname as zk}from"os";import qa from"path";async function pc(n,e,t,r,o){if(r){let i=qa.extname(r),a=`${Du()}-screenshot${i}`,s=qa.join(t,a),c=await(await fetch(r)).arrayBuffer();return dc.writeFileSync(s,Buffer.from(c)),a}if(o){let i=await e.getScreenshot(n,o);if(i){let a=`${o}-screenshot.jpeg`,s=qa.join(t,a);return dc.writeFileSync(s,i),a}}}async function Hk(n,e,t,r){let o=r.runId??Du(),i={uuid:o,historyId:o,testCaseId:r.test.id,fullName:r.test.name,name:Me(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 jk(n,e,t.folder,i.steps,r.results);let a=`${o}-result.json`;dc.writeFileSync(qa.join(t.folder,a),JSON.stringify(i,void 0,2))}async function Pi(n,e,t,r){let o={name:mn(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 pc(n,e,t,r.beforeScreenshot,r.beforeSnapshot);i&&o.attachments.push({name:"Screenshot before step",source:i,type:"image/jpeg"});let a=await pc(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=`${Du()}-attachment.json`,l=qa.join(t,s);dc.writeFileSync(l,JSON.stringify(r.data,null,2)),o.attachments.push({name:"Step output data",source:s,type:"text/plain"})}return o}async function jk(n,e,t,r,o){for(let i of o)switch(i.type){case"PRESET_ACTION":{r.push(await Pi(n,e,t,i));break}case"CONDITIONAL":{let a=await Pi(n,e,t,i);a.steps=[],i.assertion&&a.steps.push(await Pi(n,e,t,i.assertion)),a.steps.push(...await Promise.all(i.results.map(s=>Pi(n,e,t,s)))),r.push(a);break}case"AI_ACTION":case"IFRAME":case"SECTION":case"MODULE":{let a=await Pi(n,e,t,i);if(a.steps=await Promise.all(i.results.map(s=>Pi(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 EE(n,e,t,r){for(let o of r.runs)await Hk(n,e,{folder:t,suiteName:r.suiteName},o)}import xE from"junit-report-builder";import Fu from"path";function $k(n,e){let t=e??xE.testCase();if(t.name(n.test.name).className(n.test.name).file(Fu.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=fs[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 Gk(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();$k(l,c)}for(let l of a){let c=s.testCase();c.name(l.name).className(l.name).file(Fu.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 TE(n,e){let t=xE.newBuilder();Gk(t,e),t.writeTo(Fu.join(n,`${e.suiteName}.xml`))}import Wk from"fs";import Vk from"path";function CE(n){return{title:mn(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(CE):[]}}async function qk(n,e,t,r){if(r.results?.length){let o=await pc(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 Kk(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(CE)||[],startTime:r.lastAttemptStartedAt.toISOString(),attachments:await qk(n,e,t,r)}}async function Yk(n,e,t,r){return{expectedStatus:"passed",status:r.status==="PASSED"?"expected":"unexpected",results:[await Kk(n,e,t,r)]}}async function Jk(n,e,t,r){return{tags:[],title:r.test.name,ok:r.status==="PASSED",tests:[await Yk(n,e,t,r)],id:r.runId,file:r.filePath}}function Uu(n,e){return n.reduce((t,r)=>e(r)?t+1:t,0)}async function Xk(n,e,t,r){return{suites:[{title:r.suiteName,file:r.projectConfigPath,specs:await Promise.all(r.runs.map(o=>Jk(n,e,t,o)))}],errors:[],stats:{startTime:r.startedAt.toISOString(),duration:r.finishedAt.getTime()-r.startedAt.getTime(),expected:Uu(r.runs,o=>o.status==="PASSED"),unexpected:Uu(r.runs,o=>o.status!=="PASSED"),flaky:Uu(r.runs,o=>!!o.isFlake),skipped:0}}}async function RE(n,e,t,r){let o=await Xk(n,e,t,r);Wk.writeFileSync(Vk.join(t,`${r.suiteName}.json`),JSON.stringify(o,null,2))}async function AE(n,e,t,r,o){switch(Zk(o)?e_(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...`),Qk(o,{recursive:!0})),t){case"junit":TE(o,r);return;case"allure":case"allure-json":await EE(n,e,o,r);return;case"playwright-json":await RE(n,e,o,r);return;default:throw new Error(`Unknown reporter format requested: '${t}'`)}}import h_ from"wait-on";import Bu from"fs";import{compact as t_}from"lodash-es";import zu from"path";import{cwd as n_}from"process";import r_ from"semver";async function uc({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=>Bu.existsSync(u)),p=n_();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:
|
|
3880
3932
|
${n.map(u=>`${Wt}- ${u}`).join(`
|
|
3881
3933
|
`)}
|
|
3882
|
-
`),n.forEach(u=>{if(!
|
|
3934
|
+
`),n.forEach(u=>{if(!Bu.existsSync(u))throw new Error(`Path '${u}' does not exist.`);let m,h;try{m=Bu.statSync(u),h=m.isDirectory()}catch(f){s.warn({err:f},`Skipping path ${u} because it cannot be read`);return}let g=zu.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:
|
|
3883
3935
|
${n.map(u=>`${Wt}- ${u}`).join(`
|
|
3884
|
-
`)}`),Object.values(e.tests).forEach(u=>{n.some(m=>u.relativePath.includes(m))&&l.add(u.fullFilePath)}))}else{!r&&!await St("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 fa(d,te,e);if(n_.gt(p.schemaVersion,De)&&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(e_)}import{cloneDeep as Oi}from"lodash-es";async function Ax({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 Gt({orgId:n,s:c,localTools:e,logger:t,context:o,flagStore:i})}return a}async function Ix({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,visualDiffScreenshotStorage:g,flagStore:f}){let S=await Ll({settings:h,customHeaders:u,envVariables:d,envName:e,testName:t,baseUrl:n,logger:p,localTools:s,orgId:c,flagStore:f}),w={baseUrl:o.baseUrl,apiKey:o.apiKey,logger:te},x=f.isBooleanFlagEnabled("icon_knowledge_base")?await a.fetchIconKnowledgeBase(p):null,y=S.browserType??"Chromium";if(!mx(y)){let L=`Browser ${y} 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 Un.init({baseUrl:n,logger:p,userBrowserSettings:S,storage:a,flagStore:f,enricher:new gi(w,l),contextArgs:{viewport:i.advanced.viewport??Jt,locale:i.advanced.locale??Do,geolocation:i.advanced.geolocation??Uo,timezoneId:i.advanced.timezone??Fo,colorScheme:i.advanced.colorScheme,deviceScaleFactor:r},iconKnowledgeBase:x}),C=new Ei({browser:T,generator:l,logger:p,orgId:c,options:{scratchPadId:void 0,slowMoMs:S.slowMoMs,autoFollowNewTabs:S.autoFollowNewTabs,useMemory:i.advanced.useMemory},storage:a,flagStore:f,localCodeEvalTools:s,visualDiffScreenshotStorage:g,analytics:new Ci}),R=new Ot({baseUrl:n,currentUrl:C.browser.url(),variablesFromEnvironment:d,envName:e,testName:t});return i.parameters&&await Promise.all(i.parameters.map(async L=>{let{name:N,defaultValue:H,required:z}=L,k=m?.[N];z&&k===void 0&&(b.error(`Required parameter '${N}' is required by test '${i.name}' but not provided`),process.exit(1));let _=await Gt({orgId:c,s:k??H,localTools:s,logger:p,context:Ot.dummyContext(R.getEnvName()),flagStore:f});R.setMomenticSystemVariable(N,_)})),{controller:C,context:R}}import{randomUUID as r_}from"crypto";async function Px({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")?Ii?!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 Lx({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:x}=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},T={orgId:o,runId:i||r_(),runAttemptId:a,testMetadata:w,steps:w.steps,beforeSteps:w.beforeSteps,afterSteps:w.afterSteps},C={collectDebugData:!0,reinitializeBrowser:!0,disableHealing:!await Px({currentAttempt:r,testId:w.id,flagStore:c,apiClient:g,testAdvancedSettings:w.advanced,aiSettingsFromEnv:x.ai,logger:h})};return await Pl({fixtures:y,inputs:T,options:C,callbacks:{step:{},test:{onTestComplete:async()=>{await s.browser.cleanup()},onProposedTestSteps:async N=>g.uploadProposedSteps(N,h)}},testParams:{tracer:S}})}async function Ox(n){let{testDefinition:e,logger:t}=n,r=new Date;try{return await o_(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 o_(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 ui(r,o),m=fi({orgId:o,client:r,gitMetadata:c,alwaysSaveCache:d,noCache:p}),h=Oi(e.steps),g=Oi(e.beforeSteps)??void 0,f=Oi(e.afterSteps)??void 0;try{await m.resolveStepCacheEntries({testId:e.id,stepLists:{steps:h,beforeSteps:g,afterSteps:f},schemaVersion:e.schemaVersion,logger:l})}catch(R){throw l.error({err:R},"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: ${R}`)}let S=n.envName??a_(e),w,x={};if(S){try{w=Sa(S,t,l)}catch(R){let L=`Failed to resolve environment ${S} for test ${e.name}: ${R}`;throw new Error(L)}x=w.variables}let y=e.baseUrl;if(i)y=i;else if(!y){let R=x[Ve];typeof R=="string"&&(y=R)}if(!y){let R=`Cannot run test with no base URL and no ${Ve} variable defined in its environment`;throw new Error(R)}let T=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}),C=l.child(T.loggerBindings||{});Object.entries(T.envVarBindings||{}).forEach(([R,L])=>{x[R]=L});try{let R=await i_({...n,variables:x,envName:S,resolvedEnv:w,baseUrl:y,storageClient:u,tracer:T,logger:C,cacheStorage:m,stepsWithCaches:h,beforeStepsWithCaches:g,afterStepsWithCaches:f});return await T.finish({logger:l,status:R.status,finishedAt:R.finishedAt,failureDetails:R.failureDetails,failureReason:R.failureReason,isFlake:R.isFlake}),{runId:T.runId,...R}}finally{a?.pop()}}async function i_(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:x,logUpdate:y,tracer:T,logger:C,flagStore:R,cacheStorage:L}=n,N=new Date,H=new li(i,a),z={ai:i.config.ai},k={envName:u,urlOverride:m,customHeaders:h,testInputs:g},_,O=Math.abs(w??i.config.retries??e.retries??0),K=[];C.info({labels:e.labels,name:e.name,cwd:process.cwd()},"Starting test run using CLI");for(let B=0;B<=O;B++){let le=await T.startAttempt(),ce=C.child(le.loggerBindings||{}),fe={...e,steps:Oi(t),beforeSteps:Oi(r),afterSteps:Oi(o)};B!==0&&y("RETRY",`attempt ${B+1}/${O+1}`);let J=new Date,_e=new Sr({httpClient:new Ft({baseUrl:s.baseUrl,apiKey:s.apiKey,logger:ce}),fakerSeed:R.isBooleanFlagEnabled("faker_constant_seed")?Bh:void 0});try{let{controller:me,context:At}=await Ix({baseUrl:c,envName:u,testName:fe.name,apiClient:s,devicePixelRatio:x,logger:ce,storageClient:d,codeEvalTools:_e,test:fe,generator:l,orgId:p,variables:f,customHeaders:h,testInputs:g,localBrowserConfig:{...i.config.browser||{},...S?.browser||{},...fe.advanced},visualDiffScreenshotStorage:H,flagStore:R});_=await Lx({attemptMetadata:{attemptNumber:B+1,orgId:p,runId:T.runId},attemptFixtures:{logger:ce,storageClient:d,billingReporter:new $o,analytics:new Ci,debugDataStorage:new Br,codeEvalTools:_e,flagStore:R,apiClient:s,context:At,controller:me,tracer:le},attemptInputs:{test:fe,orgSettings:z}});let yt=new Date;_?.status==="PASSED"&&await $s({logger:C,cacheStorage:L,orgId:p,testId:e.id,originalSteps:{steps:e.steps,beforeSteps:e.beforeSteps,afterSteps:e.afterSteps},updatedSteps:{steps:fe.steps,beforeSteps:fe.beforeSteps,afterSteps:fe.afterSteps}}),await le.finish({logger:ce,result:_}),K.unshift(_.status);let En=await Ax({orgId:p,codeEvalTools:_e,logger:ce,outputDefinitions:e.outputs??[],testContext:At,flagStore:R}),fo=fh(K),So=B+1;if(_.status!=="FAILED")return{..._,parameters:k,test:fe,filePath:fe.relativeFilePath,startedAt:N,lastAttemptStartedAt:J,finishedAt:yt,attempts:So,baseUrl:c,outputs:En,isFlake:fo};let nr=_.failedStepResult,dn=nr?.message||"Unknown failure",j=nr?.failureReason??Yh(dn)??"UnknownError",Ni=ce.child({errResult:nr,failureReason:j,errorMessage:dn,numAttempts:O+1,name:fe.name});if(B<O){Ni.warn(`Retrying failed execution attempt for run: ${dn}`);continue}return Ni.error(`Test failed after all exhausting attempts: ${dn}`),{..._,parameters:k,failureDetails:{errorMessage:dn},failureReason:j,test:fe,filePath:fe.relativeFilePath,startedAt:N,lastAttemptStartedAt:J,finishedAt:yt,attempts:B+1,baseUrl:c,outputs:En}}catch(me){_i(me);let At=`Encountered fatal platform error while running test '${fe.name}': ${me}`,yt=new Date,En=B+1;ce.error({err:me},At),b.error(At);let fo={errorMessage:me.message,errStack:me.stack},So={status:"FAILED",failureDetails:fo,failureReason:"InternalPlatformError",finishedAt:yt};return await le.finish({logger:ce,result:{status:"FAILED",results:[]}}),{...So,parameters:k,test:fe,filePath:fe.relativeFilePath,startedAt:N,lastAttemptStartedAt:J,finishedAt:new Date,attempts:En,baseUrl:c,outputs:{}}}}throw new Error("This code should not be reachable")}function a_(n){for(let e of n.envs??[])if(e.default)return e.name}import{randomUUID as Nx}from"crypto";import s_ from"adm-zip";import er from"fs";import ho from"path";var Ka=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(ho.join(this.filePath,e))}storeFile(e){let{name:t,contents:r}=e,o=ho.join(this.filePath,t);try{er.writeFileSync(o,r)}catch{}}createRunArchive(e){return new ju(ho.join(this.filePath,"runs"),e)}},ju=class{constructor(e,t){this.filePath=e;this.tempPath=ho.join(e,`.${t}`),this.finalPath=ho.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 Ka(ho.join(this.tempPath,e))}storeFile(e){let{name:t,contents:r}=e,o=ho.join(this.tempPath,t);er.writeFileSync(o,r)}close(){let e=new s_;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 Mx(n,e,t,r,o){let i=aa(o.type);if(i&&await e.reportCreditsUsed(n,o.type,i,{testId:t,testName:r}),"command"in o){let a=sa(o.command);a&&await e.reportCreditsUsed(n,o.command.type,a,{testId:t,testName:r})}}function l_(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 c_(n){switch(n){case"SUCCESS":return"PASSED";case"FAILED":return"FAILED";case"CANCELLED":return"CANCELLED";case"RUNNING":return"RUNNING";case"IDLE":return"PENDING"}}var $u=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:c_(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 mc(this.testId,this.testName,e,this.billingReporter,this.asyncWork);return this.children.push(t),t}},mc=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(Mx(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 $u(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:l_(e.status),finishedAt:e.finishedAt}))))}},Gu=class{constructor(e,t,r,o,i,a,s,l,c){this.orgId=e;this.testId=t;this.testName=r;this.originalSteps=o;this.metadata=i;this.client=a;this.diskStorage=s;this.billingReporter=l;this.asyncWork=c}finished=!1;children=[];trackStatus(){}attachNetworkLogs(e){let{logs:t}=e;this.diskStorage.storeFile({name:"network.har",contents:JSON.stringify(t,null,2)})}attachConsoleLogs(e){let{logs:t}=e;this.diskStorage.storeFile({name:"console.json",contents:JSON.stringify(t,null,2)})}async finish(e){if(this.finished)return;this.finished=!0;let{logger:t,result:r}=e,o={...this.metadata,status:r.status,finishedAt:new Date,results:Ws(r.results,t),beforeResults:r.beforeResults?Ws(r.beforeResults,t):void 0,afterResults:r.afterResults?Ws(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 mc(this.testId,this.testName,e,this.billingReporter,this.asyncWork);return this.children.push(t),t}},Wu=class{constructor(e,t,r,o,i,a,s,l,c,d){this.orgId=e;this.testId=t;this.testName=r;this.runId=o;this.originalSteps=i;this.metadata=a;this.client=s;this.diskStorage=l;this.billingReporter=c;this.asyncWork=d}children=[];finished=!1;get loggerBindings(){return{runId:this.runId}}get envVarBindings(){return{[Ky]:this.runId}}async finish(e){if(this.finished)return;this.finished=!0;let t={...this.metadata,finishedAt:e.finishedAt||new Date,status:e.status,failureDetails:e.failureDetails,failureReason:e.failureReason,flake:e.isFlake||!1};await Promise.all(this.children.map(r=>r.finish({logger:e.logger,result:{status:t.status,results:[],beforeResults:[],afterResults:[]}}))),this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(t,null,2)}),this.diskStorage.close()}trackStatus(){}async startAttempt(){this.metadata.attempts=this.metadata.attempts+1,this.metadata.status="RUNNING",this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(this.metadata,null,2)});let e=this.diskStorage.cd(`attempts/${this.metadata.attempts}`),t={schemaVersion:De,startedAt:new Date,status:"RUNNING"};e.storeFile({name:"metadata.json",contents:JSON.stringify(t,null,2)});let r=new Gu(this.orgId,this.testId,this.testName,this.originalSteps,t,this.client,e,this.billingReporter,this.asyncWork);return this.children.push(r),r}},hc=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=Nx(),l={...a,id:s,trigger:Xt.CLI,startedAt:new Date,status:"RUNNING",cliVersion:vn},c=new Ka(r);return c.storeFile({name:"metadata.json",contents:JSON.stringify(l,null,2)}),new n(t,s,l,o,c,i)}async finish(e){if(this.finished)return;this.finished=!0;let{status:t}=e,r={...this.metadata,status:t,updatedAt:new Date,finishedAt:new Date};await Promise.all(this.children.map(o=>o.finish({logger:e.logger,status:r.status,finishedAt:r.finishedAt}))),this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(r,null,2)}),await Promise.allSettled(this.asyncWork)}trackStatus(){}async startRun(e){let t=Nx(),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:vn,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 Wu(this.orgId,e.testId,e.testName,t,e.originalSteps,o,this.client,r,this.billingReporter,this.asyncWork);return this.children.push(i),i}};import kx from"adm-zip";import Vu from"fs";import gc from"path";function d_(n){let e=new kx,t=gc.join(n,"metadata.json"),r=pa.parse(JSON.parse(Vu.readFileSync(t,"utf-8")));e.addLocalFile(t);for(let o of Vu.readdirSync(gc.join(n,"runs"))){if(!o.endsWith(".zip"))continue;let i=o.replace(/\.zip$/,""),a=new kx(gc.join(n,"runs",o));for(let s of a.getEntries())s.isDirectory||e.addFile(gc.join("runs",i,s.entryName),s.getData())}return{runGroupId:r.id,buffer:e.toBuffer()}}async function fc(n){let{client:e,consoleLogger:t,resultsPath:r}=n;if(!Vu.existsSync(r)){t.warn("Results path does not exist, skipping upload.");return}let o=new xl(e);try{let{runGroupId:i,buffer:a}=d_(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 _x(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:x,exclude:y,labels:T,reporterDir:C=my,outputDir:R=hy,uploadResults:L=!1,waitOnTimeout:N=60,parallel:H=d.config.parallel??1,shardIndex:z=1,shardCount:k=1,regenerateGoldenFiles:_,gitMetadata:O,alwaysSaveCache:K,noCache:B}=n;o&&(e.info({orgId:h},`Executing start command: ${o}`),await Lv(o,!1)),i&&(e.info({orgId:h},`Waiting for url: ${i} with timeout: ${N} seconds.`),await m_({resources:[i],interval:2500,timeout:N*1e3,headers:{Accept:"*/*"},followRedirect:!0,verbose:!1,log:!0,strictSSL:!1}));let le=new hi(d.config.ai?.agentConfig,{baseUrl:a.baseUrl,apiKey:a.apiKey,logger:e}),ce=we(d,b),fe=await uc({tests:t,momenticFiles:ce,yes:r,project:d,include:x,exclude:y,labels:T,logger:e}),J=fe.filter(Fe=>!Fe.disabled),_e=fe.filter(Fe=>Fe.disabled),me=[];J.forEach((Fe,Rr)=>{S?S.forEach((bo,bt)=>{me.push({testIndex:Rr,inputs:bo,inputIndex:bt})}):me.push({testIndex:Rr,inputs:void 0,inputIndex:void 0})}),k&&k>1&&(me=h_(me,z,k));let At=`Running ${me.length} tests with ${H} workers:`;e.info({allTestsToRunWithInputs:me,shardCount:k,shardIndex:z,orgId:h},At),b.info(At),me.forEach(Fe=>{b.info(`${Wt}- ${[J[Fe.testIndex].relativeFilePath]}${typeof Fe.inputIndex=="number"?` with input set ${Fe.inputIndex}`:""}`)}),b.log("");let yt=[],En=new Date,fo=new Set,So=async()=>{let Fe=a.getAppUrl(),Rr=Pi({results:yt,startTime:En.getTime(),onFailed:bt=>{lc(bt,bt.filePath)},getDisplayLine:bt=>{let Ar=`${Wt}- ${bt.filePath}${bt.proposedTest?" [AUTO-HEALED] ":""}`;return bt.runId&&(Ar+=` ( link when uploaded: ${Fe}/runs/${bt.runId} )`),Ar},entity:"test"}),bo=yt.filter(bt=>!!bt.proposedTest);return bo.length>0&&b.warn(`${bo.length} tests passed with auto-healing. Please use the run links printed above to review proposed changes and apply them locally.`),b.log(""),L?(b.success(`Test results have been saved to the folder ${R}. Uploading to Momentic cloud.`),await fc({client:a,consoleLogger:b,resultsPath:R})):b.success(`Test results have been saved to the folder ${R}. Upload them to Momentic cloud by running 'npx momentic results upload ${R}'.`),Rr};u_.existsSync(R)&&b.warn(`Output directory ${R} already exists, removing before test execution...`);let nr=await hc.start(e,h,R,a,l,O),dn=e.child(nr.loggerBindings||{}),j=[],Ni=async()=>{b.warn("SIGINT received. Stopping tests and printing latest results..."),await nr.finish({logger:dn,status:"CANCELLED"}),await So(),await Promise.allSettled(j.map(Fe=>Fe())),process.exit(1)};process.once("SIGINT",Ni);let yo={};for(let Fe=0;Fe<me.length;Fe++){let Rr=Object.values(yo);Rr.length===H&&await Promise.race(Rr.map(Ar=>Ar.promise));let bo=me[Fe],bt=`test-${Fe}`;yo[bt]={done:!1,promise:(async({testIndex:Ar,inputs:Ju})=>{let wo=J[Ar];fo.add({testIndex:Ar,inputs:Ju});let Gx=wo.relativeFilePath.includes("..")?wo.fullFilePath:wo.relativeFilePath,Ya=(dt,ki)=>{dt=dt.toUpperCase();let Bn=dt,rr;dt.includes("FAIL")?(Bn=Mi.bgRed.white("FAIL"),rr=3):dt.includes("PASS")?(Bn=Mi.bgGreen.white("PASS"),rr=3):dt.includes("START")?(Bn=Mi.bgBlue.white("START"),rr=2):dt.includes("CANCEL")?(Bn=Mi.bgRgb(191,68,11).white("CANCEL"),rr=1):dt.includes("RETRY")?(Bn=Mi.bgRgb(191,68,11).white("RETRY"),rr=2):dt.includes("RUN")||dt.includes("PROG")?(Bn=Mi.bgMagenta.white("RUNNING"),rr=0):(dn.warn(`Unknown status tried to be logged in run test locally: ${dt}`),rr=0),p_||(Bn=`${Bn}`),b.log(`${Bn}${" ".repeat(rr)} ${Gx} ${ki?`${ki} `:""}(${fo.size}/${me.length})`)};Ya("START");let Wx=setInterval(()=>Ya("RUN"),5*60*1e3),Xu=dn.child({testId:wo.id});try{let dt=await Ox({testDefinition:wo,project:d,testInputs:Ju,orgId:h,devicePixelRatio:g,apiClient:a,runGroupTracer:nr,generator:le,retriesOverride:p,urlOverride:u,envName:m,customHeaders:f,regenerateGoldenFiles:_,logUpdate:Ya,runSigIntHandlers:j,logger:Xu,flagStore:c,gitMetadata:O,alwaysSaveCache:K,noCache:B});Ya(dt.status),yt.push(dt)}catch(dt){let ki=`Encountered unexpected fatal error when running test '${wo.name}': ${dt.message}`;b.error(ki),Xu.error(ki)}finally{clearInterval(Wx),yo[bt].done=!0,delete yo[bt]}})(bo)}}await Promise.allSettled(Object.values(yo).map(Fe=>Fe.promise));let Yu="PASSED";return yt.some(Fe=>Fe.status==="FAILED")&&(Yu="FAILED"),await nr.finish({logger:dn,status:Yu}),process.off("SIGINT",Ni),w&&await Rx(dn,s,w,{projectConfigPath:d.configFilePath,suiteName:d.config.name,startedAt:En,finishedAt:new Date,runs:yt,skippedTests:_e},C),So()}function h_(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 g_}from"crypto";import tr from"fs";import go from"path";var Dx={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 Fx(n,e){let t=n[e];if(!t)throw new Error(`No metadata value found for key: ${e}`);return t}function f_(n,e,t){if(Dx[t]){let i=Dx[t];return i(n,e)}let r=Fx(n,t),o=Fx(e,t);if(r!==o)throw new Error(`Metadata values for key "${t}" do not match: "${r}" vs "${o}"`);return r}var Ux=new Set([".DS_Store","__MACOSX"]);function Bx(n,e,t){let r=g_(),o=n.child({runGroupId:r});tr.rmSync(e,{recursive:!0,force:!0});let i=tr.readdirSync(t).filter(c=>!Ux.has(c)).map(c=>go.join(t,c));tr.mkdirSync(e,{recursive:!0});let a=go.join(i[0],"metadata.json"),s={...pa.parse(JSON.parse(tr.readFileSync(a,"utf-8"))),id:r};for(let c of i){let d=go.join(c,"runs");if(!tr.existsSync(d))continue;let p=tr.readdirSync(d);for(let h of p){if(Ux.has(h))continue;let g=go.join(d,h),f=go.join(e,"runs",h);tr.cpSync(g,f,{recursive:!0})}let u=go.join(c,"metadata.json"),m=pa.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]=f_(s,m,g)}}let l=go.join(e,"metadata.json");tr.writeFileSync(l,JSON.stringify(s,null,2))}var zx=new Ri({platform:"cli"},{flushAt:1,flushInterval:0});bc||te.warn("Sentry is not enabled in this environment due to unsupported node version");var x_=process.argv.some(n=>n.includes("--log-level"))&&process.argv.some(n=>n.includes("debug")),qu=n=>{x_&&b.dimmed(n)},Rt=new S_;Rt.name("momentic").description("CLI").version(vn);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 hx({rawBrowsers:n,force:e.force,all:e.all})});Rt.addOption(new Vt("--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 Vt("--verbose","enable verbose logging")).on("option:verbose",()=>{te.enableConsoleLogs(),b.setMinLevel(0)});var Ku=Rt.command("checks").alias("check").description("Perform various project checks");Ku.command("config").addOption(xn).action(async n=>{$t({configFilePath:n.config})});Ku.command("duplicate-ids").description("Checks if any steps in your entire Momentic test repository share the same ID.").addOption(xn).addOption(Vv).action(async n=>{let e=await cn(n),t=$t({configFilePath:n.config});await nx({project:t,fix:e.fix})});Ku.command("duplicate-names").description("Checks if tests or modules with duplicate names or ids exist").addOption(xn).action(async n=>{let e=$t({configFilePath:n.config});await rx({project:e})});var Hx=Rt.command("migrate").description("Migrate and upgrade tooling");Hx.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(xn).action(async n=>{let e=$t({configFilePath:n.config});await gx(e)});Hx.command("v1-v2").description("Migrate from v1 of the Momentic CLI to v2").addOption(Qn).addOption(xn).addOption(Zn).action(async n=>{let e=await cn(n);!e.yes&&!await St("This command will modify your existing Momentic configuration. Please backup your local directory using Git or another version control system before proceeding. Continue?",!0)&&process.exit(1);let t=$t({configFilePath:n.config}),r=new ct({baseUrl:e.server,apiKey:e.apiKey,logger:te}),{orgId:o}=await r.getAuthInfo();await Sx({project:t,orgId:o,apiClient:r}),process.exit(0)});Rt.command("import").addOption(Zn).addOption(Qn).addOption(xn).addOption(uo).addArgument(Kv).action(async(n,e)=>{let t=await cn(e),{apiKey:r,server:o,config:i,yes:a}=t,s=$t({configFilePath:i}),l=new ct({baseUrl:o,apiKey:r,logger:te});!n||n.length===0?await lx({client:l,project:s,skipPrompts:a}):await cx({client:l,project:s,paths:n,skipPrompts:a}),process.exit(0)});Rt.command("init").description("Initialize an empty Momentic project in the current working directory").addOption(new Vt("--name <name>","Name of the project")).action(async n=>{b.info(`Welcome to the Momentic project setup wizard! \u{1F680}
|
|
3885
|
-
`),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."),yc.existsSync(
|
|
3886
|
-
`)),process.exit(0)});var
|
|
3936
|
+
`)}`),Object.values(e.tests).forEach(u=>{n.some(m=>u.relativePath.includes(m))&&l.add(u.fullFilePath)}))}else{!r&&!await St("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=zu.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 fa(d,te,e);if(r_.gt(p.schemaVersion,De)&&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:zu.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(t_)}import{cloneDeep as Li}from"lodash-es";async function IE({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 Gt({orgId:n,s:c,localTools:e,logger:t,context:o,flagStore:i})}return a}async function PE({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,visualDiffScreenshotStorage:g,flagStore:f}){let S=await Ll({settings:h,customHeaders:u,envVariables:d,envName:e,testName:t,baseUrl:n,logger:p,localTools:s,orgId:c,flagStore:f}),w={baseUrl:o.baseUrl,apiKey:o.apiKey,logger:te},E=f.isBooleanFlagEnabled("icon_knowledge_base")?await a.fetchIconKnowledgeBase(p):null,y=S.browserType??"Chromium";if(!hE(y)){let L=`Browser ${y} 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:S,storage:a,flagStore:f,enricher:new hi(w,l),contextArgs:{viewport:i.advanced.viewport??Jt,locale:i.advanced.locale??_o,geolocation:i.advanced.geolocation??Fo,timezoneId:i.advanced.timezone??Do,colorScheme:i.advanced.colorScheme,deviceScaleFactor:r},iconKnowledgeBase:E}),C=new Ei({browser:T,generator:l,logger:p,orgId:c,options:{scratchPadId:void 0,slowMoMs:S.slowMoMs,autoFollowNewTabs:S.autoFollowNewTabs,useMemory:i.advanced.useMemory},storage:a,flagStore:f,localCodeEvalTools:s,visualDiffScreenshotStorage:g,analytics:new Ti}),R=new Ot({baseUrl:n,currentUrl:C.browser.url(),variablesFromEnvironment:d,envName:e,testName:t});return i.parameters&&await Promise.all(i.parameters.map(async L=>{let{name:M,defaultValue:H,required:z}=L,k=m?.[M];z&&k===void 0&&(b.error(`Required parameter '${M}' is required by test '${i.name}' but not provided`),process.exit(1));let _=await Gt({orgId:c,s:k??H,localTools:s,logger:p,context:Ot.dummyContext(R.getEnvName()),flagStore:f});R.setMomenticSystemVariable(M,_)})),{controller:C,context:R}}import{randomUUID as o_}from"crypto";async function LE({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")?Ai?!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 OE({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},T={orgId:o,runId:i||o_(),runAttemptId:a,testMetadata:w,steps:w.steps,beforeSteps:w.beforeSteps,afterSteps:w.afterSteps},C={collectDebugData:!0,reinitializeBrowser:!0,disableHealing:!await LE({currentAttempt:r,testId:w.id,flagStore:c,apiClient:g,testAdvancedSettings:w.advanced,aiSettingsFromEnv:E.ai,logger:h})};return await Pl({fixtures:y,inputs:T,options:C,callbacks:{step:{},test:{onTestComplete:async()=>{await s.browser.cleanup()},onProposedTestSteps:async M=>g.uploadProposedSteps(M,h)}},testParams:{tracer:S}})}async function NE(n){let{testDefinition:e,logger:t}=n,r=new Date;try{return await i_(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 i_(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 pi(r,o),m=gi({orgId:o,client:r,gitMetadata:c,alwaysSaveCache:d,noCache:p}),h=Li(e.steps),g=Li(e.beforeSteps)??void 0,f=Li(e.afterSteps)??void 0;try{await m.resolveStepCacheEntries({testId:e.id,stepLists:{steps:h,beforeSteps:g,afterSteps:f},schemaVersion:e.schemaVersion,logger:l})}catch(R){throw l.error({err:R},"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: ${R}`)}let S=n.envName??s_(e),w,E={};if(S){try{w=Sa(S,t,l)}catch(R){let L=`Failed to resolve environment ${S} for test ${e.name}: ${R}`;throw new Error(L)}E=w.variables}let y=e.baseUrl;if(i)y=i;else if(!y){let R=E[We];typeof R=="string"&&(y=R)}if(!y){let R=`Cannot run test with no base URL and no ${We} variable defined in its environment`;throw new Error(R)}let T=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}),C=l.child(T.loggerBindings||{});Object.entries(T.envVarBindings||{}).forEach(([R,L])=>{E[R]=L});try{let R=await a_({...n,variables:E,envName:S,resolvedEnv:w,baseUrl:y,storageClient:u,tracer:T,logger:C,cacheStorage:m,stepsWithCaches:h,beforeStepsWithCaches:g,afterStepsWithCaches:f});return await T.finish({logger:l,status:R.status,finishedAt:R.finishedAt,failureDetails:R.failureDetails,failureReason:R.failureReason,isFlake:R.isFlake}),{runId:T.runId,...R}}finally{a?.pop()}}async function a_(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:T,logger:C,flagStore:R,cacheStorage:L}=n,M=new Date,H=new si(i,a),z={ai:i.config.ai},k={envName:u,urlOverride:m,customHeaders:h,testInputs:g},_,O=Math.abs(w??i.config.retries??e.retries??0),K=[];C.info({labels:e.labels,name:e.name,cwd:process.cwd()},"Starting test run using CLI");for(let B=0;B<=O;B++){let se=await T.startAttempt(),le=C.child(se.loggerBindings||{}),fe={...e,steps:Li(t),beforeSteps:Li(r),afterSteps:Li(o)};B!==0&&y("RETRY",`attempt ${B+1}/${O+1}`);let J=new Date,_e=new Sr({httpClient:new Ft({baseUrl:s.baseUrl,apiKey:s.apiKey,logger:le}),fakerSeed:R.isBooleanFlagEnabled("faker_constant_seed")?Uh:void 0});try{let{controller:ue,context:At}=await PE({baseUrl:c,envName:u,testName:fe.name,apiClient:s,devicePixelRatio:E,logger:le,storageClient:d,codeEvalTools:_e,test:fe,generator:l,orgId:p,variables:f,customHeaders:h,testInputs:g,localBrowserConfig:{...i.config.browser||{},...S?.browser||{},...fe.advanced},visualDiffScreenshotStorage:H,flagStore:R});_=await OE({attemptMetadata:{attemptNumber:B+1,orgId:p,runId:T.runId},attemptFixtures:{logger:le,storageClient:d,billingReporter:new jo,analytics:new Ti,debugDataStorage:new Br,codeEvalTools:_e,flagStore:R,apiClient:s,context:At,controller:ue,tracer:se},attemptInputs:{test:fe,orgSettings:z}});let yt=new Date;_?.status==="PASSED"&&await $s({logger:C,cacheStorage:L,orgId:p,testId:e.id,originalSteps:{steps:e.steps,beforeSteps:e.beforeSteps,afterSteps:e.afterSteps},updatedSteps:{steps:fe.steps,beforeSteps:fe.beforeSteps,afterSteps:fe.afterSteps}}),await se.finish({logger:le,result:_}),K.unshift(_.status);let xn=await IE({orgId:p,codeEvalTools:_e,logger:le,outputDefinitions:e.outputs??[],testContext:At,flagStore:R}),go=gh(K),fo=B+1;if(_.status!=="FAILED")return{..._,parameters:k,test:fe,filePath:fe.relativeFilePath,startedAt:M,lastAttemptStartedAt:J,finishedAt:yt,attempts:fo,baseUrl:c,outputs:xn,isFlake:go};let nr=_.failedStepResult,dn=nr?.message||"Unknown failure",j=nr?.failureReason??Kh(dn)??"UnknownError",Ni=le.child({errResult:nr,failureReason:j,errorMessage:dn,numAttempts:O+1,name:fe.name});if(B<O){Ni.warn(`Retrying failed execution attempt for run: ${dn}`);continue}return Ni.error(`Test failed after all exhausting attempts: ${dn}`),{..._,parameters:k,failureDetails:{errorMessage:dn},failureReason:j,test:fe,filePath:fe.relativeFilePath,startedAt:M,lastAttemptStartedAt:J,finishedAt:yt,attempts:B+1,baseUrl:c,outputs:xn}}catch(ue){ki(ue);let At=`Encountered fatal platform error while running test '${fe.name}': ${ue}`,yt=new Date,xn=B+1;le.error({err:ue},At),b.error(At);let go={errorMessage:ue.message,errStack:ue.stack},fo={status:"FAILED",failureDetails:go,failureReason:"InternalPlatformError",finishedAt:yt};return await se.finish({logger:le,result:{status:"FAILED",results:[]}}),{...fo,parameters:k,test:fe,filePath:fe.relativeFilePath,startedAt:M,lastAttemptStartedAt:J,finishedAt:new Date,attempts:xn,baseUrl:c,outputs:{}}}}throw new Error("This code should not be reachable")}function s_(n){for(let e of n.envs??[])if(e.default)return e.name}import{randomUUID as kE}from"crypto";import l_ from"adm-zip";import er from"fs";import mo from"path";var Ka=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 Hu(mo.join(this.filePath,"runs"),e)}},Hu=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 Ka(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 l_;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 ME(n,e,t,r,o){let i=ia(o.type);if(i&&await e.reportCreditsUsed(n,o.type,i,{testId:t,testName:r}),"command"in o){let a=aa(o.command);a&&await e.reportCreditsUsed(n,o.command.type,a,{testId:t,testName:r})}}function c_(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 d_(n){switch(n){case"SUCCESS":return"PASSED";case"FAILED":return"FAILED";case"CANCELLED":return"CANCELLED";case"RUNNING":return"RUNNING";case"IDLE":return"PENDING"}}var ju=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:d_(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 mc(this.testId,this.testName,e,this.billingReporter,this.asyncWork);return this.children.push(t),t}},mc=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(ME(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 ju(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:c_(e.status),finishedAt:e.finishedAt}))))}},$u=class{constructor(e,t,r,o,i,a,s,l,c){this.orgId=e;this.testId=t;this.testName=r;this.originalSteps=o;this.metadata=i;this.client=a;this.diskStorage=s;this.billingReporter=l;this.asyncWork=c}finished=!1;children=[];trackStatus(){}attachNetworkLogs(e){let{logs:t}=e;this.diskStorage.storeFile({name:"network.har",contents:JSON.stringify(t,null,2)})}attachConsoleLogs(e){let{logs:t}=e;this.diskStorage.storeFile({name:"console.json",contents:JSON.stringify(t,null,2)})}async finish(e){if(this.finished)return;this.finished=!0;let{logger:t,result:r}=e,o={...this.metadata,status:r.status,finishedAt:new Date,results:Ws(r.results,t),beforeResults:r.beforeResults?Ws(r.beforeResults,t):void 0,afterResults:r.afterResults?Ws(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 mc(this.testId,this.testName,e,this.billingReporter,this.asyncWork);return this.children.push(t),t}},Gu=class{constructor(e,t,r,o,i,a,s,l,c,d){this.orgId=e;this.testId=t;this.testName=r;this.runId=o;this.originalSteps=i;this.metadata=a;this.client=s;this.diskStorage=l;this.billingReporter=c;this.asyncWork=d}children=[];finished=!1;get loggerBindings(){return{runId:this.runId}}get envVarBindings(){return{[qy]:this.runId}}async finish(e){if(this.finished)return;this.finished=!0;let t={...this.metadata,finishedAt:e.finishedAt||new Date,status:e.status,failureDetails:e.failureDetails,failureReason:e.failureReason,flake:e.isFlake||!1};await Promise.all(this.children.map(r=>r.finish({logger:e.logger,result:{status:t.status,results:[],beforeResults:[],afterResults:[]}}))),this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(t,null,2)}),this.diskStorage.close()}trackStatus(){}async startAttempt(){this.metadata.attempts=this.metadata.attempts+1,this.metadata.status="RUNNING",this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(this.metadata,null,2)});let e=this.diskStorage.cd(`attempts/${this.metadata.attempts}`),t={schemaVersion:De,startedAt:new Date,status:"RUNNING"};e.storeFile({name:"metadata.json",contents:JSON.stringify(t,null,2)});let r=new $u(this.orgId,this.testId,this.testName,this.originalSteps,t,this.client,e,this.billingReporter,this.asyncWork);return this.children.push(r),r}},hc=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=kE(),l={...a,id:s,trigger:Xt.CLI,startedAt:new Date,status:"RUNNING",cliVersion:vn},c=new Ka(r);return c.storeFile({name:"metadata.json",contents:JSON.stringify(l,null,2)}),new n(t,s,l,o,c,i)}async finish(e){if(this.finished)return;this.finished=!0;let{status:t}=e,r={...this.metadata,status:t,updatedAt:new Date,finishedAt:new Date};await Promise.all(this.children.map(o=>o.finish({logger:e.logger,status:r.status,finishedAt:r.finishedAt}))),this.diskStorage.storeFile({name:"metadata.json",contents:JSON.stringify(r,null,2)}),await Promise.allSettled(this.asyncWork)}trackStatus(){}async startRun(e){let t=kE(),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:vn,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 Gu(this.orgId,e.testId,e.testName,t,e.originalSteps,o,this.client,r,this.billingReporter,this.asyncWork);return this.children.push(i),i}};import _E from"adm-zip";import Wu from"fs";import gc from"path";function p_(n){let e=new _E,t=gc.join(n,"metadata.json"),r=pa.parse(JSON.parse(Wu.readFileSync(t,"utf-8")));e.addLocalFile(t);for(let o of Wu.readdirSync(gc.join(n,"runs"))){if(!o.endsWith(".zip"))continue;let i=o.replace(/\.zip$/,""),a=new _E(gc.join(n,"runs",o));for(let s of a.getEntries())s.isDirectory||e.addFile(gc.join("runs",i,s.entryName),s.getData())}return{runGroupId:r.id,buffer:e.toBuffer()}}async function fc(n){let{client:e,consoleLogger:t,resultsPath:r}=n;if(!Wu.existsSync(r)){t.warn("Results path does not exist, skipping upload.");return}let o=new El(e);try{let{runGroupId:i,buffer:a}=p_(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 DE(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:T,reporterDir:C=uy,outputDir:R=my,uploadResults:L=!1,waitOnTimeout:M=60,parallel:H=d.config.parallel??1,shardIndex:z=1,shardCount:k=1,regenerateGoldenFiles:_,gitMetadata:O,alwaysSaveCache:K,noCache:B}=n;o&&(e.info({orgId:h},`Executing start command: ${o}`),await Ov(o,!1)),i&&(e.info({orgId:h},`Waiting for url: ${i} with timeout: ${M} seconds.`),await h_({resources:[i],interval:2500,timeout:M*1e3,headers:{Accept:"*/*"},followRedirect:!0,verbose:!1,log:!0,strictSSL:!1}));let se=new mi(d.config.ai?.agentConfig,{baseUrl:a.baseUrl,apiKey:a.apiKey,logger:e}),le=ve(d,b),fe=await uc({tests:t,momenticFiles:le,yes:r,project:d,include:E,exclude:y,labels:T,logger:e}),J=fe.filter(Fe=>!Fe.disabled),_e=fe.filter(Fe=>Fe.disabled),ue=[];J.forEach((Fe,Rr)=>{S?S.forEach((yo,bt)=>{ue.push({testIndex:Rr,inputs:yo,inputIndex:bt})}):ue.push({testIndex:Rr,inputs:void 0,inputIndex:void 0})}),k&&k>1&&(ue=g_(ue,z,k));let At=`Running ${ue.length} tests with ${H} workers:`;e.info({allTestsToRunWithInputs:ue,shardCount:k,shardIndex:z,orgId:h},At),b.info(At),ue.forEach(Fe=>{b.info(`${Wt}- ${[J[Fe.testIndex].relativeFilePath]}${typeof Fe.inputIndex=="number"?` with input set ${Fe.inputIndex}`:""}`)}),b.log("");let yt=[],xn=new Date,go=new Set,fo=async()=>{let Fe=a.getAppUrl(),Rr=Ii({results:yt,startTime:xn.getTime(),onFailed:bt=>{lc(bt,bt.filePath)},getDisplayLine:bt=>{let Ar=`${Wt}- ${bt.filePath}${bt.proposedTest?" [AUTO-HEALED] ":""}`;return bt.runId&&(Ar+=` ( link when uploaded: ${Fe}/runs/${bt.runId} )`),Ar},entity:"test"}),yo=yt.filter(bt=>!!bt.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(""),L?(b.success(`Test results have been saved to the folder ${R}. Uploading to Momentic cloud.`),await fc({client:a,consoleLogger:b,resultsPath:R})):b.success(`Test results have been saved to the folder ${R}. Upload them to Momentic cloud by running 'npx momentic results upload ${R}'.`),Rr};m_.existsSync(R)&&b.warn(`Output directory ${R} already exists, removing before test execution...`);let nr=await hc.start(e,h,R,a,l,O),dn=e.child(nr.loggerBindings||{}),j=[],Ni=async()=>{b.warn("SIGINT received. Stopping tests and printing latest results..."),await nr.finish({logger:dn,status:"CANCELLED"}),await fo(),await Promise.allSettled(j.map(Fe=>Fe())),process.exit(1)};process.once("SIGINT",Ni);let So={};for(let Fe=0;Fe<ue.length;Fe++){let Rr=Object.values(So);Rr.length===H&&await Promise.race(Rr.map(Ar=>Ar.promise));let yo=ue[Fe],bt=`test-${Fe}`;So[bt]={done:!1,promise:(async({testIndex:Ar,inputs:Yu})=>{let bo=J[Ar];go.add({testIndex:Ar,inputs:Yu});let WE=bo.relativeFilePath.includes("..")?bo.fullFilePath:bo.relativeFilePath,Ya=(dt,Mi)=>{dt=dt.toUpperCase();let Un=dt,rr;dt.includes("FAIL")?(Un=Oi.bgRed.white("FAIL"),rr=3):dt.includes("PASS")?(Un=Oi.bgGreen.white("PASS"),rr=3):dt.includes("START")?(Un=Oi.bgBlue.white("START"),rr=2):dt.includes("CANCEL")?(Un=Oi.bgRgb(191,68,11).white("CANCEL"),rr=1):dt.includes("RETRY")?(Un=Oi.bgRgb(191,68,11).white("RETRY"),rr=2):dt.includes("RUN")||dt.includes("PROG")?(Un=Oi.bgMagenta.white("RUNNING"),rr=0):(dn.warn(`Unknown status tried to be logged in run test locally: ${dt}`),rr=0),u_||(Un=`${Un}`),b.log(`${Un}${" ".repeat(rr)} ${WE} ${Mi?`${Mi} `:""}(${go.size}/${ue.length})`)};Ya("START");let VE=setInterval(()=>Ya("RUN"),5*60*1e3),Ju=dn.child({testId:bo.id});try{let dt=await NE({testDefinition:bo,project:d,testInputs:Yu,orgId:h,devicePixelRatio:g,apiClient:a,runGroupTracer:nr,generator:se,retriesOverride:p,urlOverride:u,envName:m,customHeaders:f,regenerateGoldenFiles:_,logUpdate:Ya,runSigIntHandlers:j,logger:Ju,flagStore:c,gitMetadata:O,alwaysSaveCache:K,noCache:B});Ya(dt.status),yt.push(dt)}catch(dt){let Mi=`Encountered unexpected fatal error when running test '${bo.name}': ${dt.message}`;b.error(Mi),Ju.error(Mi)}finally{clearInterval(VE),So[bt].done=!0,delete So[bt]}})(yo)}}await Promise.allSettled(Object.values(So).map(Fe=>Fe.promise));let Ku="PASSED";return yt.some(Fe=>Fe.status==="FAILED")&&(Ku="FAILED"),await nr.finish({logger:dn,status:Ku}),process.off("SIGINT",Ni),w&&await AE(dn,s,w,{projectConfigPath:d.configFilePath,suiteName:d.config.name,startedAt:xn,finishedAt:new Date,runs:yt,skippedTests:_e},C),fo()}function g_(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 f_}from"crypto";import tr from"fs";import ho from"path";var FE={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 UE(n,e){let t=n[e];if(!t)throw new Error(`No metadata value found for key: ${e}`);return t}function S_(n,e,t){if(FE[t]){let i=FE[t];return i(n,e)}let r=UE(n,t),o=UE(e,t);if(r!==o)throw new Error(`Metadata values for key "${t}" do not match: "${r}" vs "${o}"`);return r}var BE=new Set([".DS_Store","__MACOSX"]);function zE(n,e,t){let r=f_(),o=n.child({runGroupId:r});tr.rmSync(e,{recursive:!0,force:!0});let i=tr.readdirSync(t).filter(c=>!BE.has(c)).map(c=>ho.join(t,c));tr.mkdirSync(e,{recursive:!0});let a=ho.join(i[0],"metadata.json"),s={...pa.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(BE.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=pa.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]=S_(s,m,g)}}let l=ho.join(e,"metadata.json");tr.writeFileSync(l,JSON.stringify(s,null,2))}var HE=new Ci({platform:"cli"},{flushAt:1,flushInterval:0});bc||te.warn("Sentry is not enabled in this environment due to unsupported node version");var x_=process.argv.some(n=>n.includes("--log-level"))&&process.argv.some(n=>n.includes("debug")),Vu=n=>{x_&&b.dimmed(n)},Rt=new y_;Rt.name("momentic").description("CLI").version(vn);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: ${ku.join(", ")}.`).action(async(n,e)=>{!e.all&&n.length===0&&(b.error("No browsers specified"),process.exit(1)),await gE({rawBrowsers:n,force:e.force,all:e.all})});Rt.addOption(new Vt("--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 Vt("--verbose","enable verbose logging")).on("option:verbose",()=>{te.enableConsoleLogs(),b.setMinLevel(0)});var qu=Rt.command("checks").alias("check").description("Perform various project checks");qu.command("config").addOption(En).action(async n=>{$t({configFilePath:n.config})});qu.command("duplicate-ids").description("Checks if any steps in your entire Momentic test repository share the same ID.").addOption(En).addOption(qv).action(async n=>{let e=await cn(n),t=$t({configFilePath:n.config});await rE({project:t,fix:e.fix})});qu.command("duplicate-names").description("Checks if tests or modules with duplicate names or ids exist").addOption(En).action(async n=>{let e=$t({configFilePath:n.config});await oE({project:e})});var jE=Rt.command("migrate").description("Migrate and upgrade tooling");jE.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(En).action(async n=>{let e=$t({configFilePath:n.config});await fE(e)});jE.command("v1-v2").description("Migrate from v1 of the Momentic CLI to v2").addOption(Qn).addOption(En).addOption(Zn).action(async n=>{let e=await cn(n);!e.yes&&!await St("This command will modify your existing Momentic configuration. Please backup your local directory using Git or another version control system before proceeding. Continue?",!0)&&process.exit(1);let t=$t({configFilePath:n.config}),r=new ct({baseUrl:e.server,apiKey:e.apiKey,logger:te}),{orgId:o}=await r.getAuthInfo();await yE({project:t,orgId:o,apiClient:r}),process.exit(0)});Rt.command("import").addOption(Zn).addOption(Qn).addOption(En).addOption(po).addArgument(Yv).action(async(n,e)=>{let t=await cn(e),{apiKey:r,server:o,config:i,yes:a}=t,s=$t({configFilePath:i}),l=new ct({baseUrl:o,apiKey:r,logger:te});!n||n.length===0?await cE({client:l,project:s,skipPrompts:a}):await dE({client:l,project:s,paths:n,skipPrompts:a}),process.exit(0)});Rt.command("init").description("Initialize an empty Momentic project in the current working directory").addOption(new Vt("--name <name>","Name of the project")).action(async n=>{b.info(`Welcome to the Momentic project setup wizard! \u{1F680}
|
|
3937
|
+
`),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."),yc.existsSync(oi)&&(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 Fv("Choose an identifier for your project, such as a service, product, or team name (default: 'app'):","app"),include:op};ii(t,oi),b.success(`Initialized Momentic project file at ${Sc.resolve(oi)}`)});Rt.command("app").addOption(Zn).addOption(Qn).addOption(po).addOption(Cu).addOption(Gv).addOption(En).addOption(Au).addOption(Iu).action(async n=>{let e=await cn(n),{apiKey:t,port:r=ec,yes:o,server:i,pixelRatio:a,disableCache:s,saveCache:l}=e,c=new ct({baseUrl:i,apiKey:t,logger:te});await Lu({client:c,skipPrompts:o});let d=E_(import.meta.url),p=Sc.dirname(d),u=Sc.resolve(p,"..","static"),m=Sc.resolve(p,"..","assets"),h=a??hu();gu(h),await Iv({momenticServerUrl:i,apiKey:t,serverPort:r,appPort:r,staticDir:u,assetsDir:m,devicePixelRatio:h,version:vn,noCache:s,alwaysSaveCache:l});let g=`http://localhost:${r}`;await v_(g)});var $E=Rt.command("queue").description("Queue tests or suites to run on Momentic Cloud");$E.command("suites").description("Run one or more suites on Momentic Cloud").addOption(Zn).addOption(Qn).addOption(wu).addOption(vu).addOption(po).addArgument(Jv).addOption(rc).addOption(nc).addOption(tc).action(async(n,e)=>{let{apiKey:t,server:r,wait:o,waitTimeout:i,env:a,urlOverride:s,customHeaders:l}=await cn(e),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 wE({client:c,orgId:d,wait:o,suitePaths:n,waitTimeout:i,env:a,urlOverride:s,customHeaders:ic(l)})});$E.command("tests").description("Run one or more tests on Momentic Cloud").addOption(Zn).addOption(Qn).addOption(po).addOption(tc).addOption(Ru).addOption(rc).addOption(nc).addOption(wu).addOption(vu).addArgument(Kv).action(async(n,e)=>{let t=await cn(e),{all:r,apiKey:o,customHeaders:i,env:a,server:s,inputCsv:l,urlOverride:c,wait:d,waitTimeout:p,yes:u}=t,m=ic(i);for(let S of n)(S.endsWith(".yaml")||yc.existsSync(S))&&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 h=new ct({baseUrl:s,apiKey:o,logger:te}),{orgId:g}=await h.getAuthInfo(),f;l&&(f=await fu(l)),await vE({client:h,orgId:g,tests:n,all:r,customHeaders:m,env:a,urlOverride:c,wait:d,waitTimeout:p,testInputMatrix:f,yes:u}),process.exit(0)});var T_=Rt.command("list").description("List test paths");T_.addOption(En).addOption(oc).addOption(xu).addOption(Tu).addOption(new Vt("--labels <labels...>","Only run tests with the specified label(s).")).addArgument(Pu).action(async(n,e)=>{let t=await cn(e),r=$t({configFilePath:t.config,nameFilter:t.filter}),o=ve(r,b),i=await uc({tests:n,momenticFiles:o,yes:!0,project:r,include:t.include,exclude:t.exclude,labels:t.labels,logger:mg});b.info(i.map(a=>a.relativeFilePath).join(`
|
|
3938
|
+
`)),process.exit(0)});var C_=Rt.command("run").alias("test").description("Run tests on the local machine");C_.addOption(Zn).addOption(Qn).addOption(En).addOption(oc).addOption(po).addOption(tc).addOption(Ru).addOption(Au).addOption(Iu).addOption(nc).addOption(rc).addOption(Cu).addOption(new Vt("--start <start>","Arbitrary setup command that will run before Momentic steps begin.")).addOption(new Vt("--wait-on <waitOn>","URL to wait to become accessible before Momentic tests begin.")).addOption(new Vt("--wait-on-timeout <waitOnTimeout>","Max time in seconds to wait for the --wait-on URL to become accessible.")).addOption(new Vt("--retries <retries>","Number of retries to attempt when running tests locally. Defaults to each test's own retry configuration.")).addOption(new Vt("-p, --parallel <parallel>","When running with the --local flag, the number of tests to run in parallel. Defaults to 1.")).addOption(new Vt("--labels <labels...>","Only run tests with the specified label(s).")).addOption(new Vt("--update-golden-files","Update locally stored golden files for steps that this is enabled for.")).addOption(Hv).addOption(jv).addOption(Eu).addOption($v).addOption(Wv).addOption(Vv).addOption(xu).addOption(Tu).addArgument(Pu).action(async(n,e)=>{b.debug("Run tests invoked");let t=await cn(e);b.debug(t,"Parsed CLI options");let r=ic(t.customHeaders),o=$t({configFilePath:t.config,nameFilter:t.filter});b.debug({projectName:o.config.name},"Identified project config");let{errors:i}=await Nu({project:o,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:t.server,apiKey:t.apiKey,logger:te});b.debug("Checking API key and dependencies");let{orgId:s,userId:l}=await Lu({client:a,skipPrompts:t.yes});b.debug("API key check and browser installation complete");let c=new wl(a),d=new vl(a),p=t.outputDir??o.config.outputDir,u=t.reporterDir??o.config.reporterDir,m=te.child({orgId:s,userId:l,cliVersion:vn,trigger:"CLI"}),h=await ci(te,a,o);m.debug(h,"Got local git metadata");let g=new li(o.config),f=HE.child({org_id:s,user_id:l,cli_version:vn,trigger:"CLI"}),S;t.inputCsv&&(S=await fu(t.inputCsv));let w=t.pixelRatio??hu();gu(w);try{(await DE({...t,retriesOverride:t.retries,devicePixelRatio:w,tests:n,project:o,client:a,debugDataStorage:d,billingReporter:c,analytics:f,flagStore:g,outputDir:p,uploadResults:t.uploadResults,reporterDir:u,customHeaders:r,envName:t.env,orgId:s,testInputMatrix:S,logger:m,regenerateGoldenFiles:t.updateGoldenFiles,gitMetadata:h,alwaysSaveCache:t.saveCache,noCache:t.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 R_=Rt.command("apply").description("Apply an operation to local resources");R_.command("patch").addOption(Zn).addOption(Qn).addOption(En).addOption(oc).addOption(po).addOption(new Vt("--from <from>","Name or ID of the patch to apply").makeOptionMandatory()).addOption(new Vt("--to <to>","Name or ID of the test to apply the patch to").makeOptionMandatory()).action(async n=>{let e=await cn(n),{apiKey:t,server:r,config:o,yes:i}=e,a=$t({configFilePath:o}),s=te,l=new ct({baseUrl:r,apiKey:t,logger:s}),c=ve(a,b),d=c.tests[n.to]??Object.values(c.tests).find(u=>Me(u.name)===n.to.trim());d||(b.error(`No test matching '${n.to}' could be found in the current project.`),process.exit(1));let p=await l.fetchTestFragment(n.from);await Uv({client:l,test:d,fragment:p,yes:i,entities:c,logger:te}),process.exit(0)});var GE=Rt.command("results").description("Merge and upload test results.");GE.command("merge").description("Merge test results files.").addOption(Eu).addArgument(Xv).action(async(n,e)=>{let t=await cn(e),{outputDir:r}=t;r||(b.error("Output directory is required."),process.exit(1)),yc.existsSync(n)||(b.warn("Results path does not exist, skipping merge."),process.exit(0)),yc.existsSync(r)&&b.warn(`Output directory ${r} already exists, removing before merging...`),zE(te,r,n)});GE.command("upload").description("Upload test results to Momentic cloud.").addOption(Zn).addOption(Qn).addArgument(Zv).action(async(n,e)=>{let t=await cn(e),{apiKey:r,server:o}=t,i=te,a=new ct({baseUrl:o,apiKey:r,logger:i});await fc({consoleLogger:b,resultsPath:n,client:a}),process.exit(0)});async function A_(){Vu("Main program started"),await Mv(te),Vu("CLI version check complete");try{await Rt.parseAsync(process.argv)}catch(n){let e={};try{e.playwrightVersion=b_("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(),ki(n,e),b.error(n),process.exit(1)}}w_.setMaxListeners(50);process.on("warning",n=>{te.warn({err:n},`Node warning received on CLI: ${n.message}`)});Vu("CLI parsing setup complete");A_();
|
|
3887
3939
|
//# sourceMappingURL=cli.js.map
|
|
3888
|
-
//# debugId=
|
|
3940
|
+
//# debugId=6256feb0-d23a-52f4-bf58-990004f6ae2f
|