Merge pull request #4956 from ayastreb/step_definitions
Merge pull request 4956
This commit is contained in:
		
						commit
						5e30823544
					
				|  | @ -19,7 +19,6 @@ AllCops: | ||||||
|   - lib/jekyll/url.rb |   - lib/jekyll/url.rb | ||||||
|   - lib/jekyll/utils.rb |   - lib/jekyll/utils.rb | ||||||
|   - lib/jekyll.rb |   - lib/jekyll.rb | ||||||
|   - features/step_definitions.rb |  | ||||||
|   - bin/**/* |   - bin/**/* | ||||||
|   - benchmark/**/* |   - benchmark/**/* | ||||||
|   - script/**/* |   - script/**/* | ||||||
|  |  | ||||||
|  | @ -14,24 +14,24 @@ end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Given %r{^I have a blank site in "(.*)"$} do |path| | Given(/^I have a blank site in "(.*)"$/) do |path| | ||||||
|   if !File.exist?(path) |   unless File.exist?(path) | ||||||
|     then FileUtils.mkdir_p(path) |     then FileUtils.mkdir_p(path) | ||||||
|   end |   end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Given %r{^I do not have a "(.*)" directory$} do |path| | Given(/^I do not have a "(.*)" directory$/) do |path| | ||||||
|   Paths.test_dir.join(path).directory? |   Paths.test_dir.join(path).directory? | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Given %r{^I have an? "(.*)" page(?: with (.*) "(.*)")? that contains "(.*)"$} do |file, key, value, text| | Given(/^I have an? "(.*)" page(?: with (.*) "(.*)")? that contains "(.*)"$/) do |file, key, value, text| | ||||||
|   File.write(file, Jekyll::Utils.strip_heredoc(<<-DATA)) |   File.write(file, Jekyll::Utils.strip_heredoc(<<-DATA)) | ||||||
|     --- |     --- | ||||||
|     #{key || 'layout'}: #{value || 'nil'} |     #{key || "layout"}: #{value || "nil"} | ||||||
|     --- |     --- | ||||||
| 
 | 
 | ||||||
|     #{text} |     #{text} | ||||||
|  | @ -40,13 +40,13 @@ end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Given %r{^I have an? "(.*)" file that contains "(.*)"$} do |file, text| | Given(/^I have an? "(.*)" file that contains "(.*)"$/) do |file, text| | ||||||
|   File.write(file, text) |   File.write(file, text) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Given %r{^I have an? (.*) (layout|theme) that contains "(.*)"$} do |name, type, text| | Given(/^I have an? (.*) (layout|theme) that contains "(.*)"$/) do |name, type, text| | ||||||
|   folder = type == "layout" ? "_layouts" : "_theme" |   folder = type == "layout" ? "_layouts" : "_theme" | ||||||
| 
 | 
 | ||||||
|   destination_file = Pathname.new(File.join(folder, "#{name}.html")) |   destination_file = Pathname.new(File.join(folder, "#{name}.html")) | ||||||
|  | @ -56,33 +56,33 @@ end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Given %r{^I have an? "(.*)" file with content:$} do |file, text| | Given(/^I have an? "(.*)" file with content:$/) do |file, text| | ||||||
|   File.write(file, text) |   File.write(file, text) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Given %r{^I have an? (.*) directory$} do |dir| | Given(/^I have an? (.*) directory$/) do |dir| | ||||||
|   if !File.directory?(dir) |   unless File.directory?(dir) | ||||||
|     then FileUtils.mkdir_p(dir) |     then FileUtils.mkdir_p(dir) | ||||||
|   end |   end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Given %r{^I have the following (draft|page|post)s?(?: (in|under) "([^"]+)")?:$} do |status, direction, folder, table| | Given(/^I have the following (draft|page|post)s?(?: (in|under) "([^"]+)")?:$/) do |status, direction, folder, table| | ||||||
|   table.hashes.each do |input_hash| |   table.hashes.each do |input_hash| | ||||||
|     title = slug(input_hash["title"]) |     title = slug(input_hash["title"]) | ||||||
|     ext = input_hash["type"] || "markdown" |     ext = input_hash["type"] || "markdown" | ||||||
|     filename = filename = "#{title}.#{ext}" if %w(draft page).include?(status) |     filename = "#{title}.#{ext}" if %w(draft page).include?(status) | ||||||
|     before, after = location(folder, direction) |     before, after = location(folder, direction) | ||||||
|     dest_folder = "_drafts" if status == "draft" |     dest_folder = "_drafts" if status == "draft" | ||||||
|     dest_folder = "_posts"  if status ==  "post" |     dest_folder = "_posts"  if status == "post" | ||||||
|     dest_folder = "" if status == "page" |     dest_folder = "" if status == "page" | ||||||
| 
 | 
 | ||||||
