azure_application_insights 0.5.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (86) hide show
  1. checksums.yaml +7 -0
  2. data/.github/workflows/gem-push.yml +34 -0
  3. data/.gitignore +40 -0
  4. data/.travis.yml +22 -0
  5. data/CHANGELOG.md +17 -0
  6. data/CONTRIBUTING.md +68 -0
  7. data/Gemfile +4 -0
  8. data/LICENSE.txt +11 -0
  9. data/README.md +161 -0
  10. data/Rakefile +15 -0
  11. data/application_insights.gemspec +30 -0
  12. data/lib/application_insights/channel/asynchronous_queue.rb +58 -0
  13. data/lib/application_insights/channel/asynchronous_sender.rb +133 -0
  14. data/lib/application_insights/channel/contracts/application.rb +14 -0
  15. data/lib/application_insights/channel/contracts/cloud.rb +14 -0
  16. data/lib/application_insights/channel/contracts/data.rb +14 -0
  17. data/lib/application_insights/channel/contracts/data_point.rb +24 -0
  18. data/lib/application_insights/channel/contracts/data_point_type.rb +7 -0
  19. data/lib/application_insights/channel/contracts/dependency_kind.rb +9 -0
  20. data/lib/application_insights/channel/contracts/dependency_source_type.rb +9 -0
  21. data/lib/application_insights/channel/contracts/device.rb +28 -0
  22. data/lib/application_insights/channel/contracts/envelope.rb +40 -0
  23. data/lib/application_insights/channel/contracts/event_data.rb +28 -0
  24. data/lib/application_insights/channel/contracts/exception_data.rb +37 -0
  25. data/lib/application_insights/channel/contracts/exception_details.rb +28 -0
  26. data/lib/application_insights/channel/contracts/internal.rb +14 -0
  27. data/lib/application_insights/channel/contracts/json_serializable.rb +59 -0
  28. data/lib/application_insights/channel/contracts/location.rb +16 -0
  29. data/lib/application_insights/channel/contracts/message_data.rb +24 -0
  30. data/lib/application_insights/channel/contracts/metric_data.rb +27 -0
  31. data/lib/application_insights/channel/contracts/operation.rb +19 -0
  32. data/lib/application_insights/channel/contracts/page_view_data.rb +30 -0
  33. data/lib/application_insights/channel/contracts/remote_dependency_data.rb +56 -0
  34. data/lib/application_insights/channel/contracts/request_data.rb +36 -0
  35. data/lib/application_insights/channel/contracts/session.rb +15 -0
  36. data/lib/application_insights/channel/contracts/severity_level.rb +13 -0
  37. data/lib/application_insights/channel/contracts/stack_frame.rb +17 -0
  38. data/lib/application_insights/channel/contracts/user.rb +19 -0
  39. data/lib/application_insights/channel/event.rb +68 -0
  40. data/lib/application_insights/channel/queue_base.rb +73 -0
  41. data/lib/application_insights/channel/sender_base.rb +88 -0
  42. data/lib/application_insights/channel/synchronous_queue.rb +45 -0
  43. data/lib/application_insights/channel/synchronous_sender.rb +17 -0
  44. data/lib/application_insights/channel/telemetry_channel.rb +131 -0
  45. data/lib/application_insights/channel/telemetry_context.rb +85 -0
  46. data/lib/application_insights/rack/track_request.rb +158 -0
  47. data/lib/application_insights/telemetry_client.rb +229 -0
  48. data/lib/application_insights/unhandled_exception.rb +49 -0
  49. data/lib/application_insights/version.rb +3 -0
  50. data/lib/application_insights.rb +9 -0
  51. data/test/application_insights/channel/contracts/test_application.rb +44 -0
  52. data/test/application_insights/channel/contracts/test_cloud.rb +44 -0
  53. data/test/application_insights/channel/contracts/test_data.rb +44 -0
  54. data/test/application_insights/channel/contracts/test_data_point.rb +109 -0
  55. data/test/application_insights/channel/contracts/test_device.rb +200 -0
  56. data/test/application_insights/channel/contracts/test_envelope.rb +209 -0
  57. data/test/application_insights/channel/contracts/test_event_data.rb +62 -0
  58. data/test/application_insights/channel/contracts/test_exception_data.rb +111 -0
  59. data/test/application_insights/channel/contracts/test_exception_details.rb +106 -0
  60. data/test/application_insights/channel/contracts/test_internal.rb +44 -0
  61. data/test/application_insights/channel/contracts/test_location.rb +70 -0
  62. data/test/application_insights/channel/contracts/test_message_data.rb +66 -0
  63. data/test/application_insights/channel/contracts/test_metric_data.rb +50 -0
  64. data/test/application_insights/channel/contracts/test_operation.rb +109 -0
  65. data/test/application_insights/channel/contracts/test_page_view_data.rb +88 -0
  66. data/test/application_insights/channel/contracts/test_remote_dependency_data.rb +209 -0
  67. data/test/application_insights/channel/contracts/test_request_data.rb +153 -0
  68. data/test/application_insights/channel/contracts/test_session.rb +57 -0
  69. data/test/application_insights/channel/contracts/test_stack_frame.rb +83 -0
  70. data/test/application_insights/channel/contracts/test_user.rb +96 -0
  71. data/test/application_insights/channel/test_asynchronous_queue.rb +47 -0
  72. data/test/application_insights/channel/test_asynchronous_sender.rb +81 -0
  73. data/test/application_insights/channel/test_event.rb +53 -0
  74. data/test/application_insights/channel/test_queue_base.rb +89 -0
  75. data/test/application_insights/channel/test_sender_base.rb +94 -0
  76. data/test/application_insights/channel/test_synchronous_queue.rb +28 -0
  77. data/test/application_insights/channel/test_synchronous_sender.rb +11 -0
  78. data/test/application_insights/channel/test_telemetry_channel.rb +167 -0
  79. data/test/application_insights/channel/test_telemetry_context.rb +83 -0
  80. data/test/application_insights/mock_sender.rb +37 -0
  81. data/test/application_insights/rack/test_track_request.rb +182 -0
  82. data/test/application_insights/test_logger.rb +10 -0
  83. data/test/application_insights/test_telemetry_client.rb +138 -0
  84. data/test/application_insights/test_unhandled_exception.rb +23 -0
  85. data/test/application_insights.rb +8 -0
  86. metadata +247 -0
