trema 0.4.7 → 0.4.8

Sign up to get free protection for your applications and to get access to all the features.
Files changed (718) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +33 -54
  3. data/.hound.yml +3 -0
  4. data/.rspec +3 -0
  5. data/.rubocop.yml +17 -1
  6. data/.travis.yml +14 -18
  7. data/CHANGELOG.md +10 -0
  8. data/Gemfile +1 -26
  9. data/README.md +25 -241
  10. data/Rakefile +4 -1056
  11. data/bin/.gitignore +3 -0
  12. data/bin/trema +163 -237
  13. data/features/cleanup_on_failure.feature +118 -0
  14. data/features/logging.feature +73 -0
  15. data/features/open_flow13.feature +21 -0
  16. data/features/step_definitions/.gitignore +35 -0
  17. data/features/step_definitions/.rubocop.yml +5 -0
  18. data/features/step_definitions/.travis.yml +19 -0
  19. data/features/step_definitions/Gemfile +9 -0
  20. data/features/step_definitions/Guardfile +4 -0
  21. data/features/step_definitions/LICENSE +675 -0
  22. data/features/step_definitions/README.md +7 -0
  23. data/features/step_definitions/Rakefile +10 -0
  24. data/features/step_definitions/show_stats_steps.rb +56 -0
  25. data/features/step_definitions/virtual_link_steps.rb +8 -0
  26. data/features/support/env.rb +0 -73
  27. data/features/support/hooks.rb +6 -50
  28. data/features/trema_delete_link.feature +30 -0
  29. data/features/trema_killall.feature +56 -0
  30. data/features/trema_run.feature +47 -0
  31. data/features/trema_start.feature +73 -0
  32. data/features/trema_stop.feature +50 -0
  33. data/lib/trema.rb +4 -0
  34. data/lib/trema/command.rb +184 -0
  35. data/lib/trema/controller.rb +289 -0
  36. data/lib/trema/dirs.rb +14 -0
  37. data/lib/trema/drb.rb +32 -0
  38. data/lib/trema/logger.rb +63 -0
  39. data/lib/trema/monkey_patch/integer.rb +8 -0
  40. data/lib/trema/monkey_patch/integer/base_conversions.rb +12 -0
  41. data/lib/trema/monkey_patch/integer/durations.rb +12 -0
  42. data/lib/trema/switch.rb +83 -0
  43. data/lib/trema/version.rb +5 -0
  44. data/spec/spec_helper.rb +9 -178
  45. data/spec/trema/controller_spec.rb +4 -53
  46. data/tasks/.gitignore +34 -0
  47. data/tasks/LICENSE +675 -0
  48. data/tasks/README.md +6 -0
  49. data/tasks/cucumber.rake +14 -0
  50. data/tasks/flay.rake +15 -0
  51. data/tasks/flog.rake +25 -0
  52. data/tasks/gem.rake +15 -0
  53. data/tasks/reek.rake +11 -0
  54. data/tasks/relish.rake +8 -0
  55. data/tasks/rspec.rake +8 -0
  56. data/tasks/rubocop.rake +2 -16
  57. data/tasks/yard.rake +11 -0
  58. data/trema.gemspec +24 -23
  59. metadata +180 -720
  60. data/.yardopts +0 -4
  61. data/Doxyfile +0 -1679
  62. data/Guardfile +0 -14
  63. data/bin/quality +0 -31
  64. data/bin/trema-config +0 -59
  65. data/build.rb +0 -32
  66. data/cruise.rb +0 -409
  67. data/features/.nav +0 -50
  68. data/features/README.md +0 -7
  69. data/features/core/get_pid_by_trema_name.feature +0 -137
  70. data/features/core/packetin_filter.feature +0 -55
  71. data/features/core/switch_manager.feature +0 -41
  72. data/features/core/trema-config.feature +0 -55
  73. data/features/dsl/switch_port_specifier.feature +0 -15
  74. data/features/examples/dumper.feature +0 -35
  75. data/features/examples/hello_trema.feature +0 -23
  76. data/features/examples/learning_switch.feature +0 -37
  77. data/features/examples/list_switches.feature +0 -24
  78. data/features/examples/message.set_config.feature +0 -27
  79. data/features/examples/message.vendor-action.feature +0 -25
  80. data/features/examples/message.vendor-stats-request.feature +0 -20
  81. data/features/examples/multi_learning_switch.feature +0 -107
  82. data/features/examples/openflow_message.echo.feature +0 -59
  83. data/features/examples/openflow_message.features_request.feature +0 -35
  84. data/features/examples/openflow_message.hello.feature +0 -59
  85. data/features/examples/packet_in.feature +0 -33
  86. data/features/examples/packetin_filter_config.feature +0 -95
  87. data/features/examples/patch_panel.feature +0 -29
  88. data/features/examples/repeater_hub.feature +0 -52
  89. data/features/examples/switch_info.feature +0 -51
  90. data/features/examples/switch_monitor.feature +0 -35
  91. data/features/examples/transparent_firewall.feature +0 -73
  92. data/features/handlers/switch_ready.feature +0 -40
  93. data/features/step_definitions/misc_steps.rb +0 -85
  94. data/features/step_definitions/send_packets_steps.rb +0 -33
  95. data/features/step_definitions/stats_steps.rb +0 -39
  96. data/features/switch_event/C-add_forward_entry.feature +0 -114
  97. data/features/switch_event/C-delete_forward_entry.feature +0 -85
  98. data/features/switch_event/C-dump_forward_entries.feature +0 -72
  99. data/features/switch_event/C-set_forward_entries.feature +0 -77
  100. data/features/switch_event/README.md +0 -40
  101. data/features/switch_event/add_forward_entry.feature +0 -160
  102. data/features/switch_event/delete_forward_entry.feature +0 -160
  103. data/features/switch_event/dump_forward_entries.feature +0 -103
  104. data/features/switch_event/set_forward_entries.feature +0 -102
  105. data/features/trema_commands/README.md +0 -8
  106. data/features/trema_commands/dump_flows.feature +0 -41
  107. data/features/trema_commands/help.feature +0 -27
  108. data/features/trema_commands/help_option.feature +0 -20
  109. data/features/trema_commands/kill.feature +0 -56
  110. data/features/trema_commands/killall.feature +0 -32
  111. data/features/trema_commands/port_down.feature +0 -71
  112. data/features/trema_commands/port_up.feature +0 -75
  113. data/features/trema_commands/reset_stats.feature +0 -56
  114. data/features/trema_commands/run.feature +0 -56
  115. data/features/trema_commands/send_packets.feature +0 -46
  116. data/features/trema_commands/show_stats.feature +0 -66
  117. data/features/trema_commands/up.feature +0 -34
  118. data/features/trema_commands/version.feature +0 -10
  119. data/features/trema_commands/version_option.feature +0 -8
  120. data/rubocop-todo.yml +0 -159
  121. data/ruby/.gitignore +0 -4
  122. data/ruby/blocker.rb +0 -74
  123. data/ruby/extconf.rb +0 -80
  124. data/ruby/sub-process.rb +0 -289
  125. data/ruby/trema/action-common.c +0 -46
  126. data/ruby/trema/action-common.h +0 -38
  127. data/ruby/trema/action.rb +0 -33
  128. data/ruby/trema/aggregate-stats-reply.rb +0 -68
  129. data/ruby/trema/app.rb +0 -114
  130. data/ruby/trema/barrier-reply.c +0 -98
  131. data/ruby/trema/barrier-reply.h +0 -44
  132. data/ruby/trema/barrier-request.c +0 -135
  133. data/ruby/trema/barrier-request.h +0 -42
  134. data/ruby/trema/cli.rb +0 -267
  135. data/ruby/trema/command.rb +0 -41
  136. data/ruby/trema/command/dump_flows.rb +0 -43
  137. data/ruby/trema/command/kill.rb +0 -75
  138. data/ruby/trema/command/killall.rb +0 -38
  139. data/ruby/trema/command/netns.rb +0 -38
  140. data/ruby/trema/command/port_down.rb +0 -43
  141. data/ruby/trema/command/port_up.rb +0 -43
  142. data/ruby/trema/command/reset_stats.rb +0 -41
  143. data/ruby/trema/command/ruby.rb +0 -38
  144. data/ruby/trema/command/run.rb +0 -110
  145. data/ruby/trema/command/send_packets.rb +0 -46
  146. data/ruby/trema/command/shell.rb +0 -57
  147. data/ruby/trema/command/show_stats.rb +0 -65
  148. data/ruby/trema/command/up.rb +0 -44
  149. data/ruby/trema/command/version.rb +0 -35
  150. data/ruby/trema/compat.h +0 -36
  151. data/ruby/trema/controller.c +0 -691
  152. data/ruby/trema/controller.h +0 -42
  153. data/ruby/trema/controller.rb +0 -255
  154. data/ruby/trema/custom-switch.rb +0 -56
  155. data/ruby/trema/daemon.rb +0 -184
  156. data/ruby/trema/default-logger.c +0 -161
  157. data/ruby/trema/default-logger.h +0 -42
  158. data/ruby/trema/default-logger.rb +0 -29
  159. data/ruby/trema/default_openflow_channel_port.rb +0 -26
  160. data/ruby/trema/desc-stats-reply.rb +0 -75
  161. data/ruby/trema/dsl.rb +0 -32
  162. data/ruby/trema/dsl/configuration.rb +0 -145
  163. data/ruby/trema/dsl/context.rb +0 -69
  164. data/ruby/trema/dsl/custom-switch.rb +0 -44
  165. data/ruby/trema/dsl/link.rb +0 -39
  166. data/ruby/trema/dsl/netns.rb +0 -78
  167. data/ruby/trema/dsl/parser.rb +0 -70
  168. data/ruby/trema/dsl/rswitch.rb +0 -47
  169. data/ruby/trema/dsl/run.rb +0 -47
  170. data/ruby/trema/dsl/runner.rb +0 -178
  171. data/ruby/trema/dsl/stanza.rb +0 -51
  172. data/ruby/trema/dsl/switch.rb +0 -76
  173. data/ruby/trema/dsl/syntax-error.rb +0 -31
  174. data/ruby/trema/dsl/syntax.rb +0 -128
  175. data/ruby/trema/dsl/vhost.rb +0 -106
  176. data/ruby/trema/dsl/vswitch.rb +0 -45
  177. data/ruby/trema/echo-reply.c +0 -122
  178. data/ruby/trema/echo-reply.h +0 -40
  179. data/ruby/trema/echo-request.c +0 -117
  180. data/ruby/trema/echo-request.h +0 -40
  181. data/ruby/trema/echo.c +0 -99
  182. data/ruby/trema/echo.h +0 -39
  183. data/ruby/trema/enqueue.rb +0 -87
  184. data/ruby/trema/error.c +0 -262
  185. data/ruby/trema/error.h +0 -42
  186. data/ruby/trema/exact-match.rb +0 -34
  187. data/ruby/trema/executables.rb +0 -99
  188. data/ruby/trema/features-reply.c +0 -330
  189. data/ruby/trema/features-reply.h +0 -54
  190. data/ruby/trema/features-request.c +0 -134
  191. data/ruby/trema/features-request.h +0 -42
  192. data/ruby/trema/flow-mod.c +0 -150
  193. data/ruby/trema/flow-mod.h +0 -42
  194. data/ruby/trema/flow-removed.c +0 -280
  195. data/ruby/trema/flow-removed.h +0 -44
  196. data/ruby/trema/flow-stats-reply.rb +0 -107
  197. data/ruby/trema/flow.rb +0 -65
  198. data/ruby/trema/get-config-reply.c +0 -158
  199. data/ruby/trema/get-config-reply.h +0 -50
  200. data/ruby/trema/get-config-request.c +0 -136
  201. data/ruby/trema/get-config-request.h +0 -42
  202. data/ruby/trema/hardware-switch.rb +0 -86
  203. data/ruby/trema/hello.c +0 -133
  204. data/ruby/trema/hello.h +0 -42
  205. data/ruby/trema/host.rb +0 -263
  206. data/ruby/trema/link.rb +0 -177
  207. data/ruby/trema/list-switches-reply.c +0 -44
  208. data/ruby/trema/list-switches-reply.h +0 -38
  209. data/ruby/trema/mac.rb +0 -29
  210. data/ruby/trema/match.c +0 -621
  211. data/ruby/trema/match.h +0 -34
  212. data/ruby/trema/monkey-patch/integer.rb +0 -35
  213. data/ruby/trema/monkey-patch/integer/base-conversions.rb +0 -34
  214. data/ruby/trema/monkey-patch/integer/ranges.rb +0 -49
  215. data/ruby/trema/monkey-patch/integer/validators.rb +0 -36
  216. data/ruby/trema/monkey-patch/module.rb +0 -33
  217. data/ruby/trema/monkey-patch/module/class-method.rb +0 -38
  218. data/ruby/trema/monkey-patch/module/deprecation.rb +0 -39
  219. data/ruby/trema/monkey-patch/string.rb +0 -31
  220. data/ruby/trema/monkey-patch/string/inflectors.rb +0 -52
  221. data/ruby/trema/netns.rb +0 -127
  222. data/ruby/trema/network-component.rb +0 -151
  223. data/ruby/trema/ofctl.rb +0 -70
  224. data/ruby/trema/open-vswitch.rb +0 -160
  225. data/ruby/trema/openflow-error.c +0 -193
  226. data/ruby/trema/openflow-error.h +0 -51
  227. data/ruby/trema/openflow-switch.rb +0 -35
  228. data/ruby/trema/ordered-hash.rb +0 -75
  229. data/ruby/trema/packet-in.c +0 -1365
  230. data/ruby/trema/packet-in.h +0 -44
  231. data/ruby/trema/packet-queue.rb +0 -181
  232. data/ruby/trema/packetin-filter.rb +0 -124
  233. data/ruby/trema/path.rb +0 -85
  234. data/ruby/trema/phost.rb +0 -76
  235. data/ruby/trema/port-mod.c +0 -232
  236. data/ruby/trema/port-mod.h +0 -34
  237. data/ruby/trema/port-stats-reply.rb +0 -109
  238. data/ruby/trema/port-status-add.rb +0 -60
  239. data/ruby/trema/port-status-delete.rb +0 -60
  240. data/ruby/trema/port-status-modify.rb +0 -60
  241. data/ruby/trema/port-status.c +0 -192
  242. data/ruby/trema/port-status.h +0 -41
  243. data/ruby/trema/port.c +0 -398
  244. data/ruby/trema/port.h +0 -45
  245. data/ruby/trema/process.rb +0 -103
  246. data/ruby/trema/queue-get-config-reply.c +0 -205
  247. data/ruby/trema/queue-get-config-reply.h +0 -45
  248. data/ruby/trema/queue-get-config-request.c +0 -141
  249. data/ruby/trema/queue-get-config-request.h +0 -42
  250. data/ruby/trema/queue-stats-reply.rb +0 -76
  251. data/ruby/trema/ruby-switch.rb +0 -62
  252. data/ruby/trema/send-out-port.rb +0 -113
  253. data/ruby/trema/set-config.c +0 -174
  254. data/ruby/trema/set-config.h +0 -42
  255. data/ruby/trema/set-eth-addr.rb +0 -54
  256. data/ruby/trema/set-eth-dst-addr.rb +0 -52
  257. data/ruby/trema/set-eth-src-addr.rb +0 -53
  258. data/ruby/trema/set-ip-addr.rb +0 -54
  259. data/ruby/trema/set-ip-dst-addr.rb +0 -53
  260. data/ruby/trema/set-ip-src-addr.rb +0 -52
  261. data/ruby/trema/set-ip-tos.rb +0 -64
  262. data/ruby/trema/set-transport-dst-port.rb +0 -53
  263. data/ruby/trema/set-transport-port.rb +0 -53
  264. data/ruby/trema/set-transport-src-port.rb +0 -54
  265. data/ruby/trema/set-vlan-priority.rb +0 -66
  266. data/ruby/trema/set-vlan-vid.rb +0 -65
  267. data/ruby/trema/shell.rb +0 -37
  268. data/ruby/trema/shell/down.rb +0 -37
  269. data/ruby/trema/shell/killall.rb +0 -38
  270. data/ruby/trema/shell/link.rb +0 -59
  271. data/ruby/trema/shell/reset_stats.rb +0 -49
  272. data/ruby/trema/shell/run.rb +0 -67
  273. data/ruby/trema/shell/send_packets.rb +0 -40
  274. data/ruby/trema/shell/show_stats.rb +0 -47
  275. data/ruby/trema/shell/up.rb +0 -41
  276. data/ruby/trema/shell/vhost.rb +0 -42
  277. data/ruby/trema/shell/vswitch.rb +0 -47
  278. data/ruby/trema/stats-helper.rb +0 -63
  279. data/ruby/trema/stats-reply.c +0 -540
  280. data/ruby/trema/stats-reply.h +0 -51
  281. data/ruby/trema/stats-request.c +0 -715
  282. data/ruby/trema/stats-request.h +0 -40
  283. data/ruby/trema/strip-vlan-header.rb +0 -41
  284. data/ruby/trema/switch-daemon.rb +0 -90
  285. data/ruby/trema/switch-disconnected.c +0 -38
  286. data/ruby/trema/switch-disconnected.h +0 -36
  287. data/ruby/trema/switch-event.c +0 -648
  288. data/ruby/trema/switch-event.h +0 -27
  289. data/ruby/trema/switch-manager.rb +0 -119
  290. data/ruby/trema/switch.c +0 -197
  291. data/ruby/trema/switch.h +0 -40
  292. data/ruby/trema/switch.rb +0 -56
  293. data/ruby/trema/table-stats-reply.rb +0 -85
  294. data/ruby/trema/timers.rb +0 -95
  295. data/ruby/trema/trema-ruby-utils.c +0 -66
  296. data/ruby/trema/trema-ruby-utils.h +0 -42
  297. data/ruby/trema/trema.c +0 -126
  298. data/ruby/trema/tremashark.rb +0 -46
  299. data/ruby/trema/util.rb +0 -116
  300. data/ruby/trema/vendor-action.rb +0 -82
  301. data/ruby/trema/vendor-stats-reply.rb +0 -64
  302. data/ruby/trema/vendor.c +0 -230
  303. data/ruby/trema/vendor.h +0 -48
  304. data/ruby/trema/version.rb +0 -28
  305. data/spec/support/action.rb +0 -49
  306. data/spec/support/mandatory-option.rb +0 -53
  307. data/spec/support/matchers/constant.rb +0 -25
  308. data/spec/support/openflow-message.rb +0 -173
  309. data/spec/support/port-status.rb +0 -35
  310. data/spec/trema/app_spec.rb +0 -88
  311. data/spec/trema/barrier-reply_spec.rb +0 -43
  312. data/spec/trema/barrier-request_spec.rb +0 -92
  313. data/spec/trema/cli_spec.rb +0 -156
  314. data/spec/trema/default-logger_spec.rb +0 -46
  315. data/spec/trema/dsl/configuration_spec.rb +0 -120
  316. data/spec/trema/dsl/link_spec.rb +0 -50
  317. data/spec/trema/dsl/run_spec.rb +0 -72
  318. data/spec/trema/dsl/runner_spec.rb +0 -247
  319. data/spec/trema/dsl/switch_spec.rb +0 -69
  320. data/spec/trema/dsl/syntax_spec.rb +0 -110
  321. data/spec/trema/dsl/vhost_spec.rb +0 -144
  322. data/spec/trema/dsl/vswitch_spec.rb +0 -80
  323. data/spec/trema/echo-reply_spec.rb +0 -84
  324. data/spec/trema/echo-request_spec.rb +0 -128
  325. data/spec/trema/enqueue_spec.rb +0 -76
  326. data/spec/trema/error_spec.rb +0 -81
  327. data/spec/trema/executables_spec.rb +0 -54
  328. data/spec/trema/features-reply_spec.rb +0 -91
  329. data/spec/trema/features-request_spec.rb +0 -93
  330. data/spec/trema/flow-mod_spec.rb +0 -99
  331. data/spec/trema/flow-removed_spec.rb +0 -144
  332. data/spec/trema/get-config-reply_spec.rb +0 -43
  333. data/spec/trema/get-config-request_spec.rb +0 -92
  334. data/spec/trema/hardware-switch_spec.rb +0 -54
  335. data/spec/trema/hello_spec.rb +0 -63
  336. data/spec/trema/host_spec.rb +0 -191
  337. data/spec/trema/link_spec.rb +0 -62
  338. data/spec/trema/list-switches-reply_spec.rb +0 -46
  339. data/spec/trema/match_spec.rb +0 -111
  340. data/spec/trema/open-vswitch_spec.rb +0 -121
  341. data/spec/trema/openflow-error_spec.rb +0 -141
  342. data/spec/trema/packet-in_spec.rb +0 -717
  343. data/spec/trema/packet-out_spec.rb +0 -125
  344. data/spec/trema/packetin-filter_spec.rb +0 -39
  345. data/spec/trema/port-mod_spec.rb +0 -98
  346. data/spec/trema/port-status-add_spec.rb +0 -32
  347. data/spec/trema/port-status-delete_spec.rb +0 -32
  348. data/spec/trema/port-status-modify_spec.rb +0 -71
  349. data/spec/trema/port-status_spec.rb +0 -38
  350. data/spec/trema/port_spec.rb +0 -59
  351. data/spec/trema/process_spec.rb +0 -69
  352. data/spec/trema/queue-get-config-reply_spec.rb +0 -65
  353. data/spec/trema/queue-get-config-request_spec.rb +0 -67
  354. data/spec/trema/send-out-port_spec.rb +0 -106
  355. data/spec/trema/set-config_spec.rb +0 -78
  356. data/spec/trema/set-eth-addr_spec.rb +0 -62
  357. data/spec/trema/set-ip-addr_spec.rb +0 -81
  358. data/spec/trema/set-ip-tos_spec.rb +0 -70
  359. data/spec/trema/set-transport-dst-port_spec.rb +0 -65
  360. data/spec/trema/set-transport-src-port_spec.rb +0 -65
  361. data/spec/trema/set-vlan-priority_spec.rb +0 -65
  362. data/spec/trema/set-vlan-vid_spec.rb +0 -65
  363. data/spec/trema/shell/vhost_spec.rb +0 -58
  364. data/spec/trema/shell/vswitch_spec.rb +0 -87
  365. data/spec/trema/stats-reply_spec.rb +0 -363
  366. data/spec/trema/stats-request_spec.rb +0 -166
  367. data/spec/trema/strip-vlan-header_spec.rb +0 -44
  368. data/spec/trema/switch-daemon_spec.rb +0 -81
  369. data/spec/trema/switch-disconnected_spec.rb +0 -56
  370. data/spec/trema/switch-manager_spec.rb +0 -41
  371. data/spec/trema/tremashark_spec.rb +0 -39
  372. data/spec/trema/util_spec.rb +0 -88
  373. data/spec/trema/vendor-action_spec.rb +0 -75
  374. data/spec/trema/vendor_spec.rb +0 -76
  375. data/spec/trema_spec.rb +0 -94
  376. data/src/examples/cbench_switch/README +0 -21
  377. data/src/examples/cbench_switch/cbench-switch.rb +0 -38
  378. data/src/examples/cbench_switch/cbench_switch.c +0 -66
  379. data/src/examples/dumper/dumper.c +0 -362
  380. data/src/examples/dumper/dumper.conf +0 -7
  381. data/src/examples/dumper/dumper.rb +0 -195
  382. data/src/examples/hello_trema/.gitignore +0 -2
  383. data/src/examples/hello_trema/README.md +0 -2
  384. data/src/examples/hello_trema/hello-trema.rb +0 -30
  385. data/src/examples/hello_trema/hello_trema.c +0 -48
  386. data/src/examples/hello_trema/sample.conf +0 -1
  387. data/src/examples/learning_switch/README +0 -15
  388. data/src/examples/learning_switch/fdb.rb +0 -110
  389. data/src/examples/learning_switch/learning-switch.rb +0 -90
  390. data/src/examples/learning_switch/learning_switch.c +0 -217
  391. data/src/examples/learning_switch/learning_switch.conf +0 -18
  392. data/src/examples/list_switches/README +0 -19
  393. data/src/examples/list_switches/list-switches.rb +0 -43
  394. data/src/examples/list_switches/list_switches.c +0 -79
  395. data/src/examples/list_switches/list_switches.conf +0 -15
  396. data/src/examples/match_compare/match-compare.conf +0 -30
  397. data/src/examples/match_compare/match-compare.rb +0 -97
  398. data/src/examples/multi_learning_switch/README +0 -14
  399. data/src/examples/multi_learning_switch/multi-learning-switch.rb +0 -94
  400. data/src/examples/multi_learning_switch/multi_learning_switch.c +0 -294
  401. data/src/examples/multi_learning_switch/multi_learning_switch.conf +0 -17
  402. data/src/examples/openflow_message/README +0 -11
  403. data/src/examples/openflow_message/echo.c +0 -80
  404. data/src/examples/openflow_message/echo.rb +0 -56
  405. data/src/examples/openflow_message/example.rb +0 -60
  406. data/src/examples/openflow_message/features-request.rb +0 -96
  407. data/src/examples/openflow_message/features_request.c +0 -167
  408. data/src/examples/openflow_message/hello.c +0 -68
  409. data/src/examples/openflow_message/hello.rb +0 -43
  410. data/src/examples/openflow_message/set-config.rb +0 -57
  411. data/src/examples/openflow_message/set_config.c +0 -68
  412. data/src/examples/openflow_message/vendor-action.rb +0 -43
  413. data/src/examples/openflow_message/vendor-stats-request.rb +0 -66
  414. data/src/examples/openflow_message/vendor_action.c +0 -103
  415. data/src/examples/openflow_switch/echo_switch.c +0 -89
  416. data/src/examples/openflow_switch/hello_switch.c +0 -85
  417. data/src/examples/packet_in/README +0 -15
  418. data/src/examples/packet_in/packet-in.rb +0 -37
  419. data/src/examples/packet_in/packet_in.c +0 -53
  420. data/src/examples/packet_in/packet_in.conf +0 -15
  421. data/src/examples/packetin_filter_config/README +0 -12
  422. data/src/examples/packetin_filter_config/add_filter.c +0 -71
  423. data/src/examples/packetin_filter_config/delete_filter.c +0 -63
  424. data/src/examples/packetin_filter_config/delete_filter_strict.c +0 -73
  425. data/src/examples/packetin_filter_config/dump_filter.c +0 -63
  426. data/src/examples/packetin_filter_config/dump_filter_strict.c +0 -73
  427. data/src/examples/packetin_filter_config/packetin_filter_config.c +0 -132
  428. data/src/examples/packetin_filter_config/packetin_filter_config.conf +0 -7
  429. data/src/examples/packetin_filter_config/utils.c +0 -100
  430. data/src/examples/packetin_filter_config/utils.h +0 -40
  431. data/src/examples/patch_panel/network.conf +0 -14
  432. data/src/examples/patch_panel/patch-panel.conf +0 -1
  433. data/src/examples/patch_panel/patch-panel.rb +0 -59
  434. data/src/examples/repeater_hub/README +0 -8
  435. data/src/examples/repeater_hub/repeater-hub.rb +0 -41
  436. data/src/examples/repeater_hub/repeater-hub_spec.rb +0 -154
  437. data/src/examples/repeater_hub/repeater_hub.c +0 -81
  438. data/src/examples/repeater_hub/repeater_hub.conf +0 -28
  439. data/src/examples/simple_router/README +0 -18
  440. data/src/examples/simple_router/arp-table.rb +0 -81
  441. data/src/examples/simple_router/interface.rb +0 -90
  442. data/src/examples/simple_router/routing-table.rb +0 -60
  443. data/src/examples/simple_router/simple-router.rb +0 -191
  444. data/src/examples/simple_router/simple_router.conf +0 -24
  445. data/src/examples/simple_router/simple_router_netns.conf +0 -15
  446. data/src/examples/simple_router/simple_router_network.conf +0 -6
  447. data/src/examples/switch_event_config/.gitignore +0 -6
  448. data/src/examples/switch_event_config/add_forward_entry.c +0 -227
  449. data/src/examples/switch_event_config/delete_forward_entry.c +0 -226
  450. data/src/examples/switch_event_config/dump_forward_entries.c +0 -190
  451. data/src/examples/switch_event_config/network.conf +0 -2
  452. data/src/examples/switch_event_config/set_forward_entries.c +0 -210
  453. data/src/examples/switch_info/README +0 -13
  454. data/src/examples/switch_info/switch-info.rb +0 -44
  455. data/src/examples/switch_info/switch_info.c +0 -78
  456. data/src/examples/switch_info/switch_info.conf +0 -3
  457. data/src/examples/switch_monitor/switch-monitor.conf +0 -3
  458. data/src/examples/switch_monitor/switch-monitor.rb +0 -56
  459. data/src/examples/switch_monitor/switch_monitor.c +0 -152
  460. data/src/examples/traffic_monitor/counter.c +0 -72
  461. data/src/examples/traffic_monitor/counter.h +0 -46
  462. data/src/examples/traffic_monitor/counter.rb +0 -44
  463. data/src/examples/traffic_monitor/fdb.c +0 -74
  464. data/src/examples/traffic_monitor/fdb.h +0 -48
  465. data/src/examples/traffic_monitor/fdb.rb +0 -42
  466. data/src/examples/traffic_monitor/traffic-monitor.rb +0 -98
  467. data/src/examples/traffic_monitor/traffic_monitor.c +0 -161
  468. data/src/examples/traffic_monitor/traffic_monitor.conf +0 -16
  469. data/src/examples/transparent_firewall/README.md +0 -61
  470. data/src/examples/transparent_firewall/aggregated-delegated-afrinic.txt +0 -713
  471. data/src/examples/transparent_firewall/aggregated-delegated-apnic.txt +0 -3440
  472. data/src/examples/transparent_firewall/aggregated-delegated-arin.txt +0 -11342
  473. data/src/examples/transparent_firewall/aggregated-delegated-lacnic.txt +0 -1937
  474. data/src/examples/transparent_firewall/aggregated-delegated-ripencc.txt +0 -7329
  475. data/src/examples/transparent_firewall/block-rfc1918.rb +0 -86
  476. data/src/examples/transparent_firewall/pass-delegated.rb +0 -178
  477. data/src/examples/transparent_firewall/regen_aggregated.sh +0 -53
  478. data/src/examples/transparent_firewall/stats-to-cidrs.rb +0 -59
  479. data/src/lib/arp.h +0 -64
  480. data/src/lib/bool.h +0 -47
  481. data/src/lib/buffer.c +0 -304
  482. data/src/lib/buffer.h +0 -54
  483. data/src/lib/byteorder.c +0 -571
  484. data/src/lib/byteorder.h +0 -108
  485. data/src/lib/checks.h +0 -40
  486. data/src/lib/chibach.c +0 -392
  487. data/src/lib/chibach.h +0 -69
  488. data/src/lib/chibach_private.c +0 -168
  489. data/src/lib/chibach_private.h +0 -50
  490. data/src/lib/daemon.c +0 -429
  491. data/src/lib/daemon.h +0 -40
  492. data/src/lib/doubly_linked_list.c +0 -284
  493. data/src/lib/doubly_linked_list.h +0 -86
  494. data/src/lib/ether.c +0 -47
  495. data/src/lib/ether.h +0 -92
  496. data/src/lib/etherip.h +0 -44
  497. data/src/lib/event_forward_interface.c +0 -788
  498. data/src/lib/event_forward_interface.h +0 -138
  499. data/src/lib/event_handler.c +0 -419
  500. data/src/lib/event_handler.h +0 -57
  501. data/src/lib/external_callback.c +0 -126
  502. data/src/lib/external_callback.h +0 -46
  503. data/src/lib/hash_table.c +0 -415
  504. data/src/lib/hash_table.h +0 -136
  505. data/src/lib/icmp.h +0 -72
  506. data/src/lib/igmp.h +0 -48
  507. data/src/lib/ipv4.h +0 -64
  508. data/src/lib/ipv6.h +0 -46
  509. data/src/lib/linked_list.c +0 -244
  510. data/src/lib/linked_list.h +0 -84
  511. data/src/lib/log.c +0 -636
  512. data/src/lib/log.h +0 -77
  513. data/src/lib/management_interface.c +0 -359
  514. data/src/lib/management_interface.h +0 -40
  515. data/src/lib/management_service_interface.c +0 -102
  516. data/src/lib/management_service_interface.h +0 -134
  517. data/src/lib/match.h +0 -82
  518. data/src/lib/match_table.c +0 -606
  519. data/src/lib/match_table.h +0 -49
  520. data/src/lib/message_queue.c +0 -143
  521. data/src/lib/message_queue.h +0 -59
  522. data/src/lib/messenger.c +0 -1821
  523. data/src/lib/messenger.h +0 -145
  524. data/src/lib/openflow_application_interface.c +0 -1800
  525. data/src/lib/openflow_application_interface.h +0 -359
  526. data/src/lib/openflow_message.c +0 -4240
  527. data/src/lib/openflow_message.h +0 -291
  528. data/src/lib/openflow_service_interface.h +0 -58
  529. data/src/lib/openflow_switch_interface.c +0 -1378
  530. data/src/lib/openflow_switch_interface.h +0 -262
  531. data/src/lib/packet_info.c +0 -336
  532. data/src/lib/packet_info.h +0 -233
  533. data/src/lib/packet_parser.c +0 -522
  534. data/src/lib/packetin_filter_interface.c +0 -292
  535. data/src/lib/packetin_filter_interface.h +0 -125
  536. data/src/lib/persistent_storage.c +0 -478
  537. data/src/lib/persistent_storage.h +0 -44
  538. data/src/lib/secure_channel.c +0 -496
  539. data/src/lib/secure_channel.h +0 -43
  540. data/src/lib/stat.c +0 -248
  541. data/src/lib/stat.h +0 -51
  542. data/src/lib/tcp.h +0 -62
  543. data/src/lib/timer.c +0 -349
  544. data/src/lib/timer.h +0 -51
  545. data/src/lib/trema.c +0 -776
  546. data/src/lib/trema.h +0 -80
  547. data/src/lib/trema.hpp +0 -49
  548. data/src/lib/trema_private.c +0 -175
  549. data/src/lib/trema_private.h +0 -64
  550. data/src/lib/trema_wrapper.c +0 -59
  551. data/src/lib/trema_wrapper.h +0 -66
  552. data/src/lib/udp.h +0 -41
  553. data/src/lib/utility.c +0 -625
  554. data/src/lib/utility.h +0 -84
  555. data/src/lib/wrapper.c +0 -121
  556. data/src/lib/wrapper.h +0 -76
  557. data/src/management/application.c +0 -222
  558. data/src/management/echo.c +0 -183
  559. data/src/management/set_logging_level.c +0 -151
  560. data/src/management/show_stats.c +0 -148
  561. data/src/management/trema_manager +0 -184
  562. data/src/packetin_filter/README +0 -17
  563. data/src/packetin_filter/packetin_filter.c +0 -575
  564. data/src/switch_manager/README +0 -20
  565. data/src/switch_manager/cookie_table.c +0 -290
  566. data/src/switch_manager/cookie_table.h +0 -70
  567. data/src/switch_manager/dpid_table.c +0 -108
  568. data/src/switch_manager/dpid_table.h +0 -43
  569. data/src/switch_manager/event_forward_entry_manipulation.c +0 -120
  570. data/src/switch_manager/event_forward_entry_manipulation.h +0 -31
  571. data/src/switch_manager/ofpmsg_recv.c +0 -497
  572. data/src/switch_manager/ofpmsg_recv.h +0 -39
  573. data/src/switch_manager/ofpmsg_send.c +0 -274
  574. data/src/switch_manager/ofpmsg_send.h +0 -51
  575. data/src/switch_manager/secure_channel_listener.c +0 -296
  576. data/src/switch_manager/secure_channel_listener.h +0 -40
  577. data/src/switch_manager/secure_channel_receiver.c +0 -129
  578. data/src/switch_manager/secure_channel_receiver.h +0 -40
  579. data/src/switch_manager/secure_channel_sender.c +0 -131
  580. data/src/switch_manager/secure_channel_sender.h +0 -41
  581. data/src/switch_manager/service_interface.c +0 -180
  582. data/src/switch_manager/service_interface.h +0 -44
  583. data/src/switch_manager/switch.c +0 -988
  584. data/src/switch_manager/switch.h +0 -50
  585. data/src/switch_manager/switch_manager.c +0 -643
  586. data/src/switch_manager/switch_manager.h +0 -65
  587. data/src/switch_manager/switch_option.c +0 -30
  588. data/src/switch_manager/switch_option.h +0 -41
  589. data/src/switch_manager/switchinfo.h +0 -81
  590. data/src/switch_manager/xid_table.c +0 -182
  591. data/src/switch_manager/xid_table.h +0 -53
  592. data/src/tremashark/README +0 -79
  593. data/src/tremashark/packet_capture.c +0 -358
  594. data/src/tremashark/pcap_private.h +0 -45
  595. data/src/tremashark/pcap_queue.c +0 -195
  596. data/src/tremashark/pcap_queue.h +0 -56
  597. data/src/tremashark/plugin/.gitignore +0 -6
  598. data/src/tremashark/plugin/packet-trema/.gitignore +0 -5
  599. data/src/tremashark/plugin/packet-trema/Makefile +0 -77
  600. data/src/tremashark/plugin/packet-trema/Makefile.am +0 -110
  601. data/src/tremashark/plugin/packet-trema/Makefile.common +0 -29
  602. data/src/tremashark/plugin/packet-trema/moduleinfo.h +0 -39
  603. data/src/tremashark/plugin/packet-trema/packet-trema.c +0 -1671
  604. data/src/tremashark/plugin/packet-trema/plugin.c +0 -31
  605. data/src/tremashark/plugin/user_dlts +0 -2
  606. data/src/tremashark/queue.c +0 -167
  607. data/src/tremashark/queue.h +0 -58
  608. data/src/tremashark/stdin_relay.c +0 -257
  609. data/src/tremashark/syslog_relay.c +0 -247
  610. data/src/tremashark/tremashark.c +0 -554
  611. data/trema +0 -11
  612. data/trema-config +0 -11
  613. data/unittests/buffer_stubs.c +0 -72
  614. data/unittests/cmockery_trema.c +0 -121
  615. data/unittests/cmockery_trema.h +0 -95
  616. data/unittests/lib/buffer_test.c +0 -368
  617. data/unittests/lib/byteorder_test.c +0 -1798
  618. data/unittests/lib/daemon_test.c +0 -804
  619. data/unittests/lib/doubly_linked_list_test.c +0 -348
  620. data/unittests/lib/ether_test.c +0 -125
  621. data/unittests/lib/event_forward_interface_test.c +0 -1676
  622. data/unittests/lib/external_callback_test.c +0 -282
  623. data/unittests/lib/hash_table_test.c +0 -278
  624. data/unittests/lib/linked_list_test.c +0 -434
  625. data/unittests/lib/log_test.c +0 -672
  626. data/unittests/lib/management_interface_test.c +0 -238
  627. data/unittests/lib/management_service_interface_test.c +0 -317
  628. data/unittests/lib/match_table_test.c +0 -1507
  629. data/unittests/lib/message_queue_test.c +0 -381
  630. data/unittests/lib/messenger_test.c +0 -623
  631. data/unittests/lib/openflow_application_interface_test.c +0 -3713
  632. data/unittests/lib/openflow_message_test.c +0 -8047
  633. data/unittests/lib/packet_info_test.c +0 -558
  634. data/unittests/lib/packet_parser_test.c +0 -784
  635. data/unittests/lib/packetin_filter_interface_test.c +0 -721
  636. data/unittests/lib/persistent_storage_test.c +0 -800
  637. data/unittests/lib/stat_test.c +0 -433
  638. data/unittests/lib/test_packets/arp_rep.cap +0 -0
  639. data/unittests/lib/test_packets/arp_req.cap +0 -0
  640. data/unittests/lib/test_packets/icmp6_echo_rep.cap +0 -0
  641. data/unittests/lib/test_packets/icmp6_echo_req.cap +0 -0
  642. data/unittests/lib/test_packets/icmp_echo_rep.cap +0 -0
  643. data/unittests/lib/test_packets/icmp_echo_req.cap +0 -0
  644. data/unittests/lib/test_packets/igmp_query_v2.cap +0 -0
  645. data/unittests/lib/test_packets/ipx.cap +0 -0
  646. data/unittests/lib/test_packets/lldp.cap +0 -0
  647. data/unittests/lib/test_packets/lldp_over_ip.cap +0 -0
  648. data/unittests/lib/test_packets/rarp_req.cap +0 -0
  649. data/unittests/lib/test_packets/tcp.cap +0 -0
  650. data/unittests/lib/test_packets/tcp_syn.cap +0 -0
  651. data/unittests/lib/test_packets/udp.cap +0 -0
  652. data/unittests/lib/test_packets/udp_frag_head.cap +0 -0
  653. data/unittests/lib/test_packets/udp_frag_next.cap +0 -0
  654. data/unittests/lib/test_packets/vtag_icmp_echo_rep.cap +0 -0
  655. data/unittests/lib/test_packets/vtag_icmp_echo_req.cap +0 -0
  656. data/unittests/lib/timer_test.c +0 -246
  657. data/unittests/lib/trema_private_test.c +0 -321
  658. data/unittests/lib/trema_test.c +0 -1030
  659. data/unittests/lib/utility_test.c +0 -711
  660. data/unittests/lib/wrapper_test.c +0 -228
  661. data/unittests/packetin_filter/packetin_filter_test.c +0 -476
  662. data/unittests/switch_manager/switch_manager_test.c +0 -1183
  663. data/unittests/wrapper_stubs.c +0 -37
  664. data/vendor/.gitignore +0 -6
  665. data/vendor/README.md +0 -29
  666. data/vendor/cmockery-20110428.tar.gz +0 -0
  667. data/vendor/oflops-0.03.trema1.tar.gz +0 -0
  668. data/vendor/oflops_no_snmp+1.0.0.diff +0 -340
  669. data/vendor/openflow-1.0.0.tar.gz +0 -0
  670. data/vendor/openflow.git.tar.gz +0 -0
  671. data/vendor/openvswitch-1.2.2.trema1.tar.gz +0 -0
  672. data/vendor/openvswitch-1.2.2_librt-check.diff +0 -21
  673. data/vendor/packet-openflow.diff +0 -13
  674. data/vendor/ruby-ifconfig-1.2/COPYING +0 -340
  675. data/vendor/ruby-ifconfig-1.2/Changelog +0 -16
  676. data/vendor/ruby-ifconfig-1.2/INSTALL +0 -239
  677. data/vendor/ruby-ifconfig-1.2/README +0 -38
  678. data/vendor/ruby-ifconfig-1.2/Rakefile +0 -14
  679. data/vendor/ruby-ifconfig-1.2/TODO +0 -8
  680. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/darwin.txt +0 -17
  681. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/dragonflybsd.txt +0 -10
  682. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/dragonflybsd_netstat.txt +0 -14
  683. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/freebsd.txt +0 -17
  684. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/freebsd_netstat.txt +0 -24
  685. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/linux.txt +0 -60
  686. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/linux_ethernet.txt +0 -20
  687. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/netbsd.txt +0 -10
  688. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/openbsd.txt +0 -36
  689. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/sunos.txt +0 -10
  690. data/vendor/ruby-ifconfig-1.2/lib/ifconfig.rb +0 -71
  691. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/bsd/ifconfig.rb +0 -72
  692. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/bsd/interface_types.rb +0 -69
  693. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/bsd/network_types.rb +0 -3
  694. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/common/ifconfig.rb +0 -84
  695. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/common/interface_types.rb +0 -130
  696. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/common/network_types.rb +0 -49
  697. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/linux/ifconfig.rb +0 -43
  698. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/linux/interface_types.rb +0 -112
  699. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/linux/network_types.rb +0 -55
  700. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/sunos/ifconfig.rb +0 -38
  701. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/sunos/interface_types.rb +0 -77
  702. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/sunos/network_types.rb +0 -4
  703. data/vendor/ruby-ifconfig-1.2/setup.rb +0 -1306
  704. data/vendor/ruby-ifconfig-1.2/test/test_bsd.rb +0 -35
  705. data/vendor/ruby-ifconfig-1.2/test/test_darwin.rb +0 -33
  706. data/vendor/ruby-ifconfig-1.2/test/test_dragonflybsd.rb +0 -35
  707. data/vendor/ruby-ifconfig-1.2/test/test_helper.rb +0 -4
  708. data/vendor/ruby-ifconfig-1.2/test/test_linux.rb +0 -31
  709. data/vendor/ruby-ifconfig-1.2/test/test_netbsd.rb +0 -33
  710. data/vendor/ruby-ifconfig-1.2/test/test_openbsd.rb +0 -33
  711. data/vendor/ruby-ifconfig-1.2/test/test_sunos.rb +0 -35
  712. data/vendor/ruby-ifconfig-1.2/test/unit/tc_darwin.rb +0 -40
  713. data/vendor/ruby-ifconfig-1.2/test/unit/tc_dragonflybsd.rb +0 -39
  714. data/vendor/ruby-ifconfig-1.2/test/unit/tc_freebsd.rb +0 -40
  715. data/vendor/ruby-ifconfig-1.2/test/unit/tc_linux.rb +0 -49
  716. data/vendor/ruby-ifconfig-1.2/test/unit/tc_netbsd.rb +0 -39
  717. data/vendor/ruby-ifconfig-1.2/test/unit/tc_openbsd.rb +0 -39
  718. data/vendor/ruby-ifconfig-1.2/test/unit/tc_sunos.rb +0 -44