|     if status == "post" |     if status == "post" | ||||||
|       parsed_date = Time.xmlschema(input_hash['date']) rescue Time.parse(input_hash['date']) |       parsed_date = Time.xmlschema(input_hash["date"]) rescue Time.parse(input_hash["date"]) | ||||||
|       filename = "#{parsed_date.strftime('%Y-%m-%d')}-#{title}.#{ext}" |       filename = "#{parsed_date.strftime("%Y-%m-%d")}-#{title}.#{ext}" | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     path = File.join(before, dest_folder, after, filename) |     path = File.join(before, dest_folder, after, filename) | ||||||
|  | @ -92,19 +92,20 @@ end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Given %r{^I have a configuration file with "(.*)" set to "(.*)"$} do |key, value| | Given(/^I have a configuration file with "(.*)" set to "(.*)"$/) do |key, value| | ||||||
|   config = if source_dir.join("_config.yml").exist? |   config = \ | ||||||
|     SafeYAML.load_file(source_dir.join("_config.yml")) |     if source_dir.join("_config.yml").exist? | ||||||
|   else |       SafeYAML.load_file(source_dir.join("_config.yml")) | ||||||
|     {} |     else | ||||||
|   end |       {} | ||||||
|  |     end | ||||||
|   config[key] = YAML.load(value) |   config[key] = YAML.load(value) | ||||||
|   File.write("_config.yml", YAML.dump(config)) |   File.write("_config.yml", YAML.dump(config)) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Given %r{^I have a configuration file with:$} do |table| | Given(/^I have a configuration file with:$/) do |table| | ||||||
|   table.hashes.each do |row| |   table.hashes.each do |row| | ||||||
|     step %(I have a configuration file with "#{row["key"]}" set to "#{row["value"]}") |     step %(I have a configuration file with "#{row["key"]}" set to "#{row["value"]}") | ||||||
|   end |   end | ||||||
|  | @ -112,7 +113,7 @@ end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Given %r{^I have a configuration file with "([^\"]*)" set to:$} do |key, table| | Given(/^I have a configuration file with "([^\"]*)" set to:$/) do |key, table| | ||||||
|   File.open("_config.yml", "w") do |f| |   File.open("_config.yml", "w") do |f| | ||||||
|     f.write("#{key}:\n") |     f.write("#{key}:\n") | ||||||
|     table.hashes.each do |row| |     table.hashes.each do |row| | ||||||
|  | @ -123,20 +124,20 @@ end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Given %r{^I have fixture collections$} do | Given(/^I have fixture collections$/) do | ||||||
|   FileUtils.cp_r Paths.source_dir.join("test", "source", "_methods"), source_dir |   FileUtils.cp_r Paths.source_dir.join("test", "source", "_methods"), source_dir | ||||||
|   FileUtils.cp_r Paths.source_dir.join("test", "source", "_thanksgiving"), source_dir |   FileUtils.cp_r Paths.source_dir.join("test", "source", "_thanksgiving"), source_dir | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Given %r{^I wait (\d+) second(s?)$} do |time, plural| | Given(/^I wait (\d+) second(s?)$/) do |time, _| | ||||||
|   sleep(time.to_f) |   sleep(time.to_f) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| When %r{^I run jekyll(.*)$} do |args| | When(/^I run jekyll(.*)$/) do |args| | ||||||
|   run_jekyll(args) |   run_jekyll(args) | ||||||
|   if args.include?("--verbose") || ENV["DEBUG"] |   if args.include?("--verbose") || ENV["DEBUG"] | ||||||
|     $stderr.puts "\n#{jekyll_run_output}\n" |     $stderr.puts "\n#{jekyll_run_output}\n" | ||||||
|  | @ -145,16 +146,16 @@ end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| When %r{^I run bundle(.*)$} do |args| | When(/^I run bundle(.*)$/) do |args| | ||||||
|   run_bundle(args) |   run_bundle(args) | ||||||
|   if args.include?("--verbose") || ENV['DEBUG'] |   if args.include?("--verbose") || ENV["DEBUG"] | ||||||
|     $stderr.puts "\n#{jekyll_run_output}\n" |     $stderr.puts "\n#{jekyll_run_output}\n" | ||||||
|   end |   end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| When %r{^I change "(.*)" to contain "(.*)"$} do |file, text| | When(/^I change "(.*)" to contain "(.*)"$/) do |file, text| | ||||||
|   File.open(file, "a") do |f| |   File.open(file, "a") do |f| | ||||||
|     f.write(text) |     f.write(text) | ||||||
|   end |   end | ||||||
|  | @ -162,13 +163,13 @@ end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| When %r{^I delete the file "(.*)"$} do |file| | When(/^I delete the file "(.*)"$/) do |file| | ||||||
|   File.delete(file) |   File.delete(file) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Then %r{^the (.*) directory should +(not )?exist$} do |dir, negative| | Then(/^the (.*) directory should +(not )?exist$/) do |dir, negative| | ||||||
|   if negative.nil? |   if negative.nil? | ||||||
|     expect(Pathname.new(dir)).to exist |     expect(Pathname.new(dir)).to exist | ||||||
|   else |   else | ||||||
|  | @ -177,7 +178,7 @@ Then %r{^the (.*) directory should +(not )?exist$} do |dir, negative| | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| Then %r{^I should (not )?see "(.*)" in "(.*)"$} do |negative, text, file| | Then(/^I should (not )?see "(.*)" in "(.*)"$/) do |negative, text, file| | ||||||
|   step %(the "#{file}" file should exist) |   step %(the "#{file}" file should exist) | ||||||
|   regexp = Regexp.new(text, Regexp::MULTILINE) |   regexp = Regexp.new(text, Regexp::MULTILINE) | ||||||
|   if negative.nil? || negative.empty? |   if negative.nil? || negative.empty? | ||||||
|  | @ -189,20 +190,20 @@ end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Then %r{^I should see exactly "(.*)" in "(.*)"$} do |text, file| | Then(/^I should see exactly "(.*)" in "(.*)"$/) do |text, file| | ||||||
|   step %(the "#{file}" file should exist) |   step %(the "#{file}" file should exist) | ||||||
|   expect(file_contents(file).strip).to eq text |   expect(file_contents(file).strip).to eq text | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Then %r{^I should see escaped "(.*)" in "(.*)"$} do |text, file| | Then(/^I should see escaped "(.*)" in "(.*)"$/) do |text, file| | ||||||
|   step %(I should see "#{Regexp.escape(text)}" in "#{file}") |   step %(I should see "#{Regexp.escape(text)}" in "#{file}") | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Then %r{^the "(.*)" file should +(not )?exist$} do |file, negative| | Then(/^the "(.*)" file should +(not )?exist$/) do |file, negative| | ||||||
|   if negative.nil? |   if negative.nil? | ||||||
|     expect(Pathname.new(file)).to exist |     expect(Pathname.new(file)).to exist | ||||||
|   else |   else | ||||||
|  | @ -212,19 +213,19 @@ end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Then %r{^I should see today's time in "(.*)"$} do |file| | Then(/^I should see today's time in "(.*)"$/) do |file| | ||||||
|   step %(I should see "#{seconds_agnostic_time(Time.now)}" in "#{file}") |   step %(I should see "#{seconds_agnostic_time(Time.now)}" in "#{file}") | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Then %r{^I should see today's date in "(.*)"$} do |file| | Then(/^I should see today's date in "(.*)"$/) do |file| | ||||||
|   step %(I should see "#{Date.today.to_s}" in "#{file}") |   step %(I should see "#{Date.today}" in "#{file}") | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Then %r{^I should (not )?see "(.*)" in the build output$} do |negative, text| | Then(/^I should (not )?see "(.*)" in the build output$/) do |negative, text| | ||||||
|   if negative.nil? || negative.empty? |   if negative.nil? || negative.empty? | ||||||
|     expect(jekyll_run_output).to match Regexp.new(text) |     expect(jekyll_run_output).to match Regexp.new(text) | ||||||
|   else |   else | ||||||
|  | @ -234,12 +235,12 @@ end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Then %r{^I should get a zero exit(?:\-| )status$} do | Then(/^I should get a zero exit(?:\-| )status$/) do | ||||||
|   step %(I should see "EXIT STATUS: 0" in the build output) |   step %(I should see "EXIT STATUS: 0" in the build output) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| Then %r{^I should get a non-zero exit(?:\-| )status$} do | Then(/^I should get a non-zero exit(?:\-| )status$/) do | ||||||
|   step %(I should not see "EXIT STATUS: 0" in the build output) |   step %(I should not see "EXIT STATUS: 0" in the build output) | ||||||
| end | end | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue