require 'spec_helper' describe SCSSLint::Linter::TrailingSemicolon do context 'when a property does not end with a semicolon' do let(:css) { <<-CSS } p { margin: 0 } CSS it { should report_lint line: 2 } end context 'when a property ends with a semicolon' do let(:css) { <<-CSS } p { margin: 0; } CSS it { should_not report_lint } end context 'when a property ends with a space followed by a semicolon' do let(:css) { <<-CSS } p { margin: 0 ; } CSS it { should report_lint line: 2 } end context 'when a property ends with a semicolon and is followed by a comment' do let(:css) { <<-CSS } p { margin: 0; // This is a comment padding: 0; /* This is another comment */ } CSS it { should_not report_lint } end context 'when a property contains nested properties' do context 'and there is a value on the namespace' do let(:css) { <<-CSS } p { font: 2px/3px { style: italic; weight: bold; } } CSS it { should_not report_lint } end context 'and there is no value on the namespace' do let(:css) { <<-CSS } p { font: { style: italic; weight: bold; } } CSS it { should_not report_lint } end end context 'when a nested property does not end with a semicolon' do let(:css) { <<-CSS } p { font: { weight: bold } } CSS it { should report_lint line: 3 } end context 'when a multi-line property ends with a semicolon' do let(:css) { <<-CSS } p { background: top repeat-x url('top-image.jpg'), right repeat-y url('right-image.jpg'), bottom repeat-x url('bottom-image.jpg'), left repeat-y url('left-image.jpg'); } CSS it { should_not report_lint } end context 'when a multi-line property does not end with a semicolon' do let(:css) { <<-CSS } p { background: top repeat-x url('top-image.jpg'), right repeat-y url('right-image.jpg'), bottom repeat-x url('bottom-image.jpg'), left repeat-y url('left-image.jpg') } CSS it { should report_lint line: 2 } end context 'when a oneline rule does not end with a semicolon' do let(:css) { <<-CSS } .foo { border: 0 } CSS it { should report_lint line: 1 } end context 'when a oneline rule has a space before a semicolon' do let(:css) { <<-CSS } .foo { border: 0 ; } CSS it { should report_lint line: 1 } end context 'when @extend does not end with a semicolon' do let(:css) { <<-CSS } .foo { @extend %bar } CSS it { should report_lint line: 2 } end context 'when @extend ends with a semicolon' do let(:css) { <<-CSS } .foo { @extend %bar; } CSS it { should_not report_lint } end context 'when @include does not end with a semicolon' do let(:css) { <<-CSS } .foo { @include bar } CSS it { should report_lint line: 2 } end context 'when @include takes a block' do let(:css) { <<-CSS } .foo { @include bar { border: 0; } } CSS it { should_not report_lint } end context 'when @include takes a block with nested props' do let(:css) { <<-CSS } .foo { @include bar { .bar { border: 0; } } } CSS it { should_not report_lint } end context 'when @include takes a block with an if-node' do let(:css) { <<-CSS } .foo { @include bar { @if $var { border: 0; } } } CSS it { should_not report_lint } end context 'when @include ends with a semicolon' do let(:css) { <<-CSS } .foo { @include bar; } CSS it { should_not report_lint } end context 'when variable declaration does not end with a semicolon' do let(:css) { <<-CSS } .foo { $bar: 1 } CSS it { should report_lint line: 2 } end context 'when variable declaration ends with a semicolon' do let(:css) { <<-CSS } .foo { $bar: 1; } CSS it { should_not report_lint } end context 'when variable declaration ends with multiple semicolons' do let(:css) { <<-CSS } .foo { $bar: 1;; } CSS it { should report_lint line: 2 } end end