trema 0.1.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (560) hide show
  1. data/.mono.rant +4107 -0
  2. data/.rspec +1 -0
  3. data/.yardopts +4 -0
  4. data/Doxyfile +1679 -0
  5. data/GPL2 +339 -0
  6. data/Gemfile +22 -0
  7. data/Gemfile.lock +71 -0
  8. data/README.md +135 -0
  9. data/Rakefile +140 -0
  10. data/Rantfile +834 -0
  11. data/VERSION +1 -0
  12. data/build.rb +32 -0
  13. data/cruise.rb +389 -0
  14. data/features/example.dumper.feature +87 -0
  15. data/features/example.learning_switch.feature +39 -0
  16. data/features/example.list_switches.feature +38 -0
  17. data/features/example.message.echo_reply.feature +26 -0
  18. data/features/example.message.echo_request.feature +25 -0
  19. data/features/example.message.features_request.feature +84 -0
  20. data/features/example.message.hello.feature +25 -0
  21. data/features/example.message.set_config.feature +27 -0
  22. data/features/example.multi_learning_switch.feature +135 -0
  23. data/features/example.packetin_filter_config.feature +91 -0
  24. data/features/example.repeater_hub.feature +49 -0
  25. data/features/example.switch_monitor.feature +39 -0
  26. data/features/packetin_filter.feature +49 -0
  27. data/features/step_definitions/kill_steps.rb +30 -0
  28. data/features/step_definitions/log_steps.rb +90 -0
  29. data/features/step_definitions/misc_steps.rb +64 -0
  30. data/features/step_definitions/off_steps.rb +30 -0
  31. data/features/step_definitions/run_steps.rb +91 -0
  32. data/features/step_definitions/send_packets_steps.rb +42 -0
  33. data/features/step_definitions/show_stats_steps.rb +43 -0
  34. data/features/step_definitions/stats_steps.rb +39 -0
  35. data/features/support/env.rb +75 -0
  36. data/features/support/hooks.rb +8 -0
  37. data/features/switch_manager.feature +35 -0
  38. data/features/trema-config.feature +68 -0
  39. data/features/trema.dump_flows.feature +25 -0
  40. data/features/trema.feature +25 -0
  41. data/features/trema.kill.feature +53 -0
  42. data/features/trema.killall.feature +30 -0
  43. data/features/trema.reset_stats.feature +14 -0
  44. data/features/trema.run.feature +46 -0
  45. data/features/trema.send_packets.feature +56 -0
  46. data/features/trema.show_stats.feature +67 -0
  47. data/features/tutorial.hello_trema.feature +27 -0
  48. data/features/tutorial.packet_in.feature +47 -0
  49. data/features/tutorial.switch_info.feature +55 -0
  50. data/ruby/.gitignore +4 -0
  51. data/ruby/blocker.rb +78 -0
  52. data/ruby/extconf.rb +71 -0
  53. data/ruby/sub-process.rb +291 -0
  54. data/ruby/trema/action-common.c +60 -0
  55. data/ruby/trema/action-common.h +42 -0
  56. data/ruby/trema/action-enqueue.c +161 -0
  57. data/ruby/trema/action-enqueue.h +40 -0
  58. data/ruby/trema/action-output.c +169 -0
  59. data/ruby/trema/action-output.h +42 -0
  60. data/ruby/trema/action-set-dl-dst.c +131 -0
  61. data/ruby/trema/action-set-dl-dst.h +44 -0
  62. data/ruby/trema/action-set-dl-src.c +131 -0
  63. data/ruby/trema/action-set-dl-src.h +44 -0
  64. data/ruby/trema/action-set-nw-dst.c +135 -0
  65. data/ruby/trema/action-set-nw-dst.h +42 -0
  66. data/ruby/trema/action-set-nw-src.c +140 -0
  67. data/ruby/trema/action-set-nw-src.h +42 -0
  68. data/ruby/trema/action-set-nw-tos.c +124 -0
  69. data/ruby/trema/action-set-nw-tos.h +42 -0
  70. data/ruby/trema/action-set-tp-dst.c +122 -0
  71. data/ruby/trema/action-set-tp-dst.h +42 -0
  72. data/ruby/trema/action-set-tp-src.c +124 -0
  73. data/ruby/trema/action-set-tp-src.h +42 -0
  74. data/ruby/trema/action-set-vlan-pcp.c +128 -0
  75. data/ruby/trema/action-set-vlan-pcp.h +42 -0
  76. data/ruby/trema/action-set-vlan-vid.c +125 -0
  77. data/ruby/trema/action-set-vlan-vid.h +42 -0
  78. data/ruby/trema/action-strip-vlan.c +81 -0
  79. data/ruby/trema/action-strip-vlan.h +42 -0
  80. data/ruby/trema/action-vendor.c +121 -0
  81. data/ruby/trema/action-vendor.h +42 -0
  82. data/ruby/trema/aggregate-stats-reply.rb +70 -0
  83. data/ruby/trema/app.rb +112 -0
  84. data/ruby/trema/barrier-reply.c +99 -0
  85. data/ruby/trema/barrier-reply.h +46 -0
  86. data/ruby/trema/barrier-request.c +108 -0
  87. data/ruby/trema/barrier-request.h +44 -0
  88. data/ruby/trema/cli.rb +269 -0
  89. data/ruby/trema/command.rb +40 -0
  90. data/ruby/trema/command/dump_flows.rb +62 -0
  91. data/ruby/trema/command/kill.rb +71 -0
  92. data/ruby/trema/command/killall.rb +56 -0
  93. data/ruby/trema/command/reset_stats.rb +61 -0
  94. data/ruby/trema/command/ruby.rb +55 -0
  95. data/ruby/trema/command/run.rb +120 -0
  96. data/ruby/trema/command/send_packets.rb +130 -0
  97. data/ruby/trema/command/shell.rb +61 -0
  98. data/ruby/trema/command/show_stats.rb +84 -0
  99. data/ruby/trema/command/usage.rb +61 -0
  100. data/ruby/trema/command/version.rb +39 -0
  101. data/ruby/trema/controller.c +595 -0
  102. data/ruby/trema/controller.h +44 -0
  103. data/ruby/trema/controller.rb +81 -0
  104. data/ruby/trema/daemon.rb +167 -0
  105. data/ruby/trema/dsl.rb +34 -0
  106. data/ruby/trema/dsl/configuration.rb +153 -0
  107. data/ruby/trema/dsl/context.rb +71 -0
  108. data/ruby/trema/dsl/link.rb +41 -0
  109. data/ruby/trema/dsl/parser.rb +70 -0
  110. data/ruby/trema/dsl/run.rb +49 -0
  111. data/ruby/trema/dsl/runner.rb +165 -0
  112. data/ruby/trema/dsl/stanza.rb +53 -0
  113. data/ruby/trema/dsl/switch.rb +78 -0
  114. data/ruby/trema/dsl/syntax-error.rb +33 -0
  115. data/ruby/trema/dsl/syntax.rb +109 -0
  116. data/ruby/trema/dsl/vhost.rb +108 -0
  117. data/ruby/trema/dsl/vswitch.rb +47 -0
  118. data/ruby/trema/echo-reply.c +107 -0
  119. data/ruby/trema/echo-reply.h +42 -0
  120. data/ruby/trema/echo-request.c +140 -0
  121. data/ruby/trema/echo-request.h +42 -0
  122. data/ruby/trema/error.c +253 -0
  123. data/ruby/trema/error.h +44 -0
  124. data/ruby/trema/exact-match.rb +36 -0
  125. data/ruby/trema/executables.rb +95 -0
  126. data/ruby/trema/features-reply.c +238 -0
  127. data/ruby/trema/features-reply.h +60 -0
  128. data/ruby/trema/features-request.c +109 -0
  129. data/ruby/trema/features-request.h +44 -0
  130. data/ruby/trema/flow-removed.c +275 -0
  131. data/ruby/trema/flow-removed.h +46 -0
  132. data/ruby/trema/flow-stats-reply.rb +109 -0
  133. data/ruby/trema/flow.rb +56 -0
  134. data/ruby/trema/get-config-reply.c +159 -0
  135. data/ruby/trema/get-config-reply.h +52 -0
  136. data/ruby/trema/get-config-request.c +107 -0
  137. data/ruby/trema/get-config-request.h +44 -0
  138. data/ruby/trema/hello.c +110 -0
  139. data/ruby/trema/hello.h +44 -0
  140. data/ruby/trema/host.rb +257 -0
  141. data/ruby/trema/ip.rb +101 -0
  142. data/ruby/trema/link.rb +176 -0
  143. data/ruby/trema/list-switches-reply.c +46 -0
  144. data/ruby/trema/list-switches-reply.h +40 -0
  145. data/ruby/trema/logger.c +162 -0
  146. data/ruby/trema/logger.h +44 -0
  147. data/ruby/trema/mac.rb +151 -0
  148. data/ruby/trema/match.c +594 -0
  149. data/ruby/trema/match.h +36 -0
  150. data/ruby/trema/monkey-patch/integer.rb +35 -0
  151. data/ruby/trema/monkey-patch/integer/base-conversions.rb +36 -0
  152. data/ruby/trema/monkey-patch/integer/ranges.rb +51 -0
  153. data/ruby/trema/monkey-patch/module.rb +33 -0
  154. data/ruby/trema/monkey-patch/module/deprecation.rb +41 -0
  155. data/ruby/trema/monkey-patch/string.rb +33 -0
  156. data/ruby/trema/monkey-patch/string/inflectors.rb +54 -0
  157. data/ruby/trema/network-component.rb +153 -0
  158. data/ruby/trema/ofctl.rb +62 -0
  159. data/ruby/trema/open-vswitch.rb +154 -0
  160. data/ruby/trema/openflow-error.c +191 -0
  161. data/ruby/trema/openflow-error.h +53 -0
  162. data/ruby/trema/openflow-switch.rb +88 -0
  163. data/ruby/trema/ordered-hash.rb +74 -0
  164. data/ruby/trema/packet-queue.rb +178 -0
  165. data/ruby/trema/packet_in.c +736 -0
  166. data/ruby/trema/packet_in.h +46 -0
  167. data/ruby/trema/packetin-filter.rb +126 -0
  168. data/ruby/trema/path.rb +135 -0
  169. data/ruby/trema/phost.rb +69 -0
  170. data/ruby/trema/port-mod.c +226 -0
  171. data/ruby/trema/port-mod.h +36 -0
  172. data/ruby/trema/port-stats-reply.rb +111 -0
  173. data/ruby/trema/port-status.c +156 -0
  174. data/ruby/trema/port-status.h +45 -0
  175. data/ruby/trema/port.c +295 -0
  176. data/ruby/trema/port.h +47 -0
  177. data/ruby/trema/process.rb +76 -0
  178. data/ruby/trema/queue-get-config-reply.c +200 -0
  179. data/ruby/trema/queue-get-config-reply.h +47 -0
  180. data/ruby/trema/queue-get-config-request.c +141 -0
  181. data/ruby/trema/queue-get-config-request.h +44 -0
  182. data/ruby/trema/queue-stats-reply.rb +78 -0
  183. data/ruby/trema/set-config.c +171 -0
  184. data/ruby/trema/set-config.h +44 -0
  185. data/ruby/trema/shell.rb +39 -0
  186. data/ruby/trema/shell/down.rb +39 -0
  187. data/ruby/trema/shell/killall.rb +40 -0
  188. data/ruby/trema/shell/link.rb +61 -0
  189. data/ruby/trema/shell/reset_stats.rb +50 -0
  190. data/ruby/trema/shell/run.rb +67 -0
  191. data/ruby/trema/shell/send_packets.rb +42 -0
  192. data/ruby/trema/shell/show_stats.rb +49 -0
  193. data/ruby/trema/shell/up.rb +43 -0
  194. data/ruby/trema/shell/vhost.rb +44 -0
  195. data/ruby/trema/shell/vswitch.rb +49 -0
  196. data/ruby/trema/stats-helper.rb +65 -0
  197. data/ruby/trema/stats-reply.c +483 -0
  198. data/ruby/trema/stats-reply.h +53 -0
  199. data/ruby/trema/stats-request.c +634 -0
  200. data/ruby/trema/stats-request.h +42 -0
  201. data/ruby/trema/switch-daemon.rb +74 -0
  202. data/ruby/trema/switch-disconnected.c +40 -0
  203. data/ruby/trema/switch-disconnected.h +38 -0
  204. data/ruby/trema/switch-manager.rb +121 -0
  205. data/ruby/trema/switch.rb +37 -0
  206. data/ruby/trema/table-stats-reply.rb +87 -0
  207. data/ruby/trema/timers.rb +97 -0
  208. data/ruby/trema/trema.c +122 -0
  209. data/ruby/trema/tremashark.rb +39 -0
  210. data/ruby/trema/util.rb +84 -0
  211. data/ruby/trema/vendor-request.c +193 -0
  212. data/ruby/trema/vendor-request.h +44 -0
  213. data/ruby/trema/vendor-stats-reply.rb +62 -0
  214. data/ruby/trema/vendor.c +152 -0
  215. data/ruby/trema/vendor.h +52 -0
  216. data/ruby/trema/version.rb +30 -0
  217. data/spec/spec_helper.rb +153 -0
  218. data/spec/support/openflow-message.rb +94 -0
  219. data/spec/trema/action-enqueue_spec.rb +100 -0
  220. data/spec/trema/action-output_spec.rb +116 -0
  221. data/spec/trema/action-set-dl-dst_spec.rb +95 -0
  222. data/spec/trema/action-set-dl-src_spec.rb +92 -0
  223. data/spec/trema/action-set-nw-dst_spec.rb +96 -0
  224. data/spec/trema/action-set-nw-src_spec.rb +97 -0
  225. data/spec/trema/action-set-nw-tos_spec.rb +88 -0
  226. data/spec/trema/action-set-tp-dst_spec.rb +88 -0
  227. data/spec/trema/action-set-tp-src_spec.rb +88 -0
  228. data/spec/trema/action-set-vlan-pcp_spec.rb +91 -0
  229. data/spec/trema/action-set-vlan-vid_spec.rb +91 -0
  230. data/spec/trema/action-strip-vlan_spec.rb +57 -0
  231. data/spec/trema/action-vendor_spec.rb +90 -0
  232. data/spec/trema/app_spec.rb +90 -0
  233. data/spec/trema/barrier-reply_spec.rb +45 -0
  234. data/spec/trema/barrier-request_spec.rb +83 -0
  235. data/spec/trema/cli_spec.rb +160 -0
  236. data/spec/trema/controller_spec.rb +100 -0
  237. data/spec/trema/dsl/configuration_spec.rb +122 -0
  238. data/spec/trema/dsl/link_spec.rb +54 -0
  239. data/spec/trema/dsl/run_spec.rb +78 -0
  240. data/spec/trema/dsl/runner_spec.rb +239 -0
  241. data/spec/trema/dsl/switch_spec.rb +77 -0
  242. data/spec/trema/dsl/syntax_spec.rb +121 -0
  243. data/spec/trema/dsl/vhost_spec.rb +148 -0
  244. data/spec/trema/dsl/vswitch_spec.rb +90 -0
  245. data/spec/trema/echo-reply_spec.rb +49 -0
  246. data/spec/trema/echo-request_spec.rb +75 -0
  247. data/spec/trema/error_spec.rb +142 -0
  248. data/spec/trema/executables_spec.rb +75 -0
  249. data/spec/trema/features-reply_spec.rb +57 -0
  250. data/spec/trema/features-request_spec.rb +66 -0
  251. data/spec/trema/flow-removed_spec.rb +146 -0
  252. data/spec/trema/get-config-reply_spec.rb +43 -0
  253. data/spec/trema/get-config-request_spec.rb +82 -0
  254. data/spec/trema/hello_spec.rb +49 -0
  255. data/spec/trema/host_spec.rb +193 -0
  256. data/spec/trema/link_spec.rb +64 -0
  257. data/spec/trema/list-switches-reply_spec.rb +48 -0
  258. data/spec/trema/logger_spec.rb +48 -0
  259. data/spec/trema/mac_spec.rb +115 -0
  260. data/spec/trema/match_spec.rb +113 -0
  261. data/spec/trema/open-vswitch_spec.rb +123 -0
  262. data/spec/trema/openflow-error_spec.rb +141 -0
  263. data/spec/trema/openflow-switch_spec.rb +56 -0
  264. data/spec/trema/packet-in_spec.rb +168 -0
  265. data/spec/trema/packet-out_spec.rb +128 -0
  266. data/spec/trema/packetin-filter_spec.rb +41 -0
  267. data/spec/trema/port-mod_spec.rb +101 -0
  268. data/spec/trema/port-status_spec.rb +108 -0
  269. data/spec/trema/port_spec.rb +61 -0
  270. data/spec/trema/process_spec.rb +71 -0
  271. data/spec/trema/queue-get-config-reply_spec.rb +66 -0
  272. data/spec/trema/queue-get-config-request_spec.rb +69 -0
  273. data/spec/trema/set-config_spec.rb +80 -0
  274. data/spec/trema/shell/vhost_spec.rb +57 -0
  275. data/spec/trema/shell/vswitch_spec.rb +89 -0
  276. data/spec/trema/stats-reply_spec.rb +306 -0
  277. data/spec/trema/stats-request_spec.rb +151 -0
  278. data/spec/trema/switch-disconnected_spec.rb +58 -0
  279. data/spec/trema/switch-manager_spec.rb +43 -0
  280. data/spec/trema/tremashark_spec.rb +41 -0
  281. data/spec/trema/util_spec.rb +93 -0
  282. data/spec/trema/vendor-request_spec.rb +79 -0
  283. data/src/examples/cbench_switch/README +21 -0
  284. data/src/examples/cbench_switch/cbench-switch.rb +39 -0
  285. data/src/examples/cbench_switch/cbench_switch.c +68 -0
  286. data/src/examples/dumper/dumper.c +370 -0
  287. data/src/examples/dumper/dumper.conf +7 -0
  288. data/src/examples/dumper/dumper.rb +196 -0
  289. data/src/examples/hello_trema/README +13 -0
  290. data/src/examples/hello_trema/hello_trema.c +51 -0
  291. data/src/examples/hello_trema/hello_trema.conf +3 -0
  292. data/src/examples/hello_trema/hello_trema.rb +35 -0
  293. data/src/examples/learning_switch/README +15 -0
  294. data/src/examples/learning_switch/fdb.rb +112 -0
  295. data/src/examples/learning_switch/learning-switch.rb +88 -0
  296. data/src/examples/learning_switch/learning_switch.c +236 -0
  297. data/src/examples/learning_switch/learning_switch.conf +18 -0
  298. data/src/examples/list_switches/README +19 -0
  299. data/src/examples/list_switches/list-switches.rb +45 -0
  300. data/src/examples/list_switches/list_switches.c +81 -0
  301. data/src/examples/list_switches/list_switches.conf +15 -0
  302. data/src/examples/match_compare/match-compare.conf +30 -0
  303. data/src/examples/match_compare/match-compare.rb +99 -0
  304. data/src/examples/multi_learning_switch/README +14 -0
  305. data/src/examples/multi_learning_switch/multi-learning-switch.rb +96 -0
  306. data/src/examples/multi_learning_switch/multi_learning_switch.c +296 -0
  307. data/src/examples/multi_learning_switch/multi_learning_switch.conf +17 -0
  308. data/src/examples/openflow_message/README +11 -0
  309. data/src/examples/openflow_message/echo-reply.rb +59 -0
  310. data/src/examples/openflow_message/echo-request.rb +58 -0
  311. data/src/examples/openflow_message/echo_reply.c +70 -0
  312. data/src/examples/openflow_message/echo_request.c +70 -0
  313. data/src/examples/openflow_message/example.rb +63 -0
  314. data/src/examples/openflow_message/features-request.rb +97 -0
  315. data/src/examples/openflow_message/features_request.c +168 -0
  316. data/src/examples/openflow_message/hello.c +70 -0
  317. data/src/examples/openflow_message/hello.rb +58 -0
  318. data/src/examples/openflow_message/set-config.rb +59 -0
  319. data/src/examples/openflow_message/set_config.c +70 -0
  320. data/src/examples/packet_in/README +15 -0
  321. data/src/examples/packet_in/packet_in.c +55 -0
  322. data/src/examples/packet_in/packet_in.conf +15 -0
  323. data/src/examples/packet_in/packet_in.rb +34 -0
  324. data/src/examples/packetin_filter_config/README +12 -0
  325. data/src/examples/packetin_filter_config/add_filter.c +73 -0
  326. data/src/examples/packetin_filter_config/delete_filter.c +65 -0
  327. data/src/examples/packetin_filter_config/delete_filter_strict.c +75 -0
  328. data/src/examples/packetin_filter_config/dump_filter.c +65 -0
  329. data/src/examples/packetin_filter_config/dump_filter_strict.c +75 -0
  330. data/src/examples/packetin_filter_config/packetin_filter_config.c +134 -0
  331. data/src/examples/packetin_filter_config/packetin_filter_config.conf +7 -0
  332. data/src/examples/packetin_filter_config/utils.c +102 -0
  333. data/src/examples/packetin_filter_config/utils.h +42 -0
  334. data/src/examples/repeater_hub/README +8 -0
  335. data/src/examples/repeater_hub/repeater-hub.rb +43 -0
  336. data/src/examples/repeater_hub/repeater-hub_spec.rb +156 -0
  337. data/src/examples/repeater_hub/repeater_hub.c +83 -0
  338. data/src/examples/repeater_hub/repeater_hub.conf +28 -0
  339. data/src/examples/switch_info/README +13 -0
  340. data/src/examples/switch_info/switch_info.c +80 -0
  341. data/src/examples/switch_info/switch_info.conf +3 -0
  342. data/src/examples/switch_info/switch_info.rb +46 -0
  343. data/src/examples/switch_monitor/switch-monitor.conf +3 -0
  344. data/src/examples/switch_monitor/switch-monitor.rb +58 -0
  345. data/src/examples/switch_monitor/switch_monitor.c +154 -0
  346. data/src/examples/traffic_monitor/counter.c +74 -0
  347. data/src/examples/traffic_monitor/counter.h +48 -0
  348. data/src/examples/traffic_monitor/counter.rb +46 -0
  349. data/src/examples/traffic_monitor/fdb.c +76 -0
  350. data/src/examples/traffic_monitor/fdb.h +50 -0
  351. data/src/examples/traffic_monitor/fdb.rb +44 -0
  352. data/src/examples/traffic_monitor/traffic-monitor.rb +100 -0
  353. data/src/examples/traffic_monitor/traffic_monitor.c +163 -0
  354. data/src/examples/traffic_monitor/traffic_monitor.conf +16 -0
  355. data/src/lib/arp.h +61 -0
  356. data/src/lib/bool.h +49 -0
  357. data/src/lib/buffer.c +305 -0
  358. data/src/lib/buffer.h +56 -0
  359. data/src/lib/byteorder.c +547 -0
  360. data/src/lib/byteorder.h +110 -0
  361. data/src/lib/checks.h +42 -0
  362. data/src/lib/daemon.c +302 -0
  363. data/src/lib/daemon.h +42 -0
  364. data/src/lib/doubly_linked_list.c +281 -0
  365. data/src/lib/doubly_linked_list.h +88 -0
  366. data/src/lib/ether.c +48 -0
  367. data/src/lib/ether.h +94 -0
  368. data/src/lib/etherip.h +46 -0
  369. data/src/lib/event_handler.c +389 -0
  370. data/src/lib/event_handler.h +64 -0
  371. data/src/lib/hash_table.c +417 -0
  372. data/src/lib/hash_table.h +138 -0
  373. data/src/lib/icmp.h +74 -0
  374. data/src/lib/igmp.h +50 -0
  375. data/src/lib/ipv4.h +50 -0
  376. data/src/lib/linked_list.c +199 -0
  377. data/src/lib/linked_list.h +84 -0
  378. data/src/lib/log.c +402 -0
  379. data/src/lib/log.h +78 -0
  380. data/src/lib/match.h +84 -0
  381. data/src/lib/match_table.c +608 -0
  382. data/src/lib/match_table.h +51 -0
  383. data/src/lib/message_queue.c +143 -0
  384. data/src/lib/message_queue.h +61 -0
  385. data/src/lib/messenger.c +1714 -0
  386. data/src/lib/messenger.h +145 -0
  387. data/src/lib/openflow_application_interface.c +1673 -0
  388. data/src/lib/openflow_application_interface.h +329 -0
  389. data/src/lib/openflow_message.c +4051 -0
  390. data/src/lib/openflow_message.h +288 -0
  391. data/src/lib/openflow_service_interface.h +59 -0
  392. data/src/lib/packet_info.c +230 -0
  393. data/src/lib/packet_info.h +209 -0
  394. data/src/lib/packet_parser.c +502 -0
  395. data/src/lib/packetin_filter_interface.c +294 -0
  396. data/src/lib/packetin_filter_interface.h +127 -0
  397. data/src/lib/persistent_storage.c +480 -0
  398. data/src/lib/persistent_storage.h +46 -0
  399. data/src/lib/stat.c +213 -0
  400. data/src/lib/stat.h +44 -0
  401. data/src/lib/tcp.h +67 -0
  402. data/src/lib/timer.c +350 -0
  403. data/src/lib/timer.h +53 -0
  404. data/src/lib/trema.c +710 -0
  405. data/src/lib/trema.h +79 -0
  406. data/src/lib/trema_private.c +177 -0
  407. data/src/lib/trema_private.h +60 -0
  408. data/src/lib/trema_wrapper.c +56 -0
  409. data/src/lib/trema_wrapper.h +64 -0
  410. data/src/lib/udp.h +43 -0
  411. data/src/lib/utility.c +515 -0
  412. data/src/lib/utility.h +67 -0
  413. data/src/lib/wrapper.c +100 -0
  414. data/src/lib/wrapper.h +76 -0
  415. data/src/packetin_filter/README +17 -0
  416. data/src/packetin_filter/packetin_filter.c +575 -0
  417. data/src/switch_manager/README +20 -0
  418. data/src/switch_manager/cookie_table.c +292 -0
  419. data/src/switch_manager/cookie_table.h +72 -0
  420. data/src/switch_manager/dpid_table.c +110 -0
  421. data/src/switch_manager/dpid_table.h +46 -0
  422. data/src/switch_manager/management_interface.h +44 -0
  423. data/src/switch_manager/ofpmsg_recv.c +482 -0
  424. data/src/switch_manager/ofpmsg_recv.h +42 -0
  425. data/src/switch_manager/ofpmsg_send.c +235 -0
  426. data/src/switch_manager/ofpmsg_send.h +50 -0
  427. data/src/switch_manager/secure_channel_listener.c +281 -0
  428. data/src/switch_manager/secure_channel_listener.h +42 -0
  429. data/src/switch_manager/secure_channel_receiver.c +126 -0
  430. data/src/switch_manager/secure_channel_receiver.h +43 -0
  431. data/src/switch_manager/secure_channel_sender.c +126 -0
  432. data/src/switch_manager/secure_channel_sender.h +43 -0
  433. data/src/switch_manager/service_interface.c +181 -0
  434. data/src/switch_manager/service_interface.h +46 -0
  435. data/src/switch_manager/switch.c +538 -0
  436. data/src/switch_manager/switch.h +51 -0
  437. data/src/switch_manager/switch_manager.c +448 -0
  438. data/src/switch_manager/switch_manager.h +63 -0
  439. data/src/switch_manager/switchinfo.h +72 -0
  440. data/src/switch_manager/xid_table.c +184 -0
  441. data/src/switch_manager/xid_table.h +56 -0
  442. data/src/tremashark/README +78 -0
  443. data/src/tremashark/packet_capture.c +357 -0
  444. data/src/tremashark/pcap_private.h +47 -0
  445. data/src/tremashark/pcap_queue.c +197 -0
  446. data/src/tremashark/pcap_queue.h +58 -0
  447. data/src/tremashark/plugin/.gitignore +6 -0
  448. data/src/tremashark/plugin/packet-trema/.gitignore +5 -0
  449. data/src/tremashark/plugin/packet-trema/Makefile +77 -0
  450. data/src/tremashark/plugin/packet-trema/Makefile.am +110 -0
  451. data/src/tremashark/plugin/packet-trema/Makefile.common +31 -0
  452. data/src/tremashark/plugin/packet-trema/moduleinfo.h +41 -0
  453. data/src/tremashark/plugin/packet-trema/packet-trema.c +1659 -0
  454. data/src/tremashark/plugin/packet-trema/plugin.c +31 -0
  455. data/src/tremashark/plugin/user_dlts +2 -0
  456. data/src/tremashark/queue.c +168 -0
  457. data/src/tremashark/queue.h +60 -0
  458. data/src/tremashark/stdin_relay.c +257 -0
  459. data/src/tremashark/syslog_relay.c +247 -0
  460. data/src/tremashark/tremashark.c +556 -0
  461. data/trema +93 -0
  462. data/trema-config +61 -0
  463. data/unittests/buffer_stubs.c +74 -0
  464. data/unittests/cmockery_trema.c +123 -0
  465. data/unittests/cmockery_trema.h +96 -0
  466. data/unittests/lib/buffer_test.c +370 -0
  467. data/unittests/lib/byteorder_test.c +1717 -0
  468. data/unittests/lib/daemon_test.c +664 -0
  469. data/unittests/lib/doubly_linked_list_test.c +346 -0
  470. data/unittests/lib/ether_test.c +127 -0
  471. data/unittests/lib/hash_table_test.c +278 -0
  472. data/unittests/lib/linked_list_test.c +343 -0
  473. data/unittests/lib/log_test.c +459 -0
  474. data/unittests/lib/match_table_test.c +1509 -0
  475. data/unittests/lib/message_queue_test.c +379 -0
  476. data/unittests/lib/messenger_test.c +438 -0
  477. data/unittests/lib/openflow_application_interface_test.c +3488 -0
  478. data/unittests/lib/openflow_message_test.c +7337 -0
  479. data/unittests/lib/packet_info_test.c +544 -0
  480. data/unittests/lib/packet_parser_test.c +703 -0
  481. data/unittests/lib/packetin_filter_interface_test.c +723 -0
  482. data/unittests/lib/persistent_storage_test.c +802 -0
  483. data/unittests/lib/stat_test.c +291 -0
  484. data/unittests/lib/test_packets/arp_rep.cap +0 -0
  485. data/unittests/lib/test_packets/arp_req.cap +0 -0
  486. data/unittests/lib/test_packets/icmp_echo_rep.cap +0 -0
  487. data/unittests/lib/test_packets/icmp_echo_req.cap +0 -0
  488. data/unittests/lib/test_packets/igmp_query_v2.cap +0 -0
  489. data/unittests/lib/test_packets/ipx.cap +0 -0
  490. data/unittests/lib/test_packets/lldp.cap +0 -0
  491. data/unittests/lib/test_packets/lldp_over_ip.cap +0 -0
  492. data/unittests/lib/test_packets/tcp.cap +0 -0
  493. data/unittests/lib/test_packets/tcp_syn.cap +0 -0
  494. data/unittests/lib/test_packets/udp.cap +0 -0
  495. data/unittests/lib/test_packets/udp_frag_head.cap +0 -0
  496. data/unittests/lib/test_packets/udp_frag_next.cap +0 -0
  497. data/unittests/lib/test_packets/vtag_icmp_echo_rep.cap +0 -0
  498. data/unittests/lib/test_packets/vtag_icmp_echo_req.cap +0 -0
  499. data/unittests/lib/timer_test.c +248 -0
  500. data/unittests/lib/trema_private_test.c +323 -0
  501. data/unittests/lib/trema_test.c +985 -0
  502. data/unittests/lib/utility_test.c +628 -0
  503. data/unittests/lib/wrapper_test.c +201 -0
  504. data/unittests/packetin_filter/packetin_filter_test.c +477 -0
  505. data/unittests/switch_manager/switch_manager_test.c +1178 -0
  506. data/unittests/wrapper_stubs.c +39 -0
  507. data/vendor/.gitignore +6 -0
  508. data/vendor/README +30 -0
  509. data/vendor/cmockery-20110428.tar.gz +0 -0
  510. data/vendor/oflops-0.03.tar.gz +0 -0
  511. data/vendor/oflops_no_snmp+1.0.0.patch +340 -0
  512. data/vendor/openflow-1.0.0.tar.gz +0 -0
  513. data/vendor/openflow.git.tar.gz +0 -0
  514. data/vendor/openvswitch-1.2.2.tar.gz +0 -0
  515. data/vendor/ruby-ifconfig-1.2/COPYING +340 -0
  516. data/vendor/ruby-ifconfig-1.2/Changelog +16 -0
  517. data/vendor/ruby-ifconfig-1.2/INSTALL +239 -0
  518. data/vendor/ruby-ifconfig-1.2/README +38 -0
  519. data/vendor/ruby-ifconfig-1.2/Rakefile +14 -0
  520. data/vendor/ruby-ifconfig-1.2/TODO +8 -0
  521. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/darwin.txt +17 -0
  522. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/dragonflybsd.txt +10 -0
  523. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/dragonflybsd_netstat.txt +14 -0
  524. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/freebsd.txt +17 -0
  525. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/freebsd_netstat.txt +24 -0
  526. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/linux.txt +60 -0
  527. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/linux_ethernet.txt +20 -0
  528. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/netbsd.txt +10 -0
  529. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/openbsd.txt +36 -0
  530. data/vendor/ruby-ifconfig-1.2/ifconfig_examples/sunos.txt +10 -0
  531. data/vendor/ruby-ifconfig-1.2/lib/ifconfig.rb +71 -0
  532. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/bsd/ifconfig.rb +72 -0
  533. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/bsd/interface_types.rb +69 -0
  534. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/bsd/network_types.rb +3 -0
  535. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/common/ifconfig.rb +84 -0
  536. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/common/interface_types.rb +130 -0
  537. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/common/network_types.rb +49 -0
  538. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/linux/ifconfig.rb +43 -0
  539. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/linux/interface_types.rb +112 -0
  540. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/linux/network_types.rb +55 -0
  541. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/sunos/ifconfig.rb +38 -0
  542. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/sunos/interface_types.rb +77 -0
  543. data/vendor/ruby-ifconfig-1.2/lib/ifconfig/sunos/network_types.rb +4 -0
  544. data/vendor/ruby-ifconfig-1.2/setup.rb +1306 -0
  545. data/vendor/ruby-ifconfig-1.2/test/test_bsd.rb +35 -0
  546. data/vendor/ruby-ifconfig-1.2/test/test_darwin.rb +33 -0
  547. data/vendor/ruby-ifconfig-1.2/test/test_dragonflybsd.rb +35 -0
  548. data/vendor/ruby-ifconfig-1.2/test/test_helper.rb +4 -0
  549. data/vendor/ruby-ifconfig-1.2/test/test_linux.rb +31 -0
  550. data/vendor/ruby-ifconfig-1.2/test/test_netbsd.rb +33 -0
  551. data/vendor/ruby-ifconfig-1.2/test/test_openbsd.rb +33 -0
  552. data/vendor/ruby-ifconfig-1.2/test/test_sunos.rb +35 -0
  553. data/vendor/ruby-ifconfig-1.2/test/unit/tc_darwin.rb +40 -0
  554. data/vendor/ruby-ifconfig-1.2/test/unit/tc_dragonflybsd.rb +39 -0
  555. data/vendor/ruby-ifconfig-1.2/test/unit/tc_freebsd.rb +40 -0
  556. data/vendor/ruby-ifconfig-1.2/test/unit/tc_linux.rb +49 -0
  557. data/vendor/ruby-ifconfig-1.2/test/unit/tc_netbsd.rb +39 -0
  558. data/vendor/ruby-ifconfig-1.2/test/unit/tc_openbsd.rb +39 -0
  559. data/vendor/ruby-ifconfig-1.2/test/unit/tc_sunos.rb +44 -0
  560. metadata +856 -0
