ref: d7e3b19621a191a5e8533b19af2eaa9742d92d74
dir: /style/css_test.go/
package style import ( "testing" ) func TestParseInline(t *testing.T) { css := "color: red;" s, err := Parse(css, true) if err != nil { t.Fatalf("%v", err) } t.Logf("s: %+v", s) if len(s.Rules) != 1 { t.Fail() } r := s.Rules[0] if len(r.Declarations) != 1 { t.Fail() } d := r.Declarations[0] if d.Prop != "color" || d.Val != "red" { t.Fail() } } func TestParseMin(t *testing.T) { css := ` h1 { font-weight: bold; font-size: 100px; } p, quote, a < b, div { color: grey !important; } :root { --emph: red; --h: 10px; } b { color: var(--emph); } ` s, err := Parse(css, false) if err != nil { t.Fatalf("%v", err) } t.Logf("s: %+v", s) if len(s.Rules) != 4 { t.Fatalf("%+v", s) } r := s.Rules[0] if len(r.Declarations) != 2 || len(r.Selectors) != 1 || r.Selectors[0].Val != "h1" { t.Fatalf("%+v", r) } d := r.Declarations[0] if d.Prop != "font-weight" || d.Val != "bold" || d.Important { t.Fatalf("%+v", d) } r = s.Rules[1] if len(r.Declarations) != 1 || len(r.Selectors) != 3 { t.Fatalf("%+v", r) } d = r.Declarations[0] if d.Prop != "color" || d.Val != "grey" || !d.Important { t.Fatalf("%+v", d) } r = s.Rules[2] if len(r.Declarations) != 2 || len(r.Selectors) != 1 || r.Selectors[0].Val != ":root" { t.Fatalf("%+v", r) } d = r.Declarations[0] if d.Prop != "--emph" || d.Val != "red" { t.Fatalf("%+v %+v", r, d) } } func TestParseMedia(t *testing.T) { css := ` @media only screen and (max-width: 600px) { body { background-color: lightblue; } } ` s, err := Parse(css, false) if err != nil { t.Fatalf("%v", err) } t.Logf("s: %+v", s) t.Logf("s.Rules[0].Prelude: %+v", s.Rules[0].Prelude) //t.Logf("s.Rules[0].Prelude: %+v", s.Rules[0].Rules[0].Prelude) if len(s.Rules) != 1 { t.Fatalf("%+v", s) } r := s.Rules[0] if len(r.Declarations) != 0 || len(r.Selectors) > 0 { t.Fatalf("%+v", r) } d := r.Rules[0].Declarations[0] if d.Prop != "background-color" || d.Val != "lightblue" { t.Fatalf("%+v", d) } } func TestParseComment(t *testing.T) { css := ` h1 { font-weight: bold; font-size: 100px; } /* grey text */ p { color: grey !important; } ` s, err := Parse(css, false) if err != nil { t.Fatalf("%v", err) } t.Logf("s: %+v", s) if len(s.Rules) != 2 { t.Fatalf("%v", s) } r := s.Rules[0] if len(r.Declarations) != 2 || r.Selectors[0].Val != "h1" { t.Fatalf("%v", r) } d := r.Declarations[0] if d.Prop != "font-weight" || d.Val != "bold" { t.Fatalf("%v", d) } r = s.Rules[1] if len(r.Declarations) != 1 || r.Selectors[0].Val != "p" { t.Fatalf("%v", r) } d = r.Declarations[0] if d.Prop != "color" || d.Val != "grey" || !d.Important { t.Fatalf("%v", d) } } func TestParseQual(t *testing.T) { css := ` h1 { font-weight: bold; font-size: 100px; } p { color: grey !important; } a[href] { color: blue; margin-right: 2px; } ` s, err := Parse(css, false) if err != nil { t.Fatalf("%v", err) } t.Logf("s: %+v", s) if len(s.Rules) != 3 { t.Fail() } r := s.Rules[0] if len(r.Declarations) != 2 || r.Selectors[0].Val != "h1" { t.Fail() } d := r.Declarations[0] if d.Prop != "font-weight" || d.Val != "bold" { t.Fail() } r = s.Rules[2] if len(r.Declarations) != 2 || r.Selectors[0].Val != "a[href]" { t.Fatalf("%+v", r) } d = r.Declarations[0] if d.Prop != "color" || d.Val != "blue" { t.Fail() } } func TestParseAtRule(t *testing.T) { css := ` @charset "UTF-8";.info{z-index:3;} @media only screen and (max-width: 600px) { body { background-color: lightblue; } } ` s, err := Parse(css, false) if err != nil { t.Fatalf("%v", err) } t.Logf("s: %+v", s) if len(s.Rules) != 2 { t.Fail() } r := s.Rules[1] if len(r.Declarations) != 0 || len(r.Selectors) > 0 { t.Fatalf("%+v", r) } d := r.Rules[0].Declarations[0] if d.Prop != "background-color" || d.Val != "lightblue" { t.Fatalf("%+v", d) } } func TestParseAtRule2(t *testing.T) { css := ` @import url(https://fonts.googleapis.com/css?family=Montserrat:400,400i,700,800);.info{z-index:3;} @media only screen and (max-width: 600px) { body { background-color: lightblue; } } ` s, err := Parse(css, false) if err != nil { t.Fatalf("%v", err) } t.Logf("s: %+v", s) if len(s.Rules) != 2 { t.Fail() } r := s.Rules[1] if len(r.Declarations) != 0 || len(r.Selectors) > 0 { t.Fatalf("%+v", r) } d := r.Rules[0].Declarations[0] if d.Prop != "background-color" || d.Val != "lightblue" { t.Fatalf("%+v", d) } } func TestPreprocessAtImport(t *testing.T) { // Examples from https://developer.mozilla.org/en-US/docs/Web/CSS/@import imports := map[string]string{ `@import url("fineprint.css") print;`: `fineprint.css`, `@import url("bluish.css") projection, tv;`: `bluish.css`, `@import 'custom.css';`: `custom.css`, `@import url("example://path/folder/");`: `example://path/folder/`, `@import "common.css" screen, projection;`: `common.css`, `@import url('landscape.css') screen and (orientation:landscape);`: `landscape.css`, } main := ` @media only screen and (max-width: 600px) { body { background-color: lightblue; } } ` for imp, exp := range imports { _, _, is, err := Preprocess(imp + main) if err != nil { t.Fatalf("%v", err) } if len(is) != 1 || is[0] != exp { t.Fatalf("%+v", is) } } }