nuwaxcode 1.1.34 → 1.1.44
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/nuwaxcode +19 -1
- package/package.json +15 -117
- package/{script/postinstall.mjs → postinstall.mjs} +18 -6
- package/AGENTS.md +0 -27
- package/Dockerfile +0 -18
- package/README.md +0 -15
- package/bunfig.toml +0 -7
- package/parsers-config.ts +0 -253
- package/script/build.ts +0 -172
- package/script/publish-registries.ts +0 -187
- package/script/publish.ts +0 -70
- package/script/schema.ts +0 -47
- package/src/acp/README.md +0 -164
- package/src/acp/agent.ts +0 -1280
- package/src/acp/session.ts +0 -111
- package/src/acp/types.ts +0 -24
- package/src/agent/agent.ts +0 -332
- package/src/agent/generate.txt +0 -75
- package/src/agent/prompt/compaction.txt +0 -12
- package/src/agent/prompt/explore.txt +0 -18
- package/src/agent/prompt/summary.txt +0 -11
- package/src/agent/prompt/title.txt +0 -43
- package/src/auth/index.ts +0 -73
- package/src/bun/index.ts +0 -134
- package/src/bus/bus-event.ts +0 -43
- package/src/bus/global.ts +0 -10
- package/src/bus/index.ts +0 -105
- package/src/cli/bootstrap.ts +0 -17
- package/src/cli/cmd/acp.ts +0 -69
- package/src/cli/cmd/agent.ts +0 -257
- package/src/cli/cmd/auth.ts +0 -400
- package/src/cli/cmd/cmd.ts +0 -7
- package/src/cli/cmd/debug/agent.ts +0 -166
- package/src/cli/cmd/debug/config.ts +0 -16
- package/src/cli/cmd/debug/file.ts +0 -97
- package/src/cli/cmd/debug/index.ts +0 -48
- package/src/cli/cmd/debug/lsp.ts +0 -52
- package/src/cli/cmd/debug/ripgrep.ts +0 -87
- package/src/cli/cmd/debug/scrap.ts +0 -16
- package/src/cli/cmd/debug/skill.ts +0 -16
- package/src/cli/cmd/debug/snapshot.ts +0 -52
- package/src/cli/cmd/export.ts +0 -88
- package/src/cli/cmd/generate.ts +0 -38
- package/src/cli/cmd/github.ts +0 -1548
- package/src/cli/cmd/import.ts +0 -98
- package/src/cli/cmd/mcp.ts +0 -755
- package/src/cli/cmd/models.ts +0 -77
- package/src/cli/cmd/pr.ts +0 -112
- package/src/cli/cmd/run.ts +0 -395
- package/src/cli/cmd/serve.ts +0 -20
- package/src/cli/cmd/session.ts +0 -135
- package/src/cli/cmd/stats.ts +0 -402
- package/src/cli/cmd/tui/app.tsx +0 -761
- package/src/cli/cmd/tui/attach.ts +0 -31
- package/src/cli/cmd/tui/component/border.tsx +0 -21
- package/src/cli/cmd/tui/component/dialog-agent.tsx +0 -31
- package/src/cli/cmd/tui/component/dialog-command.tsx +0 -148
- package/src/cli/cmd/tui/component/dialog-mcp.tsx +0 -86
- package/src/cli/cmd/tui/component/dialog-model.tsx +0 -234
- package/src/cli/cmd/tui/component/dialog-provider.tsx +0 -256
- package/src/cli/cmd/tui/component/dialog-session-list.tsx +0 -114
- package/src/cli/cmd/tui/component/dialog-session-rename.tsx +0 -31
- package/src/cli/cmd/tui/component/dialog-stash.tsx +0 -87
- package/src/cli/cmd/tui/component/dialog-status.tsx +0 -164
- package/src/cli/cmd/tui/component/dialog-tag.tsx +0 -44
- package/src/cli/cmd/tui/component/dialog-theme-list.tsx +0 -50
- package/src/cli/cmd/tui/component/logo.tsx +0 -88
- package/src/cli/cmd/tui/component/prompt/autocomplete.tsx +0 -632
- package/src/cli/cmd/tui/component/prompt/frecency.tsx +0 -89
- package/src/cli/cmd/tui/component/prompt/history.tsx +0 -108
- package/src/cli/cmd/tui/component/prompt/index.tsx +0 -1096
- package/src/cli/cmd/tui/component/prompt/stash.tsx +0 -101
- package/src/cli/cmd/tui/component/textarea-keybindings.ts +0 -73
- package/src/cli/cmd/tui/component/tips.tsx +0 -153
- package/src/cli/cmd/tui/component/todo-item.tsx +0 -32
- package/src/cli/cmd/tui/context/args.tsx +0 -14
- package/src/cli/cmd/tui/context/directory.ts +0 -13
- package/src/cli/cmd/tui/context/exit.tsx +0 -23
- package/src/cli/cmd/tui/context/helper.tsx +0 -25
- package/src/cli/cmd/tui/context/keybind.tsx +0 -101
- package/src/cli/cmd/tui/context/kv.tsx +0 -52
- package/src/cli/cmd/tui/context/local.tsx +0 -402
- package/src/cli/cmd/tui/context/prompt.tsx +0 -18
- package/src/cli/cmd/tui/context/route.tsx +0 -46
- package/src/cli/cmd/tui/context/sdk.tsx +0 -94
- package/src/cli/cmd/tui/context/sync.tsx +0 -427
- package/src/cli/cmd/tui/context/theme/aura.json +0 -69
- package/src/cli/cmd/tui/context/theme/ayu.json +0 -80
- package/src/cli/cmd/tui/context/theme/carbonfox.json +0 -248
- package/src/cli/cmd/tui/context/theme/catppuccin-frappe.json +0 -233
- package/src/cli/cmd/tui/context/theme/catppuccin-macchiato.json +0 -233
- package/src/cli/cmd/tui/context/theme/catppuccin.json +0 -112
- package/src/cli/cmd/tui/context/theme/cobalt2.json +0 -228
- package/src/cli/cmd/tui/context/theme/cursor.json +0 -249
- package/src/cli/cmd/tui/context/theme/dracula.json +0 -219
- package/src/cli/cmd/tui/context/theme/everforest.json +0 -241
- package/src/cli/cmd/tui/context/theme/flexoki.json +0 -237
- package/src/cli/cmd/tui/context/theme/github.json +0 -233
- package/src/cli/cmd/tui/context/theme/gruvbox.json +0 -95
- package/src/cli/cmd/tui/context/theme/kanagawa.json +0 -77
- package/src/cli/cmd/tui/context/theme/lucent-orng.json +0 -237
- package/src/cli/cmd/tui/context/theme/material.json +0 -235
- package/src/cli/cmd/tui/context/theme/matrix.json +0 -77
- package/src/cli/cmd/tui/context/theme/mercury.json +0 -252
- package/src/cli/cmd/tui/context/theme/monokai.json +0 -221
- package/src/cli/cmd/tui/context/theme/nightowl.json +0 -221
- package/src/cli/cmd/tui/context/theme/nord.json +0 -223
- package/src/cli/cmd/tui/context/theme/one-dark.json +0 -84
- package/src/cli/cmd/tui/context/theme/orng.json +0 -249
- package/src/cli/cmd/tui/context/theme/osaka-jade.json +0 -93
- package/src/cli/cmd/tui/context/theme/palenight.json +0 -222
- package/src/cli/cmd/tui/context/theme/rosepine.json +0 -234
- package/src/cli/cmd/tui/context/theme/solarized.json +0 -223
- package/src/cli/cmd/tui/context/theme/synthwave84.json +0 -226
- package/src/cli/cmd/tui/context/theme/tokyonight.json +0 -243
- package/src/cli/cmd/tui/context/theme/vercel.json +0 -245
- package/src/cli/cmd/tui/context/theme/vesper.json +0 -218
- package/src/cli/cmd/tui/context/theme/zenburn.json +0 -223
- package/src/cli/cmd/tui/context/theme.tsx +0 -1152
- package/src/cli/cmd/tui/event.ts +0 -48
- package/src/cli/cmd/tui/routes/home.tsx +0 -140
- package/src/cli/cmd/tui/routes/session/dialog-fork-from-timeline.tsx +0 -64
- package/src/cli/cmd/tui/routes/session/dialog-message.tsx +0 -109
- package/src/cli/cmd/tui/routes/session/dialog-subagent.tsx +0 -26
- package/src/cli/cmd/tui/routes/session/dialog-timeline.tsx +0 -47
- package/src/cli/cmd/tui/routes/session/footer.tsx +0 -91
- package/src/cli/cmd/tui/routes/session/header.tsx +0 -136
- package/src/cli/cmd/tui/routes/session/index.tsx +0 -2050
- package/src/cli/cmd/tui/routes/session/permission.tsx +0 -495
- package/src/cli/cmd/tui/routes/session/question.tsx +0 -435
- package/src/cli/cmd/tui/routes/session/sidebar.tsx +0 -312
- package/src/cli/cmd/tui/thread.ts +0 -165
- package/src/cli/cmd/tui/ui/dialog-alert.tsx +0 -57
- package/src/cli/cmd/tui/ui/dialog-confirm.tsx +0 -83
- package/src/cli/cmd/tui/ui/dialog-export-options.tsx +0 -204
- package/src/cli/cmd/tui/ui/dialog-help.tsx +0 -38
- package/src/cli/cmd/tui/ui/dialog-prompt.tsx +0 -77
- package/src/cli/cmd/tui/ui/dialog-select.tsx +0 -354
- package/src/cli/cmd/tui/ui/dialog.tsx +0 -167
- package/src/cli/cmd/tui/ui/link.tsx +0 -28
- package/src/cli/cmd/tui/ui/spinner.ts +0 -368
- package/src/cli/cmd/tui/ui/toast.tsx +0 -100
- package/src/cli/cmd/tui/util/clipboard.ts +0 -160
- package/src/cli/cmd/tui/util/editor.ts +0 -32
- package/src/cli/cmd/tui/util/signal.ts +0 -7
- package/src/cli/cmd/tui/util/terminal.ts +0 -114
- package/src/cli/cmd/tui/util/transcript.ts +0 -98
- package/src/cli/cmd/tui/worker.ts +0 -152
- package/src/cli/cmd/uninstall.ts +0 -357
- package/src/cli/cmd/upgrade.ts +0 -73
- package/src/cli/cmd/web.ts +0 -81
- package/src/cli/error.ts +0 -57
- package/src/cli/network.ts +0 -53
- package/src/cli/ui.ts +0 -84
- package/src/cli/upgrade.ts +0 -25
- package/src/command/index.ts +0 -131
- package/src/command/template/initialize.txt +0 -10
- package/src/command/template/review.txt +0 -99
- package/src/config/config.ts +0 -1255
- package/src/config/markdown.ts +0 -93
- package/src/env/index.ts +0 -26
- package/src/file/ignore.ts +0 -83
- package/src/file/index.ts +0 -411
- package/src/file/ripgrep.ts +0 -409
- package/src/file/time.ts +0 -64
- package/src/file/watcher.ts +0 -118
- package/src/flag/flag.ts +0 -54
- package/src/format/formatter.ts +0 -359
- package/src/format/index.ts +0 -137
- package/src/global/index.ts +0 -55
- package/src/id/id.ts +0 -83
- package/src/ide/index.ts +0 -76
- package/src/index.ts +0 -159
- package/src/installation/index.ts +0 -246
- package/src/lsp/client.ts +0 -252
- package/src/lsp/index.ts +0 -485
- package/src/lsp/language.ts +0 -119
- package/src/lsp/server.ts +0 -2046
- package/src/mcp/auth.ts +0 -135
- package/src/mcp/index.ts +0 -926
- package/src/mcp/oauth-callback.ts +0 -200
- package/src/mcp/oauth-provider.ts +0 -154
- package/src/patch/index.ts +0 -680
- package/src/permission/arity.ts +0 -163
- package/src/permission/index.ts +0 -210
- package/src/permission/next.ts +0 -269
- package/src/plugin/codex.ts +0 -493
- package/src/plugin/copilot.ts +0 -269
- package/src/plugin/index.ts +0 -135
- package/src/project/bootstrap.ts +0 -35
- package/src/project/instance.ts +0 -91
- package/src/project/project.ts +0 -320
- package/src/project/state.ts +0 -66
- package/src/project/vcs.ts +0 -76
- package/src/provider/auth.ts +0 -147
- package/src/provider/models-macro.ts +0 -11
- package/src/provider/models.ts +0 -112
- package/src/provider/provider.ts +0 -1219
- package/src/provider/sdk/openai-compatible/src/README.md +0 -5
- package/src/provider/sdk/openai-compatible/src/index.ts +0 -2
- package/src/provider/sdk/openai-compatible/src/openai-compatible-provider.ts +0 -100
- package/src/provider/sdk/openai-compatible/src/responses/convert-to-openai-responses-input.ts +0 -303
- package/src/provider/sdk/openai-compatible/src/responses/map-openai-responses-finish-reason.ts +0 -22
- package/src/provider/sdk/openai-compatible/src/responses/openai-config.ts +0 -18
- package/src/provider/sdk/openai-compatible/src/responses/openai-error.ts +0 -22
- package/src/provider/sdk/openai-compatible/src/responses/openai-responses-api-types.ts +0 -207
- package/src/provider/sdk/openai-compatible/src/responses/openai-responses-language-model.ts +0 -1732
- package/src/provider/sdk/openai-compatible/src/responses/openai-responses-prepare-tools.ts +0 -177
- package/src/provider/sdk/openai-compatible/src/responses/openai-responses-settings.ts +0 -1
- package/src/provider/sdk/openai-compatible/src/responses/tool/code-interpreter.ts +0 -88
- package/src/provider/sdk/openai-compatible/src/responses/tool/file-search.ts +0 -128
- package/src/provider/sdk/openai-compatible/src/responses/tool/image-generation.ts +0 -115
- package/src/provider/sdk/openai-compatible/src/responses/tool/local-shell.ts +0 -65
- package/src/provider/sdk/openai-compatible/src/responses/tool/web-search-preview.ts +0 -104
- package/src/provider/sdk/openai-compatible/src/responses/tool/web-search.ts +0 -103
- package/src/provider/transform.ts +0 -724
- package/src/pty/index.ts +0 -229
- package/src/question/index.ts +0 -171
- package/src/scheduler/index.ts +0 -61
- package/src/server/error.ts +0 -36
- package/src/server/mdns.ts +0 -59
- package/src/server/routes/config.ts +0 -92
- package/src/server/routes/experimental.ts +0 -157
- package/src/server/routes/file.ts +0 -197
- package/src/server/routes/global.ts +0 -135
- package/src/server/routes/mcp.ts +0 -225
- package/src/server/routes/permission.ts +0 -68
- package/src/server/routes/project.ts +0 -82
- package/src/server/routes/provider.ts +0 -165
- package/src/server/routes/pty.ts +0 -169
- package/src/server/routes/question.ts +0 -98
- package/src/server/routes/session.ts +0 -935
- package/src/server/routes/tui.ts +0 -379
- package/src/server/server.ts +0 -578
- package/src/session/compaction.ts +0 -225
- package/src/session/index.ts +0 -488
- package/src/session/llm.ts +0 -279
- package/src/session/message-v2.ts +0 -702
- package/src/session/message.ts +0 -189
- package/src/session/processor.ts +0 -406
- package/src/session/prompt/anthropic-20250930.txt +0 -166
- package/src/session/prompt/anthropic.txt +0 -105
- package/src/session/prompt/anthropic_spoof.txt +0 -1
- package/src/session/prompt/beast.txt +0 -147
- package/src/session/prompt/build-switch.txt +0 -5
- package/src/session/prompt/codex.txt +0 -73
- package/src/session/prompt/codex_header.txt +0 -72
- package/src/session/prompt/copilot-gpt-5.txt +0 -143
- package/src/session/prompt/gemini.txt +0 -155
- package/src/session/prompt/max-steps.txt +0 -16
- package/src/session/prompt/plan-reminder-anthropic.txt +0 -67
- package/src/session/prompt/plan.txt +0 -26
- package/src/session/prompt/qwen.txt +0 -109
- package/src/session/prompt.ts +0 -1805
- package/src/session/retry.ts +0 -90
- package/src/session/revert.ts +0 -108
- package/src/session/status.ts +0 -76
- package/src/session/summary.ts +0 -150
- package/src/session/system.ts +0 -138
- package/src/session/todo.ts +0 -37
- package/src/share/share-next.ts +0 -194
- package/src/share/share.ts +0 -87
- package/src/shell/shell.ts +0 -67
- package/src/skill/index.ts +0 -1
- package/src/skill/skill.ts +0 -136
- package/src/snapshot/index.ts +0 -236
- package/src/storage/storage.ts +0 -227
- package/src/tool/apply_patch.ts +0 -277
- package/src/tool/apply_patch.txt +0 -1
- package/src/tool/bash.ts +0 -258
- package/src/tool/bash.txt +0 -115
- package/src/tool/batch.ts +0 -175
- package/src/tool/batch.txt +0 -24
- package/src/tool/codesearch.ts +0 -132
- package/src/tool/codesearch.txt +0 -12
- package/src/tool/edit.ts +0 -645
- package/src/tool/edit.txt +0 -10
- package/src/tool/external-directory.ts +0 -32
- package/src/tool/glob.ts +0 -77
- package/src/tool/glob.txt +0 -6
- package/src/tool/grep.ts +0 -154
- package/src/tool/grep.txt +0 -8
- package/src/tool/invalid.ts +0 -17
- package/src/tool/ls.ts +0 -121
- package/src/tool/ls.txt +0 -1
- package/src/tool/lsp.ts +0 -96
- package/src/tool/lsp.txt +0 -19
- package/src/tool/multiedit.ts +0 -46
- package/src/tool/multiedit.txt +0 -41
- package/src/tool/plan-enter.txt +0 -14
- package/src/tool/plan-exit.txt +0 -13
- package/src/tool/plan.ts +0 -130
- package/src/tool/question.ts +0 -33
- package/src/tool/question.txt +0 -10
- package/src/tool/read.ts +0 -202
- package/src/tool/read.txt +0 -12
- package/src/tool/registry.ts +0 -158
- package/src/tool/skill.ts +0 -75
- package/src/tool/task.ts +0 -188
- package/src/tool/task.txt +0 -60
- package/src/tool/todo.ts +0 -53
- package/src/tool/todoread.txt +0 -14
- package/src/tool/todowrite.txt +0 -167
- package/src/tool/tool.ts +0 -88
- package/src/tool/truncation.ts +0 -106
- package/src/tool/webfetch.ts +0 -182
- package/src/tool/webfetch.txt +0 -13
- package/src/tool/websearch.ts +0 -150
- package/src/tool/websearch.txt +0 -14
- package/src/tool/write.ts +0 -80
- package/src/tool/write.txt +0 -8
- package/src/util/archive.ts +0 -16
- package/src/util/color.ts +0 -19
- package/src/util/context.ts +0 -25
- package/src/util/defer.ts +0 -12
- package/src/util/eventloop.ts +0 -20
- package/src/util/filesystem.ts +0 -93
- package/src/util/fn.ts +0 -11
- package/src/util/format.ts +0 -20
- package/src/util/iife.ts +0 -3
- package/src/util/keybind.ts +0 -103
- package/src/util/lazy.ts +0 -18
- package/src/util/locale.ts +0 -81
- package/src/util/lock.ts +0 -98
- package/src/util/log.ts +0 -180
- package/src/util/queue.ts +0 -32
- package/src/util/rpc.ts +0 -66
- package/src/util/scrap.ts +0 -10
- package/src/util/signal.ts +0 -12
- package/src/util/timeout.ts +0 -14
- package/src/util/token.ts +0 -7
- package/src/util/wildcard.ts +0 -56
- package/src/worktree/index.ts +0 -217
- package/sst-env.d.ts +0 -9
- package/test/acp/event-subscription.test.ts +0 -436
- package/test/acp/system-prompt.test.ts +0 -262
- package/test/agent/agent.test.ts +0 -638
- package/test/bun.test.ts +0 -53
- package/test/cli/github-action.test.ts +0 -129
- package/test/cli/github-remote.test.ts +0 -80
- package/test/cli/tui/transcript.test.ts +0 -297
- package/test/config/agent-color.test.ts +0 -66
- package/test/config/config.test.ts +0 -1414
- package/test/config/fixtures/empty-frontmatter.md +0 -4
- package/test/config/fixtures/frontmatter.md +0 -28
- package/test/config/fixtures/no-frontmatter.md +0 -1
- package/test/config/markdown.test.ts +0 -192
- package/test/file/ignore.test.ts +0 -10
- package/test/file/path-traversal.test.ts +0 -198
- package/test/fixture/fixture.ts +0 -45
- package/test/fixture/lsp/fake-lsp-server.js +0 -77
- package/test/ide/ide.test.ts +0 -82
- package/test/keybind.test.ts +0 -421
- package/test/lsp/client.test.ts +0 -95
- package/test/mcp/headers.test.ts +0 -153
- package/test/mcp/oauth-browser.test.ts +0 -261
- package/test/patch/patch.test.ts +0 -348
- package/test/permission/arity.test.ts +0 -33
- package/test/permission/next.test.ts +0 -652
- package/test/permission-task.test.ts +0 -319
- package/test/plugin/codex.test.ts +0 -123
- package/test/preload.ts +0 -65
- package/test/project/project.test.ts +0 -120
- package/test/provider/amazon-bedrock.test.ts +0 -268
- package/test/provider/gitlab-duo.test.ts +0 -286
- package/test/provider/provider.test.ts +0 -2149
- package/test/provider/transform.test.ts +0 -1596
- package/test/question/question.test.ts +0 -300
- package/test/scheduler.test.ts +0 -73
- package/test/server/session-list.test.ts +0 -39
- package/test/server/session-select.test.ts +0 -78
- package/test/session/compaction.test.ts +0 -293
- package/test/session/llm.test.ts +0 -90
- package/test/session/message-v2.test.ts +0 -662
- package/test/session/retry.test.ts +0 -131
- package/test/session/revert-compact.test.ts +0 -285
- package/test/session/session.test.ts +0 -71
- package/test/skill/skill.test.ts +0 -185
- package/test/snapshot/snapshot.test.ts +0 -939
- package/test/tool/__snapshots__/tool.test.ts.snap +0 -9
- package/test/tool/apply_patch.test.ts +0 -515
- package/test/tool/bash.test.ts +0 -320
- package/test/tool/external-directory.test.ts +0 -126
- package/test/tool/fixtures/large-image.png +0 -0
- package/test/tool/fixtures/models-api.json +0 -33453
- package/test/tool/grep.test.ts +0 -109
- package/test/tool/question.test.ts +0 -105
- package/test/tool/read.test.ts +0 -332
- package/test/tool/registry.test.ts +0 -76
- package/test/tool/truncation.test.ts +0 -159
- package/test/util/filesystem.test.ts +0 -39
- package/test/util/format.test.ts +0 -59
- package/test/util/iife.test.ts +0 -36
- package/test/util/lazy.test.ts +0 -50
- package/test/util/lock.test.ts +0 -72
- package/test/util/timeout.test.ts +0 -21
- package/test/util/wildcard.test.ts +0 -75
- package/tsconfig.json +0 -16
|
@@ -1,159 +0,0 @@
|
|
|
1
|
-
import { describe, test, expect, afterAll } from "bun:test"
|
|
2
|
-
import { Truncate } from "../../src/tool/truncation"
|
|
3
|
-
import { Identifier } from "../../src/id/id"
|
|
4
|
-
import fs from "fs/promises"
|
|
5
|
-
import path from "path"
|
|
6
|
-
|
|
7
|
-
const FIXTURES_DIR = path.join(import.meta.dir, "fixtures")
|
|
8
|
-
|
|
9
|
-
describe("Truncate", () => {
|
|
10
|
-
describe("output", () => {
|
|
11
|
-
test("truncates large json file by bytes", async () => {
|
|
12
|
-
const content = await Bun.file(path.join(FIXTURES_DIR, "models-api.json")).text()
|
|
13
|
-
const result = await Truncate.output(content)
|
|
14
|
-
|
|
15
|
-
expect(result.truncated).toBe(true)
|
|
16
|
-
expect(result.content).toContain("truncated...")
|
|
17
|
-
if (result.truncated) expect(result.outputPath).toBeDefined()
|
|
18
|
-
})
|
|
19
|
-
|
|
20
|
-
test("returns content unchanged when under limits", async () => {
|
|
21
|
-
const content = "line1\nline2\nline3"
|
|
22
|
-
const result = await Truncate.output(content)
|
|
23
|
-
|
|
24
|
-
expect(result.truncated).toBe(false)
|
|
25
|
-
expect(result.content).toBe(content)
|
|
26
|
-
})
|
|
27
|
-
|
|
28
|
-
test("truncates by line count", async () => {
|
|
29
|
-
const lines = Array.from({ length: 100 }, (_, i) => `line${i}`).join("\n")
|
|
30
|
-
const result = await Truncate.output(lines, { maxLines: 10 })
|
|
31
|
-
|
|
32
|
-
expect(result.truncated).toBe(true)
|
|
33
|
-
expect(result.content).toContain("...90 lines truncated...")
|
|
34
|
-
})
|
|
35
|
-
|
|
36
|
-
test("truncates by byte count", async () => {
|
|
37
|
-
const content = "a".repeat(1000)
|
|
38
|
-
const result = await Truncate.output(content, { maxBytes: 100 })
|
|
39
|
-
|
|
40
|
-
expect(result.truncated).toBe(true)
|
|
41
|
-
expect(result.content).toContain("truncated...")
|
|
42
|
-
})
|
|
43
|
-
|
|
44
|
-
test("truncates from head by default", async () => {
|
|
45
|
-
const lines = Array.from({ length: 10 }, (_, i) => `line${i}`).join("\n")
|
|
46
|
-
const result = await Truncate.output(lines, { maxLines: 3 })
|
|
47
|
-
|
|
48
|
-
expect(result.truncated).toBe(true)
|
|
49
|
-
expect(result.content).toContain("line0")
|
|
50
|
-
expect(result.content).toContain("line1")
|
|
51
|
-
expect(result.content).toContain("line2")
|
|
52
|
-
expect(result.content).not.toContain("line9")
|
|
53
|
-
})
|
|
54
|
-
|
|
55
|
-
test("truncates from tail when direction is tail", async () => {
|
|
56
|
-
const lines = Array.from({ length: 10 }, (_, i) => `line${i}`).join("\n")
|
|
57
|
-
const result = await Truncate.output(lines, { maxLines: 3, direction: "tail" })
|
|
58
|
-
|
|
59
|
-
expect(result.truncated).toBe(true)
|
|
60
|
-
expect(result.content).toContain("line7")
|
|
61
|
-
expect(result.content).toContain("line8")
|
|
62
|
-
expect(result.content).toContain("line9")
|
|
63
|
-
expect(result.content).not.toContain("line0")
|
|
64
|
-
})
|
|
65
|
-
|
|
66
|
-
test("uses default MAX_LINES and MAX_BYTES", () => {
|
|
67
|
-
expect(Truncate.MAX_LINES).toBe(2000)
|
|
68
|
-
expect(Truncate.MAX_BYTES).toBe(50 * 1024)
|
|
69
|
-
})
|
|
70
|
-
|
|
71
|
-
test("large single-line file truncates with byte message", async () => {
|
|
72
|
-
const content = await Bun.file(path.join(FIXTURES_DIR, "models-api.json")).text()
|
|
73
|
-
const result = await Truncate.output(content)
|
|
74
|
-
|
|
75
|
-
expect(result.truncated).toBe(true)
|
|
76
|
-
expect(result.content).toContain("bytes truncated...")
|
|
77
|
-
expect(Buffer.byteLength(content, "utf-8")).toBeGreaterThan(Truncate.MAX_BYTES)
|
|
78
|
-
})
|
|
79
|
-
|
|
80
|
-
test("writes full output to file when truncated", async () => {
|
|
81
|
-
const lines = Array.from({ length: 100 }, (_, i) => `line${i}`).join("\n")
|
|
82
|
-
const result = await Truncate.output(lines, { maxLines: 10 })
|
|
83
|
-
|
|
84
|
-
expect(result.truncated).toBe(true)
|
|
85
|
-
expect(result.content).toContain("The tool call succeeded but the output was truncated")
|
|
86
|
-
expect(result.content).toContain("Grep")
|
|
87
|
-
if (!result.truncated) throw new Error("expected truncated")
|
|
88
|
-
expect(result.outputPath).toBeDefined()
|
|
89
|
-
expect(result.outputPath).toContain("tool_")
|
|
90
|
-
|
|
91
|
-
const written = await Bun.file(result.outputPath).text()
|
|
92
|
-
expect(written).toBe(lines)
|
|
93
|
-
})
|
|
94
|
-
|
|
95
|
-
test("suggests Task tool when agent has task permission", async () => {
|
|
96
|
-
const lines = Array.from({ length: 100 }, (_, i) => `line${i}`).join("\n")
|
|
97
|
-
const agent = { permission: [{ permission: "task", pattern: "*", action: "allow" as const }] }
|
|
98
|
-
const result = await Truncate.output(lines, { maxLines: 10 }, agent as any)
|
|
99
|
-
|
|
100
|
-
expect(result.truncated).toBe(true)
|
|
101
|
-
expect(result.content).toContain("Grep")
|
|
102
|
-
expect(result.content).toContain("Task tool")
|
|
103
|
-
})
|
|
104
|
-
|
|
105
|
-
test("omits Task tool hint when agent lacks task permission", async () => {
|
|
106
|
-
const lines = Array.from({ length: 100 }, (_, i) => `line${i}`).join("\n")
|
|
107
|
-
const agent = { permission: [{ permission: "task", pattern: "*", action: "deny" as const }] }
|
|
108
|
-
const result = await Truncate.output(lines, { maxLines: 10 }, agent as any)
|
|
109
|
-
|
|
110
|
-
expect(result.truncated).toBe(true)
|
|
111
|
-
expect(result.content).toContain("Grep")
|
|
112
|
-
expect(result.content).not.toContain("Task tool")
|
|
113
|
-
})
|
|
114
|
-
|
|
115
|
-
test("does not write file when not truncated", async () => {
|
|
116
|
-
const content = "short content"
|
|
117
|
-
const result = await Truncate.output(content)
|
|
118
|
-
|
|
119
|
-
expect(result.truncated).toBe(false)
|
|
120
|
-
if (result.truncated) throw new Error("expected not truncated")
|
|
121
|
-
expect("outputPath" in result).toBe(false)
|
|
122
|
-
})
|
|
123
|
-
})
|
|
124
|
-
|
|
125
|
-
describe("cleanup", () => {
|
|
126
|
-
const DAY_MS = 24 * 60 * 60 * 1000
|
|
127
|
-
let oldFile: string
|
|
128
|
-
let recentFile: string
|
|
129
|
-
|
|
130
|
-
afterAll(async () => {
|
|
131
|
-
await fs.unlink(oldFile).catch(() => {})
|
|
132
|
-
await fs.unlink(recentFile).catch(() => {})
|
|
133
|
-
})
|
|
134
|
-
|
|
135
|
-
test("deletes files older than 7 days and preserves recent files", async () => {
|
|
136
|
-
await fs.mkdir(Truncate.DIR, { recursive: true })
|
|
137
|
-
|
|
138
|
-
// Create an old file (10 days ago)
|
|
139
|
-
const oldTimestamp = Date.now() - 10 * DAY_MS
|
|
140
|
-
const oldId = Identifier.create("tool", false, oldTimestamp)
|
|
141
|
-
oldFile = path.join(Truncate.DIR, oldId)
|
|
142
|
-
await Bun.write(Bun.file(oldFile), "old content")
|
|
143
|
-
|
|
144
|
-
// Create a recent file (3 days ago)
|
|
145
|
-
const recentTimestamp = Date.now() - 3 * DAY_MS
|
|
146
|
-
const recentId = Identifier.create("tool", false, recentTimestamp)
|
|
147
|
-
recentFile = path.join(Truncate.DIR, recentId)
|
|
148
|
-
await Bun.write(Bun.file(recentFile), "recent content")
|
|
149
|
-
|
|
150
|
-
await Truncate.cleanup()
|
|
151
|
-
|
|
152
|
-
// Old file should be deleted
|
|
153
|
-
expect(await Bun.file(oldFile).exists()).toBe(false)
|
|
154
|
-
|
|
155
|
-
// Recent file should still exist
|
|
156
|
-
expect(await Bun.file(recentFile).exists()).toBe(true)
|
|
157
|
-
})
|
|
158
|
-
})
|
|
159
|
-
})
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { describe, expect, test } from "bun:test"
|
|
2
|
-
import os from "node:os"
|
|
3
|
-
import path from "node:path"
|
|
4
|
-
import { mkdtemp, mkdir, rm } from "node:fs/promises"
|
|
5
|
-
import { Filesystem } from "../../src/util/filesystem"
|
|
6
|
-
|
|
7
|
-
describe("util.filesystem", () => {
|
|
8
|
-
test("exists() is true for files and directories", async () => {
|
|
9
|
-
const tmp = await mkdtemp(path.join(os.tmpdir(), "opencode-filesystem-"))
|
|
10
|
-
const dir = path.join(tmp, "dir")
|
|
11
|
-
const file = path.join(tmp, "file.txt")
|
|
12
|
-
const missing = path.join(tmp, "missing")
|
|
13
|
-
|
|
14
|
-
await mkdir(dir, { recursive: true })
|
|
15
|
-
await Bun.write(file, "hello")
|
|
16
|
-
|
|
17
|
-
const cases = await Promise.all([Filesystem.exists(dir), Filesystem.exists(file), Filesystem.exists(missing)])
|
|
18
|
-
|
|
19
|
-
expect(cases).toEqual([true, true, false])
|
|
20
|
-
|
|
21
|
-
await rm(tmp, { recursive: true, force: true })
|
|
22
|
-
})
|
|
23
|
-
|
|
24
|
-
test("isDir() is true only for directories", async () => {
|
|
25
|
-
const tmp = await mkdtemp(path.join(os.tmpdir(), "opencode-filesystem-"))
|
|
26
|
-
const dir = path.join(tmp, "dir")
|
|
27
|
-
const file = path.join(tmp, "file.txt")
|
|
28
|
-
const missing = path.join(tmp, "missing")
|
|
29
|
-
|
|
30
|
-
await mkdir(dir, { recursive: true })
|
|
31
|
-
await Bun.write(file, "hello")
|
|
32
|
-
|
|
33
|
-
const cases = await Promise.all([Filesystem.isDir(dir), Filesystem.isDir(file), Filesystem.isDir(missing)])
|
|
34
|
-
|
|
35
|
-
expect(cases).toEqual([true, false, false])
|
|
36
|
-
|
|
37
|
-
await rm(tmp, { recursive: true, force: true })
|
|
38
|
-
})
|
|
39
|
-
})
|
package/test/util/format.test.ts
DELETED
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import { describe, expect, test } from "bun:test"
|
|
2
|
-
import { formatDuration } from "../../src/util/format"
|
|
3
|
-
|
|
4
|
-
describe("util.format", () => {
|
|
5
|
-
describe("formatDuration", () => {
|
|
6
|
-
test("returns empty string for zero or negative values", () => {
|
|
7
|
-
expect(formatDuration(0)).toBe("")
|
|
8
|
-
expect(formatDuration(-1)).toBe("")
|
|
9
|
-
expect(formatDuration(-100)).toBe("")
|
|
10
|
-
})
|
|
11
|
-
|
|
12
|
-
test("formats seconds under a minute", () => {
|
|
13
|
-
expect(formatDuration(1)).toBe("1s")
|
|
14
|
-
expect(formatDuration(30)).toBe("30s")
|
|
15
|
-
expect(formatDuration(59)).toBe("59s")
|
|
16
|
-
})
|
|
17
|
-
|
|
18
|
-
test("formats minutes under an hour", () => {
|
|
19
|
-
expect(formatDuration(60)).toBe("1m")
|
|
20
|
-
expect(formatDuration(61)).toBe("1m 1s")
|
|
21
|
-
expect(formatDuration(90)).toBe("1m 30s")
|
|
22
|
-
expect(formatDuration(120)).toBe("2m")
|
|
23
|
-
expect(formatDuration(330)).toBe("5m 30s")
|
|
24
|
-
expect(formatDuration(3599)).toBe("59m 59s")
|
|
25
|
-
})
|
|
26
|
-
|
|
27
|
-
test("formats hours under a day", () => {
|
|
28
|
-
expect(formatDuration(3600)).toBe("1h")
|
|
29
|
-
expect(formatDuration(3660)).toBe("1h 1m")
|
|
30
|
-
expect(formatDuration(7200)).toBe("2h")
|
|
31
|
-
expect(formatDuration(8100)).toBe("2h 15m")
|
|
32
|
-
expect(formatDuration(86399)).toBe("23h 59m")
|
|
33
|
-
})
|
|
34
|
-
|
|
35
|
-
test("formats days under a week", () => {
|
|
36
|
-
expect(formatDuration(86400)).toBe("~1 day")
|
|
37
|
-
expect(formatDuration(172800)).toBe("~2 days")
|
|
38
|
-
expect(formatDuration(259200)).toBe("~3 days")
|
|
39
|
-
expect(formatDuration(604799)).toBe("~6 days")
|
|
40
|
-
})
|
|
41
|
-
|
|
42
|
-
test("formats weeks", () => {
|
|
43
|
-
expect(formatDuration(604800)).toBe("~1 week")
|
|
44
|
-
expect(formatDuration(1209600)).toBe("~2 weeks")
|
|
45
|
-
expect(formatDuration(1609200)).toBe("~2 weeks")
|
|
46
|
-
})
|
|
47
|
-
|
|
48
|
-
test("handles boundary values correctly", () => {
|
|
49
|
-
expect(formatDuration(59)).toBe("59s")
|
|
50
|
-
expect(formatDuration(60)).toBe("1m")
|
|
51
|
-
expect(formatDuration(3599)).toBe("59m 59s")
|
|
52
|
-
expect(formatDuration(3600)).toBe("1h")
|
|
53
|
-
expect(formatDuration(86399)).toBe("23h 59m")
|
|
54
|
-
expect(formatDuration(86400)).toBe("~1 day")
|
|
55
|
-
expect(formatDuration(604799)).toBe("~6 days")
|
|
56
|
-
expect(formatDuration(604800)).toBe("~1 week")
|
|
57
|
-
})
|
|
58
|
-
})
|
|
59
|
-
})
|
package/test/util/iife.test.ts
DELETED
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { describe, expect, test } from "bun:test"
|
|
2
|
-
import { iife } from "../../src/util/iife"
|
|
3
|
-
|
|
4
|
-
describe("util.iife", () => {
|
|
5
|
-
test("should execute function immediately and return result", () => {
|
|
6
|
-
let called = false
|
|
7
|
-
const result = iife(() => {
|
|
8
|
-
called = true
|
|
9
|
-
return 42
|
|
10
|
-
})
|
|
11
|
-
|
|
12
|
-
expect(called).toBe(true)
|
|
13
|
-
expect(result).toBe(42)
|
|
14
|
-
})
|
|
15
|
-
|
|
16
|
-
test("should work with async functions", async () => {
|
|
17
|
-
let called = false
|
|
18
|
-
const result = await iife(async () => {
|
|
19
|
-
called = true
|
|
20
|
-
return "async result"
|
|
21
|
-
})
|
|
22
|
-
|
|
23
|
-
expect(called).toBe(true)
|
|
24
|
-
expect(result).toBe("async result")
|
|
25
|
-
})
|
|
26
|
-
|
|
27
|
-
test("should handle functions with no return value", () => {
|
|
28
|
-
let called = false
|
|
29
|
-
const result = iife(() => {
|
|
30
|
-
called = true
|
|
31
|
-
})
|
|
32
|
-
|
|
33
|
-
expect(called).toBe(true)
|
|
34
|
-
expect(result).toBeUndefined()
|
|
35
|
-
})
|
|
36
|
-
})
|
package/test/util/lazy.test.ts
DELETED
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import { describe, expect, test } from "bun:test"
|
|
2
|
-
import { lazy } from "../../src/util/lazy"
|
|
3
|
-
|
|
4
|
-
describe("util.lazy", () => {
|
|
5
|
-
test("should call function only once", () => {
|
|
6
|
-
let callCount = 0
|
|
7
|
-
const getValue = () => {
|
|
8
|
-
callCount++
|
|
9
|
-
return "expensive value"
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
const lazyValue = lazy(getValue)
|
|
13
|
-
|
|
14
|
-
expect(callCount).toBe(0)
|
|
15
|
-
|
|
16
|
-
const result1 = lazyValue()
|
|
17
|
-
expect(result1).toBe("expensive value")
|
|
18
|
-
expect(callCount).toBe(1)
|
|
19
|
-
|
|
20
|
-
const result2 = lazyValue()
|
|
21
|
-
expect(result2).toBe("expensive value")
|
|
22
|
-
expect(callCount).toBe(1)
|
|
23
|
-
})
|
|
24
|
-
|
|
25
|
-
test("should preserve the same reference", () => {
|
|
26
|
-
const obj = { value: 42 }
|
|
27
|
-
const lazyObj = lazy(() => obj)
|
|
28
|
-
|
|
29
|
-
const result1 = lazyObj()
|
|
30
|
-
const result2 = lazyObj()
|
|
31
|
-
|
|
32
|
-
expect(result1).toBe(obj)
|
|
33
|
-
expect(result2).toBe(obj)
|
|
34
|
-
expect(result1).toBe(result2)
|
|
35
|
-
})
|
|
36
|
-
|
|
37
|
-
test("should work with different return types", () => {
|
|
38
|
-
const lazyString = lazy(() => "string")
|
|
39
|
-
const lazyNumber = lazy(() => 123)
|
|
40
|
-
const lazyBoolean = lazy(() => true)
|
|
41
|
-
const lazyNull = lazy(() => null)
|
|
42
|
-
const lazyUndefined = lazy(() => undefined)
|
|
43
|
-
|
|
44
|
-
expect(lazyString()).toBe("string")
|
|
45
|
-
expect(lazyNumber()).toBe(123)
|
|
46
|
-
expect(lazyBoolean()).toBe(true)
|
|
47
|
-
expect(lazyNull()).toBe(null)
|
|
48
|
-
expect(lazyUndefined()).toBe(undefined)
|
|
49
|
-
})
|
|
50
|
-
})
|
package/test/util/lock.test.ts
DELETED
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
import { describe, expect, test } from "bun:test"
|
|
2
|
-
import { Lock } from "../../src/util/lock"
|
|
3
|
-
|
|
4
|
-
function tick() {
|
|
5
|
-
return new Promise<void>((r) => queueMicrotask(r))
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
async function flush(n = 5) {
|
|
9
|
-
for (let i = 0; i < n; i++) await tick()
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
describe("util.lock", () => {
|
|
13
|
-
test("writer exclusivity: blocks reads and other writes while held", async () => {
|
|
14
|
-
const key = "lock:" + Math.random().toString(36).slice(2)
|
|
15
|
-
|
|
16
|
-
const state = {
|
|
17
|
-
writer2: false,
|
|
18
|
-
reader: false,
|
|
19
|
-
writers: 0,
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
// Acquire writer1
|
|
23
|
-
using writer1 = await Lock.write(key)
|
|
24
|
-
state.writers++
|
|
25
|
-
expect(state.writers).toBe(1)
|
|
26
|
-
|
|
27
|
-
// Start writer2 candidate (should block)
|
|
28
|
-
const writer2Task = (async () => {
|
|
29
|
-
const w = await Lock.write(key)
|
|
30
|
-
state.writers++
|
|
31
|
-
expect(state.writers).toBe(1)
|
|
32
|
-
state.writer2 = true
|
|
33
|
-
// Hold for a tick so reader cannot slip in
|
|
34
|
-
await tick()
|
|
35
|
-
return w
|
|
36
|
-
})()
|
|
37
|
-
|
|
38
|
-
// Start reader candidate (should block)
|
|
39
|
-
const readerTask = (async () => {
|
|
40
|
-
const r = await Lock.read(key)
|
|
41
|
-
state.reader = true
|
|
42
|
-
return r
|
|
43
|
-
})()
|
|
44
|
-
|
|
45
|
-
// Flush microtasks and assert neither acquired
|
|
46
|
-
await flush()
|
|
47
|
-
expect(state.writer2).toBe(false)
|
|
48
|
-
expect(state.reader).toBe(false)
|
|
49
|
-
|
|
50
|
-
// Release writer1
|
|
51
|
-
writer1[Symbol.dispose]()
|
|
52
|
-
state.writers--
|
|
53
|
-
|
|
54
|
-
// writer2 should acquire next
|
|
55
|
-
const writer2 = await writer2Task
|
|
56
|
-
expect(state.writer2).toBe(true)
|
|
57
|
-
|
|
58
|
-
// Reader still blocked while writer2 held
|
|
59
|
-
await flush()
|
|
60
|
-
expect(state.reader).toBe(false)
|
|
61
|
-
|
|
62
|
-
// Release writer2
|
|
63
|
-
writer2[Symbol.dispose]()
|
|
64
|
-
state.writers--
|
|
65
|
-
|
|
66
|
-
// Reader should now acquire
|
|
67
|
-
const reader = await readerTask
|
|
68
|
-
expect(state.reader).toBe(true)
|
|
69
|
-
|
|
70
|
-
reader[Symbol.dispose]()
|
|
71
|
-
})
|
|
72
|
-
})
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { describe, expect, test } from "bun:test"
|
|
2
|
-
import { withTimeout } from "../../src/util/timeout"
|
|
3
|
-
|
|
4
|
-
describe("util.timeout", () => {
|
|
5
|
-
test("should resolve when promise completes before timeout", async () => {
|
|
6
|
-
const fastPromise = new Promise<string>((resolve) => {
|
|
7
|
-
setTimeout(() => resolve("fast"), 10)
|
|
8
|
-
})
|
|
9
|
-
|
|
10
|
-
const result = await withTimeout(fastPromise, 100)
|
|
11
|
-
expect(result).toBe("fast")
|
|
12
|
-
})
|
|
13
|
-
|
|
14
|
-
test("should reject when promise exceeds timeout", async () => {
|
|
15
|
-
const slowPromise = new Promise<string>((resolve) => {
|
|
16
|
-
setTimeout(() => resolve("slow"), 200)
|
|
17
|
-
})
|
|
18
|
-
|
|
19
|
-
await expect(withTimeout(slowPromise, 50)).rejects.toThrow("Operation timed out after 50ms")
|
|
20
|
-
})
|
|
21
|
-
})
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
import { test, expect } from "bun:test"
|
|
2
|
-
import { Wildcard } from "../../src/util/wildcard"
|
|
3
|
-
|
|
4
|
-
test("match handles glob tokens", () => {
|
|
5
|
-
expect(Wildcard.match("file1.txt", "file?.txt")).toBe(true)
|
|
6
|
-
expect(Wildcard.match("file12.txt", "file?.txt")).toBe(false)
|
|
7
|
-
expect(Wildcard.match("foo+bar", "foo+bar")).toBe(true)
|
|
8
|
-
})
|
|
9
|
-
|
|
10
|
-
test("match with trailing space+wildcard matches command with or without args", () => {
|
|
11
|
-
// "ls *" should match "ls" (no args) and "ls -la" (with args)
|
|
12
|
-
expect(Wildcard.match("ls", "ls *")).toBe(true)
|
|
13
|
-
expect(Wildcard.match("ls -la", "ls *")).toBe(true)
|
|
14
|
-
expect(Wildcard.match("ls foo bar", "ls *")).toBe(true)
|
|
15
|
-
|
|
16
|
-
// "ls*" (no space) should NOT match "ls" alone — wait, it should because .* matches empty
|
|
17
|
-
// but it WILL match "lstmeval" which is the dangerous case users should avoid
|
|
18
|
-
expect(Wildcard.match("ls", "ls*")).toBe(true)
|
|
19
|
-
expect(Wildcard.match("lstmeval", "ls*")).toBe(true)
|
|
20
|
-
|
|
21
|
-
// "ls *" (with space) should NOT match "lstmeval"
|
|
22
|
-
expect(Wildcard.match("lstmeval", "ls *")).toBe(false)
|
|
23
|
-
|
|
24
|
-
// multi-word commands
|
|
25
|
-
expect(Wildcard.match("git status", "git *")).toBe(true)
|
|
26
|
-
expect(Wildcard.match("git", "git *")).toBe(true)
|
|
27
|
-
expect(Wildcard.match("git commit -m foo", "git *")).toBe(true)
|
|
28
|
-
})
|
|
29
|
-
|
|
30
|
-
test("all picks the most specific pattern", () => {
|
|
31
|
-
const rules = {
|
|
32
|
-
"*": "deny",
|
|
33
|
-
"git *": "ask",
|
|
34
|
-
"git status": "allow",
|
|
35
|
-
}
|
|
36
|
-
expect(Wildcard.all("git status", rules)).toBe("allow")
|
|
37
|
-
expect(Wildcard.all("git log", rules)).toBe("ask")
|
|
38
|
-
expect(Wildcard.all("echo hi", rules)).toBe("deny")
|
|
39
|
-
})
|
|
40
|
-
|
|
41
|
-
test("allStructured matches command sequences", () => {
|
|
42
|
-
const rules = {
|
|
43
|
-
"git *": "ask",
|
|
44
|
-
"git status*": "allow",
|
|
45
|
-
}
|
|
46
|
-
expect(Wildcard.allStructured({ head: "git", tail: ["status", "--short"] }, rules)).toBe("allow")
|
|
47
|
-
expect(Wildcard.allStructured({ head: "npm", tail: ["run", "build", "--watch"] }, { "npm run *": "allow" })).toBe(
|
|
48
|
-
"allow",
|
|
49
|
-
)
|
|
50
|
-
expect(Wildcard.allStructured({ head: "ls", tail: ["-la"] }, rules)).toBeUndefined()
|
|
51
|
-
})
|
|
52
|
-
|
|
53
|
-
test("allStructured prioritizes flag-specific patterns", () => {
|
|
54
|
-
const rules = {
|
|
55
|
-
"find *": "allow",
|
|
56
|
-
"find * -delete*": "ask",
|
|
57
|
-
"sort*": "allow",
|
|
58
|
-
"sort -o *": "ask",
|
|
59
|
-
}
|
|
60
|
-
expect(Wildcard.allStructured({ head: "find", tail: ["src", "-delete"] }, rules)).toBe("ask")
|
|
61
|
-
expect(Wildcard.allStructured({ head: "find", tail: ["src", "-print"] }, rules)).toBe("allow")
|
|
62
|
-
expect(Wildcard.allStructured({ head: "sort", tail: ["-o", "out.txt"] }, rules)).toBe("ask")
|
|
63
|
-
expect(Wildcard.allStructured({ head: "sort", tail: ["--reverse"] }, rules)).toBe("allow")
|
|
64
|
-
})
|
|
65
|
-
|
|
66
|
-
test("allStructured handles sed flags", () => {
|
|
67
|
-
const rules = {
|
|
68
|
-
"sed * -i*": "ask",
|
|
69
|
-
"sed -n*": "allow",
|
|
70
|
-
}
|
|
71
|
-
expect(Wildcard.allStructured({ head: "sed", tail: ["-i", "file"] }, rules)).toBe("ask")
|
|
72
|
-
expect(Wildcard.allStructured({ head: "sed", tail: ["-i.bak", "file"] }, rules)).toBe("ask")
|
|
73
|
-
expect(Wildcard.allStructured({ head: "sed", tail: ["-n", "1p", "file"] }, rules)).toBe("allow")
|
|
74
|
-
expect(Wildcard.allStructured({ head: "sed", tail: ["-i", "-n", "/./p", "myfile.txt"] }, rules)).toBe("ask")
|
|
75
|
-
})
|
package/tsconfig.json
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"$schema": "https://json.schemastore.org/tsconfig",
|
|
3
|
-
"extends": "@tsconfig/bun/tsconfig.json",
|
|
4
|
-
"compilerOptions": {
|
|
5
|
-
"jsx": "preserve",
|
|
6
|
-
"jsxImportSource": "@opentui/solid",
|
|
7
|
-
"lib": ["ESNext", "DOM", "DOM.Iterable"],
|
|
8
|
-
"types": [],
|
|
9
|
-
"noUncheckedIndexedAccess": false,
|
|
10
|
-
"customConditions": ["browser"],
|
|
11
|
-
"paths": {
|
|
12
|
-
"@/*": ["./src/*"],
|
|
13
|
-
"@tui/*": ["./src/cli/cmd/tui/*"]
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
}
|