1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158
|
# -*- mode: cperl; tab-width: 8; indent-tabs-mode: nil; basic-offset: 2 -*-
# vim:ts=8:sw=2:et:sta:sts=2
#########
# Author: rmp
# Last Modified: $Date: 2012-09-12 09:42:30 +0100 (Wed, 12 Sep 2012) $
# Id: $Id: 81-sass-ex.t 71 2012-09-12 08:42:30Z zerojinx $
# $HeadURL: https://text-sass.svn.sourceforge.net/svnroot/text-sass/trunk/t/81-sass-ex.t $
#
use strict;
use warnings;
use Text::Sass;
use Test::More tests => 4;
# $Text::Sass::DEBUG = 1;
{
my $css = <<EOT;
.content-navigation {
border-color: #3bbfce;
color: #2ba1af;
}
.border {
padding: 8px;
margin: 8px;
border-color: #3bbfce;
}
EOT
my $sass = <<EOT;
/* SASS
\$blue: #3bbfce
\$margin: 16px
.content-navigation
border-color: \$blue
color: darken(\$blue, 9%)
.border
padding: \$margin / 2
margin: \$margin / 2
border-color: \$blue
EOT
my $ts = Text::Sass->new();
is($ts->sass2css($sass), $css, "variables examples");
}
{
my $sass = <<EOT;
table.hl
margin: 2em 0
td.ln
text-align: right
li
font:
family: serif
weight: bold
size: 1.2em
EOT
my $css = <<EOT;
table.hl {
margin: 2em 0;
}
table.hl td.ln {
text-align: right;
}
li {
font-family: serif;
font-weight: bold;
font-size: 1.2em;
}
EOT
my $ts = Text::Sass->new();
is($ts->sass2css($sass), $css, "nesting example");
}
{
my $sass = <<EOT;
.error
border: 1px #f00
background: #fdd
.error.intrusion
font-size: 1.3em
font-weight: bold
.badError
\@extend .error
border-width: 3px
EOT
my $css = <<EOT;
.error, .badError {
border: 1px #f00;
background: #fdd;
}
.error.intrusion, .badError.intrusion {
font-size: 1.3em;
font-weight: bold;
}
.badError {
border-width: 3px;
}
EOT
my $ts = Text::Sass->new();
# BOS: This looks like is wrongly implemented in sass-lang.com/try.html as well.
local $TODO = "no support for extend yet";
is($ts->sass2css($sass), $css, "inherintance example");
}
{
my $sass = <<EOT;
\@mixin table-base
th
text-align: center
font-weight: bold
td, th
padding: 2px
\@mixin left(\$dist)
float: left
margin-left: \$dist
#data
\@include left(10px)
\@include table-base
EOT
my $css = <<EOT;
#data {
float: left;
margin-left: 10px;
}
#data th {
text-align: center;
font-weight: bold;
}
#data td, #data th {
padding: 2px;
}
EOT
# $Text::Sass::DEBUG = 1;
my $ts = Text::Sass->new();
#local $TODO = "no support for extend yet";
is($ts->sass2css($sass), $css, "mixin example");
}
|