@@ -0,0 +1,200 @@
1
+ require_relative '../../../../lib/application_insights/channel/contracts/device'
2
+ require 'test/unit'
3
+
4
+ include ApplicationInsights::Channel
5
+
6
+ class TestDevice < Test::Unit::TestCase
7
+ def test_initialize
8
+ item = Contracts::Device.new
9
+ assert_not_nil item
10
+ end
11
+
12
+ def test_id_works_as_expected
13
+ expected = 'Test string'
14
+ item = Contracts::Device.new
15
+ item.id = expected
16
+ actual = item.id
17
+ assert_equal expected, actual
18
+ expected = 'Other string'
19
+ item.id = expected
20
+ actual = item.id
21
+ assert_equal expected, actual
22
+ end
23
+
24
+ def test_ip_works_as_expected
25
+ expected = 'Test string'
26
+ item = Contracts::Device.new
27
+ item.ip = expected
28
+ actual = item.ip
29
+ assert_equal expected, actual
30
+ expected = 'Other string'
31
+ item.ip = expected
32
+ actual = item.ip
33
+ assert_equal expected, actual
34
+ end
35
+
36
+ def test_language_works_as_expected
37
+ expected = 'Test string'
38
+ item = Contracts::Device.new
39
+ item.language = expected
40
+ actual = item.language
41
+ assert_equal expected, actual
42
+ expected = 'Other string'
43
+ item.language = expected
44
+ actual = item.language
45
+ assert_equal expected, actual
46
+ end
47
+
48
+ def test_locale_works_as_expected
49
+ expected = 'Test string'
50
+ item = Contracts::Device.new
51
+ item.locale = expected
52
+ actual = item.locale
53
+ assert_equal expected, actual
54
+ expected = 'Other string'
55
+ item.locale = expected
56
+ actual = item.locale
57
+ assert_equal expected, actual
58
+ end
59
+
60
+ def test_model_works_as_expected
61
+ expected = 'Test string'
62
+ item = Contracts::Device.new
63
+ item.model = expected
64
+ actual = item.model
65
+ assert_equal expected, actual
66
+ expected = 'Other string'
67
+ item.model = expected
68
+ actual = item.model
69
+ assert_equal expected, actual
70
+ end
71
+
72
+ def test_network_works_as_expected
73
+ expected = 'Test string'
74
+ item = Contracts::Device.new
75
+ item.network = expected
76
+ actual = item.network
77
+ assert_equal expected, actual
78
+ expected = 'Other string'
79
+ item.network = expected
80
+ actual = item.network
81
+ assert_equal expected, actual
82
+ end
83
+
84
+ def test_oem_name_works_as_expected
85
+ expected = 'Test string'
86
+ item = Contracts::Device.new
87
+ item.oem_name = expected
88
+ actual = item.oem_name
89
+ assert_equal expected, actual
90
+ expected = 'Other string'
91
+ item.oem_name = expected
92
+ actual = item.oem_name
93
+ assert_equal expected, actual
94
+ end
95
+
96
+ def test_os_works_as_expected
97
+ expected = 'Test string'
98
+ item = Contracts::Device.new
99
+ item.os = expected
100
+ actual = item.os
101
+ assert_equal expected, actual
102
+ expected = 'Other string'
103
+ item.os = expected
104
+ actual = item.os
105
+ assert_equal expected, actual
106
+ end
107
+
108
+ def test_os_version_works_as_expected
109
+ expected = 'Test string'
110
+ item = Contracts::Device.new
111
+ item.os_version = expected
112
+ actual = item.os_version
113
+ assert_equal expected, actual
114
+ expected = 'Other string'
115
+ item.os_version = expected
116
+ actual = item.os_version
117
+ assert_equal expected, actual
118
+ end
119
+
120
+ def test_role_instance_works_as_expected
121
+ expected = 'Test string'
122
+ item = Contracts::Device.new
123
+ item.role_instance = expected
124
+ actual = item.role_instance
125
+ assert_equal expected, actual
126
+ expected = 'Other string'
127
+ item.role_instance = expected
128
+ actual = item.role_instance
129
+ assert_equal expected, actual
130
+ end
131
+
132
+ def test_role_name_works_as_expected
133
+ expected = 'Test string'
134
+ item = Contracts::Device.new
135
+ item.role_name = expected
136
+ actual = item.role_name
137
+ assert_equal expected, actual
138
+ expected = 'Other string'
139
+ item.role_name = expected
140
+ actual = item.role_name
141
+ assert_equal expected, actual
142
+ end
143
+
144
+ def test_screen_resolution_works_as_expected
145
+ expected = 'Test string'
146
+ item = Contracts::Device.new
147
+ item.screen_resolution = expected
148
+ actual = item.screen_resolution
149
+ assert_equal expected, actual
150
+ expected = 'Other string'
151
+ item.screen_resolution = expected
152
+ actual = item.screen_resolution
153
+ assert_equal expected, actual
154
+ end
155
+
156
+ def test_type_works_as_expected
157
+ expected = 'Test string'
158
+ item = Contracts::Device.new
159
+ item.type = expected
160
+ actual = item.type
161
+ assert_equal expected, actual
162
+ expected = 'Other string'
163
+ item.type = expected
164
+ actual = item.type
165
+ assert_equal expected, actual
166
+ end
167
+
168
+ def test_machine_name_works_as_expected
169
+ expected = 'Test string'
170
+ item = Contracts::Device.new
171
+ item.machine_name = expected
172
+ actual = item.machine_name
173
+ assert_equal expected, actual
174
+ expected = 'Other string'
175
+ item.machine_name = expected
176
+ actual = item.machine_name
177
+ assert_equal expected, actual
178
+ end
179
+
180
+ def test_to_json_works_as_expected
181
+ item = Contracts::Device.new
182
+ item.id = 'Test string'
183
+ item.ip = 'Test string'
184
+ item.language = 'Test string'
185
+ item.locale = 'Test string'
186
+ item.model = 'Test string'
187
+ item.network = 'Test string'
188
+ item.oem_name = 'Test string'
189
+ item.os = 'Test string'
190
+ item.os_version = 'Test string'
191
+ item.role_instance = 'Test string'
192
+ item.role_name = 'Test string'
193
+ item.screen_resolution = 'Test string'
194
+ item.type = 'Test string'
195
+ item.machine_name = 'Test string'
196
+ actual = item.to_json
197
+ expected = '{"ai.device.id":"Test string","ai.device.ip":"Test string","ai.device.language":"Test string","ai.device.locale":"Test string","ai.device.model":"Test string","ai.device.network":"Test string","ai.device.oemName":"Test string","ai.device.os":"Test string","ai.device.osVersion":"Test string","ai.device.roleInstance":"Test string","ai.device.roleName":"Test string","ai.device.screenResolution":"Test string","ai.device.type":"Test string","ai.device.machineName":"Test string"}'
198
+ assert_equal expected, actual
199
+ end
200
+ end
@@ -0,0 +1,209 @@
1
+ require_relative '../../../../lib/application_insights/channel/contracts/envelope'
2
+ require 'test/unit'
3
+
4
+ include ApplicationInsights::Channel
5
+
6
+ class TestEnvelope < Test::Unit::TestCase
7
+ def test_initialize
8
+ item = Contracts::Envelope.new
9
+ assert_not_nil item
10
+ end
11
+
12
+ def test_ver_works_as_expected
13
+ expected = 42
14
+ item = Contracts::Envelope.new
15
+ item.ver = expected
16
+ actual = item.ver
17
+ assert_equal expected, actual
18
+ expected = 13
19
+ item.ver = expected
20
+ actual = item.ver
21
+ assert_equal expected, actual
22
+ end
23
+
24
+ def test_name_works_as_expected
25
+ expected = 'Test string'
26
+ item = Contracts::Envelope.new
27
+ item.name = expected
28
+ actual = item.name
29
+ assert_equal expected, actual
30
+ expected = 'Other string'
31
+ item.name = expected
32
+ actual = item.name
33
+ assert_equal expected, actual
34
+ end
35
+
36
+ def test_time_works_as_expected
37
+ expected = 'Test string'
38
+ item = Contracts::Envelope.new
39
+ item.time = expected
40
+ actual = item.time
41
+ assert_equal expected, actual
42
+ expected = 'Other string'
43
+ item.time = expected
44
+ actual = item.time
45
+ assert_equal expected, actual
46
+ end
47
+
48
+ def test_sample_rate_works_as_expected
49
+ expected = 1.5
50
+ item = Contracts::Envelope.new
51
+ item.sample_rate = expected
52
+ actual = item.sample_rate
53
+ assert_equal expected, actual
54
+ expected = 4.8
55
+ item.sample_rate = expected
56
+ actual = item.sample_rate
57
+ assert_equal expected, actual
58
+ end
59
+
60
+ def test_seq_works_as_expected
61
+ expected = 'Test string'
62
+ item = Contracts::Envelope.new
63
+ item.seq = expected
64
+ actual = item.seq
65
+ assert_equal expected, actual
66
+ expected = 'Other string'
67
+ item.seq = expected
68
+ actual = item.seq
69
+ assert_equal expected, actual
70
+ end
71
+
72
+ def test_i_key_works_as_expected
73
+ expected = 'Test string'
74
+ item = Contracts::Envelope.new
75
+ item.i_key = expected
76
+ actual = item.i_key
77
+ assert_equal expected, actual
78
+ expected = 'Other string'
79
+ item.i_key = expected
80
+ actual = item.i_key
81
+ assert_equal expected, actual
82
+ end
83
+
84
+ def test_flags_works_as_expected
85
+ expected = 42
86
+ item = Contracts::Envelope.new
87
+ item.flags = expected
88
+ actual = item.flags
89
+ assert_equal expected, actual
90
+ expected = 13
91
+ item.flags = expected
92
+ actual = item.flags
93
+ assert_equal expected, actual
94
+ end
95
+
96
+ def test_device_id_works_as_expected
97
+ expected = 'Test string'
98
+ item = Contracts::Envelope.new
99
+ item.device_id = expected
100
+ actual = item.device_id
101
+ assert_equal expected, actual
102
+ expected = 'Other string'
103
+ item.device_id = expected
104
+ actual = item.device_id
105
+ assert_equal expected, actual
106
+ end
107
+
108
+ def test_os_works_as_expected
109
+ expected = 'Test string'
110
+ item = Contracts::Envelope.new
111
+ item.os = expected
112
+ actual = item.os
113
+ assert_equal expected, actual
114
+ expected = 'Other string'
115
+ item.os = expected
116
+ actual = item.os
117
+ assert_equal expected, actual
118
+ end
119
+
120
+ def test_os_ver_works_as_expected
121
+ expected = 'Test string'
122
+ item = Contracts::Envelope.new
123
+ item.os_ver = expected
124
+ actual = item.os_ver
125
+ assert_equal expected, actual
126
+ expected = 'Other string'
127
+ item.os_ver = expected
128
+ actual = item.os_ver
129
+ assert_equal expected, actual
130
+ end
131
+
132
+ def test_app_id_works_as_expected
133
+ expected = 'Test string'
134
+ item = Contracts::Envelope.new
135
+ item.app_id = expected
136
+ actual = item.app_id
137
+ assert_equal expected, actual
138
+ expected = 'Other string'
139
+ item.app_id = expected
140
+ actual = item.app_id
141
+ assert_equal expected, actual
142
+ end
143
+
144
+ def test_app_ver_works_as_expected
145
+ expected = 'Test string'
146
+ item = Contracts::Envelope.new
147
+ item.app_ver = expected
148
+ actual = item.app_ver
149
+ assert_equal expected, actual
150
+ expected = 'Other string'
151
+ item.app_ver = expected
152
+ actual = item.app_ver
153
+ assert_equal expected, actual
154
+ end
155
+
156
+ def test_user_id_works_as_expected
157
+ expected = 'Test string'
158
+ item = Contracts::Envelope.new
159
+ item.user_id = expected
160
+ actual = item.user_id
161
+ assert_equal expected, actual
162
+ expected = 'Other string'
163
+ item.user_id = expected
164
+ actual = item.user_id
165
+ assert_equal expected, actual
166
+ end
167
+
168
+ def test_tags_works_as_expected
169
+ item = Contracts::Envelope.new
170
+ actual = item.tags
171
+ assert_not_nil actual
172
+ end
173
+
174
+ def test_data_works_as_expected
175
+ expected = { 'key' => 'value' }
176
+ item = Contracts::Envelope.new
177
+ item.data = expected
178
+ actual = item.data
179
+ assert_equal expected, actual
180
+ expected = { 'key' => 'value' }
181
+ item.data = expected
182
+ actual = item.data
183
+ assert_equal expected, actual
184
+ end
185
+
186
+ def test_to_json_works_as_expected
187
+ item = Contracts::Envelope.new
188
+ item.ver = 42
189
+ item.name = 'Test string'
190
+ item.time = 'Test string'
191
+ item.sample_rate = 1.5
192
+ item.seq = 'Test string'
193
+ item.i_key = 'Test string'
194
+ item.flags = 42
195
+ item.device_id = 'Test string'
196
+ item.os = 'Test string'
197
+ item.os_ver = 'Test string'
198
+ item.app_id = 'Test string'
199
+ item.app_ver = 'Test string'
200
+ item.user_id = 'Test string'
201
+ { 'key1' => 'test value 1' , 'key2' => 'test value 2' }.each do |key, value|
202
+ item.tags[key] = value
203
+ end
204
+ item.data = { 'key' => 'value' }
205
+ actual = item.to_json
206
+ expected = '{"ver":42,"name":"Test string","time":"Test string","sampleRate":1.5,"seq":"Test string","iKey":"Test string","flags":42,"deviceId":"Test string","os":"Test string","osVer":"Test string","appId":"Test string","appVer":"Test string","userId":"Test string","tags":{"key1":"test value 1","key2":"test value 2"},"data":{"key":"value"}}'
207
+ assert_equal expected, actual
208
+ end
209
+ end
@@ -0,0 +1,62 @@
1
+ require_relative '../../../../lib/application_insights/channel/contracts/event_data'
2
+ require 'test/unit'
3
+
4
+ include ApplicationInsights::Channel
5
+
6
+ class TestEventData < Test::Unit::TestCase
7
+ def test_initialize
8
+ item = Contracts::EventData.new
9
+ assert_not_nil item
10
+ end
11
+
12
+ def test_ver_works_as_expected
13
+ expected = 42
14
+ item = Contracts::EventData.new
15
+ item.ver = expected
16
+ actual = item.ver
17
+ assert_equal expected, actual
18
+ expected = 13
19
+ item.ver = expected
20
+ actual = item.ver
21
+ assert_equal expected, actual
22
+ end
23
+
24
+ def test_name_works_as_expected
25
+ expected = 'Test string'
26
+ item = Contracts::EventData.new
27
+ item.name = expected
28
+ actual = item.name
29
+ assert_equal expected, actual
30
+ expected = 'Other string'
31
+ item.name = expected
32
+ actual = item.name
33
+ assert_equal expected, actual
34
+ end
35
+
36
+ def test_properties_works_as_expected
37
+ item = Contracts::EventData.new
38
+ actual = item.properties
39
+ assert_not_nil actual
40
+ end
41
+
42
+ def test_measurements_works_as_expected
43
+ item = Contracts::EventData.new
44
+ actual = item.measurements
45
+ assert_not_nil actual
46
+ end
47
+
48
+ def test_to_json_works_as_expected
49
+ item = Contracts::EventData.new
50
+ item.ver = 42
51
+ item.name = 'Test string'
52
+ { 'key1' => 'test value 1' , 'key2' => 'test value 2' }.each do |key, value|
53
+ item.properties[key] = value
54
+ end
55
+ { 'key1' => 3.1415 , 'key2' => 42.2 }.each do |key, value|
56
+ item.measurements[key] = value
57
+ end
58
+ actual = item.to_json
59
+ expected = '{"ver":42,"name":"Test string","properties":{"key1":"test value 1","key2":"test value 2"},"measurements":{"key1":3.1415,"key2":42.2}}'
60
+ assert_equal expected, actual
61
+ end
62
+ end
@@ -0,0 +1,111 @@
1
+ require_relative '../../../../lib/application_insights/channel/contracts/exception_data'
2
+ require 'test/unit'
3
+
4
+ include ApplicationInsights::Channel
5
+
6
+ class TestExceptionData < Test::Unit::TestCase
7
+ def test_initialize
8
+ item = Contracts::ExceptionData.new
9
+ assert_not_nil item
10
+ end
11
+
12
+ def test_ver_works_as_expected
13
+ expected = 42
14
+ item = Contracts::ExceptionData.new
15
+ item.ver = expected
16
+ actual = item.ver
17
+ assert_equal expected, actual
18
+ expected = 13
19
+ item.ver = expected
20
+ actual = item.ver
21
+ assert_equal expected, actual
22
+ end
23
+
24
+ def test_handled_at_works_as_expected
25
+ expected = 'Test string'
26
+ item = Contracts::ExceptionData.new
27
+ item.handled_at = expected
28
+ actual = item.handled_at
29
+ assert_equal expected, actual
30
+ expected = 'Other string'
31
+ item.handled_at = expected
32
+ actual = item.handled_at
33
+ assert_equal expected, actual
34
+ end
35
+
36
+ def test_exceptions_works_as_expected
37
+ item = Contracts::ExceptionData.new
38
+ actual = item.exceptions
39
+ assert_not_nil actual
40
+ end
41
+
42
+ def test_severity_level_works_as_expected
43
+ expected = 5
44
+ item = Contracts::ExceptionData.new
45
+ item.severity_level = expected
46
+ actual = item.severity_level
47
+ assert_equal expected, actual
48
+ expected = 3
49
+ item.severity_level = expected
50
+ actual = item.severity_level
51
+ assert_equal expected, actual
52
+ end
53
+
54
+ def test_problem_id_works_as_expected
55
+ expected = 'Test string'
56
+ item = Contracts::ExceptionData.new
57
+ item.problem_id = expected
58
+ actual = item.problem_id
59
+ assert_equal expected, actual
60
+ expected = 'Other string'
61
+ item.problem_id = expected
62
+ actual = item.problem_id
63
+ assert_equal expected, actual
64
+ end
65
+
66
+ def test_crash_thread_id_works_as_expected
67
+ expected = 42
68
+ item = Contracts::ExceptionData.new
69
+ item.crash_thread_id = expected
70
+ actual = item.crash_thread_id
71
+ assert_equal expected, actual
72
+ expected = 13
73
+ item.crash_thread_id = expected
74
+ actual = item.crash_thread_id
75
+ assert_equal expected, actual
76
+ end
77
+
78
+ def test_properties_works_as_expected
79
+ item = Contracts::ExceptionData.new
80
+ actual = item.properties
81
+ assert_not_nil actual
82
+ end
83
+
84
+ def test_measurements_works_as_expected
85
+ item = Contracts::ExceptionData.new
86
+ actual = item.measurements
87
+ assert_not_nil actual
88
+ end
89
+
90
+ def test_to_json_works_as_expected
91
+ item = Contracts::ExceptionData.new
92
+ item.ver = 42
93
+ item.handled_at = 'Test string'
94
+ [ { 'key' => 'value' } ].each do |value|
95
+ item.exceptions.push value
96
+ end
97
+
98
+ item.severity_level = 5
99
+ item.problem_id = 'Test string'
100
+ item.crash_thread_id = 42
101
+ { 'key1' => 'test value 1' , 'key2' => 'test value 2' }.each do |key, value|
102
+ item.properties[key] = value
103
+ end
104
+ { 'key1' => 3.1415 , 'key2' => 42.2 }.each do |key, value|
105
+ item.measurements[key] = value
106
+ end
107
+ actual = item.to_json
108
+ expected = '{"ver":42,"handledAt":"Test string","exceptions":[{"key":"value"}],"severityLevel":5,"problemId":"Test string","crashThreadId":42,"properties":{"key1":"test value 1","key2":"test value 2"},"measurements":{"key1":3.1415,"key2":42.2}}'
109
+ assert_equal expected, actual
110
+ end
111
+ end
@@ -0,0 +1,106 @@
1
+ require_relative '../../../../lib/application_insights/channel/contracts/exception_details'
2
+ require 'test/unit'
3
+
4
+ include ApplicationInsights::Channel
5
+
6
+ class TestExceptionDetails < Test::Unit::TestCase
7
+ def test_initialize
8
+ item = Contracts::ExceptionDetails.new
9
+ assert_not_nil item
10
+ end
11
+
12
+ def test_id_works_as_expected
13
+ expected = 42
14
+ item = Contracts::ExceptionDetails.new
15
+ item.id = expected
16
+ actual = item.id
17
+ assert_equal expected, actual
18
+ expected = 13
19
+ item.id = expected
20
+ actual = item.id
21
+ assert_equal expected, actual
22
+ end
23
+
24
+ def test_outer_id_works_as_expected
25
+ expected = 42
26
+ item = Contracts::ExceptionDetails.new
27
+ item.outer_id = expected
28
+ actual = item.outer_id
29
+ assert_equal expected, actual
30
+ expected = 13
31
+ item.outer_id = expected
32
+ actual = item.outer_id
33
+ assert_equal expected, actual
34
+ end
35
+
36
+ def test_type_name_works_as_expected
37
+ expected = 'Test string'
38
+ item = Contracts::ExceptionDetails.new
39
+ item.type_name = expected
40
+ actual = item.type_name
41
+ assert_equal expected, actual
42
+ expected = 'Other string'
43
+ item.type_name = expected
44
+ actual = item.type_name
45
+ assert_equal expected, actual
46
+ end
47
+
48
+ def test_message_works_as_expected
49
+ expected = 'Test string'
50
+ item = Contracts::ExceptionDetails.new
51
+ item.message = expected
52
+ actual = item.message
53
+ assert_equal expected, actual
54
+ expected = 'Other string'
55
+ item.message = expected
56
+ actual = item.message
57
+ assert_equal expected, actual
58
+ end
59
+
60
+ def test_has_full_stack_works_as_expected
61
+ expected = true
62
+ item = Contracts::ExceptionDetails.new
63
+ item.has_full_stack = expected
64
+ actual = item.has_full_stack
65
+ assert_equal expected, actual
66
+ expected = false
67
+ item.has_full_stack = expected
68
+ actual = item.has_full_stack
69
+ assert_equal expected, actual
70
+ end
71
+
72
+ def test_stack_works_as_expected
73
+ expected = 'Test string'
74
+ item = Contracts::ExceptionDetails.new
75
+ item.stack = expected
76
+ actual = item.stack
77
+ assert_equal expected, actual
78
+ expected = 'Other string'
79
+ item.stack = expected
80
+ actual = item.stack
81
+ assert_equal expected, actual
82
+ end
83
+
84
+ def test_parsed_stack_works_as_expected
85
+ item = Contracts::ExceptionDetails.new
86
+ actual = item.parsed_stack
87
+ assert_not_nil actual
88
+ end
89
+
90
+ def test_to_json_works_as_expected
91
+ item = Contracts::ExceptionDetails.new
92
+ item.id = 42
93
+ item.outer_id = 42
94
+ item.type_name = 'Test string'
95
+ item.message = 'Test string'
96
+ item.has_full_stack = true
97
+ item.stack = 'Test string'
98
+ [ { 'key' => 'value' } ].each do |value|
99
+ item.parsed_stack.push value
100
+ end
101
+
102
+ actual = item.to_json
103
+ expected = '{"id":42,"outerId":42,"typeName":"Test string","message":"Test string","hasFullStack":true,"stack":"Test string","parsedStack":[{"key":"value"}]}'
104
+ assert_equal expected, actual
105
+ end
106
+ end