chef 10.28.2-x86-mingw32

Sign up to get free protection for your applications and to get access to all the features.
Files changed (960) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE +201 -0
  3. data/README.rdoc +177 -0
  4. data/Rakefile +128 -0
  5. data/bin/chef-client +26 -0
  6. data/bin/chef-solo +25 -0
  7. data/bin/knife +26 -0
  8. data/bin/shef +34 -0
  9. data/distro/README +2 -0
  10. data/distro/arch/etc/conf.d/chef-client.conf +5 -0
  11. data/distro/arch/etc/conf.d/chef-expander.conf +8 -0
  12. data/distro/arch/etc/conf.d/chef-server-webui.conf +10 -0
  13. data/distro/arch/etc/conf.d/chef-server.conf +10 -0
  14. data/distro/arch/etc/conf.d/chef-solr.conf +8 -0
  15. data/distro/arch/etc/rc.d/chef-client +90 -0
  16. data/distro/arch/etc/rc.d/chef-expander +78 -0
  17. data/distro/arch/etc/rc.d/chef-server +78 -0
  18. data/distro/arch/etc/rc.d/chef-server-webui +78 -0
  19. data/distro/arch/etc/rc.d/chef-solr +78 -0
  20. data/distro/common/html/chef-client.8.html +145 -0
  21. data/distro/common/html/chef-expander.8.html +164 -0
  22. data/distro/common/html/chef-expanderctl.8.html +146 -0
  23. data/distro/common/html/chef-server-webui.8.html +185 -0
  24. data/distro/common/html/chef-server.8.html +182 -0
  25. data/distro/common/html/chef-solo.8.html +185 -0
  26. data/distro/common/html/chef-solr.8.html +165 -0
  27. data/distro/common/html/knife-bootstrap.1.html +241 -0
  28. data/distro/common/html/knife-client.1.html +219 -0
  29. data/distro/common/html/knife-configure.1.html +170 -0
  30. data/distro/common/html/knife-cookbook-site.1.html +241 -0
  31. data/distro/common/html/knife-cookbook.1.html +381 -0
  32. data/distro/common/html/knife-data-bag.1.html +235 -0
  33. data/distro/common/html/knife-environment.1.html +265 -0
  34. data/distro/common/html/knife-exec.1.html +134 -0
  35. data/distro/common/html/knife-index.1.html +125 -0
  36. data/distro/common/html/knife-node.1.html +250 -0
  37. data/distro/common/html/knife-recipe.1.html +92 -0
  38. data/distro/common/html/knife-role.1.html +200 -0
  39. data/distro/common/html/knife-search.1.html +288 -0
  40. data/distro/common/html/knife-ssh.1.html +156 -0
  41. data/distro/common/html/knife-status.1.html +128 -0
  42. data/distro/common/html/knife-tag.1.html +137 -0
  43. data/distro/common/html/knife.1.html +320 -0
  44. data/distro/common/html/shef.1.html +283 -0
  45. data/distro/common/man/man1/knife-bootstrap.1 +201 -0
  46. data/distro/common/man/man1/knife-client.1 +99 -0
  47. data/distro/common/man/man1/knife-configure.1 +88 -0
  48. data/distro/common/man/man1/knife-cookbook-site.1 +145 -0
  49. data/distro/common/man/man1/knife-cookbook.1 +332 -0
  50. data/distro/common/man/man1/knife-data-bag.1 +123 -0
  51. data/distro/common/man/man1/knife-environment.1 +168 -0
  52. data/distro/common/man/man1/knife-exec.1 +46 -0
  53. data/distro/common/man/man1/knife-index.1 +29 -0
  54. data/distro/common/man/man1/knife-node.1 +134 -0
  55. data/distro/common/man/man1/knife-role.1 +88 -0
  56. data/distro/common/man/man1/knife-search.1 +280 -0
  57. data/distro/common/man/man1/knife-ssh.1 +79 -0
  58. data/distro/common/man/man1/knife-status.1 +29 -0
  59. data/distro/common/man/man1/knife-tag.1 +43 -0
  60. data/distro/common/man/man1/knife.1 +288 -0
  61. data/distro/common/man/man1/shef.1 +256 -0
  62. data/distro/common/man/man8/chef-client.8 +104 -0
  63. data/distro/common/man/man8/chef-expander.8 +97 -0
  64. data/distro/common/man/man8/chef-expanderctl.8 +62 -0
  65. data/distro/common/man/man8/chef-server-webui.8 +155 -0
  66. data/distro/common/man/man8/chef-server.8 +147 -0
  67. data/distro/common/man/man8/chef-solo.8 +126 -0
  68. data/distro/common/man/man8/chef-solr.8 +122 -0
  69. data/distro/common/markdown/README +3 -0
  70. data/distro/common/markdown/man1/knife-bootstrap.mkd +141 -0
  71. data/distro/common/markdown/man1/knife-client.mkd +103 -0
  72. data/distro/common/markdown/man1/knife-configure.mkd +70 -0
  73. data/distro/common/markdown/man1/knife-cookbook-site.mkd +123 -0
  74. data/distro/common/markdown/man1/knife-cookbook.mkd +263 -0
  75. data/distro/common/markdown/man1/knife-data-bag.mkd +121 -0
  76. data/distro/common/markdown/man1/knife-environment.mkd +151 -0
  77. data/distro/common/markdown/man1/knife-exec.mkd +37 -0
  78. data/distro/common/markdown/man1/knife-index.mkd +30 -0
  79. data/distro/common/markdown/man1/knife-node.mkd +130 -0
  80. data/distro/common/markdown/man1/knife-role.mkd +85 -0
  81. data/distro/common/markdown/man1/knife-search.mkd +180 -0
  82. data/distro/common/markdown/man1/knife-ssh.mkd +69 -0
  83. data/distro/common/markdown/man1/knife-status.mkd +36 -0
  84. data/distro/common/markdown/man1/knife-tag.mkd +39 -0
  85. data/distro/common/markdown/man1/knife.mkd +218 -0
  86. data/distro/common/markdown/man1/shef.mkd +189 -0
  87. data/distro/common/markdown/man8/chef-client.mkd +74 -0
  88. data/distro/common/markdown/man8/chef-expander.mkd +82 -0
  89. data/distro/common/markdown/man8/chef-expanderctl.mkd +58 -0
  90. data/distro/common/markdown/man8/chef-server-webui.mkd +121 -0
  91. data/distro/common/markdown/man8/chef-server.mkd +121 -0
  92. data/distro/common/markdown/man8/chef-solo.mkd +107 -0
  93. data/distro/common/markdown/man8/chef-solr.mkd +89 -0
  94. data/distro/debian/etc/default/chef-client +5 -0
  95. data/distro/debian/etc/default/chef-expander +8 -0
  96. data/distro/debian/etc/default/chef-server +9 -0
  97. data/distro/debian/etc/default/chef-server-webui +9 -0
  98. data/distro/debian/etc/default/chef-solr +8 -0
  99. data/distro/debian/etc/init.d/chef-client +210 -0
  100. data/distro/debian/etc/init.d/chef-expander +176 -0
  101. data/distro/debian/etc/init.d/chef-server +122 -0
  102. data/distro/debian/etc/init.d/chef-server-webui +123 -0
  103. data/distro/debian/etc/init.d/chef-solr +176 -0
  104. data/distro/debian/etc/init/chef-client.conf +17 -0
  105. data/distro/debian/etc/init/chef-expander.conf +17 -0
  106. data/distro/debian/etc/init/chef-server-webui.conf +17 -0
  107. data/distro/debian/etc/init/chef-server.conf +17 -0
  108. data/distro/debian/etc/init/chef-solr.conf +17 -0
  109. data/distro/redhat/etc/init.d/chef-client +121 -0
  110. data/distro/redhat/etc/init.d/chef-expander +104 -0
  111. data/distro/redhat/etc/init.d/chef-server +112 -0
  112. data/distro/redhat/etc/init.d/chef-server-webui +112 -0
  113. data/distro/redhat/etc/init.d/chef-solr +104 -0
  114. data/distro/redhat/etc/logrotate.d/chef-client +8 -0
  115. data/distro/redhat/etc/logrotate.d/chef-expander +8 -0
  116. data/distro/redhat/etc/logrotate.d/chef-server +8 -0
  117. data/distro/redhat/etc/logrotate.d/chef-server-webui +8 -0
  118. data/distro/redhat/etc/logrotate.d/chef-solr +8 -0
  119. data/distro/redhat/etc/sysconfig/chef-client +15 -0
  120. data/distro/redhat/etc/sysconfig/chef-expander +7 -0
  121. data/distro/redhat/etc/sysconfig/chef-server +14 -0
  122. data/distro/redhat/etc/sysconfig/chef-server-webui +14 -0
  123. data/distro/redhat/etc/sysconfig/chef-solr +8 -0
  124. data/distro/windows/service_manager.rb +164 -0
  125. data/lib/chef.rb +41 -0
  126. data/lib/chef/api_client.rb +293 -0
  127. data/lib/chef/application.rb +168 -0
  128. data/lib/chef/application/agent.rb +18 -0
  129. data/lib/chef/application/client.rb +322 -0
  130. data/lib/chef/application/knife.rb +183 -0
  131. data/lib/chef/application/solo.rb +248 -0
  132. data/lib/chef/application/windows_service.rb +227 -0
  133. data/lib/chef/applications.rb +4 -0
  134. data/lib/chef/certificate.rb +161 -0
  135. data/lib/chef/checksum.rb +167 -0
  136. data/lib/chef/checksum/storage.rb +18 -0
  137. data/lib/chef/checksum/storage/filesystem.rb +56 -0
  138. data/lib/chef/checksum_cache.rb +190 -0
  139. data/lib/chef/client.rb +499 -0
  140. data/lib/chef/config.rb +330 -0
  141. data/lib/chef/cookbook/chefignore.rb +66 -0
  142. data/lib/chef/cookbook/cookbook_collection.rb +45 -0
  143. data/lib/chef/cookbook/cookbook_version_loader.rb +171 -0
  144. data/lib/chef/cookbook/file_system_file_vendor.rb +56 -0
  145. data/lib/chef/cookbook/file_vendor.rb +48 -0
  146. data/lib/chef/cookbook/metadata.rb +629 -0
  147. data/lib/chef/cookbook/remote_file_vendor.rb +84 -0
  148. data/lib/chef/cookbook/synchronizer.rb +218 -0
  149. data/lib/chef/cookbook/syntax_check.rb +136 -0
  150. data/lib/chef/cookbook_loader.rb +121 -0
  151. data/lib/chef/cookbook_site_streaming_uploader.rb +244 -0
  152. data/lib/chef/cookbook_uploader.rb +173 -0
  153. data/lib/chef/cookbook_version.rb +1081 -0
  154. data/lib/chef/cookbook_version_selector.rb +168 -0
  155. data/lib/chef/couchdb.rb +246 -0
  156. data/lib/chef/daemon.rb +187 -0
  157. data/lib/chef/data_bag.rb +239 -0
  158. data/lib/chef/data_bag_item.rb +277 -0
  159. data/lib/chef/encrypted_data_bag_item.rb +268 -0
  160. data/lib/chef/environment.rb +458 -0
  161. data/lib/chef/event_dispatch/base.rb +311 -0
  162. data/lib/chef/event_dispatch/dispatcher.rb +42 -0
  163. data/lib/chef/exceptions.rb +192 -0
  164. data/lib/chef/file_access_control.rb +75 -0
  165. data/lib/chef/file_access_control/unix.rb +216 -0
  166. data/lib/chef/file_access_control/windows.rb +310 -0
  167. data/lib/chef/file_cache.rb +220 -0
  168. data/lib/chef/formatters/base.rb +247 -0
  169. data/lib/chef/formatters/doc.rb +236 -0
  170. data/lib/chef/formatters/error_descriptor.rb +66 -0
  171. data/lib/chef/formatters/error_inspectors.rb +19 -0
  172. data/lib/chef/formatters/error_inspectors/api_error_formatting.rb +111 -0
  173. data/lib/chef/formatters/error_inspectors/compile_error_inspector.rb +106 -0
  174. data/lib/chef/formatters/error_inspectors/cookbook_resolve_error_inspector.rb +146 -0
  175. data/lib/chef/formatters/error_inspectors/cookbook_sync_error_inspector.rb +80 -0
  176. data/lib/chef/formatters/error_inspectors/node_load_error_inspector.rb +125 -0
  177. data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +137 -0
  178. data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +109 -0
  179. data/lib/chef/formatters/error_inspectors/run_list_expansion_error_inspector.rb +118 -0
  180. data/lib/chef/formatters/error_mapper.rb +85 -0
  181. data/lib/chef/formatters/minimal.rb +235 -0
  182. data/lib/chef/handler.rb +235 -0
  183. data/lib/chef/handler/error_report.rb +33 -0
  184. data/lib/chef/handler/json_file.rb +64 -0
  185. data/lib/chef/index_queue.rb +29 -0
  186. data/lib/chef/index_queue/amqp_client.rb +116 -0
  187. data/lib/chef/index_queue/consumer.rb +76 -0
  188. data/lib/chef/index_queue/indexable.rb +109 -0
  189. data/lib/chef/json_compat.rb +149 -0
  190. data/lib/chef/knife.rb +537 -0
  191. data/lib/chef/knife/bootstrap.rb +233 -0
  192. data/lib/chef/knife/bootstrap/archlinux-gems.erb +62 -0
  193. data/lib/chef/knife/bootstrap/centos5-gems.erb +62 -0
  194. data/lib/chef/knife/bootstrap/chef-full.erb +60 -0
  195. data/lib/chef/knife/bootstrap/fedora13-gems.erb +44 -0
  196. data/lib/chef/knife/bootstrap/ubuntu10.04-apt.erb +53 -0
  197. data/lib/chef/knife/bootstrap/ubuntu10.04-gems.erb +48 -0
  198. data/lib/chef/knife/bootstrap/ubuntu12.04-gems.erb +46 -0
  199. data/lib/chef/knife/bootstrap/ubuntu12.10-gems.erb +60 -0
  200. data/lib/chef/knife/client_bulk_delete.rb +65 -0
  201. data/lib/chef/knife/client_create.rb +80 -0
  202. data/lib/chef/knife/client_delete.rb +46 -0
  203. data/lib/chef/knife/client_edit.rb +45 -0
  204. data/lib/chef/knife/client_list.rb +42 -0
  205. data/lib/chef/knife/client_reregister.rb +59 -0
  206. data/lib/chef/knife/client_show.rb +52 -0
  207. data/lib/chef/knife/configure.rb +168 -0
  208. data/lib/chef/knife/configure_client.rb +50 -0
  209. data/lib/chef/knife/cookbook_bulk_delete.rb +72 -0
  210. data/lib/chef/knife/cookbook_create.rb +447 -0
  211. data/lib/chef/knife/cookbook_delete.rb +151 -0
  212. data/lib/chef/knife/cookbook_download.rb +137 -0
  213. data/lib/chef/knife/cookbook_list.rb +47 -0
  214. data/lib/chef/knife/cookbook_metadata.rb +107 -0
  215. data/lib/chef/knife/cookbook_metadata_from_file.rb +44 -0
  216. data/lib/chef/knife/cookbook_show.rb +102 -0
  217. data/lib/chef/knife/cookbook_site_download.rb +109 -0
  218. data/lib/chef/knife/cookbook_site_install.rb +164 -0
  219. data/lib/chef/knife/cookbook_site_list.rb +62 -0
  220. data/lib/chef/knife/cookbook_site_search.rb +51 -0
  221. data/lib/chef/knife/cookbook_site_share.rb +114 -0
  222. data/lib/chef/knife/cookbook_site_show.rb +60 -0
  223. data/lib/chef/knife/cookbook_site_unshare.rb +56 -0
  224. data/lib/chef/knife/cookbook_site_vendor.rb +46 -0
  225. data/lib/chef/knife/cookbook_test.rb +93 -0
  226. data/lib/chef/knife/cookbook_upload.rb +290 -0
  227. data/lib/chef/knife/core/bootstrap_context.rb +106 -0
  228. data/lib/chef/knife/core/cookbook_scm_repo.rb +160 -0
  229. data/lib/chef/knife/core/generic_presenter.rb +191 -0
  230. data/lib/chef/knife/core/node_editor.rb +130 -0
  231. data/lib/chef/knife/core/node_presenter.rb +137 -0
  232. data/lib/chef/knife/core/object_loader.rb +112 -0
  233. data/lib/chef/knife/core/subcommand_loader.rb +112 -0
  234. data/lib/chef/knife/core/text_formatter.rb +100 -0
  235. data/lib/chef/knife/core/ui.rb +217 -0
  236. data/lib/chef/knife/data_bag_create.rb +93 -0
  237. data/lib/chef/knife/data_bag_delete.rb +51 -0
  238. data/lib/chef/knife/data_bag_edit.rb +94 -0
  239. data/lib/chef/knife/data_bag_from_file.rb +136 -0
  240. data/lib/chef/knife/data_bag_list.rb +46 -0
  241. data/lib/chef/knife/data_bag_show.rb +81 -0
  242. data/lib/chef/knife/environment_create.rb +53 -0
  243. data/lib/chef/knife/environment_delete.rb +45 -0
  244. data/lib/chef/knife/environment_edit.rb +45 -0
  245. data/lib/chef/knife/environment_from_file.rb +83 -0
  246. data/lib/chef/knife/environment_list.rb +42 -0
  247. data/lib/chef/knife/environment_show.rb +46 -0
  248. data/lib/chef/knife/exec.rb +86 -0
  249. data/lib/chef/knife/help.rb +103 -0
  250. data/lib/chef/knife/help_topics.rb +4 -0
  251. data/lib/chef/knife/index_rebuild.rb +50 -0
  252. data/lib/chef/knife/node_bulk_delete.rb +80 -0
  253. data/lib/chef/knife/node_create.rb +50 -0
  254. data/lib/chef/knife/node_delete.rb +47 -0
  255. data/lib/chef/knife/node_edit.rb +72 -0
  256. data/lib/chef/knife/node_from_file.rb +50 -0
  257. data/lib/chef/knife/node_list.rb +46 -0
  258. data/lib/chef/knife/node_run_list_add.rb +75 -0
  259. data/lib/chef/knife/node_run_list_remove.rb +48 -0
  260. data/lib/chef/knife/node_show.rb +73 -0
  261. data/lib/chef/knife/recipe_list.rb +32 -0
  262. data/lib/chef/knife/role_bulk_delete.rb +70 -0
  263. data/lib/chef/knife/role_create.rb +55 -0
  264. data/lib/chef/knife/role_delete.rb +47 -0
  265. data/lib/chef/knife/role_edit.rb +48 -0
  266. data/lib/chef/knife/role_from_file.rb +56 -0
  267. data/lib/chef/knife/role_list.rb +43 -0
  268. data/lib/chef/knife/role_show.rb +54 -0
  269. data/lib/chef/knife/search.rb +141 -0
  270. data/lib/chef/knife/ssh.rb +459 -0
  271. data/lib/chef/knife/status.rb +119 -0
  272. data/lib/chef/knife/tag_create.rb +52 -0
  273. data/lib/chef/knife/tag_delete.rb +60 -0
  274. data/lib/chef/knife/tag_list.rb +47 -0
  275. data/lib/chef/log.rb +39 -0
  276. data/lib/chef/mash.rb +225 -0
  277. data/lib/chef/mixin/check_helper.rb +31 -0
  278. data/lib/chef/mixin/checksum.rb +32 -0
  279. data/lib/chef/mixin/command.rb +164 -0
  280. data/lib/chef/mixin/command/unix.rb +220 -0
  281. data/lib/chef/mixin/command/windows.rb +76 -0
  282. data/lib/chef/mixin/convert_to_class_name.rb +65 -0
  283. data/lib/chef/mixin/create_path.rb +57 -0
  284. data/lib/chef/mixin/deep_merge.rb +247 -0
  285. data/lib/chef/mixin/deprecation.rb +65 -0
  286. data/lib/chef/mixin/enforce_ownership_and_permissions.rb +39 -0
  287. data/lib/chef/mixin/file_class.rb +46 -0
  288. data/lib/chef/mixin/from_file.rb +50 -0
  289. data/lib/chef/mixin/get_source_from_package.rb +42 -0
  290. data/lib/chef/mixin/language.rb +249 -0
  291. data/lib/chef/mixin/language_include_attribute.rb +61 -0
  292. data/lib/chef/mixin/language_include_recipe.rb +58 -0
  293. data/lib/chef/mixin/params_validate.rb +238 -0
  294. data/lib/chef/mixin/path_sanity.rb +67 -0
  295. data/lib/chef/mixin/recipe_definition_dsl_core.rb +86 -0
  296. data/lib/chef/mixin/securable.rb +180 -0
  297. data/lib/chef/mixin/shell_out.rb +69 -0
  298. data/lib/chef/mixin/template.rb +100 -0
  299. data/lib/chef/mixin/why_run.rb +332 -0
  300. data/lib/chef/mixin/xml_escape.rb +140 -0
  301. data/lib/chef/mixins.rb +18 -0
  302. data/lib/chef/monkey_patches/dir.rb +36 -0
  303. data/lib/chef/monkey_patches/fileutils.rb +65 -0
  304. data/lib/chef/monkey_patches/moneta.rb +50 -0
  305. data/lib/chef/monkey_patches/net_http.rb +22 -0
  306. data/lib/chef/monkey_patches/numeric.rb +15 -0
  307. data/lib/chef/monkey_patches/object.rb +9 -0
  308. data/lib/chef/monkey_patches/regexp.rb +34 -0
  309. data/lib/chef/monkey_patches/string.rb +49 -0
  310. data/lib/chef/monkey_patches/tempfile.rb +64 -0
  311. data/lib/chef/nil_argument.rb +3 -0
  312. data/lib/chef/node.rb +682 -0
  313. data/lib/chef/node/attribute.rb +504 -0
  314. data/lib/chef/openid_registration.rb +187 -0
  315. data/lib/chef/platform.rb +520 -0
  316. data/lib/chef/provider.rb +223 -0
  317. data/lib/chef/provider/breakpoint.rb +36 -0
  318. data/lib/chef/provider/cookbook_file.rb +105 -0
  319. data/lib/chef/provider/cron.rb +214 -0
  320. data/lib/chef/provider/cron/solaris.rb +56 -0
  321. data/lib/chef/provider/deploy.rb +474 -0
  322. data/lib/chef/provider/deploy/revision.rb +80 -0
  323. data/lib/chef/provider/deploy/timestamped.rb +32 -0
  324. data/lib/chef/provider/directory.rb +128 -0
  325. data/lib/chef/provider/env.rb +152 -0
  326. data/lib/chef/provider/env/windows.rb +75 -0
  327. data/lib/chef/provider/erl_call.rb +106 -0
  328. data/lib/chef/provider/execute.rb +68 -0
  329. data/lib/chef/provider/file.rb +355 -0
  330. data/lib/chef/provider/git.rb +260 -0
  331. data/lib/chef/provider/group.rb +159 -0
  332. data/lib/chef/provider/group/aix.rb +70 -0
  333. data/lib/chef/provider/group/dscl.rb +129 -0
  334. data/lib/chef/provider/group/gpasswd.rb +65 -0
  335. data/lib/chef/provider/group/groupadd.rb +96 -0
  336. data/lib/chef/provider/group/groupmod.rb +120 -0
  337. data/lib/chef/provider/group/pw.rb +93 -0
  338. data/lib/chef/provider/group/suse.rb +60 -0
  339. data/lib/chef/provider/group/usermod.rb +68 -0
  340. data/lib/chef/provider/group/windows.rb +79 -0
  341. data/lib/chef/provider/http_request.rb +136 -0
  342. data/lib/chef/provider/ifconfig.rb +214 -0
  343. data/lib/chef/provider/link.rb +130 -0
  344. data/lib/chef/provider/log.rb +54 -0
  345. data/lib/chef/provider/mdadm.rb +92 -0
  346. data/lib/chef/provider/mount.rb +128 -0
  347. data/lib/chef/provider/mount/mount.rb +252 -0
  348. data/lib/chef/provider/mount/windows.rb +81 -0
  349. data/lib/chef/provider/ohai.rb +47 -0
  350. data/lib/chef/provider/package.rb +229 -0
  351. data/lib/chef/provider/package/apt.rb +147 -0
  352. data/lib/chef/provider/package/dpkg.rb +128 -0
  353. data/lib/chef/provider/package/easy_install.rb +136 -0
  354. data/lib/chef/provider/package/freebsd.rb +149 -0
  355. data/lib/chef/provider/package/ips.rb +101 -0
  356. data/lib/chef/provider/package/macports.rb +105 -0
  357. data/lib/chef/provider/package/pacman.rb +111 -0
  358. data/lib/chef/provider/package/portage.rb +143 -0
  359. data/lib/chef/provider/package/rpm.rb +121 -0
  360. data/lib/chef/provider/package/rubygems.rb +580 -0
  361. data/lib/chef/provider/package/smartos.rb +84 -0
  362. data/lib/chef/provider/package/solaris.rb +139 -0
  363. data/lib/chef/provider/package/yum-dump.py +307 -0
  364. data/lib/chef/provider/package/yum.rb +1261 -0
  365. data/lib/chef/provider/package/zypper.rb +144 -0
  366. data/lib/chef/provider/remote_directory.rb +178 -0
  367. data/lib/chef/provider/remote_file.rb +126 -0
  368. data/lib/chef/provider/resource_update.rb +55 -0
  369. data/lib/chef/provider/route.rb +223 -0
  370. data/lib/chef/provider/ruby_block.rb +39 -0
  371. data/lib/chef/provider/script.rb +57 -0
  372. data/lib/chef/provider/service.rb +158 -0
  373. data/lib/chef/provider/service/arch.rb +113 -0
  374. data/lib/chef/provider/service/debian.rb +152 -0
  375. data/lib/chef/provider/service/freebsd.rb +175 -0
  376. data/lib/chef/provider/service/gentoo.rb +67 -0
  377. data/lib/chef/provider/service/init.rb +87 -0
  378. data/lib/chef/provider/service/insserv.rb +52 -0
  379. data/lib/chef/provider/service/invokercd.rb +35 -0
  380. data/lib/chef/provider/service/macosx.rb +144 -0
  381. data/lib/chef/provider/service/redhat.rb +77 -0
  382. data/lib/chef/provider/service/simple.rb +172 -0
  383. data/lib/chef/provider/service/solaris.rb +86 -0
  384. data/lib/chef/provider/service/systemd.rb +115 -0
  385. data/lib/chef/provider/service/upstart.rb +232 -0
  386. data/lib/chef/provider/service/windows.rb +163 -0
  387. data/lib/chef/provider/subversion.rb +214 -0
  388. data/lib/chef/provider/template.rb +117 -0
  389. data/lib/chef/provider/user.rb +207 -0
  390. data/lib/chef/provider/user/dscl.rb +280 -0
  391. data/lib/chef/provider/user/pw.rb +113 -0
  392. data/lib/chef/provider/user/solaris.rb +90 -0
  393. data/lib/chef/provider/user/useradd.rb +153 -0
  394. data/lib/chef/provider/user/windows.rb +124 -0
  395. data/lib/chef/providers.rb +101 -0
  396. data/lib/chef/recipe.rb +129 -0
  397. data/lib/chef/reserved_names.rb +9 -0
  398. data/lib/chef/resource.rb +912 -0
  399. data/lib/chef/resource/apt_package.rb +43 -0
  400. data/lib/chef/resource/bash.rb +33 -0
  401. data/lib/chef/resource/breakpoint.rb +35 -0
  402. data/lib/chef/resource/chef_gem.rb +53 -0
  403. data/lib/chef/resource/conditional.rb +101 -0
  404. data/lib/chef/resource/cookbook_file.rb +52 -0
  405. data/lib/chef/resource/cron.rb +202 -0
  406. data/lib/chef/resource/csh.rb +33 -0
  407. data/lib/chef/resource/deploy.rb +403 -0
  408. data/lib/chef/resource/deploy_revision.rb +40 -0
  409. data/lib/chef/resource/directory.rb +65 -0
  410. data/lib/chef/resource/dpkg_package.rb +34 -0
  411. data/lib/chef/resource/easy_install_package.rb +57 -0
  412. data/lib/chef/resource/env.rb +63 -0
  413. data/lib/chef/resource/erl_call.rb +86 -0
  414. data/lib/chef/resource/execute.rb +132 -0
  415. data/lib/chef/resource/file.rb +96 -0
  416. data/lib/chef/resource/freebsd_package.rb +35 -0
  417. data/lib/chef/resource/gem_package.rb +53 -0
  418. data/lib/chef/resource/git.rb +46 -0
  419. data/lib/chef/resource/group.rb +83 -0
  420. data/lib/chef/resource/http_request.rb +64 -0
  421. data/lib/chef/resource/ifconfig.rb +149 -0
  422. data/lib/chef/resource/ips_package.rb +42 -0
  423. data/lib/chef/resource/link.rb +92 -0
  424. data/lib/chef/resource/log.rb +74 -0
  425. data/lib/chef/resource/macports_package.rb +29 -0
  426. data/lib/chef/resource/mdadm.rb +105 -0
  427. data/lib/chef/resource/mount.rb +139 -0
  428. data/lib/chef/resource/ohai.rb +54 -0
  429. data/lib/chef/resource/package.rb +84 -0
  430. data/lib/chef/resource/pacman_package.rb +33 -0
  431. data/lib/chef/resource/perl.rb +33 -0
  432. data/lib/chef/resource/portage_package.rb +33 -0
  433. data/lib/chef/resource/python.rb +33 -0
  434. data/lib/chef/resource/remote_directory.rb +125 -0
  435. data/lib/chef/resource/remote_file.rb +90 -0
  436. data/lib/chef/resource/route.rb +140 -0
  437. data/lib/chef/resource/rpm_package.rb +34 -0
  438. data/lib/chef/resource/ruby.rb +33 -0
  439. data/lib/chef/resource/ruby_block.rb +51 -0
  440. data/lib/chef/resource/scm.rb +151 -0
  441. data/lib/chef/resource/script.rb +63 -0
  442. data/lib/chef/resource/service.rb +164 -0
  443. data/lib/chef/resource/smartos_package.rb +36 -0
  444. data/lib/chef/resource/solaris_package.rb +36 -0
  445. data/lib/chef/resource/subversion.rb +37 -0
  446. data/lib/chef/resource/template.rb +76 -0
  447. data/lib/chef/resource/timestamped_deploy.rb +31 -0
  448. data/lib/chef/resource/user.rb +134 -0
  449. data/lib/chef/resource/yum_package.rb +63 -0
  450. data/lib/chef/resource_collection.rb +217 -0
  451. data/lib/chef/resource_collection/stepable_iterator.rb +124 -0
  452. data/lib/chef/resource_definition.rb +67 -0
  453. data/lib/chef/resource_definition_list.rb +38 -0
  454. data/lib/chef/resource_platform_map.rb +151 -0
  455. data/lib/chef/resource_reporter.rb +281 -0
  456. data/lib/chef/resources.rb +67 -0
  457. data/lib/chef/rest.rb +510 -0
  458. data/lib/chef/rest/auth_credentials.rb +73 -0
  459. data/lib/chef/rest/cookie_jar.rb +31 -0
  460. data/lib/chef/rest/rest_request.rb +229 -0
  461. data/lib/chef/role.rb +349 -0
  462. data/lib/chef/run_context.rb +236 -0
  463. data/lib/chef/run_list.rb +165 -0
  464. data/lib/chef/run_list/run_list_expansion.rb +206 -0
  465. data/lib/chef/run_list/run_list_item.rb +99 -0
  466. data/lib/chef/run_list/versioned_recipe_list.rb +68 -0
  467. data/lib/chef/run_status.rb +124 -0
  468. data/lib/chef/runner.rb +95 -0
  469. data/lib/chef/sandbox.rb +153 -0
  470. data/lib/chef/scan_access_control.rb +135 -0
  471. data/lib/chef/search/query.rb +65 -0
  472. data/lib/chef/shef.rb +327 -0
  473. data/lib/chef/shef/ext.rb +591 -0
  474. data/lib/chef/shef/model_wrapper.rb +120 -0
  475. data/lib/chef/shef/shef_rest.rb +28 -0
  476. data/lib/chef/shef/shef_session.rb +296 -0
  477. data/lib/chef/shell_out.rb +6 -0
  478. data/lib/chef/solr_query.rb +187 -0
  479. data/lib/chef/solr_query/lucene.treetop +150 -0
  480. data/lib/chef/solr_query/lucene_nodes.rb +285 -0
  481. data/lib/chef/solr_query/query_transform.rb +65 -0
  482. data/lib/chef/solr_query/solr_http_request.rb +132 -0
  483. data/lib/chef/streaming_cookbook_uploader.rb +201 -0
  484. data/lib/chef/tasks/chef_repo.rake +334 -0
  485. data/lib/chef/util/file_edit.rb +132 -0
  486. data/lib/chef/util/windows.rb +56 -0
  487. data/lib/chef/util/windows/net_group.rb +101 -0
  488. data/lib/chef/util/windows/net_use.rb +121 -0
  489. data/lib/chef/util/windows/net_user.rb +198 -0
  490. data/lib/chef/util/windows/volume.rb +59 -0
  491. data/lib/chef/version.rb +23 -0
  492. data/lib/chef/version_class.rb +70 -0
  493. data/lib/chef/version_constraint.rb +116 -0
  494. data/lib/chef/webui_user.rb +231 -0
  495. data/lib/chef/win32/api.rb +364 -0
  496. data/lib/chef/win32/api/error.rb +921 -0
  497. data/lib/chef/win32/api/file.rb +535 -0
  498. data/lib/chef/win32/api/memory.rb +105 -0
  499. data/lib/chef/win32/api/process.rb +41 -0
  500. data/lib/chef/win32/api/psapi.rb +51 -0
  501. data/lib/chef/win32/api/security.rb +341 -0
  502. data/lib/chef/win32/api/system.rb +192 -0
  503. data/lib/chef/win32/api/unicode.rb +178 -0
  504. data/lib/chef/win32/error.rb +73 -0
  505. data/lib/chef/win32/file.rb +167 -0
  506. data/lib/chef/win32/file/info.rb +100 -0
  507. data/lib/chef/win32/handle.rb +55 -0
  508. data/lib/chef/win32/memory.rb +101 -0
  509. data/lib/chef/win32/process.rb +84 -0
  510. data/lib/chef/win32/security.rb +489 -0
  511. data/lib/chef/win32/security/ace.rb +125 -0
  512. data/lib/chef/win32/security/acl.rb +101 -0
  513. data/lib/chef/win32/security/securable_object.rb +109 -0
  514. data/lib/chef/win32/security/security_descriptor.rb +93 -0
  515. data/lib/chef/win32/security/sid.rb +199 -0
  516. data/lib/chef/win32/security/token.rb +64 -0
  517. data/lib/chef/win32/unicode.rb +43 -0
  518. data/lib/chef/win32/version.rb +119 -0
  519. data/spec/data/bad-config.rb +1 -0
  520. data/spec/data/big_json.json +2 -0
  521. data/spec/data/big_json_plus_one.json +2 -0
  522. data/spec/data/bootstrap/test-hints.erb +12 -0
  523. data/spec/data/bootstrap/test.erb +1 -0
  524. data/spec/data/cb_version_cookbooks/tatft/README.rdoc +3 -0
  525. data/spec/data/cb_version_cookbooks/tatft/attributes/default.rb +1 -0
  526. data/spec/data/cb_version_cookbooks/tatft/definitions/runit_service.rb +1 -0
  527. data/spec/data/cb_version_cookbooks/tatft/files/default/giant_blob.tgz +1 -0
  528. data/spec/data/cb_version_cookbooks/tatft/libraries/ownage.rb +1 -0
  529. data/spec/data/cb_version_cookbooks/tatft/providers/lwp.rb +1 -0
  530. data/spec/data/cb_version_cookbooks/tatft/recipes/default.rb +1 -0
  531. data/spec/data/cb_version_cookbooks/tatft/resources/lwr.rb +1 -0
  532. data/spec/data/cb_version_cookbooks/tatft/templates/default/configuration.erb +0 -0
  533. data/spec/data/checksum/random.txt +1 -0
  534. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-600hhz-0 +1 -0
  535. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-6m8zdk-0 +0 -0
  536. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ahd2gq-0 +1 -0
  537. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-api8ux-0 +1 -0
  538. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-b0r1m1-0 +1 -0
  539. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-bfygsi-0 +1 -0
  540. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-el14l6-0 +1 -0
  541. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ivrl3y-0 +1 -0
  542. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-kkbs85-0 +1 -0
  543. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ory1ux-0 +1 -0
  544. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-pgsq76-0 +1 -0
  545. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ra8uim-0 +1 -0
  546. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t7k1g-0 +1 -0
  547. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t8g0sv-0 +1 -0
  548. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ufy6g3-0 +1 -0
  549. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-x2d6j9-0 +1 -0
  550. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-xi0l6h-0 +1 -0
  551. data/spec/data/config.rb +6 -0
  552. data/spec/data/cookbooks/angrybash/recipes/default.rb +8 -0
  553. data/spec/data/cookbooks/apache2/files/default/apache2_module_conf_generate.pl +2 -0
  554. data/spec/data/cookbooks/apache2/recipes/default.rb +3 -0
  555. data/spec/data/cookbooks/borken/recipes/default.rb +2 -0
  556. data/spec/data/cookbooks/borken/templates/default/borken.erb +2 -0
  557. data/spec/data/cookbooks/chefignore +8 -0
  558. data/spec/data/cookbooks/java/files/default/java.response +2 -0
  559. data/spec/data/cookbooks/openldap/attributes/default.rb +15 -0
  560. data/spec/data/cookbooks/openldap/attributes/smokey.rb +1 -0
  561. data/spec/data/cookbooks/openldap/definitions/client.rb +5 -0
  562. data/spec/data/cookbooks/openldap/definitions/server.rb +5 -0
  563. data/spec/data/cookbooks/openldap/files/default/.dotfile +1 -0
  564. data/spec/data/cookbooks/openldap/files/default/.ssh/id_rsa +1 -0
  565. data/spec/data/cookbooks/openldap/files/default/remotedir/.a_dotdir/.a_dotfile_in_a_dotdir +1 -0
  566. data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file1.txt +3 -0
  567. data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file2.txt +3 -0
  568. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/.a_dotfile +1 -0
  569. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file1.txt +3 -0
  570. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file2.txt +3 -0
  571. data/spec/data/cookbooks/openldap/files/default/remotedir/subdir_with_no_file_just_a_subsubdir/the_subsubdir/some_file.txt +3 -0
  572. data/spec/data/cookbooks/openldap/recipes/default.rb +3 -0
  573. data/spec/data/cookbooks/openldap/recipes/gigantor.rb +3 -0
  574. data/spec/data/cookbooks/openldap/recipes/one.rb +15 -0
  575. data/spec/data/cookbooks/openldap/templates/default/openldap_stuff.conf.erb +1 -0
  576. data/spec/data/cookbooks/openldap/templates/default/openldap_variable_stuff.conf.erb +1 -0
  577. data/spec/data/cookbooks/openldap/templates/default/test.erb +1 -0
  578. data/spec/data/definitions/test.rb +5 -0
  579. data/spec/data/environment-config.rb +5 -0
  580. data/spec/data/fileedit/blank +0 -0
  581. data/spec/data/fileedit/hosts +4 -0
  582. data/spec/data/gems/chef-integration-test-0.1.0.gem +0 -0
  583. data/spec/data/git_bundles/sinatra-test-app-with-callback-files.gitbundle +0 -0
  584. data/spec/data/git_bundles/sinatra-test-app-with-symlinks.gitbundle +0 -0
  585. data/spec/data/git_bundles/sinatra-test-app.gitbundle +0 -0
  586. data/spec/data/kitchen/chefignore +6 -0
  587. data/spec/data/kitchen/openldap/attributes/default.rb +3 -0
  588. data/spec/data/kitchen/openldap/attributes/robinson.rb +3 -0
  589. data/spec/data/kitchen/openldap/definitions/client.rb +3 -0
  590. data/spec/data/kitchen/openldap/definitions/drewbarrymore.rb +3 -0
  591. data/spec/data/kitchen/openldap/recipes/gigantor.rb +3 -0
  592. data/spec/data/kitchen/openldap/recipes/ignoreme.rb +3 -0
  593. data/spec/data/kitchen/openldap/recipes/woot.rb +3 -0
  594. data/spec/data/knife-home/.chef/plugins/knife/example_home_subcommand.rb +0 -0
  595. data/spec/data/knife-site-subcommands/plugins/knife/example_subcommand.rb +0 -0
  596. data/spec/data/knife_subcommand/test_explicit_category.rb +7 -0
  597. data/spec/data/knife_subcommand/test_name_mapping.rb +4 -0
  598. data/spec/data/knife_subcommand/test_yourself.rb +13 -0
  599. data/spec/data/lwrp/providers/buck_passer.rb +3 -0
  600. data/spec/data/lwrp/providers/buck_passer_2.rb +10 -0
  601. data/spec/data/lwrp/providers/embedded_resource_accesses_providers_scope.rb +16 -0
  602. data/spec/data/lwrp/providers/monkey_name_printer.rb +5 -0
  603. data/spec/data/lwrp/providers/paint_drying_watcher.rb +7 -0
  604. data/spec/data/lwrp/providers/thumb_twiddler.rb +7 -0
  605. data/spec/data/lwrp/resources/bar.rb +1 -0
  606. data/spec/data/lwrp/resources/foo.rb +3 -0
  607. data/spec/data/lwrp/resources_with_default_attributes/nodeattr.rb +1 -0
  608. data/spec/data/lwrp_const_scoping/resources/conflict.rb +0 -0
  609. data/spec/data/lwrp_override/providers/buck_passer.rb +10 -0
  610. data/spec/data/lwrp_override/resources/foo.rb +4 -0
  611. data/spec/data/metadata/quick_start/metadata.rb +19 -0
  612. data/spec/data/nodes/default.rb +15 -0
  613. data/spec/data/nodes/test.example.com.rb +17 -0
  614. data/spec/data/nodes/test.rb +15 -0
  615. data/spec/data/object_loader/environments/test.json +5 -0
  616. data/spec/data/object_loader/environments/test.rb +2 -0
  617. data/spec/data/object_loader/environments/test_json_class.json +6 -0
  618. data/spec/data/object_loader/nodes/test.json +5 -0
  619. data/spec/data/object_loader/nodes/test.rb +2 -0
  620. data/spec/data/object_loader/nodes/test_json_class.json +6 -0
  621. data/spec/data/object_loader/roles/test.json +5 -0
  622. data/spec/data/object_loader/roles/test.rb +2 -0
  623. data/spec/data/object_loader/roles/test_json_class.json +6 -0
  624. data/spec/data/old_home_dir/my-dot-emacs +0 -0
  625. data/spec/data/old_home_dir/my-dot-vim +0 -0
  626. data/spec/data/recipes/test.rb +7 -0
  627. data/spec/data/remote_directory_data/remote_dir_file.txt +1 -0
  628. data/spec/data/remote_directory_data/remote_subdirectory/remote_subdir_file.txt +1 -0
  629. data/spec/data/remote_file/nyan_cat.png +0 -0
  630. data/spec/data/run_context/cookbooks/test/attributes/george.rb +1 -0
  631. data/spec/data/run_context/cookbooks/test/definitions/new_animals.rb +9 -0
  632. data/spec/data/run_context/cookbooks/test/definitions/new_cat.rb +5 -0
  633. data/spec/data/run_context/cookbooks/test/recipes/default.rb +5 -0
  634. data/spec/data/run_context/cookbooks/test/recipes/one.rb +7 -0
  635. data/spec/data/run_context/cookbooks/test/recipes/two.rb +7 -0
  636. data/spec/data/run_context/nodes/run_context.rb +5 -0
  637. data/spec/data/search_queries_to_transform.txt +98 -0
  638. data/spec/data/ssl/5e707473.0 +18 -0
  639. data/spec/data/ssl/chef-rspec.cert +27 -0
  640. data/spec/data/ssl/chef-rspec.key +27 -0
  641. data/spec/data/ssl/key.pem +15 -0
  642. data/spec/data/ssl/private_key.pem +27 -0
  643. data/spec/data/ssl/private_key_with_whitespace.pem +32 -0
  644. data/spec/data/templates/seattle.txt +1 -0
  645. data/spec/functional/knife/cookbook_delete_spec.rb +160 -0
  646. data/spec/functional/knife/exec_spec.rb +60 -0
  647. data/spec/functional/knife/ssh_spec.rb +268 -0
  648. data/spec/functional/resource/cookbook_file_spec.rb +75 -0
  649. data/spec/functional/resource/deploy_revision_spec.rb +515 -0
  650. data/spec/functional/resource/directory_spec.rb +39 -0
  651. data/spec/functional/resource/file_spec.rb +69 -0
  652. data/spec/functional/resource/link_spec.rb +572 -0
  653. data/spec/functional/resource/remote_directory_spec.rb +114 -0
  654. data/spec/functional/resource/remote_file_spec.rb +65 -0
  655. data/spec/functional/resource/template_spec.rb +68 -0
  656. data/spec/functional/tiny_server_spec.rb +78 -0
  657. data/spec/rcov.opts +2 -0
  658. data/spec/spec_helper.rb +82 -0
  659. data/spec/stress/win32/file_spec.rb +37 -0
  660. data/spec/stress/win32/memory_spec.rb +22 -0
  661. data/spec/stress/win32/security_spec.rb +69 -0
  662. data/spec/support/chef_helpers.rb +65 -0
  663. data/spec/support/lib/chef/provider/easy.rb +35 -0
  664. data/spec/support/lib/chef/provider/snakeoil.rb +40 -0
  665. data/spec/support/lib/chef/resource/cat.rb +41 -0
  666. data/spec/support/lib/chef/resource/one_two_three_four.rb +43 -0
  667. data/spec/support/lib/chef/resource/zen_master.rb +46 -0
  668. data/spec/support/matchers/leak.rb +96 -0
  669. data/spec/support/mock/constant.rb +52 -0
  670. data/spec/support/mock/platform.rb +18 -0
  671. data/spec/support/platform_helpers.rb +39 -0
  672. data/spec/support/platforms/prof/gc.rb +54 -0
  673. data/spec/support/platforms/prof/win32.rb +46 -0
  674. data/spec/support/shared/functional/directory_resource.rb +85 -0
  675. data/spec/support/shared/functional/file_resource.rb +202 -0
  676. data/spec/support/shared/functional/knife.rb +37 -0
  677. data/spec/support/shared/functional/securable_resource.rb +402 -0
  678. data/spec/support/shared/unit/api_error_inspector.rb +192 -0
  679. data/spec/tiny_server.rb +202 -0
  680. data/spec/unit/api_client_spec.rb +257 -0
  681. data/spec/unit/application/agent_spec.rb +0 -0
  682. data/spec/unit/application/client_spec.rb +171 -0
  683. data/spec/unit/application/knife_spec.rb +152 -0
  684. data/spec/unit/application/server_spec.rb +0 -0
  685. data/spec/unit/application/solo_spec.rb +167 -0
  686. data/spec/unit/application_spec.rb +239 -0
  687. data/spec/unit/certificate_spec.rb +76 -0
  688. data/spec/unit/checksum/storage/filesystem_spec.rb +69 -0
  689. data/spec/unit/checksum_cache_spec.rb +209 -0
  690. data/spec/unit/checksum_spec.rb +94 -0
  691. data/spec/unit/chef_spec.rb +25 -0
  692. data/spec/unit/client_spec.rb +290 -0
  693. data/spec/unit/config_spec.rb +223 -0
  694. data/spec/unit/cookbook/chefignore_spec.rb +39 -0
  695. data/spec/unit/cookbook/metadata_spec.rb +627 -0
  696. data/spec/unit/cookbook/synchronizer_spec.rb +306 -0
  697. data/spec/unit/cookbook/syntax_check_spec.rb +211 -0
  698. data/spec/unit/cookbook_loader_spec.rb +145 -0
  699. data/spec/unit/cookbook_manifest_spec.rb +554 -0
  700. data/spec/unit/cookbook_spec.rb +101 -0
  701. data/spec/unit/cookbook_version_spec.rb +406 -0
  702. data/spec/unit/couchdb_spec.rb +274 -0
  703. data/spec/unit/daemon_spec.rb +302 -0
  704. data/spec/unit/data_bag_item_spec.rb +280 -0
  705. data/spec/unit/data_bag_spec.rb +169 -0
  706. data/spec/unit/encrypted_data_bag_item_spec.rb +293 -0
  707. data/spec/unit/environment_spec.rb +492 -0
  708. data/spec/unit/exceptions_spec.rb +74 -0
  709. data/spec/unit/file_access_control_spec.rb +282 -0
  710. data/spec/unit/file_cache_spec.rb +114 -0
  711. data/spec/unit/formatters/error_inspectors/compile_error_inspector_spec.rb +202 -0
  712. data/spec/unit/formatters/error_inspectors/cookbook_resolve_error_inspector_spec.rb +93 -0
  713. data/spec/unit/formatters/error_inspectors/cookbook_sync_error_inspector_spec.rb +43 -0
  714. data/spec/unit/formatters/error_inspectors/node_load_error_inspector_spec.rb +27 -0
  715. data/spec/unit/formatters/error_inspectors/registration_error_inspector_spec.rb +27 -0
  716. data/spec/unit/formatters/error_inspectors/resource_failure_inspector_spec.rb +182 -0
  717. data/spec/unit/formatters/error_inspectors/run_list_expansion_error_inspector_spec.rb +93 -0
  718. data/spec/unit/handler/json_file_spec.rb +64 -0
  719. data/spec/unit/handler_spec.rb +216 -0
  720. data/spec/unit/index_queue_spec.rb +391 -0
  721. data/spec/unit/json_compat_spec.rb +61 -0
  722. data/spec/unit/knife/bootstrap_spec.rb +265 -0
  723. data/spec/unit/knife/client_bulk_delete_spec.rb +78 -0
  724. data/spec/unit/knife/client_create_spec.rb +74 -0
  725. data/spec/unit/knife/client_delete_spec.rb +40 -0
  726. data/spec/unit/knife/client_edit_spec.rb +40 -0
  727. data/spec/unit/knife/client_list_spec.rb +34 -0
  728. data/spec/unit/knife/client_reregister_spec.rb +62 -0
  729. data/spec/unit/knife/client_show_spec.rb +42 -0
  730. data/spec/unit/knife/config_file_selection_spec.rb +118 -0
  731. data/spec/unit/knife/configure_client_spec.rb +83 -0
  732. data/spec/unit/knife/configure_spec.rb +229 -0
  733. data/spec/unit/knife/cookbook_bulk_delete_spec.rb +87 -0
  734. data/spec/unit/knife/cookbook_create_spec.rb +271 -0
  735. data/spec/unit/knife/cookbook_delete_spec.rb +239 -0
  736. data/spec/unit/knife/cookbook_download_spec.rb +217 -0
  737. data/spec/unit/knife/cookbook_list_spec.rb +88 -0
  738. data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +65 -0
  739. data/spec/unit/knife/cookbook_metadata_spec.rb +172 -0
  740. data/spec/unit/knife/cookbook_show_spec.rb +223 -0
  741. data/spec/unit/knife/cookbook_site_download_spec.rb +151 -0
  742. data/spec/unit/knife/cookbook_site_install_spec.rb +148 -0
  743. data/spec/unit/knife/cookbook_site_share_spec.rb +146 -0
  744. data/spec/unit/knife/cookbook_site_unshare_spec.rb +77 -0
  745. data/spec/unit/knife/cookbook_test_spec.rb +83 -0
  746. data/spec/unit/knife/cookbook_upload_spec.rb +148 -0
  747. data/spec/unit/knife/core/bootstrap_context_spec.rb +135 -0
  748. data/spec/unit/knife/core/cookbook_scm_repo_spec.rb +187 -0
  749. data/spec/unit/knife/core/object_loader_spec.rb +81 -0
  750. data/spec/unit/knife/core/subcommand_loader_spec.rb +54 -0
  751. data/spec/unit/knife/core/ui_spec.rb +160 -0
  752. data/spec/unit/knife/data_bag_create_spec.rb +101 -0
  753. data/spec/unit/knife/data_bag_edit_spec.rb +96 -0
  754. data/spec/unit/knife/data_bag_from_file_spec.rb +198 -0
  755. data/spec/unit/knife/data_bag_show_spec.rb +105 -0
  756. data/spec/unit/knife/environment_create_spec.rb +91 -0
  757. data/spec/unit/knife/environment_delete_spec.rb +71 -0
  758. data/spec/unit/knife/environment_edit_spec.rb +79 -0
  759. data/spec/unit/knife/environment_from_file_spec.rb +89 -0
  760. data/spec/unit/knife/environment_list_spec.rb +54 -0
  761. data/spec/unit/knife/environment_show_spec.rb +52 -0
  762. data/spec/unit/knife/index_rebuild_spec.rb +65 -0
  763. data/spec/unit/knife/knife_help.rb +92 -0
  764. data/spec/unit/knife/node_bulk_delete_spec.rb +97 -0
  765. data/spec/unit/knife/node_delete_spec.rb +68 -0
  766. data/spec/unit/knife/node_edit_spec.rb +88 -0
  767. data/spec/unit/knife/node_from_file_spec.rb +59 -0
  768. data/spec/unit/knife/node_list_spec.rb +63 -0
  769. data/spec/unit/knife/node_run_list_add_spec.rb +125 -0
  770. data/spec/unit/knife/node_run_list_remove_spec.rb +73 -0
  771. data/spec/unit/knife/node_show_spec.rb +48 -0
  772. data/spec/unit/knife/role_bulk_delete_spec.rb +80 -0
  773. data/spec/unit/knife/role_create_spec.rb +80 -0
  774. data/spec/unit/knife/role_delete_spec.rb +67 -0
  775. data/spec/unit/knife/role_edit_spec.rb +79 -0
  776. data/spec/unit/knife/role_from_file_spec.rb +69 -0
  777. data/spec/unit/knife/role_list_spec.rb +56 -0
  778. data/spec/unit/knife/ssh_spec.rb +293 -0
  779. data/spec/unit/knife/status_spec.rb +43 -0
  780. data/spec/unit/knife/tag_create_spec.rb +23 -0
  781. data/spec/unit/knife/tag_delete_spec.rb +25 -0
  782. data/spec/unit/knife/tag_list_spec.rb +23 -0
  783. data/spec/unit/knife_spec.rb +295 -0
  784. data/spec/unit/log_spec.rb +24 -0
  785. data/spec/unit/lwrp_spec.rb +256 -0
  786. data/spec/unit/mash_spec.rb +51 -0
  787. data/spec/unit/mixin/checksum_spec.rb +41 -0
  788. data/spec/unit/mixin/command_spec.rb +105 -0
  789. data/spec/unit/mixin/convert_to_class_name_spec.rb +50 -0
  790. data/spec/unit/mixin/deep_merge_spec.rb +786 -0
  791. data/spec/unit/mixin/deprecation_spec.rb +34 -0
  792. data/spec/unit/mixin/enforce_ownership_and_permissions_spec.rb +90 -0
  793. data/spec/unit/mixin/language_spec.rb +305 -0
  794. data/spec/unit/mixin/params_validate_spec.rb +405 -0
  795. data/spec/unit/mixin/path_sanity_spec.rb +80 -0
  796. data/spec/unit/mixin/securable_spec.rb +254 -0
  797. data/spec/unit/mixin/shell_out_spec.rb +109 -0
  798. data/spec/unit/mixin/template_spec.rb +104 -0
  799. data/spec/unit/mixin/xml_escape_spec.rb +54 -0
  800. data/spec/unit/monkey_patches/string_spec.rb +37 -0
  801. data/spec/unit/node/attribute_spec.rb +1033 -0
  802. data/spec/unit/node_spec.rb +744 -0
  803. data/spec/unit/openid_registration_spec.rb +153 -0
  804. data/spec/unit/platform_spec.rb +241 -0
  805. data/spec/unit/provider/breakpoint_spec.rb +54 -0
  806. data/spec/unit/provider/cookbook_file_spec.rb +218 -0
  807. data/spec/unit/provider/cron/solaris_spec.rb +121 -0
  808. data/spec/unit/provider/cron_spec.rb +812 -0
  809. data/spec/unit/provider/deploy/revision_spec.rb +103 -0
  810. data/spec/unit/provider/deploy/timestamped_spec.rb +40 -0
  811. data/spec/unit/provider/deploy_spec.rb +620 -0
  812. data/spec/unit/provider/directory_spec.rb +156 -0
  813. data/spec/unit/provider/env_spec.rb +232 -0
  814. data/spec/unit/provider/erl_call_spec.rb +86 -0
  815. data/spec/unit/provider/execute_spec.rb +63 -0
  816. data/spec/unit/provider/file_spec.rb +505 -0
  817. data/spec/unit/provider/git_spec.rb +342 -0
  818. data/spec/unit/provider/group/dscl_spec.rb +294 -0
  819. data/spec/unit/provider/group/gpasswd_spec.rb +108 -0
  820. data/spec/unit/provider/group/groupadd_spec.rb +161 -0
  821. data/spec/unit/provider/group/groupmod_spec.rb +134 -0
  822. data/spec/unit/provider/group/pw_spec.rb +140 -0
  823. data/spec/unit/provider/group/usermod_spec.rb +95 -0
  824. data/spec/unit/provider/group/windows_spec.rb +94 -0
  825. data/spec/unit/provider/group_spec.rb +259 -0
  826. data/spec/unit/provider/http_request_spec.rb +178 -0
  827. data/spec/unit/provider/ifconfig_spec.rb +213 -0
  828. data/spec/unit/provider/link_spec.rb +252 -0
  829. data/spec/unit/provider/log_spec.rb +81 -0
  830. data/spec/unit/provider/mdadm_spec.rb +128 -0
  831. data/spec/unit/provider/mount/mount_spec.rb +398 -0
  832. data/spec/unit/provider/mount/windows_spec.rb +134 -0
  833. data/spec/unit/provider/mount_spec.rb +160 -0
  834. data/spec/unit/provider/ohai_spec.rb +85 -0
  835. data/spec/unit/provider/package/apt_spec.rb +352 -0
  836. data/spec/unit/provider/package/dpkg_spec.rb +216 -0
  837. data/spec/unit/provider/package/easy_install_spec.rb +112 -0
  838. data/spec/unit/provider/package/freebsd_spec.rb +259 -0
  839. data/spec/unit/provider/package/ips_spec.rb +210 -0
  840. data/spec/unit/provider/package/macports_spec.rb +203 -0
  841. data/spec/unit/provider/package/pacman_spec.rb +206 -0
  842. data/spec/unit/provider/package/portage_spec.rb +320 -0
  843. data/spec/unit/provider/package/rpm_spec.rb +152 -0
  844. data/spec/unit/provider/package/rubygems_spec.rb +639 -0
  845. data/spec/unit/provider/package/smartos_spec.rb +83 -0
  846. data/spec/unit/provider/package/solaris_spec.rb +181 -0
  847. data/spec/unit/provider/package/yum_spec.rb +1856 -0
  848. data/spec/unit/provider/package/zypper_spec.rb +159 -0
  849. data/spec/unit/provider/package_spec.rb +427 -0
  850. data/spec/unit/provider/remote_directory_spec.rb +222 -0
  851. data/spec/unit/provider/remote_file_spec.rb +288 -0
  852. data/spec/unit/provider/route_spec.rb +226 -0
  853. data/spec/unit/provider/ruby_block_spec.rb +38 -0
  854. data/spec/unit/provider/script_spec.rb +96 -0
  855. data/spec/unit/provider/service/arch_service_spec.rb +330 -0
  856. data/spec/unit/provider/service/debian_service_spec.rb +254 -0
  857. data/spec/unit/provider/service/freebsd_service_spec.rb +379 -0
  858. data/spec/unit/provider/service/gentoo_service_spec.rb +144 -0
  859. data/spec/unit/provider/service/init_service_spec.rb +212 -0
  860. data/spec/unit/provider/service/insserv_service_spec.rb +76 -0
  861. data/spec/unit/provider/service/invokercd_service_spec.rb +212 -0
  862. data/spec/unit/provider/service/macosx_spec.rb +229 -0
  863. data/spec/unit/provider/service/redhat_spec.rb +156 -0
  864. data/spec/unit/provider/service/simple_service_spec.rb +171 -0
  865. data/spec/unit/provider/service/solaris_smf_service_spec.rb +140 -0
  866. data/spec/unit/provider/service/systemd_service_spec.rb +239 -0
  867. data/spec/unit/provider/service/upstart_service_spec.rb +314 -0
  868. data/spec/unit/provider/service/windows_spec.rb +235 -0
  869. data/spec/unit/provider/service_spec.rb +169 -0
  870. data/spec/unit/provider/subversion_spec.rb +281 -0
  871. data/spec/unit/provider/template_spec.rb +196 -0
  872. data/spec/unit/provider/user/dscl_spec.rb +454 -0
  873. data/spec/unit/provider/user/pw_spec.rb +235 -0
  874. data/spec/unit/provider/user/solaris_spec.rb +414 -0
  875. data/spec/unit/provider/user/useradd_spec.rb +386 -0
  876. data/spec/unit/provider/user/windows_spec.rb +178 -0
  877. data/spec/unit/provider/user_spec.rb +468 -0
  878. data/spec/unit/provider_spec.rb +169 -0
  879. data/spec/unit/recipe_spec.rb +268 -0
  880. data/spec/unit/resource/apt_package_spec.rb +43 -0
  881. data/spec/unit/resource/bash_spec.rb +40 -0
  882. data/spec/unit/resource/breakpoint_spec.rb +43 -0
  883. data/spec/unit/resource/chef_gem_spec.rb +49 -0
  884. data/spec/unit/resource/conditional_spec.rb +147 -0
  885. data/spec/unit/resource/cookbook_file_spec.rb +89 -0
  886. data/spec/unit/resource/cron_spec.rb +181 -0
  887. data/spec/unit/resource/csh_spec.rb +40 -0
  888. data/spec/unit/resource/deploy_revision_spec.rb +47 -0
  889. data/spec/unit/resource/deploy_spec.rb +259 -0
  890. data/spec/unit/resource/directory_spec.rb +82 -0
  891. data/spec/unit/resource/dpkg_package_spec.rb +38 -0
  892. data/spec/unit/resource/easy_install_package_spec.rb +48 -0
  893. data/spec/unit/resource/env_spec.rb +85 -0
  894. data/spec/unit/resource/erl_call_spec.rb +81 -0
  895. data/spec/unit/resource/execute_spec.rb +124 -0
  896. data/spec/unit/resource/file_spec.rb +121 -0
  897. data/spec/unit/resource/freebsd_package_spec.rb +39 -0
  898. data/spec/unit/resource/gem_package_spec.rb +49 -0
  899. data/spec/unit/resource/git_spec.rb +46 -0
  900. data/spec/unit/resource/group_spec.rb +148 -0
  901. data/spec/unit/resource/http_request_spec.rb +59 -0
  902. data/spec/unit/resource/ifconfig_spec.rb +46 -0
  903. data/spec/unit/resource/ips_package_spec.rb +43 -0
  904. data/spec/unit/resource/link_spec.rb +118 -0
  905. data/spec/unit/resource/log_spec.rb +70 -0
  906. data/spec/unit/resource/macports_package_spec.rb +37 -0
  907. data/spec/unit/resource/mdadm_spec.rb +102 -0
  908. data/spec/unit/resource/mount_spec.rb +158 -0
  909. data/spec/unit/resource/ohai_spec.rb +62 -0
  910. data/spec/unit/resource/package_spec.rb +80 -0
  911. data/spec/unit/resource/pacman_package_spec.rb +38 -0
  912. data/spec/unit/resource/perl_spec.rb +40 -0
  913. data/spec/unit/resource/portage_package_spec.rb +38 -0
  914. data/spec/unit/resource/python_spec.rb +40 -0
  915. data/spec/unit/resource/remote_directory_spec.rb +97 -0
  916. data/spec/unit/resource/remote_file_spec.rb +125 -0
  917. data/spec/unit/resource/route_spec.rb +107 -0
  918. data/spec/unit/resource/rpm_package_spec.rb +38 -0
  919. data/spec/unit/resource/ruby_block_spec.rb +57 -0
  920. data/spec/unit/resource/ruby_spec.rb +40 -0
  921. data/spec/unit/resource/scm_spec.rb +159 -0
  922. data/spec/unit/resource/script_spec.rb +69 -0
  923. data/spec/unit/resource/service_spec.rb +165 -0
  924. data/spec/unit/resource/smartos_package_spec.rb +38 -0
  925. data/spec/unit/resource/subversion_spec.rb +58 -0
  926. data/spec/unit/resource/template_spec.rb +108 -0
  927. data/spec/unit/resource/timestamped_deploy_spec.rb +28 -0
  928. data/spec/unit/resource/user_spec.rb +122 -0
  929. data/spec/unit/resource/yum_package_spec.rb +85 -0
  930. data/spec/unit/resource_collection/stepable_iterator_spec.rb +144 -0
  931. data/spec/unit/resource_collection_spec.rb +257 -0
  932. data/spec/unit/resource_definition_spec.rb +119 -0
  933. data/spec/unit/resource_platform_map_spec.rb +164 -0
  934. data/spec/unit/resource_reporter_spec.rb +591 -0
  935. data/spec/unit/resource_spec.rb +721 -0
  936. data/spec/unit/rest/auth_credentials_spec.rb +431 -0
  937. data/spec/unit/rest_spec.rb +644 -0
  938. data/spec/unit/role_spec.rb +275 -0
  939. data/spec/unit/run_context_spec.rb +64 -0
  940. data/spec/unit/run_list/run_list_expansion_spec.rb +129 -0
  941. data/spec/unit/run_list/run_list_item_spec.rb +117 -0
  942. data/spec/unit/run_list/versioned_recipe_list_spec.rb +123 -0
  943. data/spec/unit/run_list_spec.rb +521 -0
  944. data/spec/unit/run_status_spec.rb +145 -0
  945. data/spec/unit/runner_spec.rb +303 -0
  946. data/spec/unit/scan_access_control_spec.rb +182 -0
  947. data/spec/unit/search/query_spec.rb +99 -0
  948. data/spec/unit/shef/model_wrapper_spec.rb +97 -0
  949. data/spec/unit/shef/shef_ext_spec.rb +153 -0
  950. data/spec/unit/shef/shef_session_spec.rb +154 -0
  951. data/spec/unit/shef_spec.rb +161 -0
  952. data/spec/unit/solr_query/query_transform_spec.rb +454 -0
  953. data/spec/unit/solr_query/solr_http_request_spec.rb +244 -0
  954. data/spec/unit/solr_query_spec.rb +203 -0
  955. data/spec/unit/util/file_edit_spec.rb +135 -0
  956. data/spec/unit/version_class_spec.rb +172 -0
  957. data/spec/unit/version_constraint_spec.rb +134 -0
  958. data/spec/unit/webui_user_spec.rb +238 -0
  959. data/tasks/rspec.rb +75 -0
  960. metadata +1548 -0
