Sha256: 0e9a0a1122d8c42b6a2ae2335e62cea7961405173ab6ee3c074c6fe320b966ac

Contents?: true

Size: 1.59 KB

Versions: 1

Compression:

Stored size: 1.59 KB

Contents

require 'nokogiri'
require 'json'

namespace :course do
  COURSE_URL = URI('http://spidr.rubyforge.org/course/')

  STATIC_DIR = File.expand_path(File.join(File.dirname(__FILE__),'..','static'))

  COURSE_DIR = File.join(STATIC_DIR,'course')

  desc "Build the JSON spec file for the course"
  task :spec do
    File.open(File.join(COURSE_DIR,'specs.json'),'w') do |spec|
      specs = []

      Dir[File.join(COURSE_DIR,'**','*.html')].each do |page|
        doc = Nokogiri::HTML(open(page))
        page_url = COURSE_URL.merge(page.sub(STATIC_DIR,''))

        link_to_spec = lambda { |link,spec_data|
          relative_url = (link.get_attribute('href') || '')
          absolute_url = page_url.merge(URI.encode(relative_url))

          if absolute_url.path
            absolute_url.path = File.expand_path(absolute_url.path)
          end

          spec_data.merge(
            :message => link.inner_text,
            :link => relative_url,
            :url => absolute_url,
            :example => link.to_html
          )
        }

        doc.search('.follow//a').each do |follow|
          specs << link_to_spec.call(follow, :behavior => :follow)
        end

        doc.search('.nofollow//a').each do |nofollow|
          specs << link_to_spec.call(nofollow, :behavior => :nofollow)
        end

        doc.search('.ignore//a').each do |ignore|
          specs << link_to_spec.call(ignore, :behavior => :ignore)
        end

        doc.search('.fail//a').each do |ignore|
          specs << link_to_spec.call(ignore, :behavior => :fail)
        end
      end

      spec.write(specs.to_json)
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
spidr-0.1.6 tasks/course.rb