kunkun/packages/api/__tests__/verify-package-export.test.ts
Huakun Shen e4d1441d73
Feature: support npm extension publish (#62)
* feat: npm package registry API

* refactor: move package registry files

* refactor: move jsr and npm api to a new package

* ci: add verify-package-export

* test: implement tests for npm package validation as kunkun extension

* chore: add missing dep for package-registry pkg

* feat: make provenance an optional input for npm validation function

* ci: add verify-package-export as dev dep to 2 packages that uses it

* feat: add rekor log API, and return commit from jsr & npm package in validation function

* feat: return github repo info from validation function of jsr and npm

* feat: extend ExtPublishMetadata to include optional GitHub repository details

* fix: eslint for ui package

* refactor: format desktop

* fix: eslint errors in desktop

* format: all code

* ci: add lint to CI

* feat: add more info to validation function returned from package-registry npm jsr

* pnpm lock

* feat: add 2 more variables to supabase extension metadata model

* format

* feat: add provenance card

* feat: add workflow path to ExtPublishMetadata and jsr/npm validation

* update provenance

* feat: make store extension and provenance more responsive

* chore: add globals to ui package

* fix: remove unnecessary any to fix eslint

* fix: svg sanitize

* chore: add @typescript-eslint/eslint-plugin to ui package to fix eslint

* fix: update eslint dep to fix error

* fix: try fixing eslint

* fix: update eslint configuration for improved compatibility

* chore: add globals package and update README for Discord invite

* fix: update eslint rules and upgrade typescript-eslint dependency

- Disabled additional eslint rules to resolve errors:
  - @typescript-eslint/no-unused-expressions
  - svelte/no-inner-declarations
- Upgraded typescript-eslint from version 8.19.1 to 8.20.0 for improved compatibility.

* update pnpm lock

---------

Co-authored-by: Huakun Shen <huaukun.shen@huakunshen.com>
2025-01-16 06:00:07 -05:00

43 lines
1.5 KiB
TypeScript

import path from "path"
import { describe, expect, test } from "bun:test"
import madge from "madge"
import * as v from "valibot"
import { exports } from "../package.json"
const buildEntries: string[] = Object.entries(exports).filter((e) => typeof e === "string")
describe("Verify Bundled Package", () => {
test("Test Circular Dependency", async () => {
const pkgRoot = path.join(__dirname, "..")
const paths = buildEntries.map((p) => path.join(pkgRoot, p)).map((p) => path.resolve(p))
// expect each paths to exist
paths.forEach(async (p) => {
expect(await Bun.file(p).exists()).toBe(true)
const madgeRes = await madge(p)
expect(madgeRes.circular()).toEqual([])
})
})
test("Verify Package Export Path", async () => {
const pkgRoot = path.join(__dirname, "..")
const pkgJsonPath = path.join(pkgRoot, "package.json")
const file = Bun.file(pkgJsonPath)
const pkgJson = await file.json()
const exports = pkgJson["exports"]
Object.entries(exports).forEach(async ([key, value]) => {
const exportPaths = v.parse(v.union([v.record(v.string(), v.string()), v.string()]), value)
if (typeof exportPaths === "string") {
// special case for "./package.json"
const resolvedPath = path.join(pkgRoot, exportPaths)
console.log("resolvedPath", resolvedPath)
expect(await Bun.file(resolvedPath).exists()).toBe(true)
} else {
Object.values(exportPaths).forEach(async (_path: string) => {
const resolvedPath = path.join(pkgRoot, _path)
expect(await Bun.file(resolvedPath).exists()).toBe(true)
})
}
})
})
})