首页/测试 & QA/migrate-to-shoehorn
M

migrate-to-shoehorn

by @mattpocockv1.0.0
4.1(20)

将测试代码中的TypeScript as断言替换为类型安全的shoehorn模式,提升测试可维护性和类型安全性

testingtypescripttype-safetytest-automationcode-qualityGitHub
安装方式
npx skills add mattpocock/skills --skill migrate-to-shoehorn
compare_arrows

Before / After 效果对比

1
使用前

使用as断言时类型错误被掩盖,测试通过但运行时崩溃,排查困难且耗时

使用后

shoehorn提供类型安全替代方案,编译期捕获类型错误,测试更可靠可维护

description SKILL.md

migrate-to-shoehorn

Migrate to Shoehorn

Why shoehorn?

shoehorn lets you pass partial data in tests while keeping TypeScript happy. It replaces as assertions with type-safe alternatives.

Test code only. Never use shoehorn in production code.

Problems with as in tests:

  • Trained not to use it

  • Must manually specify target type

  • Double-as (as unknown as Type) for intentionally wrong data

Install

npm i @total-typescript/shoehorn

Migration patterns

Large objects with few needed properties

Before:

type Request = {
  body: { id: string };
  headers: Record<string, string>;
  cookies: Record<string, string>;
  // ...20 more properties
};

it("gets user by id", () => {
  // Only care about body.id but must fake entire Request
  getUser({
    body: { id: "123" },
    headers: {},
    cookies: {},
    // ...fake all 20 properties
  });
});

After:

import { fromPartial } from "@total-typescript/shoehorn";

it("gets user by id", () => {
  getUser(
    fromPartial({
      body: { id: "123" },
    }),
  );
});

as TypefromPartial()

Before:

getUser({ body: { id: "123" } } as Request);

After:

import { fromPartial } from "@total-typescript/shoehorn";

getUser(fromPartial({ body: { id: "123" } }));

as unknown as TypefromAny()

Before:

getUser({ body: { id: 123 } } as unknown as Request); // wrong type on purpose

After:

import { fromAny } from "@total-typescript/shoehorn";

getUser(fromAny({ body: { id: 123 } }));

When to use each

Function Use case

fromPartial() Pass partial data that still type-checks

fromAny() Pass intentionally wrong data (keeps autocomplete)

fromExact() Force full object (swap with fromPartial later)

Workflow

Gather requirements - ask user:

What test files have as assertions causing problems?

  • Are they dealing with large objects where only some properties matter?

  • Do they need to pass intentionally wrong data for error testing?

Install and migrate:

Install: npm i @total-typescript/shoehorn

  • Find test files with as assertions: grep -r " as [A-Z]" --include="*.test.ts" --include="*.spec.ts"

  • Replace as Type with fromPartial()

  • Replace as unknown as Type with fromAny()

  • Add imports from @total-typescript/shoehorn

  • Run type check to verify

Weekly Installs279Repositorymattpocock/skillsGitHub Stars4.6KFirst SeenFeb 13, 2026Security AuditsGen Agent Trust HubFailSocketPassSnykPassInstalled onopencode260codex257gemini-cli256github-copilot251kimi-cli250amp250

forum用户评价 (0)

发表评价

效果
易用性
文档
兼容性

暂无评价,来写第一条吧

统计数据

安装量545
评分4.1 / 5.0
版本1.0.0
更新日期2026年3月20日
对比案例1 组

用户评分

4.1(20)
5
0%
4
0%
3
0%
2
0%
1
0%

为此 Skill 评分

0.0

兼容平台

🔧Claude Code

时间线

创建2026年3月20日
最后更新2026年3月20日