@ranger-testing/ranger-cli 2.5.3 → 2.5.4-alpha.1f7a251-7

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.
Files changed (80) hide show
  1. package/build/cli.js +1 -1
  2. package/build/commands/addEnv.js +1 -1
  3. package/build/commands/authEncrypt.js +1 -1
  4. package/build/commands/clean.js +1 -1
  5. package/build/commands/config.js +1 -1
  6. package/build/commands/env.js +1 -1
  7. package/build/commands/feature.js +1 -1
  8. package/build/commands/hook.js +1 -1
  9. package/build/commands/hooks/autoPrompt.js +1 -1
  10. package/build/commands/hooks/disable.js +1 -1
  11. package/build/commands/hooks/enable.js +1 -1
  12. package/build/commands/hooks/exitPlanMode.js +1 -1
  13. package/build/commands/hooks/index.js +1 -1
  14. package/build/commands/hooks/output.js +1 -1
  15. package/build/commands/hooks/planReminder.js +1 -1
  16. package/build/commands/hooks/planStart.js +1 -1
  17. package/build/commands/hooks/postEdit.js +1 -1
  18. package/build/commands/hooks/preCompact.js +1 -1
  19. package/build/commands/hooks/sessionEnd.js +1 -1
  20. package/build/commands/hooks/sessionStart.js +1 -1
  21. package/build/commands/hooks/stopHook.js +1 -1
  22. package/build/commands/index.js +1 -1
  23. package/build/commands/login.js +1 -1
  24. package/build/commands/mcpBootstrap.js +1 -1
  25. package/build/commands/migrateProfile.js +1 -0
  26. package/build/commands/setup/claude.js +1 -1
  27. package/build/commands/setup/opencode.js +1 -1
  28. package/build/commands/setupCi.js +1 -1
  29. package/build/commands/skillup.js +1 -1
  30. package/build/commands/start.js +1 -1
  31. package/build/commands/status.js +1 -1
  32. package/build/commands/update.js +1 -1
  33. package/build/commands/updateEnv.js +1 -1
  34. package/build/commands/useEnv.js +1 -1
  35. package/build/commands/utils/activeProfile.js +1 -1
  36. package/build/commands/utils/agentEnv.js +1 -1
  37. package/build/commands/utils/browserSessionsApi.js +1 -1
  38. package/build/commands/utils/claudeConfig.js +1 -1
  39. package/build/commands/utils/claudeOverrideSettings.js +1 -1
  40. package/build/commands/utils/claudePlugin.js +1 -1
  41. package/build/commands/utils/cloudProfile.js +1 -0
  42. package/build/commands/utils/cloudProfileSession.js +1 -0
  43. package/build/commands/utils/crypto.js +1 -1
  44. package/build/commands/utils/desirePathLog.js +1 -1
  45. package/build/commands/utils/deviceAuth.js +1 -1
  46. package/build/commands/utils/environment.js +1 -1
  47. package/build/commands/utils/featureApi.js +1 -1
  48. package/build/commands/utils/fixWebmDuration.js +1 -1
  49. package/build/commands/utils/gitTracked.js +1 -0
  50. package/build/commands/utils/keychain.js +1 -1
  51. package/build/commands/utils/localAgentInstallationsApi.js +1 -1
  52. package/build/commands/utils/matchAuthEnvironment.js +1 -0
  53. package/build/commands/utils/mcpImageBase64.js +1 -1
  54. package/build/commands/utils/model.js +1 -1
  55. package/build/commands/utils/opencodeConfig.js +1 -1
  56. package/build/commands/utils/playwrightCli.js +1 -1
  57. package/build/commands/utils/profileMessages.js +1 -1
  58. package/build/commands/utils/profileSetupBanner.js +1 -1
  59. package/build/commands/utils/projectsConfig.js +1 -0
  60. package/build/commands/utils/rangerConfig.js +1 -1
  61. package/build/commands/utils/rangerRoot.js +1 -1
  62. package/build/commands/utils/resolveProfileContext.js +1 -0
  63. package/build/commands/utils/resolveProfileUrl.js +1 -0
  64. package/build/commands/utils/retry.js +1 -1
  65. package/build/commands/utils/sessionCache.js +1 -1
  66. package/build/commands/utils/settings.js +1 -1
  67. package/build/commands/utils/skillContent.js +1 -1
  68. package/build/commands/utils/skills.js +1 -1
  69. package/build/commands/utils/stitchWebmFiles.js +1 -1
  70. package/build/commands/utils/telemetry.js +1 -1
  71. package/build/commands/utils/tokenRefresh.js +1 -1
  72. package/build/commands/utils/traceSnapshotMapper.js +1 -1
  73. package/build/commands/utils/userApi.js +1 -1
  74. package/build/commands/utils/version.js +1 -1
  75. package/build/commands/verifyFeature.js +1 -1
  76. package/build/commands/verifyFeatureCli.js +1 -1
  77. package/build/skills/ranger/SKILL.md +18 -4
  78. package/build/skills/ranger/create.md +6 -0
  79. package/build/skills/ranger/verify.md +23 -3
  80. package/package.json +6 -2