@@ -0,0 +1,1509 @@
1
+ /*
2
+ * Unit tests for match table.
3
+ *
4
+ * Author: Kazushi SUGYO
5
+ *
6
+ * Copyright (C) 2008-2012 NEC Corporation
7
+ *
8
+ * This program is free software; you can redistribute it and/or modify
9
+ * it under the terms of the GNU General Public License, version 2, as
10
+ * published by the Free Software Foundation.
11
+ *
12
+ * This program is distributed in the hope that it will be useful,
13
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
14
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
+ * GNU General Public License for more details.
16
+ *
17
+ * You should have received a copy of the GNU General Public License along
18
+ * with this program; if not, write to the Free Software Foundation, Inc.,
19
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20
+ */
21
+
22
+
23
+ #include <net/ethernet.h>
24
+ #include <stdio.h>
25
+ #include <stdlib.h>
26
+ #include <string.h>
27
+ #include "checks.h"
28
+ #include "cmockery_trema.h"
29
+ #include "ether.h"
30
+ #include "log.h"
31
+ #include "match_table.h"
32
+ #include "linked_list.h"
33
+ #include "utility.h"
34
+ #include "wrapper.h"
35
+
36
+
37
+ typedef struct match_table {
38
+ hash_table *exact_table;
39
+ list_element *wildcards_table;
40
+ pthread_mutex_t *mutex;
41
+ } match_table;
42
+
43
+
44
+ extern match_table *_match_table_head;
45
+
46
+
47
+ /*************************************************************************
48
+ * Helper.
49
+ *************************************************************************/
50
+
51
+ // Setup and teardown function.
52
+
53
+ #define XFREE( x ) ({ void *p = ( x ); assert_true( p != NULL ); xfree( p ); })
54
+
55
+ static void ( *original_die )( const char *format, ... );
56
+
57
+ static void
58
+ mock_die( const char *format, ... ) {
59
+ UNUSED( format );
60
+ mock_assert( false, "mock_die", __FILE__, __LINE__ ); } // Hoaxes gcov.
61
+
62
+
63
+ static void
64
+ setup() {
65
+ original_die = die;
66
+ die = mock_die;
67
+ }
68
+
69
+
70
+ static void
71
+ teardown() {
72
+ die = original_die;
73
+ }
74
+
75
+
76
+ static void
77
+ setup_and_init() {
78
+ setup();
79
+ init_match_table();
80
+ }
81
+
82
+
83
+ static void
84
+ finalize_and_teardown() {
85
+ finalize_match_table();
86
+ teardown();
87
+ }
88
+
89
+
90
+ #define HIGH_PRIORITY 0xffff
91
+ #define LOW_PRIORITY 0x0
92
+ #define DEFAULT_PRIORITY OFP_DEFAULT_PRIORITY
93
+
94
+ // Exact entry helper.
95
+
96
+ static void
97
+ set_alice_match_entry( struct ofp_match *match ) {
98
+ memset( match, 0, sizeof( struct ofp_match ) );
99
+ match->wildcards = 0;
100
+ match->dl_type = ETHERTYPE_IP;
101
+ match->nw_src = 0x0a000101;
102
+ match->nw_dst = 0x0a000202;
103
+ }
104
+
105
+
106
+ static void
107
+ set_bob_match_entry( struct ofp_match *match ) {
108
+ memset( match, 0, sizeof( struct ofp_match ) );
109
+ match->wildcards = 0;
110
+ match->dl_type = ETHERTYPE_IP;
111
+ match->nw_src = 0x0a000202;
112
+ match->nw_dst = 0x0a000101;
113
+ }
114
+
115
+
116
+ static void
117
+ set_carol_match_entry( struct ofp_match *match ) {
118
+ memset( match, 0, sizeof( struct ofp_match ) );
119
+ match->wildcards = 0;
120
+ match->dl_type = ETHERTYPE_IP;
121
+ match->nw_src = 0x0a000303;
122
+ match->nw_dst = 0xffffffff;
123
+ }
124
+
125
+ #define ALICE_MATCH_SERVICE_NAME "service-name-alice"
126
+ #define BOB_MATCH_SERVICE_NAME "service-name-bob"
127
+ #define CAROL_MATCH_SERVICE_NAME "service-name-carol"
128
+ #define CAROL_MATCH_OTHER_SERVICE_NAME "other-service-name-carol"
129
+
130
+ #define USER_DATA "user-data"
131
+
132
+
133
+ // Wildcards entry helper.
134
+
135
+ static void
136
+ set_any_wildcards_entry( struct ofp_match *match ) {
137
+ memset( match, 0, sizeof( struct ofp_match ) );
138
+ match->wildcards = OFPFW_ALL;
139
+ }
140
+
141
+
142
+ static void
143
+ set_lldp_wildcards_entry( struct ofp_match *match ) {
144
+ memset( match, 0, sizeof( struct ofp_match ) );
145
+ match->wildcards = OFPFW_ALL & ~OFPFW_DL_TYPE;
146
+ match->dl_type = ETH_ETHTYPE_LLDP;
147
+ }
148
+
149
+
150
+ static void
151
+ set_alice_wildcards_entry( struct ofp_match *match ) {
152
+ memset( match, 0, sizeof( struct ofp_match ) );
153
+ match->wildcards = OFPFW_ALL & ~OFPFW_DL_TYPE & ~OFPFW_NW_SRC_MASK;
154
+ match->dl_type = ETHERTYPE_IP;
155
+ match->nw_src = 0x0a000101;
156
+ }
157
+
158
+
159
+ static void
160
+ set_bob_wildcards_entry( struct ofp_match *match ) {
161
+ memset( match, 0, sizeof( struct ofp_match ) );
162
+ match->wildcards = OFPFW_ALL & ~OFPFW_DL_TYPE & ~OFPFW_NW_SRC_MASK;
163
+ match->dl_type = ETHERTYPE_IP;
164
+ match->nw_src = 0x0a000202;
165
+ }
166
+
167
+
168
+ static void
169
+ set_carol_wildcards_entry( struct ofp_match *match ) {
170
+ memset( match, 0, sizeof( struct ofp_match ) );
171
+ match->wildcards = OFPFW_ALL & ~OFPFW_DL_TYPE & ~OFPFW_NW_SRC_MASK;
172
+ match->dl_type = ETHERTYPE_IP;
173
+ match->nw_src = 0x0a000303;
174
+ }
175
+
176
+
177
+ #define ANY_MATCH_SERVICE_NAME "service-name-any"
178
+ #define LLDP_MATCH_SERVICE_NAME "service-name-lldp"
179
+
180
+
181
+ /*************************************************************************
182
+ * init and finalize tests.
183
+ *************************************************************************/
184
+
185
+ static void
186
+ test_init_and_finalize_match_table_succeeds() {
187
+ assert_true( _match_table_head == NULL );
188
+ init_match_table();
189
+ assert_true( _match_table_head != NULL );
190
+ finalize_match_table();
191
+ assert_true( _match_table_head == NULL );
192
+ }
193
+
194
+
195
+ static void
196
+ test_init_match_table_dies_if_already_initialized() {
197
+ init_match_table();
198
+ assert_true( _match_table_head != NULL );
199
+ expect_assert_failure( init_match_table() );
200
+ }
201
+
202
+
203
+ static void
204
+ test_finalize_match_table_dies_if_not_initialized() {
205
+ assert_true( _match_table_head == NULL );
206
+ expect_assert_failure( finalize_match_table() );
207
+ }
208
+
209
+
210
+ static void
211
+ test_insert_match_entry_dies_if_not_initialized() {
212
+ assert_true( _match_table_head == NULL );
213
+ struct ofp_match alice;
214
+ set_alice_match_entry( &alice );
215
+ void *data = xstrdup( ALICE_MATCH_SERVICE_NAME );
216
+ expect_assert_failure( insert_match_entry( alice, DEFAULT_PRIORITY, data ) );
217
+ XFREE( data );
218
+ }
219
+
220
+
221
+ static void
222
+ test_lookup_match_strict_entry_dies_if_not_initialized() {
223
+ assert_true( _match_table_head == NULL );
224
+ struct ofp_match alice;
225
+ set_alice_match_entry( &alice );
226
+ expect_assert_failure( lookup_match_strict_entry( alice, DEFAULT_PRIORITY ) );
227
+ }
228
+
229
+
230
+ static void
231
+ test_lookup_match_entry_dies_if_not_initialized() {
232
+ assert_true( _match_table_head == NULL );
233
+ struct ofp_match alice;
234
+ set_alice_match_entry( &alice );
235
+ expect_assert_failure( lookup_match_entry( alice ) );
236
+ }
237
+
238
+
239
+ static void
240
+ test_update_match_entry_dies_if_not_initialized() {
241
+ assert_true( _match_table_head == NULL );
242
+ struct ofp_match alice;
243
+ set_alice_match_entry( &alice );
244
+ void *data = xstrdup( ALICE_MATCH_SERVICE_NAME );
245
+ expect_assert_failure( update_match_entry( alice, DEFAULT_PRIORITY, data ) );
246
+ XFREE( data );
247
+ }
248
+
249
+
250
+ static void
251
+ test_delete_match_strict_entry_dies_if_not_initialized() {
252
+ assert_true( _match_table_head == NULL );
253
+ struct ofp_match alice;
254
+ set_alice_match_entry( &alice );
255
+ expect_assert_failure( delete_match_strict_entry( alice, DEFAULT_PRIORITY ) );
256
+ }
257
+
258
+
259
+ static void
260
+ test_foreach_match_entry_dies_if_not_initialized_helper( struct ofp_match match, uint16_t priority, void *data, void *user_data ) {
261
+ UNUSED( match );
262
+ UNUSED( priority );
263
+ UNUSED( data );
264
+ UNUSED( user_data );
265
+ assert_true( false );
266
+ }
267
+
268
+
269
+ static void
270
+ test_foreach_match_entry_dies_if_not_initialized() {
271
+ assert_true( _match_table_head == NULL );
272
+ expect_assert_failure( foreach_match_table( test_foreach_match_entry_dies_if_not_initialized_helper, NULL ) );
273
+ }
274
+
275
+
276
+ /*************************************************************************
277
+ * insert, lookup and delete entry tests.
278
+ *************************************************************************/
279
+
280
+ // insert, lookup and delete exact entry tests.
281
+
282
+ static void
283
+ test_insert_exact_entry_into_empty_table_succeeds() {
284
+ struct ofp_match alice;
285
+ set_alice_match_entry( &alice );
286
+ assert_true( insert_match_entry( alice, DEFAULT_PRIORITY, xstrdup( ALICE_MATCH_SERVICE_NAME ) ) );
287
+
288
+ void *data0 = lookup_match_strict_entry( alice, DEFAULT_PRIORITY );
289
+ assert_true( data0 != NULL );
290
+ assert_string_equal( ( char * ) data0, ALICE_MATCH_SERVICE_NAME );
291
+ void *data1 = lookup_match_entry( alice );
292
+ assert_true( data1 != NULL );
293
+ assert_string_equal( ( char * ) data1, ALICE_MATCH_SERVICE_NAME );
294
+ assert_true( data0 == data1 );
295
+ void *data2 = delete_match_strict_entry( alice, DEFAULT_PRIORITY );
296
+ assert_true( data2 != NULL );
297
+ assert_string_equal( ( char * ) data2, ALICE_MATCH_SERVICE_NAME );
298
+ assert_true( data1 == data2 );
299
+ XFREE( data2 );
300
+ }
301
+
302
+
303
+ static void
304
+ test_insert_exact_entry_into_not_empty_exact_table_succeeds() {
305
+ struct ofp_match alice;
306
+ set_alice_match_entry( &alice );
307
+ assert_true( insert_match_entry( alice, DEFAULT_PRIORITY, xstrdup( ALICE_MATCH_SERVICE_NAME ) ) );
308
+
309
+ struct ofp_match bob;
310
+ set_bob_match_entry( &bob );
311
+ assert_true( insert_match_entry( bob, DEFAULT_PRIORITY, xstrdup( BOB_MATCH_SERVICE_NAME ) ) );
312
+
313
+ void *data0 = lookup_match_strict_entry( bob, DEFAULT_PRIORITY );
314
+ assert_true( data0 != NULL );
315
+ assert_string_equal( ( char * ) data0, BOB_MATCH_SERVICE_NAME );
316
+ void *data1 = lookup_match_entry( bob );
317
+ assert_true( data1 != NULL );
318
+ assert_string_equal( ( char * ) data1, BOB_MATCH_SERVICE_NAME );
319
+ assert_true( data0 == data1 );
320
+
321
+ struct ofp_match carol;
322
+ set_carol_match_entry( &carol );
323
+ assert_true( insert_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
324
+
325
+ data0 = lookup_match_strict_entry( carol, DEFAULT_PRIORITY );
326
+ assert_true( data0 != NULL );
327
+ assert_string_equal( ( char * ) data0, CAROL_MATCH_SERVICE_NAME );
328
+ data1 = lookup_match_entry( carol );
329
+ assert_true( data1 != NULL );
330
+ assert_string_equal( ( char * ) data1, CAROL_MATCH_SERVICE_NAME );
331
+ assert_true( data0 == data1 );
332
+
333
+ XFREE( delete_match_strict_entry( alice, DEFAULT_PRIORITY ) );
334
+ XFREE( delete_match_strict_entry( bob, DEFAULT_PRIORITY ) );
335
+ XFREE( delete_match_strict_entry( carol, DEFAULT_PRIORITY ) );
336
+ }
337
+
338
+
339
+ static void
340
+ test_insert_existing_exact_entry_fails() {
341
+ struct ofp_match carol;
342
+ set_carol_match_entry( &carol );
343
+ assert_true( insert_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
344
+ assert_true( !insert_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
345
+
346
+ void *data = lookup_match_entry( carol );
347
+ assert_true( data != NULL );
348
+ assert_string_equal( ( char * ) data, CAROL_MATCH_SERVICE_NAME );
349
+ XFREE( delete_match_strict_entry( carol, DEFAULT_PRIORITY ) );
350
+ }
351
+
352
+
353
+ static void
354
+ test_insert_different_priority_exact_entry_fails() {
355
+ struct ofp_match carol;
356
+ set_carol_match_entry( &carol );
357
+ assert_true( insert_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
358
+ assert_true( !insert_match_entry( carol, DEFAULT_PRIORITY + 1, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
359
+
360
+ void *data = lookup_match_entry( carol );
361
+ assert_true( data != NULL );
362
+ assert_string_equal( ( char * ) data, CAROL_MATCH_SERVICE_NAME );
363
+ XFREE( delete_match_strict_entry( carol, DEFAULT_PRIORITY ) );
364
+ }
365
+
366
+
367
+ static void
368
+ test_reinsert_of_deleted_exact_entry_succeeds() {
369
+ struct ofp_match carol;
370
+ set_carol_match_entry( &carol );
371
+ assert_true( insert_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
372
+ XFREE( delete_match_strict_entry( carol, DEFAULT_PRIORITY ) );
373
+ void *data = lookup_match_strict_entry( carol, DEFAULT_PRIORITY );
374
+ assert_true( data == NULL );
375
+ data = lookup_match_entry( carol );
376
+ assert_true( data == NULL );
377
+ assert_true( insert_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
378
+
379
+ data = lookup_match_entry( carol );
380
+ assert_true( data != NULL );
381
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
382
+ XFREE( delete_match_strict_entry( carol, DEFAULT_PRIORITY ) );
383
+ }
384
+
385
+
386
+ // insert, lookup and delete wildcards entry tests.
387
+
388
+ static void
389
+ test_insert_wildcards_entry_into_empty_table_succeeds() {
390
+ struct ofp_match alice;
391
+ set_alice_match_entry( &alice );
392
+ struct ofp_match alice_wildcards;
393
+ set_alice_wildcards_entry( &alice_wildcards );
394
+ assert_true( insert_match_entry( alice_wildcards, DEFAULT_PRIORITY, xstrdup( ALICE_MATCH_SERVICE_NAME ) ) );
395
+
396
+ struct ofp_match bob;
397
+ set_bob_match_entry( &bob );
398
+
399
+ void *data0 = lookup_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY );
400
+ assert_true( data0 != NULL );
401
+ assert_string_equal( ( char * ) data0, ALICE_MATCH_SERVICE_NAME );
402
+ void *data1 = lookup_match_entry( alice );
403
+ assert_true( data1 != NULL );
404
+ assert_string_equal( ( char * ) data1, ALICE_MATCH_SERVICE_NAME );
405
+ assert_true( data0 == data1 );
406
+ assert_true( lookup_match_entry( bob ) == NULL );
407
+ void *data2 = delete_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY );
408
+ assert_true( data2 != NULL );
409
+ assert_string_equal( ( char * ) data2, ALICE_MATCH_SERVICE_NAME );
410
+ assert_true( data1 == data2 );
411
+ XFREE( data2 );
412
+ }
413
+
414
+
415
+ static void
416
+ test_insert_wildcards_entry_into_not_empty_exact_table_succeeds() {
417
+ struct ofp_match alice_wildcards;
418
+ set_alice_wildcards_entry( &alice_wildcards );
419
+ assert_true( insert_match_entry( alice_wildcards, DEFAULT_PRIORITY, xstrdup( ALICE_MATCH_SERVICE_NAME ) ) );
420
+
421
+ struct ofp_match bob;
422
+ set_bob_match_entry( &bob );
423
+ struct ofp_match bob_wildcards;
424
+ set_bob_wildcards_entry( &bob_wildcards );
425
+ assert_true( insert_match_entry( bob_wildcards, DEFAULT_PRIORITY + 1, xstrdup( BOB_MATCH_SERVICE_NAME ) ) );
426
+
427
+ void *data0 = lookup_match_strict_entry( bob_wildcards, DEFAULT_PRIORITY + 1 );
428
+ assert_true( data0 != NULL );
429
+ assert_string_equal( ( char * ) data0, BOB_MATCH_SERVICE_NAME );
430
+ void *data1 = lookup_match_entry( bob );
431
+ assert_true( data1 != NULL );
432
+ assert_string_equal( ( char * ) data1, BOB_MATCH_SERVICE_NAME );
433
+ assert_true( data0 == data1 );
434
+
435
+ struct ofp_match carol;
436
+ set_carol_match_entry( &carol );
437
+ struct ofp_match carol_wildcards;
438
+ set_carol_wildcards_entry( &carol_wildcards );
439
+ assert_true( insert_match_entry( carol_wildcards, DEFAULT_PRIORITY - 1, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
440
+
441
+ data0 = lookup_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY - 1 );
442
+ assert_true( data0 != NULL );
443
+ assert_string_equal( ( char * ) data0, CAROL_MATCH_SERVICE_NAME );
444
+ data1 = lookup_match_entry( carol );
445
+ assert_true( data1 != NULL );
446
+ assert_string_equal( ( char * ) data1, CAROL_MATCH_SERVICE_NAME );
447
+ assert_true( data0 == data1 );
448
+
449
+ XFREE( delete_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY ) );
450
+ XFREE( delete_match_strict_entry( bob_wildcards, DEFAULT_PRIORITY + 1 ) );
451
+ XFREE( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY - 1 ) );
452
+ }
453
+
454
+
455
+ static void
456
+ test_insert_existing_same_priority_wildcards_entry_succeeds() {
457
+ struct ofp_match alice;
458
+ set_alice_match_entry( &alice );
459
+ struct ofp_match alice_wildcards;
460
+ set_alice_wildcards_entry( &alice_wildcards );
461
+ assert_true( insert_match_entry( alice_wildcards, DEFAULT_PRIORITY, xstrdup( ALICE_MATCH_SERVICE_NAME ) ) );
462
+
463
+ struct ofp_match bob;
464
+ set_bob_match_entry( &bob );
465
+ struct ofp_match bob_wildcards;
466
+ set_bob_wildcards_entry( &bob_wildcards );
467
+ assert_true( insert_match_entry( bob_wildcards, DEFAULT_PRIORITY, xstrdup( BOB_MATCH_SERVICE_NAME ) ) );
468
+
469
+ void *data0 = lookup_match_strict_entry( bob_wildcards, DEFAULT_PRIORITY );
470
+ assert_true( data0 != NULL );
471
+ assert_string_equal( ( char * ) data0, BOB_MATCH_SERVICE_NAME );
472
+ void *data1 = lookup_match_entry( bob );
473
+ assert_true( data1 != NULL );
474
+ assert_string_equal( ( char * ) data1, BOB_MATCH_SERVICE_NAME );
475
+ assert_true( data0 == data1 );
476
+
477
+ struct ofp_match any_wildcards;
478
+ set_any_wildcards_entry( &any_wildcards );
479
+ assert_true( insert_match_entry( any_wildcards, DEFAULT_PRIORITY, xstrdup( ANY_MATCH_SERVICE_NAME ) ) );
480
+
481
+ struct ofp_match carol;
482
+ set_carol_match_entry( &carol );
483
+ struct ofp_match carol_wildcards;
484
+ set_carol_wildcards_entry( &carol_wildcards );
485
+ assert_true( insert_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
486
+
487
+ data0 = lookup_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY );
488
+ assert_true( data0 != NULL );
489
+ assert_string_equal( ( char * ) data0, CAROL_MATCH_SERVICE_NAME );
490
+ data1 = lookup_match_entry( carol );
491
+ assert_true( data1 != NULL );
492
+ assert_string_equal( ( char * ) data1, ANY_MATCH_SERVICE_NAME );
493
+ assert_true( data0 != data1 );
494
+
495
+ data1 = lookup_match_entry( alice );
496
+ assert_true( data1 != NULL );
497
+ assert_string_equal( ( char * ) data1, ALICE_MATCH_SERVICE_NAME );
498
+ data1 = lookup_match_entry( bob );
499
+ assert_true( data1 != NULL );
500
+ assert_string_equal( ( char * ) data1, BOB_MATCH_SERVICE_NAME );
501
+
502
+ XFREE( delete_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY ) );
503
+ XFREE( delete_match_strict_entry( bob_wildcards, DEFAULT_PRIORITY ) );
504
+ XFREE( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) );
505
+ XFREE( delete_match_strict_entry( any_wildcards, DEFAULT_PRIORITY ) );
506
+ }
507
+
508
+
509
+ static void
510
+ test_insert_existing_same_match_same_priority_wildcards_entry_fails() {
511
+ struct ofp_match carol;
512
+ set_carol_match_entry( &carol );
513
+ struct ofp_match carol_wildcards;
514
+ set_carol_wildcards_entry( &carol_wildcards );
515
+ assert_true( insert_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
516
+ assert_true( !insert_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
517
+
518
+ void *data = lookup_match_entry( carol );
519
+ assert_true( data != NULL );
520
+ assert_string_equal( ( char * ) data, CAROL_MATCH_SERVICE_NAME );
521
+ XFREE( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) );
522
+ }
523
+
524
+
525
+ static void
526
+ test_insert_different_priority_wildcards_entry_succeeds() {
527
+ struct ofp_match carol;
528
+ set_carol_match_entry( &carol );
529
+ struct ofp_match carol_wildcards;
530
+ set_carol_wildcards_entry( &carol_wildcards );
531
+ assert_true( insert_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
532
+
533
+ assert_true( insert_match_entry( carol_wildcards, DEFAULT_PRIORITY + 1, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
534
+
535
+ void *data = lookup_match_entry( carol );
536
+ assert_true( data != NULL );
537
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
538
+ XFREE( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) );
539
+ XFREE( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY + 1 ) );
540
+ }
541
+
542
+
543
+ static void
544
+ test_insert_highest_priority_wildcards_entry_succeeds() {
545
+ struct ofp_match alice;
546
+ set_alice_match_entry( &alice );
547
+ struct ofp_match alice_wildcards;
548
+ set_alice_wildcards_entry( &alice_wildcards );
549
+ assert_true( insert_match_entry( alice_wildcards, DEFAULT_PRIORITY, xstrdup( ALICE_MATCH_SERVICE_NAME ) ) );
550
+
551
+ struct ofp_match bob_wildcards;
552
+ set_bob_wildcards_entry( &bob_wildcards );
553
+ assert_true( insert_match_entry( bob_wildcards, HIGH_PRIORITY, xstrdup( BOB_MATCH_SERVICE_NAME ) ) );
554
+
555
+ void *data0 = lookup_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY );
556
+ assert_true( data0 != NULL );
557
+ assert_string_equal( ( char * ) data0, ALICE_MATCH_SERVICE_NAME );
558
+ void *data1 = lookup_match_entry( alice );
559
+ assert_true( data1 != NULL );
560
+ assert_string_equal( ( char * ) data1, ALICE_MATCH_SERVICE_NAME );
561
+ assert_true( data0 == data1 );
562
+
563
+ struct ofp_match lldp_wildcards;
564
+ set_lldp_wildcards_entry( &lldp_wildcards );
565
+ assert_true( insert_match_entry( lldp_wildcards, HIGH_PRIORITY, xstrdup( LLDP_MATCH_SERVICE_NAME ) ) );
566
+
567
+ data0 = lookup_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY );
568
+ assert_true( data0 != NULL );
569
+ assert_string_equal( ( char * ) data0, ALICE_MATCH_SERVICE_NAME );
570
+ data1 = lookup_match_entry( alice );
571
+ assert_true( data1 != NULL );
572
+ assert_string_equal( ( char * ) data1, ALICE_MATCH_SERVICE_NAME );
573
+ assert_true( data0 == data1 );
574
+
575
+ struct ofp_match any_wildcards;
576
+ set_any_wildcards_entry( &any_wildcards );
577
+ assert_true( insert_match_entry( any_wildcards, HIGH_PRIORITY, xstrdup( ANY_MATCH_SERVICE_NAME ) ) );
578
+
579
+ data0 = lookup_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY );
580
+ assert_true( data0 != NULL );
581
+ assert_string_equal( ( char * ) data0, ALICE_MATCH_SERVICE_NAME );
582
+ data1 = lookup_match_entry( alice );
583
+ assert_true( data1 != NULL );
584
+ assert_string_equal( ( char * ) data1, ANY_MATCH_SERVICE_NAME );
585
+ assert_true( data0 != data1 );
586
+
587
+ XFREE( delete_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY ) );
588
+ XFREE( delete_match_strict_entry( bob_wildcards, HIGH_PRIORITY ) );
589
+ XFREE( delete_match_strict_entry( lldp_wildcards, HIGH_PRIORITY ) );
590
+ XFREE( delete_match_strict_entry( any_wildcards, HIGH_PRIORITY ) );
591
+ }
592
+
593
+
594
+ static void
595
+ test_insert_lowest_priority_wildcards_entry_succeeds() {
596
+ struct ofp_match alice;
597
+ set_alice_match_entry( &alice );
598
+ struct ofp_match alice_wildcards;
599
+ set_alice_wildcards_entry( &alice_wildcards );
600
+ assert_true( insert_match_entry( alice_wildcards, DEFAULT_PRIORITY, xstrdup( ALICE_MATCH_SERVICE_NAME ) ) );
601
+
602
+ struct ofp_match bob_wildcards;
603
+ set_bob_wildcards_entry( &bob_wildcards );
604
+ assert_true( insert_match_entry( bob_wildcards, LOW_PRIORITY, xstrdup( BOB_MATCH_SERVICE_NAME ) ) );
605
+
606
+ void *data0 = lookup_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY );
607
+ assert_true( data0 != NULL );
608
+ assert_string_equal( ( char * ) data0, ALICE_MATCH_SERVICE_NAME );
609
+ void *data1 = lookup_match_entry( alice );
610
+ assert_true( data1 != NULL );
611
+ assert_string_equal( ( char * ) data1, ALICE_MATCH_SERVICE_NAME );
612
+ assert_true( data0 == data1 );
613
+
614
+ struct ofp_match lldp_wildcards;
615
+ set_lldp_wildcards_entry( &lldp_wildcards );
616
+ assert_true( insert_match_entry( lldp_wildcards, LOW_PRIORITY, xstrdup( LLDP_MATCH_SERVICE_NAME ) ) );
617
+
618
+ data0 = lookup_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY );
619
+ assert_true( data0 != NULL );
620
+ assert_string_equal( ( char * ) data0, ALICE_MATCH_SERVICE_NAME );
621
+ data1 = lookup_match_entry( alice );
622
+ assert_true( data1 != NULL );
623
+ assert_string_equal( ( char * ) data1, ALICE_MATCH_SERVICE_NAME );
624
+ assert_true( data0 == data1 );
625
+
626
+ struct ofp_match any_wildcards;
627
+ set_any_wildcards_entry( &any_wildcards );
628
+ assert_true( insert_match_entry( any_wildcards, LOW_PRIORITY, xstrdup( ANY_MATCH_SERVICE_NAME ) ) );
629
+
630
+ data0 = lookup_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY );
631
+ assert_true( data0 != NULL );
632
+ assert_string_equal( ( char * ) data0, ALICE_MATCH_SERVICE_NAME );
633
+ data1 = lookup_match_entry( alice );
634
+ assert_true( data1 != NULL );
635
+ assert_string_equal( ( char * ) data1, ALICE_MATCH_SERVICE_NAME );
636
+ assert_true( data0 == data1 );
637
+
638
+ XFREE( delete_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY ) );
639
+ XFREE( delete_match_strict_entry( bob_wildcards, LOW_PRIORITY ) );
640
+ XFREE( delete_match_strict_entry( lldp_wildcards, LOW_PRIORITY ) );
641
+ XFREE( delete_match_strict_entry( any_wildcards, LOW_PRIORITY ) );
642
+ }
643
+
644
+
645
+ static void
646
+ test_reinsert_of_deleted_wildcards_entry_succeeds() {
647
+ struct ofp_match carol;
648
+ set_carol_match_entry( &carol );
649
+ struct ofp_match carol_wildcards;
650
+ set_carol_wildcards_entry( &carol_wildcards );
651
+ assert_true( insert_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
652
+ XFREE( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) );
653
+ void *data = lookup_match_strict_entry( carol, DEFAULT_PRIORITY );
654
+ assert_true( data == NULL );
655
+ data = lookup_match_entry( carol );
656
+ assert_true( data == NULL );
657
+ assert_true( insert_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
658
+
659
+ data = lookup_match_entry( carol );
660
+ assert_true( data != NULL );
661
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
662
+ XFREE( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) );
663
+ }
664
+
665
+
666
+ static void
667
+ test_reinsert_of_deleted_highest_priority_wildcards_entry_succeeds() {
668
+ struct ofp_match carol;
669
+ set_carol_match_entry( &carol );
670
+ struct ofp_match carol_wildcards;
671
+ set_carol_wildcards_entry( &carol_wildcards );
672
+ assert_true( insert_match_entry( carol_wildcards, HIGH_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
673
+ XFREE( delete_match_strict_entry( carol_wildcards, HIGH_PRIORITY ) );
674
+ void *data = lookup_match_strict_entry( carol, HIGH_PRIORITY );
675
+ assert_true( data == NULL );
676
+ data = lookup_match_entry( carol );
677
+ assert_true( data == NULL );
678
+ assert_true( insert_match_entry( carol_wildcards, HIGH_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
679
+
680
+ data = lookup_match_entry( carol );
681
+ assert_true( data != NULL );
682
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
683
+ XFREE( delete_match_strict_entry( carol_wildcards, HIGH_PRIORITY ) );
684
+ }
685
+
686
+
687
+ static void
688
+ test_reinsert_of_deleted_lowhest_priority_wildcards_entry_succeeds() {
689
+ struct ofp_match carol;
690
+ set_carol_match_entry( &carol );
691
+ struct ofp_match carol_wildcards;
692
+ set_carol_wildcards_entry( &carol_wildcards );
693
+ assert_true( insert_match_entry( carol_wildcards, LOW_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
694
+ XFREE( delete_match_strict_entry( carol_wildcards, LOW_PRIORITY ) );
695
+ void *data = lookup_match_strict_entry( carol, LOW_PRIORITY );
696
+ assert_true( data == NULL );
697
+ data = lookup_match_entry( carol );
698
+ assert_true( data == NULL );
699
+ assert_true( insert_match_entry( carol_wildcards, LOW_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
700
+
701
+ data = lookup_match_entry( carol );
702
+ assert_true( data != NULL );
703
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
704
+ XFREE( delete_match_strict_entry( carol_wildcards, LOW_PRIORITY ) );
705
+ }
706
+
707
+
708
+ /*************************************************************************
709
+ * update, lookup and delete entry tests.
710
+ *************************************************************************/
711
+
712
+ // update, lookup and delete exact entry tests.
713
+
714
+ static void
715
+ test_update_exact_entry_succeeds() {
716
+ struct ofp_match carol;
717
+ set_carol_match_entry( &carol );
718
+ assert_true( insert_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
719
+ void *data = lookup_match_strict_entry( carol, DEFAULT_PRIORITY );
720
+ assert_true( data != NULL );
721
+ assert_string_equal( ( char * ) data, CAROL_MATCH_SERVICE_NAME );
722
+ data = lookup_match_entry( carol );
723
+ assert_true( data != NULL );
724
+ assert_string_equal( ( char * ) data, CAROL_MATCH_SERVICE_NAME );
725
+
726
+ assert_true( update_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
727
+
728
+ data = lookup_match_strict_entry( carol, DEFAULT_PRIORITY );
729
+ assert_true( data != NULL );
730
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
731
+ data = lookup_match_entry( carol );
732
+ assert_true( data != NULL );
733
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
734
+
735
+ assert_true( update_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
736
+
737
+ data = lookup_match_strict_entry( carol, DEFAULT_PRIORITY );
738
+ assert_true( data != NULL );
739
+ assert_string_equal( ( char * ) data, CAROL_MATCH_SERVICE_NAME );
740
+ data = lookup_match_entry( carol );
741
+ assert_true( data != NULL );
742
+ assert_string_equal( ( char * ) data, CAROL_MATCH_SERVICE_NAME );
743
+
744
+ XFREE( delete_match_strict_entry( carol, DEFAULT_PRIORITY ) );
745
+ }
746
+
747
+
748
+ static void
749
+ test_update_nonexistent_exact_entry_fails() {
750
+ struct ofp_match carol;
751
+ set_carol_match_entry( &carol );
752
+ assert_true( !update_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
753
+
754
+ struct ofp_match alice;
755
+ set_alice_match_entry( &alice );
756
+ assert_true( insert_match_entry( alice, DEFAULT_PRIORITY, xstrdup( ALICE_MATCH_SERVICE_NAME ) ) );
757
+
758
+ assert_true( !update_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
759
+
760
+ void *data = lookup_match_strict_entry( carol, DEFAULT_PRIORITY );
761
+ assert_true( data == NULL );
762
+ data = lookup_match_entry( carol );
763
+ assert_true( data == NULL );
764
+
765
+ XFREE( delete_match_strict_entry( alice, DEFAULT_PRIORITY ) );
766
+ }
767
+
768
+
769
+ static void
770
+ test_update_different_priority_exact_entry_succeeds() {
771
+ struct ofp_match carol;
772
+ set_carol_match_entry( &carol );
773
+ assert_true( insert_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
774
+ assert_true( update_match_entry( carol, DEFAULT_PRIORITY + 1, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
775
+
776
+ void *data = lookup_match_entry( carol );
777
+ assert_true( data != NULL );
778
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
779
+ XFREE( delete_match_strict_entry( carol, DEFAULT_PRIORITY ) );
780
+ }
781
+
782
+
783
+ static void
784
+ test_update_of_deleted_exact_entry_fails() {
785
+ struct ofp_match carol;
786
+ set_carol_match_entry( &carol );
787
+ assert_true( insert_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
788
+ XFREE( delete_match_strict_entry( carol, DEFAULT_PRIORITY ) );
789
+
790
+ assert_true( !update_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
791
+
792
+ void *data = lookup_match_strict_entry( carol, DEFAULT_PRIORITY );
793
+ assert_true( data == NULL );
794
+ data = lookup_match_entry( carol );
795
+ assert_true( data == NULL );
796
+ }
797
+
798
+ // update, lookup and delete wildcards entry tests.
799
+
800
+ static void
801
+ test_update_exact_wildcards_succeeds() {
802
+ struct ofp_match carol;
803
+ set_carol_match_entry( &carol );
804
+ struct ofp_match carol_wildcards;
805
+ set_carol_wildcards_entry( &carol_wildcards );
806
+ assert_true( insert_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
807
+ void *data = lookup_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY );
808
+ assert_true( data != NULL );
809
+ assert_string_equal( ( char * ) data, CAROL_MATCH_SERVICE_NAME );
810
+ data = lookup_match_entry( carol );
811
+ assert_true( data != NULL );
812
+ assert_string_equal( ( char * ) data, CAROL_MATCH_SERVICE_NAME );
813
+
814
+ assert_true( update_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
815
+
816
+ data = lookup_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY );
817
+ assert_true( data != NULL );
818
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
819
+ data = lookup_match_entry( carol );
820
+ assert_true( data != NULL );
821
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
822
+
823
+ assert_true( update_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
824
+
825
+ data = lookup_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY );
826
+ assert_true( data != NULL );
827
+ assert_string_equal( ( char * ) data, CAROL_MATCH_SERVICE_NAME );
828
+ data = lookup_match_entry( carol );
829
+ assert_true( data != NULL );
830
+ assert_string_equal( ( char * ) data, CAROL_MATCH_SERVICE_NAME );
831
+
832
+ XFREE( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) );
833
+ }
834
+
835
+
836
+ static void
837
+ test_update_nonexistent_wildcards_entry_fails() {
838
+ struct ofp_match carol;
839
+ set_carol_match_entry( &carol );
840
+ struct ofp_match carol_wildcards;
841
+ set_carol_wildcards_entry( &carol_wildcards );
842
+ assert_true( !update_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
843
+
844
+ struct ofp_match alice_wildcards;
845
+ set_alice_match_entry( &alice_wildcards );
846
+ assert_true( insert_match_entry( alice_wildcards, DEFAULT_PRIORITY, xstrdup( ALICE_MATCH_SERVICE_NAME ) ) );
847
+
848
+ assert_true( !update_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
849
+
850
+ void *data = lookup_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY );
851
+ assert_true( data == NULL );
852
+ data = lookup_match_entry( carol );
853
+ assert_true( data == NULL );
854
+
855
+ XFREE( delete_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY ) );
856
+ }
857
+
858
+
859
+ static void
860
+ test_update_of_deleted_wildcards_entry_fails() {
861
+ struct ofp_match carol;
862
+ set_carol_match_entry( &carol );
863
+ struct ofp_match carol_wildcards;
864
+ set_carol_wildcards_entry( &carol_wildcards );
865
+ assert_true( insert_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
866
+ XFREE( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) );
867
+
868
+ assert_true( !update_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
869
+
870
+ void *data = lookup_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY );
871
+ assert_true( data == NULL );
872
+ data = lookup_match_entry( carol );
873
+ assert_true( data == NULL );
874
+ }
875
+
876
+
877
+ static void
878
+ test_update_different_priority_wildcards_entry_fails() {
879
+ struct ofp_match carol;
880
+ set_carol_match_entry( &carol );
881
+ struct ofp_match carol_wildcards;
882
+ set_carol_wildcards_entry( &carol_wildcards );
883
+ assert_true( insert_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
884
+
885
+ assert_true( !update_match_entry( carol_wildcards, DEFAULT_PRIORITY + 1, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
886
+
887
+ XFREE( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) );
888
+ }
889
+
890
+
891
+ /*************************************************************************
892
+ * delete entry tests.
893
+ *************************************************************************/
894
+
895
+ // delete exact entry tests.
896
+
897
+ static void
898
+ test_delete_nonexistent_exact_entry_fails() {
899
+ struct ofp_match carol;
900
+ set_carol_match_entry( &carol );
901
+ assert_true( delete_match_strict_entry( carol, DEFAULT_PRIORITY ) == NULL );
902
+
903
+ struct ofp_match alice;
904
+ set_alice_match_entry( &alice );
905
+ assert_true( insert_match_entry( alice, DEFAULT_PRIORITY, xstrdup( ALICE_MATCH_SERVICE_NAME ) ) );
906
+
907
+ assert_true( delete_match_strict_entry( carol, DEFAULT_PRIORITY ) == NULL );
908
+
909
+ XFREE( delete_match_strict_entry( alice, DEFAULT_PRIORITY ) );
910
+ }
911
+
912
+
913
+ static void
914
+ test_delete_different_priority_exact_entry_succeeds() {
915
+ struct ofp_match carol;
916
+ set_carol_match_entry( &carol );
917
+ assert_true( insert_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
918
+ XFREE( delete_match_strict_entry( carol, DEFAULT_PRIORITY + 1 ) );
919
+ }
920
+
921
+
922
+ static void
923
+ test_delete_of_deleted_exact_entry_fails() {
924
+ struct ofp_match carol;
925
+ set_carol_match_entry( &carol );
926
+ assert_true( insert_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
927
+ XFREE( delete_match_strict_entry( carol, DEFAULT_PRIORITY ) );
928
+
929
+ assert_true( delete_match_strict_entry( carol, DEFAULT_PRIORITY ) == NULL );
930
+ }
931
+
932
+ // delete wildcards entry tests.
933
+
934
+ static void
935
+ test_delete_nonexistent_wildcards_entry_fails() {
936
+ struct ofp_match carol;
937
+ set_carol_match_entry( &carol );
938
+ struct ofp_match carol_wildcards;
939
+ set_carol_wildcards_entry( &carol_wildcards );
940
+ assert_true( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) == NULL );
941
+
942
+ struct ofp_match alice_wildcards;
943
+ set_alice_match_entry( &alice_wildcards );
944
+ assert_true( insert_match_entry( alice_wildcards, DEFAULT_PRIORITY, xstrdup( ALICE_MATCH_SERVICE_NAME ) ) );
945
+
946
+ assert_true( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) == NULL );
947
+
948
+ XFREE( delete_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY ) );
949
+ }
950
+
951
+
952
+ static void
953
+ test_delete_of_deleted_wildcards_entry_fails() {
954
+ struct ofp_match carol;
955
+ set_carol_match_entry( &carol );
956
+ struct ofp_match carol_wildcards;
957
+ set_carol_wildcards_entry( &carol_wildcards );
958
+ assert_true( insert_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
959
+ XFREE( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) );
960
+
961
+ assert_true( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) == NULL );
962
+ }
963
+
964
+
965
+ static void
966
+ test_delete_different_priority_wildcards_entry_fails() {
967
+ struct ofp_match carol;
968
+ set_carol_match_entry( &carol );
969
+ struct ofp_match carol_wildcards;
970
+ set_carol_wildcards_entry( &carol_wildcards );
971
+ assert_true( insert_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
972
+
973
+ assert_true( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY + 1 ) == NULL );
974
+
975
+ XFREE( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) );
976
+ }
977
+
978
+
979
+ /*************************************************************************
980
+ * foreach entry tests.
981
+ *************************************************************************/
982
+
983
+ static void
984
+ test_foreach_match_entry_dies_if_function_is_null() {
985
+ expect_assert_failure( foreach_match_table( NULL, NULL ) );
986
+ }
987
+
988
+
989
+ static void
990
+ test_foreach_entry_if_empty_table_helper( struct ofp_match match, uint16_t priority, void *data, void *user_data ) {
991
+ UNUSED( match );
992
+ UNUSED( priority );
993
+ UNUSED( data );
994
+ UNUSED( user_data );
995
+ assert_true( false );
996
+ }
997
+
998
+
999
+ static void
1000
+ test_foreach_entry_if_empty_table() {
1001
+ foreach_match_table( test_foreach_entry_if_empty_table_helper, NULL );
1002
+ }
1003
+
1004
+
1005
+ static int count = 0;
1006
+
1007
+
1008
+ static void
1009
+ test_foreach_entry_if_exact_table_only_helper( struct ofp_match match, uint16_t priority, void *data, void *user_data ) {
1010
+
1011
+ struct ofp_match alice;
1012
+ set_alice_match_entry( &alice );
1013
+ struct ofp_match bob;
1014
+ set_bob_match_entry( &bob );
1015
+ struct ofp_match carol;
1016
+ set_carol_match_entry( &carol );
1017
+
1018
+ assert_true( priority == 0 );
1019
+
1020
+ switch ( ++count ) {
1021
+ case 3:
1022
+ assert_string_equal( ( char * ) data, ALICE_MATCH_SERVICE_NAME );
1023
+ assert_memory_equal( &match, &alice, sizeof( struct ofp_match ) );
1024
+ break;
1025
+ case 2:
1026
+ assert_string_equal( ( char * ) data, BOB_MATCH_SERVICE_NAME );
1027
+ assert_memory_equal( &match, &bob, sizeof( struct ofp_match ) );
1028
+ break;
1029
+ case 1:
1030
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
1031
+ assert_memory_equal( &match, &carol, sizeof( struct ofp_match ) );
1032
+ break;
1033
+ default:
1034
+ assert_true( false );
1035
+ break;
1036
+ }
1037
+ assert_string_equal( ( char * ) user_data, USER_DATA );
1038
+ }
1039
+
1040
+
1041
+ static void
1042
+ add_all_exact_entry() {
1043
+ struct ofp_match alice;
1044
+ set_alice_match_entry( &alice );
1045
+ assert_true( insert_match_entry( alice, DEFAULT_PRIORITY, xstrdup( ALICE_MATCH_SERVICE_NAME ) ) );
1046
+ struct ofp_match bob;
1047
+ set_bob_match_entry( &bob );
1048
+ assert_true( insert_match_entry( bob, DEFAULT_PRIORITY, xstrdup( BOB_MATCH_SERVICE_NAME ) ) );
1049
+ struct ofp_match carol;
1050
+ set_carol_match_entry( &carol );
1051
+ assert_true( insert_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
1052
+ assert_true( update_match_entry( carol, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
1053
+ }
1054
+
1055
+
1056
+ static void
1057
+ delete_all_exact_entry() {
1058
+ struct ofp_match alice;
1059
+ set_alice_match_entry( &alice );
1060
+ XFREE( delete_match_strict_entry( alice, DEFAULT_PRIORITY ) );
1061
+ struct ofp_match bob;
1062
+ set_bob_match_entry( &bob );
1063
+ XFREE( delete_match_strict_entry( bob, DEFAULT_PRIORITY ) );
1064
+ struct ofp_match carol;
1065
+ set_carol_match_entry( &carol );
1066
+ XFREE( delete_match_strict_entry( carol, DEFAULT_PRIORITY ) );
1067
+ }
1068
+
1069
+
1070
+ static void
1071
+ test_foreach_entry_if_exact_table_only() {
1072
+ add_all_exact_entry();
1073
+ char *user_data = xstrdup( USER_DATA );
1074
+ count = 0;
1075
+ foreach_match_table( test_foreach_entry_if_exact_table_only_helper, user_data );
1076
+ assert_int_equal( count, 3 );
1077
+
1078
+ delete_all_exact_entry();
1079
+ XFREE( user_data );
1080
+ }
1081
+
1082
+
1083
+ static void
1084
+ test_foreach_entry_if_wildcards_table_only_helper( struct ofp_match match, uint16_t priority, void *data, void *user_data ) {
1085
+ struct ofp_match alice_wildcards;
1086
+ set_alice_wildcards_entry( &alice_wildcards );
1087
+ struct ofp_match bob_wildcards;
1088
+ set_bob_wildcards_entry( &bob_wildcards );
1089
+ struct ofp_match carol_wildcards;
1090
+ set_carol_wildcards_entry( &carol_wildcards );
1091
+ struct ofp_match any_wildcards;
1092
+ set_any_wildcards_entry( &any_wildcards );
1093
+ struct ofp_match lldp_wildcards;
1094
+ set_lldp_wildcards_entry( &lldp_wildcards );
1095
+
1096
+
1097
+ switch ( ++count ) {
1098
+ case 2:
1099
+ assert_string_equal( ( char * ) data, ALICE_MATCH_SERVICE_NAME );
1100
+ assert_true( priority == DEFAULT_PRIORITY );
1101
+ assert_memory_equal( &match, &alice_wildcards, sizeof( struct ofp_match ) );
1102
+ break;
1103
+ case 3:
1104
+ assert_string_equal( ( char * ) data, BOB_MATCH_SERVICE_NAME );
1105
+ assert_true( priority == DEFAULT_PRIORITY );
1106
+ assert_memory_equal( &match, &bob_wildcards, sizeof( struct ofp_match ) );
1107
+ break;
1108
+ case 4:
1109
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
1110
+ assert_true( priority == DEFAULT_PRIORITY );
1111
+ assert_memory_equal( &match, &carol_wildcards, sizeof( struct ofp_match ) );
1112
+ break;
1113
+ case 5:
1114
+ assert_string_equal( ( char * ) data, ANY_MATCH_SERVICE_NAME );
1115
+ assert_true( priority == LOW_PRIORITY );
1116
+ assert_memory_equal( &match, &any_wildcards, sizeof( struct ofp_match ) );
1117
+ break;
1118
+ case 1:
1119
+ assert_string_equal( ( char * ) data, LLDP_MATCH_SERVICE_NAME );
1120
+ assert_true( priority == HIGH_PRIORITY );
1121
+ assert_memory_equal( &match, &lldp_wildcards, sizeof( struct ofp_match ) );
1122
+ break;
1123
+ default:
1124
+ assert_true( false );
1125
+ break;
1126
+ }
1127
+ assert_string_equal( ( char * ) user_data, USER_DATA );
1128
+ }
1129
+
1130
+
1131
+ static void
1132
+ add_all_wildcards_entry() {
1133
+ struct ofp_match alice_wildcards;
1134
+ set_alice_wildcards_entry( &alice_wildcards );
1135
+ assert_true( insert_match_entry( alice_wildcards, DEFAULT_PRIORITY, xstrdup( ALICE_MATCH_SERVICE_NAME ) ) );
1136
+ struct ofp_match bob_wildcards;
1137
+ set_bob_wildcards_entry( &bob_wildcards );
1138
+ assert_true( insert_match_entry( bob_wildcards, DEFAULT_PRIORITY, xstrdup( BOB_MATCH_SERVICE_NAME ) ) );
1139
+ struct ofp_match carol_wildcards;
1140
+ set_carol_wildcards_entry( &carol_wildcards );
1141
+ assert_true( insert_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_SERVICE_NAME ) ) );
1142
+ struct ofp_match any_wildcards;
1143
+ set_any_wildcards_entry( &any_wildcards );
1144
+ assert_true( insert_match_entry( any_wildcards, LOW_PRIORITY, xstrdup( ANY_MATCH_SERVICE_NAME ) ) );
1145
+ struct ofp_match lldp_wildcards;
1146
+ set_lldp_wildcards_entry( &lldp_wildcards );
1147
+ assert_true( insert_match_entry( lldp_wildcards, HIGH_PRIORITY, xstrdup( LLDP_MATCH_SERVICE_NAME ) ) );
1148
+ assert_true( update_match_entry( carol_wildcards, DEFAULT_PRIORITY, xstrdup( CAROL_MATCH_OTHER_SERVICE_NAME ) ) );
1149
+ }
1150
+
1151
+
1152
+ static void
1153
+ delete_all_wildcards_entry() {
1154
+ struct ofp_match alice_wildcards;
1155
+ set_alice_wildcards_entry( &alice_wildcards );
1156
+ XFREE( delete_match_strict_entry( alice_wildcards, DEFAULT_PRIORITY ) );
1157
+ struct ofp_match bob_wildcards;
1158
+ set_bob_wildcards_entry( &bob_wildcards );
1159
+ XFREE( delete_match_strict_entry( bob_wildcards, DEFAULT_PRIORITY ) );
1160
+ struct ofp_match carol_wildcards;
1161
+ set_carol_wildcards_entry( &carol_wildcards );
1162
+ XFREE( delete_match_strict_entry( carol_wildcards, DEFAULT_PRIORITY ) );
1163
+ struct ofp_match any_wildcards;
1164
+ set_any_wildcards_entry( &any_wildcards );
1165
+ XFREE( delete_match_strict_entry( any_wildcards, LOW_PRIORITY ) );
1166
+ struct ofp_match lldp_wildcards;
1167
+ set_lldp_wildcards_entry( &lldp_wildcards );
1168
+ XFREE( delete_match_strict_entry( lldp_wildcards, HIGH_PRIORITY ) );
1169
+ }
1170
+
1171
+
1172
+ static void
1173
+ test_foreach_entry_if_wildcards_table_only() {
1174
+ add_all_wildcards_entry();
1175
+
1176
+ char *user_data = xstrdup( USER_DATA );
1177
+ count = 0;
1178
+ foreach_match_table( test_foreach_entry_if_wildcards_table_only_helper, user_data );
1179
+ assert_int_equal( count, 5 );
1180
+
1181
+ delete_all_wildcards_entry();
1182
+ XFREE( user_data );
1183
+ }
1184
+
1185
+
1186
+ static void
1187
+ test_foreach_entry_helper( struct ofp_match match, uint16_t priority, void *data, void *user_data ) {
1188
+ struct ofp_match alice;
1189
+ set_alice_match_entry( &alice );
1190
+ struct ofp_match bob;
1191
+ set_bob_match_entry( &bob );
1192
+ struct ofp_match carol;
1193
+ set_carol_match_entry( &carol );
1194
+
1195
+ struct ofp_match alice_wildcards;
1196
+ set_alice_wildcards_entry( &alice_wildcards );
1197
+ struct ofp_match bob_wildcards;
1198
+ set_bob_wildcards_entry( &bob_wildcards );
1199
+ struct ofp_match carol_wildcards;
1200
+ set_carol_wildcards_entry( &carol_wildcards );
1201
+ struct ofp_match any_wildcards;
1202
+ set_any_wildcards_entry( &any_wildcards );
1203
+ struct ofp_match lldp_wildcards;
1204
+ set_lldp_wildcards_entry( &lldp_wildcards );
1205
+
1206
+
1207
+ switch ( ++count ) {
1208
+ case 3:
1209
+ assert_string_equal( ( char * ) data, ALICE_MATCH_SERVICE_NAME );
1210
+ assert_true( priority == 0 );
1211
+ assert_memory_equal( &match, &alice, sizeof( struct ofp_match ) );
1212
+ XFREE( data );
1213
+ break;
1214
+ case 2:
1215
+ assert_string_equal( ( char * ) data, BOB_MATCH_SERVICE_NAME );
1216
+ assert_true( priority == 0 );
1217
+ assert_memory_equal( &match, &bob, sizeof( struct ofp_match ) );
1218
+ XFREE( data );
1219
+ break;
1220
+ case 1:
1221
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
1222
+ assert_true( priority == 0 );
1223
+ assert_memory_equal( &match, &carol, sizeof( struct ofp_match ) );
1224
+ XFREE( data );
1225
+ break;
1226
+ case 5:
1227
+ assert_string_equal( ( char * ) data, ALICE_MATCH_SERVICE_NAME );
1228
+ assert_true( priority == DEFAULT_PRIORITY );
1229
+ assert_memory_equal( &match, &alice_wildcards, sizeof( struct ofp_match ) );
1230
+ XFREE( data );
1231
+ break;
1232
+ case 6:
1233
+ assert_string_equal( ( char * ) data, BOB_MATCH_SERVICE_NAME );
1234
+ assert_true( priority == DEFAULT_PRIORITY );
1235
+ assert_memory_equal( &match, &bob_wildcards, sizeof( struct ofp_match ) );
1236
+ XFREE( data );
1237
+ break;
1238
+ case 7:
1239
+ assert_string_equal( ( char * ) data, CAROL_MATCH_OTHER_SERVICE_NAME );
1240
+ assert_true( priority == DEFAULT_PRIORITY );
1241
+ assert_memory_equal( &match, &carol_wildcards, sizeof( struct ofp_match ) );
1242
+ XFREE( data );
1243
+ break;
1244
+ case 8:
1245
+ assert_string_equal( ( char * ) data, ANY_MATCH_SERVICE_NAME );
1246
+ assert_true( priority == LOW_PRIORITY );
1247
+ assert_memory_equal( &match, &any_wildcards, sizeof( struct ofp_match ) );
1248
+ XFREE( data );
1249
+ break;
1250
+ case 4:
1251
+ assert_string_equal( ( char * ) data, LLDP_MATCH_SERVICE_NAME );
1252
+ assert_true( priority == HIGH_PRIORITY );
1253
+ assert_memory_equal( &match, &lldp_wildcards, sizeof( struct ofp_match ) );
1254
+ XFREE( data );
1255
+ break;
1256
+ default:
1257
+ assert_true( false );
1258
+ break;
1259
+ }
1260
+ assert_string_equal( ( char * ) user_data, USER_DATA );
1261
+ }
1262
+
1263
+
1264
+ static void
1265
+ test_foreach_entry() {
1266
+ add_all_exact_entry();
1267
+ add_all_wildcards_entry();
1268
+
1269
+ char *user_data = xstrdup( USER_DATA );
1270
+ count = 0;
1271
+ foreach_match_table( test_foreach_entry_helper, user_data );
1272
+ assert_int_equal( count, 8 );
1273
+
1274
+ XFREE( user_data );
1275
+ }
1276
+
1277
+
1278
+ static void
1279
+ test_map_entry_if_match_set_nw_src_helper( struct ofp_match match, uint16_t priority, void *data, void *user_data ) {
1280
+ struct ofp_match alice;
1281
+ set_alice_match_entry( &alice );
1282
+
1283
+ struct ofp_match alice_wildcards;
1284
+ set_alice_wildcards_entry( &alice_wildcards );
1285
+
1286
+
1287
+ switch ( ++count ) {
1288
+ case 1:
1289
+ assert_string_equal( ( char * ) data, ALICE_MATCH_SERVICE_NAME );
1290
+ assert_true( priority == 0 );
1291
+ assert_memory_equal( &match, &alice, sizeof( struct ofp_match ) );
1292
+ XFREE( data );
1293
+ break;
1294
+ case 2:
1295
+ assert_string_equal( ( char * ) data, ALICE_MATCH_SERVICE_NAME );
1296
+ assert_true( priority == DEFAULT_PRIORITY );
1297
+ assert_memory_equal( &match, &alice_wildcards, sizeof( struct ofp_match ) );
1298
+ XFREE( data );
1299
+ break;
1300
+ default:
1301
+ assert_true( false );
1302
+ break;
1303
+ }
1304
+ assert_string_equal( ( char * ) user_data, USER_DATA );
1305
+ }
1306
+
1307
+
1308
+ static void
1309
+ test_map_entry_if_match_set_nw_src() {
1310
+ add_all_exact_entry();
1311
+ add_all_wildcards_entry();
1312
+
1313
+ struct ofp_match match;
1314
+ memset( &match, 0, sizeof( struct ofp_match ) );
1315
+ match.wildcards = OFPFW_ALL & ~( OFPFW_DL_TYPE | OFPFW_NW_SRC_MASK );
1316
+ match.dl_type = ETHERTYPE_IP;
1317
+ match.nw_src = 0x0a000101;
1318
+ char *user_data = xstrdup( USER_DATA );
1319
+ count = 0;
1320
+ map_match_table( match, test_map_entry_if_match_set_nw_src_helper, user_data );
1321
+ assert_int_equal( count, 2 );
1322
+
1323
+ XFREE( user_data );
1324
+ }
1325
+
1326
+
1327
+ static void
1328
+ set_nw_src_prefix_20_wildcards_entry( struct ofp_match *match ) {
1329
+ memset( match, 0, sizeof( struct ofp_match ) );
1330
+ match->wildcards = OFPFW_ALL & ~( OFPFW_DL_TYPE | OFPFW_NW_SRC_MASK | OFPFW_NW_DST_MASK );
1331
+ match->dl_type = ETHERTYPE_IP;
1332
+ match->nw_src = 0x0a000200;
1333
+ match->wildcards |= ( 12 << OFPFW_NW_SRC_SHIFT );
1334
+ match->nw_dst = 0x0a000100;
1335
+ match->wildcards |= ( 4 << OFPFW_NW_DST_SHIFT );
1336
+ }
1337
+
1338
+
1339
+ static void
1340
+ set_nw_dst_prefix_20_wildcards_entry( struct ofp_match *match ) {
1341
+ memset( match, 0, sizeof( struct ofp_match ) );
1342
+ match->wildcards = OFPFW_ALL & ~( OFPFW_DL_TYPE | OFPFW_NW_SRC_MASK | OFPFW_NW_DST_MASK );
1343
+ match->dl_type = ETHERTYPE_IP;
1344
+ match->nw_src = 0x0a000200;
1345
+ match->wildcards |= ( 4 << OFPFW_NW_SRC_SHIFT );
1346
+ match->nw_dst = 0x0a000100;
1347
+ match->wildcards |= ( 12 << OFPFW_NW_DST_SHIFT );
1348
+ }
1349
+
1350
+
1351
+ static void
1352
+ set_nw_prefix_24_wildcards_entry( struct ofp_match *match ) {
1353
+ memset( match, 0, sizeof( struct ofp_match ) );
1354
+ match->wildcards = OFPFW_ALL & ~( OFPFW_DL_TYPE | OFPFW_NW_SRC_MASK | OFPFW_NW_DST_MASK );
1355
+ match->dl_type = ETHERTYPE_IP;
1356
+ match->nw_src = 0x0a000200;
1357
+ match->wildcards |= ( 8 << OFPFW_NW_SRC_SHIFT );
1358
+ match->nw_dst = 0x0a000100;
1359
+ match->wildcards |= ( 8 << OFPFW_NW_DST_SHIFT );
1360
+ }
1361
+
1362
+
1363
+ static void
1364
+ set_nw_prefix_28_wildcards_entry( struct ofp_match *match ) {
1365
+ memset( match, 0, sizeof( struct ofp_match ) );
1366
+ match->wildcards = OFPFW_ALL & ~( OFPFW_DL_TYPE | OFPFW_NW_SRC_MASK | OFPFW_NW_DST_MASK );
1367
+ match->dl_type = ETHERTYPE_IP;
1368
+ match->nw_src = 0x0a000200;
1369
+ match->wildcards |= ( 4 << OFPFW_NW_SRC_SHIFT );
1370
+ match->nw_dst = 0x0a000100;
1371
+ match->wildcards |= ( 4 << OFPFW_NW_DST_SHIFT );
1372
+ }
1373
+
1374
+
1375
+
1376
+ #define NW_SRC_PREFIX_20_SERVICE_NAME "nw_src_prefix-20"
1377
+ #define NW_DST_PREFIX_20_SERVICE_NAME "nw_dst_prefix-20"
1378
+ #define NW_PREFIX_24_SERVICE_NAME "nw_prefix-24"
1379
+ #define NW_PREFIX_28_SERVICE_NAME "nw_prefix-28"
1380
+
1381
+
1382
+ static void
1383
+ test_map_entry_if_match_set_nw_prefix_helper( struct ofp_match match, uint16_t priority, void *data, void *user_data ) {
1384
+ struct ofp_match nw_prefix_24;
1385
+ set_nw_prefix_24_wildcards_entry( &nw_prefix_24 );
1386
+ struct ofp_match nw_prefix_28;
1387
+ set_nw_prefix_28_wildcards_entry( &nw_prefix_28 );
1388
+
1389
+
1390
+ switch ( ++count ) {
1391
+ case 1:
1392
+ assert_string_equal( ( char * ) data, NW_PREFIX_24_SERVICE_NAME );
1393
+ assert_true( priority == DEFAULT_PRIORITY );
1394
+ assert_memory_equal( &match, &nw_prefix_24, sizeof( struct ofp_match ) );
1395
+ XFREE( data );
1396
+ break;
1397
+ case 2:
1398
+ assert_string_equal( ( char * ) data, NW_PREFIX_28_SERVICE_NAME );
1399
+ assert_true( priority == DEFAULT_PRIORITY );
1400
+ assert_memory_equal( &match, &nw_prefix_28, sizeof( struct ofp_match ) );
1401
+ XFREE( data );
1402
+ break;
1403
+ default:
1404
+ assert_true( false );
1405
+ break;
1406
+ }
1407
+ assert_string_equal( ( char * ) user_data, USER_DATA );
1408
+ }
1409
+
1410
+
1411
+ static void
1412
+ test_map_entry_if_match_set_nw_prefix() {
1413
+ struct ofp_match nw_src_prefix_20;
1414
+ set_nw_src_prefix_20_wildcards_entry( &nw_src_prefix_20 );
1415
+ assert_true( insert_match_entry( nw_src_prefix_20, DEFAULT_PRIORITY, xstrdup( NW_SRC_PREFIX_20_SERVICE_NAME ) ) );
1416
+ struct ofp_match nw_dst_prefix_20;
1417
+ set_nw_dst_prefix_20_wildcards_entry( &nw_dst_prefix_20 );
1418
+ assert_true( insert_match_entry( nw_dst_prefix_20, DEFAULT_PRIORITY, xstrdup( NW_DST_PREFIX_20_SERVICE_NAME ) ) );
1419
+ struct ofp_match nw_prefix_24;
1420
+ set_nw_prefix_24_wildcards_entry( &nw_prefix_24 );
1421
+ assert_true( insert_match_entry( nw_prefix_24, DEFAULT_PRIORITY, xstrdup( NW_PREFIX_24_SERVICE_NAME ) ) );
1422
+ struct ofp_match nw_prefix_28;
1423
+ set_nw_prefix_28_wildcards_entry( &nw_prefix_28 );
1424
+ assert_true( insert_match_entry( nw_prefix_28, DEFAULT_PRIORITY, xstrdup( NW_PREFIX_28_SERVICE_NAME ) ) );
1425
+
1426
+ struct ofp_match match;
1427
+ set_nw_prefix_24_wildcards_entry( &match );
1428
+ char *user_data = xstrdup( USER_DATA );
1429
+ count = 0;
1430
+ map_match_table( match, test_map_entry_if_match_set_nw_prefix_helper, user_data );
1431
+ assert_int_equal( count, 2 );
1432
+
1433
+ XFREE( user_data );
1434
+ }
1435
+
1436
+
1437
+ /*************************************************************************
1438
+ * Run tests.
1439
+ *************************************************************************/
1440
+
1441
+ int
1442
+ main() {
1443
+ const UnitTest tests[] = {
1444
+ // init and finalize tests.
1445
+ unit_test_setup_teardown( test_init_and_finalize_match_table_succeeds, setup, teardown ),
1446
+ unit_test_setup_teardown( test_init_match_table_dies_if_already_initialized, setup, finalize_and_teardown ),
1447
+ unit_test_setup_teardown( test_finalize_match_table_dies_if_not_initialized, setup, teardown ),
1448
+ unit_test_setup_teardown( test_insert_match_entry_dies_if_not_initialized, setup, teardown ),
1449
+ unit_test_setup_teardown( test_lookup_match_strict_entry_dies_if_not_initialized, setup, teardown ),
1450
+ unit_test_setup_teardown( test_lookup_match_entry_dies_if_not_initialized, setup, teardown ),
1451
+ unit_test_setup_teardown( test_update_match_entry_dies_if_not_initialized, setup, teardown ),
1452
+ unit_test_setup_teardown( test_delete_match_strict_entry_dies_if_not_initialized, setup, teardown ),
1453
+ unit_test_setup_teardown( test_foreach_match_entry_dies_if_not_initialized, setup, teardown ),
1454
+
1455
+ // insert tests.
1456
+ unit_test_setup_teardown( test_insert_exact_entry_into_empty_table_succeeds, setup_and_init, finalize_and_teardown ),
1457
+ unit_test_setup_teardown( test_insert_exact_entry_into_not_empty_exact_table_succeeds, setup_and_init, finalize_and_teardown ),
1458
+ unit_test_setup_teardown( test_insert_existing_exact_entry_fails, setup_and_init, finalize_and_teardown ),
1459
+ unit_test_setup_teardown( test_insert_different_priority_exact_entry_fails, setup_and_init, finalize_and_teardown ),
1460
+ unit_test_setup_teardown( test_reinsert_of_deleted_exact_entry_succeeds, setup_and_init, finalize_and_teardown ),
1461
+ unit_test_setup_teardown( test_insert_wildcards_entry_into_empty_table_succeeds, setup_and_init, finalize_and_teardown ),
1462
+ unit_test_setup_teardown( test_insert_wildcards_entry_into_not_empty_exact_table_succeeds, setup_and_init, finalize_and_teardown ),
1463
+ unit_test_setup_teardown( test_insert_existing_same_priority_wildcards_entry_succeeds, setup_and_init, finalize_and_teardown ),
1464
+ unit_test_setup_teardown( test_insert_existing_same_match_same_priority_wildcards_entry_fails, setup_and_init, finalize_and_teardown ),
1465
+ unit_test_setup_teardown( test_insert_different_priority_wildcards_entry_succeeds, setup_and_init, finalize_and_teardown ),
1466
+ unit_test_setup_teardown( test_insert_highest_priority_wildcards_entry_succeeds, setup_and_init, finalize_and_teardown ),
1467
+ unit_test_setup_teardown( test_insert_lowest_priority_wildcards_entry_succeeds, setup_and_init, finalize_and_teardown ),
1468
+ unit_test_setup_teardown( test_reinsert_of_deleted_wildcards_entry_succeeds, setup_and_init, finalize_and_teardown ),
1469
+ unit_test_setup_teardown( test_reinsert_of_deleted_highest_priority_wildcards_entry_succeeds, setup_and_init, finalize_and_teardown ),
1470
+ unit_test_setup_teardown( test_reinsert_of_deleted_lowhest_priority_wildcards_entry_succeeds, setup_and_init, finalize_and_teardown ),
1471
+
1472
+ // update tests.
1473
+ unit_test_setup_teardown( test_update_exact_entry_succeeds, setup_and_init, finalize_and_teardown ),
1474
+ unit_test_setup_teardown( test_update_nonexistent_exact_entry_fails, setup_and_init, finalize_and_teardown ),
1475
+ unit_test_setup_teardown( test_update_different_priority_exact_entry_succeeds, setup_and_init, finalize_and_teardown ),
1476
+ unit_test_setup_teardown( test_update_of_deleted_exact_entry_fails, setup_and_init, finalize_and_teardown ),
1477
+ unit_test_setup_teardown( test_update_exact_wildcards_succeeds, setup_and_init, finalize_and_teardown ),
1478
+ unit_test_setup_teardown( test_update_nonexistent_wildcards_entry_fails, setup_and_init, finalize_and_teardown ),
1479
+ unit_test_setup_teardown( test_update_of_deleted_wildcards_entry_fails, setup_and_init, finalize_and_teardown ),
1480
+ unit_test_setup_teardown( test_update_different_priority_wildcards_entry_fails, setup_and_init, finalize_and_teardown ),
1481
+
1482
+ // delete tests.
1483
+ unit_test_setup_teardown( test_delete_nonexistent_exact_entry_fails, setup_and_init, finalize_and_teardown ),
1484
+ unit_test_setup_teardown( test_delete_different_priority_exact_entry_succeeds, setup_and_init, finalize_and_teardown ),
1485
+ unit_test_setup_teardown( test_delete_of_deleted_exact_entry_fails, setup_and_init, finalize_and_teardown ),
1486
+ unit_test_setup_teardown( test_delete_nonexistent_wildcards_entry_fails, setup_and_init, finalize_and_teardown ),
1487
+ unit_test_setup_teardown( test_delete_of_deleted_wildcards_entry_fails, setup_and_init, finalize_and_teardown ),
1488
+ unit_test_setup_teardown( test_delete_different_priority_wildcards_entry_fails, setup_and_init, finalize_and_teardown ),
1489
+
1490
+ // foreach tests.
1491
+ unit_test_setup_teardown( test_foreach_match_entry_dies_if_function_is_null, setup_and_init, finalize_and_teardown ),
1492
+ unit_test_setup_teardown( test_foreach_entry_if_empty_table, setup_and_init, finalize_and_teardown ),
1493
+ unit_test_setup_teardown( test_foreach_entry_if_exact_table_only, setup_and_init, finalize_and_teardown ),
1494
+ unit_test_setup_teardown( test_foreach_entry_if_wildcards_table_only, setup_and_init, finalize_and_teardown ),
1495
+ unit_test_setup_teardown( test_foreach_entry, setup_and_init, finalize_and_teardown ),
1496
+ unit_test_setup_teardown( test_map_entry_if_match_set_nw_src, setup_and_init, finalize_and_teardown ),
1497
+ unit_test_setup_teardown( test_map_entry_if_match_set_nw_prefix, setup_and_init, finalize_and_teardown ),
1498
+ };
1499
+
1500
+ return run_tests( tests );
1501
+ }
1502
+
1503
+
1504
+ /*
1505
+ * Local variables:
1506
+ * c-basic-offset: 2
1507
+ * indent-tabs-mode: nil
1508
+ * End:
1509
+ */