eric-adhearsion 0.7.999

Sign up to get free protection for your applications and to get access to all the features.
Files changed (150) hide show
  1. data/CHANGELOG +3 -0
  2. data/LICENSE +456 -0
  3. data/Manifest.txt +149 -0
  4. data/README.txt +6 -0
  5. data/Rakefile +48 -0
  6. data/ahn_generators/component/USAGE +5 -0
  7. data/ahn_generators/component/component_generator.rb +57 -0
  8. data/ahn_generators/component/templates/configuration.rb +0 -0
  9. data/ahn_generators/component/templates/lib/lib.rb.erb +3 -0
  10. data/ahn_generators/component/templates/test/test.rb.erb +12 -0
  11. data/ahn_generators/component/templates/test/test_helper.rb +14 -0
  12. data/app_generators/ahn/USAGE +5 -0
  13. data/app_generators/ahn/ahn_generator.rb +76 -0
  14. data/app_generators/ahn/templates/.ahnrc +12 -0
  15. data/app_generators/ahn/templates/README +8 -0
  16. data/app_generators/ahn/templates/Rakefile +3 -0
  17. data/app_generators/ahn/templates/components/simon_game/configuration.rb +0 -0
  18. data/app_generators/ahn/templates/components/simon_game/lib/simon_game.rb +61 -0
  19. data/app_generators/ahn/templates/components/simon_game/test/test_helper.rb +14 -0
  20. data/app_generators/ahn/templates/components/simon_game/test/test_simon_game.rb +31 -0
  21. data/app_generators/ahn/templates/config/startup.rb +53 -0
  22. data/app_generators/ahn/templates/dialplan.rb +4 -0
  23. data/bin/ahn +28 -0
  24. data/bin/ahnctl +68 -0
  25. data/bin/jahn +32 -0
  26. data/lib/adhearsion/blank_slate.rb +5 -0
  27. data/lib/adhearsion/cli.rb +106 -0
  28. data/lib/adhearsion/component_manager.rb +277 -0
  29. data/lib/adhearsion/core_extensions/all.rb +9 -0
  30. data/lib/adhearsion/core_extensions/array.rb +0 -0
  31. data/lib/adhearsion/core_extensions/custom_daemonizer.rb +45 -0
  32. data/lib/adhearsion/core_extensions/global.rb +1 -0
  33. data/lib/adhearsion/core_extensions/guid.rb +5 -0
  34. data/lib/adhearsion/core_extensions/hash.rb +0 -0
  35. data/lib/adhearsion/core_extensions/metaprogramming.rb +17 -0
  36. data/lib/adhearsion/core_extensions/numeric.rb +4 -0
  37. data/lib/adhearsion/core_extensions/proc.rb +0 -0
  38. data/lib/adhearsion/core_extensions/pseudo_uuid.rb +11 -0
  39. data/lib/adhearsion/core_extensions/publishable.rb +73 -0
  40. data/lib/adhearsion/core_extensions/relationship_properties.rb +40 -0
  41. data/lib/adhearsion/core_extensions/string.rb +26 -0
  42. data/lib/adhearsion/core_extensions/thread.rb +13 -0
  43. data/lib/adhearsion/core_extensions/thread_safety.rb +7 -0
  44. data/lib/adhearsion/core_extensions/time.rb +0 -0
  45. data/lib/adhearsion/distributed/gateways/dbus_gateway.rb +0 -0
  46. data/lib/adhearsion/distributed/gateways/osa_gateway.rb +0 -0
  47. data/lib/adhearsion/distributed/gateways/rest_gateway.rb +9 -0
  48. data/lib/adhearsion/distributed/gateways/soap_gateway.rb +9 -0
  49. data/lib/adhearsion/distributed/gateways/xmlrpc_gateway.rb +9 -0
  50. data/lib/adhearsion/distributed/peer_finder.rb +0 -0
  51. data/lib/adhearsion/distributed/remote_cli.rb +0 -0
  52. data/lib/adhearsion/hooks.rb +57 -0
  53. data/lib/adhearsion/host_definitions.rb +63 -0
  54. data/lib/adhearsion/initializer/asterisk.rb +59 -0
  55. data/lib/adhearsion/initializer/configuration.rb +202 -0
  56. data/lib/adhearsion/initializer/database.rb +92 -0
  57. data/lib/adhearsion/initializer/drb.rb +25 -0
  58. data/lib/adhearsion/initializer/freeswitch.rb +22 -0
  59. data/lib/adhearsion/initializer/paths.rb +55 -0
  60. data/lib/adhearsion/initializer/rails.rb +40 -0
  61. data/lib/adhearsion/initializer.rb +217 -0
  62. data/lib/adhearsion/logging.rb +92 -0
  63. data/lib/adhearsion/services/scheduler.rb +5 -0
  64. data/lib/adhearsion/tasks/database.rb +5 -0
  65. data/lib/adhearsion/tasks/generating.rb +20 -0
  66. data/lib/adhearsion/tasks/lint.rb +4 -0
  67. data/lib/adhearsion/tasks/testing.rb +37 -0
  68. data/lib/adhearsion/tasks.rb +15 -0
  69. data/lib/adhearsion/version.rb +9 -0
  70. data/lib/adhearsion/voip/asterisk/agi_server.rb +78 -0
  71. data/lib/adhearsion/voip/asterisk/ami/actions.rb +238 -0
  72. data/lib/adhearsion/voip/asterisk/ami/machine.rb +871 -0
  73. data/lib/adhearsion/voip/asterisk/ami/machine.rl +109 -0
  74. data/lib/adhearsion/voip/asterisk/ami/parser.rb +262 -0
  75. data/lib/adhearsion/voip/asterisk/ami.rb +147 -0
  76. data/lib/adhearsion/voip/asterisk/commands.rb +1182 -0
  77. data/lib/adhearsion/voip/asterisk/config_generators/agents.conf.rb +140 -0
  78. data/lib/adhearsion/voip/asterisk/config_generators/config_generator.rb +101 -0
  79. data/lib/adhearsion/voip/asterisk/config_generators/queues.conf.rb +250 -0
  80. data/lib/adhearsion/voip/asterisk/config_generators/voicemail.conf.rb +240 -0
  81. data/lib/adhearsion/voip/asterisk/config_manager.rb +71 -0
  82. data/lib/adhearsion/voip/asterisk/special_dial_plan_managers.rb +80 -0
  83. data/lib/adhearsion/voip/asterisk.rb +4 -0
  84. data/lib/adhearsion/voip/call.rb +391 -0
  85. data/lib/adhearsion/voip/call_routing.rb +64 -0
  86. data/lib/adhearsion/voip/commands.rb +9 -0
  87. data/lib/adhearsion/voip/constants.rb +39 -0
  88. data/lib/adhearsion/voip/conveniences.rb +18 -0
  89. data/lib/adhearsion/voip/dial_plan.rb +205 -0
  90. data/lib/adhearsion/voip/dsl/dialing_dsl/dialing_dsl_monkey_patches.rb +37 -0
  91. data/lib/adhearsion/voip/dsl/dialing_dsl.rb +151 -0
  92. data/lib/adhearsion/voip/dsl/dialplan/control_passing_exception.rb +27 -0
  93. data/lib/adhearsion/voip/dsl/dialplan/dispatcher.rb +124 -0
  94. data/lib/adhearsion/voip/dsl/dialplan/parser.rb +75 -0
  95. data/lib/adhearsion/voip/dsl/dialplan/thread_mixin.rb +16 -0
  96. data/lib/adhearsion/voip/dsl/numerical_string.rb +117 -0
  97. data/lib/adhearsion/voip/freeswitch/basic_connection_manager.rb +48 -0
  98. data/lib/adhearsion/voip/freeswitch/event_handler.rb +58 -0
  99. data/lib/adhearsion/voip/freeswitch/freeswitch_dialplan_command_factory.rb +129 -0
  100. data/lib/adhearsion/voip/freeswitch/inbound_connection_manager.rb +38 -0
  101. data/lib/adhearsion/voip/freeswitch/oes_server.rb +195 -0
  102. data/lib/adhearsion/voip/menu_state_machine/calculated_match.rb +80 -0
  103. data/lib/adhearsion/voip/menu_state_machine/matchers.rb +123 -0
  104. data/lib/adhearsion/voip/menu_state_machine/menu_builder.rb +58 -0
  105. data/lib/adhearsion/voip/menu_state_machine/menu_class.rb +149 -0
  106. data/lib/adhearsion.rb +31 -0
  107. data/script/destroy +14 -0
  108. data/script/generate +14 -0
  109. data/spec/fixtures/dialplan.rb +3 -0
  110. data/spec/initializer/test_configuration.rb +267 -0
  111. data/spec/initializer/test_loading.rb +162 -0
  112. data/spec/initializer/test_paths.rb +43 -0
  113. data/spec/silence.rb +10 -0
  114. data/spec/test_ahn_command.rb +149 -0
  115. data/spec/test_code_quality.rb +87 -0
  116. data/spec/test_component_manager.rb +97 -0
  117. data/spec/test_constants.rb +8 -0
  118. data/spec/test_drb.rb +104 -0
  119. data/spec/test_helper.rb +94 -0
  120. data/spec/test_hooks.rb +37 -0
  121. data/spec/test_host_definitions.rb +79 -0
  122. data/spec/test_initialization.rb +105 -0
  123. data/spec/test_logging.rb +80 -0
  124. data/spec/test_relationship_properties.rb +54 -0
  125. data/spec/voip/asterisk/ami_response_definitions.rb +23 -0
  126. data/spec/voip/asterisk/config_file_generators/test_agents.rb +253 -0
  127. data/spec/voip/asterisk/config_file_generators/test_queues.rb +325 -0
  128. data/spec/voip/asterisk/config_file_generators/test_voicemail.rb +306 -0
  129. data/spec/voip/asterisk/menu_command/test_calculated_match.rb +111 -0
  130. data/spec/voip/asterisk/menu_command/test_matchers.rb +98 -0
  131. data/spec/voip/asterisk/mock_ami_server.rb +176 -0
  132. data/spec/voip/asterisk/test_agi_server.rb +451 -0
  133. data/spec/voip/asterisk/test_ami.rb +227 -0
  134. data/spec/voip/asterisk/test_commands.rb +2006 -0
  135. data/spec/voip/asterisk/test_config_manager.rb +129 -0
  136. data/spec/voip/dsl/dispatcher_spec_helper.rb +45 -0
  137. data/spec/voip/dsl/test_dialing_dsl.rb +268 -0
  138. data/spec/voip/dsl/test_dispatcher.rb +82 -0
  139. data/spec/voip/dsl/test_parser.rb +87 -0
  140. data/spec/voip/freeswitch/test_basic_connection_manager.rb +39 -0
  141. data/spec/voip/freeswitch/test_inbound_connection_manager.rb +39 -0
  142. data/spec/voip/freeswitch/test_oes_server.rb +9 -0
  143. data/spec/voip/test_call_routing.rb +127 -0
  144. data/spec/voip/test_dialplan_manager.rb +372 -0
  145. data/spec/voip/test_numerical_string.rb +48 -0
  146. data/spec/voip/test_phone_number.rb +36 -0
  147. data/test/test_ahn_generator.rb +59 -0
  148. data/test/test_component_generator.rb +52 -0
  149. data/test/test_generator_helper.rb +20 -0
  150. metadata +254 -0
