require 'projectlocker_pulse' require File.join(File.dirname(__FILE__), 'shared_tasks') namespace :pulse do desc "Verify your gem installation by sending a test exception to the pulse service" task :test => [:environment] do Rails.logger = defined?(ActiveSupport::TaggedLogging) ? ActiveSupport::TaggedLogging.new(Logger.new(STDOUT)) : Logger.new(STDOUT) def wait_for_threads # if using multiple threads, we have to wait for # them to finish if GirlFriday.status.empty? Thread.list.each do |thread| thread.join unless thread == Thread.current end else GirlFriday.shutdown! end end Rails.logger.level = Logger::DEBUG Pulse.configure(true) do |config| config.logger = Rails.logger end require './app/controllers/application_controller' class PulseTestingException < RuntimeError; end unless Pulse.configuration.api_key puts "Pulse needs an API key configured! Check the README to see how to add it." exit end Pulse.configuration.development_environments = [] puts "Configuration:" Pulse.configuration.to_hash.each do |key, value| puts sprintf("%25s: %s", key.to_s, value.inspect.slice(0, 55)) end unless defined?(ApplicationController) puts "No ApplicationController found" exit end puts 'Setting up the Controller.' class ApplicationController # This is to bypass any filters that may prevent access to the action. prepend_before_filter :test_pulse def test_pulse puts "Raising '#{exception_class.name}' to simulate application failure." raise exception_class.new, 'Testing Pulse via "rake pulse:test". If you can see this, it works.' end # def rescue_action(exception) # rescue_action_in_public exception # end # Ensure we actually have an action to go to. def verify; end # def consider_all_requests_local # false # end # def local_request? # false # end def exception_class exception_name = ENV['EXCEPTION'] || "PulseTestingException" Object.const_get(exception_name) rescue Object.const_set(exception_name, Class.new(Exception)) end def logger nil end end class PulseVerificationController < ApplicationController; end Rails.application.routes_reloader.execute_if_updated Rails.application.routes.draw do match 'verify' => 'application#verify', :as => 'verify' end puts 'Processing request.' env = Rack::MockRequest.env_for("/verify") Rails.application.call(env) wait_for_threads end end