From 681247bc85df9d60956cd11bd1ad665c32b5d989 Mon Sep 17 00:00:00 2001 From: Nick Hudkins Date: Thu, 28 Apr 2022 12:19:59 -0400 Subject: [PATCH 1/4] Introduces `importOrderBuiltinModulesToTop` for Node Builtins #71 # Conflicts: # src/utils/__tests__/get-sorted-nodes.spec.ts # src/utils/get-sorted-nodes.ts --- README.md | 10 ++++ src/constants.ts | 2 + src/preprocessor.ts | 2 + src/types.ts | 2 + .../get-all-comments-from-nodes.spec.ts | 1 + src/utils/__tests__/get-code-from-ast.spec.ts | 1 + .../get-import-nodes-matched-group.spec.ts | 2 - .../get-sorted-nodes-by-import-order.spec.ts | 50 +++++++++++++++++++ src/utils/__tests__/get-sorted-nodes.spec.ts | 4 ++ .../remove-nodes-from-original-code.spec.ts | 1 + src/utils/get-sorted-nodes-by-import-order.ts | 11 +++- 11 files changed, 83 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index d35975d..af2832f 100644 --- a/README.md +++ b/README.md @@ -213,6 +213,16 @@ with options as a JSON string of the plugin array: importOrderParserPlugins: [] ``` + +#### `importOrderBuiltinModulesToTop` + +**type**: `boolean` + +**default value:** `false` + +A boolean value to enable sorting of builtins to the top of all import groups. + + ### How does import sort work ? The plugin extracts the imports which are defined in `importOrder`. These imports are considered as _local imports_. diff --git a/src/constants.ts b/src/constants.ts index b1edca6..45c6185 100644 --- a/src/constants.ts +++ b/src/constants.ts @@ -1,5 +1,6 @@ import { ParserPlugin } from '@babel/parser'; import { expressionStatement, stringLiteral } from '@babel/types'; +import { builtinModules } from 'module'; export const flow: ParserPlugin = 'flow'; export const typescript: ParserPlugin = 'typescript'; @@ -15,6 +16,7 @@ export const chunkTypeOther = 'other'; * where the not matched imports should be placed */ export const THIRD_PARTY_MODULES_SPECIAL_WORD = ''; +export const BUILTIN_MODULES = builtinModules.join('|'); const PRETTIER_PLUGIN_SORT_IMPORTS_NEW_LINE = 'PRETTIER_PLUGIN_SORT_IMPORTS_NEW_LINE'; diff --git a/src/preprocessor.ts b/src/preprocessor.ts index a636ce1..285c063 100644 --- a/src/preprocessor.ts +++ b/src/preprocessor.ts @@ -15,6 +15,7 @@ export function preprocessor(code: string, options: PrettierOptions): string { importOrderSeparation, importOrderGroupNamespaceSpecifiers, importOrderSortSpecifiers, + importOrderBuiltinModulesToTop, } = options; const importNodes: ImportDeclaration[] = []; @@ -50,6 +51,7 @@ export function preprocessor(code: string, options: PrettierOptions): string { importOrderSeparation, importOrderGroupNamespaceSpecifiers, importOrderSortSpecifiers, + importOrderBuiltinModulesToTop, }); return getCodeFromAst(allImports, code, directives, interpreter); diff --git a/src/types.ts b/src/types.ts index b4b52ac..8e8567c 100644 --- a/src/types.ts +++ b/src/types.ts @@ -4,6 +4,7 @@ import { RequiredOptions } from 'prettier'; export interface PrettierOptions extends RequiredOptions { importOrder: string[]; importOrderCaseInsensitive: boolean; + importOrderBuiltinModulesToTop: boolean; // should be of type ParserPlugin from '@babel/parser' but prettier does not support nested arrays in options importOrderParserPlugins: string[]; importOrderSeparation: boolean; @@ -24,6 +25,7 @@ export type GetSortedNodes = ( options: Pick< PrettierOptions, | 'importOrder' + | 'importOrderBuiltinModulesToTop' | 'importOrderCaseInsensitive' | 'importOrderSeparation' | 'importOrderGroupNamespaceSpecifiers' diff --git a/src/utils/__tests__/get-all-comments-from-nodes.spec.ts b/src/utils/__tests__/get-all-comments-from-nodes.spec.ts index ff8f156..1d543aa 100644 --- a/src/utils/__tests__/get-all-comments-from-nodes.spec.ts +++ b/src/utils/__tests__/get-all-comments-from-nodes.spec.ts @@ -14,6 +14,7 @@ const getSortedImportNodes = (code: string, options?: ParserOptions) => { importOrderSeparation: false, importOrderGroupNamespaceSpecifiers: false, importOrderSortSpecifiers: false, + importOrderBuiltinModulesToTop: false, }); }; diff --git a/src/utils/__tests__/get-code-from-ast.spec.ts b/src/utils/__tests__/get-code-from-ast.spec.ts index d64a7d2..e1209fe 100644 --- a/src/utils/__tests__/get-code-from-ast.spec.ts +++ b/src/utils/__tests__/get-code-from-ast.spec.ts @@ -21,6 +21,7 @@ import a from 'a'; importOrderSeparation: false, importOrderGroupNamespaceSpecifiers: false, importOrderSortSpecifiers: false, + importOrderBuiltinModulesToTop: false, }); const formatted = getCodeFromAst(sortedNodes, code, [], undefined); expect(format(formatted, { parser: 'babel' })).toEqual( diff --git a/src/utils/__tests__/get-import-nodes-matched-group.spec.ts b/src/utils/__tests__/get-import-nodes-matched-group.spec.ts index 2912cb0..b7dd837 100644 --- a/src/utils/__tests__/get-import-nodes-matched-group.spec.ts +++ b/src/utils/__tests__/get-import-nodes-matched-group.spec.ts @@ -1,5 +1,3 @@ -import { THIRD_PARTY_MODULES_SPECIAL_WORD } from '../../constants'; -import { ImportGroups } from '../../types'; import { getImportNodes } from '../get-import-nodes'; import { getImportNodesMatchedGroup } from '../get-import-nodes-matched-group'; diff --git a/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts b/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts index d488c92..71e3b73 100644 --- a/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts +++ b/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts @@ -14,6 +14,7 @@ import { tC, tA, tB } from 't'; import k, { kE, kB } from 'k'; import * as a from 'a'; import * as x from 'x'; +import path from 'path'; import BY from 'BY'; import Ba from 'Ba'; import XY from 'XY'; @@ -28,6 +29,7 @@ test('it returns all sorted nodes', () => { importOrderSeparation: false, importOrderGroupNamespaceSpecifiers: false, importOrderSortSpecifiers: false, + importOrderBuiltinModulesToTop: false, }) as ImportDeclaration[]; expect(getSortedNodesNames(sorted)).toEqual([ @@ -39,6 +41,7 @@ test('it returns all sorted nodes', () => { 'c', 'g', 'k', + 'path', 't', 'x', 'z', @@ -58,6 +61,7 @@ test('it returns all sorted nodes', () => { ['c', 'cD'], ['g'], ['k', 'kE', 'kB'], + ['path'], ['tC', 'tA', 'tB'], ['x'], ['z'], @@ -72,6 +76,7 @@ test('it returns all sorted nodes case-insensitive', () => { importOrderSeparation: false, importOrderGroupNamespaceSpecifiers: false, importOrderSortSpecifiers: false, + importOrderBuiltinModulesToTop: false, }) as ImportDeclaration[]; expect(getSortedNodesNames(sorted)).toEqual([ @@ -81,6 +86,7 @@ test('it returns all sorted nodes case-insensitive', () => { 'c', 'g', 'k', + 'path', 't', 'x', 'Xa', @@ -100,6 +106,7 @@ test('it returns all sorted nodes case-insensitive', () => { ['c', 'cD'], ['g'], ['k', 'kE', 'kB'], + ['path'], ['tC', 'tA', 'tB'], ['x'], ['Xa'], @@ -116,6 +123,7 @@ test('it returns all sorted nodes with sort order', () => { importOrderSeparation: false, importOrderGroupNamespaceSpecifiers: false, importOrderSortSpecifiers: false, + importOrderBuiltinModulesToTop: false, }) as ImportDeclaration[]; expect(getSortedNodesNames(sorted)).toEqual([ @@ -123,6 +131,7 @@ test('it returns all sorted nodes with sort order', () => { 'Xa', 'c', 'g', + 'path', 'x', 'z', 'a', @@ -142,6 +151,7 @@ test('it returns all sorted nodes with sort order', () => { ['Xa'], ['c', 'cD'], ['g'], + ['path'], ['x'], ['z'], ['a'], @@ -160,10 +170,12 @@ test('it returns all sorted nodes with sort order case-insensitive', () => { importOrderSeparation: false, importOrderGroupNamespaceSpecifiers: false, importOrderSortSpecifiers: false, + importOrderBuiltinModulesToTop: false, }) as ImportDeclaration[]; expect(getSortedNodesNames(sorted)).toEqual([ 'c', 'g', + 'path', 'x', 'Xa', 'XY', @@ -183,6 +195,7 @@ test('it returns all sorted nodes with sort order case-insensitive', () => { ).toEqual([ ['c', 'cD'], ['g'], + ['path'], ['x'], ['Xa'], ['XY'], @@ -203,12 +216,14 @@ test('it returns all sorted import nodes with sorted import specifiers', () => { importOrderSeparation: false, importOrderGroupNamespaceSpecifiers: false, importOrderSortSpecifiers: true, + importOrderBuiltinModulesToTop: false, }) as ImportDeclaration[]; expect(getSortedNodesNames(sorted)).toEqual([ 'XY', 'Xa', 'c', 'g', + 'path', 'x', 'z', 'a', @@ -228,6 +243,7 @@ test('it returns all sorted import nodes with sorted import specifiers', () => { ['Xa'], ['c', 'cD'], ['g'], + ['path'], ['x'], ['z'], ['a'], @@ -246,10 +262,12 @@ test('it returns all sorted import nodes with sorted import specifiers with case importOrderSeparation: false, importOrderGroupNamespaceSpecifiers: false, importOrderSortSpecifiers: true, + importOrderBuiltinModulesToTop: false, }) as ImportDeclaration[]; expect(getSortedNodesNames(sorted)).toEqual([ 'c', 'g', + 'path', 'x', 'Xa', 'XY', @@ -269,6 +287,7 @@ test('it returns all sorted import nodes with sorted import specifiers with case ).toEqual([ ['c', 'cD'], ['g'], + ['path'], ['x'], ['Xa'], ['XY'], @@ -289,6 +308,7 @@ test('it returns all sorted nodes with custom third party modules', () => { importOrderCaseInsensitive: true, importOrderGroupNamespaceSpecifiers: false, importOrderSortSpecifiers: false, + importOrderBuiltinModulesToTop: false, }) as ImportDeclaration[]; expect(getSortedNodesNames(sorted)).toEqual([ 'a', @@ -296,6 +316,7 @@ test('it returns all sorted nodes with custom third party modules', () => { 'BY', 'c', 'g', + 'path', 'x', 'Xa', 'XY', @@ -313,6 +334,7 @@ test('it returns all sorted nodes with namespace specifiers at the top', () => { importOrderSeparation: false, importOrderGroupNamespaceSpecifiers: true, importOrderSortSpecifiers: false, + importOrderBuiltinModulesToTop: false, }) as ImportDeclaration[]; expect(getSortedNodesNames(sorted)).toEqual([ @@ -325,7 +347,35 @@ test('it returns all sorted nodes with namespace specifiers at the top', () => { 'c', 'g', 'k', + 'path', 't', 'z', ]); }); + +test('it returns all sorted nodes with builtin specifiers at the top, ', () => { + const result = getImportNodes(code); + const sorted = getSortedNodes(result, { + importOrder: [], + importOrderCaseInsensitive: false, + importOrderSeparation: false, + importOrderGroupNamespaceSpecifiers: false, + importOrderSortSpecifiers: false, + importOrderBuiltinModulesToTop: true, + }) as ImportDeclaration[]; + + expect(getSortedNodesNames(sorted)).toEqual([ + 'path', + 'BY', + 'Ba', + 'XY', + 'Xa', + 'a', + 'c', + 'g', + 'k', + 't', + 'x', + 'z', + ]); +}); diff --git a/src/utils/__tests__/get-sorted-nodes.spec.ts b/src/utils/__tests__/get-sorted-nodes.spec.ts index e8cc8c6..63d017f 100644 --- a/src/utils/__tests__/get-sorted-nodes.spec.ts +++ b/src/utils/__tests__/get-sorted-nodes.spec.ts @@ -17,6 +17,7 @@ import "se4"; import "se1"; import * as a from 'a'; import * as x from 'x'; +import path from 'path'; import BY from 'BY'; import Ba from 'Ba'; import XY from 'XY'; @@ -32,6 +33,7 @@ test('it returns all sorted nodes, preserving the order side effect nodes', () = importOrderSeparation: false, importOrderGroupNamespaceSpecifiers: false, importOrderSortSpecifiers: false, + importOrderBuiltinModulesToTop: false, }) as ImportDeclaration[]; expect(getSortedNodesNames(sorted)).toEqual([ @@ -48,6 +50,7 @@ test('it returns all sorted nodes, preserving the order side effect nodes', () = 'XY', 'Xa', 'a', + 'path', 'x', 'se2', ]); @@ -71,6 +74,7 @@ test('it returns all sorted nodes, preserving the order side effect nodes', () = ['XY'], ['Xa'], ['a'], + ['path'], ['x'], [], ]); diff --git a/src/utils/__tests__/remove-nodes-from-original-code.spec.ts b/src/utils/__tests__/remove-nodes-from-original-code.spec.ts index 978f6e1..40c81d4 100644 --- a/src/utils/__tests__/remove-nodes-from-original-code.spec.ts +++ b/src/utils/__tests__/remove-nodes-from-original-code.spec.ts @@ -27,6 +27,7 @@ test('it should remove nodes from the original code', () => { importOrderSeparation: false, importOrderGroupNamespaceSpecifiers: false, importOrderSortSpecifiers: false, + importOrderBuiltinModulesToTop: false, }); const allCommentsFromImports = getAllCommentsFromNodes(sortedNodes); diff --git a/src/utils/get-sorted-nodes-by-import-order.ts b/src/utils/get-sorted-nodes-by-import-order.ts index d8ddd62..ed462dd 100644 --- a/src/utils/get-sorted-nodes-by-import-order.ts +++ b/src/utils/get-sorted-nodes-by-import-order.ts @@ -1,6 +1,10 @@ import { clone } from 'lodash'; -import { THIRD_PARTY_MODULES_SPECIAL_WORD, newLineNode } from '../constants'; +import { + BUILTIN_MODULES, + THIRD_PARTY_MODULES_SPECIAL_WORD, + newLineNode, +} from '../constants'; import { naturalSort } from '../natural-sort'; import { GetSortedNodes, ImportGroups, ImportOrLine } from '../types'; import { getImportNodesMatchedGroup } from './get-import-nodes-matched-group'; @@ -22,6 +26,7 @@ export const getSortedNodesByImportOrder: GetSortedNodes = (nodes, options) => { importOrderSeparation, importOrderSortSpecifiers, importOrderGroupNamespaceSpecifiers, + importOrderBuiltinModulesToTop, } = options; const originalNodes = nodes.map(clone); @@ -31,6 +36,10 @@ export const getSortedNodesByImportOrder: GetSortedNodes = (nodes, options) => { importOrder = [THIRD_PARTY_MODULES_SPECIAL_WORD, ...importOrder]; } + if (importOrderBuiltinModulesToTop) { + importOrder = [BUILTIN_MODULES, ...importOrder]; + } + const importOrderGroups = importOrder.reduce( (groups, regexp) => ({ ...groups, From b20c23d1de0ecbb927d8ee1df33603a27d33a76e Mon Sep 17 00:00:00 2001 From: Ian VanSchooten Date: Thu, 12 May 2022 08:25:11 -0400 Subject: [PATCH 2/4] Test for node: prefixed modules --- .../get-sorted-nodes-by-import-order.spec.ts | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts b/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts index 71e3b73..dba12bb 100644 --- a/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts +++ b/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts @@ -15,6 +15,7 @@ import k, { kE, kB } from 'k'; import * as a from 'a'; import * as x from 'x'; import path from 'path'; +import url from 'node:url'; import BY from 'BY'; import Ba from 'Ba'; import XY from 'XY'; @@ -41,6 +42,7 @@ test('it returns all sorted nodes', () => { 'c', 'g', 'k', + 'node:url', 'path', 't', 'x', @@ -61,6 +63,7 @@ test('it returns all sorted nodes', () => { ['c', 'cD'], ['g'], ['k', 'kE', 'kB'], + ['url'], ['path'], ['tC', 'tA', 'tB'], ['x'], @@ -86,6 +89,7 @@ test('it returns all sorted nodes case-insensitive', () => { 'c', 'g', 'k', + 'node:url', 'path', 't', 'x', @@ -106,6 +110,7 @@ test('it returns all sorted nodes case-insensitive', () => { ['c', 'cD'], ['g'], ['k', 'kE', 'kB'], + ['url'], ['path'], ['tC', 'tA', 'tB'], ['x'], @@ -131,6 +136,7 @@ test('it returns all sorted nodes with sort order', () => { 'Xa', 'c', 'g', + 'node:url', 'path', 'x', 'z', @@ -151,6 +157,7 @@ test('it returns all sorted nodes with sort order', () => { ['Xa'], ['c', 'cD'], ['g'], + ['url'], ['path'], ['x'], ['z'], @@ -175,6 +182,7 @@ test('it returns all sorted nodes with sort order case-insensitive', () => { expect(getSortedNodesNames(sorted)).toEqual([ 'c', 'g', + 'node:url', 'path', 'x', 'Xa', @@ -195,6 +203,7 @@ test('it returns all sorted nodes with sort order case-insensitive', () => { ).toEqual([ ['c', 'cD'], ['g'], + ['url'], ['path'], ['x'], ['Xa'], @@ -223,6 +232,7 @@ test('it returns all sorted import nodes with sorted import specifiers', () => { 'Xa', 'c', 'g', + 'node:url', 'path', 'x', 'z', @@ -243,6 +253,7 @@ test('it returns all sorted import nodes with sorted import specifiers', () => { ['Xa'], ['c', 'cD'], ['g'], + ['url'], ['path'], ['x'], ['z'], @@ -267,6 +278,7 @@ test('it returns all sorted import nodes with sorted import specifiers with case expect(getSortedNodesNames(sorted)).toEqual([ 'c', 'g', + 'node:url', 'path', 'x', 'Xa', @@ -287,6 +299,7 @@ test('it returns all sorted import nodes with sorted import specifiers with case ).toEqual([ ['c', 'cD'], ['g'], + ['url'], ['path'], ['x'], ['Xa'], @@ -316,6 +329,7 @@ test('it returns all sorted nodes with custom third party modules', () => { 'BY', 'c', 'g', + 'node:url', 'path', 'x', 'Xa', @@ -347,6 +361,7 @@ test('it returns all sorted nodes with namespace specifiers at the top', () => { 'c', 'g', 'k', + 'node:url', 'path', 't', 'z', @@ -365,6 +380,7 @@ test('it returns all sorted nodes with builtin specifiers at the top, ', () => { }) as ImportDeclaration[]; expect(getSortedNodesNames(sorted)).toEqual([ + 'node:url', 'path', 'BY', 'Ba', From 605f2f08687b68ca36e7ec38181fba690534e2cb Mon Sep 17 00:00:00 2001 From: Ian VanSchooten Date: Thu, 12 May 2022 08:30:38 -0400 Subject: [PATCH 3/4] Test combination of builtins and custom order --- .../get-sorted-nodes-by-import-order.spec.ts | 27 +++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts b/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts index dba12bb..3b7f65f 100644 --- a/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts +++ b/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts @@ -395,3 +395,30 @@ test('it returns all sorted nodes with builtin specifiers at the top, ', () => { 'z', ]); }); + +test('it returns all sorted nodes with custom third party modules and builtins at top', () => { + const result = getImportNodes(code); + const sorted = getSortedNodes(result, { + importOrder: ['^a$', '', '^t$', '^k$'], + importOrderSeparation: false, + importOrderCaseInsensitive: true, + importOrderGroupNamespaceSpecifiers: false, + importOrderSortSpecifiers: false, + importOrderBuiltinModulesToTop: true, + }) as ImportDeclaration[]; + expect(getSortedNodesNames(sorted)).toEqual([ + 'node:url', + 'path', + 'a', + 'Ba', + 'BY', + 'c', + 'g', + 'x', + 'Xa', + 'XY', + 'z', + 't', + 'k', + ]); +}); From 10ea67e8714294b1f46e6ca582d2f750f6ef1c41 Mon Sep 17 00:00:00 2001 From: Ian VanSchooten Date: Thu, 12 May 2022 08:37:16 -0400 Subject: [PATCH 4/4] Add tests for namespace import from builtin submodule --- .../get-sorted-nodes-by-import-order.spec.ts | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts b/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts index 3b7f65f..c9a11a9 100644 --- a/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts +++ b/src/utils/__tests__/get-sorted-nodes-by-import-order.spec.ts @@ -16,6 +16,7 @@ import * as a from 'a'; import * as x from 'x'; import path from 'path'; import url from 'node:url'; +import * as fs from "node:fs/promises" import BY from 'BY'; import Ba from 'Ba'; import XY from 'XY'; @@ -42,6 +43,7 @@ test('it returns all sorted nodes', () => { 'c', 'g', 'k', + 'node:fs/promises', 'node:url', 'path', 't', @@ -63,6 +65,7 @@ test('it returns all sorted nodes', () => { ['c', 'cD'], ['g'], ['k', 'kE', 'kB'], + ['fs'], ['url'], ['path'], ['tC', 'tA', 'tB'], @@ -89,6 +92,7 @@ test('it returns all sorted nodes case-insensitive', () => { 'c', 'g', 'k', + 'node:fs/promises', 'node:url', 'path', 't', @@ -110,6 +114,7 @@ test('it returns all sorted nodes case-insensitive', () => { ['c', 'cD'], ['g'], ['k', 'kE', 'kB'], + ['fs'], ['url'], ['path'], ['tC', 'tA', 'tB'], @@ -136,6 +141,7 @@ test('it returns all sorted nodes with sort order', () => { 'Xa', 'c', 'g', + 'node:fs/promises', 'node:url', 'path', 'x', @@ -157,6 +163,7 @@ test('it returns all sorted nodes with sort order', () => { ['Xa'], ['c', 'cD'], ['g'], + ['fs'], ['url'], ['path'], ['x'], @@ -182,6 +189,7 @@ test('it returns all sorted nodes with sort order case-insensitive', () => { expect(getSortedNodesNames(sorted)).toEqual([ 'c', 'g', + 'node:fs/promises', 'node:url', 'path', 'x', @@ -203,6 +211,7 @@ test('it returns all sorted nodes with sort order case-insensitive', () => { ).toEqual([ ['c', 'cD'], ['g'], + ['fs'], ['url'], ['path'], ['x'], @@ -232,6 +241,7 @@ test('it returns all sorted import nodes with sorted import specifiers', () => { 'Xa', 'c', 'g', + 'node:fs/promises', 'node:url', 'path', 'x', @@ -253,6 +263,7 @@ test('it returns all sorted import nodes with sorted import specifiers', () => { ['Xa'], ['c', 'cD'], ['g'], + ['fs'], ['url'], ['path'], ['x'], @@ -278,6 +289,7 @@ test('it returns all sorted import nodes with sorted import specifiers with case expect(getSortedNodesNames(sorted)).toEqual([ 'c', 'g', + 'node:fs/promises', 'node:url', 'path', 'x', @@ -299,6 +311,7 @@ test('it returns all sorted import nodes with sorted import specifiers with case ).toEqual([ ['c', 'cD'], ['g'], + ['fs'], ['url'], ['path'], ['x'], @@ -329,6 +342,7 @@ test('it returns all sorted nodes with custom third party modules', () => { 'BY', 'c', 'g', + 'node:fs/promises', 'node:url', 'path', 'x', @@ -353,6 +367,7 @@ test('it returns all sorted nodes with namespace specifiers at the top', () => { expect(getSortedNodesNames(sorted)).toEqual([ 'a', + 'node:fs/promises', 'x', 'BY', 'Ba', @@ -380,6 +395,7 @@ test('it returns all sorted nodes with builtin specifiers at the top, ', () => { }) as ImportDeclaration[]; expect(getSortedNodesNames(sorted)).toEqual([ + 'node:fs/promises', 'node:url', 'path', 'BY', @@ -407,6 +423,7 @@ test('it returns all sorted nodes with custom third party modules and builtins a importOrderBuiltinModulesToTop: true, }) as ImportDeclaration[]; expect(getSortedNodesNames(sorted)).toEqual([ + 'node:fs/promises', 'node:url', 'path', 'a',