Commit 19dc2fb0 authored by Brett Walker's avatar Brett Walker Committed by Fatih Acet

Fix TaskListToggleService specs

parent 58cd21c2
...@@ -4,6 +4,7 @@ require 'spec_helper' ...@@ -4,6 +4,7 @@ require 'spec_helper'
describe TaskListToggleService do describe TaskListToggleService do
context 'when ' do context 'when ' do
let(:sourcepos) { true }
let(:markdown) do let(:markdown) do
<<-EOT.strip_heredoc <<-EOT.strip_heredoc
* [ ] Task 1 * [ ] Task 1
...@@ -18,20 +19,20 @@ describe TaskListToggleService do ...@@ -18,20 +19,20 @@ describe TaskListToggleService do
let(:markdown_html) do let(:markdown_html) do
<<-EOT.strip_heredoc <<-EOT.strip_heredoc
<ul class="task-list" dir="auto"> <ul data-sourcepos="1:1-3:0" class="task-list" dir="auto">
<li class="task-list-item"> <li data-sourcepos="1:1-1:12" class="task-list-item">
<input type="checkbox" class="task-list-item-checkbox" disabled> Task 1 <input type="checkbox" class="task-list-item-checkbox" disabled> Task 1
</li> </li>
<li class="task-list-item"> <li data-sourcepos="2:1-3:0" class="task-list-item">
<input type="checkbox" class="task-list-item-checkbox" disabled checked> Task 2 <input type="checkbox" class="task-list-item-checkbox" disabled checked> Task 2
</li> </li>
</ul> </ul>
<p dir="auto">A paragraph</p> <p data-sourcepos="4:1-4:11" dir="auto">A paragraph</p>
<ol class="task-list" dir="auto"> <ol data-sourcepos="6:1-7:19" class="task-list" dir="auto">
<li class="task-list-item"> <li data-sourcepos="6:1-7:19" class="task-list-item">
<input type="checkbox" class="task-list-item-checkbox" disabled checked> Item 1 <input type="checkbox" class="task-list-item-checkbox" disabled checked> Item 1
<ul class="task-list"> <ul data-sourcepos="7:4-7:19" class="task-list">
<li class="task-list-item"> <li data-sourcepos="7:4-7:19" class="task-list-item">
<input type="checkbox" class="task-list-item-checkbox" disabled> Sub-item 1 <input type="checkbox" class="task-list-item-checkbox" disabled> Sub-item 1
</li> </li>
</ul> </ul>
...@@ -40,48 +41,88 @@ describe TaskListToggleService do ...@@ -40,48 +41,88 @@ describe TaskListToggleService do
EOT EOT
end end
it 'checks Task 1' do shared_examples 'task lists' do
toggler = described_class.new(markdown, markdown_html, it 'checks Task 1' do
index: 1, currently_checked: false, toggler = described_class.new(markdown, markdown_html,
line_source: '* [ ] Task 1', line_number: 1) index: 1, toggle_as_checked: true,
line_source: '* [ ] Task 1', line_number: 1,
sourcepos: sourcepos)
expect(toggler.execute).to be_truthy expect(toggler.execute).to be_truthy
expect(toggler.updated_markdown.lines[0]).to eq "* [x] Task 1\n" expect(toggler.updated_markdown.lines[0]).to eq "* [x] Task 1\n"
expect(toggler.updated_markdown_html).to include('disabled checked> Task 1') expect(toggler.updated_markdown_html).to include('disabled checked> Task 1')
end end
it 'unchecks Item 1' do it 'unchecks Item 1' do
toggler = described_class.new(markdown, markdown_html, toggler = described_class.new(markdown, markdown_html,
index: 3, currently_checked: true, index: 3, toggle_as_checked: false,
line_source: '1. [X] Item 1', line_number: 6) line_source: '1. [X] Item 1', line_number: 6,
sourcepos: sourcepos)
expect(toggler.execute).to be_truthy expect(toggler.execute).to be_truthy
expect(toggler.updated_markdown.lines[5]).to eq "1. [ ] Item 1\n" expect(toggler.updated_markdown.lines[5]).to eq "1. [ ] Item 1\n"
expect(toggler.updated_markdown_html).to include('disabled> Item 1') expect(toggler.updated_markdown_html).to include('disabled> Item 1')
end end
it 'returns false if line_source does not match the text' do it 'returns false if line_source does not match the text' do
toggler = described_class.new(markdown, markdown_html, toggler = described_class.new(markdown, markdown_html,
index: 2, currently_checked: true, index: 2, toggle_as_checked: false,
line_source: '* [x] Task Added', line_number: 2) line_source: '* [x] Task Added', line_number: 2,
sourcepos: sourcepos)
expect(toggler.execute).to be_falsey expect(toggler.execute).to be_falsey
end end
it 'returns false if markdown is nil' do
toggler = described_class.new(nil, markdown_html,
index: 2, toggle_as_checked: false,
line_source: '* [x] Task Added', line_number: 2,
sourcepos: sourcepos)
expect(toggler.execute).to be_falsey
end
it 'returns false if markdown is nil' do it 'returns false if markdown_html is nil' do
toggler = described_class.new(nil, markdown_html, toggler = described_class.new(markdown, nil,
index: 2, currently_checked: true, index: 2, toggle_as_checked: false,
line_source: '* [x] Task Added', line_number: 2) line_source: '* [x] Task Added', line_number: 2,
sourcepos: sourcepos)
expect(toggler.execute).to be_falsey expect(toggler.execute).to be_falsey
end
end end
it 'returns false if markdown_html is nil' do context 'when using sourcepos' do
toggler = described_class.new(markdown, nil, it_behaves_like 'task lists'
index: 2, currently_checked: true, end
line_source: '* [x] Task Added', line_number: 2)
context 'when using checkbox indexing' do
let(:sourcepos) { false }
let(:markdown_html) do
<<-EOT.strip_heredoc
<ul class="task-list" dir="auto">
<li class="task-list-item">
<input type="checkbox" class="task-list-item-checkbox" disabled> Task 1
</li>
<li class="task-list-item">
<input type="checkbox" class="task-list-item-checkbox" disabled checked> Task 2
</li>
</ul>
<p dir="auto">A paragraph</p>
<ol class="task-list" dir="auto">
<li class="task-list-item">
<input type="checkbox" class="task-list-item-checkbox" disabled checked> Item 1
<ul class="task-list">
<li class="task-list-item">
<input type="checkbox" class="task-list-item-checkbox" disabled> Sub-item 1
</li>
</ul>
</li>
</ol>
EOT
end
expect(toggler.execute).to be_falsey it_behaves_like 'task lists'
end end
end end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment