@ranger-testing/ranger-cli 2.5.4-alpha.071b7bd-1 → 2.5.4-alpha.0e8b82c-9

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 +17 -3
  80. package/package.json +6 -2
@@ -1 +1 @@
1
- (function(_0xd11e83,_0x15ae2d){const _0xefe01c=_0x421c,_0xf2479b=_0xd11e83();while(!![]){try{const _0x223f50=parseInt(_0xefe01c(0x236))/0x1+-parseInt(_0xefe01c(0x1db))/0x2*(-parseInt(_0xefe01c(0x201))/0x3)+parseInt(_0xefe01c(0x234))/0x4+parseInt(_0xefe01c(0x252))/0x5*(parseInt(_0xefe01c(0x214))/0x6)+-parseInt(_0xefe01c(0x1f3))/0x7+-parseInt(_0xefe01c(0x20a))/0x8*(parseInt(_0xefe01c(0x262))/0x9)+-parseInt(_0xefe01c(0x22a))/0xa;if(_0x223f50===_0x15ae2d)break;else _0xf2479b['push'](_0xf2479b['shift']());}catch(_0x17199f){_0xf2479b['push'](_0xf2479b['shift']());}}}(_0x4b14,0x6c444));function _0x421c(_0x53d2b8,_0x3da4a8){_0x53d2b8=_0x53d2b8-0x1db;const _0x4b1465=_0x4b14();let _0x421c9f=_0x4b1465[_0x53d2b8];return _0x421c9f;}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 truncatePreview(_0x4ae1fa,_0x5c51ae=PLAYWRIGHT_CLI_PREVIEW_LIMIT){const _0x43bfbd=_0x421c,_0x32c443={'AardL':_0x43bfbd(0x1f7)};return _0x4ae1fa[_0x43bfbd(0x250)]>_0x5c51ae?_0x4ae1fa[_0x43bfbd(0x256)](0x0,_0x5c51ae)+_0x32c443[_0x43bfbd(0x1e7)]:_0x4ae1fa;}function buildCliArtifactPath(_0x2ece33,_0x1c06c9){return join(_0x2ece33,_0x1c06c9);}function toStepDisplayName(_0x220f6c){const _0x403843=_0x421c,_0x390d91={'QGakz':function(_0xbaea00,_0x52bf5d){return _0xbaea00(_0x52bf5d);}},_0x3494df=basename(_0x220f6c)[_0x403843(0x217)](/\.(?:png|ya?ml)$/i,'')[_0x403843(0x217)](/^key_/i,'')[_0x403843(0x217)](/^\d+_/,'')['replace'](/-/g,'\x20');return{'name':_0x3494df,'isKeyStep':/^key_/i[_0x403843(0x25c)](_0x390d91['QGakz'](basename,_0x220f6c))};}function extractShellValue(_0x2017f2){if(!_0x2017f2)return null;return _0x2017f2[0x1]??_0x2017f2[0x2]??_0x2017f2[0x3]??null;}function extractFilenameOption(_0x5af635){const _0x272bfd={'AjHkb':function(_0x2388bb,_0x1a46b7){return _0x2388bb(_0x1a46b7);}};return _0x272bfd['AjHkb'](extractShellValue,_0x5af635['match'](/--filename(?:=|\s+)(?:"([^"]+)"|'([^']+)'|(\S+))/));}function extractFirstCommandArgument(_0x419532,_0x11dbc6){const _0x12f785=_0x421c,_0x2aebc4={'hYxNc':function(_0x245246,_0x95f96e){return _0x245246(_0x95f96e);}},_0x24101a=_0x11dbc6[_0x12f785(0x217)](/[.*+?^${}()|[\]\\]/g,_0x12f785(0x206));return _0x2aebc4['hYxNc'](extractShellValue,_0x419532[_0x12f785(0x21b)](new RegExp('(?:^|\x5cs)'+_0x24101a+_0x12f785(0x25a))));}function formatCommandTarget(_0x42f9bf){const _0x1d1470=_0x421c,_0x5f3da8={'RInvV':function(_0x3b85c1,_0x5621a7,_0x1805a2){return _0x3b85c1(_0x5621a7,_0x1805a2);}};if(!_0x42f9bf)return'target';if(/^e\d+$/i['test'](_0x42f9bf))return _0x1d1470(0x24a)+_0x42f9bf;return JSON[_0x1d1470(0x253)](_0x5f3da8[_0x1d1470(0x212)](truncatePreview,_0x42f9bf,0x78));}function formatPlaywrightCliLog(_0x5f1f3b,_0x4b4b55){const _0x429863=_0x421c,_0xbd108c={'eViEb':function(_0x1b84f4,_0x596512,_0x56f1c4){return _0x1b84f4(_0x596512,_0x56f1c4);},'CyCdd':_0x429863(0x241),'wcPxN':_0x429863(0x202),'BoGjY':_0x429863(0x224),'abuMp':'stop\x20tracing','hFvBM':_0x429863(0x242),'wrrGE':'stop\x20video\x20recording','mJHlu':function(_0x270432,_0x1942fd){return _0x270432(_0x1942fd);},'difUh':_0x429863(0x259),'sugri':function(_0x290d03,_0x3f1d6f){return _0x290d03(_0x3f1d6f);},'HKCCX':'click','GTqtp':function(_0x4e6cb9,_0x2d8b22){return _0x4e6cb9(_0x2d8b22);},'JWnlE':_0x429863(0x1dc),'NkkLF':function(_0x36062a,_0x162779,_0x245b0f){return _0x36062a(_0x162779,_0x245b0f);},'YZoPE':function(_0x1418e7,_0x4d75bd){return _0x1418e7(_0x4d75bd);},'HIlpu':'tab-new','GOBFX':'select\x20tab'};switch(_0x4b4b55){case'open':{const _0x391a52=_0xbd108c[_0x429863(0x226)](extractFirstCommandArgument,_0x5f1f3b,_0x4b4b55);return _0x391a52?_0x429863(0x1ef)+_0x391a52:_0x429863(0x229);}case _0xbd108c['CyCdd']:return _0xbd108c['wcPxN'];case _0xbd108c['BoGjY']:return _0xbd108c[_0x429863(0x1f2)];case'video-start':return'start\x20video\x20recording';case _0xbd108c['hFvBM']:return _0xbd108c[_0x429863(0x209)];case _0x429863(0x25e):{const _0x15e8db=extractFilenameOption(_0x5f1f3b);if(!_0x15e8db)return'capture\x20snapshot';const {name:_0x328184}=_0xbd108c['mJHlu'](toStepDisplayName,_0x15e8db);return'capture\x20snapshot\x20`'+_0x328184+'`';}case _0xbd108c[_0x429863(0x203)]:{const _0x146c6f=_0xbd108c['mJHlu'](extractFilenameOption,_0x5f1f3b);if(!_0x146c6f)return'capture\x20screenshot';const {name:_0x28f17d,isKeyStep:_0x1f44d0}=_0xbd108c[_0x429863(0x20b)](toStepDisplayName,_0x146c6f);return _0x1f44d0?_0x429863(0x219)+_0x28f17d+'`':_0x429863(0x247)+_0x28f17d+'`';}case _0xbd108c['HKCCX']:return _0x429863(0x22e)+_0xbd108c['GTqtp'](formatCommandTarget,extractFirstCommandArgument(_0x5f1f3b,_0x4b4b55));case'check':return _0x429863(0x1ec)+formatCommandTarget(_0xbd108c[_0x429863(0x226)](extractFirstCommandArgument,_0x5f1f3b,_0x4b4b55));case _0xbd108c['JWnlE']:return'fill\x20'+formatCommandTarget(_0xbd108c[_0x429863(0x216)](extractFirstCommandArgument,_0x5f1f3b,_0x4b4b55));case'press':return _0x429863(0x22d)+_0xbd108c[_0x429863(0x255)](formatCommandTarget,_0xbd108c['eViEb'](extractFirstCommandArgument,_0x5f1f3b,_0x4b4b55));case _0x429863(0x211):return _0x429863(0x23a);case _0xbd108c[_0x429863(0x218)]:{const _0x561f6c=extractFirstCommandArgument(_0x5f1f3b,_0x4b4b55);return _0x561f6c?'open\x20new\x20tab\x20'+_0x561f6c:_0x429863(0x249);}case'tab-select':{const _0x13b7fd=_0xbd108c[_0x429863(0x226)](extractFirstCommandArgument,_0x5f1f3b,_0x4b4b55);return _0x13b7fd?'select\x20tab\x20'+_0x13b7fd:_0xbd108c['GOBFX'];}default:return _0x4b4b55;}}function extractPlaywrightCliToolDescription(_0x11adf7){const _0x2b8b64=_0x421c,_0x185804=_0x11adf7['description'];if(typeof _0x185804!=='string')return null;const _0x55760a=_0x185804[_0x2b8b64(0x1fb)]()['replace'](/\s+/g,'\x20');return _0x55760a[_0x2b8b64(0x250)]>0x0?_0x55760a:null;}export function formatPlaywrightCliConsoleLogMessage(_0x330311,_0x421f1c,_0xc49bad){const _0xa6b3e9=_0x421c,_0x9496d4={'PHjYA':function(_0x1925bf,_0x4d33c4,_0x180b41){return _0x1925bf(_0x4d33c4,_0x180b41);}},_0x1a40eb=_0x9496d4['PHjYA'](formatPlaywrightCliLog,_0x421f1c,_0xc49bad),_0xbc5552=extractPlaywrightCliToolDescription(_0x330311);if(!_0xbc5552)return _0xa6b3e9(0x20f)+_0x1a40eb;if(process['env'][_0xa6b3e9(0x263)])return'[ranger-verification-agent]\x20'+_0xbc5552+'\x20('+_0x1a40eb+')';return'[ranger-verification-agent]\x20'+_0xbc5552;}export function buildVerifyFeatureCliDebugPrompt(_0x2cd93c,_0x5e4d99){const _0x4012f8=_0x421c,_0x3a88f4={'NJzvX':'00_mozilla-homepage.yml','dSXSO':function(_0x4ba7cf,_0x3428ba,_0x1c2026){return _0x4ba7cf(_0x3428ba,_0x1c2026);},'kliHt':'02_learn-more.yml','qldKC':function(_0x1082a8,_0x2225f4,_0xdc59b3){return _0x1082a8(_0x2225f4,_0xdc59b3);},'KKNuy':function(_0x1506da,_0x4b2f65){return _0x1506da(_0x4b2f65);}},_0x2bf79e=buildCliArtifactPath(_0x5e4d99,_0x3a88f4['NJzvX']),_0x3f4ee7=_0x3a88f4['dSXSO'](buildCliArtifactPath,_0x5e4d99,_0x4012f8(0x23d)),_0x597d25=_0x3a88f4[_0x4012f8(0x221)](buildCliArtifactPath,_0x5e4d99,_0x3a88f4[_0x4012f8(0x1f0)]),_0x31c989=_0x3a88f4['qldKC'](buildCliArtifactPath,_0x5e4d99,_0x4012f8(0x215)),_0x7e0e03=quoteShellArg(_0x2bf79e),_0x51db0d=quoteShellArg(_0x3f4ee7),_0x3578c7=quoteShellArg(_0x597d25),_0x55fa23=_0x3a88f4['KKNuy'](quoteShellArg,_0x31c989);return'You\x20are\x20testing\x20browser\x20automation.\x20Your\x20task\x20is\x20simple:\x0a\x0aUse\x20Bash\x20and\x20Playwright\x20CLI\x20only.\x20The\x20browser\x20command\x20prefix\x20is:\x0a'+_0x2cd93c+'\x0a\x0a1.\x20Run\x20`'+_0x2cd93c+_0x4012f8(0x248)+_0x2cd93c+_0x4012f8(0x1e6)+_0x2cd93c+_0x4012f8(0x1e9)+_0x5e4d99+'`\x20using\x20absolute\x20paths\x20only.\x20Do\x20not\x20use\x20relative\x20filenames.\x0a5.\x20Run\x20`'+_0x2cd93c+'\x20snapshot\x20--filename\x20'+_0x7e0e03+'`\x0a5.\x20Read\x20the\x20snapshot\x20file\x20to\x20find\x20the\x20\x22Learn\x20More\x22\x20link\x20reference\x0a6.\x20Run\x20`'+_0x2cd93c+'\x20screenshot\x20--filename\x20'+_0x51db0d+_0x4012f8(0x205)+_0x2cd93c+'\x20snapshot\x20--filename\x20'+_0x3578c7+'`\x0a9.\x20Run\x20`'+_0x2cd93c+_0x4012f8(0x1e3)+_0x55fa23+_0x4012f8(0x235);}export function buildVerifyFeatureCliPrompt(_0x2eeba0){const _0x855f08=_0x421c,_0x328faf={'mJjWl':'en-US','MIRJy':'numeric','aZGhJ':_0x855f08(0x222),'xUGaS':_0x855f08(0x246),'HiRXK':'02_state.yml','rzYcE':'key_03_success-state.png','NobEc':function(_0x3e7174,_0x58889f){return _0x3e7174(_0x58889f);},'hjSCk':function(_0x381e2e,_0x15016c,_0x5a07dd){return _0x381e2e(_0x15016c,_0x5a07dd);},'WMgyu':_0x855f08(0x213)},{checklistItem:_0x138d56,itemFeedback:_0x499db7,taskDescription:_0x446a51,cliCommandPrefix:_0x4a3043,cliArtifactDir:_0x280fff,isCdpMode:_0x2fca04,url:_0x44305f,cdpEndpoint:_0x57b378,loginInstructions:_0x4de534}=_0x2eeba0,_0x3b1d52=buildCliArtifactPath(_0x280fff,_0x328faf['xUGaS']),_0x2bd3cc=buildCliArtifactPath(_0x280fff,_0x328faf[_0x855f08(0x1e0)]),_0x546799=buildCliArtifactPath(_0x280fff,_0x328faf[_0x855f08(0x21e)]),_0xaf980c=buildCliArtifactPath(_0x280fff,_0x855f08(0x233)),_0x4dbc7d=_0x328faf[_0x855f08(0x227)](quoteShellArg,_0x3b1d52),_0x475d71=quoteShellArg(_0x2bd3cc),_0x4f16e0=_0x328faf[_0x855f08(0x227)](quoteShellArg,_0x546799),_0x337c8a=quoteShellArg(_0xaf980c),_0x4dd92c=_0x138d56[_0x855f08(0x22c)]?_0x855f08(0x264)+_0x138d56['notes']:'';let _0x1f7c11='';if(_0x499db7&&_0x499db7[_0x855f08(0x1f8)]['length']>0x0){const _0x1ce249=_0x499db7[_0x855f08(0x1f8)]['map'](_0x4eb8e2=>{const _0x5f0eed=_0x855f08,_0x57d76d=new Date(_0x4eb8e2[_0x5f0eed(0x230)])[_0x5f0eed(0x21f)](_0x328faf['mJjWl'],{'month':'short','day':_0x328faf['MIRJy']}),_0x5079e5=_0x4eb8e2[_0x5f0eed(0x20e)]||_0x4eb8e2[_0x5f0eed(0x207)]||_0x5f0eed(0x260),_0x3e0c16=_0x4eb8e2[_0x5f0eed(0x210)]?'\x20(on\x20element:\x20<'+(_0x4eb8e2['domRef'][_0x5f0eed(0x1fd)]['split'](_0x328faf['aZGhJ'])['pop']()?.[_0x5f0eed(0x1ea)](':')[0x0]||'element')+_0x5f0eed(0x237)+(_0x4eb8e2[_0x5f0eed(0x210)]['textContent']||'')[_0x5f0eed(0x256)](0x0,0x32)+'\x22)':'';return _0x5f0eed(0x23f)+_0x4eb8e2['id']+_0x5f0eed(0x21c)+_0x5079e5+'**\x20('+_0x57d76d+_0x5f0eed(0x22b)+_0x4eb8e2[_0x5f0eed(0x200)]+'\x22'+_0x3e0c16;})['join']('\x0a');_0x1f7c11='\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'+_0x1ce249;}const _0x27fd2a=_0x499db7?.['canonicalFlow']?_0x855f08(0x225)+_0x499db7[_0x855f08(0x267)]:'',_0x1faa28=_0x2fca04?_0x855f08(0x208)+_0x57b378+'.\x0aThis\x20is\x20NOT\x20a\x20web\x20app\x20—\x20there\x20is\x20no\x20URL\x20to\x20navigate\x20to.\x20The\x20app\x20is\x20already\x20running\x20and\x20connected.':_0x855f08(0x23c)+_0x44305f+_0x855f08(0x1dd),_0x352c44=_0x44305f?quoteShellArg(_0x44305f):'',_0x205686=_0x2fca04?_0x855f08(0x22f)+_0x4a3043+_0x855f08(0x220)+_0x4a3043+_0x855f08(0x1ed)+_0x4a3043+_0x855f08(0x1f6)+_0x280fff+_0x855f08(0x25d)+_0x4a3043+_0x855f08(0x24d)+_0x4dbc7d+'`\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`'+_0x4a3043+'\x20screenshot\x20--filename\x20'+_0x337c8a+_0x855f08(0x1f5)+_0x4a3043+_0x855f08(0x20d):_0x855f08(0x22f)+_0x4a3043+_0x855f08(0x24f)+_0x352c44+_0x855f08(0x24b)+_0x4a3043+_0x855f08(0x1ed)+_0x4a3043+_0x855f08(0x1f6)+_0x280fff+_0x855f08(0x25d)+_0x4a3043+_0x855f08(0x24d)+_0x4dbc7d+_0x855f08(0x1fe)+_0x4a3043+_0x855f08(0x1e3)+_0x337c8a+'`\x20style\x20absolute\x20paths\x20at\x20key\x20moments.\x0a8.\x20If\x20you\x20need\x20waits\x20or\x20custom\x20assertions,\x20use\x20`'+_0x4a3043+_0x855f08(0x1e5),_0x4f3138=_0x2fca04?'\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.':_0x855f08(0x251),_0x353496=_0x4de534?'\x0a\x0a##\x20Authentication\x0aBEFORE\x20starting\x20the\x20verification\x20task,\x20you\x20MUST\x20authenticate\x20using\x20these\x20steps:\x0a'+_0x4de534+_0x855f08(0x1f1):'';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'+_0x138d56['description']+_0x4dd92c+_0x1f7c11+_0x27fd2a+'\x0a\x0a##\x20Task\x20to\x20Execute\x0a'+_0x446a51+'\x0a\x0a'+_0x1faa28+_0x353496+'\x0a\x0a'+_0x205686+_0x855f08(0x261)+_0x4a3043+'`\x0a\x0a-\x20Write\x20all\x20artifacts\x20under\x20`'+_0x280fff+'`\x0a-\x20`snapshot\x20--filename\x20'+_0x475d71+'`\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'+_0x4f16e0+'`\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`'+_0x280fff+_0x855f08(0x20c)+_0xaf980c+_0x855f08(0x23e)+_0x328faf[_0x855f08(0x1df)](buildCliArtifactPath,_0x280fff,_0x855f08(0x231))+'\x22,\x20\x22'+_0x328faf[_0x855f08(0x1df)](buildCliArtifactPath,_0x280fff,_0x328faf['WMgyu'])+'\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(_0x280fff,_0x855f08(0x1ee))+'\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'+_0x4f3138+_0x855f08(0x269);}export function summarizeVerifyFeatureCliCommandAvailability(_0x3a6501){const _0x4b7f5e=_0x421c,_0x173a87={'ryQUk':function(_0x5b4b05,_0x1af4c){return _0x5b4b05===_0x1af4c;}},_0x39480b=[..._0x3a6501[_0x4b7f5e(0x1e1)]()]['sort']();let _0x2f1759=0x0;for(const _0x199503 of _0x3a6501['values']()){_0x2f1759+=_0x199503;}return{'cliCommandCount':_0x2f1759,'cliCommandsSeen':_0x39480b,'noCliCommandsCalled':_0x173a87[_0x4b7f5e(0x243)](_0x2f1759,0x0)};}export function createVerifyFeatureCliHooks(_0x2ff677){const _0x409505=_0x421c,_0x2fdd3b={'fXPOS':'PostToolUse','GRqUW':function(_0x8a3b57,_0x1c944c){return _0x8a3b57+_0x1c944c;},'oMvkC':_0x409505(0x1e8),'OztzJ':'tool_call','zanNQ':function(_0x210dcd,_0x367815){return _0x210dcd(_0x367815);},'zMWqz':function(_0x470e6d,_0x3c1130){return _0x470e6d!==_0x3c1130;},'tuNWa':_0x409505(0x254),'prktP':function(_0x4a4411,_0x2ab1cd){return _0x4a4411!==_0x2ab1cd;},'yivVb':'Bash'},_0x4c23a2=new Map(),_0xd2e6e5=async _0x39f49f=>{const _0x48ff8c=_0x409505;if(_0x39f49f['hook_event_name']!==_0x2fdd3b['fXPOS'])return{};const _0x43d23d=_0x39f49f;if(_0x43d23d[_0x48ff8c(0x232)]!=='Bash')return{};const _0x4a6224=_0x43d23d[_0x48ff8c(0x1eb)],_0x586c39=extractBashCommand(_0x4a6224);if(!_0x586c39)return{};const _0x8748d3=parsePlaywrightCliCommand(_0x586c39);if(!_0x8748d3)return{};return _0x4c23a2['set'](_0x8748d3,_0x2fdd3b['GRqUW'](_0x4c23a2[_0x48ff8c(0x24c)](_0x8748d3)||0x0,0x1)),_0x2ff677[_0x48ff8c(0x258)]('tool_call',{'transport':_0x2fdd3b[_0x48ff8c(0x1fa)],'toolName':_0x8748d3}),_0x2ff677['trackPhaseEnd'](_0x2fdd3b[_0x48ff8c(0x1e4)],{'transport':_0x2fdd3b[_0x48ff8c(0x1fa)],'toolName':_0x8748d3,'bashCommandPreview':_0x2fdd3b['zanNQ'](truncatePreview,_0x586c39)}),_0x2fdd3b[_0x48ff8c(0x240)](_0x8748d3,_0x48ff8c(0x25e))&&console[_0x48ff8c(0x24e)](formatPlaywrightCliConsoleLogMessage(_0x4a6224,_0x586c39,_0x8748d3)),{};},_0xc212b1=async _0x5695f4=>{const _0x454796=_0x409505;if(_0x5695f4['hook_event_name']!==_0x2fdd3b['tuNWa'])return{};const _0x11d029=_0x5695f4;if(_0x2fdd3b[_0x454796(0x21a)](_0x11d029[_0x454796(0x232)],_0x2fdd3b[_0x454796(0x239)]))return{};return await _0x2ff677['trackPhaseError']('tool_failure',_0x11d029['error'],{'transport':_0x2fdd3b['oMvkC'],'toolName':_0x454796(0x245)}),{};};return{'postToolUseHook':_0xd2e6e5,'postToolUseFailureHook':_0xc212b1,'commandCounts':_0x4c23a2};}async function runPlaywrightCliLifecycleCommand(_0x3a13a7){const _0x189831=_0x421c,_0x4dbc5d={'vasrE':function(_0x5e0935,_0x3892bc){return _0x5e0935(_0x3892bc);},'nshha':function(_0x2e5498,_0x14508c){return _0x2e5498??_0x14508c;}},{sessionId:_0x20e57c,configPath:_0x17a60e,commandArgs:_0x1aafac,env:_0x12e0e9,telemetry:_0xb3829b,phase:_0x3635a3,metadata:_0x18d2b3,timeoutMs:_0x1ad3c4}=_0x3a13a7;_0xb3829b['trackPhaseStart'](_0x3635a3,_0x18d2b3);try{const _0x5edfb5=await _0x4dbc5d[_0x189831(0x1f9)](runPlaywrightCliCommand,{'sessionId':_0x20e57c,'configPath':_0x17a60e,'commandArgs':_0x1aafac,'cwd':process[_0x189831(0x21d)](),'env':_0x12e0e9,'timeoutMs':_0x4dbc5d[_0x189831(0x268)](_0x1ad3c4,PLAYWRIGHT_CLI_COMMAND_TIMEOUT_MS)});_0xb3829b[_0x189831(0x244)](_0x3635a3,{..._0x18d2b3,'subcommand':_0x5edfb5[_0x189831(0x25b)]['subcommand'],'stdoutPreview':truncatePreview(_0x5edfb5[_0x189831(0x25f)],0x7d0),'stderrPreview':truncatePreview(_0x5edfb5['stderr'],0x7d0)});}catch(_0x41c1ac){await _0xb3829b[_0x189831(0x228)](_0x3635a3,_0x41c1ac,_0x18d2b3);throw _0x41c1ac;}}export async function finalizeVerifyFeatureCliSession(_0x518d7a){const _0x485f9a=_0x421c,_0xe0ce07={'VAhSX':'playwright_cli_tracing_stop','cFIdj':'tracing-stop','FJEzu':function(_0x32661c,_0x4108ce,_0x45f8e7){return _0x32661c(_0x4108ce,_0x45f8e7);},'vNGoq':'session-recording.webm','BYpqX':_0x485f9a(0x223)},{telemetry:_0x100986,sessionId:_0x1cde0e,configPath:_0x5aa928,cliArtifactDir:_0x38d66e,env:_0x290dea,transportMetadata:_0x3c3807}=_0x518d7a,_0x7370d2=[{'phase':_0xe0ce07['VAhSX'],'commandArgs':[_0xe0ce07['cFIdj']]},{'phase':_0x485f9a(0x1fc),'commandArgs':[_0x485f9a(0x242),_0x485f9a(0x1de)+_0xe0ce07['FJEzu'](buildCliArtifactPath,_0x38d66e,_0xe0ce07['vNGoq'])]},{'phase':_0xe0ce07[_0x485f9a(0x238)],'commandArgs':[_0x485f9a(0x23b)]}];for(const _0x3079cf of _0x7370d2){try{await runPlaywrightCliLifecycleCommand({'sessionId':_0x1cde0e,'configPath':_0x5aa928,'commandArgs':[..._0x3079cf[_0x485f9a(0x1f4)]],'env':_0x290dea,'telemetry':_0x100986,'phase':_0x3079cf[_0x485f9a(0x1e2)],'metadata':_0x3c3807});}catch{}}}export async function loadVerifyFeatureCliTraceUploadArtifact(_0x466571){const _0x392640={'rhGXr':'trace.zip','fHOXv':'trace.trace.zip','bHoVn':function(_0x261e63,_0x5a7c24,_0x4c5508){return _0x261e63(_0x5a7c24,_0x4c5508);}},_0x257ea5=[_0x392640['rhGXr'],_0x392640['fHOXv']];for(const _0x26b145 of _0x257ea5){const _0x42b4d5=_0x392640['bHoVn'](join,_0x466571,_0x26b145);try{return{'buffer':await readFile(_0x42b4d5),'source':_0x42b4d5};}catch{}}return null;}export async function rehomeVerifyFeatureCliArtifacts(_0xfefd80){const _0x2b75f1=_0x421c,_0x57e1aa={'ufnsj':function(_0x315e63,_0x1334f7,_0x3d0743){return _0x315e63(_0x1334f7,_0x3d0743);},'RNRnS':function(_0x410649,_0x79912a){return _0x410649(_0x79912a);},'Ylykl':function(_0x266dda,_0x5a8930){return _0x266dda<_0x5a8930;}},{cwd:_0xdddfc1,cliArtifactDir:_0x17f1a6,startTime:_0x5107e2}=_0xfefd80,_0x25eec7=[];await _0x57e1aa['ufnsj'](mkdir,_0x17f1a6,{'recursive':!![]});const _0x2e1ce9=await readdir(_0xdddfc1,{'withFileTypes':!![]});for(const _0x5b0f28 of _0x2e1ce9){if(!_0x5b0f28['isFile']()||!VERIFY_FEATURE_CLI_ARTIFACT_FILE_PATTERN[_0x2b75f1(0x25c)](_0x5b0f28[_0x2b75f1(0x1ff)]))continue;const _0x1b0707=_0x57e1aa[_0x2b75f1(0x257)](join,_0xdddfc1,_0x5b0f28[_0x2b75f1(0x1ff)]),_0x36bd4b=await _0x57e1aa['RNRnS'](stat,_0x1b0707);if(_0x57e1aa['Ylykl'](_0x36bd4b[_0x2b75f1(0x266)]+0x7d0,_0x5107e2))continue;const _0x2abc9b=buildCliArtifactPath(_0x17f1a6,_0x5b0f28['name']);if(_0x1b0707===_0x2abc9b)continue;await rename(_0x1b0707,_0x2abc9b),_0x25eec7[_0x2b75f1(0x265)](_0x5b0f28['name']);}return _0x25eec7[_0x2b75f1(0x204)]();}function _0x4b14(){const _0x3b85f3=['open\x20new\x20tab','ref\x20','`,\x20then\x20`','get','\x20snapshot\x20--filename\x20','log','\x20open\x20','length','\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.','178015UqEsWi','stringify','PostToolUseFailure','YZoPE','slice','ufnsj','trackPhaseStart','screenshot','(?:\x5cs+(?:\x22([^\x22]+)\x22|\x27([^\x27]+)\x27|(\x5cS+)))','invocation','test','`\x20using\x20absolute\x20paths\x20only.\x20Do\x20not\x20use\x20relative\x20filenames.\x0a4.\x20Take\x20a\x20snapshot\x20with\x20`','snapshot','stdout','Reviewer','\x0a\x0a##\x20Browser\x20Command\x20Reference\x0aUse\x20Bash\x20to\x20run\x20Playwright\x20CLI\x20commands\x20with\x20this\x20exact\x20prefix:\x0a`','36uwnvfE','DEBUG','\x0a\x0a##\x20Additional\x20Notes\x0a','push','mtimeMs','canonicalFlow','nshha','\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.','4YSKrBN','fill','\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','--filename=','hjSCk','HiRXK','keys','phase','\x20screenshot\x20--filename\x20','OztzJ','\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','\x20tracing-start`\x0a3.\x20Run\x20`','AardL','playwright-cli','\x20video-start`\x0a4.\x20Save\x20every\x20snapshot\x20and\x20screenshot\x20under\x20`','split','tool_input','check\x20','\x20tracing-start`,\x20then\x20`','key_04_success-state.png','open\x20','kliHt','\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.','abuMp','757001KVDDyg','commandArgs','`\x20style\x20absolute\x20paths\x20at\x20key\x20moments.\x0a6.\x20If\x20you\x20need\x20waits\x20or\x20custom\x20assertions,\x20use\x20`','\x20video-start`.\x0a3.\x20Save\x20every\x20snapshot\x20and\x20screenshot\x20under\x20`','...','unaddressedComments','vasrE','oMvkC','trim','playwright_cli_video_stop','selector','`\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`','name','content','215814bgACYq','start\x20tracing','difUh','sort','`\x0a7.\x20Click\x20the\x20\x22Learn\x20More\x22\x20link\x20with\x20Playwright\x20CLI\x0a8.\x20Run\x20`','\x5c$&','authorEmail','##\x20App\x20Context\x0aYou\x20are\x20connected\x20to\x20a\x20desktop\x20application\x20via\x20CDP\x20(Chrome\x20DevTools\x20Protocol)\x20at\x20','wrrGE','1331392XGxIjT','sugri','`:\x20\x22','\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','authorName','[playwright-cli]\x20','domRef','run-code','RInvV','03_result-visible.png','18iSCRNY','03_learn-more.png','NkkLF','replace','HIlpu','capture\x20key\x20step\x20`','prktP','match',']\x20**','cwd','rzYcE','toLocaleDateString','\x20open`,\x20then\x20`','dSXSO','\x20>\x20','playwright_cli_close','tracing-stop','\x0a\x0a##\x20Expected\x20Flow\x20(from\x20previous\x20verification)\x0a','eViEb','NobEc','trackPhaseError','open\x20browser','1895590gVHZHK','):\x20\x22','notes','press\x20','click\x20','##\x20Instructions\x0a1.\x20Use\x20Bash\x20plus\x20Playwright\x20CLI\x20only.\x20Do\x20NOT\x20call\x20MCP\x20browser\x20tools.\x0a2.\x20Start\x20by\x20running\x20`','createdAt','02_button-clicked.png','tool_name','01_initial-state.png','3427856ldVuRJ','`\x0a10.\x20Return\x20immediately\x20with\x20the\x20structured\x20output\x0a\x0aReturn\x20your\x20findings\x20in\x20the\x20structured\x20output\x20format.','299209HnGfnn','>\x20\x22','BYpqX','yivVb','run\x20custom\x20Playwright\x20code','close','CRITICAL\x20URL\x20REQUIREMENT:\x0aYour\x20base\x20URL\x20is:\x20','01_mozilla-homepage.png','\x22,\x20\x22','-\x20[','zMWqz','tracing-start','video-stop','ryQUk','trackPhaseEnd','Bash','01_initial.yml','capture\x20step\x20`','\x20open\x20https://www.mozilla.org`\x0a2.\x20Run\x20`'];_0x4b14=function(){return _0x3b85f3;};return _0x4b14();}
1
+ (function(_0x4672dc,_0x5f2ced){const _0x442b53=_0x3ff2,_0x4a7578=_0x4672dc();while(!![]){try{const _0x5f2f5d=parseInt(_0x442b53(0x186))/0x1+-parseInt(_0x442b53(0x1c0))/0x2+parseInt(_0x442b53(0x176))/0x3+parseInt(_0x442b53(0x1c9))/0x4*(-parseInt(_0x442b53(0x17e))/0x5)+parseInt(_0x442b53(0x1b0))/0x6*(parseInt(_0x442b53(0x17d))/0x7)+-parseInt(_0x442b53(0x1c8))/0x8+parseInt(_0x442b53(0x1df))/0x9;if(_0x5f2f5d===_0x5f2ced)break;else _0x4a7578['push'](_0x4a7578['shift']());}catch(_0x28303b){_0x4a7578['push'](_0x4a7578['shift']());}}}(_0x12e1,0xd78bc));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 truncatePreview(_0x4c70e0,_0x5a68a4=PLAYWRIGHT_CLI_PREVIEW_LIMIT){const _0x50a598=_0x3ff2,_0x2062d0={'skzFf':'...'};return _0x4c70e0[_0x50a598(0x1a6)]>_0x5a68a4?_0x4c70e0['slice'](0x0,_0x5a68a4)+_0x2062d0['skzFf']:_0x4c70e0;}function _0x12e1(){const _0x29c67b=['target','75414ZiNBWo','bYwcq','open\x20new\x20tab\x20','authorEmail','trim','`\x20using\x20absolute\x20paths\x20only.\x20Do\x20not\x20use\x20relative\x20filenames.\x0a4.\x20Take\x20a\x20snapshot\x20with\x20`','ABUzo','7yKUKTK','5ZBSygp','authorName','hook_event_name','trackPhaseStart','map','\x20video-start`\x0a4.\x20Save\x20every\x20snapshot\x20and\x20screenshot\x20under\x20`','-\x20[','01_initial-state.png','1413524eLYaOr','GHovm','name','02_state.yml','[playwright-cli]\x20','phase','qiWSC','tool_failure','test','`\x0a\x0a-\x20Write\x20all\x20artifacts\x20under\x20`','close','unaddressedComments','\x20snapshot\x20--filename\x20','stdout','toLocaleDateString','content','\x20(on\x20element:\x20<','mtimeMs','trace.trace.zip','video-stop','IslIs','invocation','`\x0a7.\x20Click\x20the\x20\x22Learn\x20More\x22\x20link\x20with\x20Playwright\x20CLI\x0a8.\x20Run\x20`','\x20screenshot\x20--filename\x20','\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.','PostToolUse','createdAt','Reviewer','\x0a\x0a##\x20Authentication\x0aBEFORE\x20starting\x20the\x20verification\x20task,\x20you\x20MUST\x20authenticate\x20using\x20these\x20steps:\x0a','\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','snapshot','##\x20Instructions\x0a1.\x20Use\x20Bash\x20plus\x20Playwright\x20CLI\x20only.\x20Do\x20NOT\x20call\x20MCP\x20browser\x20tools.\x0a2.\x20Start\x20by\x20running\x20`','length','DMgpM','\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','vaPmy','FJwEV','kfOyf','\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','\x20video-start`.\x0a3.\x20Save\x20every\x20snapshot\x20and\x20screenshot\x20under\x20`','`\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','match','7634286YtESEw','EAddq','select\x20tab','BrRzw','00_mozilla-homepage.yml','pjHca','`\x0a-\x20`snapshot\x20--filename\x20','gQCSC','MDswe','open','WiLHh','Bash','values','XtMEB','tab-new','`\x20style\x20absolute\x20paths\x20at\x20key\x20moments.\x0a6.\x20If\x20you\x20need\x20waits\x20or\x20custom\x20assertions,\x20use\x20`','3080854rYRGro','key_04_success-state.png','run-code','trackPhaseEnd','dZGhq','`\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`','\x0a\x0a##\x20Task\x20to\x20Execute\x0a','\x20open\x20https://www.mozilla.org`\x0a2.\x20Run\x20`','11424744poawBJ','1497196kgAlvV','sAZMj','open\x20new\x20tab','vYaqq','cwd','--filename=','domRef','fill','Vzbee','tracing-start','replace','tool_call','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','sort','capture\x20step\x20`','nOSMx','02_button-clicked.png','\x0a\x0a##\x20Expected\x20Flow\x20(from\x20previous\x20verification)\x0a','`\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`','keys','MZcFZ','You\x20are\x20testing\x20browser\x20automation.\x20Your\x20task\x20is\x20simple:\x0a\x0aUse\x20Bash\x20and\x20Playwright\x20CLI\x20only.\x20The\x20browser\x20command\x20prefix\x20is:\x0a','13631868pqPqGQ','`\x20style\x20absolute\x20paths\x20at\x20key\x20moments.\x0a8.\x20If\x20you\x20need\x20waits\x20or\x20custom\x20assertions,\x20use\x20`','\x20tracing-start`\x0a3.\x20Run\x20`','dOIqJ','`\x0a9.\x20Run\x20`','fmxeg','HrIrm',']\x20**','`\x20using\x20absolute\x20paths\x20only.\x20Do\x20not\x20use\x20relative\x20filenames.\x0a5.\x20Run\x20`','get','short','playwright_cli_tracing_stop','open\x20browser','\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.','prlby','[ranger-verification-agent]\x20','\x0a\x0a##\x20Browser\x20Command\x20Reference\x0aUse\x20Bash\x20to\x20run\x20Playwright\x20CLI\x20commands\x20with\x20this\x20exact\x20prefix:\x0a`','check','01_mozilla-homepage.png','capture\x20key\x20step\x20`','tqpAf','Audce','error','\x20open\x20','run\x20custom\x20Playwright\x20code','pop','WJKJz','##\x20App\x20Context\x0aYou\x20are\x20connected\x20to\x20a\x20desktop\x20application\x20via\x20CDP\x20(Chrome\x20DevTools\x20Protocol)\x20at\x20','SKLac','subcommand','start\x20tracing','MlyLS','select\x20tab\x20','split','trackPhaseError','02_learn-more.yml'];_0x12e1=function(){return _0x29c67b;};return _0x12e1();}function buildCliArtifactPath(_0x36b67a,_0x29c404){return join(_0x36b67a,_0x29c404);}function toStepDisplayName(_0x1e193e){const _0x4fc715=_0x3ff2,_0x5e04fb=basename(_0x1e193e)['replace'](/\.(?:png|ya?ml)$/i,'')['replace'](/^key_/i,'')['replace'](/^\d+_/,'')[_0x4fc715(0x1d3)](/-/g,'\x20');return{'name':_0x5e04fb,'isKeyStep':/^key_/i[_0x4fc715(0x18e)](basename(_0x1e193e))};}function extractShellValue(_0x4d72e8){if(!_0x4d72e8)return null;return _0x4d72e8[0x1]??_0x4d72e8[0x2]??_0x4d72e8[0x3]??null;}function extractFilenameOption(_0x371187){const _0x2935cc=_0x3ff2,_0x150db9={'MDswe':function(_0x2b6e07,_0x3e03a6){return _0x2b6e07(_0x3e03a6);}};return _0x150db9[_0x2935cc(0x1b8)](extractShellValue,_0x371187['match'](/--filename(?:=|\s+)(?:"([^"]+)"|'([^']+)'|(\S+))/));}function extractFirstCommandArgument(_0x280781,_0x41dadb){const _0x3a3d75=_0x3ff2,_0x3417ad=_0x41dadb[_0x3a3d75(0x1d3)](/[.*+?^${}()|[\]\\]/g,'\x5c$&');return extractShellValue(_0x280781[_0x3a3d75(0x1af)](new RegExp('(?:^|\x5cs)'+_0x3417ad+'(?:\x5cs+(?:\x22([^\x22]+)\x22|\x27([^\x27]+)\x27|(\x5cS+)))')));}function formatCommandTarget(_0x502f77){const _0x5a7793=_0x3ff2,_0x464b37={'bYwcq':_0x5a7793(0x175),'tqpAf':function(_0x2c78c0,_0x23cf91,_0x4aa7fd){return _0x2c78c0(_0x23cf91,_0x4aa7fd);}};if(!_0x502f77)return _0x464b37[_0x5a7793(0x177)];if(/^e\d+$/i['test'](_0x502f77))return'ref\x20'+_0x502f77;return JSON['stringify'](_0x464b37[_0x5a7793(0x1f3)](truncatePreview,_0x502f77,0x78));}function formatPlaywrightCliLog(_0x4752a8,_0x5c4a87){const _0x248a8c=_0x3ff2,_0x53122d={'nOSMx':function(_0x4f2871,_0x56ca67,_0x227b53){return _0x4f2871(_0x56ca67,_0x227b53);},'tEMgD':_0x248a8c(0x1eb),'XtMEB':_0x248a8c(0x16f),'GHovm':'stop\x20tracing','qiWSC':'video-start','FJwEV':'start\x20video\x20recording','MlyLS':'video-stop','NTzcZ':'stop\x20video\x20recording','PxdoE':function(_0x7b5dd5,_0x5aec79){return _0x7b5dd5(_0x5aec79);},'yUMjW':'capture\x20snapshot','fmxeg':function(_0x5033f8,_0x23ef9b){return _0x5033f8(_0x23ef9b);},'EAddq':'capture\x20screenshot','sAZMj':'click','vYaqq':function(_0xefe5d4,_0x40d314){return _0xefe5d4(_0x40d314);},'ABUzo':_0x248a8c(0x1f0),'LKssV':function(_0xaec9aa,_0x5b1797,_0x338111){return _0xaec9aa(_0x5b1797,_0x338111);},'roddT':_0x248a8c(0x1c2),'fkLmx':function(_0x347120,_0x5380d8,_0x2cb0bf){return _0x347120(_0x5380d8,_0x2cb0bf);},'ULzcc':_0x248a8c(0x1b2)};switch(_0x5c4a87){case _0x248a8c(0x1b9):{const _0x1ff048=_0x53122d['nOSMx'](extractFirstCommandArgument,_0x4752a8,_0x5c4a87);return _0x1ff048?'open\x20'+_0x1ff048:_0x53122d['tEMgD'];}case _0x248a8c(0x1d2):return _0x53122d[_0x248a8c(0x1bd)];case'tracing-stop':return _0x53122d[_0x248a8c(0x187)];case _0x53122d[_0x248a8c(0x18c)]:return _0x53122d[_0x248a8c(0x1aa)];case _0x53122d[_0x248a8c(0x170)]:return _0x53122d['NTzcZ'];case _0x248a8c(0x1a4):{const _0x1db52b=_0x53122d['PxdoE'](extractFilenameOption,_0x4752a8);if(!_0x1db52b)return _0x53122d['yUMjW'];const {name:_0x32748b}=toStepDisplayName(_0x1db52b);return'capture\x20snapshot\x20`'+_0x32748b+'`';}case'screenshot':{const _0x56ca80=_0x53122d[_0x248a8c(0x1e4)](extractFilenameOption,_0x4752a8);if(!_0x56ca80)return _0x53122d[_0x248a8c(0x1b1)];const {name:_0x1aae33,isKeyStep:_0x48a18f}=toStepDisplayName(_0x56ca80);return _0x48a18f?_0x248a8c(0x1f2)+_0x1aae33+'`':_0x248a8c(0x1d7)+_0x1aae33+'`';}case _0x53122d[_0x248a8c(0x1ca)]:return'click\x20'+_0x53122d[_0x248a8c(0x1cc)](formatCommandTarget,extractFirstCommandArgument(_0x4752a8,_0x5c4a87));case _0x53122d[_0x248a8c(0x17c)]:return'check\x20'+formatCommandTarget(_0x53122d[_0x248a8c(0x1d8)](extractFirstCommandArgument,_0x4752a8,_0x5c4a87));case _0x248a8c(0x1d0):return'fill\x20'+_0x53122d['fmxeg'](formatCommandTarget,_0x53122d['LKssV'](extractFirstCommandArgument,_0x4752a8,_0x5c4a87));case'press':return'press\x20'+formatCommandTarget(extractFirstCommandArgument(_0x4752a8,_0x5c4a87));case _0x53122d['roddT']:return _0x248a8c(0x1f7);case _0x248a8c(0x1be):{const _0x40bac2=_0x53122d['fkLmx'](extractFirstCommandArgument,_0x4752a8,_0x5c4a87);return _0x40bac2?_0x248a8c(0x178)+_0x40bac2:_0x248a8c(0x1cb);}case'tab-select':{const _0x3a6f56=extractFirstCommandArgument(_0x4752a8,_0x5c4a87);return _0x3a6f56?_0x248a8c(0x171)+_0x3a6f56:_0x53122d['ULzcc'];}default:return _0x5c4a87;}}function extractPlaywrightCliToolDescription(_0x3cdb81){const _0x41f390=_0x3ff2,_0x50a9e4=_0x3cdb81['description'];if(typeof _0x50a9e4!=='string')return null;const _0x1d0606=_0x50a9e4[_0x41f390(0x17a)]()[_0x41f390(0x1d3)](/\s+/g,'\x20');return _0x1d0606[_0x41f390(0x1a6)]>0x0?_0x1d0606:null;}export function formatPlaywrightCliConsoleLogMessage(_0x45d30b,_0x396d47,_0x38fe15){const _0x5718f8=_0x3ff2,_0x2a81d9={'clBbe':function(_0x2d15a0,_0x56185f){return _0x2d15a0(_0x56185f);}},_0x557b42=formatPlaywrightCliLog(_0x396d47,_0x38fe15),_0x22661e=_0x2a81d9['clBbe'](extractPlaywrightCliToolDescription,_0x45d30b);if(!_0x22661e)return _0x5718f8(0x18a)+_0x557b42;if(process['env']['DEBUG'])return _0x5718f8(0x1ee)+_0x22661e+'\x20('+_0x557b42+')';return'[ranger-verification-agent]\x20'+_0x22661e;}export function buildVerifyFeatureCliDebugPrompt(_0x550fb5,_0x309c8a){const _0x503b38=_0x3ff2,_0xa7e87a={'CWQGt':function(_0x1eb94d,_0x23b85f,_0x3a9264){return _0x1eb94d(_0x23b85f,_0x3a9264);},'WiLHh':function(_0x368b26,_0x1bf8a9,_0x5efd94){return _0x368b26(_0x1bf8a9,_0x5efd94);},'lAvlG':function(_0x33de5d,_0x1f5bd7){return _0x33de5d(_0x1f5bd7);},'IslIs':function(_0x365725,_0x4fb09f){return _0x365725(_0x4fb09f);}},_0x55a531=_0xa7e87a['CWQGt'](buildCliArtifactPath,_0x309c8a,_0x503b38(0x1b4)),_0x47bdeb=buildCliArtifactPath(_0x309c8a,_0x503b38(0x1f1)),_0x2240e8=buildCliArtifactPath(_0x309c8a,_0x503b38(0x174)),_0x967502=_0xa7e87a[_0x503b38(0x1ba)](buildCliArtifactPath,_0x309c8a,'03_learn-more.png'),_0x8f1495=_0xa7e87a['lAvlG'](quoteShellArg,_0x55a531),_0x47f732=quoteShellArg(_0x47bdeb),_0x3bebd1=_0xa7e87a['lAvlG'](quoteShellArg,_0x2240e8),_0x4ec230=_0xa7e87a[_0x503b38(0x19a)](quoteShellArg,_0x967502);return _0x503b38(0x1de)+_0x550fb5+'\x0a\x0a1.\x20Run\x20`'+_0x550fb5+_0x503b38(0x1c7)+_0x550fb5+_0x503b38(0x1e1)+_0x550fb5+_0x503b38(0x183)+_0x309c8a+_0x503b38(0x1e7)+_0x550fb5+'\x20snapshot\x20--filename\x20'+_0x8f1495+'`\x0a5.\x20Read\x20the\x20snapshot\x20file\x20to\x20find\x20the\x20\x22Learn\x20More\x22\x20link\x20reference\x0a6.\x20Run\x20`'+_0x550fb5+_0x503b38(0x19d)+_0x47f732+_0x503b38(0x19c)+_0x550fb5+'\x20snapshot\x20--filename\x20'+_0x3bebd1+_0x503b38(0x1e3)+_0x550fb5+'\x20screenshot\x20--filename\x20'+_0x4ec230+'`\x0a10.\x20Return\x20immediately\x20with\x20the\x20structured\x20output\x0a\x0aReturn\x20your\x20findings\x20in\x20the\x20structured\x20output\x20format.';}export function buildVerifyFeatureCliPrompt(_0xe881bf){const _0x4eb70f=_0x3ff2,_0x112374={'rSQii':'en-US','jpOjl':_0x4eb70f(0x1e9),'DNFTe':'numeric','prlby':'\x20>\x20','dZGhq':'element','HrIrm':function(_0x463f54,_0x496899,_0x51fe90){return _0x463f54(_0x496899,_0x51fe90);},'dOIqJ':'key_03_success-state.png','dmLBI':function(_0x3eafce,_0x4160e4,_0x3e4058){return _0x3eafce(_0x4160e4,_0x3e4058);},'SKLac':function(_0x2ac1b8,_0x3937bd){return _0x2ac1b8(_0x3937bd);},'cFWae':function(_0x3a0862,_0x3cda1c,_0x323224){return _0x3a0862(_0x3cda1c,_0x323224);},'RJhAj':'03_result-visible.png','pjHca':_0x4eb70f(0x1c1)},{checklistItem:_0x11a516,itemFeedback:_0x1e256b,taskDescription:_0x2fd2c3,cliCommandPrefix:_0x35e128,cliArtifactDir:_0x55a450,isCdpMode:_0x3b6a1e,url:_0x37104d,cdpEndpoint:_0x3bfbcf,loginInstructions:_0xb4cc81}=_0xe881bf,_0x4808f5=_0x112374[_0x4eb70f(0x1e5)](buildCliArtifactPath,_0x55a450,'01_initial.yml'),_0x26103d=buildCliArtifactPath(_0x55a450,_0x4eb70f(0x189)),_0x2ffa7f=buildCliArtifactPath(_0x55a450,_0x112374[_0x4eb70f(0x1e2)]),_0xc3b9b2=_0x112374['dmLBI'](buildCliArtifactPath,_0x55a450,_0x4eb70f(0x185)),_0x2efcae=quoteShellArg(_0x4808f5),_0x390390=_0x112374[_0x4eb70f(0x16d)](quoteShellArg,_0x26103d),_0x526e4a=quoteShellArg(_0x2ffa7f),_0x3a28ec=_0x112374['SKLac'](quoteShellArg,_0xc3b9b2),_0x2d4918=_0x11a516['notes']?'\x0a\x0a##\x20Additional\x20Notes\x0a'+_0x11a516['notes']:'';let _0x379751='';if(_0x1e256b&&_0x1e256b['unaddressedComments']['length']>0x0){const _0x3314db=_0x1e256b[_0x4eb70f(0x191)][_0x4eb70f(0x182)](_0x5ee17b=>{const _0x2a1b84=_0x4eb70f,_0x446858=new Date(_0x5ee17b[_0x2a1b84(0x1a0)])[_0x2a1b84(0x194)](_0x112374['rSQii'],{'month':_0x112374['jpOjl'],'day':_0x112374['DNFTe']}),_0x334e0a=_0x5ee17b[_0x2a1b84(0x17f)]||_0x5ee17b[_0x2a1b84(0x179)]||_0x2a1b84(0x1a1),_0x59b71d=_0x5ee17b[_0x2a1b84(0x1cf)]?_0x2a1b84(0x196)+(_0x5ee17b['domRef']['selector'][_0x2a1b84(0x172)](_0x112374[_0x2a1b84(0x1ed)])[_0x2a1b84(0x16a)]()?.['split'](':')[0x0]||_0x112374[_0x2a1b84(0x1c4)])+'>\x20\x22'+(_0x5ee17b[_0x2a1b84(0x1cf)]['textContent']||'')['slice'](0x0,0x32)+'\x22)':'';return _0x2a1b84(0x184)+_0x5ee17b['id']+_0x2a1b84(0x1e6)+_0x334e0a+'**\x20('+_0x446858+'):\x20\x22'+_0x5ee17b[_0x2a1b84(0x195)]+'\x22'+_0x59b71d;})['join']('\x0a');_0x379751=_0x4eb70f(0x1a8)+_0x3314db;}const _0x3fdde6=_0x1e256b?.['canonicalFlow']?_0x4eb70f(0x1da)+_0x1e256b['canonicalFlow']:'',_0x1cf0c2=_0x3b6a1e?_0x4eb70f(0x16c)+_0x3bfbcf+'.\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'+_0x37104d+_0x4eb70f(0x1a3),_0x3b8b9d=_0x37104d?quoteShellArg(_0x37104d):'',_0x123534=_0x3b6a1e?_0x4eb70f(0x1a5)+_0x35e128+'\x20open`,\x20then\x20`'+_0x35e128+'\x20tracing-start`,\x20then\x20`'+_0x35e128+_0x4eb70f(0x1ad)+_0x55a450+_0x4eb70f(0x17b)+_0x35e128+'\x20snapshot\x20--filename\x20'+_0x2efcae+_0x4eb70f(0x1c5)+_0x35e128+'\x20screenshot\x20--filename\x20'+_0x3a28ec+_0x4eb70f(0x1bf)+_0x35e128+_0x4eb70f(0x1ac):'##\x20Instructions\x0a1.\x20Use\x20Bash\x20plus\x20Playwright\x20CLI\x20only.\x20Do\x20NOT\x20call\x20MCP\x20browser\x20tools.\x0a2.\x20Start\x20by\x20running\x20`'+_0x35e128+_0x4eb70f(0x1f6)+_0x3b8b9d+'`,\x20then\x20`'+_0x35e128+'\x20tracing-start`,\x20then\x20`'+_0x35e128+_0x4eb70f(0x1ad)+_0x55a450+_0x4eb70f(0x17b)+_0x35e128+_0x4eb70f(0x192)+_0x2efcae+'`\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`'+_0x35e128+_0x4eb70f(0x19d)+_0x3a28ec+_0x4eb70f(0x1e0)+_0x35e128+'\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',_0x112a27=_0x3b6a1e?'\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.':_0x4eb70f(0x1ec),_0x126ce1=_0xb4cc81?_0x4eb70f(0x1a2)+_0xb4cc81+'\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 _0x4eb70f(0x1d5)+_0x11a516['description']+_0x2d4918+_0x379751+_0x3fdde6+_0x4eb70f(0x1c6)+_0x2fd2c3+'\x0a\x0a'+_0x1cf0c2+_0x126ce1+'\x0a\x0a'+_0x123534+_0x4eb70f(0x1ef)+_0x35e128+_0x4eb70f(0x18f)+_0x55a450+_0x4eb70f(0x1b6)+_0x390390+_0x4eb70f(0x1ae)+_0x526e4a+_0x4eb70f(0x1db)+_0x55a450+'`:\x20\x22'+_0xc3b9b2+'\x22,\x20\x22'+buildCliArtifactPath(_0x55a450,_0x4eb70f(0x1d9))+'\x22,\x20\x22'+_0x112374['cFWae'](buildCliArtifactPath,_0x55a450,_0x112374['RJhAj'])+'\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'+_0x112374[_0x4eb70f(0x1e5)](buildCliArtifactPath,_0x55a450,_0x112374[_0x4eb70f(0x1b5)])+'\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'+_0x112a27+_0x4eb70f(0x19e);}export function summarizeVerifyFeatureCliCommandAvailability(_0x3683cf){const _0x477e69=_0x3ff2,_0x4f8f95={'dgFDX':function(_0x396c7b,_0x3ceffc){return _0x396c7b===_0x3ceffc;}},_0x34378d=[..._0x3683cf[_0x477e69(0x1dc)]()]['sort']();let _0x1e42ab=0x0;for(const _0x3f7081 of _0x3683cf[_0x477e69(0x1bc)]()){_0x1e42ab+=_0x3f7081;}return{'cliCommandCount':_0x1e42ab,'cliCommandsSeen':_0x34378d,'noCliCommandsCalled':_0x4f8f95['dgFDX'](_0x1e42ab,0x0)};}export function createVerifyFeatureCliHooks(_0x9955c8){const _0x17119f={'oNXkI':function(_0x80e5ae,_0x353140){return _0x80e5ae!==_0x353140;},'lkMYR':function(_0x5e2d60,_0x16b7af){return _0x5e2d60(_0x16b7af);},'DMgpM':function(_0x939e3e,_0x5a884d){return _0x939e3e+_0x5a884d;},'MZcFZ':'tool_call','Hckdq':'PostToolUseFailure','gQCSC':function(_0xfa45a3,_0x4b0612){return _0xfa45a3!==_0x4b0612;},'Isgtd':'playwright-cli'},_0x61d940=new Map(),_0x8f7c5=async _0x45d6e2=>{const _0x1eb3ef=_0x3ff2;if(_0x17119f['oNXkI'](_0x45d6e2[_0x1eb3ef(0x180)],_0x1eb3ef(0x19f)))return{};const _0x5b13bf=_0x45d6e2;if(_0x5b13bf['tool_name']!=='Bash')return{};const _0x40f213=_0x5b13bf['tool_input'],_0x94912e=extractBashCommand(_0x40f213);if(!_0x94912e)return{};const _0x67dd67=_0x17119f['lkMYR'](parsePlaywrightCliCommand,_0x94912e);if(!_0x67dd67)return{};return _0x61d940['set'](_0x67dd67,_0x17119f[_0x1eb3ef(0x1a7)](_0x61d940[_0x1eb3ef(0x1e8)](_0x67dd67)||0x0,0x1)),_0x9955c8[_0x1eb3ef(0x181)](_0x1eb3ef(0x1d4),{'transport':'playwright-cli','toolName':_0x67dd67}),_0x9955c8[_0x1eb3ef(0x1c3)](_0x17119f[_0x1eb3ef(0x1dd)],{'transport':'playwright-cli','toolName':_0x67dd67,'bashCommandPreview':truncatePreview(_0x94912e)}),_0x67dd67!==_0x1eb3ef(0x1a4)&&console['log'](formatPlaywrightCliConsoleLogMessage(_0x40f213,_0x94912e,_0x67dd67)),{};},_0x53b621=async _0x5d4ec2=>{const _0x54f9f3=_0x3ff2;if(_0x17119f['oNXkI'](_0x5d4ec2['hook_event_name'],_0x17119f['Hckdq']))return{};const _0x488c76=_0x5d4ec2;if(_0x17119f[_0x54f9f3(0x1b7)](_0x488c76['tool_name'],_0x54f9f3(0x1bb)))return{};return await _0x9955c8[_0x54f9f3(0x173)](_0x54f9f3(0x18d),_0x488c76[_0x54f9f3(0x1f5)],{'transport':_0x17119f['Isgtd'],'toolName':_0x54f9f3(0x1bb)}),{};};return{'postToolUseHook':_0x8f7c5,'postToolUseFailureHook':_0x53b621,'commandCounts':_0x61d940};}function _0x3ff2(_0x31a6cf,_0x12ace3){_0x31a6cf=_0x31a6cf-0x16a;const _0x12e1d0=_0x12e1();let _0x3ff22f=_0x12e1d0[_0x31a6cf];return _0x3ff22f;}async function runPlaywrightCliLifecycleCommand(_0x3a583b){const _0x4ae655=_0x3ff2,_0x23c811={'TvXtA':function(_0x5b11d4,_0x3b1219){return _0x5b11d4(_0x3b1219);},'Vzbee':function(_0x45c927,_0x2b6398){return _0x45c927??_0x2b6398;},'pvcxB':function(_0x58a5d1,_0x54bd4,_0x4114ea){return _0x58a5d1(_0x54bd4,_0x4114ea);}},{sessionId:_0x3a1abb,configPath:_0x1beed8,commandArgs:_0x3b72d9,env:_0x52efa5,telemetry:_0x5279ef,phase:_0x55dbb8,metadata:_0x24a5b8,timeoutMs:_0x33473b}=_0x3a583b;_0x5279ef[_0x4ae655(0x181)](_0x55dbb8,_0x24a5b8);try{const _0x2a7850=await _0x23c811['TvXtA'](runPlaywrightCliCommand,{'sessionId':_0x3a1abb,'configPath':_0x1beed8,'commandArgs':_0x3b72d9,'cwd':process[_0x4ae655(0x1cd)](),'env':_0x52efa5,'timeoutMs':_0x23c811[_0x4ae655(0x1d1)](_0x33473b,PLAYWRIGHT_CLI_COMMAND_TIMEOUT_MS)});_0x5279ef[_0x4ae655(0x1c3)](_0x55dbb8,{..._0x24a5b8,'subcommand':_0x2a7850[_0x4ae655(0x19b)][_0x4ae655(0x16e)],'stdoutPreview':truncatePreview(_0x2a7850[_0x4ae655(0x193)],0x7d0),'stderrPreview':_0x23c811['pvcxB'](truncatePreview,_0x2a7850['stderr'],0x7d0)});}catch(_0x55cde3){await _0x5279ef['trackPhaseError'](_0x55dbb8,_0x55cde3,_0x24a5b8);throw _0x55cde3;}}export async function finalizeVerifyFeatureCliSession(_0x559847){const _0x555a2a=_0x3ff2,_0x16efa5={'WJKJz':_0x555a2a(0x1ea),'hlBwA':'tracing-stop','kfOyf':'playwright_cli_video_stop','vaPmy':'session-recording.webm'},{telemetry:_0x390b9e,sessionId:_0x521f87,configPath:_0xf9ced4,cliArtifactDir:_0x2c25bf,env:_0x5b14b2,transportMetadata:_0x1be6d0}=_0x559847,_0x545c83=[{'phase':_0x16efa5[_0x555a2a(0x16b)],'commandArgs':[_0x16efa5['hlBwA']]},{'phase':_0x16efa5[_0x555a2a(0x1ab)],'commandArgs':[_0x555a2a(0x199),_0x555a2a(0x1ce)+buildCliArtifactPath(_0x2c25bf,_0x16efa5[_0x555a2a(0x1a9)])]},{'phase':'playwright_cli_close','commandArgs':[_0x555a2a(0x190)]}];for(const _0x3d2fcb of _0x545c83){try{await runPlaywrightCliLifecycleCommand({'sessionId':_0x521f87,'configPath':_0xf9ced4,'commandArgs':[..._0x3d2fcb['commandArgs']],'env':_0x5b14b2,'telemetry':_0x390b9e,'phase':_0x3d2fcb[_0x555a2a(0x18b)],'metadata':_0x1be6d0});}catch{}}}export async function loadVerifyFeatureCliTraceUploadArtifact(_0x1c4140){const _0x4f4017=_0x3ff2,_0xee2628={'vPlAX':'trace.zip','xTtPu':function(_0x45d98f,_0x1a7387,_0x583569){return _0x45d98f(_0x1a7387,_0x583569);}},_0x3c62dc=[_0xee2628['vPlAX'],_0x4f4017(0x198)];for(const _0x248f59 of _0x3c62dc){const _0x2bb5c4=_0xee2628['xTtPu'](join,_0x1c4140,_0x248f59);try{return{'buffer':await readFile(_0x2bb5c4),'source':_0x2bb5c4};}catch{}}return null;}export async function rehomeVerifyFeatureCliArtifacts(_0x2c1741){const _0x383ca6=_0x3ff2,_0x5f5be1={'Audce':function(_0x347178,_0xf97771,_0x20dca1){return _0x347178(_0xf97771,_0x20dca1);},'PZPsN':function(_0x18728e,_0x2f9222){return _0x18728e+_0x2f9222;},'BrRzw':function(_0x4659bb,_0x16d379,_0x4fd2b6){return _0x4659bb(_0x16d379,_0x4fd2b6);},'XAcGB':function(_0x291337,_0x3262f8){return _0x291337===_0x3262f8;}},{cwd:_0x6d7d9,cliArtifactDir:_0x215b8a,startTime:_0x537e3f}=_0x2c1741,_0x4f7ef8=[];await _0x5f5be1[_0x383ca6(0x1f4)](mkdir,_0x215b8a,{'recursive':!![]});const _0x3a67dd=await _0x5f5be1['Audce'](readdir,_0x6d7d9,{'withFileTypes':!![]});for(const _0x4678f5 of _0x3a67dd){if(!_0x4678f5['isFile']()||!VERIFY_FEATURE_CLI_ARTIFACT_FILE_PATTERN['test'](_0x4678f5[_0x383ca6(0x188)]))continue;const _0x49d012=join(_0x6d7d9,_0x4678f5['name']),_0x3cb95f=await stat(_0x49d012);if(_0x5f5be1['PZPsN'](_0x3cb95f[_0x383ca6(0x197)],0x7d0)<_0x537e3f)continue;const _0x4c06eb=_0x5f5be1[_0x383ca6(0x1b3)](buildCliArtifactPath,_0x215b8a,_0x4678f5['name']);if(_0x5f5be1['XAcGB'](_0x49d012,_0x4c06eb))continue;await rename(_0x49d012,_0x4c06eb),_0x4f7ef8['push'](_0x4678f5['name']);}return _0x4f7ef8[_0x383ca6(0x1d6)]();}
@@ -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,21 @@ 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
+ ## Profile resolution
12
+
13
+ When the user gives you a username + password, set them inline and run `go` — no `profile add` step:
14
+
15
+ ```bash
16
+ RANGER_TEST_USERNAME='alice@example.com' RANGER_TEST_PASSWORD='hunter2' \
17
+ ranger-cli go --url <target> --notes '<what to verify>'
18
+ ```
19
+
20
+ Resolution order:
21
+
22
+ 1. `--profile <name>` flag (or `RANGER_PROFILE` env var)
23
+ 2. Saved active profile (`ranger-cli profile use <name>`)
24
+ 3. `RANGER_TEST_USERNAME` (reuses or creates a matching profile)
25
+ 4. The org's sole profile when exactly one exists
12
26
 
13
27
  ## Required: Active Feature Review
14
28
 
@@ -41,7 +55,7 @@ You do NOT need to manually include reviewer feedback in your `--notes` descript
41
55
 
42
56
  | Option | Required | Description |
43
57
  |--------|----------|-------------|
44
- | `--profile` | No | Profile to use (defaults to active profile) |
58
+ | `--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
59
  | `--notes` | No | What to verify (defaults to scenario description) |
46
60
  | `--scenario` | No | Scenario index to verify (skips selection prompt) |
47
61
  | `--start-path` | No | Path to start on (appended to base URL, e.g., `/dashboard`) |
@@ -182,7 +196,7 @@ Always end the conversational turn by sharing the dashboard link whenever you ru
182
196
  Run `ranger-cli list` to find feature reviews, then `ranger-cli resume <id>` to resume one.
183
197
 
184
198
  ### "No active profile"
185
- Run `ranger-cli profile use <profile-name>` to set a profile with browser access.
199
+ 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
200
 
187
201
  ### Verification times out
188
202
  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.4-alpha.071b7bd-1",
3
+ "version": "2.5.4-alpha.0e8b82c-9",
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
  },