Agent skill
run-bicep-in-console
Validates Bicep functions using bicep console with piped input. Use when user asks to test, validate, or run Bicep functions, or wants to verify function behavior with test cases.
Stars
11
Forks
2
Install this agent skill to your Project
npx add-skill https://github.com/johnlokerse/azure-bicep-github-copilot/tree/main/.github/skills/run-bicep-in-console
SKILL.md
Run Bicep in the Bicep Console
Quickly validate Bicep functions by piping test cases to bicep console.
Workflow
- Analyze the function: Understand inputs and outputs
- Generate test cases: Create at least 2 test cases
- Detect shell type: Check the user's active terminal to determine if they're using PowerShell or bash
- Look at terminal context for
pwsh,PowerShell, orbash - Check
$SHELLenvironment variable or terminal name
- Look at terminal context for
- Run in bicep console: Pipe function + test expressions using the appropriate shell syntax
PowerShell Command
CRITICAL: Use single-quoted here-string (@'...'@) to prevent $ interpolation:
powershell
@'
func myFunction(input string) string => ...
myFunction('test1')
myFunction('test2')
'@ | bicep console
Bash Command
Use a heredoc with cat:
bash
cat <<'EOF' | bicep console
func myFunction(input string) string => ...
myFunction('test1')
myFunction('test2')
EOF
Note: Quote 'EOF' to prevent $ expansion (same principle as PowerShell).
Test Case Guidelines
- Normal case: Typical expected input
- Edge case: Empty strings, special characters, boundary values
- Return value validation: Include expected output as comment
Example
For a reverse function:
powershell
@'
func reverse(input string) string =>
reduce(range(0, length(input)), '', (acc, i) => '${acc}${substring(input, length(input) - 1 - i, 1)}')
reverse('hello') // Expected: 'olleh'
reverse('world!') // Expected: '!dlrow'
'@ | bicep console
Didn't find tool you were looking for?