mirror of
https://github.com/denoland/std.git
synced 2024-11-21 12:40:03 +00:00
d102a10235
* refactor: import from `@std/assert` * update
135 lines
3.5 KiB
TypeScript
135 lines
3.5 KiB
TypeScript
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
// This module is browser compatible.
|
|
|
|
import { bgGreen, bgRed, bold, gray, green, red, white } from "./styles.ts";
|
|
import type { DiffResult, DiffType } from "./types.ts";
|
|
|
|
/**
|
|
* Colors the output of assertion diffs.
|
|
*
|
|
* @param diffType Difference type, either added or removed.
|
|
* @param background If true, colors the background instead of the text.
|
|
*
|
|
* @returns A function that colors the input string.
|
|
*
|
|
* @example Usage
|
|
* ```ts
|
|
* import { createColor } from "@std/internal";
|
|
* import { assertEquals } from "@std/assert";
|
|
* import { bold, green, red, white } from "@std/fmt/colors";
|
|
*
|
|
* assertEquals(createColor("added")("foo"), green(bold("foo")));
|
|
* assertEquals(createColor("removed")("foo"), red(bold("foo")));
|
|
* assertEquals(createColor("common")("foo"), white("foo"));
|
|
* ```
|
|
*/
|
|
export function createColor(
|
|
diffType: DiffType,
|
|
/**
|
|
* TODO(@littledivy): Remove this when we can detect true color terminals. See
|
|
* https://github.com/denoland/deno_std/issues/2575.
|
|
*/
|
|
background = false,
|
|
): (s: string) => string {
|
|
switch (diffType) {
|
|
case "added":
|
|
return (s) => background ? bgGreen(white(s)) : green(bold(s));
|
|
case "removed":
|
|
return (s) => background ? bgRed(white(s)) : red(bold(s));
|
|
default:
|
|
return white;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Prefixes `+` or `-` in diff output.
|
|
*
|
|
* @param diffType Difference type, either added or removed
|
|
*
|
|
* @returns A string representing the sign.
|
|
*
|
|
* @example Usage
|
|
* ```ts
|
|
* import { createSign } from "@std/internal";
|
|
* import { assertEquals } from "@std/assert";
|
|
*
|
|
* assertEquals(createSign("added"), "+ ");
|
|
* assertEquals(createSign("removed"), "- ");
|
|
* assertEquals(createSign("common"), " ");
|
|
* ```
|
|
*/
|
|
export function createSign(diffType: DiffType): string {
|
|
switch (diffType) {
|
|
case "added":
|
|
return "+ ";
|
|
case "removed":
|
|
return "- ";
|
|
default:
|
|
return " ";
|
|
}
|
|
}
|
|
|
|
/** Options for {@linkcode buildMessage}. */
|
|
export interface BuildMessageOptions {
|
|
/**
|
|
* Whether to output the diff as a single string.
|
|
*
|
|
* @default {false}
|
|
*/
|
|
stringDiff?: boolean;
|
|
}
|
|
|
|
/**
|
|
* Builds a message based on the provided diff result.
|
|
*
|
|
* @param diffResult The diff result array.
|
|
* @param options Optional parameters for customizing the message.
|
|
*
|
|
* @returns An array of strings representing the built message.
|
|
*
|
|
* @example Usage
|
|
* ```ts no-assert
|
|
* import { diffStr, buildMessage } from "@std/internal";
|
|
*
|
|
* const diffResult = diffStr("Hello, world!", "Hello, world");
|
|
*
|
|
* console.log(buildMessage(diffResult));
|
|
* // [
|
|
* // "",
|
|
* // "",
|
|
* // " [Diff] Actual / Expected",
|
|
* // "",
|
|
* // "",
|
|
* // "- Hello, world!",
|
|
* // "+ Hello, world",
|
|
* // "",
|
|
* // ]
|
|
* ```
|
|
*/
|
|
export function buildMessage(
|
|
diffResult: ReadonlyArray<DiffResult<string>>,
|
|
options: BuildMessageOptions = {},
|
|
): string[] {
|
|
const { stringDiff = false } = options;
|
|
const messages = [
|
|
"",
|
|
"",
|
|
` ${gray(bold("[Diff]"))} ${red(bold("Actual"))} / ${
|
|
green(bold("Expected"))
|
|
}`,
|
|
"",
|
|
"",
|
|
];
|
|
const diffMessages = diffResult.map((result) => {
|
|
const color = createColor(result.type);
|
|
const line = result.details?.map((detail) =>
|
|
detail.type !== "common"
|
|
? createColor(detail.type, true)(detail.value)
|
|
: detail.value
|
|
).join("") ?? result.value;
|
|
return color(`${createSign(result.type)}${line}`);
|
|
});
|
|
messages.push(...(stringDiff ? [diffMessages.join("")] : diffMessages), "");
|
|
return messages;
|
|
}
|