@@ -1,434 +0,0 @@
1
- /*
2
- * Unit tests for linked list library.
3
- *
4
- * Copyright (C) 2008-2013 NEC Corporation
5
- *
6
- * This program is free software; you can redistribute it and/or modify
7
- * it under the terms of the GNU General Public License, version 2, as
8
- * published by the Free Software Foundation.
9
- *
10
- * This program is distributed in the hope that it will be useful,
11
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
- * GNU General Public License for more details.
14
- *
15
- * You should have received a copy of the GNU General Public License along
16
- * with this program; if not, write to the Free Software Foundation, Inc.,
17
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18
- */
19
-
20
-
21
- #include <stdio.h>
22
- #include <string.h>
23
- #include "checks.h"
24
- #include "cmockery_trema.h"
25
- #include "linked_list.h"
26
- #include "utility.h"
27
-
28
-
29
- /********************************************************************************
30
- * Setup and Teardown
31
- ********************************************************************************/
32
-
33
- static void ( *original_die )( const char *format, ... );
34
-
35
- static void
36
- mock_die( const char *format, ... ) {
37
- char output[ 256 ];
38
- va_list args;
39
- va_start( args, format );
40
- vsprintf( output, format, args );
41
- va_end( args );
42
- check_expected( output );
43
-
44
- mock_assert( false, "mock_die", __FILE__, __LINE__ ); } // Hoaxes gcov.
45
-
46
-
47
- static void
48
- setup() {
49
- original_die = die;
50
- die = mock_die;
51
- }
52
-
53
-
54
- static void
55
- teardown() {
56
- die = original_die;
57
- }
58
-
59
-
60
- /********************************************************************************
61
- * List and elements.
62
- ********************************************************************************/
63
-
64
- static list_element *new_list;
65
- static char alpha[] = "alpha";
66
- static char bravo[] = "bravo";
67
- static char charlie[] = "charlie";
68
- static char delete_me[] = "delete me!";
69
-
70
-
71
- /********************************************************************************
72
- * Tests.
73
- ********************************************************************************/
74
-
75
- static void
76
- test_create_list() {
77
- assert_true( create_list( &new_list ) );
78
- assert_true( new_list == NULL );
79
- }
80
-
81
-
82
- static void
83
- test_create_and_delete_empty_list() {
84
- create_list( &new_list );
85
- delete_list( new_list );
86
- }
87
-
88
-
89
- static void
90
- test_create_list_aborts_with_NULL() {
91
- expect_string( mock_die, output, "list must not be NULL" );
92
- expect_assert_failure( create_list( NULL ) );
93
- }
94
-
95
-
96
- static void
97
- test_insert_in_front() {
98
- create_list( &new_list );
99
-
100
- assert_true( insert_in_front( &new_list, alpha ) );
101
- assert_true( insert_in_front( &new_list, bravo ) );
102
- assert_true( insert_in_front( &new_list, charlie ) );
103
-
104
- assert_string_equal( new_list->data, "charlie" );
105
- assert_string_equal( new_list->next->data, "bravo" );
106
- assert_string_equal( new_list->next->next->data, "alpha" );
107
- assert_true( new_list->next->next->next == NULL );
108
-
109
- delete_list( new_list );
110
- }
111
-
112
-
113
- static void
114
- test_insert_in_front_aborts_with_NULL_head() {
115
- expect_string( mock_die, output, "head must not be NULL" );
116
- expect_assert_failure( insert_in_front( NULL, alpha ) );
117
- }
118
-
119
-
120
- static void
121
- test_insert_before() {
122
- create_list( &new_list );
123
- char before_bravo[] = "before bravo";
124
-
125
- append_to_tail( &new_list, alpha );
126
- append_to_tail( &new_list, bravo );
127
- append_to_tail( &new_list, charlie );
128
-
129
- insert_before( &new_list, bravo, before_bravo );
130
-
131
- assert_string_equal( new_list->data, "alpha" );
132
- assert_string_equal( new_list->next->data, "before bravo" );
133
- assert_string_equal( new_list->next->next->data, "bravo" );
134
- assert_string_equal( new_list->next->next->next->data, "charlie" );
135
- assert_true( new_list->next->next->next->next == NULL );
136
-
137
- delete_list( new_list );
138
- }
139
-
140
-
141
- static void
142
- test_insert_before_fails_if_sibling_not_found() {
143
- create_list( &new_list );
144
- char no_such_data[] = "NO SUCH DATA";
145
-
146
- append_to_tail( &new_list, alpha );
147
- append_to_tail( &new_list, bravo );
148
- append_to_tail( &new_list, charlie );
149
-
150
- assert_false( insert_before( &new_list, no_such_data, ( void * ) 123 ) );
151
-
152
- delete_list( new_list );
153
- }
154
-
155
-
156
- static void
157
- test_insert_before_aborts_with_NULL_head() {
158
- expect_string( mock_die, output, "head must not be NULL" );
159
- expect_assert_failure( insert_before( NULL, alpha, ( void * ) 123 ) );
160
- }
161
-
162
-
163
- static void
164
- test_append_to_tail() {
165
- create_list( &new_list );
166
-
167
- assert_true( append_to_tail( &new_list, alpha ) );
168
- assert_true( append_to_tail( &new_list, bravo ) );
169
- assert_true( append_to_tail( &new_list, charlie ) );
170
-
171
- assert_string_equal( new_list->data, "alpha" );
172
- assert_string_equal( new_list->next->data, "bravo" );
173
- assert_string_equal( new_list->next->next->data, "charlie" );
174
- assert_true( new_list->next->next->next == NULL );
175
-
176
- delete_list( new_list );
177
- }
178
-
179
-
180
- static void
181
- test_append_to_tail_aborts_with_NULL_head() {
182
- expect_string( mock_die, output, "head must not be NULL" );
183
- expect_assert_failure( append_to_tail( NULL, alpha ) );
184
- }
185
-
186
-
187
- static void
188
- test_delete_first_element() {
189
- create_list( &new_list );
190
-
191
- append_to_tail( &new_list, delete_me );
192
- append_to_tail( &new_list, bravo );
193
- append_to_tail( &new_list, charlie );
194
-
195
- assert_true( delete_element( &new_list, delete_me ) );
196
- assert_string_equal( new_list->data, "bravo" );
197
- assert_string_equal( new_list->next->data, "charlie" );
198
- assert_true( new_list->next->next == NULL );
199
-
200
- delete_list( new_list );
201
- }
202
-
203
-
204
- static void
205
- test_delete_middle_element() {
206
- create_list( &new_list );
207
-
208
- append_to_tail( &new_list, alpha );
209
- append_to_tail( &new_list, delete_me );
210
- append_to_tail( &new_list, charlie );
211
-
212
- assert_true( delete_element( &new_list, delete_me ) );
213
- assert_string_equal( new_list->data, "alpha" );
214
- assert_string_equal( new_list->next->data, "charlie" );
215
- assert_true( new_list->next->next == NULL );
216
-
217
- delete_list( new_list );
218
- }
219
-
220
-
221
- static void
222
- test_delete_last_element() {
223
- create_list( &new_list );
224
-
225
- append_to_tail( &new_list, alpha );
226
- append_to_tail( &new_list, bravo );
227
- append_to_tail( &new_list, delete_me );
228
-
229
- assert_true( delete_element( &new_list, delete_me ) );
230
- assert_string_equal( new_list->data, "alpha" );
231
- assert_string_equal( new_list->next->data, "bravo" );
232
- assert_true( new_list->next->next == NULL );
233
-
234
- delete_list( new_list );
235
- }
236
-
237
-
238
- static void
239
- test_delete_nonexisting_element() {
240
- create_list( &new_list );
241
-
242
- append_to_tail( &new_list, alpha );
243
- append_to_tail( &new_list, bravo );
244
- append_to_tail( &new_list, charlie );
245
-
246
- assert_false( delete_element( &new_list, delete_me ) );
247
- assert_string_equal( new_list->data, "alpha" );
248
- assert_string_equal( new_list->next->data, "bravo" );
249
- assert_string_equal( new_list->next->next->data, "charlie" );
250
- assert_true( new_list->next->next->next == NULL );
251
-
252
- delete_list( new_list );
253
- }
254
-
255
-
256
- static void
257
- test_delete_element_aborts_with_NULL_head() {
258
- expect_string( mock_die, output, "head must not be NULL" );
259
- expect_assert_failure( delete_element( NULL, delete_me ) );
260
- }
261
-
262
-
263
- static void
264
- test_list_length() {
265
- create_list( &new_list );
266
- append_to_tail( &new_list, alpha );
267
- append_to_tail( &new_list, bravo );
268
- append_to_tail( &new_list, charlie );
269
-
270
- assert_int_equal( 3, ( int ) list_length_of( new_list ) );
271
-
272
- delete_list( new_list );
273
- }
274
-
275
-
276
- static void
277
- test_list_length_of_empty_list() {
278
- create_list( &new_list );
279
- assert_int_equal( 0, ( int ) list_length_of( new_list ) );
280
- }
281
-
282
-
283
- static void
284
- get_sum_length( void *data, void *user_data ) {
285
- size_t *sum_length = user_data;
286
- *sum_length += strlen( data );
287
- }
288
-
289
-
290
- static void
291
- test_iterate_list() {
292
- create_list( &new_list );
293
-
294
- append_to_tail( &new_list, &alpha );
295
- append_to_tail( &new_list, &bravo );
296
- append_to_tail( &new_list, &charlie );
297
-
298
- size_t sum_length = 0;
299
- iterate_list( new_list, get_sum_length, &sum_length );
300
- assert_int_equal( 17, sum_length );
301
-
302
- delete_list( new_list );
303
- }
304
-
305
-
306
- static void
307
- test_iterate_list_on_empty_list() {
308
- create_list( &new_list );
309
-
310
- size_t sum_length = 0;
311
- iterate_list( new_list, get_sum_length, &sum_length );
312
- assert_int_equal( 0, sum_length );
313
-
314
- delete_list( new_list );
315
- }
316
-
317
-
318
- static bool
319
- find_bravo( void *data, void *user_data ) {
320
- UNUSED( user_data );
321
-
322
- if ( strcmp( data, "bravo" ) == 0 ) {
323
- return true;
324
- }
325
- else {
326
- return false;
327
- }
328
- }
329
-
330
-
331
- static bool
332
- find_nothing( void *data, void *user_data ) {
333
- UNUSED( data );
334
- UNUSED( user_data );
335
-
336
- return false;
337
- }
338
-
339
-
340
- static void
341
- test_find_list_custom() {
342
- create_list( &new_list );
343
-
344
- append_to_tail( &new_list, &alpha );
345
- append_to_tail( &new_list, &bravo );
346
- append_to_tail( &new_list, &charlie );
347
-
348
- void *found = find_list_custom( new_list, find_bravo, NULL );
349
- assert_string_equal( found, "bravo" );
350
-
351
- delete_list( new_list );
352
- }
353
-
354
-
355
- static void
356
- test_find_list_custom_fail() {
357
- create_list( &new_list );
358
-
359
- append_to_tail( &new_list, &alpha );
360
- append_to_tail( &new_list, &bravo );
361
- append_to_tail( &new_list, &charlie );
362
-
363
- void *found = find_list_custom( new_list, find_nothing, NULL );
364
- assert_true( found == NULL );
365
-
366
- delete_list( new_list );
367
- }
368
-
369
-
370
- static void
371
- test_delete_list() {
372
- create_list( &new_list );
373
-
374
- insert_in_front( &new_list, alpha );
375
- insert_in_front( &new_list, bravo );
376
- insert_in_front( &new_list, charlie );
377
-
378
- assert_true( delete_list( new_list ) );
379
- }
380
-
381
-
382
- /********************************************************************************
383
- * Run tests.
384
- ********************************************************************************/
385
-
386
- int
387
- main() {
388
- const UnitTest tests[] = {
389
- unit_test( test_create_list ),
390
- unit_test( test_create_and_delete_empty_list ),
391
- unit_test_setup_teardown( test_create_list_aborts_with_NULL,
392
- setup, teardown ),
393
-
394
- unit_test( test_insert_in_front ),
395
- unit_test_setup_teardown( test_insert_in_front_aborts_with_NULL_head,
396
- setup, teardown ),
397
-
398
- unit_test( test_insert_before ),
399
- unit_test( test_insert_before_fails_if_sibling_not_found ),
400
- unit_test_setup_teardown( test_insert_before_aborts_with_NULL_head,
401
- setup, teardown ),
402
-
403
- unit_test( test_append_to_tail ),
404
- unit_test_setup_teardown( test_append_to_tail_aborts_with_NULL_head,
405
- setup, teardown ),
406
-
407
- unit_test( test_delete_first_element ),
408
- unit_test( test_delete_middle_element ),
409
- unit_test( test_delete_last_element ),
410
- unit_test( test_delete_nonexisting_element ),
411
- unit_test_setup_teardown( test_delete_element_aborts_with_NULL_head,
412
- setup, teardown ),
413
-
414
- unit_test( test_list_length ),
415
- unit_test( test_list_length_of_empty_list ),
416
-
417
- unit_test( test_iterate_list ),
418
- unit_test( test_iterate_list_on_empty_list ),
419
- unit_test( test_find_list_custom ),
420
- unit_test( test_find_list_custom_fail ),
421
-
422
- unit_test( test_delete_list ),
423
- };
424
- setup_leak_detector();
425
- return run_tests( tests );
426
- }
427
-
428
-
429
- /*
430
- * Local variables:
431
- * c-basic-offset: 2
432
- * indent-tabs-mode: nil
433
- * End:
434
- */
@@ -1,672 +0,0 @@
1
- /*
2
- * Unit tests for logging functions and macros.
3
- *
4
- * Copyright (C) 2008-2013 NEC Corporation
5
- *
6
- * This program is free software; you can redistribute it and/or modify
7
- * it under the terms of the GNU General Public License, version 2, as
8
- * published by the Free Software Foundation.
9
- *
10
- * This program is distributed in the hope that it will be useful,
11
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
- * GNU General Public License for more details.
14
- *
15
- * You should have received a copy of the GNU General Public License along
16
- * with this program; if not, write to the Free Software Foundation, Inc.,
17
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18
- */
19
-
20
-
21
- #include <stdarg.h>
22
- #include <stdio.h>
23
- #include <stdlib.h>
24
- #include <syslog.h>
25
- #include "checks.h"
26
- #include "cmockery_trema.h"
27
- #include "log.h"
28
- #include "trema.h"
29
- #include "trema_wrapper.h"
30
- #include "utility.h"
31
-
32
-
33
- /********************************************************************************
34
- * Mocks
35
- ********************************************************************************/
36
-
37
- static void ( *original_die )( const char *format, ... );
38
-
39
- static void
40
- mock_die( const char *format, ... ) {
41
- char output[ 256 ];
42
- va_list args;
43
- va_start( args, format );
44
- vsprintf( output, format, args );
45
- va_end( args );
46
- check_expected( output );
47
-
48
- mock_assert( false, "mock_die", __FILE__, __LINE__ ); } // Hoaxes gcov.
49
-
50
-
51
- static void
52
- mock_abort() {
53
- mock_assert( false, "mock_abort", __FILE__, __LINE__ ); } // Hoaxes gcov.
54
-
55
-
56
- static int
57
- mock_vprintf( const char *format, va_list ap ) {
58
- char output[ 256 ];
59
- vsnprintf( output, sizeof( output ), format, ap );
60
-
61
- check_expected( output );
62
-
63
- return 0;
64
- }
65
-
66
-
67
- static int
68
- mock_fprintf( FILE *stream, const char *format, ... ) {
69
- UNUSED( stream );
70
-
71
- char line[ 256 ];
72
- va_list args;
73
- va_start( args, format );
74
- vsprintf( line, format, args );
75
- va_end( args );
76
-
77
- char *output = strchr( line, ']' ) + 2;
78
- check_expected( output );
79
-
80
- return 0;
81
- }
82
-
83
-
84
- static bool syslog_initialized = false;
85
-
86
- static void
87
- mock_openlog( const char *ident, int option, int facility ) {
88
- check_expected( ident );
89
- check_expected( option );
90
- check_expected( facility );
91
-
92
- syslog_initialized = true;
93
- }
94
-
95
-
96
- static void
97
- mock_closelog( void ) {
98
- syslog_initialized = false;
99
- }
100
-
101
-
102
- static void
103
- mock_vsyslog( int priority, const char *format, va_list ap ) {
104
- check_expected( priority );
105
-
106
- char output[ 256 ];
107
- vsnprintf( output, sizeof( output ), format, ap );
108
-
109
- check_expected( output );
110
- }
111
-
112
-
113
- /********************************************************************************
114
- * Setup and teardown function.
115
- ********************************************************************************/
116
-
117
- static void
118
- reset_LOGGING_LEVEL() {
119
- unsetenv( "LOGGING_LEVEL" );
120
- }
121
-
122
-
123
- static void
124
- reset_LOGGING_FACILITY() {
125
- unsetenv( "LOGGING_FACILITY" );
126
- }
127
-
128
-
129
- static void
130
- setup() {
131
- finalize_log();
132
- reset_LOGGING_LEVEL();
133
- reset_LOGGING_FACILITY();
134
-
135
- setup_leak_detector();
136
-
137
- original_die = die;
138
- die = mock_die;
139
-
140
- trema_abort = mock_abort;
141
- trema_vprintf = mock_vprintf;
142
- trema_fprintf = mock_fprintf;
143
- trema_openlog = mock_openlog;
144
- trema_closelog = mock_closelog;
145
- trema_vsyslog = mock_vsyslog;
146
- }
147
-
148
-
149
- static void
150
- setup_logger_stdout() {
151
- setup();
152
- init_log( "log_test.c", get_trema_tmp(), LOGGING_TYPE_STDOUT );
153
- }
154
-
155
-
156
- static void
157
- setup_logger_file() {
158
- setup();
159
- init_log( "log_test.c", get_trema_tmp(), LOGGING_TYPE_FILE );
160
- }
161
-
162
-
163
- static void
164
- setup_logger_file_stdout() {
165
- setup();
166
- init_log( "log_test.c", get_trema_tmp(), LOGGING_TYPE_FILE | LOGGING_TYPE_STDOUT );
167
- }
168
-
169
-
170
- static void
171
- setup_logger_syslog() {
172
- setup();
173
- const char *ident = "log_test.c";
174
- expect_string( mock_openlog, ident, ident );
175
- expect_value( mock_openlog, option, LOG_NDELAY );
176
- expect_value( mock_openlog, facility, LOG_USER );
177
- init_log( ident, get_trema_tmp(), LOGGING_TYPE_SYSLOG );
178
- }
179
-
180
-
181
- static void
182
- teardown() {
183
- finalize_log();
184
- reset_LOGGING_LEVEL();
185
- reset_LOGGING_FACILITY();
186
-
187
- teardown_leak_detector();
188
-
189
- die = original_die;
190
- trema_abort = abort;
191
- trema_vprintf = vprintf;
192
- trema_fprintf = fprintf;
193
- trema_openlog = openlog;
194
- trema_closelog = closelog;
195
- trema_vsyslog = vsyslog;
196
- }
197
-
198
-
199
- /********************************************************************************
200
- * Initialization tests.
201
- ********************************************************************************/
202
-
203
- void
204
- test_init_log_reads_LOGING_LEVEL_environment_variable() {
205
- setenv( "LOGGING_LEVEL", "CRITICAL", 1 );
206
- init_log( "tetris", get_trema_tmp(), LOGGING_TYPE_FILE );
207
- assert_int_equal( LOG_CRIT, get_logging_level() );
208
- }
209
-
210
-
211
- void
212
- test_init_log_opens_syslog() {
213
- const char *ident = "tetris";
214
- expect_string( mock_openlog, ident, ident );
215
- expect_value( mock_openlog, option, LOG_NDELAY );
216
- expect_value( mock_openlog, facility, LOG_USER );
217
- init_log( ident, get_trema_tmp(), LOGGING_TYPE_SYSLOG );
218
- assert_true( syslog_initialized );
219
- }
220
-
221
-
222
- void
223
- test_init_log_reads_LOGGING_FACILITY_environment_variable() {
224
- const char *ident = "tetris";
225
- setenv( "LOGGING_FACILITY", "LOCAL7", 1 );
226
-
227
- expect_string( mock_openlog, ident, ident );
228
- expect_value( mock_openlog, option, LOG_NDELAY );
229
- expect_value( mock_openlog, facility, LOG_LOCAL7 );
230
- init_log( ident, get_trema_tmp(), LOGGING_TYPE_SYSLOG );
231
- assert_true( syslog_initialized );
232
- }
233
-
234
-
235
- /********************************************************************************
236
- * Finalization test.
237
- ********************************************************************************/
238
-
239
- void
240
- test_finalize_log_closes_syslog() {
241
- finalize_log();
242
- assert_false( syslog_initialized );
243
- }
244
-
245
-
246
- /********************************************************************************
247
- * Logging level tests.
248
- ********************************************************************************/
249
-
250
- void
251
- test_default_logging_level_is_INFO() {
252
- assert_int_equal( LOG_INFO, get_logging_level() );
253
- }
254
-
255
-
256
- void
257
- test_set_logging_level_succeeds() {
258
- set_logging_level( "critical" );
259
- assert_int_equal( LOG_CRIT, get_logging_level() );
260
- }
261
-
262
-
263
- void
264
- test_set_logging_level_fails_with_invalid_value() {
265
- expect_assert_failure( set_logging_level( "INVALID_LEVEL" ) );
266
- }
267
-
268
-
269
- void
270
- test_set_logging_level_is_called_before_init_log() {
271
- set_logging_level( "critical" );
272
- init_log( "tetris", get_trema_tmp(), LOGGING_TYPE_FILE );
273
- assert_int_equal( LOG_CRIT, get_logging_level() );
274
- }
275
-
276
-
277
- void
278
- test_LOGGING_LEVEL_overrides_logging_level() {
279
- setenv( "LOGGING_LEVEL", "DEBUG", 1 );
280
- set_logging_level( "critical" );
281
- init_log( "tetris", get_trema_tmp(), LOGGING_TYPE_FILE );
282
- assert_int_equal( LOG_DEBUG, get_logging_level() );
283
- }
284
-
285
-
286
- void
287
- test_valid_logging_level_returns_true_with_valid_logging_level() {
288
- assert_true( valid_logging_level( "information" ) );
289
- }
290
-
291
-
292
- void
293
- test_valid_logging_level_returns_false_with_invalid_logging_level() {
294
- assert_false( valid_logging_level( "INVALID_LOGGING_LEVEL" ) );
295
- }
296
-
297
-
298
- /********************************************************************************
299
- * Syslog facility tests.
300
- ********************************************************************************/
301
-
302
- void
303
- test_default_faciliity_is_USER() {
304
- const char *ident = "tetris";
305
- expect_string( mock_openlog, ident, ident );
306
- expect_value( mock_openlog, option, LOG_NDELAY );
307
- expect_value( mock_openlog, facility, LOG_USER );
308
- init_log( ident, get_trema_tmp(), LOGGING_TYPE_SYSLOG );
309
- }
310
-
311
-
312
- void
313
- test_set_syslog_facility_succeeds() {
314
- const char *ident = "tetris";
315
- set_syslog_facility( "LOCAL0" );
316
-
317
- expect_string( mock_openlog, ident, ident );
318
- expect_value( mock_openlog, option, LOG_NDELAY );
319
- expect_value( mock_openlog, facility, LOG_LOCAL0 );
320
- init_log( ident, get_trema_tmp(), LOGGING_TYPE_SYSLOG );
321
- }
322
-
323
-
324
- void
325
- test_set_syslog_facility_fails_with_invalid_value() {
326
- expect_assert_failure( set_syslog_facility( "INVALID_FACILITY" ) );
327
- }
328
-
329
-
330
- void
331
- test_LOGGING_FACILITY_overrides_logging_facility() {
332
- const char *ident = "tetris";
333
- setenv( "LOGGING_FACILITY", "LOCAL0", 1 );
334
- set_syslog_facility( "LOCAL7" );
335
-
336
- expect_string( mock_openlog, ident, ident );
337
- expect_value( mock_openlog, option, LOG_NDELAY );
338
- expect_value( mock_openlog, facility, LOG_LOCAL0 );
339
- init_log( ident, get_trema_tmp(), LOGGING_TYPE_SYSLOG );
340
- }
341
-
342
-
343
- /********************************************************************************
344
- * critical() tests.
345
- ********************************************************************************/
346
-
347
- void
348
- test_critical_logs_if_logging_level_is_CRITICAL() {
349
- expect_string( mock_fprintf, output, "CRITICAL message.\n" );
350
-
351
- set_logging_level( "critical" );
352
- critical( "CRITICAL message." );
353
- }
354
-
355
-
356
- void
357
- test_critical_logs_if_logging_level_is_ERROR() {
358
- expect_string( mock_fprintf, output, "CRITICAL message.\n" );
359
-
360
- set_logging_level( "error" );
361
- critical( "CRITICAL message." );
362
- }
363
-
364
-
365
- void
366
- test_critical_fail_if_NULL() {
367
- expect_assert_failure( critical( NULL ) );
368
- }
369
-
370
-
371
- /********************************************************************************
372
- * error() tests.
373
- ********************************************************************************/
374
-
375
- void
376
- test_error_donothing_if_logging_level_is_CRITICAL() {
377
- set_logging_level( "critical" );
378
- error( "This message must not be logged." );
379
- }
380
-
381
-
382
- void
383
- test_error_logs_if_logging_level_is_ERROR() {
384
- expect_string( mock_fprintf, output, "ERROR message.\n" );
385
-
386
- set_logging_level( "error" );
387
- error( "ERROR message." );
388
- }
389
-
390
-
391
- void
392
- test_error_logs_if_logging_level_is_WARNING() {
393
- expect_string( mock_fprintf, output, "ERROR message.\n" );
394
-
395
- set_logging_level( "warning" );
396
- error( "ERROR message." );
397
- }
398
-
399
-
400
- void
401
- test_error_fail_if_NULL() {
402
- expect_assert_failure( error( NULL ) );
403
- }
404
-
405
-
406
- /********************************************************************************
407
- * warn() tests.
408
- ********************************************************************************/
409
-
410
- void
411
- test_warn_donothing_if_logging_level_is_ERROR() {
412
- set_logging_level( "error" );
413
- warn( "This message must not be logged." );
414
- }
415
-
416
-
417
- void
418
- test_warn_logs_if_logging_level_is_WARNING() {
419
- expect_string( mock_fprintf, output, "WARN message.\n" );
420
-
421
- set_logging_level( "warning" );
422
- warn( "WARN message." );
423
- }
424
-
425
-
426
- void
427
- test_warn_logs_if_logging_level_is_NOTICE() {
428
- expect_string( mock_fprintf, output, "WARN message.\n" );
429
-
430
- set_logging_level( "notice" );
431
- warn( "WARN message." );
432
- }
433
-
434
-
435
- void
436
- test_warn_fail_if_NULL() {
437
- expect_assert_failure( warn( NULL ) );
438
- }
439
-
440
-
441
- /********************************************************************************
442
- * notice() tests.
443
- ********************************************************************************/
444
-
445
- void
446
- test_notice_donothing_if_logging_level_is_WARNING() {
447
- set_logging_level( "warning" );
448
- notice( "This message must not be logged." );
449
- }
450
-
451
-
452
- void
453
- test_notice_logs_if_logging_level_is_NOTICE() {
454
- expect_string( mock_fprintf, output, "NOTICE message.\n" );
455
-
456
- set_logging_level( "notice" );
457
- notice( "NOTICE message." );
458
- }
459
-
460
-
461
- void
462
- test_notice_logs_if_logging_level_is_INFO() {
463
- expect_string( mock_fprintf, output, "NOTICE message.\n" );
464
-
465
- set_logging_level( "info" );
466
- notice( "NOTICE message." );
467
- }
468
-
469
-
470
- void
471
- test_notice_fail_if_NULL() {
472
- expect_assert_failure( notice( NULL ) );
473
- }
474
-
475
-
476
- /********************************************************************************
477
- * info() tests.
478
- ********************************************************************************/
479
-
480
- void
481
- test_info_donothing_if_logging_level_is_NOTICE() {
482
- set_logging_level( "notice" );
483
- info( "This message must not be logged." );
484
- }
485
-
486
-
487
- void
488
- test_info_logs_if_logging_level_is_INFO() {
489
- expect_string( mock_fprintf, output, "INFO message.\n" );
490
-
491
- set_logging_level( "info" );
492
- info( "INFO message." );
493
- }
494
-
495
-
496
- void
497
- test_info_logs_if_logging_level_is_DEBUG() {
498
- expect_string( mock_fprintf, output, "INFO message.\n" );
499
-
500
- set_logging_level( "debug" );
501
- info( "INFO message." );
502
- }
503
-
504
-
505
- void
506
- test_info_fail_if_NULL() {
507
- expect_assert_failure( info( NULL ) );
508
- }
509
-
510
-
511
- /********************************************************************************
512
- * debug() tests.
513
- ********************************************************************************/
514
-
515
- void
516
- test_DEBUG_donothing_if_logging_level_is_INFO() {
517
- set_logging_level( "info" );
518
- debug( "This message must not be logged." );
519
- }
520
-
521
-
522
- void
523
- test_DEBUG_logs_if_logging_level_is_DEBUG() {
524
- expect_string( mock_fprintf, output, "DEBUG message.\n" );
525
-
526
- set_logging_level( "debug" );
527
- debug( "DEBUG message." );
528
- }
529
-
530
-
531
- void
532
- test_debug_fail_if_NULL() {
533
- expect_assert_failure( debug( NULL ) );
534
- }
535
-
536
-
537
- /********************************************************************************
538
- * Output type tests.
539
- ********************************************************************************/
540
-
541
- void
542
- test_output_to_stdout() {
543
- expect_string( mock_vprintf, output, "Hello World\n" );
544
-
545
- info( "Hello World" );
546
- }
547
-
548
-
549
- void
550
- test_output_to_file_stdout() {
551
- expect_string( mock_vprintf, output, "Hello World\n" );
552
- expect_string( mock_fprintf, output, "Hello World\n" );
553
-
554
- info( "Hello World" );
555
- }
556
-
557
-
558
- void
559
- test_output_to_syslog() {
560
- expect_value( mock_vsyslog, priority, LOG_INFO );
561
- expect_string( mock_vsyslog, output, "Hello World" );
562
-
563
- info( "Hello World" );
564
- }
565
-
566
-
567
- /********************************************************************************
568
- * Run tests.
569
- ********************************************************************************/
570
-
571
- int
572
- main() {
573
- const UnitTest tests[] = {
574
- unit_test_setup_teardown( test_init_log_reads_LOGING_LEVEL_environment_variable,
575
- reset_LOGGING_LEVEL, reset_LOGGING_LEVEL ),
576
- unit_test_setup_teardown( test_init_log_opens_syslog,
577
- setup, teardown ),
578
- unit_test_setup_teardown( test_init_log_reads_LOGGING_FACILITY_environment_variable,
579
- setup, teardown ),
580
-
581
- unit_test_setup_teardown( test_finalize_log_closes_syslog,
582
- setup_logger_syslog, teardown ),
583
-
584
- unit_test_setup_teardown( test_default_logging_level_is_INFO,
585
- setup_logger_file, teardown ),
586
- unit_test_setup_teardown( test_set_logging_level_succeeds,
587
- setup_logger_file, teardown ),
588
- unit_test_setup_teardown( test_set_logging_level_fails_with_invalid_value,
589
- setup_logger_file, teardown ),
590
- unit_test_setup_teardown( test_set_logging_level_is_called_before_init_log,
591
- setup, teardown ),
592
- unit_test_setup_teardown( test_LOGGING_LEVEL_overrides_logging_level,
593
- setup, teardown ),
594
- unit_test( test_valid_logging_level_returns_true_with_valid_logging_level ),
595
- unit_test( test_valid_logging_level_returns_false_with_invalid_logging_level ),
596
-
597
- unit_test_setup_teardown( test_default_faciliity_is_USER,
598
- setup, teardown ),
599
- unit_test_setup_teardown( test_set_syslog_facility_succeeds,
600
- setup, teardown ),
601
- unit_test_setup_teardown( test_set_syslog_facility_fails_with_invalid_value,
602
- setup, teardown ),
603
- unit_test_setup_teardown( test_LOGGING_FACILITY_overrides_logging_facility,
604
- setup, teardown ),
605
-
606
- unit_test_setup_teardown( test_critical_logs_if_logging_level_is_CRITICAL,
607
- setup_logger_file, teardown ),
608
- unit_test_setup_teardown( test_critical_logs_if_logging_level_is_ERROR,
609
- setup_logger_file, teardown ),
610
- unit_test_setup_teardown( test_critical_fail_if_NULL,
611
- setup_logger_file, teardown ),
612
-
613
- unit_test_setup_teardown( test_error_donothing_if_logging_level_is_CRITICAL,
614
- setup_logger_file, teardown ),
615
- unit_test_setup_teardown( test_error_logs_if_logging_level_is_ERROR,
616
- setup_logger_file, teardown ),
617
- unit_test_setup_teardown( test_error_logs_if_logging_level_is_WARNING,
618
- setup_logger_file, teardown ),
619
- unit_test_setup_teardown( test_error_fail_if_NULL,
620
- setup_logger_file, teardown ),
621
-
622
- unit_test_setup_teardown( test_warn_donothing_if_logging_level_is_ERROR,
623
- setup_logger_file, teardown ),
624
- unit_test_setup_teardown( test_warn_logs_if_logging_level_is_WARNING,
625
- setup_logger_file, teardown ),
626
- unit_test_setup_teardown( test_warn_logs_if_logging_level_is_NOTICE,
627
- setup_logger_file, teardown ),
628
- unit_test_setup_teardown( test_warn_fail_if_NULL,
629
- setup_logger_file, teardown ),
630
-
631
- unit_test_setup_teardown( test_notice_donothing_if_logging_level_is_WARNING,
632
- setup_logger_file, teardown ),
633
- unit_test_setup_teardown( test_notice_logs_if_logging_level_is_NOTICE,
634
- setup_logger_file, teardown ),
635
- unit_test_setup_teardown( test_notice_logs_if_logging_level_is_INFO,
636
- setup_logger_file, teardown ),
637
- unit_test_setup_teardown( test_notice_fail_if_NULL,
638
- setup_logger_file, teardown ),
639
-
640
- unit_test_setup_teardown( test_info_logs_if_logging_level_is_DEBUG,
641
- setup_logger_file, teardown ),
642
- unit_test_setup_teardown( test_info_logs_if_logging_level_is_INFO,
643
- setup_logger_file, teardown ),
644
- unit_test_setup_teardown( test_info_donothing_if_logging_level_is_NOTICE,
645
- setup_logger_file, teardown ),
646
- unit_test_setup_teardown( test_info_fail_if_NULL,
647
- setup_logger_file, teardown ),
648
-
649
- unit_test_setup_teardown( test_DEBUG_donothing_if_logging_level_is_INFO,
650
- setup_logger_file, teardown ),
651
- unit_test_setup_teardown( test_DEBUG_logs_if_logging_level_is_DEBUG,
652
- setup_logger_file, teardown ),
653
- unit_test_setup_teardown( test_debug_fail_if_NULL,
654
- setup_logger_file, teardown ),
655
-
656
- unit_test_setup_teardown( test_output_to_stdout,
657
- setup_logger_stdout, teardown ),
658
- unit_test_setup_teardown( test_output_to_file_stdout,
659
- setup_logger_file_stdout, teardown ),
660
- unit_test_setup_teardown( test_output_to_syslog,
661
- setup_logger_syslog, teardown ),
662
- };
663
- return run_tests( tests );
664
- }
665
-
666
-
667
- /*
668
- * Local variables:
669
- * c-basic-offset: 2
670
- * indent-tabs-mode: nil
671
- * End:
672
- */