Files
pnpm/store/commands/test/inspecting/catFile.ts
Zoltan Kochan 187049055f chore: upgrade @typescript/native-preview to 7.0.0-dev.20260421.2 (#11332)
* chore: upgrade @typescript/native-preview to 7.0.0-dev.20260421.2

- Add explicit `types: ["node"]` to the shared tsconfig because tsgo
  20260421 no longer auto-acquires `@types/*` from `node_modules`.
- Refactor test files to explicitly import jest globals (`describe`,
  `it`, `test`, `expect`, `beforeEach`, etc.) from `@jest/globals`
  instead of relying on `@types/jest` ambient declarations. Under the
  new tsgo build, `import { jest } from '@jest/globals'` shadows the
  ambient `jest` namespace, breaking `@types/jest`'s `declare var
  describe: jest.Describe;` globals.
- Add `@jest/globals` to each package's devDependencies where tests
  now import from it, and add `@types/node` to packages that need it
  but were relying on hoisted resolution.
- Replace `fail()` calls with `throw new Error(...)` since `fail` is
  no longer globally available.

* chore: fix remaining tsgo type-strictness errors

- Strip `as <PnpmType>` casts on objects passed to toMatchObject /
  toStrictEqual / toEqual; @jest/globals rejects the typed objects
  (which include AsymmetricMatchers) vs. the repo-specific type.
- Type `jest.fn<...>()` explicitly where the mock's signature matters
  for toHaveBeenCalledWith.
- Replace `beforeEach(() => X)` with `beforeEach(() => { X })` so the
  return value is void, as the stricter jest typing requires.
- Use `expect.objectContaining({...})` in one place where the full
  expected object triggered stricter type resolution.
- Cast `prompt.mock.calls` arg through `as unknown as Record<...>[]`
  for patch.test.ts's nested-array matchers.
- Fix off-by-one `<reference path>` in pnpm/test/getConfig.test.ts
  that only surfaced now.
- Move `@jest/globals` from devDependencies to dependencies in the
  two `__utils__` packages that import it from `src/`.
- Clean up unused imports from the @jest/globals migration.

* chore: address Copilot review on #11332

- Move misplaced `@jest/globals` imports to the top import block in
  checkEngine, run.ts, and workspace/root-finder tests where the
  script dropped them below executable code.
- Replace `try { await x(); throw new Error('should have thrown') } catch`
  in bins/linker, lockfile/fs, and resolving/local-resolver tests with
  `await expect(x()).rejects.toMatchObject({...})`. The old pattern
  swallowed an unrelated `throw` if the under-test call silently
  succeeded, which would fail on the catch-block assertion with a
  misleading message.
2026-04-21 22:50:40 +02:00

207 lines
6.3 KiB
TypeScript
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
/// <reference path="../../../../__typings__/index.d.ts" />
import path from 'node:path'
import { expect, test } from '@jest/globals'
import { getConfig } from '@pnpm/config.reader'
import type { PnpmError } from '@pnpm/error'
import { prepare } from '@pnpm/prepare'
import { catFile } from '@pnpm/store.commands'
import { safeExeca as execa } from 'execa'
const pnpmBin = path.join(import.meta.dirname, '../../../../pnpm/bin/pnpm.mjs')
// cat-file
test('print hash file content', async () => {
prepare({
dependencies: {
bytes: '3.1.2',
},
})
await execa('node', [pnpmBin, 'install'])
{
const { config } = await getConfig({
cliOptions: {},
packageManager: {
name: 'pnpm',
version: '8.12.1',
},
})
const output = await catFile.handler(config as catFile.CatFileCommandOptions, ['sha512-ZF9Q82J2KaXGIXWxGC0iecrQmfa08Cs/D+e2BPzGSnOn5aCyWiJbwlMm3HqKMK6qKrBg+/u6LduS/a1mc8IsNQ=='])
expect(output).toBe(`# Bytes utility
[![NPM Version][npm-image]][npm-url]
[![NPM Downloads][downloads-image]][downloads-url]
[![Build Status][ci-image]][ci-url]
[![Test Coverage][coveralls-image]][coveralls-url]
Utility to parse a string bytes (ex: \`1TB\`) to bytes (\`1099511627776\`) and vice-versa.
## Installation
This is a [Node.js](https://nodejs.org/en/) module available through the
[npm registry](https://www.npmjs.com/). Installation is done using the
[\`npm install\` command](https://docs.npmjs.com/getting-started/installing-npm-packages-locally):
\`\`\`bash
$ npm install bytes
\`\`\`
## Usage
\`\`\`js
var bytes = require('bytes');
\`\`\`
#### bytes(numberstring value, [options]): numberstringnull
Default export function. Delegates to either \`bytes.format\` or \`bytes.parse\` based on the type of \`value\`.
**Arguments**
| Name | Type | Description |
|---------|----------|--------------------|
| value | \`number\`\`string\` | Number value to format or string value to parse |
| options | \`Object\` | Conversion options for \`format\` |
**Returns**
| Name | Type | Description |
|---------|------------------|-------------------------------------------------|
| results | \`string\`\`number\`\`null\` | Return null upon error. Numeric value in bytes, or string value otherwise. |
**Example**
\`\`\`js
bytes(1024);
// output: '1KB'
bytes('1KB');
// output: 1024
\`\`\`
#### bytes.format(number value, [options]): stringnull
Format the given value in bytes into a string. If the value is negative, it is kept as such. If it is a float, it is
rounded.
**Arguments**
| Name | Type | Description |
|---------|----------|--------------------|
| value | \`number\` | Value in bytes |
| options | \`Object\` | Conversion options |
**Options**
| Property | Type | Description |
|-------------------|--------|-----------------------------------------------------------------------------------------|
| decimalPlaces | \`number\`\`null\` | Maximum number of decimal places to include in output. Default value to \`2\`. |
| fixedDecimals | \`boolean\`\`null\` | Whether to always display the maximum number of decimal places. Default value to \`false\` |
| thousandsSeparator | \`string\`\`null\` | Example of values: \`' '\`, \`','\` and \`'.'\`... Default value to \`''\`. |
| unit | \`string\`\`null\` | The unit in which the result will be returned (B/KB/MB/GB/TB). Default value to \`''\` (which means auto detect). |
| unitSeparator | \`string\`\`null\` | Separator to use between number and unit. Default value to \`''\`. |
**Returns**
| Name | Type | Description |
|---------|------------------|-------------------------------------------------|
| results | \`string\`\`null\` | Return null upon error. String value otherwise. |
**Example**
\`\`\`js
bytes.format(1024);
// output: '1KB'
bytes.format(1000);
// output: '1000B'
bytes.format(1000, {thousandsSeparator: ' '});
// output: '1 000B'
bytes.format(1024 * 1.7, {decimalPlaces: 0});
// output: '2KB'
bytes.format(1024, {unitSeparator: ' '});
// output: '1 KB'
\`\`\`
#### bytes.parse(stringnumber value): numbernull
Parse the string value into an integer in bytes. If no unit is given, or \`value\`
is a number, it is assumed the value is in bytes.
Supported units and abbreviations are as follows and are case-insensitive:
* \`b\` for bytes
* \`kb\` for kilobytes
* \`mb\` for megabytes
* \`gb\` for gigabytes
* \`tb\` for terabytes
* \`pb\` for petabytes
The units are in powers of two, not ten. This means 1kb = 1024b according to this parser.
**Arguments**
| Name | Type | Description |
|---------------|--------|--------------------|
| value | \`string\`\`number\` | String to parse, or number in bytes. |
**Returns**
| Name | Type | Description |
|---------|-------------|-------------------------|
| results | \`number\`\`null\` | Return null upon error. Value in bytes otherwise. |
**Example**
\`\`\`js
bytes.parse('1KB');
// output: 1024
bytes.parse('1024');
// output: 1024
bytes.parse(1024);
// output: 1024
\`\`\`
## License
[MIT](LICENSE)
[ci-image]: https://badgen.net/github/checks/visionmedia/bytes.js/master?label=ci
[ci-url]: https://github.com/visionmedia/bytes.js/actions?query=workflow%3Aci
[coveralls-image]: https://badgen.net/coveralls/c/github/visionmedia/bytes.js/master
[coveralls-url]: https://coveralls.io/r/visionmedia/bytes.js?branch=master
[downloads-image]: https://badgen.net/npm/dm/bytes
[downloads-url]: https://npmjs.org/package/bytes
[npm-image]: https://badgen.net/npm/v/bytes
[npm-url]: https://npmjs.org/package/bytes
`)
}
})
test('print hash file content error', async () => {
let err!: PnpmError
try {
const { config } = await getConfig({
cliOptions: {},
packageManager: {
name: 'pnpm',
version: '8.12.1',
},
})
await catFile.handler(config as catFile.CatFileCommandOptions, ['sha512-ZF9Q82J2KaXGIXWxGC0iecrQmfa08'])
} catch (_err: any) { // eslint-disable-line
err = _err
}
expect(err.code).toBe('ERR_PNPM_INVALID_HASH')
expect(err.message).toBe('Corresponding hash file not found')
})