@@ -0,0 +1,83 @@
1
+ #
2
+ # Author:: Trevor O (trevoro@joyent.com)
3
+ # Copyright:: Copyright (c) 2012 Opscode
4
+ # License:: Apache License, Version 2.0
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # http://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+ #
18
+
19
+ require File.expand_path(File.join(File.dirname(__FILE__), "..", "..", "..", "spec_helper"))
20
+ require 'ostruct'
21
+
22
+ describe Chef::Provider::Package::SmartOS, "load_current_resource" do
23
+ before(:each) do
24
+ @node = Chef::Node.new
25
+ @events = Chef::EventDispatch::Dispatcher.new
26
+ @run_context = Chef::RunContext.new(@node, {}, @events)
27
+ @new_resource = Chef::Resource::Package.new("varnish")
28
+ @current_resource = Chef::Resource::Package.new("varnish")
29
+
30
+
31
+ @status = mock("Status", :exitstatus => 0)
32
+ @provider = Chef::Provider::Package::SmartOS.new(@new_resource, @run_context)
33
+ Chef::Resource::Package.stub!(:new).and_return(@current_resource)
34
+ @stdin = StringIO.new
35
+ @stdout = "varnish-2.1.5nb2\n"
36
+ @stderr = StringIO.new
37
+ @pid = 10
38
+ @shell_out = OpenStruct.new(:stdout => @stdout, :stdin => @stdin, :stderr => @stderr, :status => @status, :exitstatus => 0)
39
+ end
40
+
41
+ describe "when loading current resource" do
42
+
43
+ it "should create a current resource with the name of the new_resource" do
44
+ @provider.should_receive(:shell_out!).and_return(@shell_out)
45
+ Chef::Resource::Package.should_receive(:new).and_return(@current_resource)
46
+ @provider.load_current_resource
47
+ end
48
+
49
+ it "should set the current resource package name" do
50
+ @provider.should_receive(:shell_out!).and_return(@shell_out)
51
+ @current_resource.should_receive(:package_name).with(@new_resource.package_name)
52
+ @provider.load_current_resource
53
+ end
54
+
55
+ it "should set the installed version if it is installed" do
56
+ @provider.should_receive(:shell_out!).and_return(@shell_out)
57
+ @provider.load_current_resource
58
+ @current_resource.version.should == "2.1.5nb2"
59
+ end
60
+
61
+ it "should set the installed version to nil if it's not installed" do
62
+ out = OpenStruct.new(:stdout => nil)
63
+ @provider.should_receive(:shell_out!).and_return(out)
64
+ @provider.load_current_resource
65
+ @current_resource.version.should == nil
66
+ end
67
+
68
+
69
+ end
70
+
71
+ describe "when manipulating a resource" do
72
+
73
+ it "run pkgin and install the package" do
74
+ out = OpenStruct.new(:stdout => nil)
75
+ @provider.should_receive(:shell_out!).with("pkg_info -E \"varnish*\"", {:env => nil, :returns=>[0,1]}).and_return(@shell_out)
76
+ @provider.should_receive(:shell_out!).with("pkgin -y install varnish-2.1.5nb2", {:env=>nil}).and_return(out)
77
+ @provider.load_current_resource
78
+ @provider.install_package("varnish", "2.1.5nb2")
79
+ end
80
+
81
+ end
82
+
83
+ end
@@ -0,0 +1,181 @@
1
+ #
2
+ # Author:: Toomas Pelberg (<toomasp@gmx.net>)
3
+ # Copyright:: Copyright (c) 2010 Opscode, Inc.
4
+ # License:: Apache License, Version 2.0
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # http://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+ #
18
+ require 'spec_helper'
19
+
20
+ describe Chef::Provider::Package::Solaris do
21
+ before(:each) do
22
+ @node = Chef::Node.new
23
+ @events = Chef::EventDispatch::Dispatcher.new
24
+ @run_context = Chef::RunContext.new(@node, {}, @events)
25
+
26
+ @new_resource = Chef::Resource::Package.new("SUNWbash")
27
+ @new_resource.source("/tmp/bash.pkg")
28
+
29
+ @provider = Chef::Provider::Package::Solaris.new(@new_resource, @run_context)
30
+ ::File.stub!(:exists?).and_return(true)
31
+ end
32
+
33
+ describe "assessing the current package status" do
34
+ before do
35
+ @pkginfo =<<-PKGINFO
36
+ PKGINST: SUNWbash
37
+ NAME: GNU Bourne-Again shell (bash)
38
+ CATEGORY: system
39
+ ARCH: sparc
40
+ VERSION: 11.10.0,REV=2005.01.08.05.16
41
+ BASEDIR: /
42
+ VENDOR: Sun Microsystems, Inc.
43
+ DESC: GNU Bourne-Again shell (bash) version 3.0
44
+ PSTAMP: sfw10-patch20070430084444
45
+ INSTDATE: Nov 04 2009 01:02
46
+ HOTLINE: Please contact your local service provider
47
+ PKGINFO
48
+
49
+ @status = mock("Status", :exitstatus => 0)
50
+ end
51
+
52
+ it "should create a current resource with the name of new_resource" do
53
+ @provider.stub!(:popen4).and_return(@status)
54
+ @provider.load_current_resource
55
+ @provider.current_resource.name.should == "SUNWbash"
56
+ end
57
+
58
+ it "should set the current reource package name to the new resource package name" do
59
+ @provider.stub!(:popen4).and_return(@status)
60
+ @provider.load_current_resource
61
+ @provider.current_resource.package_name.should == "SUNWbash"
62
+ end
63
+
64
+ it "should raise an exception if a source is supplied but not found" do
65
+ @provider.stub!(:popen4).and_return(@status)
66
+ ::File.stub!(:exists?).and_return(false)
67
+ @provider.define_resource_requirements
68
+ @provider.load_current_resource
69
+ lambda { @provider.process_resource_requirements }.should raise_error(Chef::Exceptions::Package)
70
+ end
71
+
72
+
73
+ it "should get the source package version from pkginfo if provided" do
74
+ @stdout = StringIO.new(@pkginfo)
75
+ @stdin, @stderr = StringIO.new, StringIO.new
76
+ @provider.should_receive(:popen4).with("pkginfo -l -d /tmp/bash.pkg SUNWbash").and_yield(@pid, @stdin, @stdout, @stderr).and_return(@status)
77
+ @provider.should_receive(:popen4).with("pkginfo -l SUNWbash").and_return(@status)
78
+ @provider.load_current_resource
79
+
80
+ @provider.current_resource.package_name.should == "SUNWbash"
81
+ @new_resource.version.should == "11.10.0,REV=2005.01.08.05.16"
82
+ end
83
+
84
+ it "should return the current version installed if found by pkginfo" do
85
+ @stdout = StringIO.new(@pkginfo)
86
+ @stdin, @stderr = StringIO.new, StringIO.new
87
+ @provider.should_receive(:popen4).with("pkginfo -l -d /tmp/bash.pkg SUNWbash").and_return(@status)
88
+ @provider.should_receive(:popen4).with("pkginfo -l SUNWbash").and_yield(@pid, @stdin, @stdout, @stderr).and_return(@status)
89
+ @provider.load_current_resource
90
+ @provider.current_resource.version.should == "11.10.0,REV=2005.01.08.05.16"
91
+ end
92
+
93
+ it "should raise an exception if the source is not set but we are installing" do
94
+ @new_resource = Chef::Resource::Package.new("SUNWbash")
95
+ @provider = Chef::Provider::Package::Solaris.new(@new_resource, @run_context)
96
+ @provider.stub!(:popen4).and_return(@status)
97
+ lambda { @provider.run_action(:install) }.should raise_error(Chef::Exceptions::Package)
98
+ end
99
+
100
+ it "should raise an exception if pkginfo fails to run" do
101
+ @status = mock("Status", :exitstatus => -1)
102
+ @provider.stub!(:popen4).and_return(@status)
103
+ lambda { @provider.load_current_resource }.should raise_error(Chef::Exceptions::Package)
104
+ end
105
+
106
+ it "should return a current resource with a nil version if the package is not found" do
107
+ @stdout = StringIO.new
108
+ @provider.should_receive(:popen4).with("pkginfo -l -d /tmp/bash.pkg SUNWbash").and_return(@status)
109
+ @provider.should_receive(:popen4).with("pkginfo -l SUNWbash").and_yield(@pid, @stdin, @stdout, @stderr).and_return(@status)
110
+ @provider.load_current_resource
111
+ @provider.current_resource.version.should be_nil
112
+ end
113
+ end
114
+
115
+ describe "candidate_version" do
116
+ it "should return the candidate_version variable if already setup" do
117
+ @provider.candidate_version = "11.10.0,REV=2005.01.08.05.16"
118
+ @provider.should_not_receive(:popen4)
119
+ @provider.candidate_version
120
+ end
121
+
122
+ it "should lookup the candidate_version if the variable is not already set" do
123
+ @status = mock("Status", :exitstatus => 0)
124
+ @provider.stub!(:popen4).and_return(@status)
125
+ @provider.should_receive(:popen4)
126
+ @provider.candidate_version
127
+ end
128
+
129
+ it "should throw and exception if the exitstatus is not 0" do
130
+ @status = mock("Status", :exitstatus => 1)
131
+ @provider.stub!(:popen4).and_return(@status)
132
+ lambda { @provider.candidate_version }.should raise_error(Chef::Exceptions::Package)
133
+ end
134
+
135
+ end
136
+
137
+ describe "install and upgrade" do
138
+ it "should run pkgadd -n -d with the package source to install" do
139
+ @provider.should_receive(:run_command_with_systems_locale).with({
140
+ :command => "pkgadd -n -d /tmp/bash.pkg all"
141
+ })
142
+ @provider.install_package("SUNWbash", "11.10.0,REV=2005.01.08.05.16")
143
+ end
144
+
145
+ it "should run pkgadd -n -d when the package is a path to install" do
146
+ @new_resource = Chef::Resource::Package.new("/tmp/bash.pkg")
147
+ @provider = Chef::Provider::Package::Solaris.new(@new_resource, @run_context)
148
+ @new_resource.source.should == "/tmp/bash.pkg"
149
+ @provider.should_receive(:run_command_with_systems_locale).with({
150
+ :command => "pkgadd -n -d /tmp/bash.pkg all"
151
+ })
152
+ @provider.install_package("/tmp/bash.pkg", "11.10.0,REV=2005.01.08.05.16")
153
+ end
154
+
155
+ it "should run pkgadd -n -a /tmp/myadmin -d with the package options -a /tmp/myadmin" do
156
+ @new_resource.stub!(:options).and_return("-a /tmp/myadmin")
157
+ @provider.should_receive(:run_command_with_systems_locale).with({
158
+ :command => "pkgadd -n -a /tmp/myadmin -d /tmp/bash.pkg all"
159
+ })
160
+ @provider.install_package("SUNWbash", "11.10.0,REV=2005.01.08.05.16")
161
+ end
162
+ end
163
+
164
+ describe "remove" do
165
+ it "should run pkgrm -n to remove the package" do
166
+ @provider.should_receive(:run_command_with_systems_locale).with({
167
+ :command => "pkgrm -n SUNWbash"
168
+ })
169
+ @provider.remove_package("SUNWbash", "11.10.0,REV=2005.01.08.05.16")
170
+ end
171
+
172
+ it "should run pkgrm -n -a /tmp/myadmin with options -a /tmp/myadmin" do
173
+ @new_resource.stub!(:options).and_return("-a /tmp/myadmin")
174
+ @provider.should_receive(:run_command_with_systems_locale).with({
175
+ :command => "pkgrm -n -a /tmp/myadmin SUNWbash"
176
+ })
177
+ @provider.remove_package("SUNWbash", "11.10.0,REV=2005.01.08.05.16")
178
+ end
179
+
180
+ end
181
+ end
@@ -0,0 +1,1856 @@
1
+ #
2
+ # Author:: Adam Jacob (<adam@opscode.com>)
3
+ # Copyright:: Copyright (c) 2008 Opscode, Inc.
4
+ # License:: Apache License, Version 2.0
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # http://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+ #
18
+
19
+ require 'spec_helper'
20
+
21
+ describe Chef::Provider::Package::Yum do
22
+ before(:each) do
23
+ @node = Chef::Node.new
24
+ @events = Chef::EventDispatch::Dispatcher.new
25
+ @run_context = Chef::RunContext.new(@node, {}, @events)
26
+ @new_resource = Chef::Resource::Package.new('cups')
27
+ @status = mock("Status", :exitstatus => 0)
28
+ @yum_cache = mock(
29
+ 'Chef::Provider::Yum::YumCache',
30
+ :reload_installed => true,
31
+ :reset => true,
32
+ :installed_version => "1.2.4-11.18.el5",
33
+ :candidate_version => "1.2.4-11.18.el5_2.3",
34
+ :package_available? => true,
35
+ :version_available? => true,
36
+ :allow_multi_install => [ "kernel" ],
37
+ :package_repository => "base",
38
+ :disable_extra_repo_control => true
39
+ )
40
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
41
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
42
+ @pid = mock("PID")
43
+ end
44
+
45
+ describe "when loading the current system state" do
46
+ it "should create a current resource with the name of the new_resource" do
47
+ @provider.load_current_resource
48
+ @provider.current_resource.name.should == "cups"
49
+ end
50
+
51
+ it "should set the current resources package name to the new resources package name" do
52
+ @provider.load_current_resource
53
+ @provider.current_resource.package_name.should == "cups"
54
+ end
55
+
56
+ it "should set the installed version to nil on the current resource if no installed package" do
57
+ @yum_cache.stub!(:installed_version).and_return(nil)
58
+ @provider.load_current_resource
59
+ @provider.current_resource.version.should be_nil
60
+ end
61
+
62
+ it "should set the installed version if yum has one" do
63
+ @provider.load_current_resource
64
+ @provider.current_resource.version.should == "1.2.4-11.18.el5"
65
+ end
66
+
67
+ it "should set the candidate version if yum info has one" do
68
+ @provider.load_current_resource
69
+ @provider.candidate_version.should eql("1.2.4-11.18.el5_2.3")
70
+ end
71
+
72
+ it "should return the current resouce" do
73
+ @provider.load_current_resource.should eql(@provider.current_resource)
74
+ end
75
+
76
+ describe "when arch in package_name" do
77
+ it "should set the arch if no existing package_name is found and new_package_name+new_arch is available" do
78
+ @new_resource = Chef::Resource::YumPackage.new('testing.noarch')
79
+ @yum_cache = mock(
80
+ 'Chef::Provider::Yum::YumCache'
81
+ )
82
+ @yum_cache.stub!(:installed_version) do |package_name, arch|
83
+ # nothing installed for package_name/new_package_name
84
+ nil
85
+ end
86
+ @yum_cache.stub!(:candidate_version) do |package_name, arch|
87
+ if package_name == "testing.noarch" || package_name == "testing.more.noarch"
88
+ nil
89
+ # candidate for new_package_name
90
+ elsif package_name == "testing" || package_name == "testing.more"
91
+ "1.1"
92
+ end
93
+ end
94
+ @yum_cache.stub!(:package_available?).and_return(true)
95
+ @yum_cache.stub!(:disable_extra_repo_control).and_return(true)
96
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
97
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
98
+ @provider.load_current_resource
99
+ @provider.new_resource.package_name.should == "testing"
100
+ @provider.new_resource.arch.should == "noarch"
101
+ @provider.arch.should == "noarch"
102
+
103
+ @new_resource = Chef::Resource::YumPackage.new('testing.more.noarch')
104
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
105
+ @provider.load_current_resource
106
+ @provider.new_resource.package_name.should == "testing.more"
107
+ @provider.new_resource.arch.should == "noarch"
108
+ @provider.arch.should == "noarch"
109
+ end
110
+
111
+ it "should not set the arch when an existing package_name is found" do
112
+ @new_resource = Chef::Resource::YumPackage.new('testing.beta3')
113
+ @yum_cache = mock(
114
+ 'Chef::Provider::Yum::YumCache'
115
+ )
116
+ @yum_cache.stub!(:installed_version) do |package_name, arch|
117
+ # installed for package_name
118
+ if package_name == "testing.beta3" || package_name == "testing.beta3.more"
119
+ "1.1"
120
+ elsif package_name == "testing" || package_name == "testing.beta3"
121
+ nil
122
+ end
123
+ end
124
+ @yum_cache.stub!(:candidate_version) do |package_name, arch|
125
+ # no candidate for package_name/new_package_name
126
+ nil
127
+ end
128
+ @yum_cache.stub!(:package_available?).and_return(true)
129
+ @yum_cache.stub!(:disable_extra_repo_control).and_return(true)
130
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
131
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
132
+ # annoying side effect of the fun stub'ing above
133
+ @provider.load_current_resource
134
+ @provider.new_resource.package_name.should == "testing.beta3"
135
+ @provider.new_resource.arch.should == nil
136
+ @provider.arch.should == nil
137
+
138
+ @new_resource = Chef::Resource::YumPackage.new('testing.beta3.more')
139
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
140
+ @provider.load_current_resource
141
+ @provider.new_resource.package_name.should == "testing.beta3.more"
142
+ @provider.new_resource.arch.should == nil
143
+ @provider.arch.should == nil
144
+ end
145
+
146
+ it "should not set the arch when no existing package_name or new_package_name+new_arch is found" do
147
+ @new_resource = Chef::Resource::YumPackage.new('testing.beta3')
148
+ @yum_cache = mock(
149
+ 'Chef::Provider::Yum::YumCache'
150
+ )
151
+ @yum_cache.stub!(:installed_version) do |package_name, arch|
152
+ # nothing installed for package_name/new_package_name
153
+ nil
154
+ end
155
+ @yum_cache.stub!(:candidate_version) do |package_name, arch|
156
+ # no candidate for package_name/new_package_name
157
+ nil
158
+ end
159
+ @yum_cache.stub!(:package_available?).and_return(true)
160
+ @yum_cache.stub!(:disable_extra_repo_control).and_return(true)
161
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
162
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
163
+ @provider.load_current_resource
164
+ @provider.new_resource.package_name.should == "testing.beta3"
165
+ @provider.new_resource.arch.should == nil
166
+ @provider.arch.should == nil
167
+
168
+ @new_resource = Chef::Resource::YumPackage.new('testing.beta3.more')
169
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
170
+ @provider.load_current_resource
171
+ @provider.new_resource.package_name.should == "testing.beta3.more"
172
+ @provider.new_resource.arch.should == nil
173
+ @provider.arch.should == nil
174
+ end
175
+
176
+ it "should ensure it doesn't clobber an existing arch if passed" do
177
+ @new_resource = Chef::Resource::YumPackage.new('testing.i386')
178
+ @new_resource.arch("x86_64")
179
+ @yum_cache = mock(
180
+ 'Chef::Provider::Yum::YumCache'
181
+ )
182
+ @yum_cache.stub!(:installed_version) do |package_name, arch|
183
+ # nothing installed for package_name/new_package_name
184
+ nil
185
+ end
186
+ @yum_cache.stub!(:candidate_version) do |package_name, arch|
187
+ if package_name == "testing.noarch"
188
+ nil
189
+ # candidate for new_package_name
190
+ elsif package_name == "testing"
191
+ "1.1"
192
+ end
193
+ end.and_return("something")
194
+ @yum_cache.stub!(:package_available?).and_return(true)
195
+ @yum_cache.stub!(:disable_extra_repo_control).and_return(true)
196
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
197
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
198
+ @provider.load_current_resource
199
+ @provider.new_resource.package_name.should == "testing.i386"
200
+ @provider.new_resource.arch.should == "x86_64"
201
+ end
202
+ end
203
+
204
+ it "should flush the cache if :before is true" do
205
+ @new_resource.stub!(:flush_cache).and_return({:after => false, :before => true})
206
+ @yum_cache.should_receive(:reload).once
207
+ @provider.load_current_resource
208
+ end
209
+
210
+ it "should flush the cache if :before is false" do
211
+ @new_resource.stub!(:flush_cache).and_return({:after => false, :before => false})
212
+ @yum_cache.should_not_receive(:reload)
213
+ @provider.load_current_resource
214
+ end
215
+
216
+ it "should detect --enablerepo or --disablerepo when passed among options, collect them preserving order and notify the yum cache" do
217
+ @new_resource.stub!(:options).and_return("--stuff --enablerepo=foo --otherthings --disablerepo=a,b,c --enablerepo=bar")
218
+ @yum_cache.should_receive(:enable_extra_repo_control).with("--enablerepo=foo --disablerepo=a,b,c --enablerepo=bar")
219
+ @provider.load_current_resource
220
+ end
221
+
222
+ it "should let the yum cache know extra repos are disabled if --enablerepo or --disablerepo aren't among options" do
223
+ @new_resource.stub!(:options).and_return("--stuff --otherthings")
224
+ @yum_cache.should_receive(:disable_extra_repo_control)
225
+ @provider.load_current_resource
226
+ end
227
+
228
+ it "should let the yum cache know extra repos are disabled if options aren't set" do
229
+ @new_resource.stub!(:options).and_return(nil)
230
+ @yum_cache.should_receive(:disable_extra_repo_control)
231
+ @provider.load_current_resource
232
+ end
233
+
234
+ it "should search provides if package name can't be found then set package_name to match" do
235
+ @yum_cache = mock(
236
+ 'Chef::Provider::Yum::YumCache',
237
+ :reload_installed => true,
238
+ :reset => true,
239
+ :installed_version => "1.2.4-11.18.el5",
240
+ :candidate_version => "1.2.4-11.18.el5",
241
+ :package_available? => false,
242
+ :version_available? => true,
243
+ :disable_extra_repo_control => true
244
+ )
245
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
246
+ pkg = Chef::Provider::Package::Yum::RPMPackage.new("test-package", "1.2.4-11.18.el5", "x86_64", [])
247
+ @yum_cache.should_receive(:packages_from_require).and_return([pkg])
248
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
249
+ @provider.load_current_resource
250
+ @new_resource.package_name.should == "test-package"
251
+ end
252
+
253
+ it "should search provides if package name can't be found, warn about multiple matches, but use the first one" do
254
+ @yum_cache = mock(
255
+ 'Chef::Provider::Yum::YumCache',
256
+ :reload_installed => true,
257
+ :reset => true,
258
+ :installed_version => "1.2.4-11.18.el5",
259
+ :candidate_version => "1.2.4-11.18.el5",
260
+ :package_available? => false,
261
+ :version_available? => true,
262
+ :disable_extra_repo_control => true
263
+ )
264
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
265
+ pkg_x = Chef::Provider::Package::Yum::RPMPackage.new("test-package-x", "1.2.4-11.18.el5", "x86_64", [])
266
+ pkg_y = Chef::Provider::Package::Yum::RPMPackage.new("test-package-y", "1.2.6-11.3.el5", "i386", [])
267
+ @yum_cache.should_receive(:packages_from_require).and_return([pkg_x, pkg_y])
268
+ Chef::Log.should_receive(:warn).exactly(1).times.with(%r{matched multiple Provides})
269
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
270
+ @provider.load_current_resource
271
+ @new_resource.package_name.should == "test-package-x"
272
+ end
273
+
274
+ it "should search provides if no package is available - if no match in installed provides then load the complete set" do
275
+ @yum_cache = mock(
276
+ 'Chef::Provider::Yum::YumCache',
277
+ :reload_installed => true,
278
+ :reset => true,
279
+ :installed_version => "1.2.4-11.18.el5",
280
+ :candidate_version => "1.2.4-11.18.el5",
281
+ :package_available? => false,
282
+ :version_available? => true,
283
+ :disable_extra_repo_control => true
284
+ )
285
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
286
+ @yum_cache.should_receive(:packages_from_require).twice.and_return([])
287
+ @yum_cache.should_receive(:reload_provides)
288
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
289
+ @provider.load_current_resource
290
+ end
291
+
292
+ it "should search provides if no package is available and not load the complete set if action is :remove or :purge" do
293
+ @yum_cache = mock(
294
+ 'Chef::Provider::Yum::YumCache',
295
+ :reload_installed => true,
296
+ :reset => true,
297
+ :installed_version => "1.2.4-11.18.el5",
298
+ :candidate_version => "1.2.4-11.18.el5",
299
+ :package_available? => false,
300
+ :version_available? => true,
301
+ :disable_extra_repo_control => true
302
+ )
303
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
304
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
305
+ @yum_cache.should_receive(:packages_from_require).once.and_return([])
306
+ @yum_cache.should_not_receive(:reload_provides)
307
+ @new_resource.action(:remove)
308
+ @provider.load_current_resource
309
+ @yum_cache.should_receive(:packages_from_require).once.and_return([])
310
+ @yum_cache.should_not_receive(:reload_provides)
311
+ @new_resource.action(:purge)
312
+ @provider.load_current_resource
313
+ end
314
+
315
+ it "should search provides if no package is available - if no match in provides leave the name intact" do
316
+ @yum_cache = mock(
317
+ 'Chef::Provider::Yum::YumCache',
318
+ :reload_provides => true,
319
+ :reload_installed => true,
320
+ :reset => true,
321
+ :installed_version => "1.2.4-11.18.el5",
322
+ :candidate_version => "1.2.4-11.18.el5",
323
+ :package_available? => false,
324
+ :version_available? => true,
325
+ :disable_extra_repo_control => true
326
+ )
327
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
328
+ @yum_cache.should_receive(:packages_from_require).twice.and_return([])
329
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
330
+ @provider.load_current_resource
331
+ @new_resource.package_name.should == "cups"
332
+ end
333
+ end
334
+
335
+ describe "when installing a package" do
336
+ it "should run yum install with the package name and version" do
337
+ @provider.load_current_resource
338
+ Chef::Provider::Package::Yum::RPMUtils.stub!(:rpmvercmp).and_return(-1)
339
+ @provider.should_receive(:yum_command).with(
340
+ "yum -d0 -e0 -y install emacs-1.0"
341
+ )
342
+ @provider.install_package("emacs", "1.0")
343
+ end
344
+
345
+ it "should run yum localinstall if given a path to an rpm" do
346
+ @new_resource.stub!(:source).and_return("/tmp/emacs-21.4-20.el5.i386.rpm")
347
+ @provider.should_receive(:yum_command).with(
348
+ "yum -d0 -e0 -y localinstall /tmp/emacs-21.4-20.el5.i386.rpm"
349
+ )
350
+ @provider.install_package("emacs", "21.4-20.el5")
351
+ end
352
+
353
+ it "should run yum localinstall if given a path to an rpm as the package" do
354
+ @new_resource = Chef::Resource::Package.new("/tmp/emacs-21.4-20.el5.i386.rpm")
355
+ ::File.stub!(:exists?).and_return(true)
356
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
357
+ @new_resource.source.should == "/tmp/emacs-21.4-20.el5.i386.rpm"
358
+ @provider.should_receive(:yum_command).with(
359
+ "yum -d0 -e0 -y localinstall /tmp/emacs-21.4-20.el5.i386.rpm"
360
+ )
361
+ @provider.install_package("/tmp/emacs-21.4-20.el5.i386.rpm", "21.4-20.el5")
362
+ end
363
+
364
+ it "should run yum install with the package name, version and arch" do
365
+ @provider.load_current_resource
366
+ @new_resource.stub!(:arch).and_return("i386")
367
+ Chef::Provider::Package::Yum::RPMUtils.stub!(:rpmvercmp).and_return(-1)
368
+ @provider.should_receive(:yum_command).with(
369
+ "yum -d0 -e0 -y install emacs-21.4-20.el5.i386"
370
+ )
371
+ @provider.install_package("emacs", "21.4-20.el5")
372
+ end
373
+
374
+ it "installs the package with the options given in the resource" do
375
+ @provider.load_current_resource
376
+ @provider.candidate_version = '11'
377
+ @new_resource.stub!(:options).and_return("--disablerepo epmd")
378
+ Chef::Provider::Package::Yum::RPMUtils.stub!(:rpmvercmp).and_return(-1)
379
+ @provider.should_receive(:yum_command).with(
380
+ "yum -d0 -e0 -y --disablerepo epmd install cups-11"
381
+ )
382
+ @provider.install_package(@new_resource.name, @provider.candidate_version)
383
+ end
384
+
385
+ it "should raise an exception if the package is not available" do
386
+ @yum_cache = mock(
387
+ 'Chef::Provider::Yum::YumCache',
388
+ :reload_from_cache => true,
389
+ :reset => true,
390
+ :installed_version => "1.2.4-11.18.el5",
391
+ :candidate_version => "1.2.4-11.18.el5_2.3",
392
+ :package_available? => true,
393
+ :version_available? => nil,
394
+ :disable_extra_repo_control => true
395
+ )
396
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
397
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
398
+ lambda { @provider.install_package("lolcats", "0.99") }.should raise_error(Chef::Exceptions::Package, %r{Version .* not found})
399
+ end
400
+
401
+ it "should raise an exception if candidate version is older than the installed version and allow_downgrade is false" do
402
+ @new_resource.stub!(:allow_downgrade).and_return(false)
403
+ @yum_cache = mock(
404
+ 'Chef::Provider::Yum::YumCache',
405
+ :reload_installed => true,
406
+ :reset => true,
407
+ :installed_version => "1.2.4-11.18.el5",
408
+ :candidate_version => "1.2.4-11.15.el5",
409
+ :package_available? => true,
410
+ :version_available? => true,
411
+ :allow_multi_install => [ "kernel" ],
412
+ :disable_extra_repo_control => true
413
+ )
414
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
415
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
416
+ @provider.load_current_resource
417
+ lambda { @provider.install_package("cups", "1.2.4-11.15.el5") }.should raise_error(Chef::Exceptions::Package, %r{is newer than candidate package})
418
+ end
419
+
420
+ it "should not raise an exception if candidate version is older than the installed version and the package is list in yum's installonlypkg option" do
421
+ @yum_cache = mock(
422
+ 'Chef::Provider::Yum::YumCache',
423
+ :reload_installed => true,
424
+ :reset => true,
425
+ :installed_version => "1.2.4-11.18.el5",
426
+ :candidate_version => "1.2.4-11.15.el5",
427
+ :package_available? => true,
428
+ :version_available? => true,
429
+ :allow_multi_install => [ "cups" ],
430
+ :package_repository => "base",
431
+ :disable_extra_repo_control => true
432
+ )
433
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
434
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
435
+ @provider.load_current_resource
436
+ @provider.should_receive(:yum_command).with(
437
+ "yum -d0 -e0 -y install cups-1.2.4-11.15.el5"
438
+ )
439
+ @provider.install_package("cups", "1.2.4-11.15.el5")
440
+ end
441
+
442
+ it "should run yum downgrade if candidate version is older than the installed version and allow_downgrade is true" do
443
+ @new_resource.stub!(:allow_downgrade).and_return(true)
444
+ @yum_cache = mock(
445
+ 'Chef::Provider::Yum::YumCache',
446
+ :reload_installed => true,
447
+ :reset => true,
448
+ :installed_version => "1.2.4-11.18.el5",
449
+ :candidate_version => "1.2.4-11.15.el5",
450
+ :package_available? => true,
451
+ :version_available? => true,
452
+ :allow_multi_install => [],
453
+ :package_repository => "base",
454
+ :disable_extra_repo_control => true
455
+ )
456
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
457
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
458
+ @provider.load_current_resource
459
+ @provider.should_receive(:yum_command).with(
460
+ "yum -d0 -e0 -y downgrade cups-1.2.4-11.15.el5"
461
+ )
462
+ @provider.install_package("cups", "1.2.4-11.15.el5")
463
+ end
464
+
465
+ it "should run yum install then flush the cache if :after is true" do
466
+ @new_resource.stub!(:flush_cache).and_return({:after => true, :before => false})
467
+ @provider.load_current_resource
468
+ Chef::Provider::Package::Yum::RPMUtils.stub!(:rpmvercmp).and_return(-1)
469
+ @provider.should_receive(:yum_command).with(
470
+ "yum -d0 -e0 -y install emacs-1.0"
471
+ )
472
+ @yum_cache.should_receive(:reload).once
473
+ @provider.install_package("emacs", "1.0")
474
+ end
475
+
476
+ it "should run yum install then not flush the cache if :after is false" do
477
+ @new_resource.stub!(:flush_cache).and_return({:after => false, :before => false})
478
+ @provider.load_current_resource
479
+ Chef::Provider::Package::Yum::RPMUtils.stub!(:rpmvercmp).and_return(-1)
480
+ @provider.should_receive(:yum_command).with(
481
+ "yum -d0 -e0 -y install emacs-1.0"
482
+ )
483
+ @yum_cache.should_not_receive(:reload)
484
+ @provider.install_package("emacs", "1.0")
485
+ end
486
+ end
487
+
488
+ describe "when upgrading a package" do
489
+ it "should run yum install if the package is installed and a version is given" do
490
+ @provider.load_current_resource
491
+ @provider.candidate_version = '11'
492
+ Chef::Provider::Package::Yum::RPMUtils.stub!(:rpmvercmp).and_return(-1)
493
+ @provider.should_receive(:yum_command).with(
494
+ "yum -d0 -e0 -y install cups-11"
495
+ )
496
+ @provider.upgrade_package(@new_resource.name, @provider.candidate_version)
497
+ end
498
+
499
+ it "should run yum install if the package is not installed" do
500
+ @provider.load_current_resource
501
+ @current_resource = Chef::Resource::Package.new('cups')
502
+ @provider.candidate_version = '11'
503
+ Chef::Provider::Package::Yum::RPMUtils.stub!(:rpmvercmp).and_return(-1)
504
+ @provider.should_receive(:yum_command).with(
505
+ "yum -d0 -e0 -y install cups-11"
506
+ )
507
+ @provider.upgrade_package(@new_resource.name, @provider.candidate_version)
508
+ end
509
+
510
+ it "should raise an exception if candidate version is older than the installed version" do
511
+ @yum_cache = mock(
512
+ 'Chef::Provider::Yum::YumCache',
513
+ :reload_installed => true,
514
+ :reset => true,
515
+ :installed_version => "1.2.4-11.18.el5",
516
+ :candidate_version => "1.2.4-11.15.el5",
517
+ :package_available? => true,
518
+ :version_available? => true,
519
+ :allow_multi_install => [ "kernel" ],
520
+ :disable_extra_repo_control => true
521
+ )
522
+ Chef::Provider::Package::Yum::YumCache.stub!(:instance).and_return(@yum_cache)
523
+ @provider = Chef::Provider::Package::Yum.new(@new_resource, @run_context)
524
+ @provider.load_current_resource
525
+ lambda { @provider.upgrade_package("cups", "1.2.4-11.15.el5") }.should raise_error(Chef::Exceptions::Package, %r{is newer than candidate package})
526
+ end
527
+
528
+ # Test our little workaround, some crossover into Chef::Provider::Package territory
529
+ it "should call action_upgrade in the parent if the current resource version is nil" do
530
+ @yum_cache.stub!(:installed_version).and_return(nil)
531
+ @provider.load_current_resource
532
+ @current_resource = Chef::Resource::Package.new('cups')
533
+ @provider.candidate_version = '11'
534
+ @provider.should_receive(:upgrade_package).with(
535
+ "cups",
536
+ "11"
537
+ )
538
+ @provider.action_upgrade
539
+ end
540
+
541
+ it "should call action_upgrade in the parent if the candidate version is nil" do
542
+ @provider.load_current_resource
543
+ @current_resource = Chef::Resource::Package.new('cups')
544
+ @provider.candidate_version = nil
545
+ @provider.should_not_receive(:upgrade_package)
546
+ @provider.action_upgrade
547
+ end
548
+
549
+ it "should call action_upgrade in the parent if the candidate is newer" do
550
+ @provider.load_current_resource
551
+ @current_resource = Chef::Resource::Package.new('cups')
552
+ @provider.candidate_version = '11'
553
+ @provider.should_receive(:upgrade_package).with(
554
+ "cups",
555
+ "11"
556
+ )
557
+ @provider.action_upgrade
558
+ end
559
+
560
+ it "should not call action_upgrade in the parent if the candidate is older" do
561
+ @yum_cache.stub!(:installed_version).and_return("12")
562
+ @provider.load_current_resource
563
+ @current_resource = Chef::Resource::Package.new('cups')
564
+ @provider.candidate_version = '11'
565
+ @provider.should_not_receive(:upgrade_package)
566
+ @provider.action_upgrade
567
+ end
568
+ end
569
+
570
+ describe "when removing a package" do
571
+ it "should run yum remove with the package name" do
572
+ @provider.should_receive(:yum_command).with(
573
+ "yum -d0 -e0 -y remove emacs-1.0"
574
+ )
575
+ @provider.remove_package("emacs", "1.0")
576
+ end
577
+
578
+ it "should run yum remove with the package name and arch" do
579
+ @new_resource.stub!(:arch).and_return("x86_64")
580
+ @provider.should_receive(:yum_command).with(
581
+ "yum -d0 -e0 -y remove emacs-1.0.x86_64"
582
+ )
583
+ @provider.remove_package("emacs", "1.0")
584
+ end
585
+ end
586
+
587
+ describe "when purging a package" do
588
+ it "should run yum remove with the package name" do
589
+ @provider.should_receive(:yum_command).with(
590
+ "yum -d0 -e0 -y remove emacs-1.0"
591
+ )
592
+ @provider.purge_package("emacs", "1.0")
593
+ end
594
+ end
595
+
596
+ describe "when running yum" do
597
+ it "should run yum once if it exits with a return code of 0" do
598
+ @status = mock("Status", :exitstatus => 0)
599
+ @provider.stub!(:output_of_command).and_return([@status, "", ""])
600
+ @provider.should_receive(:output_of_command).once.with(
601
+ "yum -d0 -e0 -y install emacs-1.0",
602
+ {:timeout => Chef::Config[:yum_timeout]}
603
+ )
604
+ @provider.yum_command("yum -d0 -e0 -y install emacs-1.0")
605
+ end
606
+
607
+ it "should run yum once if it exits with a return code > 0 and no scriptlet failures" do
608
+ @status = mock("Status", :exitstatus => 2)
609
+ @provider.stub!(:output_of_command).and_return([@status, "failure failure", "problem problem"])
610
+ @provider.should_receive(:output_of_command).once.with(
611
+ "yum -d0 -e0 -y install emacs-1.0",
612
+ {:timeout => Chef::Config[:yum_timeout]}
613
+ )
614
+ lambda { @provider.yum_command("yum -d0 -e0 -y install emacs-1.0") }.should raise_error(Chef::Exceptions::Exec)
615
+ end
616
+
617
+ it "should run yum once if it exits with a return code of 1 and %pre scriptlet failures" do
618
+ @status = mock("Status", :exitstatus => 1)
619
+ @provider.stub!(:output_of_command).and_return([@status, "error: %pre(demo-1-1.el5.centos.x86_64) scriptlet failed, exit status 2", ""])
620
+ @provider.should_receive(:output_of_command).once.with(
621
+ "yum -d0 -e0 -y install emacs-1.0",
622
+ {:timeout => Chef::Config[:yum_timeout]}
623
+ )
624
+ # will still raise an exception, can't stub out the subsequent call
625
+ lambda { @provider.yum_command("yum -d0 -e0 -y install emacs-1.0") }.should raise_error(Chef::Exceptions::Exec)
626
+ end
627
+
628
+ it "should run yum twice if it exits with a return code of 1 and %post scriptlet failures" do
629
+ @status = mock("Status", :exitstatus => 1)
630
+ @provider.stub!(:output_of_command).and_return([@status, "error: %post(demo-1-1.el5.centos.x86_64) scriptlet failed, exit status 2", ""])
631
+ @provider.should_receive(:output_of_command).twice.with(
632
+ "yum -d0 -e0 -y install emacs-1.0",
633
+ {:timeout => Chef::Config[:yum_timeout]}
634
+ )
635
+ # will still raise an exception, can't stub out the subsequent call
636
+ lambda { @provider.yum_command("yum -d0 -e0 -y install emacs-1.0") }.should raise_error(Chef::Exceptions::Exec)
637
+ end
638
+ end
639
+ end
640
+
641
+ describe Chef::Provider::Package::Yum::RPMUtils do
642
+ describe "version_parse" do
643
+ before do
644
+ @rpmutils = Chef::Provider::Package::Yum::RPMUtils
645
+ end
646
+
647
+ it "parses known good epoch strings" do
648
+ [
649
+ [ "0:3.3", [ 0, "3.3", nil ] ],
650
+ [ "9:1.7.3", [ 9, "1.7.3", nil ] ],
651
+ [ "15:20020927", [ 15, "20020927", nil ] ]
652
+ ].each do |x, y|
653
+ @rpmutils.version_parse(x).should == y
654
+ end
655
+ end
656
+
657
+ it "parses strange epoch strings" do
658
+ [
659
+ [ ":3.3", [ 0, "3.3", nil ] ],
660
+ [ "-1:1.7.3", [ nil, nil, "1:1.7.3" ] ],
661
+ [ "-:20020927", [ nil, nil, ":20020927" ] ]
662
+ ].each do |x, y|
663
+ @rpmutils.version_parse(x).should == y
664
+ end
665
+ end
666
+
667
+ it "parses known good version strings" do
668
+ [
669
+ [ "3.3", [ nil, "3.3", nil ] ],
670
+ [ "1.7.3", [ nil, "1.7.3", nil ] ],
671
+ [ "20020927", [ nil, "20020927", nil ] ]
672
+ ].each do |x, y|
673
+ @rpmutils.version_parse(x).should == y
674
+ end
675
+ end
676
+
677
+ it "parses strange version strings" do
678
+ [
679
+ [ "3..3", [ nil, "3..3", nil ] ],
680
+ [ "0001.7.3", [ nil, "0001.7.3", nil ] ],
681
+ [ "20020927,3", [ nil, "20020927,3", nil ] ]
682
+ ].each do |x, y|
683
+ @rpmutils.version_parse(x).should == y
684
+ end
685
+ end
686
+
687
+ it "parses known good version release strings" do
688
+ [
689
+ [ "3.3-0.pre3.1.60.el5_5.1", [ nil, "3.3", "0.pre3.1.60.el5_5.1" ] ],
690
+ [ "1.7.3-1jpp.2.el5", [ nil, "1.7.3", "1jpp.2.el5" ] ],
691
+ [ "20020927-46.el5", [ nil, "20020927", "46.el5" ] ]
692
+ ].each do |x, y|
693
+ @rpmutils.version_parse(x).should == y
694
+ end
695
+ end
696
+
697
+ it "parses strange version release strings" do
698
+ [
699
+ [ "3.3-", [ nil, "3.3", nil ] ],
700
+ [ "-1jpp.2.el5", [ nil, nil, "1jpp.2.el5" ] ],
701
+ [ "-0020020927-46.el5", [ nil, "-0020020927", "46.el5" ] ]
702
+ ].each do |x, y|
703
+ @rpmutils.version_parse(x).should == y
704
+ end
705
+ end
706
+ end
707
+
708
+ describe "rpmvercmp" do
709
+ before do
710
+ @rpmutils = Chef::Provider::Package::Yum::RPMUtils
711
+ end
712
+
713
+ it "should validate version compare logic for standard examples" do
714
+ [
715
+ # numeric
716
+ [ "0.0.2", "0.0.1", 1 ],
717
+ [ "0.2.0", "0.1.0", 1 ],
718
+ [ "2.0.0", "1.0.0", 1 ],
719
+ [ "0.0.1", "0.0.1", 0 ],
720
+ [ "0.0.1", "0.0.2", -1 ],
721
+ [ "0.1.0", "0.2.0", -1 ],
722
+ [ "1.0.0", "2.0.0", -1 ],
723
+ # alpha
724
+ [ "bb", "aa", 1 ],
725
+ [ "ab", "aa", 1 ],
726
+ [ "aa", "aa", 0 ],
727
+ [ "aa", "bb", -1 ],
728
+ [ "aa", "ab", -1 ],
729
+ [ "BB", "AA", 1 ],
730
+ [ "AA", "AA", 0 ],
731
+ [ "AA", "BB", -1 ],
732
+ [ "aa", "AA", 1 ],
733
+ [ "AA", "aa", -1 ],
734
+ # alphanumeric
735
+ [ "0.0.1b", "0.0.1a", 1 ],
736
+ [ "0.1b.0", "0.1a.0", 1 ],
737
+ [ "1b.0.0", "1a.0.0", 1 ],
738
+ [ "0.0.1a", "0.0.1a", 0 ],
739
+ [ "0.0.1a", "0.0.1b", -1 ],
740
+ [ "0.1a.0", "0.1b.0", -1 ],
741
+ [ "1a.0.0", "1b.0.0", -1 ],
742
+ # alphanumeric against alphanumeric
743
+ [ "0.0.1", "0.0.a", 1 ],
744
+ [ "0.1.0", "0.a.0", 1 ],
745
+ [ "1.0.0", "a.0.0", 1 ],
746
+ [ "0.0.a", "0.0.a", 0 ],
747
+ [ "0.0.a", "0.0.1", -1 ],
748
+ [ "0.a.0", "0.1.0", -1 ],
749
+ [ "a.0.0", "1.0.0", -1 ],
750
+ # alphanumeric against numeric
751
+ [ "0.0.2", "0.0.1a", 1 ],
752
+ [ "0.0.2a", "0.0.1", 1 ],
753
+ [ "0.0.1", "0.0.2a", -1 ],
754
+ [ "0.0.1a", "0.0.2", -1 ],
755
+ # length
756
+ [ "0.0.1aa", "0.0.1a", 1 ],
757
+ [ "0.0.1aa", "0.0.1aa", 0 ],
758
+ [ "0.0.1a", "0.0.1aa", -1 ],
759
+ ].each do |x, y, result|
760
+ @rpmutils.rpmvercmp(x,y).should == result
761
+ end
762
+ end
763
+
764
+ it "should validate version compare logic for strange examples" do
765
+ [
766
+ [ "2,0,0", "1.0.0", 1 ],
767
+ [ "0.0.1", "0,0.1", 0 ],
768
+ [ "1.0.0", "2,0,0", -1 ],
769
+ [ "002.0.0", "001.0.0", 1 ],
770
+ [ "001..0.1", "001..0.0", 1 ],
771
+ [ "-001..1", "-001..0", 1 ],
772
+ [ "1.0.1", nil, 1 ],
773
+ [ nil, nil, 0 ],
774
+ [ nil, "1.0.1", -1 ],
775
+ [ "1.0.1", "", 1 ],
776
+ [ "", "", 0 ],
777
+ [ "", "1.0.1", -1 ]
778
+ ].each do |x, y, result|
779
+ @rpmutils.rpmvercmp(x,y).should == result
780
+ end
781
+ end
782
+
783
+ it "tests isalnum good input" do
784
+ [ 'a', 'z', 'A', 'Z', '0', '9' ].each do |t|
785
+ @rpmutils.isalnum(t).should == true
786
+ end
787
+ end
788
+
789
+ it "tests isalnum bad input" do
790
+ [ '-', '.', '!', '^', ':', '_' ].each do |t|
791
+ @rpmutils.isalnum(t).should == false
792
+ end
793
+ end
794
+
795
+ it "tests isalpha good input" do
796
+ [ 'a', 'z', 'A', 'Z', ].each do |t|
797
+ @rpmutils.isalpha(t).should == true
798
+ end
799
+ end
800
+
801
+ it "tests isalpha bad input" do
802
+ [ '0', '9', '-', '.', '!', '^', ':', '_' ].each do |t|
803
+ @rpmutils.isalpha(t).should == false
804
+ end
805
+ end
806
+
807
+ it "tests isdigit good input" do
808
+ [ '0', '9', ].each do |t|
809
+ @rpmutils.isdigit(t).should == true
810
+ end
811
+ end
812
+
813
+ it "tests isdigit bad input" do
814
+ [ 'A', 'z', '-', '.', '!', '^', ':', '_' ].each do |t|
815
+ @rpmutils.isdigit(t).should == false
816
+ end
817
+ end
818
+ end
819
+
820
+ end
821
+
822
+ describe Chef::Provider::Package::Yum::RPMVersion do
823
+ describe "new - with parsing" do
824
+ before do
825
+ @rpmv = Chef::Provider::Package::Yum::RPMVersion.new("1:1.6.5-9.36.el5")
826
+ end
827
+
828
+ it "should expose evr (name-version-release) available" do
829
+ @rpmv.e.should == 1
830
+ @rpmv.v.should == "1.6.5"
831
+ @rpmv.r.should == "9.36.el5"
832
+
833
+ @rpmv.evr.should == "1:1.6.5-9.36.el5"
834
+ end
835
+
836
+ it "should output a version-release string" do
837
+ @rpmv.to_s.should == "1.6.5-9.36.el5"
838
+ end
839
+ end
840
+
841
+ describe "new - no parsing" do
842
+ before do
843
+ @rpmv = Chef::Provider::Package::Yum::RPMVersion.new("1", "1.6.5", "9.36.el5")
844
+ end
845
+
846
+ it "should expose evr (name-version-release) available" do
847
+ @rpmv.e.should == 1
848
+ @rpmv.v.should == "1.6.5"
849
+ @rpmv.r.should == "9.36.el5"
850
+
851
+ @rpmv.evr.should == "1:1.6.5-9.36.el5"
852
+ end
853
+
854
+ it "should output a version-release string" do
855
+ @rpmv.to_s.should == "1.6.5-9.36.el5"
856
+ end
857
+ end
858
+
859
+ it "should raise an error unless passed 1 or 3 args" do
860
+ lambda {
861
+ Chef::Provider::Package::Yum::RPMVersion.new()
862
+ }.should raise_error(ArgumentError)
863
+ lambda {
864
+ Chef::Provider::Package::Yum::RPMVersion.new("1:1.6.5-9.36.el5")
865
+ }.should_not raise_error
866
+ lambda {
867
+ Chef::Provider::Package::Yum::RPMVersion.new("1:1.6.5-9.36.el5", "extra")
868
+ }.should raise_error(ArgumentError)
869
+ lambda {
870
+ Chef::Provider::Package::Yum::RPMVersion.new("1", "1.6.5", "9.36.el5")
871
+ }.should_not raise_error
872
+ lambda {
873
+ Chef::Provider::Package::Yum::RPMVersion.new("1", "1.6.5", "9.36.el5", "extra")
874
+ }.should raise_error(ArgumentError)
875
+ end
876
+
877
+ # thanks version_class_spec.rb!
878
+ describe "compare" do
879
+ it "should sort based on complete epoch-version-release data" do
880
+ [
881
+ # smaller, larger
882
+ [ "0:1.6.5-9.36.el5",
883
+ "1:1.6.5-9.36.el5" ],
884
+ [ "0:2.3-15.el5",
885
+ "0:3.3-15.el5" ],
886
+ [ "0:alpha9.8-27.2",
887
+ "0:beta9.8-27.2" ],
888
+ [ "0:0.09-14jpp.3",
889
+ "0:0.09-15jpp.3" ],
890
+ [ "0:0.9.0-0.6.20110211.el5",
891
+ "0:0.9.0-0.6.20120211.el5" ],
892
+ [ "0:1.9.1-4.el5",
893
+ "0:1.9.1-5.el5" ],
894
+ [ "0:1.4.10-7.20090624svn.el5",
895
+ "0:1.4.10-7.20090625svn.el5" ],
896
+ [ "0:2.3.4-2.el5",
897
+ "0:2.3.4-2.el6" ]
898
+ ].each do |smaller, larger|
899
+ sm = Chef::Provider::Package::Yum::RPMVersion.new(smaller)
900
+ lg = Chef::Provider::Package::Yum::RPMVersion.new(larger)
901
+ sm.should be < lg
902
+ lg.should be > sm
903
+ sm.should_not == lg
904
+ end
905
+ end
906
+
907
+ it "should sort based on partial epoch-version-release data" do
908
+ [
909
+ # smaller, larger
910
+ [ ":1.6.5-9.36.el5",
911
+ "1:1.6.5-9.36.el5" ],
912
+ [ "2.3-15.el5",
913
+ "3.3-15.el5" ],
914
+ [ "alpha9.8",
915
+ "beta9.8" ],
916
+ [ "14jpp",
917
+ "15jpp" ],
918
+ [ "0.9.0-0.6",
919
+ "0.9.0-0.7" ],
920
+ [ "0:1.9",
921
+ "3:1.9" ],
922
+ [ "2.3-2.el5",
923
+ "2.3-2.el6" ]
924
+ ].each do |smaller, larger|
925
+ sm = Chef::Provider::Package::Yum::RPMVersion.new(smaller)
926
+ lg = Chef::Provider::Package::Yum::RPMVersion.new(larger)
927
+ sm.should be < lg
928
+ lg.should be > sm
929
+ sm.should_not == lg
930
+ end
931
+ end
932
+
933
+ it "should verify equality of complete epoch-version-release data" do
934
+ [
935
+ [ "0:1.6.5-9.36.el5",
936
+ "0:1.6.5-9.36.el5" ],
937
+ [ "0:2.3-15.el5",
938
+ "0:2.3-15.el5" ],
939
+ [ "0:alpha9.8-27.2",
940
+ "0:alpha9.8-27.2" ]
941
+ ].each do |smaller, larger|
942
+ sm = Chef::Provider::Package::Yum::RPMVersion.new(smaller)
943
+ lg = Chef::Provider::Package::Yum::RPMVersion.new(larger)
944
+ sm.should be == lg
945
+ end
946
+ end
947
+
948
+ it "should verify equality of partial epoch-version-release data" do
949
+ [
950
+ [ ":1.6.5-9.36.el5",
951
+ "0:1.6.5-9.36.el5" ],
952
+ [ "2.3-15.el5",
953
+ "2.3-15.el5" ],
954
+ [ "alpha9.8-3",
955
+ "alpha9.8-3" ]
956
+ ].each do |smaller, larger|
957
+ sm = Chef::Provider::Package::Yum::RPMVersion.new(smaller)
958
+ lg = Chef::Provider::Package::Yum::RPMVersion.new(larger)
959
+ sm.should be == lg
960
+ end
961
+ end
962
+ end
963
+
964
+ describe "partial compare" do
965
+ it "should compare based on partial epoch-version-release data" do
966
+ [
967
+ # smaller, larger
968
+ [ "0:1.1.1-1",
969
+ "1:" ],
970
+ [ "0:1.1.1-1",
971
+ "0:1.1.2" ],
972
+ [ "0:1.1.1-1",
973
+ "0:1.1.2-1" ],
974
+ [ "0:",
975
+ "1:1.1.1-1" ],
976
+ [ "0:1.1.1",
977
+ "0:1.1.2-1" ],
978
+ [ "0:1.1.1-1",
979
+ "0:1.1.2-1" ],
980
+ ].each do |smaller, larger|
981
+ sm = Chef::Provider::Package::Yum::RPMVersion.new(smaller)
982
+ lg = Chef::Provider::Package::Yum::RPMVersion.new(larger)
983
+ sm.partial_compare(lg).should be == -1
984
+ lg.partial_compare(sm).should be == 1
985
+ sm.partial_compare(lg).should_not be == 0
986
+ end
987
+ end
988
+
989
+ it "should verify equality based on partial epoch-version-release data" do
990
+ [
991
+ [ "0:",
992
+ "0:1.1.1-1" ],
993
+ [ "0:1.1.1",
994
+ "0:1.1.1-1" ],
995
+ [ "0:1.1.1-1",
996
+ "0:1.1.1-1" ],
997
+ ].each do |smaller, larger|
998
+ sm = Chef::Provider::Package::Yum::RPMVersion.new(smaller)
999
+ lg = Chef::Provider::Package::Yum::RPMVersion.new(larger)
1000
+ sm.partial_compare(lg).should be == 0
1001
+ end
1002
+ end
1003
+ end
1004
+
1005
+ end
1006
+
1007
+ describe Chef::Provider::Package::Yum::RPMPackage do
1008
+ describe "new - with parsing" do
1009
+ before do
1010
+ @rpm = Chef::Provider::Package::Yum::RPMPackage.new("testing", "1:1.6.5-9.36.el5", "x86_64", [])
1011
+ end
1012
+
1013
+ it "should expose nevra (name-epoch-version-release-arch) available" do
1014
+ @rpm.name.should == "testing"
1015
+ @rpm.version.e.should == 1
1016
+ @rpm.version.v.should == "1.6.5"
1017
+ @rpm.version.r.should == "9.36.el5"
1018
+ @rpm.arch.should == "x86_64"
1019
+
1020
+ @rpm.nevra.should == "testing-1:1.6.5-9.36.el5.x86_64"
1021
+ @rpm.to_s.should == @rpm.nevra
1022
+ end
1023
+
1024
+ it "should always have at least one provide, itself" do
1025
+ @rpm.provides.size.should == 1
1026
+ @rpm.provides[0].name == "testing"
1027
+ @rpm.provides[0].version.evr == "1:1.6.5-9.36.el5"
1028
+ @rpm.provides[0].flag == :==
1029
+ end
1030
+ end
1031
+
1032
+ describe "new - no parsing" do
1033
+ before do
1034
+ @rpm = Chef::Provider::Package::Yum::RPMPackage.new("testing", "1", "1.6.5", "9.36.el5", "x86_64", [])
1035
+ end
1036
+
1037
+ it "should expose nevra (name-epoch-version-release-arch) available" do
1038
+ @rpm.name.should == "testing"
1039
+ @rpm.version.e.should == 1
1040
+ @rpm.version.v.should == "1.6.5"
1041
+ @rpm.version.r.should == "9.36.el5"
1042
+ @rpm.arch.should == "x86_64"
1043
+
1044
+ @rpm.nevra.should == "testing-1:1.6.5-9.36.el5.x86_64"
1045
+ @rpm.to_s.should == @rpm.nevra
1046
+ end
1047
+
1048
+ it "should always have at least one provide, itself" do
1049
+ @rpm.provides.size.should == 1
1050
+ @rpm.provides[0].name == "testing"
1051
+ @rpm.provides[0].version.evr == "1:1.6.5-9.36.el5"
1052
+ @rpm.provides[0].flag == :==
1053
+ end
1054
+ end
1055
+
1056
+ it "should raise an error unless passed 4 or 6 args" do
1057
+ lambda {
1058
+ Chef::Provider::Package::Yum::RPMPackage.new()
1059
+ }.should raise_error(ArgumentError)
1060
+ lambda {
1061
+ Chef::Provider::Package::Yum::RPMPackage.new("testing")
1062
+ }.should raise_error(ArgumentError)
1063
+ lambda {
1064
+ Chef::Provider::Package::Yum::RPMPackage.new("testing", "1:1.6.5-9.36.el5")
1065
+ }.should raise_error(ArgumentError)
1066
+ lambda {
1067
+ Chef::Provider::Package::Yum::RPMPackage.new("testing", "1:1.6.5-9.36.el5", "x86_64")
1068
+ }.should raise_error(ArgumentError)
1069
+ lambda {
1070
+ Chef::Provider::Package::Yum::RPMPackage.new("testing", "1:1.6.5-9.36.el5", "x86_64", [])
1071
+ }.should_not raise_error
1072
+ lambda {
1073
+ Chef::Provider::Package::Yum::RPMPackage.new("testing", "1", "1.6.5", "9.36.el5", "x86_64")
1074
+ }.should raise_error(ArgumentError)
1075
+ lambda {
1076
+ Chef::Provider::Package::Yum::RPMPackage.new("testing", "1", "1.6.5", "9.36.el5", "x86_64", [])
1077
+ }.should_not raise_error
1078
+ lambda {
1079
+ Chef::Provider::Package::Yum::RPMPackage.new("testing", "1", "1.6.5", "9.36.el5", "x86_64", [], "extra")
1080
+ }.should raise_error(ArgumentError)
1081
+ end
1082
+
1083
+ describe "<=>" do
1084
+ it "should sort alphabetically based on package name" do
1085
+ [
1086
+ [ "a-test",
1087
+ "b-test" ],
1088
+ [ "B-test",
1089
+ "a-test" ],
1090
+ [ "A-test",
1091
+ "B-test" ],
1092
+ [ "Aa-test",
1093
+ "aA-test" ],
1094
+ [ "1test",
1095
+ "2test" ],
1096
+ ].each do |smaller, larger|
1097
+ sm = Chef::Provider::Package::Yum::RPMPackage.new(smaller, "0:0.0.1-1", "x86_64", [])
1098
+ lg = Chef::Provider::Package::Yum::RPMPackage.new(larger, "0:0.0.1-1", "x86_64", [])
1099
+ sm.should be < lg
1100
+ lg.should be > sm
1101
+ sm.should_not == lg
1102
+ end
1103
+ end
1104
+
1105
+ it "should sort alphabetically based on package arch" do
1106
+ [
1107
+ [ "i386",
1108
+ "x86_64" ],
1109
+ [ "i386",
1110
+ "noarch" ],
1111
+ [ "noarch",
1112
+ "x86_64" ],
1113
+ ].each do |smaller, larger|
1114
+ sm = Chef::Provider::Package::Yum::RPMPackage.new("test-package", "0:0.0.1-1", smaller, [])
1115
+ lg = Chef::Provider::Package::Yum::RPMPackage.new("test-package", "0:0.0.1-1", larger, [])
1116
+ sm.should be < lg
1117
+ lg.should be > sm
1118
+ sm.should_not == lg
1119
+ end
1120
+ end
1121
+ end
1122
+
1123
+ end
1124
+
1125
+ describe Chef::Provider::Package::Yum::RPMDbPackage do
1126
+ before(:each) do
1127
+ # name, version, arch, installed, available, repoid
1128
+ @rpm_x = Chef::Provider::Package::Yum::RPMDbPackage.new("test-package-b", "0:1.6.5-9.36.el5", "noarch", [], false, true, "base")
1129
+ @rpm_y = Chef::Provider::Package::Yum::RPMDbPackage.new("test-package-b", "0:1.6.5-9.36.el5", "noarch", [], true, true, "extras")
1130
+ @rpm_z = Chef::Provider::Package::Yum::RPMDbPackage.new("test-package-b", "0:1.6.5-9.36.el5", "noarch", [], true, false, "other")
1131
+ end
1132
+
1133
+ describe "initialize" do
1134
+ it "should return a Chef::Provider::Package::Yum::RPMDbPackage object" do
1135
+ @rpm_x.should be_kind_of(Chef::Provider::Package::Yum::RPMDbPackage)
1136
+ end
1137
+ end
1138
+
1139
+ describe "available" do
1140
+ it "should return true" do
1141
+ @rpm_x.available.should be == true
1142
+ @rpm_y.available.should be == true
1143
+ @rpm_z.available.should be == false
1144
+ end
1145
+ end
1146
+
1147
+ describe "installed" do
1148
+ it "should return true" do
1149
+ @rpm_x.installed.should be == false
1150
+ @rpm_y.installed.should be == true
1151
+ @rpm_z.installed.should be == true
1152
+ end
1153
+ end
1154
+
1155
+ describe "repoid" do
1156
+ it "should return the source repository repoid" do
1157
+ @rpm_x.repoid.should be == "base"
1158
+ @rpm_y.repoid.should be == "extras"
1159
+ @rpm_z.repoid.should be == "other"
1160
+ end
1161
+ end
1162
+ end
1163
+
1164
+ describe Chef::Provider::Package::Yum::RPMDependency do
1165
+ describe "new - with parsing" do
1166
+ before do
1167
+ @rpmdep = Chef::Provider::Package::Yum::RPMDependency.new("testing", "1:1.6.5-9.36.el5", :==)
1168
+ end
1169
+
1170
+ it "should expose name, version, flag available" do
1171
+ @rpmdep.name.should == "testing"
1172
+ @rpmdep.version.e.should == 1
1173
+ @rpmdep.version.v.should == "1.6.5"
1174
+ @rpmdep.version.r.should == "9.36.el5"
1175
+ @rpmdep.flag.should == :==
1176
+ end
1177
+ end
1178
+
1179
+ describe "new - no parsing" do
1180
+ before do
1181
+ @rpmdep = Chef::Provider::Package::Yum::RPMDependency.new("testing", "1", "1.6.5", "9.36.el5", :==)
1182
+ end
1183
+
1184
+ it "should expose name, version, flag available" do
1185
+ @rpmdep.name.should == "testing"
1186
+ @rpmdep.version.e.should == 1
1187
+ @rpmdep.version.v.should == "1.6.5"
1188
+ @rpmdep.version.r.should == "9.36.el5"
1189
+ @rpmdep.flag.should == :==
1190
+ end
1191
+ end
1192
+
1193
+ it "should raise an error unless passed 3 or 5 args" do
1194
+ lambda {
1195
+ Chef::Provider::Package::Yum::RPMDependency.new()
1196
+ }.should raise_error(ArgumentError)
1197
+ lambda {
1198
+ Chef::Provider::Package::Yum::RPMDependency.new("testing")
1199
+ }.should raise_error(ArgumentError)
1200
+ lambda {
1201
+ Chef::Provider::Package::Yum::RPMDependency.new("testing", "1:1.6.5-9.36.el5")
1202
+ }.should raise_error(ArgumentError)
1203
+ lambda {
1204
+ Chef::Provider::Package::Yum::RPMDependency.new("testing", "1:1.6.5-9.36.el5", :==)
1205
+ }.should_not raise_error
1206
+ lambda {
1207
+ Chef::Provider::Package::Yum::RPMDependency.new("testing", "1:1.6.5-9.36.el5", :==, "extra")
1208
+ }.should raise_error(ArgumentError)
1209
+ lambda {
1210
+ Chef::Provider::Package::Yum::RPMDependency.new("testing", "1", "1.6.5", "9.36.el5", :==)
1211
+ }.should_not raise_error
1212
+ lambda {
1213
+ Chef::Provider::Package::Yum::RPMDependency.new("testing", "1", "1.6.5", "9.36.el5", :==, "extra")
1214
+ }.should raise_error(ArgumentError)
1215
+ end
1216
+
1217
+ describe "parse" do
1218
+ it "should parse a name, flag, version string into a valid RPMDependency object" do
1219
+ @rpmdep = Chef::Provider::Package::Yum::RPMDependency.parse("testing >= 1:1.6.5-9.36.el5")
1220
+
1221
+ @rpmdep.name.should == "testing"
1222
+ @rpmdep.version.e.should == 1
1223
+ @rpmdep.version.v.should == "1.6.5"
1224
+ @rpmdep.version.r.should == "9.36.el5"
1225
+ @rpmdep.flag.should == :>=
1226
+ end
1227
+
1228
+ it "should parse a name into a valid RPMDependency object" do
1229
+ @rpmdep = Chef::Provider::Package::Yum::RPMDependency.parse("testing")
1230
+
1231
+ @rpmdep.name.should == "testing"
1232
+ @rpmdep.version.e.should == nil
1233
+ @rpmdep.version.v.should == nil
1234
+ @rpmdep.version.r.should == nil
1235
+ @rpmdep.flag.should == :==
1236
+ end
1237
+
1238
+ it "should parse an invalid string into the name of a RPMDependency object" do
1239
+ @rpmdep = Chef::Provider::Package::Yum::RPMDependency.parse("testing blah >")
1240
+
1241
+ @rpmdep.name.should == "testing blah >"
1242
+ @rpmdep.version.e.should == nil
1243
+ @rpmdep.version.v.should == nil
1244
+ @rpmdep.version.r.should == nil
1245
+ @rpmdep.flag.should == :==
1246
+ end
1247
+
1248
+ it "should parse various valid flags" do
1249
+ [
1250
+ [ ">", :> ],
1251
+ [ ">=", :>= ],
1252
+ [ "=", :== ],
1253
+ [ "==", :== ],
1254
+ [ "<=", :<= ],
1255
+ [ "<", :< ]
1256
+ ].each do |before, after|
1257
+ @rpmdep = Chef::Provider::Package::Yum::RPMDependency.parse("testing #{before} 1:1.1-1")
1258
+ @rpmdep.flag.should == after
1259
+ end
1260
+ end
1261
+
1262
+ it "should parse various invalid flags and treat them as names" do
1263
+ [
1264
+ [ "<>", :== ],
1265
+ [ "!=", :== ],
1266
+ [ ">>", :== ],
1267
+ [ "<<", :== ],
1268
+ [ "!", :== ],
1269
+ [ "~", :== ]
1270
+ ].each do |before, after|
1271
+ @rpmdep = Chef::Provider::Package::Yum::RPMDependency.parse("testing #{before} 1:1.1-1")
1272
+ @rpmdep.name.should == "testing #{before} 1:1.1-1"
1273
+ @rpmdep.flag.should == after
1274
+ end
1275
+ end
1276
+ end
1277
+
1278
+ describe "satisfy?" do
1279
+ it "should raise an error unless a RPMDependency is passed" do
1280
+ @rpmprovide = Chef::Provider::Package::Yum::RPMDependency.new("testing", "1:1.6.5-9.36.el5", :==)
1281
+ @rpmrequire = Chef::Provider::Package::Yum::RPMDependency.new("testing", "1:1.6.5-9.36.el5", :>=)
1282
+ lambda {
1283
+ @rpmprovide.satisfy?("hi")
1284
+ }.should raise_error(ArgumentError)
1285
+ lambda {
1286
+ @rpmprovide.satisfy?(@rpmrequire)
1287
+ }.should_not raise_error
1288
+ end
1289
+
1290
+ it "should validate dependency satisfaction logic for standard examples" do
1291
+ [
1292
+ # names
1293
+ [ "test", "test", true ],
1294
+ [ "test", "foo", false ],
1295
+ # full: epoch:version-relese
1296
+ [ "testing = 1:1.1-1", "testing > 1:1.1-0", true ],
1297
+ [ "testing = 1:1.1-1", "testing >= 1:1.1-0", true ],
1298
+ [ "testing = 1:1.1-1", "testing >= 1:1.1-1", true ],
1299
+ [ "testing = 1:1.1-1", "testing = 1:1.1-1", true ],
1300
+ [ "testing = 1:1.1-1", "testing == 1:1.1-1", true ],
1301
+ [ "testing = 1:1.1-1", "testing <= 1:1.1-1", true ],
1302
+ [ "testing = 1:1.1-1", "testing <= 1:1.1-0", false ],
1303
+ [ "testing = 1:1.1-1", "testing < 1:1.1-0", false ],
1304
+ # partial: epoch:version
1305
+ [ "testing = 1:1.1", "testing > 1:1.0", true ],
1306
+ [ "testing = 1:1.1", "testing >= 1:1.0", true ],
1307
+ [ "testing = 1:1.1", "testing >= 1:1.1", true ],
1308
+ [ "testing = 1:1.1", "testing = 1:1.1", true ],
1309
+ [ "testing = 1:1.1", "testing == 1:1.1", true ],
1310
+ [ "testing = 1:1.1", "testing <= 1:1.1", true ],
1311
+ [ "testing = 1:1.1", "testing <= 1:1.0", false ],
1312
+ [ "testing = 1:1.1", "testing < 1:1.0", false ],
1313
+ # partial: epoch
1314
+ [ "testing = 1:", "testing > 0:", true ],
1315
+ [ "testing = 1:", "testing >= 0:", true ],
1316
+ [ "testing = 1:", "testing >= 1:", true ],
1317
+ [ "testing = 1:", "testing = 1:", true ],
1318
+ [ "testing = 1:", "testing == 1:", true ],
1319
+ [ "testing = 1:", "testing <= 1:", true ],
1320
+ [ "testing = 1:", "testing <= 0:", false ],
1321
+ [ "testing = 1:", "testing < 0:", false ],
1322
+ # mix and match!
1323
+ [ "testing = 1:1.1-1", "testing == 1:1.1", true ],
1324
+ [ "testing = 1:1.1-1", "testing == 1:", true ],
1325
+ ].each do |prov, req, result|
1326
+ @rpmprovide = Chef::Provider::Package::Yum::RPMDependency.parse(prov)
1327
+ @rpmrequire = Chef::Provider::Package::Yum::RPMDependency.parse(req)
1328
+
1329
+ @rpmprovide.satisfy?(@rpmrequire).should == result
1330
+ @rpmrequire.satisfy?(@rpmprovide).should == result
1331
+ end
1332
+ end
1333
+ end
1334
+
1335
+ end
1336
+
1337
+ # thanks resource_collection_spec.rb!
1338
+ describe Chef::Provider::Package::Yum::RPMDb do
1339
+ before(:each) do
1340
+ @rpmdb = Chef::Provider::Package::Yum::RPMDb.new
1341
+ # name, version, arch, installed, available
1342
+ deps_v = [
1343
+ Chef::Provider::Package::Yum::RPMDependency.parse("libz.so.1()(64bit)"),
1344
+ Chef::Provider::Package::Yum::RPMDependency.parse("test-package-a = 0:1.6.5-9.36.el5")
1345
+ ]
1346
+ deps_z = [
1347
+ Chef::Provider::Package::Yum::RPMDependency.parse("libz.so.1()(64bit)"),
1348
+ Chef::Provider::Package::Yum::RPMDependency.parse("config(test) = 0:1.6.5-9.36.el5"),
1349
+ Chef::Provider::Package::Yum::RPMDependency.parse("test-package-c = 0:1.6.5-9.36.el5")
1350
+ ]
1351
+ @rpm_v = Chef::Provider::Package::Yum::RPMDbPackage.new("test-package-a", "0:1.6.5-9.36.el5", "i386", deps_v, true, false, "base")
1352
+ @rpm_w = Chef::Provider::Package::Yum::RPMDbPackage.new("test-package-b", "0:1.6.5-9.36.el5", "i386", [], true, true, "extras")
1353
+ @rpm_x = Chef::Provider::Package::Yum::RPMDbPackage.new("test-package-b", "0:1.6.5-9.36.el5", "x86_64", [], false, true, "extras")
1354
+ @rpm_y = Chef::Provider::Package::Yum::RPMDbPackage.new("test-package-b", "1:1.6.5-9.36.el5", "x86_64", [], true, true, "extras")
1355
+ @rpm_z = Chef::Provider::Package::Yum::RPMDbPackage.new("test-package-c", "0:1.6.5-9.36.el5", "noarch", deps_z, true, true, "base")
1356
+ @rpm_z_mirror = Chef::Provider::Package::Yum::RPMDbPackage.new("test-package-c", "0:1.6.5-9.36.el5", "noarch", deps_z, true, true, "base")
1357
+ end
1358
+
1359
+ describe "initialize" do
1360
+ it "should return a Chef::Provider::Package::Yum::RPMDb object" do
1361
+ @rpmdb.should be_kind_of(Chef::Provider::Package::Yum::RPMDb)
1362
+ end
1363
+ end
1364
+
1365
+ describe "push" do
1366
+ it "should accept an RPMDbPackage object through pushing" do
1367
+ lambda { @rpmdb.push(@rpm_w) }.should_not raise_error
1368
+ end
1369
+
1370
+ it "should accept multiple RPMDbPackage object through pushing" do
1371
+ lambda { @rpmdb.push(@rpm_w, @rpm_x, @rpm_y, @rpm_z) }.should_not raise_error
1372
+ end
1373
+
1374
+ it "should only accept an RPMDbPackage object" do
1375
+ lambda { @rpmdb.push("string") }.should raise_error
1376
+ end
1377
+
1378
+ it "should add the package to the package db" do
1379
+ @rpmdb.push(@rpm_w)
1380
+ @rpmdb["test-package-b"].should_not be == nil
1381
+ end
1382
+
1383
+ it "should add conditionally add the package to the available list" do
1384
+ @rpmdb.available_size.should be == 0
1385
+ @rpmdb.push(@rpm_v, @rpm_w)
1386
+ @rpmdb.available_size.should be == 1
1387
+ end
1388
+
1389
+ it "should add conditionally add the package to the installed list" do
1390
+ @rpmdb.installed_size.should be == 0
1391
+ @rpmdb.push(@rpm_w, @rpm_x)
1392
+ @rpmdb.installed_size.should be == 1
1393
+ end
1394
+
1395
+ it "should have a total of 2 packages in the RPMDb" do
1396
+ @rpmdb.size.should be == 0
1397
+ @rpmdb.push(@rpm_w, @rpm_x, @rpm_y, @rpm_z)
1398
+ @rpmdb.size.should be == 2
1399
+ end
1400
+
1401
+ it "should keep the Array unique when a duplicate is pushed" do
1402
+ @rpmdb.push(@rpm_z, @rpm_z_mirror)
1403
+ @rpmdb["test-package-c"].size.should be == 1
1404
+ end
1405
+
1406
+ it "should register the package provides in the provides index" do
1407
+ @rpmdb.push(@rpm_v, @rpm_w, @rpm_z)
1408
+ @rpmdb.lookup_provides("test-package-a")[0].should be == @rpm_v
1409
+ @rpmdb.lookup_provides("config(test)")[0].should be == @rpm_z
1410
+ @rpmdb.lookup_provides("libz.so.1()(64bit)")[0].should be == @rpm_v
1411
+ @rpmdb.lookup_provides("libz.so.1()(64bit)")[1].should be == @rpm_z
1412
+ end
1413
+ end
1414
+
1415
+ describe "<<" do
1416
+ it "should accept an RPMPackage object through the << operator" do
1417
+ lambda { @rpmdb << @rpm_w }.should_not raise_error
1418
+ end
1419
+ end
1420
+
1421
+ describe "lookup" do
1422
+ it "should return an Array of RPMPackage objects by index" do
1423
+ @rpmdb << @rpm_w
1424
+ @rpmdb.lookup("test-package-b").should be_kind_of(Array)
1425
+ end
1426
+ end
1427
+
1428
+ describe "[]" do
1429
+ it "should return an Array of RPMPackage objects though the [index] operator" do
1430
+ @rpmdb << @rpm_w
1431
+ @rpmdb["test-package-b"].should be_kind_of(Array)
1432
+ end
1433
+
1434
+ it "should return an Array of 3 RPMPackage objects" do
1435
+ @rpmdb.push(@rpm_w, @rpm_x, @rpm_y, @rpm_z)
1436
+ @rpmdb["test-package-b"].size.should be == 3
1437
+ end
1438
+
1439
+ it "should return an Array of RPMPackage objects sorted from newest to oldest" do
1440
+ @rpmdb.push(@rpm_w, @rpm_x, @rpm_y, @rpm_z)
1441
+ @rpmdb["test-package-b"][0].should be == @rpm_y
1442
+ @rpmdb["test-package-b"][1].should be == @rpm_x
1443
+ @rpmdb["test-package-b"][2].should be == @rpm_w
1444
+ end
1445
+ end
1446
+
1447
+ describe "lookup_provides" do
1448
+ it "should return an Array of RPMPackage objects by index" do
1449
+ @rpmdb << @rpm_z
1450
+ x = @rpmdb.lookup_provides("config(test)")
1451
+ x.should be_kind_of(Array)
1452
+ x[0].should be == @rpm_z
1453
+ end
1454
+ end
1455
+
1456
+ describe "clear" do
1457
+ it "should clear the RPMDb" do
1458
+ @rpmdb.should_receive(:clear_available).once
1459
+ @rpmdb.should_receive(:clear_installed).once
1460
+ @rpmdb.push(@rpm_w, @rpm_x, @rpm_y, @rpm_z)
1461
+ @rpmdb.size.should_not be == 0
1462
+ @rpmdb.lookup_provides("config(test)").should be_kind_of(Array)
1463
+ @rpmdb.clear
1464
+ @rpmdb.lookup_provides("config(test)").should be == nil
1465
+ @rpmdb.size.should be == 0
1466
+ end
1467
+ end
1468
+
1469
+ describe "clear_available" do
1470
+ it "should clear the available list" do
1471
+ @rpmdb.push(@rpm_w, @rpm_x, @rpm_y, @rpm_z)
1472
+ @rpmdb.available_size.should_not be == 0
1473
+ @rpmdb.clear_available
1474
+ @rpmdb.available_size.should be == 0
1475
+ end
1476
+ end
1477
+
1478
+ describe "available?" do
1479
+ it "should return true if a package is available" do
1480
+ @rpmdb.available?(@rpm_w).should be == false
1481
+ @rpmdb.push(@rpm_v, @rpm_w)
1482
+ @rpmdb.available?(@rpm_v).should be == false
1483
+ @rpmdb.available?(@rpm_w).should be == true
1484
+ end
1485
+ end
1486
+
1487
+ describe "clear_installed" do
1488
+ it "should clear the installed list" do
1489
+ @rpmdb.push(@rpm_w, @rpm_x, @rpm_y, @rpm_z)
1490
+ @rpmdb.installed_size.should_not be == 0
1491
+ @rpmdb.clear_installed
1492
+ @rpmdb.installed_size.should be == 0
1493
+ end
1494
+ end
1495
+
1496
+ describe "installed?" do
1497
+ it "should return true if a package is installed" do
1498
+ @rpmdb.installed?(@rpm_w).should be == false
1499
+ @rpmdb.push(@rpm_w, @rpm_x)
1500
+ @rpmdb.installed?(@rpm_w).should be == true
1501
+ @rpmdb.installed?(@rpm_x).should be == false
1502
+ end
1503
+ end
1504
+
1505
+ describe "whatprovides" do
1506
+ it "should raise an error unless a RPMDependency is passed" do
1507
+ @rpmprovide = Chef::Provider::Package::Yum::RPMDependency.new("testing", "1:1.6.5-9.36.el5", :==)
1508
+ @rpmrequire = Chef::Provider::Package::Yum::RPMDependency.new("testing", "1:1.6.5-9.36.el5", :>=)
1509
+ lambda {
1510
+ @rpmdb.whatprovides("hi")
1511
+ }.should raise_error(ArgumentError)
1512
+ lambda {
1513
+ @rpmdb.whatprovides(@rpmrequire)
1514
+ }.should_not raise_error
1515
+ end
1516
+
1517
+ it "should return an Array of packages statisfying a RPMDependency" do
1518
+ @rpmdb.push(@rpm_v, @rpm_w, @rpm_z)
1519
+
1520
+ @rpmrequire = Chef::Provider::Package::Yum::RPMDependency.parse("test-package-a >= 1.6.5")
1521
+ x = @rpmdb.whatprovides(@rpmrequire)
1522
+ x.should be_kind_of(Array)
1523
+ x[0].should be == @rpm_v
1524
+
1525
+ @rpmrequire = Chef::Provider::Package::Yum::RPMDependency.parse("libz.so.1()(64bit)")
1526
+ x = @rpmdb.whatprovides(@rpmrequire)
1527
+ x.should be_kind_of(Array)
1528
+ x[0].should be == @rpm_v
1529
+ x[1].should be == @rpm_z
1530
+ end
1531
+ end
1532
+
1533
+ end
1534
+
1535
+ describe Chef::Provider::Package::Yum::YumCache do
1536
+ # allow for the reset of a Singleton
1537
+ # thanks to Ian White (http://blog.ardes.com/2006/12/11/testing-singletons-with-ruby)
1538
+ class << Chef::Provider::Package::Yum::YumCache
1539
+ def reset_instance
1540
+ Singleton.send :__init__, self
1541
+ self
1542
+ end
1543
+ end
1544
+
1545
+ before(:each) do
1546
+ @stdin = mock("STDIN", :nil_object => true)
1547
+ @stdout = mock("STDOUT", :nil_object => true)
1548
+
1549
+ @stdout_good = <<EOF
1550
+ [option installonlypkgs] kernel kernel-bigmem kernel-enterprise
1551
+ erlang-mochiweb 0 1.4.1 5.el5 x86_64 ['erlang-mochiweb = 1.4.1-5.el5', 'mochiweb = 1.4.1-5.el5'] i installed
1552
+ zip 0 2.31 2.el5 x86_64 ['zip = 2.31-2.el5'] r base
1553
+ zisofs-tools 0 1.0.6 3.2.2 x86_64 [] a extras
1554
+ zlib 0 1.2.3 3 x86_64 ['zlib = 1.2.3-3', 'libz.so.1()(64bit)'] r base
1555
+ zlib 0 1.2.3 3 i386 ['zlib = 1.2.3-3', 'libz.so.1'] r base
1556
+ zlib-devel 0 1.2.3 3 i386 [] a extras
1557
+ zlib-devel 0 1.2.3 3 x86_64 ['zlib-devel = 1.2.3-3'] r base
1558
+ znc 0 0.098 1.el5 x86_64 [] a base
1559
+ znc-devel 0 0.098 1.el5 i386 [] a extras
1560
+ znc-devel 0 0.098 1.el5 x86_64 [] a base
1561
+ znc-extra 0 0.098 1.el5 x86_64 [] a base
1562
+ znc-modtcl 0 0.098 1.el5 x86_64 [] a base
1563
+ znc-test.beta1 0 0.098 1.el5 x86_64 [] a extras
1564
+ znc-test.test.beta1 0 0.098 1.el5 x86_64 [] a base
1565
+ EOF
1566
+ @stdout_bad_type = <<EOF
1567
+ zip 0 2.31 2.el5 x86_64 ['zip = 2.31-2.el5'] r base
1568
+ zlib 0 1.2.3 3 x86_64 ['zlib = 1.2.3-3', 'libz.so.1()(64bit)'] c base
1569
+ zlib-devel 0 1.2.3 3 i386 [] a extras
1570
+ zlib-devel 0 1.2.3 3 x86_64 ['zlib-devel = 1.2.3-3'] bad installed
1571
+ znc-modtcl 0 0.098 1.el5 x86_64 [] a base
1572
+ EOF
1573
+
1574
+ @stdout_bad_separators = <<EOF
1575
+ zip 0 2.31 2.el5 x86_64 ['zip = 2.31-2.el5'] r base
1576
+ zlib 0 1.2.3 3 x86_64 ['zlib = 1.2.3-3', 'libz.so.1()(64bit)'] i base bad
1577
+ zlib-devel 0 1.2.3 3 i386 [] a extras
1578
+ bad zlib-devel 0 1.2.3 3 x86_64 ['zlib-devel = 1.2.3-3'] i installed
1579
+ znc-modtcl 0 0.098 1.el5 x86_64 [] a base bad
1580
+ EOF
1581
+
1582
+ @stdout_no_output = ""
1583
+
1584
+ @stderr = <<EOF
1585
+ yum-dump Config Error: File contains no section headers.
1586
+ file: file://///etc/yum.repos.d/CentOS-Base.repo, line: 12
1587
+ 'qeqwewe\n'
1588
+ EOF
1589
+ @status = mock("Status", :exitstatus => 0, :stdin => @stdin, :stdout => @stdout_good, :stderr => @stderr)
1590
+
1591
+ # new singleton each time
1592
+ Chef::Provider::Package::Yum::YumCache.reset_instance
1593
+ @yc = Chef::Provider::Package::Yum::YumCache.instance
1594
+ # load valid data
1595
+ @yc.stub!(:shell_out!).and_return(@status)
1596
+ end
1597
+
1598
+ describe "initialize" do
1599
+ it "should return a Chef::Provider::Package::Yum::YumCache object" do
1600
+ @yc.should be_kind_of(Chef::Provider::Package::Yum::YumCache)
1601
+ end
1602
+
1603
+ it "should register reload for start of Chef::Client runs" do
1604
+ Chef::Provider::Package::Yum::YumCache.reset_instance
1605
+ Chef::Client.should_receive(:when_run_starts) do |&b|
1606
+ b.should_not be_nil
1607
+ end
1608
+ @yc = Chef::Provider::Package::Yum::YumCache.instance
1609
+ end
1610
+ end
1611
+
1612
+ describe "refresh" do
1613
+ it "should implicitly call yum-dump.py only once by default after being instantiated" do
1614
+ @yc.should_receive(:shell_out!).once
1615
+ @yc.installed_version("zlib")
1616
+ @yc.reset
1617
+ @yc.installed_version("zlib")
1618
+ end
1619
+
1620
+ it "should run yum-dump.py using the system python when next_refresh is for :all" do
1621
+ @yc.reload
1622
+ @yc.should_receive(:shell_out!).with(%r{^/usr/bin/python .*/yum-dump.py --options --installed-provides$}, :timeout=>Chef::Config[:yum_timeout])
1623
+ @yc.refresh
1624
+ end
1625
+
1626
+ it "should run yum-dump.py with the installed flag when next_refresh is for :installed" do
1627
+ @yc.reload_installed
1628
+ @yc.should_receive(:shell_out!).with(%r{^/usr/bin/python .*/yum-dump.py --installed$}, :timeout=>Chef::Config[:yum_timeout])
1629
+ @yc.refresh
1630
+ end
1631
+
1632
+ it "should run yum-dump.py with the all-provides flag when next_refresh is for :provides" do
1633
+ @yc.reload_provides
1634
+ @yc.should_receive(:shell_out!).with(%r{^/usr/bin/python .*/yum-dump.py --options --all-provides$}, :timeout=>Chef::Config[:yum_timeout])
1635
+ @yc.refresh
1636
+ end
1637
+
1638
+ it "should pass extra_repo_control args to yum-dump.py" do
1639
+ @yc.enable_extra_repo_control("--enablerepo=foo --disablerepo=bar")
1640
+ @yc.should_receive(:shell_out!).with(%r{^/usr/bin/python .*/yum-dump.py --options --installed-provides --enablerepo=foo --disablerepo=bar$}, :timeout=>Chef::Config[:yum_timeout])
1641
+ @yc.refresh
1642
+ end
1643
+
1644
+ it "should warn about invalid data with too many separators" do
1645
+ @status = mock("Status", :exitstatus => 0, :stdin => @stdin, :stdout => @stdout_bad_separators, :stderr => @stderr)
1646
+ @yc.stub!(:shell_out!).and_return(@status)
1647
+ Chef::Log.should_receive(:warn).exactly(3).times.with(%r{Problem parsing})
1648
+ @yc.refresh
1649
+ end
1650
+
1651
+ it "should warn about invalid data with an incorrect type" do
1652
+ @status = mock("Status", :exitstatus => 0, :stdin => @stdin, :stdout => @stdout_bad_type, :stderr => @stderr)
1653
+ @yc.stub!(:shell_out!).and_return(@status)
1654
+ Chef::Log.should_receive(:warn).exactly(2).times.with(%r{Problem parsing})
1655
+ @yc.refresh
1656
+ end
1657
+
1658
+ it "should warn about no output from yum-dump.py" do
1659
+ @status = mock("Status", :exitstatus => 0, :stdin => @stdin, :stdout => @stdout_no_output, :stderr => @stderr)
1660
+ @yc.stub!(:shell_out!).and_return(@status)
1661
+ Chef::Log.should_receive(:warn).exactly(1).times.with(%r{no output from yum-dump.py})
1662
+ @yc.refresh
1663
+ end
1664
+
1665
+ it "should raise exception yum-dump.py exits with a non zero status" do
1666
+ @status = mock("Status", :exitstatus => 1, :stdin => @stdin, :stdout => @stdout_no_output, :stderr => @stderr)
1667
+ @yc.stub!(:shell_out!).and_return(@status)
1668
+ lambda { @yc.refresh}.should raise_error(Chef::Exceptions::Package, %r{CentOS-Base.repo, line: 12})
1669
+ end
1670
+
1671
+ it "should parse type 'i' into an installed state for a package" do
1672
+ @yc.available_version("erlang-mochiweb").should be == nil
1673
+ @yc.installed_version("erlang-mochiweb").should_not be == nil
1674
+ end
1675
+
1676
+ it "should parse type 'a' into an available state for a package" do
1677
+ @yc.available_version("znc").should_not be == nil
1678
+ @yc.installed_version("znc").should be == nil
1679
+ end
1680
+
1681
+ it "should parse type 'r' into an installed and available states for a package" do
1682
+ @yc.available_version("zip").should_not be == nil
1683
+ @yc.installed_version("zip").should_not be == nil
1684
+ end
1685
+
1686
+ it "should parse installonlypkgs from yum-dump.py options output" do
1687
+ @yc.allow_multi_install.should be == %w{kernel kernel-bigmem kernel-enterprise}
1688
+ end
1689
+ end
1690
+
1691
+ describe "installed_version" do
1692
+ it "should take one or two arguments" do
1693
+ lambda { @yc.installed_version("zip") }.should_not raise_error(ArgumentError)
1694
+ lambda { @yc.installed_version("zip", "i386") }.should_not raise_error(ArgumentError)
1695
+ lambda { @yc.installed_version("zip", "i386", "extra") }.should raise_error(ArgumentError)
1696
+ end
1697
+
1698
+ it "should return version-release for matching package regardless of arch" do
1699
+ @yc.installed_version("zip", "x86_64").should be == "2.31-2.el5"
1700
+ @yc.installed_version("zip", nil).should be == "2.31-2.el5"
1701
+ end
1702
+
1703
+ it "should return version-release for matching package and arch" do
1704
+ @yc.installed_version("zip", "x86_64").should be == "2.31-2.el5"
1705
+ @yc.installed_version("zisofs-tools", "i386").should be == nil
1706
+ end
1707
+
1708
+ it "should return nil for an unmatched package" do
1709
+ @yc.installed_version(nil, nil).should be == nil
1710
+ @yc.installed_version("test1", nil).should be == nil
1711
+ @yc.installed_version("test2", "x86_64").should be == nil
1712
+ end
1713
+ end
1714
+
1715
+ describe "available_version" do
1716
+ it "should take one or two arguments" do
1717
+ lambda { @yc.available_version("zisofs-tools") }.should_not raise_error(ArgumentError)
1718
+ lambda { @yc.available_version("zisofs-tools", "i386") }.should_not raise_error(ArgumentError)
1719
+ lambda { @yc.available_version("zisofs-tools", "i386", "extra") }.should raise_error(ArgumentError)
1720
+ end
1721
+
1722
+ it "should return version-release for matching package regardless of arch" do
1723
+ @yc.available_version("zip", "x86_64").should be == "2.31-2.el5"
1724
+ @yc.available_version("zip", nil).should be == "2.31-2.el5"
1725
+ end
1726
+
1727
+ it "should return version-release for matching package and arch" do
1728
+ @yc.available_version("zip", "x86_64").should be == "2.31-2.el5"
1729
+ @yc.available_version("zisofs-tools", "i386").should be == nil
1730
+ end
1731
+
1732
+ it "should return nil for an unmatched package" do
1733
+ @yc.available_version(nil, nil).should be == nil
1734
+ @yc.available_version("test1", nil).should be == nil
1735
+ @yc.available_version("test2", "x86_64").should be == nil
1736
+ end
1737
+ end
1738
+
1739
+ describe "version_available?" do
1740
+ it "should take two or three arguments" do
1741
+ lambda { @yc.version_available?("zisofs-tools") }.should raise_error(ArgumentError)
1742
+ lambda { @yc.version_available?("zisofs-tools", "1.0.6-3.2.2") }.should_not raise_error(ArgumentError)
1743
+ lambda { @yc.version_available?("zisofs-tools", "1.0.6-3.2.2", "x86_64") }.should_not raise_error(ArgumentError)
1744
+ end
1745
+
1746
+ it "should return true if our package-version-arch is available" do
1747
+ @yc.version_available?("zisofs-tools", "1.0.6-3.2.2", "x86_64").should be == true
1748
+ end
1749
+
1750
+ it "should return true if our package-version, no arch, is available" do
1751
+ @yc.version_available?("zisofs-tools", "1.0.6-3.2.2", nil).should be == true
1752
+ @yc.version_available?("zisofs-tools", "1.0.6-3.2.2").should be == true
1753
+ end
1754
+
1755
+ it "should return false if our package-version-arch isn't available" do
1756
+ @yc.version_available?("zisofs-tools", "1.0.6-3.2.2", "pretend").should be == false
1757
+ @yc.version_available?("zisofs-tools", "pretend", "x86_64").should be == false
1758
+ @yc.version_available?("pretend", "1.0.6-3.2.2", "x86_64").should be == false
1759
+ end
1760
+
1761
+ it "should return false if our package-version, no arch, isn't available" do
1762
+ @yc.version_available?("zisofs-tools", "pretend", nil).should be == false
1763
+ @yc.version_available?("zisofs-tools", "pretend").should be == false
1764
+ @yc.version_available?("pretend", "1.0.6-3.2.2").should be == false
1765
+ end
1766
+ end
1767
+
1768
+ describe "package_repository" do
1769
+ it "should take two or three arguments" do
1770
+ lambda { @yc.package_repository("zisofs-tools") }.should raise_error(ArgumentError)
1771
+ lambda { @yc.package_repository("zisofs-tools", "1.0.6-3.2.2") }.should_not raise_error(ArgumentError)
1772
+ lambda { @yc.package_repository("zisofs-tools", "1.0.6-3.2.2", "x86_64") }.should_not raise_error(ArgumentError)
1773
+ end
1774
+
1775
+ it "should return repoid for package-version-arch" do
1776
+ @yc.package_repository("zlib-devel", "1.2.3-3", "i386").should be == "extras"
1777
+ @yc.package_repository("zlib-devel", "1.2.3-3", "x86_64").should be == "base"
1778
+ end
1779
+
1780
+ it "should return repoid for package-version, no arch" do
1781
+ @yc.package_repository("zisofs-tools", "1.0.6-3.2.2", nil).should be == "extras"
1782
+ @yc.package_repository("zisofs-tools", "1.0.6-3.2.2").should be == "extras"
1783
+ end
1784
+
1785
+ it "should return nil when no match for package-version-arch" do
1786
+ @yc.package_repository("zisofs-tools", "1.0.6-3.2.2", "pretend").should be == nil
1787
+ @yc.package_repository("zisofs-tools", "pretend", "x86_64").should be == nil
1788
+ @yc.package_repository("pretend", "1.0.6-3.2.2", "x86_64").should be == nil
1789
+ end
1790
+
1791
+ it "should return nil when no match for package-version, no arch" do
1792
+ @yc.package_repository("zisofs-tools", "pretend", nil).should be == nil
1793
+ @yc.package_repository("zisofs-tools", "pretend").should be == nil
1794
+ @yc.package_repository("pretend", "1.0.6-3.2.2").should be == nil
1795
+ end
1796
+ end
1797
+
1798
+ describe "reset" do
1799
+ it "should empty the installed and available packages RPMDb" do
1800
+ @yc.available_version("zip", "x86_64").should be == "2.31-2.el5"
1801
+ @yc.installed_version("zip", "x86_64").should be == "2.31-2.el5"
1802
+ @yc.reset
1803
+ @yc.available_version("zip", "x86_64").should be == nil
1804
+ @yc.installed_version("zip", "x86_64").should be == nil
1805
+ end
1806
+ end
1807
+
1808
+ describe "package_available?" do
1809
+ it "should return true a package name is available" do
1810
+ @yc.package_available?("zisofs-tools").should be == true
1811
+ @yc.package_available?("moo").should be == false
1812
+ @yc.package_available?(nil).should be == false
1813
+ end
1814
+
1815
+ it "should return true a package name + arch is available" do
1816
+ @yc.package_available?("zlib-devel.i386").should be == true
1817
+ @yc.package_available?("zisofs-tools.x86_64").should be == true
1818
+ @yc.package_available?("znc-test.beta1.x86_64").should be == true
1819
+ @yc.package_available?("znc-test.beta1").should be == true
1820
+ @yc.package_available?("znc-test.test.beta1").should be == true
1821
+ @yc.package_available?("moo.i386").should be == false
1822
+ @yc.package_available?("zisofs-tools.beta").should be == false
1823
+ @yc.package_available?("znc-test.test").should be == false
1824
+ end
1825
+ end
1826
+
1827
+ describe "enable_extra_repo_control" do
1828
+ it "should set @extra_repo_control to arg" do
1829
+ @yc.enable_extra_repo_control("--enablerepo=test")
1830
+ @yc.extra_repo_control.should be == "--enablerepo=test"
1831
+ end
1832
+
1833
+ it "should call reload once when set to flag cache for update" do
1834
+ @yc.should_receive(:reload).once
1835
+ @yc.enable_extra_repo_control("--enablerepo=test")
1836
+ @yc.enable_extra_repo_control("--enablerepo=test")
1837
+ end
1838
+ end
1839
+
1840
+ describe "disable_extra_repo_control" do
1841
+ it "should set @extra_repo_control to nil" do
1842
+ @yc.enable_extra_repo_control("--enablerepo=test")
1843
+ @yc.disable_extra_repo_control
1844
+ @yc.extra_repo_control.should be == nil
1845
+ end
1846
+
1847
+ it "should call reload once when cleared to flag cache for update" do
1848
+ @yc.should_receive(:reload).once
1849
+ @yc.enable_extra_repo_control("--enablerepo=test")
1850
+ @yc.should_receive(:reload).once
1851
+ @yc.disable_extra_repo_control
1852
+ @yc.disable_extra_repo_control
1853
+ end
1854
+ end
1855
+
1856
+ end