mirror of
https://github.com/gohugoio/hugo.git
synced 2025-08-11 15:19:10 -04:00

To avoid breaking existing setup and to make a better default option, the option is now `disableInlineImports` (default false). Fixes #13719
137 lines
3.4 KiB
Go
137 lines
3.4 KiB
Go
// Copyright 2024 The Hugo Authors. All rights reserved.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package cssjs_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/bep/logg"
|
|
qt "github.com/frankban/quicktest"
|
|
"github.com/gohugoio/hugo/htesting"
|
|
"github.com/gohugoio/hugo/hugolib"
|
|
)
|
|
|
|
func TestTailwindV4Basic(t *testing.T) {
|
|
if !htesting.IsCI() {
|
|
t.Skip("Skip long running test when running locally")
|
|
}
|
|
|
|
files := `
|
|
-- hugo.toml --
|
|
-- package.json --
|
|
{
|
|
"license": "MIT",
|
|
"repository": {
|
|
"type": "git",
|
|
"url": "https://github.com/bep/hugo-starter-tailwind-basic.git"
|
|
},
|
|
"devDependencies": {
|
|
"@tailwindcss/cli": "^4.0.1",
|
|
"tailwindcss": "^4.0.1"
|
|
},
|
|
"name": "hugo-starter-tailwind-basic",
|
|
"version": "0.1.0"
|
|
}
|
|
-- assets/css/styles.css --
|
|
@import "tailwindcss";
|
|
|
|
@theme {
|
|
--font-family-display: "Satoshi", "sans-serif";
|
|
|
|
--breakpoint-3xl: 1920px;
|
|
|
|
--color-neon-pink: oklch(71.7% 0.25 360);
|
|
--color-neon-lime: oklch(91.5% 0.258 129);
|
|
--color-neon-cyan: oklch(91.3% 0.139 195.8);
|
|
}
|
|
-- layouts/index.html --
|
|
{{ $css := resources.Get "css/styles.css" | css.TailwindCSS }}
|
|
CSS: {{ $css.Content | safeCSS }}|
|
|
`
|
|
|
|
b := hugolib.NewIntegrationTestBuilder(
|
|
hugolib.IntegrationTestConfig{
|
|
T: t,
|
|
TxtarString: files,
|
|
NeedsOsFS: true,
|
|
NeedsNpmInstall: true,
|
|
LogLevel: logg.LevelInfo,
|
|
}).Build()
|
|
|
|
b.AssertFileContent("public/index.html", "/*! tailwindcss v4.")
|
|
}
|
|
|
|
func TestTailwindCSSNoInlineImportsIssue13719(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
files := `
|
|
-- hugo.toml --
|
|
disableKinds = ['page','rss','section','sitemap','taxonomy','term']
|
|
theme = 'my-theme'
|
|
|
|
[[module.mounts]]
|
|
source = 'assets'
|
|
target = 'assets'
|
|
|
|
[[module.mounts]]
|
|
source = 'other'
|
|
target = 'assets/css'
|
|
-- assets/css/main.css --
|
|
@import "tailwindcss";
|
|
|
|
@import "colors/red.css";
|
|
@import "colors/blue.css";
|
|
@import "colors/purple.css";
|
|
-- assets/css/colors/red.css --
|
|
@import "green.css";
|
|
|
|
.red {color: red;}
|
|
-- assets/css/colors/green.css --
|
|
.green {color: green;}
|
|
-- themes/my-theme/assets/css/colors/blue.css --
|
|
.blue {color: blue;}
|
|
-- other/colors/purple.css --
|
|
.purple {color: purple;}
|
|
-- layouts/home.html --
|
|
{{ with (templates.Defer (dict "key" "global")) }}
|
|
{{ with resources.Get "css/main.css" }}
|
|
{{ $opts := dict "disableInlineImports" true }}
|
|
{{ with . | css.TailwindCSS $opts }}
|
|
<link rel="stylesheet" href="{{ .RelPermalink }}">
|
|
{{ end }}
|
|
{{ end }}
|
|
{{ end }}
|
|
-- package.json --
|
|
{
|
|
"devDependencies": {
|
|
"@tailwindcss/cli": "^4.1.7",
|
|
"tailwindcss": "^4.1.7"
|
|
}
|
|
}
|
|
`
|
|
|
|
b, err := hugolib.NewIntegrationTestBuilder(
|
|
hugolib.IntegrationTestConfig{
|
|
T: t,
|
|
TxtarString: files,
|
|
NeedsOsFS: true,
|
|
NeedsNpmInstall: true,
|
|
LogLevel: logg.LevelInfo,
|
|
}).BuildE()
|
|
|
|
b.Assert(err, qt.IsNotNil)
|
|
b.Assert(err.Error(), qt.Contains, "Can't resolve 'colors/red.css'")
|
|
b.Assert(err.Error(), qt.Contains, "You may want to set the 'disableInlineImports' option to false")
|
|
}
|