@@ -0,0 +1,94 @@
1
+ Dir.chdir File.join(File.dirname(__FILE__), '..')
2
+ require 'rubygems'
3
+ def require_or_report_dependency(require_name, gem_name)
4
+ begin
5
+ require require_name
6
+ rescue LoadError
7
+ report_dependency!(gem_name)
8
+ end
9
+ end
10
+
11
+ def report_dependency!(name)
12
+ puts;puts
13
+ puts "You need #{name} to run these tests: gem install #{name}"
14
+ puts;puts
15
+ exit!
16
+ end
17
+
18
+ require_or_report_dependency('test/spec', 'test-spec')
19
+ require_or_report_dependency('flexmock/test_unit', 'flexmock')
20
+ require_or_report_dependency('active_support', 'activesupport')
21
+ # require_or_report_dependency('ruby-debug', 'ruby-debug')
22
+ require_or_report_dependency('rubigen', 'rubigen')
23
+
24
+ require 'pp'
25
+ require 'stringio'
26
+
27
+ $: << File.expand_path(File.join(File.dirname(__FILE__), '..', 'lib'))
28
+ $: << File.expand_path('lib')
29
+ $: << File.dirname(__FILE__)
30
+
31
+ require 'adhearsion'
32
+ class Adhearsion::Initializer
33
+ def asterisk_enabled?
34
+ false
35
+ end
36
+ end
37
+
38
+
39
+
40
+
41
+ class Test::Unit::TestCase
42
+
43
+ alias_method :the_following_code, :lambda
44
+ def self.test(*args, &block)
45
+ if block_given?
46
+ specify(args, &block)
47
+ else
48
+ disabled_test(*args)
49
+ end
50
+ end
51
+
52
+ def self.disabled_test(*args, &block)
53
+ xspecify(*args, &block)
54
+ end
55
+
56
+ end
57
+
58
+ module InitializerStubs
59
+
60
+ UNWANTED_BEHAVIOR = {
61
+ Adhearsion::Initializer => [:initialize_log_file, :switch_to_root_directory, :daemonize!],
62
+ Adhearsion::Hooks::AfterInitialized.metaclass => [:create_hook, :trigger_hooks]
63
+ } unless defined? UNWANTED_BEHAVIOR
64
+
65
+ def with_new_initializer_with_no_path_changing_behavior
66
+ stub_unwanted_behavior
67
+ Adhearsion::Initializer.new('path does not matter')
68
+ yield if block_given?
69
+ unstub_directory_changing_behavior
70
+ end
71
+
72
+ def stub_unwanted_behavior
73
+ UNWANTED_BEHAVIOR.each do |stub_victim_class, undesired_methods|
74
+ undesired_methods.each do |undesired_method_name|
75
+ stub_victim_class.send(:alias_method, "pre_stubbed_#{undesired_method_name}", undesired_method_name)
76
+ stub_victim_class.send(:define_method, undesired_method_name) { |*args| }
77
+ end
78
+ end
79
+ end
80
+
81
+ def unstub_directory_changing_behavior
82
+ UNWANTED_BEHAVIOR.each do |stub_victim_class, undesired_methods|
83
+ undesired_methods.each do |undesired_method_name|
84
+ stub_victim_class.send(:alias_method, undesired_method_name, "pre_stubbed_#{undesired_method_name}")
85
+ end
86
+ end
87
+ end
88
+ end
89
+
90
+ Adhearsion::Initializer.ahn_root = File.dirname(__FILE__) + '/fixtures'
91
+ require 'spec/silence' unless ENV['SHOW_DISABLED']
92
+
93
+ require 'adhearsion/voip/asterisk'
94
+ require 'adhearsion/component_manager'
@@ -0,0 +1,37 @@
1
+ require File.dirname(__FILE__) + "/test_helper.rb"
2
+
3
+ # context "Adhearsion::Hooks::TearDown when initializing a project" do
4
+ # include InitializerStubs
5
+ # test "should trap TERM and INT signals" do
6
+ # flexmock(Adhearsion::Hooks::TearDown).should_receive(:catch_termination_signals).at_least.once
7
+ # with_new_initializer_with_no_path_changing_behavior {}
8
+ # end
9
+ # end
10
+
11
+ # module StandardHookBehavior
12
+ # def test_standard_hook_behavior
13
+ # @hook.should.respond_to(:trigger_hooks)
14
+ # @hook.should.respond_to(:create_hook)
15
+ # end
16
+ # end
17
+
18
+ # for hook in Adhearsion::Hooks.constants.map { |c| (Adhearsion::Hooks.const_get c) }
19
+ # describe hook.to_s do
20
+ # include StandardHookBehavior
21
+ # before(:each) { @hook = hook }
22
+ # end
23
+ # end
24
+
25
+ context "A HookWithArguments" do
26
+ test "should pass the arguments to trigger_hooks() along to each registered block" do
27
+ hook_manager = Adhearsion::Hooks::HookWithArguments.new
28
+ hook_manager.create_hook do |foo, bar|
29
+ foo.should.equal :foo
30
+ bar.should.equal :bar
31
+ throw :inside_hook
32
+ end
33
+ the_following_code {
34
+ hook_manager.trigger_hooks(:foo, :bar)
35
+ }.should.throw :inside_hook
36
+ end
37
+ end
@@ -0,0 +1,79 @@
1
+ require File.join(File.dirname(__FILE__), 'test_helper.rb')
2
+ require 'adhearsion/host_definitions'
3
+
4
+ context 'HostDefinition' do
5
+
6
+ after :each do
7
+ Adhearsion::HostDefinition.clear_definitions!
8
+ end
9
+
10
+ test 'when loading from a YAML array, it should pass each nested Hash to the constructor' do
11
+ hosts = [
12
+ {:host => "hostname1", :username => "user", :password => "password"},
13
+ {:host => "hostname2", :username => "user", :password => "password"},
14
+ {:host => "hostname3", :username => "user", :password => "password"}
15
+ ]
16
+ flexmock(Adhearsion::HostDefinition).should_receive(:new).once.with(hosts[0])
17
+ flexmock(Adhearsion::HostDefinition).should_receive(:new).once.with(hosts[1])
18
+ flexmock(Adhearsion::HostDefinition).should_receive(:new).once.with(hosts[2])
19
+ Adhearsion::HostDefinition.import_from_yaml hosts.to_yaml
20
+ end
21
+
22
+ test 'should set the @name property to a new UUID when no name is given' do
23
+ definition = {:host => "hostname", :username => "user", :password => "pass"}
24
+ Adhearsion::HostDefinition.new(definition).name.should =~ /^[a-z0-9]{8}-([a-z0-9]{4}-){3}[a-z0-9]{12}$/i
25
+ end
26
+
27
+ test 'when loading from YAML keys, it should pass each nested Hash to the constructor with the key as :name' do
28
+ definitions = { :pbx1 => {},
29
+ :pbx2 => {},
30
+ :pbx3 => {} }
31
+ definitions.each_pair do |key,value|
32
+ flexmock(Adhearsion::HostDefinition).should_receive(:new).once.with(value.merge(:name => key))
33
+ end
34
+ Adhearsion::HostDefinition.import_from_data_structure(definitions)
35
+ end
36
+
37
+ test 'should have an Array class variable named definitions' do
38
+ Adhearsion::HostDefinition.definitions.should.be.kind_of Array
39
+ end
40
+
41
+ test 'should add each HostDefinition to a class variable named @@definitions when instantiated' do
42
+ Adhearsion::HostDefinition.definitions.size.should.equal 0
43
+ Adhearsion::HostDefinition.new :name => "foobar", :host => "hostname", :username => "user", :password => "password"
44
+ Adhearsion::HostDefinition.definitions.size.should.equal 1
45
+ Adhearsion::HostDefinition.clear_definitions!
46
+ Adhearsion::HostDefinition.definitions.size.should.equal 0
47
+ end
48
+
49
+ test 'should raise a HostDefinitionException when a password and a key are given' do
50
+ the_following_code {
51
+ Adhearsion::HostDefinition.new(:username => "user", :host => "foobar", :key => "doesntmatter", :password => "pass")
52
+ }.should.raise Adhearsion::HostDefinition::HostDefinitionException
53
+ end
54
+
55
+ test 'should raise a HostDefinitionException when no password or key is given' do
56
+ the_following_code {
57
+ Adhearsion::HostDefinition.new(:username => "user", :host => "foobar")
58
+ }.should.raise Adhearsion::HostDefinition::HostDefinitionException
59
+ end
60
+
61
+ test 'should raise a HostDefinitionException when no username is given' do
62
+ the_following_code {
63
+ Adhearsion::HostDefinition.new(:host => "host", :password => "password")
64
+ }.should.raise Adhearsion::HostDefinition::HostDefinitionException
65
+ end
66
+
67
+ test 'should raise a HostDefinitionException when no "host" key is given' do
68
+ the_following_code {
69
+ Adhearsion::HostDefinition.new(:username => "foobar", :password => "password")
70
+ }.should.raise Adhearsion::HostDefinition::HostDefinitionException
71
+ end
72
+
73
+ test 'should raise a HostDefinitionException when an unrecognized key is given' do
74
+ the_following_code {
75
+ Adhearsion::HostDefinition.new(:username => "foobar", :password => "password", :host => "blah", :thiskeyisnotrecognized => nil)
76
+ }.should.raise Adhearsion::HostDefinition::HostDefinitionException
77
+ end
78
+
79
+ end
@@ -0,0 +1,105 @@
1
+ require File.dirname(__FILE__) + '/test_helper'
2
+
3
+ context "Adhearsion::Initializer" do
4
+
5
+ include InitializerStubs
6
+ # TODO: create a specification for aliases
7
+
8
+ before :each do
9
+ Adhearsion.send(:remove_const, 'AHN_CONFIG') if Adhearsion.const_defined? 'AHN_CONFIG'
10
+ Adhearsion::AHN_CONFIG = Adhearsion::Configuration.new
11
+ end
12
+
13
+ test "initialization will start with only a path given" do
14
+ with_new_initializer_with_no_path_changing_behavior do
15
+ Adhearsion::Initializer.new path
16
+ end
17
+ end
18
+
19
+ test "should create a pid file in the app's path when given 'true' as the pid_file hash key argument" do
20
+ with_new_initializer_with_no_path_changing_behavior do
21
+ flexmock(File).should_receive(:open).once.with(File.join(path, 'adhearsion.pid'), 'w', Proc)
22
+ ahn = Adhearsion::Initializer.new path, :pid_file => true
23
+ ahn.pid_file[0, path.length].should.equal(path)
24
+ end
25
+ end
26
+
27
+ test "should NOT create a pid file in the app's path when given 'false' as the pid_file hash key argument" do
28
+ with_new_initializer_with_no_path_changing_behavior do
29
+ ahn = Adhearsion::Initializer.new path, :pid_file => false
30
+ assert_nil ahn.pid_file
31
+ end
32
+ end
33
+
34
+ test "should create a pid file in the app's path by default when daemonizing" do
35
+ with_new_initializer_with_no_path_changing_behavior do
36
+ flexmock(File).should_receive(:open).once.with(File.join(path, 'adhearsion.pid'), 'w', Proc)
37
+ ahn = Adhearsion::Initializer.new path, :daemon => true
38
+ ahn.pid_file[0, path.size].should.equal(path)
39
+ end
40
+ end
41
+
42
+ test "should NOT create a pid file in the app's path when daemonizing and :pid_file is given as false" do
43
+ with_new_initializer_with_no_path_changing_behavior do
44
+ ahn = Adhearsion::Initializer.new path, :daemon => true, :pid_file => false
45
+ assert_nil ahn.pid_file
46
+ end
47
+ end
48
+
49
+ test "should create a designated pid file when supplied a String path as :pid_file" do
50
+ random_file = "/tmp/AHN_TEST_#{rand 100000}.pid"
51
+ with_new_initializer_with_no_path_changing_behavior do
52
+ ahn = Adhearsion::Initializer.new path, :pid_file => random_file
53
+ ahn.pid_file.should.equal(random_file)
54
+ assert File.exists?(random_file)
55
+ File.delete random_file
56
+ end
57
+ end
58
+
59
+ private
60
+ def path
61
+ '/any/ole/path'
62
+ end
63
+ end
64
+
65
+ context "AHN_ROOT" do
66
+ include InitializerStubs
67
+ setup do
68
+ Object.send(:remove_const, :AHN_ROOT) if defined? AHN_ROOT
69
+ end
70
+
71
+ test "initializing will create the AHN_ROOT" do
72
+ with_new_initializer_with_no_path_changing_behavior do
73
+ ahn = Adhearsion::Initializer.new path
74
+ assert Object.constants.include?("AHN_ROOT")
75
+ end
76
+ end
77
+
78
+ test "swapping out the base_path for the duration of the block" do
79
+ original_base_path = '.'
80
+ temporary_base = '/foo'
81
+
82
+ path = Adhearsion::PathString.new(original_base_path)
83
+ path.should.equal original_base_path
84
+
85
+ path.using_base_path temporary_base do
86
+ path.should.equal temporary_base
87
+ end
88
+ path.should.equal original_base_path
89
+ end
90
+
91
+ test "creating the AHN_ROOT will set defaults" do
92
+ with_new_initializer_with_no_path_changing_behavior do
93
+ ahn = Adhearsion::Initializer.new path
94
+ full_path = File.expand_path(path)
95
+ AHN_ROOT.to_s.should.equal(full_path)
96
+ AHN_ROOT.component_path.should.equal(File.join(full_path, "components"))
97
+ AHN_ROOT.log_path.should.equal(File.join(full_path, "logs"))
98
+ AHN_ROOT.dialplan_path.should.equal(full_path)
99
+ end
100
+ end
101
+ private
102
+ def path
103
+ '/any/ole/path'
104
+ end
105
+ end
@@ -0,0 +1,80 @@
1
+ require File.dirname(__FILE__) + "/test_helper"
2
+
3
+ context 'The ahn_log command' do
4
+
5
+ test 'should add the ahn_log method to the global namespace' do
6
+ ahn_log.should.be Adhearsion::Logging::DefaultAdhearsionLogger
7
+ end
8
+
9
+ test "should log to the standard Adhearsion logger when given arguments" do
10
+ message = "o hai. ur home erly."
11
+ flexmock(Log4r::Logger['ahn']).should_receive(:info).once.with(message)
12
+ ahn_log message
13
+ end
14
+
15
+ test 'should create a new logger when given method_missing' do
16
+ ahn_log.micromenus 'danger will robinson!'
17
+ Log4r::Logger['micromenus'].should.not.be nil
18
+ end
19
+
20
+ test 'should define a singleton method on itself of any name found by method_missing' do
21
+ ahn_log.agi "SOMETHING IMPORTANT HAPPENED"
22
+ Adhearsion::Logging::AdhearsionLogger.instance_methods.should.include 'agi'
23
+ end
24
+
25
+ test "dynamically generated loggers should support logging with blocks" do
26
+ # I had to comment out this test because Flexmock makes it impossible to#
27
+ # set up an expectation for receiving blocks.
28
+
29
+ # proc_to_log = lambda { [1,2,3].reverse.join }
30
+ #
31
+ # info_catcher = flexmock "A logger that responds to info()"
32
+ # info_catcher.should_receive(:info).once.with(&proc_to_log)
33
+ #
34
+ # flexmock(Log4r::Logger).should_receive(:[]).with('log4r')
35
+ # flexmock(Log4r::Logger).should_receive(:[]).once.with('ami').and_return info_catcher
36
+ #
37
+ # ahn_log.ami(&proc_to_log)
38
+ end
39
+
40
+ test 'new loggers created by method_missing() should be instances of AdhearsionLogger' do
41
+ ahn_log.qwerty.should.be.kind_of Adhearsion::Logging::AdhearsionLogger
42
+ end
43
+
44
+ end
45
+
46
+ # Essential for running the tests
47
+ context 'Logger level changing' do
48
+
49
+ after :each do
50
+ Adhearsion::Logging.logging_level = :info
51
+ end
52
+
53
+ after :all do
54
+ Adhearsion::Logging.logging_level = :fatal # Silence them again
55
+ end
56
+
57
+ test 'changing the logging level should affect all loggers' do
58
+ loggers = [ahn_log.one, ahn_log.two, ahn_log.three]
59
+ loggers.map(&:level).should.not == [Log4r::WARN] * 3
60
+ Adhearsion::Logging.logging_level = :warn
61
+ loggers.map(&:level).should == [Log4r::WARN] * 3
62
+ end
63
+
64
+ test 'a new logger should have the global Adhearsion logging level' do
65
+ ahn_log.foo.level.should.equal Log4r::INFO
66
+ Adhearsion::Logging.logging_level = :fatal
67
+ ahn_log.brand_new.level.should.equal Log4r::FATAL
68
+ end
69
+
70
+ test '#silence!() should change the level to be FATAL' do
71
+ flexmock(Adhearsion::Logging::DefaultAdhearsionLogger).should_receive(:level=).once.with(Log4r::FATAL)
72
+ Adhearsion::Logging.silence!
73
+ end
74
+
75
+ test '#unsilence!() should change the level to be INFO' do
76
+ flexmock(Adhearsion::Logging::DefaultAdhearsionLogger).should_receive(:level=).once.with(Log4r::INFO)
77
+ Adhearsion::Logging.unsilence!
78
+ end
79
+
80
+ end
@@ -0,0 +1,54 @@
1
+ require File.dirname(__FILE__) + "/test_helper.rb"
2
+ require 'adhearsion/core_extensions/relationship_properties'
3
+
4
+ describe "Module#relationships" do
5
+
6
+ describe "Overriding relationships in subclasses" do
7
+
8
+ it "should be overridable in subclasses" do
9
+ super_class = Class.new do
10
+ relationships :storage_medium => Array
11
+ end
12
+ sub_class = Class.new(super_class) do
13
+ relationships :storage_medium => Hash
14
+ end
15
+ super_class.new.send(:storage_medium).should.equal Array
16
+ sub_class.new.send(:storage_medium).should.equal Hash
17
+ end
18
+
19
+ it "should not affect other defined relationships" do
20
+ super_class = Class.new do
21
+ relationships :io_class => TCPSocket, :error_class => StandardError
22
+ end
23
+ sub_class = Class.new(super_class) do
24
+ relationships :error_class => RuntimeError
25
+ end
26
+ super_class.new.send(:io_class).should.equal TCPSocket
27
+ sub_class.new.send(:io_class).should.equal TCPSocket
28
+ end
29
+
30
+ end
31
+
32
+ it "should be accessible within instance methods of that Class as another instance method" do
33
+ klass = Class.new do
34
+ relationships :struct => Struct
35
+ def new_struct
36
+ struct.new
37
+ end
38
+ end
39
+ end
40
+
41
+ it "should be accessible in subclasses" do
42
+ super_class = Class.new do
43
+ relationships :number_class => Bignum
44
+ end
45
+
46
+ Class.new(super_class) do
47
+ def number_class_name
48
+ number_class.name
49
+ end
50
+ end.new.number_class_name.should == "Bignum"
51
+
52
+ end
53
+
54
+ end
@@ -0,0 +1,23 @@
1
+ def ami(m, &block) context("AMI", "##{m}", &block) end
2
+
3
+ ami:ping do
4
+ test "should return the number of seconds before a response if reachable"
5
+ test "should raise a PingError if unreachable"
6
+ end
7
+
8
+ ami:agents do
9
+ test "should return an Array of Agent objects"
10
+ test "should convert the logged-in time to a Ruby DateTime"
11
+ test "should convert the logged-in status to a Symbol"
12
+ test "should work with known logged-in statuses"
13
+ test "should convert unrecognized logged-in statuses to :unknown"
14
+ end
15
+
16
+ ami:queues do
17
+
18
+ end
19
+
20
+ ami:state_of_extension do
21
+ test "should take one argument"
22
+ test "should "
23
+ end