|
| 1 | +import test from 'ava'; |
1 | 2 | import {promises as fs, constants as fsConstants} from 'fs'; |
2 | 3 | import * as path from 'path'; |
3 | | -import test from 'ava'; |
4 | 4 | import sinon from 'sinon'; |
5 | 5 | import {OutputOptions, rollup, RollupOutput} from 'rollup'; |
6 | 6 | import * as sassJs from 'sass'; |
7 | | -import sass from '../src/index'; |
8 | | -import {SassOptions} from "../src/types"; |
9 | | -import {error} from "../src/utils"; |
10 | 7 | import postcss from "postcss"; |
11 | 8 | import {extractICSS} from "icss-utils"; |
12 | 9 |
|
| 10 | +import sass from "../src/index"; |
| 11 | +import { SassOptions } from "../src/types"; |
| 12 | + |
13 | 13 | const repoRoot = path.join(__dirname, '../'), |
14 | 14 |
|
15 | 15 | tmpDir = path.join(repoRoot, '.tests-output/'), |
@@ -86,6 +86,22 @@ test('should import *.scss and *.sass files', async t => { |
86 | 86 | t.true([expectA, expectB, expectC].every(xs => rslt.includes(xs))); |
87 | 87 | }); |
88 | 88 |
|
| 89 | +test("should import *.scss and *.sass files with default configuration", async (t) => { |
| 90 | + const outputBundle = await rollup({ |
| 91 | + input: "test/fixtures/basic/index.js", |
| 92 | + plugins: [ |
| 93 | + sass(), |
| 94 | + ], |
| 95 | + }), |
| 96 | + { output } = await outputBundle.generate({ |
| 97 | + format: "es", |
| 98 | + file: path.join(tmpDir, "import_scss_and_sass_default_options.js"), |
| 99 | + }), |
| 100 | + rslt = squash(unwrap(output)); |
| 101 | + |
| 102 | + t.snapshot(rslt) |
| 103 | +}); |
| 104 | + |
89 | 105 | test('should compress the dest CSS', async t => { |
90 | 106 | const outputBundle = await rollup({ |
91 | 107 | ...baseConfig, |
@@ -152,8 +168,51 @@ test('should insert CSS into head tag', async t => { |
152 | 168 | }), |
153 | 169 | {output} = await outputBundle.generate(generateOptions); |
154 | 170 |
|
155 | | - t.true(unwrap(output).includes('___$insertStyle("body{color:red}");')); |
156 | | - t.true(unwrap(output).includes('___$insertStyle("body{color:green}");')); |
| 171 | + t.snapshot(unwrap(output)); |
| 172 | +}); |
| 173 | + |
| 174 | +test("should generate chunks with import insertStyle when `insert` is true", async (t) => { |
| 175 | + const outputBundle = await rollup({ |
| 176 | + input: { |
| 177 | + entryA: "test/fixtures/multiple-entry-points/entryA.js", |
| 178 | + entryB: "test/fixtures/multiple-entry-points/entryB.js", |
| 179 | + }, |
| 180 | + plugins: [ |
| 181 | + sass({ |
| 182 | + insert: true, |
| 183 | + options: sassOptions, |
| 184 | + }), |
| 185 | + ], |
| 186 | + output: { |
| 187 | + preserveModules: true, |
| 188 | + preserveModulesRoot: "src", |
| 189 | + }, |
| 190 | + external: [/\/insertStyle\.js$/], |
| 191 | + }); |
| 192 | + |
| 193 | + const { output } = await outputBundle.generate(generateOptions); |
| 194 | + |
| 195 | + t.is(output.length, 2, "has 2 chunks"); |
| 196 | + t.true( |
| 197 | + output.every( |
| 198 | + (outputItem) => { |
| 199 | + if (outputItem.type === "chunk") { |
| 200 | + const insertStyleImportsCount = outputItem.imports.filter((it) => |
| 201 | + it.includes("/insertStyle.js") |
| 202 | + ).length; |
| 203 | + return insertStyleImportsCount === 1; |
| 204 | + } |
| 205 | + // if is an assets there is no need to check imports |
| 206 | + return true; |
| 207 | + } |
| 208 | + ), |
| 209 | + "each chunk must include insertStyle once" |
| 210 | + ); |
| 211 | + |
| 212 | + // outputBundle.write({ |
| 213 | + // format: 'es', |
| 214 | + // dir: path.join(tmpDir, 'insert-style-preserve-modules'), |
| 215 | + // }); |
157 | 216 | }); |
158 | 217 |
|
159 | 218 | test('should support output as function', async t => { |
|
0 commit comments