@@ -1 +1 @@
1
- (function(_0xc3785f,_0x6f68f4){const _0x1dcd5f=_0x1906,_0x14e9e8=_0xc3785f();while(!![]){try{const _0x2589a3=-parseInt(_0x1dcd5f(0x120))/0x1+-parseInt(_0x1dcd5f(0xbe))/0x2*(-parseInt(_0x1dcd5f(0x123))/0x3)+-parseInt(_0x1dcd5f(0xf3))/0x4+-parseInt(_0x1dcd5f(0xcd))/0x5+parseInt(_0x1dcd5f(0xfd))/0x6+parseInt(_0x1dcd5f(0xcc))/0x7*(parseInt(_0x1dcd5f(0x101))/0x8)+parseInt(_0x1dcd5f(0xda))/0x9*(parseInt(_0x1dcd5f(0x105))/0xa);if(_0x2589a3===_0x6f68f4)break;else _0x14e9e8['push'](_0x14e9e8['shift']());}catch(_0x476f29){_0x14e9e8['push'](_0x14e9e8['shift']());}}}(_0x3e1e,0xa034e));import{mkdir,readFile,readdir,rename,stat}from'fs/promises';import{basename,join}from'path';import{extractBashCommand,parsePlaywrightCliCommand,quoteShellArg,runPlaywrightCliCommand}from'./utils/playwrightCli.js';const PLAYWRIGHT_CLI_COMMAND_TIMEOUT_MS=0xea60,PLAYWRIGHT_CLI_PREVIEW_LIMIT=0xf0,VERIFY_FEATURE_CLI_ARTIFACT_FILE_PATTERN=/^(?:\d{2}_.+\.(?:png|ya?ml)|key_.+\.png|session-recording(?:-\d+)?\.webm|trace(?:\.trace)?(?:-\d+)?\.zip|current_snap\.ya?ml)$/i;function _0x3e1e(){const _0x595fd5=['nTWDe','--filename=','(?:\x5cs+(?:\x22([^\x22]+)\x22|\x27([^\x27]+)\x27|(\x5cS+)))','tool_call','mtimeMs','tZDQi','press','YwWpn','capture\x20snapshot','trackPhaseError','values','start\x20video\x20recording','fDzmm','02_state.yml','capture\x20snapshot\x20`','03_result-visible.png','QonmR','4266324YOKqMh','\x0a\x0a##\x20Critical:\x20Early\x20Error\x20Detection\x0aAfter\x20taking\x20the\x20initial\x20snapshot,\x20IMMEDIATELY\x20check\x20for\x20blocking\x20errors:\x0a\x0a**Blocking\x20errors\x20to\x20detect:**\x0a-\x20Crash\x20or\x20error\x20dialogs\x20(\x22An\x20error\x20occurred\x22,\x20\x22Something\x20went\x20wrong\x22,\x20unhandled\x20exception\x20messages)\x0a-\x20Blank\x20or\x20empty\x20window\x20with\x20no\x20rendered\x20content\x0a-\x20Framework\x20error\x20boundaries\x20(React\x20error\x20page,\x20Electron\x20crash\x20reporter)\x0a-\x20Unresponsive\x20or\x20frozen\x20UI\x20(no\x20interactive\x20elements\x20in\x20snapshot)\x0a\x0a**If\x20ANY\x20blocking\x20error\x20is\x20detected:**\x0a1.\x20DO\x20NOT\x20continue\x20with\x20the\x20task\x0a2.\x20Return\x20IMMEDIATELY\x20with\x20evaluation:\x20\x22blocked\x22\x0a3.\x20Set\x20evaluationReason\x20to\x20describe\x20the\x20specific\x20error\x20(e.g.,\x20\x22App\x20crashed\x20—\x20error\x20dialog\x20visible\x20on\x20launch\x22)\x0a4.\x20Include\x20the\x20error\x20in\x20issues\x20array\x20with\x20severity:\x20\x22BLOCKER\x22\x20and\x20type:\x20\x22APP_ERROR\x22\x0a\x0aThis\x20early\x20exit\x20prevents\x20wasting\x20time\x20on\x20tasks\x20that\x20cannot\x20succeed\x20due\x20to\x20fundamental\x20errors.','\x22\x0a-\x20Number\x20prefixes\x20(01_,\x2002_,\x20etc.)\x20help\x20maintain\x20chronological\x20order\x0a-\x20For\x20KEY\x20MOMENTS\x20that\x20prove\x20the\x20scenario\x20is\x20complete,\x20prefix\x20with\x20\x22key_\x22:\x20\x22','\x0a\x0a##\x20Additional\x20Notes\x0a','\x22,\x20\x22','push','DEBUG','BlppD','mnoHK','snapshot','5525802DXcFnv','`\x0a\x0a-\x20Write\x20all\x20artifacts\x20under\x20`','\x20run-code\x20\x22<playwright\x20code>\x22`.\x0a7.\x20Do\x20not\x20run\x20`close`,\x20`tracing-stop`,\x20or\x20`video-stop`;\x20the\x20host\x20finalizes\x20the\x20session\x20and\x20artifacts.\x0a8.\x20After\x20completing\x20the\x20verification,\x20evaluate\x20whether\x20the\x20result\x20adequately\x20verifies\x20the\x20scenario','uBanL','221664iBYGYI','You\x20are\x20testing\x20browser\x20automation.\x20Your\x20task\x20is\x20simple:\x0a\x0aUse\x20Bash\x20and\x20Playwright\x20CLI\x20only.\x20The\x20browser\x20command\x20prefix\x20is:\x0a','fill\x20','stderr','20QRFyQa','subcommand','jbeng','domRef','\x0a\x0a1.\x20Run\x20`','test','Hvgtu','CRITICAL\x20URL\x20REQUIREMENT:\x0aYour\x20base\x20URL\x20is:\x20','pop','error','`\x20to\x20inspect\x20the\x20current\x20app\x20state.\x0a5.\x20Read\x20snapshot\x20YAML\x20files\x20to\x20find\x20element\x20references\x20like\x20`e12`,\x20then\x20use\x20them\x20with\x20`click`,\x20`fill`,\x20`check`,\x20or\x20`select`.\x0a6.\x20Use\x20`','BLagu','pFnGX','):\x20\x22','trackPhaseEnd','textContent','numeric','unaddressedComments','tracing-stop','capture\x20screenshot','voKXt','description','close','canonicalFlow','BrLHk','selector','tool_input','195319OvhOKS','env','`\x20using\x20absolute\x20paths\x20only.\x20Do\x20not\x20use\x20relative\x20filenames.\x0a5.\x20Run\x20`','3045XmydOW','\x20video-start`.\x0a3.\x20Save\x20every\x20snapshot\x20and\x20screenshot\x20under\x20`','PostToolUseFailure','.\x0aThis\x20is\x20NOT\x20a\x20web\x20app\x20—\x20there\x20is\x20no\x20URL\x20to\x20navigate\x20to.\x20The\x20app\x20is\x20already\x20running\x20and\x20connected.','check','eEPeT','GlgiT','isFile','##\x20App\x20Context\x0aYou\x20are\x20connected\x20to\x20a\x20desktop\x20application\x20via\x20CDP\x20(Chrome\x20DevTools\x20Protocol)\x20at\x20','ZAcWi','name','dXKXI','set','XNYyU','-\x20[','playwright-cli','cFoBI','RqMat','`\x0a-\x20`run-code\x20\x22await\x20page.waitForTimeout(1000)\x22`\x20for\x20waits\x20or\x20small\x20custom\x20checks\x0a\x0a##\x20Screenshot\x20Guidelines\x20-\x20IMPORTANT\x0aTake\x20screenshots\x20throughout\x20the\x20verification\x20flow\x20so\x20a\x20human\x20can\x20review\x20it\x20for\x20completeness.\x20Screenshots\x20are\x20your\x20evidence\x20trail.\x0a\x0a**When\x20to\x20take\x20screenshots\x20(use\x20Playwright\x20CLI\x20screenshot):**\x0a-\x20After\x20the\x20initial\x20snapshot\x20(capture\x20starting\x20state)\x0a-\x20Before\x20and\x20after\x20clicking\x20buttons\x20or\x20submitting\x20forms\x0a-\x20When\x20important\x20UI\x20elements\x20appear\x20(modals,\x20notifications,\x20loading\x20states)\x0a-\x20After\x20navigating\x20to\x20different\x20views\x20or\x20pages\x0a-\x20When\x20verifying\x20specific\x20elements\x20exist\x0a-\x20At\x20the\x20final\x20state\x20showing\x20the\x20completed\x20action\x0a\x0a**Screenshot\x20naming:**\x0a-\x20Use\x20descriptive\x20filenames\x20under\x20`','ref\x20','\x20tracing-start`\x0a3.\x20Run\x20`','Bash','stop\x20tracing','map','invocation','authorName','ptAuM','mGyuo','iqcGc','EuGeZ','UVmLE','video-start','`\x0a7.\x20Click\x20the\x20\x22Learn\x20More\x22\x20link\x20with\x20Playwright\x20CLI\x0a8.\x20Run\x20`','SesNj','hook_event_name','`\x0a10.\x20Return\x20immediately\x20with\x20the\x20structured\x20output\x0a\x0aReturn\x20your\x20findings\x20in\x20the\x20structured\x20output\x20format.','trace.zip','trim','run-code','\x20screenshot\x20--filename\x20','trackPhaseStart','cwd','fill','match','310MLINek','key_04_success-state.png','wccsK','split','\x20snapshot\x20--filename\x20','\x20run-code\x20\x22<playwright\x20code>\x22`.\x0a9.\x20Do\x20not\x20run\x20`close`,\x20`tracing-stop`,\x20or\x20`video-stop`;\x20the\x20host\x20finalizes\x20the\x20session\x20and\x20artifacts.\x0a10.\x20After\x20completing\x20the\x20verification,\x20evaluate\x20whether\x20the\x20result\x20adequately\x20verifies\x20the\x20scenario','run\x20custom\x20Playwright\x20code','HFjfv','replace','tracing-start','stop\x20video\x20recording','yjvfV','open','`\x20using\x20absolute\x20paths\x20only.\x20Do\x20not\x20use\x20relative\x20filenames.\x0a4.\x20Take\x20a\x20snapshot\x20with\x20`','259zPMeKY','6294320exfDXP','\x0a\x0a##\x20Task\x20to\x20Execute\x0a','trace.trace.zip','tool_name','03_learn-more.png','element','`\x20and\x20read\x20the\x20snapshot\x20file\x20to\x20inspect\x20the\x20page.\x0a5.\x20**IMMEDIATELY\x20check\x20for\x20blocking\x20HTTP\x20errors\x20before\x20proceeding.**\x0a6.\x20Execute\x20the\x20task\x20step-by-step\x20with\x20Playwright\x20CLI\x20commands.\x0a7.\x20Use\x20`','\x20video-start`\x0a4.\x20Save\x20every\x20snapshot\x20and\x20screenshot\x20under\x20`','sort','(?:^|\x5cs)','HKBvu','\x0a\x0a##\x20Expected\x20Flow\x20(from\x20previous\x20verification)\x0a','JuCFV','4830669TvfbrR','commandArgs','janFE','##\x20Instructions\x0a1.\x20Use\x20Bash\x20plus\x20Playwright\x20CLI\x20only.\x20Do\x20NOT\x20call\x20MCP\x20browser\x20tools.\x0a2.\x20Start\x20by\x20running\x20`','02_button-clicked.png','press\x20','\x5c$&','NdWgF'];_0x3e1e=function(){return _0x595fd5;};return _0x3e1e();}function truncatePreview(_0x20ed24,_0x12edfc=PLAYWRIGHT_CLI_PREVIEW_LIMIT){return _0x20ed24['length']>_0x12edfc?_0x20ed24['slice'](0x0,_0x12edfc)+'...':_0x20ed24;}function buildCliArtifactPath(_0x245d07,_0x4424a1){const _0x24b3b6=_0x1906,_0x271358={'ZAcWi':function(_0x339ade,_0x417183,_0x2a62f0){return _0x339ade(_0x417183,_0x2a62f0);}};return _0x271358[_0x24b3b6(0x12c)](join,_0x245d07,_0x4424a1);}function _0x1906(_0x13987c,_0x98b125){_0x13987c=_0x13987c-0xa6;const _0x3e1ed9=_0x3e1e();let _0x190632=_0x3e1ed9[_0x13987c];return _0x190632;}function toStepDisplayName(_0x611250){const _0x123f57=_0x1906,_0x13e715={'HFjfv':function(_0x51ae87,_0x25eff2){return _0x51ae87(_0x25eff2);}},_0x20c995=_0x13e715[_0x123f57(0xc5)](basename,_0x611250)['replace'](/\.(?:png|ya?ml)$/i,'')['replace'](/^key_/i,'')['replace'](/^\d+_/,'')[_0x123f57(0xc6)](/-/g,'\x20');return{'name':_0x20c995,'isKeyStep':/^key_/i['test'](basename(_0x611250))};}function extractShellValue(_0x98f4b7){if(!_0x98f4b7)return null;return _0x98f4b7[0x1]??_0x98f4b7[0x2]??_0x98f4b7[0x3]??null;}function extractFilenameOption(_0x118230){return extractShellValue(_0x118230['match'](/--filename(?:=|\s+)(?:"([^"]+)"|'([^']+)'|(\S+))/));}function extractFirstCommandArgument(_0x584aef,_0x27887e){const _0x19e55c=_0x1906,_0x360d43={'SesNj':_0x19e55c(0xe0),'fDzmm':function(_0x4b211e,_0x4ab5d4){return _0x4b211e(_0x4ab5d4);}},_0x11889b=_0x27887e[_0x19e55c(0xc6)](/[.*+?^${}()|[\]\\]/g,_0x360d43[_0x19e55c(0xb3)]);return _0x360d43[_0x19e55c(0xee)](extractShellValue,_0x584aef[_0x19e55c(0xbd)](new RegExp(_0x19e55c(0xd6)+_0x11889b+_0x19e55c(0xe4))));}function formatCommandTarget(_0x44523f){const _0x1a2230=_0x1906,_0x56bc82={'plrAw':'target'};if(!_0x44523f)return _0x56bc82['plrAw'];if(/^e\d+$/i[_0x1a2230(0x10a)](_0x44523f))return _0x1a2230(0x136)+_0x44523f;return JSON['stringify'](truncatePreview(_0x44523f,0x78));}function formatPlaywrightCliLog(_0x22859d,_0x6085c3){const _0x460921=_0x1906,_0x313a2c={'tXGvZ':_0x460921(0xca),'nTWDe':function(_0x33ae35,_0x40a40f,_0x2804be){return _0x33ae35(_0x40a40f,_0x2804be);},'voKXt':'open\x20browser','uBanL':_0x460921(0xc7),'HKBvu':'start\x20tracing','fCBFX':_0x460921(0xed),'bpDMK':_0x460921(0xc8),'QonmR':_0x460921(0xfc),'BlppD':function(_0x173337,_0x5df837){return _0x173337(_0x5df837);},'ZUKuF':'screenshot','BLagu':_0x460921(0x118),'dXKXI':'click','yXqPx':_0x460921(0xbc),'CVVIj':_0x460921(0xc4),'JuCFV':'open\x20new\x20tab','mGyuo':'tab-select','ptAuM':function(_0x13e6d5,_0x197a48,_0xf5f181){return _0x13e6d5(_0x197a48,_0xf5f181);}};switch(_0x6085c3){case _0x313a2c['tXGvZ']:{const _0x20f85b=_0x313a2c[_0x460921(0xe2)](extractFirstCommandArgument,_0x22859d,_0x6085c3);return _0x20f85b?'open\x20'+_0x20f85b:_0x313a2c[_0x460921(0x119)];}case _0x313a2c[_0x460921(0x100)]:return _0x313a2c[_0x460921(0xd7)];case _0x460921(0x117):return _0x460921(0xa8);case _0x460921(0xb1):return _0x313a2c['fCBFX'];case'video-stop':return _0x313a2c['bpDMK'];case _0x313a2c[_0x460921(0xf2)]:{const _0x25e76f=_0x313a2c[_0x460921(0xfa)](extractFilenameOption,_0x22859d);if(!_0x25e76f)return _0x460921(0xea);const {name:_0x198a44}=toStepDisplayName(_0x25e76f);return _0x460921(0xf0)+_0x198a44+'`';}case _0x313a2c['ZUKuF']:{const _0x470fe4=_0x313a2c[_0x460921(0xfa)](extractFilenameOption,_0x22859d);if(!_0x470fe4)return _0x313a2c[_0x460921(0x110)];const {name:_0x2795b6,isKeyStep:_0x277694}=toStepDisplayName(_0x470fe4);return _0x277694?'capture\x20key\x20step\x20`'+_0x2795b6+'`':'capture\x20step\x20`'+_0x2795b6+'`';}case _0x313a2c[_0x460921(0x12e)]:return'click\x20'+formatCommandTarget(extractFirstCommandArgument(_0x22859d,_0x6085c3));case _0x460921(0x127):return'check\x20'+_0x313a2c[_0x460921(0xfa)](formatCommandTarget,_0x313a2c[_0x460921(0xe2)](extractFirstCommandArgument,_0x22859d,_0x6085c3));case _0x313a2c['yXqPx']:return _0x460921(0x103)+formatCommandTarget(extractFirstCommandArgument(_0x22859d,_0x6085c3));case _0x460921(0xe8):return _0x460921(0xdf)+formatCommandTarget(extractFirstCommandArgument(_0x22859d,_0x6085c3));case _0x460921(0xb8):return _0x313a2c['CVVIj'];case'tab-new':{const _0x30d17d=extractFirstCommandArgument(_0x22859d,_0x6085c3);return _0x30d17d?'open\x20new\x20tab\x20'+_0x30d17d:_0x313a2c[_0x460921(0xd9)];}case _0x313a2c[_0x460921(0xad)]:{const _0x51cb4e=_0x313a2c[_0x460921(0xac)](extractFirstCommandArgument,_0x22859d,_0x6085c3);return _0x51cb4e?'select\x20tab\x20'+_0x51cb4e:'select\x20tab';}default:return _0x6085c3;}}function extractPlaywrightCliToolDescription(_0x44118d){const _0xfdc1aa=_0x1906,_0x22232e=_0x44118d['description'];if(typeof _0x22232e!=='string')return null;const _0x48659c=_0x22232e[_0xfdc1aa(0xb7)]()['replace'](/\s+/g,'\x20');return _0x48659c['length']>0x0?_0x48659c:null;}export function formatPlaywrightCliConsoleLogMessage(_0x3d7b39,_0x5de6d2,_0x558024){const _0x28d829=_0x1906,_0x5adfac={'RqMat':function(_0x21c3f0,_0x3caf5d){return _0x21c3f0(_0x3caf5d);}},_0x4d0e92=formatPlaywrightCliLog(_0x5de6d2,_0x558024),_0x48ab94=_0x5adfac[_0x28d829(0x134)](extractPlaywrightCliToolDescription,_0x3d7b39);if(!_0x48ab94)return'[playwright-cli]\x20'+_0x4d0e92;if(process[_0x28d829(0x121)][_0x28d829(0xf9)])return'[ranger-verification-agent]\x20'+_0x48ab94+'\x20('+_0x4d0e92+')';return'[ranger-verification-agent]\x20'+_0x48ab94;}export function buildVerifyFeatureCliDebugPrompt(_0x15372b,_0x4b3fbf){const _0x2c640e=_0x1906,_0x411c4a={'mnoHK':function(_0x5122b2,_0x78efe3,_0x457bca){return _0x5122b2(_0x78efe3,_0x457bca);},'yjvfV':_0x2c640e(0xd1),'Hvgtu':function(_0x226946,_0x38d38e){return _0x226946(_0x38d38e);},'ZacWf':function(_0xf16cfe,_0x1d8018){return _0xf16cfe(_0x1d8018);}},_0x1e7239=_0x411c4a[_0x2c640e(0xfb)](buildCliArtifactPath,_0x4b3fbf,'00_mozilla-homepage.yml'),_0x1a178c=buildCliArtifactPath(_0x4b3fbf,'01_mozilla-homepage.png'),_0x20c7c3=buildCliArtifactPath(_0x4b3fbf,'02_learn-more.yml'),_0x8000a6=buildCliArtifactPath(_0x4b3fbf,_0x411c4a[_0x2c640e(0xc9)]),_0x2eb8a9=_0x411c4a[_0x2c640e(0x10b)](quoteShellArg,_0x1e7239),_0x116d28=_0x411c4a[_0x2c640e(0x10b)](quoteShellArg,_0x1a178c),_0x2f24c0=_0x411c4a['ZacWf'](quoteShellArg,_0x20c7c3),_0x1f604c=quoteShellArg(_0x8000a6);return _0x2c640e(0x102)+_0x15372b+_0x2c640e(0x109)+_0x15372b+'\x20open\x20https://www.mozilla.org`\x0a2.\x20Run\x20`'+_0x15372b+_0x2c640e(0xa6)+_0x15372b+_0x2c640e(0xd4)+_0x4b3fbf+_0x2c640e(0x122)+_0x15372b+'\x20snapshot\x20--filename\x20'+_0x2eb8a9+'`\x0a5.\x20Read\x20the\x20snapshot\x20file\x20to\x20find\x20the\x20\x22Learn\x20More\x22\x20link\x20reference\x0a6.\x20Run\x20`'+_0x15372b+_0x2c640e(0xb9)+_0x116d28+_0x2c640e(0xb2)+_0x15372b+'\x20snapshot\x20--filename\x20'+_0x2f24c0+'`\x0a9.\x20Run\x20`'+_0x15372b+'\x20screenshot\x20--filename\x20'+_0x1f604c+_0x2c640e(0xb5);}export function buildVerifyFeatureCliPrompt(_0x4eacd5){const _0x4dff8c=_0x1906,_0x18be0a={'zMDby':_0x4dff8c(0x115),'UcNGE':'\x20>\x20','GlgiT':function(_0x1bfef5,_0x37505f,_0x2c5517){return _0x1bfef5(_0x37505f,_0x2c5517);},'pFnGX':'key_03_success-state.png','GTjsq':function(_0x33b853,_0x48e804){return _0x33b853(_0x48e804);},'qlPUL':function(_0x4b04ac,_0x2ffd55){return _0x4b04ac(_0x2ffd55);},'YpUHw':function(_0x2d51ce,_0x37eae4){return _0x2d51ce(_0x37eae4);},'UVmLE':_0x4dff8c(0xde),'XnrLj':_0x4dff8c(0xbf)},{checklistItem:_0x1020a2,itemFeedback:_0x2bc69e,taskDescription:_0xff138e,cliCommandPrefix:_0x35b73e,cliArtifactDir:_0x34036f,isCdpMode:_0x247860,url:_0x1284ce,cdpEndpoint:_0x470506,loginInstructions:_0x48a385}=_0x4eacd5,_0x3c4aec=buildCliArtifactPath(_0x34036f,'01_initial.yml'),_0x35e5cd=buildCliArtifactPath(_0x34036f,_0x4dff8c(0xef)),_0x8061d0=_0x18be0a[_0x4dff8c(0x129)](buildCliArtifactPath,_0x34036f,_0x18be0a[_0x4dff8c(0x111)]),_0x3d503b=_0x18be0a[_0x4dff8c(0x129)](buildCliArtifactPath,_0x34036f,'01_initial-state.png'),_0x5b3c0f=_0x18be0a['GTjsq'](quoteShellArg,_0x3c4aec),_0x3c313f=quoteShellArg(_0x35e5cd),_0x3d20e7=_0x18be0a['qlPUL'](quoteShellArg,_0x8061d0),_0x18477e=_0x18be0a['qlPUL'](quoteShellArg,_0x3d503b),_0x45fe33=_0x1020a2['notes']?_0x4dff8c(0xf6)+_0x1020a2['notes']:'';let _0x5cbb7e='';if(_0x2bc69e&&_0x2bc69e['unaddressedComments']['length']>0x0){const _0x3c8de1=_0x2bc69e[_0x4dff8c(0x116)][_0x4dff8c(0xa9)](_0x13a784=>{const _0xe3073d=_0x4dff8c,_0x4a917c=new Date(_0x13a784['createdAt'])['toLocaleDateString']('en-US',{'month':'short','day':_0x18be0a['zMDby']}),_0x545cc5=_0x13a784[_0xe3073d(0xab)]||_0x13a784['authorEmail']||'Reviewer',_0x5e20c1=_0x13a784[_0xe3073d(0x108)]?'\x20(on\x20element:\x20<'+(_0x13a784[_0xe3073d(0x108)][_0xe3073d(0x11e)][_0xe3073d(0xc1)](_0x18be0a['UcNGE'])[_0xe3073d(0x10d)]()?.['split'](':')[0x0]||_0xe3073d(0xd2))+'>\x20\x22'+(_0x13a784['domRef'][_0xe3073d(0x114)]||'')['slice'](0x0,0x32)+'\x22)':'';return _0xe3073d(0x131)+_0x13a784['id']+']\x20**'+_0x545cc5+'**\x20('+_0x4a917c+_0xe3073d(0x112)+_0x13a784['content']+'\x22'+_0x5e20c1;})['join']('\x0a');_0x5cbb7e='\x0a\x0a##\x20Reviewer\x20Feedback\x20to\x20Address\x0aThe\x20following\x20reviewer\x20comments\x20were\x20left\x20on\x20the\x20previous\x20version\x20of\x20this\x20item.\x0aVerify\x20that\x20each\x20concern\x20has\x20been\x20addressed\x20in\x20the\x20current\x20implementation.\x0aFor\x20each\x20comment\x20you\x20believe\x20has\x20been\x20addressed,\x20include\x20its\x20ID\x20(the\x20bracketed\x20value)\x20in\x20the\x20addressedCommentIds\x20array\x20in\x20your\x20output.\x0a\x0a'+_0x3c8de1;}const _0x5b1ebe=_0x2bc69e?.[_0x4dff8c(0x11c)]?_0x4dff8c(0xd8)+_0x2bc69e['canonicalFlow']:'',_0x960474=_0x247860?_0x4dff8c(0x12b)+_0x470506+_0x4dff8c(0x126):_0x4dff8c(0x10c)+_0x1284ce+'\x0a-\x20You\x20may\x20ONLY\x20navigate\x20to\x20paths\x20under\x20this\x20base\x20URL\x20(same\x20protocol,\x20host,\x20and\x20port)\x0a-\x20For\x20example,\x20if\x20the\x20base\x20URL\x20is\x20\x22http://localhost:3000\x22,\x20you\x20can\x20navigate\x20to\x20\x22http://localhost:3000/home\x22,\x20\x22http://localhost:3000/settings\x22,\x20etc.\x0a-\x20DO\x20NOT\x20navigate\x20to\x20any\x20different\x20domain,\x20host,\x20or\x20port\x20under\x20any\x20circumstances\x0a-\x20If\x20documentation\x20or\x20code\x20diffs\x20suggest\x20a\x20path\x20exists\x20(e.g.,\x20\x22/dashboard\x22),\x20you\x20may\x20navigate\x20to\x20that\x20path\x20ONLY\x20under\x20the\x20base\x20URL\x20above\x0a-\x20The\x20base\x20URL\x20above\x20is\x20the\x20ONLY\x20authorized\x20profile\x20for\x20this\x20verification',_0x50f248=_0x1284ce?_0x18be0a['YpUHw'](quoteShellArg,_0x1284ce):'',_0x4b30bf=_0x247860?_0x4dff8c(0xdd)+_0x35b73e+'\x20open`,\x20then\x20`'+_0x35b73e+'\x20tracing-start`,\x20then\x20`'+_0x35b73e+_0x4dff8c(0x124)+_0x34036f+_0x4dff8c(0xcb)+_0x35b73e+'\x20snapshot\x20--filename\x20'+_0x5b3c0f+_0x4dff8c(0x10f)+_0x35b73e+_0x4dff8c(0xb9)+_0x18477e+'`\x20style\x20absolute\x20paths\x20at\x20key\x20moments.\x0a6.\x20If\x20you\x20need\x20waits\x20or\x20custom\x20assertions,\x20use\x20`'+_0x35b73e+_0x4dff8c(0xff):'##\x20Instructions\x0a1.\x20Use\x20Bash\x20plus\x20Playwright\x20CLI\x20only.\x20Do\x20NOT\x20call\x20MCP\x20browser\x20tools.\x0a2.\x20Start\x20by\x20running\x20`'+_0x35b73e+'\x20open\x20'+_0x50f248+'`,\x20then\x20`'+_0x35b73e+'\x20tracing-start`,\x20then\x20`'+_0x35b73e+'\x20video-start`.\x0a3.\x20Save\x20every\x20snapshot\x20and\x20screenshot\x20under\x20`'+_0x34036f+_0x4dff8c(0xcb)+_0x35b73e+_0x4dff8c(0xc2)+_0x5b3c0f+_0x4dff8c(0xd3)+_0x35b73e+'\x20screenshot\x20--filename\x20'+_0x18477e+'`\x20style\x20absolute\x20paths\x20at\x20key\x20moments.\x0a8.\x20If\x20you\x20need\x20waits\x20or\x20custom\x20assertions,\x20use\x20`'+_0x35b73e+_0x4dff8c(0xc3),_0x3b483b=_0x247860?_0x4dff8c(0xf4):'\x0a\x0a##\x20Critical:\x20Early\x20Error\x20Detection\x0aAfter\x20step\x202\x20(taking\x20initial\x20snapshot),\x20IMMEDIATELY\x20check\x20for\x20blocking\x20HTTP\x20errors:\x0a\x0a**Blocking\x20errors\x20to\x20detect:**\x0a-\x20HTTP\x20404:\x20\x22404\x22,\x20\x22Not\x20Found\x22,\x20\x22Page\x20not\x20found\x22,\x20\x22does\x20not\x20exist\x22\x0a-\x20HTTP\x20500:\x20\x22500\x22,\x20\x22Internal\x20Server\x20Error\x22,\x20\x22Server\x20Error\x22,\x20\x22Something\x20went\x20wrong\x22\x0a-\x20HTTP\x20400:\x20\x22400\x22,\x20\x22Bad\x20Request\x22,\x20\x22Invalid\x20request\x22\x0a\x0a**Also\x20check\x20for:**\x0a-\x20Framework\x20error\x20pages\x20(Next.js\x20error\x20boundary,\x20React\x20error\x20page,\x20\x22Application\x20error\x22)\x0a-\x20Completely\x20blank/empty\x20pages\x20with\x20no\x20content\x0a-\x20\x22Cannot\x20GET\x20/path\x22\x20messages\x0a\x0a**If\x20ANY\x20blocking\x20error\x20is\x20detected:**\x0a1.\x20DO\x20NOT\x20continue\x20with\x20the\x20task\x0a2.\x20Return\x20IMMEDIATELY\x20with\x20evaluation:\x20\x22blocked\x22\x0a3.\x20Set\x20evaluationReason\x20to\x20describe\x20the\x20specific\x20error\x20(e.g.,\x20\x22HTTP\x20404\x20-\x20Page\x20not\x20found\x20at\x20/dashboard\x22)\x0a4.\x20Include\x20the\x20error\x20in\x20issues\x20array\x20with\x20severity:\x20\x22BLOCKER\x22\x20and\x20appropriate\x20type\x20(HTTP_404,\x20HTTP_500,\x20HTTP_400,\x20or\x20NAVIGATION_ERROR)\x0a\x0aThis\x20early\x20exit\x20prevents\x20wasting\x20time\x20on\x20tasks\x20that\x20cannot\x20succeed\x20due\x20to\x20fundamental\x20errors.',_0x5059c0=_0x48a385?'\x0a\x0a##\x20Authentication\x0aBEFORE\x20starting\x20the\x20verification\x20task,\x20you\x20MUST\x20authenticate\x20using\x20these\x20steps:\x0a'+_0x48a385+'\x0a\x0aAfter\x20completing\x20authentication,\x20proceed\x20with\x20the\x20verification\x20task\x20below.\x0aIf\x20authentication\x20fails,\x20return\x20immediately\x20with\x20evaluation\x20\x22blocked\x22\x20and\x20describe\x20the\x20auth\x20failure.':'';return'You\x20are\x20a\x20Feature\x20Review\x20Verifier.\x20Your\x20job\x20is\x20to\x20verify\x20a\x20scenario\x20by\x20executing\x20a\x20UI\x20flow\x20and\x20evaluating\x20whether\x20it\x20adequately\x20completes\x20the\x20scenario.\x0a\x0a##\x20Scenario\x20to\x20Verify\x0a'+_0x1020a2[_0x4dff8c(0x11a)]+_0x45fe33+_0x5cbb7e+_0x5b1ebe+_0x4dff8c(0xce)+_0xff138e+'\x0a\x0a'+_0x960474+_0x5059c0+'\x0a\x0a'+_0x4b30bf+'\x0a\x0a##\x20Browser\x20Command\x20Reference\x0aUse\x20Bash\x20to\x20run\x20Playwright\x20CLI\x20commands\x20with\x20this\x20exact\x20prefix:\x0a`'+_0x35b73e+_0x4dff8c(0xfe)+_0x34036f+'`\x0a-\x20`snapshot\x20--filename\x20'+_0x3c313f+'`\x20writes\x20a\x20YAML\x20snapshot\x20you\x20can\x20read\x20for\x20element\x20refs\x0a-\x20`click\x20<ref>`,\x20`fill\x20<ref>\x20\x22text\x22`,\x20`check\x20<ref>`,\x20`press\x20Enter`\x0a-\x20`tab-list`,\x20`tab-select\x20<index>`,\x20`tab-new\x20<url>`\x0a-\x20`screenshot\x20--filename\x20'+_0x3d20e7+_0x4dff8c(0x135)+_0x34036f+'`:\x20\x22'+_0x3d503b+_0x4dff8c(0xf7)+_0x18be0a[_0x4dff8c(0x129)](buildCliArtifactPath,_0x34036f,_0x18be0a[_0x4dff8c(0xb0)])+'\x22,\x20\x22'+buildCliArtifactPath(_0x34036f,_0x4dff8c(0xf1))+_0x4dff8c(0xf5)+_0x18be0a['GlgiT'](buildCliArtifactPath,_0x34036f,_0x18be0a['XnrLj'])+'\x22\x0a-\x20The\x20\x22key_\x22\x20prefix\x20marks\x20screenshots\x20as\x20high-priority\x20evidence\x20for\x20human\x20reviewers\x0a\x0a**Aim\x20for\x203-6\x20screenshots\x20per\x20verification**\x20to\x20document\x20the\x20complete\x20flow.\x20Mark\x201-2\x20of\x20the\x20most\x20important\x20ones\x20with\x20the\x20\x22key_\x22\x20prefix.\x0a'+_0x3b483b+'\x0a##\x20Evaluation\x20Criteria\x0a-\x20VERIFIED:\x20The\x20task\x20completed\x20successfully\x20and\x20the\x20scenario\x20requirements\x20are\x20fully\x20met\x0a-\x20PARTIAL:\x20The\x20task\x20partially\x20completed\x20but\x20some\x20aspects\x20of\x20the\x20scenario\x20are\x20not\x20verified\x0a-\x20BLOCKED:\x20A\x20blocking\x20issue\x20(bug,\x20error,\x20missing\x20feature)\x20prevents\x20completion\x0a-\x20FAILED:\x20The\x20task\x20could\x20not\x20be\x20completed\x20due\x20to\x20errors\x0a\x0aReturn\x20your\x20findings\x20in\x20the\x20structured\x20output\x20format\x20with\x20your\x20evaluation.';}export function summarizeVerifyFeatureCliCommandAvailability(_0x533e79){const _0x5ec125=_0x1906,_0x22aed4=[..._0x533e79['keys']()][_0x5ec125(0xd5)]();let _0x3e8aab=0x0;for(const _0x1844a8 of _0x533e79[_0x5ec125(0xec)]()){_0x3e8aab+=_0x1844a8;}return{'cliCommandCount':_0x3e8aab,'cliCommandsSeen':_0x22aed4,'noCliCommandsCalled':_0x3e8aab===0x0};}export function createVerifyFeatureCliHooks(_0x4e9526){const _0x55684e=_0x1906,_0x44c979={'EuGeZ':function(_0xbf523d,_0x176df3){return _0xbf523d!==_0x176df3;},'mzTTf':'Bash','rxRne':function(_0x36d7dc,_0x3b1836){return _0x36d7dc(_0x3b1836);},'BrLHk':function(_0x2fb28c,_0x51cf20){return _0x2fb28c+_0x51cf20;},'eEPeT':_0x55684e(0xe5),'DvySY':'playwright-cli','vtQTx':function(_0x9933df,_0x1523ae){return _0x9933df(_0x1523ae);},'NdWgF':function(_0x56aafa,_0x18bce2,_0x15b37f,_0x3845d7){return _0x56aafa(_0x18bce2,_0x15b37f,_0x3845d7);},'wccsK':'tool_failure'},_0x178770=new Map(),_0x2f5229=async _0x25f706=>{const _0x359398=_0x55684e;if(_0x44c979[_0x359398(0xaf)](_0x25f706[_0x359398(0xb4)],'PostToolUse'))return{};const _0x1541c4=_0x25f706;if(_0x1541c4[_0x359398(0xd0)]!==_0x44c979['mzTTf'])return{};const _0x512277=_0x1541c4[_0x359398(0x11f)],_0x538d14=_0x44c979['rxRne'](extractBashCommand,_0x512277);if(!_0x538d14)return{};const _0x2dbb31=parsePlaywrightCliCommand(_0x538d14);if(!_0x2dbb31)return{};return _0x178770[_0x359398(0x12f)](_0x2dbb31,_0x44c979[_0x359398(0x11d)](_0x178770['get'](_0x2dbb31)||0x0,0x1)),_0x4e9526['trackPhaseStart'](_0x44c979[_0x359398(0x128)],{'transport':_0x44c979['DvySY'],'toolName':_0x2dbb31}),_0x4e9526[_0x359398(0x113)](_0x359398(0xe5),{'transport':_0x359398(0x132),'toolName':_0x2dbb31,'bashCommandPreview':_0x44c979['vtQTx'](truncatePreview,_0x538d14)}),_0x44c979['EuGeZ'](_0x2dbb31,'snapshot')&&console['log'](_0x44c979[_0x359398(0xe1)](formatPlaywrightCliConsoleLogMessage,_0x512277,_0x538d14,_0x2dbb31)),{};},_0xeb72a1=async _0x2f381d=>{const _0x5670ed=_0x55684e;if(_0x44c979[_0x5670ed(0xaf)](_0x2f381d['hook_event_name'],_0x5670ed(0x125)))return{};const _0x2691ce=_0x2f381d;if(_0x2691ce['tool_name']!==_0x5670ed(0xa7))return{};return await _0x4e9526[_0x5670ed(0xeb)](_0x44c979[_0x5670ed(0xc0)],_0x2691ce[_0x5670ed(0x10e)],{'transport':_0x5670ed(0x132),'toolName':_0x5670ed(0xa7)}),{};};return{'postToolUseHook':_0x2f5229,'postToolUseFailureHook':_0xeb72a1,'commandCounts':_0x178770};}async function runPlaywrightCliLifecycleCommand(_0x30b1ea){const _0x455014=_0x1906,_0x5525b5={'iqcGc':function(_0x134a84,_0x3aa5df){return _0x134a84??_0x3aa5df;},'cFoBI':function(_0x32f36f,_0x3b0cca,_0x39cda5){return _0x32f36f(_0x3b0cca,_0x39cda5);}},{sessionId:_0x15ee24,configPath:_0x1cb610,commandArgs:_0x242f93,env:_0x79b7a,telemetry:_0x282777,phase:_0x159a7,metadata:_0x27a80d,timeoutMs:_0x350b3b}=_0x30b1ea;_0x282777[_0x455014(0xba)](_0x159a7,_0x27a80d);try{const _0x574887=await runPlaywrightCliCommand({'sessionId':_0x15ee24,'configPath':_0x1cb610,'commandArgs':_0x242f93,'cwd':process[_0x455014(0xbb)](),'env':_0x79b7a,'timeoutMs':_0x5525b5[_0x455014(0xae)](_0x350b3b,PLAYWRIGHT_CLI_COMMAND_TIMEOUT_MS)});_0x282777[_0x455014(0x113)](_0x159a7,{..._0x27a80d,'subcommand':_0x574887[_0x455014(0xaa)][_0x455014(0x106)],'stdoutPreview':_0x5525b5[_0x455014(0x133)](truncatePreview,_0x574887['stdout'],0x7d0),'stderrPreview':truncatePreview(_0x574887[_0x455014(0x104)],0x7d0)});}catch(_0x32134c){await _0x282777[_0x455014(0xeb)](_0x159a7,_0x32134c,_0x27a80d);throw _0x32134c;}}export async function finalizeVerifyFeatureCliSession(_0x3d40f5){const _0x574673=_0x1906,_0x2e2eb6={'RDSys':'playwright_cli_video_stop','YRJoO':_0x574673(0x11b),'jGFUo':function(_0xa168af,_0x22be95){return _0xa168af(_0x22be95);}},{telemetry:_0x3098e5,sessionId:_0x2a3ef1,configPath:_0x1f9628,cliArtifactDir:_0x28632b,env:_0x21e1b2,transportMetadata:_0x4c006e}=_0x3d40f5,_0xbab236=[{'phase':'playwright_cli_tracing_stop','commandArgs':['tracing-stop']},{'phase':_0x2e2eb6['RDSys'],'commandArgs':['video-stop',_0x574673(0xe3)+buildCliArtifactPath(_0x28632b,'session-recording.webm')]},{'phase':'playwright_cli_close','commandArgs':[_0x2e2eb6['YRJoO']]}];for(const _0x3d73cf of _0xbab236){try{await _0x2e2eb6['jGFUo'](runPlaywrightCliLifecycleCommand,{'sessionId':_0x2a3ef1,'configPath':_0x1f9628,'commandArgs':[..._0x3d73cf[_0x574673(0xdb)]],'env':_0x21e1b2,'telemetry':_0x3098e5,'phase':_0x3d73cf['phase'],'metadata':_0x4c006e});}catch{}}}export async function loadVerifyFeatureCliTraceUploadArtifact(_0x2c39fc){const _0x45682c=_0x1906,_0x2f8a1d={'tZDQi':_0x45682c(0xcf),'YwWpn':function(_0x164885,_0x208c69,_0x17b58f){return _0x164885(_0x208c69,_0x17b58f);},'XNYyU':function(_0x138229,_0x534186){return _0x138229(_0x534186);}},_0x3bb9e9=[_0x45682c(0xb6),_0x2f8a1d[_0x45682c(0xe7)]];for(const _0x5152c4 of _0x3bb9e9){const _0x2e0015=_0x2f8a1d[_0x45682c(0xe9)](join,_0x2c39fc,_0x5152c4);try{return{'buffer':await _0x2f8a1d[_0x45682c(0x130)](readFile,_0x2e0015),'source':_0x2e0015};}catch{}}return null;}export async function rehomeVerifyFeatureCliArtifacts(_0x1eb370){const _0x47b175=_0x1906,_0xdd8929={'janFE':function(_0x326471,_0x4ff840,_0x1493c1){return _0x326471(_0x4ff840,_0x1493c1);},'DhBPt':function(_0x55f9f5,_0xb6764){return _0x55f9f5(_0xb6764);},'jbeng':function(_0x448827,_0x518712){return _0x448827<_0x518712;},'QMTEM':function(_0x6a91be,_0x15a995){return _0x6a91be+_0x15a995;},'stTPr':function(_0x18f614,_0x3bcd35){return _0x18f614===_0x3bcd35;},'xlARc':function(_0x8c448a,_0x12bfa2,_0x30883c){return _0x8c448a(_0x12bfa2,_0x30883c);}},{cwd:_0x3ca8ef,cliArtifactDir:_0xe808ad,startTime:_0x511164}=_0x1eb370,_0xeeca37=[];await _0xdd8929[_0x47b175(0xdc)](mkdir,_0xe808ad,{'recursive':!![]});const _0x2e3988=await _0xdd8929[_0x47b175(0xdc)](readdir,_0x3ca8ef,{'withFileTypes':!![]});for(const _0x5e6938 of _0x2e3988){if(!_0x5e6938[_0x47b175(0x12a)]()||!VERIFY_FEATURE_CLI_ARTIFACT_FILE_PATTERN['test'](_0x5e6938['name']))continue;const _0x5c1045=join(_0x3ca8ef,_0x5e6938['name']),_0xedbee5=await _0xdd8929['DhBPt'](stat,_0x5c1045);if(_0xdd8929[_0x47b175(0x107)](_0xdd8929['QMTEM'](_0xedbee5[_0x47b175(0xe6)],0x7d0),_0x511164))continue;const _0x42f27b=buildCliArtifactPath(_0xe808ad,_0x5e6938[_0x47b175(0x12d)]);if(_0xdd8929['stTPr'](_0x5c1045,_0x42f27b))continue;await _0xdd8929['xlARc'](rename,_0x5c1045,_0x42f27b),_0xeeca37[_0x47b175(0xf8)](_0x5e6938['name']);}return _0xeeca37['sort']();}
1
+ (function(_0x18d502,_0x5b1b28){const _0x3a1625=_0x3816,_0x355bfc=_0x18d502();while(!![]){try{const _0x1720f9=parseInt(_0x3a1625(0x121))/0x1*(-parseInt(_0x3a1625(0x13c))/0x2)+parseInt(_0x3a1625(0x173))/0x3+parseInt(_0x3a1625(0x153))/0x4*(-parseInt(_0x3a1625(0x14c))/0x5)+-parseInt(_0x3a1625(0x188))/0x6+parseInt(_0x3a1625(0x12b))/0x7*(parseInt(_0x3a1625(0x14d))/0x8)+-parseInt(_0x3a1625(0x176))/0x9*(-parseInt(_0x3a1625(0x17b))/0xa)+parseInt(_0x3a1625(0x177))/0xb*(parseInt(_0x3a1625(0x129))/0xc);if(_0x1720f9===_0x5b1b28)break;else _0x355bfc['push'](_0x355bfc['shift']());}catch(_0x2fd36a){_0x355bfc['push'](_0x355bfc['shift']());}}}(_0xd62d,0xaf260));import{mkdir,readFile,readdir,rename,stat}from'fs/promises';import{basename,join}from'path';function _0x3816(_0x36474b,_0x3c2b2d){_0x36474b=_0x36474b-0x103;const _0xd62d62=_0xd62d();let _0x3816af=_0xd62d62[_0x36474b];return _0x3816af;}import{extractBashCommand,parsePlaywrightCliCommand,quoteShellArg,runPlaywrightCliCommand}from'./utils/playwrightCli.js';const PLAYWRIGHT_CLI_COMMAND_TIMEOUT_MS=0xea60,PLAYWRIGHT_CLI_PREVIEW_LIMIT=0xf0,VERIFY_FEATURE_CLI_ARTIFACT_FILE_PATTERN=/^(?:\d{2}_.+\.(?:png|ya?ml)|key_.+\.png|session-recording(?:-\d+)?\.webm|trace(?:\.trace)?(?:-\d+)?\.zip|current_snap\.ya?ml)$/i;function truncatePreview(_0x444994,_0x6ba93c=PLAYWRIGHT_CLI_PREVIEW_LIMIT){const _0x2810ff=_0x3816,_0x1d53c3={'AXlRR':function(_0x3f7b3a,_0x48f7dc){return _0x3f7b3a+_0x48f7dc;},'lKgUq':'...'};return _0x444994['length']>_0x6ba93c?_0x1d53c3['AXlRR'](_0x444994[_0x2810ff(0x16e)](0x0,_0x6ba93c),_0x1d53c3['lKgUq']):_0x444994;}function buildCliArtifactPath(_0x4443ff,_0x2f5c78){return join(_0x4443ff,_0x2f5c78);}function toStepDisplayName(_0x43dfdc){const _0x593b49=_0x3816,_0x1836c6=basename(_0x43dfdc)['replace'](/\.(?:png|ya?ml)$/i,'')['replace'](/^key_/i,'')['replace'](/^\d+_/,'')[_0x593b49(0x13b)](/-/g,'\x20');return{'name':_0x1836c6,'isKeyStep':/^key_/i[_0x593b49(0x10a)](basename(_0x43dfdc))};}function extractShellValue(_0x1b35c6){if(!_0x1b35c6)return null;return _0x1b35c6[0x1]??_0x1b35c6[0x2]??_0x1b35c6[0x3]??null;}function extractFilenameOption(_0x58b72f){return extractShellValue(_0x58b72f['match'](/--filename(?:=|\s+)(?:"([^"]+)"|'([^']+)'|(\S+))/));}function extractFirstCommandArgument(_0xc52965,_0x43df9d){const _0x56a521=_0x3816,_0x1541d6={'IpvAz':'\x5c$&','gPWvr':function(_0x20a298,_0x3012f5){return _0x20a298(_0x3012f5);}},_0x4b2f73=_0x43df9d['replace'](/[.*+?^${}()|[\]\\]/g,_0x1541d6[_0x56a521(0x10b)]);return _0x1541d6['gPWvr'](extractShellValue,_0xc52965['match'](new RegExp('(?:^|\x5cs)'+_0x4b2f73+_0x56a521(0x184))));}function _0xd62d(){const _0x3ff655=['`\x0a\x0a-\x20Write\x20all\x20artifacts\x20under\x20`','commandArgs','open\x20new\x20tab','GWzmy','authorName','hxnbg','--filename=','03_learn-more.png','01_initial-state.png','`\x20and\x20read\x20the\x20snapshot\x20file\x20to\x20inspect\x20the\x20page.\x0a5.\x20**IMMEDIATELY\x20check\x20for\x20blocking\x20HTTP\x20errors\x20before\x20proceeding.**\x0a6.\x20Execute\x20the\x20task\x20step-by-step\x20with\x20Playwright\x20CLI\x20commands.\x0a7.\x20Use\x20`','slice','keys','invocation','clBzV','notes','1734879FykGJu','short','\x20snapshot\x20--filename\x20','1278qtPWjO','33CXDxhS','capture\x20snapshot','\x0a\x0a##\x20Reviewer\x20Feedback\x20to\x20Address\x0aThe\x20following\x20reviewer\x20comments\x20were\x20left\x20on\x20the\x20previous\x20version\x20of\x20this\x20item.\x0aVerify\x20that\x20each\x20concern\x20has\x20been\x20addressed\x20in\x20the\x20current\x20implementation.\x0aFor\x20each\x20comment\x20you\x20believe\x20has\x20been\x20addressed,\x20include\x20its\x20ID\x20(the\x20bracketed\x20value)\x20in\x20the\x20addressedCommentIds\x20array\x20in\x20your\x20output.\x0a\x0a','QgSfP','64360SzxOkV','npxtt','SjYgO','BDeQM','\x20tracing-start`\x0a3.\x20Run\x20`','-\x20[','open\x20new\x20tab\x20','\x20(on\x20element:\x20<','\x20open`,\x20then\x20`','(?:\x5cs+(?:\x22([^\x22]+)\x22|\x27([^\x27]+)\x27|(\x5cS+)))','You\x20are\x20testing\x20browser\x20automation.\x20Your\x20task\x20is\x20simple:\x0a\x0aUse\x20Bash\x20and\x20Playwright\x20CLI\x20only.\x20The\x20browser\x20command\x20prefix\x20is:\x0a','gETUO','env','3227592yKqLVD','pop','\x0a-\x20You\x20may\x20ONLY\x20navigate\x20to\x20paths\x20under\x20this\x20base\x20URL\x20(same\x20protocol,\x20host,\x20and\x20port)\x0a-\x20For\x20example,\x20if\x20the\x20base\x20URL\x20is\x20\x22http://localhost:3000\x22,\x20you\x20can\x20navigate\x20to\x20\x22http://localhost:3000/home\x22,\x20\x22http://localhost:3000/settings\x22,\x20etc.\x0a-\x20DO\x20NOT\x20navigate\x20to\x20any\x20different\x20domain,\x20host,\x20or\x20port\x20under\x20any\x20circumstances\x0a-\x20If\x20documentation\x20or\x20code\x20diffs\x20suggest\x20a\x20path\x20exists\x20(e.g.,\x20\x22/dashboard\x22),\x20you\x20may\x20navigate\x20to\x20that\x20path\x20ONLY\x20under\x20the\x20base\x20URL\x20above\x0a-\x20The\x20base\x20URL\x20above\x20is\x20the\x20ONLY\x20authorized\x20profile\x20for\x20this\x20verification','`\x0a5.\x20Read\x20the\x20snapshot\x20file\x20to\x20find\x20the\x20\x22Learn\x20More\x22\x20link\x20reference\x0a6.\x20Run\x20`','\x0a\x0a1.\x20Run\x20`','`\x20style\x20absolute\x20paths\x20at\x20key\x20moments.\x0a6.\x20If\x20you\x20need\x20waits\x20or\x20custom\x20assertions,\x20use\x20`','\x0a\x0aAfter\x20completing\x20authentication,\x20proceed\x20with\x20the\x20verification\x20task\x20below.\x0aIf\x20authentication\x20fails,\x20return\x20immediately\x20with\x20evaluation\x20\x22blocked\x22\x20and\x20describe\x20the\x20auth\x20failure.','press','\x20video-start`.\x0a3.\x20Save\x20every\x20snapshot\x20and\x20screenshot\x20under\x20`','click\x20','createdAt','CQALy','test','IpvAz','hook_event_name','**\x20(','`\x0a-\x20`run-code\x20\x22await\x20page.waitForTimeout(1000)\x22`\x20for\x20waits\x20or\x20small\x20custom\x20checks\x0a\x0a##\x20Screenshot\x20Guidelines\x20-\x20IMPORTANT\x0aTake\x20screenshots\x20throughout\x20the\x20verification\x20flow\x20so\x20a\x20human\x20can\x20review\x20it\x20for\x20completeness.\x20Screenshots\x20are\x20your\x20evidence\x20trail.\x0a\x0a**When\x20to\x20take\x20screenshots\x20(use\x20Playwright\x20CLI\x20screenshot):**\x0a-\x20After\x20the\x20initial\x20snapshot\x20(capture\x20starting\x20state)\x0a-\x20Before\x20and\x20after\x20clicking\x20buttons\x20or\x20submitting\x20forms\x0a-\x20When\x20important\x20UI\x20elements\x20appear\x20(modals,\x20notifications,\x20loading\x20states)\x0a-\x20After\x20navigating\x20to\x20different\x20views\x20or\x20pages\x0a-\x20When\x20verifying\x20specific\x20elements\x20exist\x0a-\x20At\x20the\x20final\x20state\x20showing\x20the\x20completed\x20action\x0a\x0a**Screenshot\x20naming:**\x0a-\x20Use\x20descriptive\x20filenames\x20under\x20`','snapshot','key_04_success-state.png','trace.zip','playwright_cli_video_stop','`,\x20then\x20`','ClJrY','tracing-stop','run\x20custom\x20Playwright\x20code','meFEn','textContent','TNhMk','Bash','stderr','authorEmail','numeric','`\x20writes\x20a\x20YAML\x20snapshot\x20you\x20can\x20read\x20for\x20element\x20refs\x0a-\x20`click\x20<ref>`,\x20`fill\x20<ref>\x20\x22text\x22`,\x20`check\x20<ref>`,\x20`press\x20Enter`\x0a-\x20`tab-list`,\x20`tab-select\x20<index>`,\x20`tab-new\x20<url>`\x0a-\x20`screenshot\x20--filename\x20','isFile','\x0a\x0a##\x20Critical:\x20Early\x20Error\x20Detection\x0aAfter\x20step\x202\x20(taking\x20initial\x20snapshot),\x20IMMEDIATELY\x20check\x20for\x20blocking\x20HTTP\x20errors:\x0a\x0a**Blocking\x20errors\x20to\x20detect:**\x0a-\x20HTTP\x20404:\x20\x22404\x22,\x20\x22Not\x20Found\x22,\x20\x22Page\x20not\x20found\x22,\x20\x22does\x20not\x20exist\x22\x0a-\x20HTTP\x20500:\x20\x22500\x22,\x20\x22Internal\x20Server\x20Error\x22,\x20\x22Server\x20Error\x22,\x20\x22Something\x20went\x20wrong\x22\x0a-\x20HTTP\x20400:\x20\x22400\x22,\x20\x22Bad\x20Request\x22,\x20\x22Invalid\x20request\x22\x0a\x0a**Also\x20check\x20for:**\x0a-\x20Framework\x20error\x20pages\x20(Next.js\x20error\x20boundary,\x20React\x20error\x20page,\x20\x22Application\x20error\x22)\x0a-\x20Completely\x20blank/empty\x20pages\x20with\x20no\x20content\x0a-\x20\x22Cannot\x20GET\x20/path\x22\x20messages\x0a\x0a**If\x20ANY\x20blocking\x20error\x20is\x20detected:**\x0a1.\x20DO\x20NOT\x20continue\x20with\x20the\x20task\x0a2.\x20Return\x20IMMEDIATELY\x20with\x20evaluation:\x20\x22blocked\x22\x0a3.\x20Set\x20evaluationReason\x20to\x20describe\x20the\x20specific\x20error\x20(e.g.,\x20\x22HTTP\x20404\x20-\x20Page\x20not\x20found\x20at\x20/dashboard\x22)\x0a4.\x20Include\x20the\x20error\x20in\x20issues\x20array\x20with\x20severity:\x20\x22BLOCKER\x22\x20and\x20appropriate\x20type\x20(HTTP_404,\x20HTTP_500,\x20HTTP_400,\x20or\x20NAVIGATION_ERROR)\x0a\x0aThis\x20early\x20exit\x20prevents\x20wasting\x20time\x20on\x20tasks\x20that\x20cannot\x20succeed\x20due\x20to\x20fundamental\x20errors.','507082HjLGLk','close','tool_call','canonicalFlow','bfMxk','trackPhaseEnd','rnaUL','selector','6054564iSvBpD','KohhG','14MopNIV','open','02_learn-more.yml','kbdsU','select\x20tab','GbsBh','target','split','stop\x20video\x20recording','jbunm','00_mozilla-homepage.yml','\x20run-code\x20\x22<playwright\x20code>\x22`.\x0a7.\x20Do\x20not\x20run\x20`close`,\x20`tracing-stop`,\x20or\x20`video-stop`;\x20the\x20host\x20finalizes\x20the\x20session\x20and\x20artifacts.\x0a8.\x20After\x20completing\x20the\x20verification,\x20evaluate\x20whether\x20the\x20result\x20adequately\x20verifies\x20the\x20scenario','MSYIy','wiRKT','CAJvN','playwright-cli','replace','2xEGQBF','name','tool_name','length','map','\x20run-code\x20\x22<playwright\x20code>\x22`.\x0a9.\x20Do\x20not\x20run\x20`close`,\x20`tracing-stop`,\x20or\x20`video-stop`;\x20the\x20host\x20finalizes\x20the\x20session\x20and\x20artifacts.\x0a10.\x20After\x20completing\x20the\x20verification,\x20evaluate\x20whether\x20the\x20result\x20adequately\x20verifies\x20the\x20scenario','set','YOjPz','key_03_success-state.png','[ranger-verification-agent]\x20','`\x20using\x20absolute\x20paths\x20only.\x20Do\x20not\x20use\x20relative\x20filenames.\x0a5.\x20Run\x20`','click','WtXBv','##\x20App\x20Context\x0aYou\x20are\x20connected\x20to\x20a\x20desktop\x20application\x20via\x20CDP\x20(Chrome\x20DevTools\x20Protocol)\x20at\x20','##\x20Instructions\x0a1.\x20Use\x20Bash\x20plus\x20Playwright\x20CLI\x20only.\x20Do\x20NOT\x20call\x20MCP\x20browser\x20tools.\x0a2.\x20Start\x20by\x20running\x20`','video-start','19250ZAKMKL','647304lzQXQg','\x20screenshot\x20--filename\x20','DYmCP','`\x0a9.\x20Run\x20`','trace.trace.zip','UBVcB','1460BxLZhq','OLIni','join','error','ckGUf','open\x20browser','content','EAcfj','\x0a\x0a##\x20Task\x20to\x20Execute\x0a','tool_input','\x20open\x20','FzMJW','Reviewer','sort','01_initial.yml','FXRJQ','check'];_0xd62d=function(){return _0x3ff655;};return _0xd62d();}function formatCommandTarget(_0x4cd515){const _0x352ccf=_0x3816;if(!_0x4cd515)return _0x352ccf(0x131);if(/^e\d+$/i[_0x352ccf(0x10a)](_0x4cd515))return'ref\x20'+_0x4cd515;return JSON['stringify'](truncatePreview(_0x4cd515,0x78));}function formatPlaywrightCliLog(_0x93a6c1,_0x5beca8){const _0x5c2113=_0x3816,_0x5c453a={'qpzZr':_0x5c2113(0x12c),'meFEn':function(_0x2a1dcb,_0xbf6c87,_0x141476){return _0x2a1dcb(_0xbf6c87,_0x141476);},'DhDON':'tracing-start','wiRKT':'start\x20tracing','xhEaK':'start\x20video\x20recording','CQALy':_0x5c2113(0x133),'lhnJI':_0x5c2113(0x10f),'qsnDA':function(_0x21c7eb,_0x19f4e0){return _0x21c7eb(_0x19f4e0);},'HyRtZ':function(_0x532b9f,_0x3c1bdc){return _0x532b9f(_0x3c1bdc);},'YJXkN':_0x5c2113(0x163),'SXFeU':'fill','OLIni':function(_0x46bd4c,_0x1d161a){return _0x46bd4c(_0x1d161a);},'RKtoZ':'tab-select','EVJnL':_0x5c2113(0x12f)};switch(_0x5beca8){case _0x5c453a['qpzZr']:{const _0x408e46=_0x5c453a[_0x5c2113(0x117)](extractFirstCommandArgument,_0x93a6c1,_0x5beca8);return _0x408e46?'open\x20'+_0x408e46:_0x5c2113(0x158);}case _0x5c453a['DhDON']:return _0x5c453a[_0x5c2113(0x138)];case'tracing-stop':return'stop\x20tracing';case _0x5c2113(0x14b):return _0x5c453a['xhEaK'];case'video-stop':return _0x5c453a[_0x5c2113(0x109)];case _0x5c453a['lhnJI']:{const _0x23d1da=extractFilenameOption(_0x93a6c1);if(!_0x23d1da)return _0x5c2113(0x178);const {name:_0x9fc40e}=toStepDisplayName(_0x23d1da);return'capture\x20snapshot\x20`'+_0x9fc40e+'`';}case'screenshot':{const _0x56dd7a=extractFilenameOption(_0x93a6c1);if(!_0x56dd7a)return'capture\x20screenshot';const {name:_0x40fa74,isKeyStep:_0x2907d4}=_0x5c453a['qsnDA'](toStepDisplayName,_0x56dd7a);return _0x2907d4?'capture\x20key\x20step\x20`'+_0x40fa74+'`':'capture\x20step\x20`'+_0x40fa74+'`';}case _0x5c2113(0x147):return _0x5c2113(0x107)+_0x5c453a['HyRtZ'](formatCommandTarget,extractFirstCommandArgument(_0x93a6c1,_0x5beca8));case _0x5c453a['YJXkN']:return'check\x20'+formatCommandTarget(extractFirstCommandArgument(_0x93a6c1,_0x5beca8));case _0x5c453a['SXFeU']:return'fill\x20'+_0x5c453a[_0x5c2113(0x154)](formatCommandTarget,extractFirstCommandArgument(_0x93a6c1,_0x5beca8));case _0x5c2113(0x105):return'press\x20'+_0x5c453a[_0x5c2113(0x154)](formatCommandTarget,_0x5c453a['meFEn'](extractFirstCommandArgument,_0x93a6c1,_0x5beca8));case'run-code':return _0x5c2113(0x116);case'tab-new':{const _0x31306c=extractFirstCommandArgument(_0x93a6c1,_0x5beca8);return _0x31306c?_0x5c2113(0x181)+_0x31306c:_0x5c2113(0x166);}case _0x5c453a['RKtoZ']:{const _0xe10a13=extractFirstCommandArgument(_0x93a6c1,_0x5beca8);return _0xe10a13?'select\x20tab\x20'+_0xe10a13:_0x5c453a['EVJnL'];}default:return _0x5beca8;}}function extractPlaywrightCliToolDescription(_0x2ab466){const _0x56ce2=_0x3816,_0x567eca={'KohhG':function(_0x2e6bab,_0x129c45){return _0x2e6bab>_0x129c45;}},_0x540bc6=_0x2ab466['description'];if(typeof _0x540bc6!=='string')return null;const _0x41c091=_0x540bc6['trim']()[_0x56ce2(0x13b)](/\s+/g,'\x20');return _0x567eca[_0x56ce2(0x12a)](_0x41c091[_0x56ce2(0x13f)],0x0)?_0x41c091:null;}export function formatPlaywrightCliConsoleLogMessage(_0x541d57,_0x592458,_0x54c27b){const _0x41e450=_0x3816,_0x10a42f={'jCiMM':function(_0xf45fad,_0xdf6f03,_0x22222f){return _0xf45fad(_0xdf6f03,_0x22222f);}},_0x184c6c=_0x10a42f['jCiMM'](formatPlaywrightCliLog,_0x592458,_0x54c27b),_0x2ae345=extractPlaywrightCliToolDescription(_0x541d57);if(!_0x2ae345)return'[playwright-cli]\x20'+_0x184c6c;if(process[_0x41e450(0x187)]['DEBUG'])return _0x41e450(0x145)+_0x2ae345+'\x20('+_0x184c6c+')';return _0x41e450(0x145)+_0x2ae345;}export function buildVerifyFeatureCliDebugPrompt(_0x5b6150,_0x1002f4){const _0x4a0aeb=_0x3816,_0x57f012={'SjYgO':function(_0x48b1c1,_0x1b2b38,_0xfdba39){return _0x48b1c1(_0x1b2b38,_0xfdba39);},'zjdAL':_0x4a0aeb(0x12d),'npxtt':function(_0x39cee9,_0x405e55){return _0x39cee9(_0x405e55);}},_0x545532=_0x57f012[_0x4a0aeb(0x17d)](buildCliArtifactPath,_0x1002f4,_0x4a0aeb(0x135)),_0x577f3a=_0x57f012[_0x4a0aeb(0x17d)](buildCliArtifactPath,_0x1002f4,'01_mozilla-homepage.png'),_0xca6536=_0x57f012[_0x4a0aeb(0x17d)](buildCliArtifactPath,_0x1002f4,_0x57f012['zjdAL']),_0x4dbe80=buildCliArtifactPath(_0x1002f4,_0x4a0aeb(0x16b)),_0x5548fd=quoteShellArg(_0x545532),_0x2c75c9=quoteShellArg(_0x577f3a),_0x58d3d0=quoteShellArg(_0xca6536),_0x18586e=_0x57f012[_0x4a0aeb(0x17c)](quoteShellArg,_0x4dbe80);return _0x4a0aeb(0x185)+_0x5b6150+_0x4a0aeb(0x18c)+_0x5b6150+'\x20open\x20https://www.mozilla.org`\x0a2.\x20Run\x20`'+_0x5b6150+_0x4a0aeb(0x17f)+_0x5b6150+'\x20video-start`\x0a4.\x20Save\x20every\x20snapshot\x20and\x20screenshot\x20under\x20`'+_0x1002f4+_0x4a0aeb(0x146)+_0x5b6150+'\x20snapshot\x20--filename\x20'+_0x5548fd+_0x4a0aeb(0x18b)+_0x5b6150+_0x4a0aeb(0x14e)+_0x2c75c9+'`\x0a7.\x20Click\x20the\x20\x22Learn\x20More\x22\x20link\x20with\x20Playwright\x20CLI\x0a8.\x20Run\x20`'+_0x5b6150+_0x4a0aeb(0x175)+_0x58d3d0+_0x4a0aeb(0x150)+_0x5b6150+'\x20screenshot\x20--filename\x20'+_0x18586e+'`\x0a10.\x20Return\x20immediately\x20with\x20the\x20structured\x20output\x0a\x0aReturn\x20your\x20findings\x20in\x20the\x20structured\x20output\x20format.';}export function buildVerifyFeatureCliPrompt(_0xf574c0){const _0x4f2352=_0x3816,_0x36df48={'tWUkz':'en-US','EAcfj':_0x4f2352(0x174),'ckGUf':_0x4f2352(0x11d),'XAgQA':_0x4f2352(0x15f),'QgSfP':'\x20>\x20','GWzmy':'element','rnaUL':function(_0x3a0237,_0x561dbf,_0x507ef0){return _0x3a0237(_0x561dbf,_0x507ef0);},'bfMxk':'02_state.yml','GbsBh':function(_0x50df3b,_0x1d88b1,_0x50a258){return _0x50df3b(_0x1d88b1,_0x50a258);},'iPynj':function(_0x4c0e13,_0x3eb26f){return _0x4c0e13(_0x3eb26f);},'FuTDb':function(_0x51ce4e,_0x367de9){return _0x51ce4e(_0x367de9);},'kbdsU':'02_button-clicked.png','DYmCP':'03_result-visible.png','jbunm':_0x4f2352(0x110)},{checklistItem:_0x3cc1ef,itemFeedback:_0xf0b1b1,taskDescription:_0x52a49,cliCommandPrefix:_0x5f0f76,cliArtifactDir:_0x140061,isCdpMode:_0x1e84cc,url:_0x332e04,cdpEndpoint:_0x3cb580,loginInstructions:_0x5369e3}=_0xf574c0,_0x14a8ba=buildCliArtifactPath(_0x140061,_0x4f2352(0x161)),_0x449da1=_0x36df48[_0x4f2352(0x127)](buildCliArtifactPath,_0x140061,_0x36df48[_0x4f2352(0x125)]),_0x5c2f2a=_0x36df48['GbsBh'](buildCliArtifactPath,_0x140061,_0x4f2352(0x144)),_0x4b2bd2=_0x36df48[_0x4f2352(0x130)](buildCliArtifactPath,_0x140061,_0x4f2352(0x16c)),_0x2646fb=quoteShellArg(_0x14a8ba),_0x75b2cb=quoteShellArg(_0x449da1),_0x303383=_0x36df48['iPynj'](quoteShellArg,_0x5c2f2a),_0x2c289f=_0x36df48['FuTDb'](quoteShellArg,_0x4b2bd2),_0x1728bc=_0x3cc1ef[_0x4f2352(0x172)]?'\x0a\x0a##\x20Additional\x20Notes\x0a'+_0x3cc1ef[_0x4f2352(0x172)]:'';let _0x3d4bcd='';if(_0xf0b1b1&&_0xf0b1b1['unaddressedComments'][_0x4f2352(0x13f)]>0x0){const _0x19bf5a=_0xf0b1b1['unaddressedComments'][_0x4f2352(0x140)](_0x5427f2=>{const _0x24a640=_0x4f2352,_0x15be93=new Date(_0x5427f2[_0x24a640(0x108)])['toLocaleDateString'](_0x36df48['tWUkz'],{'month':_0x36df48[_0x24a640(0x15a)],'day':_0x36df48[_0x24a640(0x157)]}),_0x5b488f=_0x5427f2[_0x24a640(0x168)]||_0x5427f2[_0x24a640(0x11c)]||_0x36df48['XAgQA'],_0x15db18=_0x5427f2['domRef']?_0x24a640(0x182)+(_0x5427f2['domRef'][_0x24a640(0x128)][_0x24a640(0x132)](_0x36df48[_0x24a640(0x17a)])[_0x24a640(0x189)]()?.['split'](':')[0x0]||_0x36df48[_0x24a640(0x167)])+'>\x20\x22'+(_0x5427f2['domRef'][_0x24a640(0x118)]||'')['slice'](0x0,0x32)+'\x22)':'';return _0x24a640(0x180)+_0x5427f2['id']+']\x20**'+_0x5b488f+_0x24a640(0x10d)+_0x15be93+'):\x20\x22'+_0x5427f2[_0x24a640(0x159)]+'\x22'+_0x15db18;})[_0x4f2352(0x155)]('\x0a');_0x3d4bcd=_0x4f2352(0x179)+_0x19bf5a;}const _0x59429c=_0xf0b1b1?.[_0x4f2352(0x124)]?'\x0a\x0a##\x20Expected\x20Flow\x20(from\x20previous\x20verification)\x0a'+_0xf0b1b1[_0x4f2352(0x124)]:'',_0x2dad88=_0x1e84cc?_0x4f2352(0x149)+_0x3cb580+'.\x0aThis\x20is\x20NOT\x20a\x20web\x20app\x20—\x20there\x20is\x20no\x20URL\x20to\x20navigate\x20to.\x20The\x20app\x20is\x20already\x20running\x20and\x20connected.':'CRITICAL\x20URL\x20REQUIREMENT:\x0aYour\x20base\x20URL\x20is:\x20'+_0x332e04+_0x4f2352(0x18a),_0x424e39=_0x332e04?quoteShellArg(_0x332e04):'',_0x131aaf=_0x1e84cc?_0x4f2352(0x14a)+_0x5f0f76+_0x4f2352(0x183)+_0x5f0f76+'\x20tracing-start`,\x20then\x20`'+_0x5f0f76+'\x20video-start`.\x0a3.\x20Save\x20every\x20snapshot\x20and\x20screenshot\x20under\x20`'+_0x140061+'`\x20using\x20absolute\x20paths\x20only.\x20Do\x20not\x20use\x20relative\x20filenames.\x0a4.\x20Take\x20a\x20snapshot\x20with\x20`'+_0x5f0f76+'\x20snapshot\x20--filename\x20'+_0x2646fb+'`\x20to\x20inspect\x20the\x20current\x20app\x20state.\x0a5.\x20Read\x20snapshot\x20YAML\x20files\x20to\x20find\x20element\x20references\x20like\x20`e12`,\x20then\x20use\x20them\x20with\x20`click`,\x20`fill`,\x20`check`,\x20or\x20`select`.\x0a6.\x20Use\x20`'+_0x5f0f76+_0x4f2352(0x14e)+_0x2c289f+_0x4f2352(0x103)+_0x5f0f76+_0x4f2352(0x136):'##\x20Instructions\x0a1.\x20Use\x20Bash\x20plus\x20Playwright\x20CLI\x20only.\x20Do\x20NOT\x20call\x20MCP\x20browser\x20tools.\x0a2.\x20Start\x20by\x20running\x20`'+_0x5f0f76+_0x4f2352(0x15d)+_0x424e39+_0x4f2352(0x113)+_0x5f0f76+'\x20tracing-start`,\x20then\x20`'+_0x5f0f76+_0x4f2352(0x106)+_0x140061+'`\x20using\x20absolute\x20paths\x20only.\x20Do\x20not\x20use\x20relative\x20filenames.\x0a4.\x20Take\x20a\x20snapshot\x20with\x20`'+_0x5f0f76+_0x4f2352(0x175)+_0x2646fb+_0x4f2352(0x16d)+_0x5f0f76+_0x4f2352(0x14e)+_0x2c289f+'`\x20style\x20absolute\x20paths\x20at\x20key\x20moments.\x0a8.\x20If\x20you\x20need\x20waits\x20or\x20custom\x20assertions,\x20use\x20`'+_0x5f0f76+_0x4f2352(0x141),_0x3261fe=_0x1e84cc?'\x0a\x0a##\x20Critical:\x20Early\x20Error\x20Detection\x0aAfter\x20taking\x20the\x20initial\x20snapshot,\x20IMMEDIATELY\x20check\x20for\x20blocking\x20errors:\x0a\x0a**Blocking\x20errors\x20to\x20detect:**\x0a-\x20Crash\x20or\x20error\x20dialogs\x20(\x22An\x20error\x20occurred\x22,\x20\x22Something\x20went\x20wrong\x22,\x20unhandled\x20exception\x20messages)\x0a-\x20Blank\x20or\x20empty\x20window\x20with\x20no\x20rendered\x20content\x0a-\x20Framework\x20error\x20boundaries\x20(React\x20error\x20page,\x20Electron\x20crash\x20reporter)\x0a-\x20Unresponsive\x20or\x20frozen\x20UI\x20(no\x20interactive\x20elements\x20in\x20snapshot)\x0a\x0a**If\x20ANY\x20blocking\x20error\x20is\x20detected:**\x0a1.\x20DO\x20NOT\x20continue\x20with\x20the\x20task\x0a2.\x20Return\x20IMMEDIATELY\x20with\x20evaluation:\x20\x22blocked\x22\x0a3.\x20Set\x20evaluationReason\x20to\x20describe\x20the\x20specific\x20error\x20(e.g.,\x20\x22App\x20crashed\x20—\x20error\x20dialog\x20visible\x20on\x20launch\x22)\x0a4.\x20Include\x20the\x20error\x20in\x20issues\x20array\x20with\x20severity:\x20\x22BLOCKER\x22\x20and\x20type:\x20\x22APP_ERROR\x22\x0a\x0aThis\x20early\x20exit\x20prevents\x20wasting\x20time\x20on\x20tasks\x20that\x20cannot\x20succeed\x20due\x20to\x20fundamental\x20errors.':_0x4f2352(0x120),_0x207a52=_0x5369e3?'\x0a\x0a##\x20Authentication\x0aBEFORE\x20starting\x20the\x20verification\x20task,\x20you\x20MUST\x20authenticate\x20using\x20these\x20steps:\x0a'+_0x5369e3+_0x4f2352(0x104):'';return'You\x20are\x20a\x20Feature\x20Review\x20Verifier.\x20Your\x20job\x20is\x20to\x20verify\x20a\x20scenario\x20by\x20executing\x20a\x20UI\x20flow\x20and\x20evaluating\x20whether\x20it\x20adequately\x20completes\x20the\x20scenario.\x0a\x0a##\x20Scenario\x20to\x20Verify\x0a'+_0x3cc1ef['description']+_0x1728bc+_0x3d4bcd+_0x59429c+_0x4f2352(0x15b)+_0x52a49+'\x0a\x0a'+_0x2dad88+_0x207a52+'\x0a\x0a'+_0x131aaf+'\x0a\x0a##\x20Browser\x20Command\x20Reference\x0aUse\x20Bash\x20to\x20run\x20Playwright\x20CLI\x20commands\x20with\x20this\x20exact\x20prefix:\x0a`'+_0x5f0f76+_0x4f2352(0x164)+_0x140061+'`\x0a-\x20`snapshot\x20--filename\x20'+_0x75b2cb+_0x4f2352(0x11e)+_0x303383+_0x4f2352(0x10e)+_0x140061+'`:\x20\x22'+_0x4b2bd2+'\x22,\x20\x22'+buildCliArtifactPath(_0x140061,_0x36df48[_0x4f2352(0x12e)])+'\x22,\x20\x22'+buildCliArtifactPath(_0x140061,_0x36df48[_0x4f2352(0x14f)])+'\x22\x0a-\x20Number\x20prefixes\x20(01_,\x2002_,\x20etc.)\x20help\x20maintain\x20chronological\x20order\x0a-\x20For\x20KEY\x20MOMENTS\x20that\x20prove\x20the\x20scenario\x20is\x20complete,\x20prefix\x20with\x20\x22key_\x22:\x20\x22'+buildCliArtifactPath(_0x140061,_0x36df48[_0x4f2352(0x134)])+'\x22\x0a-\x20The\x20\x22key_\x22\x20prefix\x20marks\x20screenshots\x20as\x20high-priority\x20evidence\x20for\x20human\x20reviewers\x0a\x0a**Aim\x20for\x203-6\x20screenshots\x20per\x20verification**\x20to\x20document\x20the\x20complete\x20flow.\x20Mark\x201-2\x20of\x20the\x20most\x20important\x20ones\x20with\x20the\x20\x22key_\x22\x20prefix.\x0a'+_0x3261fe+'\x0a##\x20Evaluation\x20Criteria\x0a-\x20VERIFIED:\x20The\x20task\x20completed\x20successfully\x20and\x20the\x20scenario\x20requirements\x20are\x20fully\x20met\x0a-\x20PARTIAL:\x20The\x20task\x20partially\x20completed\x20but\x20some\x20aspects\x20of\x20the\x20scenario\x20are\x20not\x20verified\x0a-\x20BLOCKED:\x20A\x20blocking\x20issue\x20(bug,\x20error,\x20missing\x20feature)\x20prevents\x20completion\x0a-\x20FAILED:\x20The\x20task\x20could\x20not\x20be\x20completed\x20due\x20to\x20errors\x0a\x0aReturn\x20your\x20findings\x20in\x20the\x20structured\x20output\x20format\x20with\x20your\x20evaluation.';}export function summarizeVerifyFeatureCliCommandAvailability(_0x47eb57){const _0x33bd83=_0x3816,_0x4b7fd2={'XetJI':function(_0x5727d4,_0x1ec8eb){return _0x5727d4===_0x1ec8eb;}},_0x16b19d=[..._0x47eb57[_0x33bd83(0x16f)]()]['sort']();let _0x17339a=0x0;for(const _0x547571 of _0x47eb57['values']()){_0x17339a+=_0x547571;}return{'cliCommandCount':_0x17339a,'cliCommandsSeen':_0x16b19d,'noCliCommandsCalled':_0x4b7fd2['XetJI'](_0x17339a,0x0)};}export function createVerifyFeatureCliHooks(_0x77aade){const _0xbe2e71=_0x3816,_0x546196={'wXlxZ':function(_0x309f67,_0xfe0687){return _0x309f67!==_0xfe0687;},'WtXBv':function(_0x1cca6e,_0x2b8f83){return _0x1cca6e!==_0x2b8f83;},'hxnbg':'Bash','CAJvN':_0xbe2e71(0x123),'UBVcB':_0xbe2e71(0x13a),'wyMSm':function(_0x337753,_0xb9b38c){return _0x337753(_0xb9b38c);},'ClJrY':'snapshot','fRmnC':'PostToolUseFailure'},_0x2435a9=new Map(),_0x5cc998=async _0x3a0a78=>{const _0x1152e8=_0xbe2e71;if(_0x546196['wXlxZ'](_0x3a0a78['hook_event_name'],'PostToolUse'))return{};const _0x49d562=_0x3a0a78;if(_0x546196[_0x1152e8(0x148)](_0x49d562[_0x1152e8(0x13e)],_0x546196[_0x1152e8(0x169)]))return{};const _0x3f0376=_0x49d562[_0x1152e8(0x15c)],_0x38ba37=extractBashCommand(_0x3f0376);if(!_0x38ba37)return{};const _0x85b5f7=parsePlaywrightCliCommand(_0x38ba37);if(!_0x85b5f7)return{};return _0x2435a9[_0x1152e8(0x142)](_0x85b5f7,(_0x2435a9['get'](_0x85b5f7)||0x0)+0x1),_0x77aade['trackPhaseStart'](_0x546196[_0x1152e8(0x139)],{'transport':_0x546196['UBVcB'],'toolName':_0x85b5f7}),_0x77aade[_0x1152e8(0x126)](_0x546196['CAJvN'],{'transport':_0x546196[_0x1152e8(0x152)],'toolName':_0x85b5f7,'bashCommandPreview':_0x546196['wyMSm'](truncatePreview,_0x38ba37)}),_0x85b5f7!==_0x546196[_0x1152e8(0x114)]&&console['log'](formatPlaywrightCliConsoleLogMessage(_0x3f0376,_0x38ba37,_0x85b5f7)),{};},_0x394e88=async _0x46ce2c=>{const _0x440a14=_0xbe2e71;if(_0x46ce2c[_0x440a14(0x10c)]!==_0x546196['fRmnC'])return{};const _0x2c6d0c=_0x46ce2c;if(_0x2c6d0c['tool_name']!==_0x546196[_0x440a14(0x169)])return{};return await _0x77aade['trackPhaseError']('tool_failure',_0x2c6d0c[_0x440a14(0x156)],{'transport':_0x440a14(0x13a),'toolName':_0x440a14(0x11a)}),{};};return{'postToolUseHook':_0x5cc998,'postToolUseFailureHook':_0x394e88,'commandCounts':_0x2435a9};}async function runPlaywrightCliLifecycleCommand(_0x4c9a33){const _0x5955b5=_0x3816,{sessionId:_0x36d9e5,configPath:_0xb3fc3a,commandArgs:_0x410a8f,env:_0x1939aa,telemetry:_0x1adbb5,phase:_0x2bb929,metadata:_0x2c2726,timeoutMs:_0x1e5d62}=_0x4c9a33;_0x1adbb5['trackPhaseStart'](_0x2bb929,_0x2c2726);try{const _0x35297c=await runPlaywrightCliCommand({'sessionId':_0x36d9e5,'configPath':_0xb3fc3a,'commandArgs':_0x410a8f,'cwd':process['cwd'](),'env':_0x1939aa,'timeoutMs':_0x1e5d62??PLAYWRIGHT_CLI_COMMAND_TIMEOUT_MS});_0x1adbb5['trackPhaseEnd'](_0x2bb929,{..._0x2c2726,'subcommand':_0x35297c[_0x5955b5(0x170)]['subcommand'],'stdoutPreview':truncatePreview(_0x35297c['stdout'],0x7d0),'stderrPreview':truncatePreview(_0x35297c[_0x5955b5(0x11b)],0x7d0)});}catch(_0x428b78){await _0x1adbb5['trackPhaseError'](_0x2bb929,_0x428b78,_0x2c2726);throw _0x428b78;}}export async function finalizeVerifyFeatureCliSession(_0x1a4f78){const _0x5245c2=_0x3816,_0x54966d={'clBzV':'playwright_cli_tracing_stop','FXRJQ':_0x5245c2(0x115),'MSYIy':_0x5245c2(0x112),'BDeQM':'video-stop','gETUO':function(_0x58ac04,_0x2dc25a,_0x4372e4){return _0x58ac04(_0x2dc25a,_0x4372e4);}},{telemetry:_0x561790,sessionId:_0x5669ab,configPath:_0x341474,cliArtifactDir:_0x590fc9,env:_0x543bb2,transportMetadata:_0x12ea48}=_0x1a4f78,_0x75603d=[{'phase':_0x54966d[_0x5245c2(0x171)],'commandArgs':[_0x54966d[_0x5245c2(0x162)]]},{'phase':_0x54966d[_0x5245c2(0x137)],'commandArgs':[_0x54966d[_0x5245c2(0x17e)],_0x5245c2(0x16a)+_0x54966d[_0x5245c2(0x186)](buildCliArtifactPath,_0x590fc9,'session-recording.webm')]},{'phase':'playwright_cli_close','commandArgs':[_0x5245c2(0x122)]}];for(const _0x6dbf2b of _0x75603d){try{await runPlaywrightCliLifecycleCommand({'sessionId':_0x5669ab,'configPath':_0x341474,'commandArgs':[..._0x6dbf2b[_0x5245c2(0x165)]],'env':_0x543bb2,'telemetry':_0x561790,'phase':_0x6dbf2b['phase'],'metadata':_0x12ea48});}catch{}}}export async function loadVerifyFeatureCliTraceUploadArtifact(_0x225a37){const _0x51e31f=_0x3816,_0x217e65={'CAOzi':function(_0x20e017,_0x709fe,_0x97636f){return _0x20e017(_0x709fe,_0x97636f);}},_0x149ea9=[_0x51e31f(0x111),_0x51e31f(0x151)];for(const _0xbd9b9 of _0x149ea9){const _0x3cfa9c=_0x217e65['CAOzi'](join,_0x225a37,_0xbd9b9);try{return{'buffer':await readFile(_0x3cfa9c),'source':_0x3cfa9c};}catch{}}return null;}export async function rehomeVerifyFeatureCliArtifacts(_0x3d6972){const _0x133d58=_0x3816,_0xf5b9bf={'FzMJW':function(_0x5547cc,_0x3a1cdb,_0x21765b){return _0x5547cc(_0x3a1cdb,_0x21765b);},'OqAVL':function(_0x4a1be9,_0x5ca443){return _0x4a1be9(_0x5ca443);},'TNhMk':function(_0x42b9fd,_0x234515,_0x41000c){return _0x42b9fd(_0x234515,_0x41000c);},'WtlsW':function(_0x50fa6d,_0x5ac9af){return _0x50fa6d===_0x5ac9af;},'YOjPz':function(_0x3d1a11,_0x15f683,_0x4dde45){return _0x3d1a11(_0x15f683,_0x4dde45);}},{cwd:_0x338484,cliArtifactDir:_0x2dccad,startTime:_0x2594f5}=_0x3d6972,_0x4be2a8=[];await mkdir(_0x2dccad,{'recursive':!![]});const _0x465fb1=await _0xf5b9bf[_0x133d58(0x15e)](readdir,_0x338484,{'withFileTypes':!![]});for(const _0x2a84b0 of _0x465fb1){if(!_0x2a84b0[_0x133d58(0x11f)]()||!VERIFY_FEATURE_CLI_ARTIFACT_FILE_PATTERN['test'](_0x2a84b0['name']))continue;const _0x5cc3d9=join(_0x338484,_0x2a84b0['name']),_0x176dc3=await _0xf5b9bf['OqAVL'](stat,_0x5cc3d9);if(_0x176dc3['mtimeMs']+0x7d0<_0x2594f5)continue;const _0x55d15f=_0xf5b9bf[_0x133d58(0x119)](buildCliArtifactPath,_0x2dccad,_0x2a84b0[_0x133d58(0x13d)]);if(_0xf5b9bf['WtlsW'](_0x5cc3d9,_0x55d15f))continue;await _0xf5b9bf[_0x133d58(0x143)](rename,_0x5cc3d9,_0x55d15f),_0x4be2a8['push'](_0x2a84b0[_0x133d58(0x13d)]);}return _0x4be2a8[_0x133d58(0x160)]();}
@@ -7,12 +7,25 @@ description: "Ranger’s browser verification tooling that supplements a coding
7
7
 
8
8
  Run Ranger commands using `ranger-cli <args>`.
9
9
 
10
- **IMPORTANT: At the start of any session, run `ranger-cli update` to ensure you have the latest CLI and skills.**
10
+ **IMPORTANT: At the start of any session, check that you have the latest CLI and skills. If you were installed from `@latest`, run `ranger-cli update`. If you are on a prerelease (e.g., `@alpha`, version contains `-alpha.`), do NOT run `ranger-cli update` it will move you to `@latest` and off the prerelease track. Check with your team lead or re-install with `npm i -g @ranger-testing/ranger-cli@alpha` to stay current on that channel.**
11
11
 
12
12
  If you are running in Claude Code, read and suggest the following claude-specific commands to the user: [claude.md](./claude.md).
13
13
 
14
14
  Use Ranger when the work includes any UI or frontend component. Do not suggest Ranger for backend-only or infra-only changes unless the user asks.
15
15
 
16
+ ## One-shot verification from user creds
17
+
18
+ When the user gives you credentials and a goal in a single message (e.g. "use `alice@example.com` / `hunter2` to log in and check the dashboard renders"), skip the create/setup ceremony and run verification directly:
19
+
20
+ ```bash
21
+ RANGER_TEST_USERNAME='alice@example.com' RANGER_TEST_PASSWORD='hunter2' \
22
+ ranger-cli go --url <target-url> --notes '<the goal verbatim>'
23
+ ```
24
+
25
+ If a feature review is required and none is active, the CLI will create one automatically. Do **not** run `ranger-cli create` first unless the user explicitly asks for a structured feature review with multiple scenarios.
26
+
27
+ When credentials sit in a `.env` next to the user's repo (look for `RANGER_TEST_USERNAME` / `RANGER_TEST_PASSWORD` / `TARGET_URL`), source that file inline before running `go` instead of typing the values.
28
+
16
29
  This skill covers three workflows for Ranger feature review tracking:
17
30
 
18
31
  ## Supported Workflows
@@ -232,9 +245,10 @@ When completing your work or ending the session, your final message to the user
232
245
 
233
246
  If you encounter authentication issues:
234
247
 
235
- 1. **Check your profiles**: Run `ranger-cli profile ls` to see all configured profiles and their details
236
- 2. **Switch profiles**: Use `ranger-cli profile use <profile-name>` to switch to a different profile
237
- 3. **Refresh auth**: Instruct the user to run `ranger-cli profile update <profile-name>` to re-capture authentication for a profile (user will need to help with that)
248
+ 1. **Log in with provided credentials**: Set `RANGER_TEST_USERNAME` and `RANGER_TEST_PASSWORD` and re-run `ranger-cli go ...`. The CLI uses those credentials to log in and reuses the same profile on subsequent runs.
249
+ 2. **Check existing profiles**: Run `ranger-cli profile ls` to see all configured profiles.
250
+ 3. **Pin a specific profile**: Use `ranger-cli profile use <profile-name>` (or pass `--profile <name>` / set `RANGER_PROFILE`).
251
+ 4. **Refresh auth**: Ask the user to run `ranger-cli profile update <profile-name>` to re-capture authentication for a profile.
238
252
 
239
253
 
240
254
  ### Authentication Issues to Ranger
@@ -2,6 +2,12 @@
2
2
 
3
3
  Create a feature review when starting new work that doesn't have an existing feature review to resume.
4
4
 
5
+ ## When NOT to use this
6
+
7
+ If the user just wants a quick browser check (e.g. "log in as X and confirm the dashboard renders"), skip this step. Run `ranger-cli go --url <target> --notes '<goal>'` directly — a feature review will be created automatically when one is needed. See the **One-shot verification from user creds** section in the parent `SKILL.md`.
8
+
9
+ Reach for `ranger-cli create` when the work is multi-scenario or you want to enumerate the user journeys up front for the reviewer.
10
+
5
11
  ## Basic Command
6
12
 
7
13
  ```bash
@@ -8,7 +8,27 @@ After implementing code for a scenario, verify it works in the browser. This cre
8
8
  ranger-cli go --scenario <N> --notes "<what to verify>"
9
9
  ```
10
10
 
11
- The URL is derived from your active profile's `baseUrl` setting.
11
+ The URL is derived from your active profile's `baseUrl` setting (or auto-materialized — see below).
12
+
13
+ ## Profile resolution (no setup required)
14
+
15
+ The fastest path: when the user gives you a username + password (in chat or in a `.env`), set them inline and run `go`. The CLI handles the rest — no `profile add` step.
16
+
17
+ ```bash
18
+ RANGER_TEST_USERNAME='alice@example.com' RANGER_TEST_PASSWORD='hunter2' \
19
+ ranger-cli go --url <target> --notes '<what to verify>'
20
+ ```
21
+
22
+ If `RANGER_TEST_USERNAME` already matches an existing cloud profile, the CLI just logs in as that user. If not, a new cloud profile keyed off that username is saved so the next run reuses it.
23
+
24
+ `go` resolves which profile to use in this order:
25
+
26
+ 1. `--profile <name>` flag (or `RANGER_PROFILE` env var)
27
+ 2. The saved active profile (`ranger-cli profile use <name>`)
28
+ 3. `RANGER_TEST_USERNAME` (logs in as that user; reuses or creates the matching cloud profile)
29
+ 4. The org's only cloud profile, if exactly one exists
30
+
31
+ For pinned-session use (`RANGER_SESSION_STATE_PATH=/path/to/storageState.json`), the CLI uses that file directly and skips both cloud-side login and the `sessionDeps` freshness check.
12
32
 
13
33
  ## Required: Active Feature Review
14
34
 
@@ -41,7 +61,7 @@ You do NOT need to manually include reviewer feedback in your `--notes` descript
41
61
 
42
62
  | Option | Required | Description |
43
63
  |--------|----------|-------------|
44
- | `--profile` | No | Profile to use (defaults to active profile) |
64
+ | `--profile` | No | Profile to use. Equivalent to `RANGER_PROFILE` env var. Defaults to active profile, or to the user keyed by `RANGER_TEST_USERNAME` if set. |
45
65
  | `--notes` | No | What to verify (defaults to scenario description) |
46
66
  | `--scenario` | No | Scenario index to verify (skips selection prompt) |
47
67
  | `--start-path` | No | Path to start on (appended to base URL, e.g., `/dashboard`) |
@@ -182,7 +202,7 @@ Always end the conversational turn by sharing the dashboard link whenever you ru
182
202
  Run `ranger-cli list` to find feature reviews, then `ranger-cli resume <id>` to resume one.
183
203
 
184
204
  ### "No active profile"
185
- Run `ranger-cli profile use <profile-name>` to set a profile with browser access.
205
+ Either set `RANGER_TEST_USERNAME` (and `RANGER_TEST_PASSWORD` for first-time login) and re-run, or pin one explicitly with `ranger-cli profile use <profile-name>`.
186
206
 
187
207
  ### Verification times out
188
208
  The agent has 59 minutes max. For very long flows, break into smaller scenarios.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ranger-testing/ranger-cli",
3
- "version": "2.5.3",
3
+ "version": "2.5.4-alpha.1f7a251-7",
4
4
  "type": "module",
5
5
  "bin": {
6
6
  "ranger": "./build/cli.js",
@@ -12,7 +12,8 @@
12
12
  "obfuscate": "node scripts/obfuscate.cjs",
13
13
  "dev": "tsx src/cli.ts",
14
14
  "check-playwright-version": "node scripts/check-playwright-version.cjs",
15
- "postinstall": "node scripts/postinstall.js"
15
+ "postinstall": "node scripts/postinstall.js",
16
+ "test": "jest --config jest.config.cjs"
16
17
  },
17
18
  "files": [
18
19
  "build",
@@ -29,9 +30,12 @@
29
30
  },
30
31
  "devDependencies": {
31
32
  "@types/inquirer": "^9.0.7",
33
+ "@types/jest": "^29.5.0",
32
34
  "@types/node": "^22.0.0",
33
35
  "@types/yargs": "^17.0.32",
36
+ "jest": "^29.7.0",
34
37
  "javascript-obfuscator": "^4.1.1",
38
+ "ts-jest": "^29.1.0",
35
39
  "tsx": "^4.20.6",
36
40
  "typescript": "^5.0.0"
37
41
  },