test_oozie_server.py 78 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537
  1. #!/usr/bin/env python
  2. '''
  3. Licensed to the Apache Software Foundation (ASF) under one
  4. or more contributor license agreements. See the NOTICE file
  5. distributed with this work for additional information
  6. regarding copyright ownership. The ASF licenses this file
  7. to you under the Apache License, Version 2.0 (the
  8. "License"); you may not use this file except in compliance
  9. with the License. You may obtain a copy of the License at
  10. http://www.apache.org/licenses/LICENSE-2.0
  11. Unless required by applicable law or agreed to in writing, software
  12. distributed under the License is distributed on an "AS IS" BASIS,
  13. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. See the License for the specific language governing permissions and
  15. limitations under the License.
  16. '''
  17. import json
  18. from mock.mock import MagicMock, call, patch
  19. from stacks.utils.RMFTestCase import *
  20. from resource_management.core import shell
  21. from resource_management.core.exceptions import Fail
  22. from resource_management.libraries import functions
  23. from resource_management.libraries.providers.hdfs_resource import WebHDFSUtil
  24. import hashlib
  25. import tempfile
  26. md5_mock = MagicMock()
  27. md5_mock.hexdigest.return_value = "abc123hash"
  28. @patch("platform.linux_distribution", new = MagicMock(return_value="Linux"))
  29. @patch.object(hashlib, "md5", new=MagicMock(return_value=md5_mock))
  30. @patch.object(WebHDFSUtil, "run_command", new=MagicMock(return_value={}))
  31. @patch.object(tempfile, "gettempdir", new=MagicMock(return_value="/tmp"))
  32. class TestOozieServer(RMFTestCase):
  33. COMMON_SERVICES_PACKAGE_DIR = "OOZIE/4.0.0.2.0/package"
  34. STACK_VERSION = "2.0.6"
  35. UPGRADE_STACK_VERSION = "2.2"
  36. def setUp(self):
  37. self.maxDiff = None
  38. def test_configure_default(self):
  39. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  40. classname = "OozieServer",
  41. command = "configure",
  42. config_file="default.json",
  43. hdp_stack_version = self.STACK_VERSION,
  44. target = RMFTestCase.TARGET_COMMON_SERVICES
  45. )
  46. self.assert_configure_default()
  47. self.assertNoMoreResources()
  48. def test_configure_default_mysql(self):
  49. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  50. classname = "OozieServer",
  51. command = "configure",
  52. config_file="default_oozie_mysql.json",
  53. hdp_stack_version = self.STACK_VERSION,
  54. target = RMFTestCase.TARGET_COMMON_SERVICES
  55. )
  56. self.assertResourceCalled('HdfsResource', '/user/oozie',
  57. security_enabled = False,
  58. hadoop_bin_dir = '/usr/bin',
  59. keytab = UnknownConfigurationMock(),
  60. kinit_path_local = '/usr/bin/kinit',
  61. user = 'hdfs',
  62. dfs_type = '',
  63. owner = 'oozie',
  64. hadoop_conf_dir = '/etc/hadoop/conf',
  65. type = 'directory',
  66. action = ['create_on_execute'], hdfs_site=self.getConfig()['configurations']['hdfs-site'], principal_name=UnknownConfigurationMock(), default_fs='hdfs://c6401.ambari.apache.org:8020',
  67. mode = 0775,
  68. )
  69. self.assertResourceCalled('HdfsResource', None,
  70. security_enabled = False,
  71. hadoop_bin_dir = '/usr/bin',
  72. keytab = UnknownConfigurationMock(),
  73. kinit_path_local = '/usr/bin/kinit',
  74. user = 'hdfs',
  75. dfs_type = '',
  76. action = ['execute'], hdfs_site=self.getConfig()['configurations']['hdfs-site'], principal_name=UnknownConfigurationMock(), default_fs='hdfs://c6401.ambari.apache.org:8020',
  77. hadoop_conf_dir = '/etc/hadoop/conf',
  78. )
  79. self.assertResourceCalled('Directory', '/etc/oozie/conf',
  80. owner = 'oozie',
  81. group = 'hadoop',
  82. recursive = True,
  83. )
  84. self.assertResourceCalled('XmlConfig', 'oozie-site.xml',
  85. group = 'hadoop',
  86. conf_dir = '/etc/oozie/conf',
  87. mode = 0664,
  88. configuration_attributes = {u'final': {u'oozie.service.CallableQueueService.queue.size': u'true',
  89. u'oozie.service.PurgeService.purge.interval': u'true'}},
  90. owner = 'oozie',
  91. configurations = self.getConfig()['configurations']['oozie-site'],
  92. )
  93. self.assertResourceCalled('File', '/etc/oozie/conf/oozie-env.sh',
  94. content = InlineTemplate(self.getConfig()['configurations']['oozie-env']['content']),
  95. owner = 'oozie',
  96. group = 'hadoop',
  97. )
  98. self.assertResourceCalled('File', '/etc/oozie/conf/oozie-log4j.properties',
  99. content = 'log4jproperties\nline2',
  100. owner = 'oozie',
  101. group = 'hadoop',
  102. mode = 0644,
  103. )
  104. self.assertResourceCalled('File', '/etc/oozie/conf/adminusers.txt',
  105. owner = 'oozie',
  106. group = 'hadoop',
  107. )
  108. self.assertResourceCalled('File', '/usr/lib/ambari-agent/DBConnectionVerification.jar',
  109. content = DownloadSource('http://c6401.ambari.apache.org:8080/resources/DBConnectionVerification.jar'),
  110. )
  111. self.assertResourceCalled('File', '/etc/oozie/conf/hadoop-config.xml',
  112. owner = 'oozie',
  113. group = 'hadoop',
  114. )
  115. self.assertResourceCalled('File', '/etc/oozie/conf/oozie-default.xml',
  116. owner = 'oozie',
  117. group = 'hadoop',
  118. )
  119. self.assertResourceCalled('Directory', '/etc/oozie/conf/action-conf',
  120. owner = 'oozie',
  121. group = 'hadoop',
  122. )
  123. self.assertResourceCalled('File', '/etc/oozie/conf/action-conf/hive.xml',
  124. owner = 'oozie',
  125. group = 'hadoop',
  126. )
  127. self.assertResourceCalled('File', '/var/run/oozie/oozie.pid',
  128. action = ['delete'],
  129. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  130. )
  131. self.assertResourceCalled('Directory', '/usr/lib/oozie//var/tmp/oozie',
  132. owner = 'oozie',
  133. cd_access = 'a',
  134. group = 'hadoop',
  135. recursive = True,
  136. mode = 0755,
  137. )
  138. self.assertResourceCalled('Directory', '/var/run/oozie',
  139. owner = 'oozie',
  140. cd_access = 'a',
  141. group = 'hadoop',
  142. recursive = True,
  143. mode = 0755,
  144. )
  145. self.assertResourceCalled('Directory', '/var/log/oozie',
  146. owner = 'oozie',
  147. cd_access = 'a',
  148. group = 'hadoop',
  149. recursive = True,
  150. mode = 0755,
  151. )
  152. self.assertResourceCalled('Directory', '/var/tmp/oozie',
  153. owner = 'oozie',
  154. cd_access = 'a',
  155. group = 'hadoop',
  156. recursive = True,
  157. mode = 0755,
  158. )
  159. self.assertResourceCalled('Directory', '/hadoop/oozie/data',
  160. owner = 'oozie',
  161. cd_access = 'a',
  162. group = 'hadoop',
  163. recursive = True,
  164. mode = 0755,
  165. )
  166. self.assertResourceCalled('Directory', '/var/lib/oozie',
  167. owner = 'oozie',
  168. cd_access = 'a',
  169. group = 'hadoop',
  170. recursive = True,
  171. mode = 0755,
  172. )
  173. self.assertResourceCalled('Directory', '/var/lib/oozie/oozie-server/webapps/',
  174. owner = 'oozie',
  175. cd_access = 'a',
  176. group = 'hadoop',
  177. recursive = True,
  178. mode = 0755,
  179. )
  180. self.assertResourceCalled('Directory', '/var/lib/oozie/oozie-server/conf',
  181. owner = 'oozie',
  182. cd_access = 'a',
  183. group = 'hadoop',
  184. recursive = True,
  185. mode = 0755,
  186. )
  187. self.assertResourceCalled('Directory', '/var/lib/oozie/oozie-server',
  188. owner = 'oozie',
  189. recursive = True,
  190. group = 'hadoop',
  191. mode = 0755,
  192. cd_access = 'a',
  193. )
  194. self.assertResourceCalled('Directory', '/usr/lib/oozie/libext',
  195. recursive = True,
  196. )
  197. self.assertResourceCalled('Execute', ('tar', '-xvf', '/usr/lib/oozie/oozie-sharelib.tar.gz', '-C', '/usr/lib/oozie'),
  198. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1' || test -f /usr/lib/oozie/.hashcode && test -d /usr/lib/oozie/share && [[ `cat /usr/lib/oozie/.hashcode` == 'abc123hash' ]]",
  199. sudo = True,
  200. )
  201. self.assertResourceCalled('Execute', ('cp', '/usr/share/HDP-oozie/ext-2.2.zip', '/usr/lib/oozie/libext'),
  202. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  203. sudo = True,
  204. )
  205. self.assertResourceCalled('Execute', ('chown', 'oozie:hadoop', '/usr/lib/oozie/libext/ext-2.2.zip'),
  206. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  207. sudo = True,
  208. )
  209. self.assertResourceCalled('Execute', ('chown', '-RL', 'oozie:hadoop', '/var/lib/oozie/oozie-server/conf'),
  210. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  211. sudo = True,
  212. )
  213. self.assertResourceCalled('File', '/tmp/mysql-connector-java.jar',
  214. content = DownloadSource('http://c6401.ambari.apache.org:8080/resources//mysql-jdbc-driver.jar'),
  215. )
  216. self.assertResourceCalled('Execute', ('cp',
  217. '--remove-destination',
  218. '/tmp/mysql-connector-java.jar',
  219. '/usr/lib/oozie/libext/mysql-connector-java.jar'),
  220. path = ['/bin', '/usr/bin/'],
  221. sudo = True,
  222. )
  223. self.assertResourceCalled('File', '/usr/lib/oozie/libext/mysql-connector-java.jar',
  224. owner = 'oozie',
  225. group = 'hadoop',
  226. )
  227. self.assertResourceCalled('Execute', 'ambari-sudo.sh cp /usr/lib/falcon/oozie/ext/falcon-oozie-el-extension-*.jar /usr/lib/oozie/libext',
  228. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  229. )
  230. self.assertResourceCalled('Execute', 'ambari-sudo.sh chown oozie:hadoop /usr/lib/oozie/libext/falcon-oozie-el-extension-*.jar',
  231. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  232. )
  233. self.assertResourceCalled('Execute', 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-setup.sh prepare-war ',
  234. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1' || test -f /usr/lib/oozie/.hashcode && test -d /usr/lib/oozie/share && [[ `cat /usr/lib/oozie/.hashcode` == 'abc123hash' ]] && test -f /usr/lib/oozie/.prepare_war_cmd && [[ `cat /usr/lib/oozie/.prepare_war_cmd` == 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-setup.sh prepare-war ' ]]",
  235. user = 'oozie',
  236. )
  237. self.assertResourceCalled('File', '/usr/lib/oozie/.hashcode',
  238. content = 'abc123hash',
  239. mode = 0644,
  240. )
  241. self.assertResourceCalled('File', '/usr/lib/oozie/.prepare_war_cmd',
  242. content = 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-setup.sh prepare-war ',
  243. mode = 0644,
  244. )
  245. self.assertResourceCalled('Execute', ('chown', '-R', 'oozie:hadoop', '/var/lib/oozie/oozie-server'),
  246. sudo = True,
  247. )
  248. def test_configure_existing_sqla(self):
  249. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  250. classname = "OozieServer",
  251. command = "configure",
  252. config_file="oozie_existing_sqla.json",
  253. hdp_stack_version = self.STACK_VERSION,
  254. target = RMFTestCase.TARGET_COMMON_SERVICES
  255. )
  256. self.assertResourceCalled('HdfsResource', '/user/oozie',
  257. security_enabled = False,
  258. hadoop_bin_dir = '/usr/bin',
  259. keytab = UnknownConfigurationMock(),
  260. default_fs = 'hdfs://c6401.ambari.apache.org:8020',
  261. hdfs_site = self.getConfig()['configurations']['hdfs-site'],
  262. kinit_path_local = '/usr/bin/kinit',
  263. principal_name = UnknownConfigurationMock(),
  264. user = 'hdfs',
  265. dfs_type = '',
  266. owner = 'oozie',
  267. hadoop_conf_dir = '/etc/hadoop/conf',
  268. type = 'directory',
  269. action = ['create_on_execute'],
  270. mode = 0775,
  271. )
  272. self.assertResourceCalled('HdfsResource', None,
  273. security_enabled = False,
  274. hadoop_bin_dir = '/usr/bin',
  275. keytab = UnknownConfigurationMock(),
  276. default_fs = 'hdfs://c6401.ambari.apache.org:8020',
  277. hdfs_site = self.getConfig()['configurations']['hdfs-site'],
  278. kinit_path_local = '/usr/bin/kinit',
  279. principal_name = UnknownConfigurationMock(),
  280. user = 'hdfs',
  281. dfs_type = '',
  282. action = ['execute'],
  283. hadoop_conf_dir = '/etc/hadoop/conf',
  284. )
  285. self.assertResourceCalled('Directory', '/etc/oozie/conf',
  286. owner = 'oozie',
  287. group = 'hadoop',
  288. recursive = True,
  289. )
  290. self.assertResourceCalled('XmlConfig', 'oozie-site.xml',
  291. group = 'hadoop',
  292. conf_dir = '/etc/oozie/conf',
  293. mode = 0664,
  294. configuration_attributes = {u'final': {u'oozie.service.CallableQueueService.queue.size': u'true',
  295. u'oozie.service.PurgeService.purge.interval': u'true'}},
  296. owner = 'oozie',
  297. configurations = self.getConfig()['configurations']['oozie-site'],
  298. )
  299. self.assertResourceCalled('File', '/etc/oozie/conf/oozie-env.sh',
  300. content = InlineTemplate(self.getConfig()['configurations']['oozie-env']['content']),
  301. owner = 'oozie',
  302. group = 'hadoop',
  303. )
  304. self.assertResourceCalled('File', '/etc/oozie/conf/oozie-log4j.properties',
  305. content = 'log4jproperties\nline2',
  306. owner = 'oozie',
  307. group = 'hadoop',
  308. mode = 0644,
  309. )
  310. self.assertResourceCalled('File', '/etc/oozie/conf/adminusers.txt',
  311. owner = 'oozie',
  312. group = 'hadoop',
  313. )
  314. self.assertResourceCalled('File', '/etc/oozie/conf/hadoop-config.xml',
  315. owner = 'oozie',
  316. group = 'hadoop',
  317. )
  318. self.assertResourceCalled('File', '/etc/oozie/conf/oozie-default.xml',
  319. owner = 'oozie',
  320. group = 'hadoop',
  321. )
  322. self.assertResourceCalled('Directory', '/etc/oozie/conf/action-conf',
  323. owner = 'oozie',
  324. group = 'hadoop',
  325. )
  326. self.assertResourceCalled('File', '/etc/oozie/conf/action-conf/hive.xml',
  327. owner = 'oozie',
  328. group = 'hadoop',
  329. )
  330. self.assertResourceCalled('File', '/var/run/oozie/oozie.pid',
  331. action = ['delete'],
  332. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  333. )
  334. self.assertResourceCalled('Directory', '/usr/lib/oozie//var/tmp/oozie',
  335. owner = 'oozie',
  336. cd_access = 'a',
  337. group = 'hadoop',
  338. recursive = True,
  339. mode = 0755,
  340. )
  341. self.assertResourceCalled('Directory', '/var/run/oozie',
  342. owner = 'oozie',
  343. cd_access = 'a',
  344. group = 'hadoop',
  345. recursive = True,
  346. mode = 0755,
  347. )
  348. self.assertResourceCalled('Directory', '/var/log/oozie',
  349. owner = 'oozie',
  350. cd_access = 'a',
  351. group = 'hadoop',
  352. recursive = True,
  353. mode = 0755,
  354. )
  355. self.assertResourceCalled('Directory', '/var/tmp/oozie',
  356. owner = 'oozie',
  357. cd_access = 'a',
  358. group = 'hadoop',
  359. recursive = True,
  360. mode = 0755,
  361. )
  362. self.assertResourceCalled('Directory', '/hadoop/oozie/data',
  363. owner = 'oozie',
  364. cd_access = 'a',
  365. group = 'hadoop',
  366. recursive = True,
  367. mode = 0755,
  368. )
  369. self.assertResourceCalled('Directory', '/var/lib/oozie',
  370. owner = 'oozie',
  371. cd_access = 'a',
  372. group = 'hadoop',
  373. recursive = True,
  374. mode = 0755,
  375. )
  376. self.assertResourceCalled('Directory', '/var/lib/oozie/oozie-server/webapps/',
  377. owner = 'oozie',
  378. cd_access = 'a',
  379. group = 'hadoop',
  380. recursive = True,
  381. mode = 0755,
  382. )
  383. self.assertResourceCalled('Directory', '/var/lib/oozie/oozie-server/conf',
  384. owner = 'oozie',
  385. cd_access = 'a',
  386. group = 'hadoop',
  387. recursive = True,
  388. mode = 0755,
  389. )
  390. self.assertResourceCalled('Directory', '/var/lib/oozie/oozie-server',
  391. owner = 'oozie',
  392. recursive = True,
  393. group = 'hadoop',
  394. mode = 0755,
  395. cd_access = 'a',
  396. )
  397. self.assertResourceCalled('Directory', '/usr/lib/oozie/libext',
  398. recursive = True,
  399. )
  400. self.assertResourceCalled('Execute', ('tar', '-xvf', '/usr/lib/oozie/oozie-sharelib.tar.gz', '-C', '/usr/lib/oozie'),
  401. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1' || test -f /usr/lib/oozie/.hashcode && test -d /usr/lib/oozie/share && [[ `cat /usr/lib/oozie/.hashcode` == 'abc123hash' ]]",
  402. sudo = True,
  403. )
  404. self.assertResourceCalled('Execute', ('cp', '/usr/share/HDP-oozie/ext-2.2.zip', '/usr/lib/oozie/libext'),
  405. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  406. sudo = True,
  407. )
  408. self.assertResourceCalled('Execute', ('chown', u'oozie:hadoop', '/usr/lib/oozie/libext/ext-2.2.zip'),
  409. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  410. sudo = True,
  411. )
  412. self.assertResourceCalled('Execute', ('chown', '-RL', u'oozie:hadoop', '/var/lib/oozie/oozie-server/conf'),
  413. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  414. sudo = True,
  415. )
  416. self.assertResourceCalled('File', '/tmp/sqla-client-jdbc.tar.gz',
  417. content = DownloadSource('http://c6401.ambari.apache.org:8080/resources//sqlanywhere-jdbc-driver.tar.gz'),
  418. )
  419. self.assertResourceCalled('Execute', ('tar', '-xvf', '/tmp/sqla-client-jdbc.tar.gz', '-C', '/tmp'),
  420. sudo = True,
  421. )
  422. self.assertResourceCalled('Execute', 'yes | ambari-sudo.sh cp /tmp/sqla-client-jdbc/java/* /usr/lib/oozie/libext')
  423. self.assertResourceCalled('Directory', '/usr/lib/oozie/libext/native/lib64',
  424. recursive = True,
  425. )
  426. self.assertResourceCalled('Execute', 'yes | ambari-sudo.sh cp /tmp/sqla-client-jdbc/native/lib64/* /usr/lib/oozie/libext/native/lib64')
  427. self.assertResourceCalled('Execute', 'ambari-sudo.sh chown -R oozie:hadoop /usr/lib/oozie/libext/*')
  428. self.assertResourceCalled('File', '/usr/lib/oozie/libext/sajdbc4.jar',
  429. owner = 'oozie',
  430. group = 'hadoop',
  431. )
  432. self.assertResourceCalled('Execute', 'ambari-sudo.sh cp /usr/lib/falcon/oozie/ext/falcon-oozie-el-extension-*.jar /usr/lib/oozie/libext',
  433. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  434. )
  435. self.assertResourceCalled('Execute', 'ambari-sudo.sh chown oozie:hadoop /usr/lib/oozie/libext/falcon-oozie-el-extension-*.jar',
  436. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  437. )
  438. self.assertResourceCalled('Execute', 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-setup.sh prepare-war ',
  439. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1' || test -f /usr/lib/oozie/.hashcode && test -d /usr/lib/oozie/share && [[ `cat /usr/lib/oozie/.hashcode` == 'abc123hash' ]] && test -f /usr/lib/oozie/.prepare_war_cmd && [[ `cat /usr/lib/oozie/.prepare_war_cmd` == 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-setup.sh prepare-war ' ]]",
  440. user = 'oozie',
  441. )
  442. self.assertResourceCalled('File', '/usr/lib/oozie/.hashcode',
  443. content = 'abc123hash',
  444. mode = 0644,
  445. )
  446. self.assertResourceCalled('File', '/usr/lib/oozie/.prepare_war_cmd',
  447. content = 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-setup.sh prepare-war ',
  448. mode = 0644,
  449. )
  450. self.assertResourceCalled('Execute', ('chown', '-R', u'oozie:hadoop', '/var/lib/oozie/oozie-server'),
  451. sudo = True,
  452. )
  453. self.assertNoMoreResources()
  454. @patch("os.path.isfile")
  455. def test_start_default(self, isfile_mock):
  456. isfile_mock.return_value = True
  457. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  458. classname = "OozieServer",
  459. command = "start",
  460. config_file="default.json",
  461. hdp_stack_version = self.STACK_VERSION,
  462. target = RMFTestCase.TARGET_COMMON_SERVICES
  463. )
  464. self.assert_configure_default()
  465. self.assertResourceCalled('Execute', 'cd /var/tmp/oozie && /usr/lib/oozie/bin/ooziedb.sh create -sqlfile oozie.sql -run',
  466. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  467. ignore_failures = True,
  468. user = 'oozie',
  469. )
  470. self.assertResourceCalled('Execute', 'hadoop --config /etc/hadoop/conf dfs -put /usr/lib/oozie/share /user/oozie',
  471. path = ['/usr/bin:/usr/bin'],
  472. user = 'oozie',
  473. )
  474. self.assertResourceCalled('HdfsResource', '/user/oozie/share',
  475. security_enabled = False,
  476. hadoop_bin_dir = '/usr/bin',
  477. keytab = UnknownConfigurationMock(),
  478. default_fs = 'hdfs://c6401.ambari.apache.org:8020',
  479. user = 'hdfs',
  480. dfs_type = '',
  481. hdfs_site = self.getConfig()['configurations']['hdfs-site'],
  482. kinit_path_local = '/usr/bin/kinit',
  483. principal_name = UnknownConfigurationMock(),
  484. recursive_chmod = True,
  485. action = ['create_on_execute'],
  486. hadoop_conf_dir = '/etc/hadoop/conf',
  487. type = 'directory',
  488. mode = 0755,
  489. )
  490. self.assertResourceCalled('HdfsResource', None,
  491. security_enabled = False,
  492. hadoop_bin_dir = '/usr/bin',
  493. keytab = UnknownConfigurationMock(),
  494. default_fs = 'hdfs://c6401.ambari.apache.org:8020',
  495. hdfs_site = self.getConfig()['configurations']['hdfs-site'],
  496. kinit_path_local = '/usr/bin/kinit',
  497. principal_name = UnknownConfigurationMock(),
  498. user = 'hdfs',
  499. dfs_type = '',
  500. action = ['execute'],
  501. hadoop_conf_dir = '/etc/hadoop/conf',
  502. )
  503. self.assertResourceCalled('Execute', 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-start.sh',
  504. environment = {'OOZIE_CONFIG': '/etc/oozie/conf'},
  505. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  506. user = 'oozie',
  507. )
  508. self.assertNoMoreResources()
  509. def test_stop_default(self):
  510. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  511. classname = "OozieServer",
  512. command = "stop",
  513. config_file="default.json",
  514. hdp_stack_version = self.STACK_VERSION,
  515. target = RMFTestCase.TARGET_COMMON_SERVICES
  516. )
  517. self.assertResourceCalled('Execute', 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-stop.sh',
  518. environment = {'OOZIE_CONFIG': '/etc/oozie/conf'},
  519. only_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  520. user = 'oozie',
  521. )
  522. self.assertResourceCalled('File', '/var/run/oozie/oozie.pid',
  523. action = ['delete'],
  524. )
  525. self.assertNoMoreResources()
  526. def test_configure_secured(self):
  527. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  528. classname = "OozieServer",
  529. command = "configure",
  530. config_file="secured.json",
  531. hdp_stack_version = self.STACK_VERSION,
  532. target = RMFTestCase.TARGET_COMMON_SERVICES
  533. )
  534. self.assert_configure_secured()
  535. self.assertNoMoreResources()
  536. @patch("os.path.isfile")
  537. def test_start_secured(self, isfile_mock):
  538. isfile_mock.return_value = True
  539. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  540. classname = "OozieServer",
  541. command = "start",
  542. config_file="secured.json",
  543. hdp_stack_version = self.STACK_VERSION,
  544. target = RMFTestCase.TARGET_COMMON_SERVICES
  545. )
  546. self.assert_configure_secured()
  547. self.assertResourceCalled('Execute', 'cd /var/tmp/oozie && /usr/lib/oozie/bin/ooziedb.sh create -sqlfile oozie.sql -run',
  548. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  549. ignore_failures = True,
  550. user = 'oozie',
  551. )
  552. self.assertResourceCalled('Execute', '/usr/bin/kinit -kt /etc/security/keytabs/oozie.service.keytab oozie/c6402.ambari.apache.org@EXAMPLE.COM;',
  553. user = 'oozie',
  554. )
  555. self.assertResourceCalled('Execute', 'hadoop --config /etc/hadoop/conf dfs -put /usr/lib/oozie/share /user/oozie',
  556. path = ['/usr/bin:/usr/bin'],
  557. user = 'oozie',
  558. )
  559. self.assertResourceCalled('HdfsResource', '/user/oozie/share',
  560. security_enabled = True,
  561. hadoop_bin_dir = '/usr/bin',
  562. keytab = '/etc/security/keytabs/hdfs.headless.keytab',
  563. default_fs = 'hdfs://c6401.ambari.apache.org:8020',
  564. user = 'hdfs',
  565. dfs_type = '',
  566. hdfs_site = self.getConfig()['configurations']['hdfs-site'],
  567. kinit_path_local = '/usr/bin/kinit',
  568. principal_name = 'hdfs',
  569. recursive_chmod = True,
  570. action = ['create_on_execute'],
  571. hadoop_conf_dir = '/etc/hadoop/conf',
  572. type = 'directory',
  573. mode = 0755,
  574. )
  575. self.assertResourceCalled('HdfsResource', None,
  576. security_enabled = True,
  577. hadoop_bin_dir = '/usr/bin',
  578. keytab = '/etc/security/keytabs/hdfs.headless.keytab',
  579. default_fs = 'hdfs://c6401.ambari.apache.org:8020',
  580. hdfs_site = self.getConfig()['configurations']['hdfs-site'],
  581. kinit_path_local = '/usr/bin/kinit',
  582. principal_name = 'hdfs',
  583. user = 'hdfs',
  584. dfs_type = '',
  585. action = ['execute'],
  586. hadoop_conf_dir = '/etc/hadoop/conf',
  587. )
  588. self.assertResourceCalled('Execute', 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-start.sh',
  589. environment = {'OOZIE_CONFIG': '/etc/oozie/conf'},
  590. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  591. user = 'oozie',
  592. )
  593. self.assertNoMoreResources()
  594. def test_stop_secured(self):
  595. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  596. classname = "OozieServer",
  597. command = "stop",
  598. config_file="secured.json",
  599. hdp_stack_version = self.STACK_VERSION,
  600. target = RMFTestCase.TARGET_COMMON_SERVICES
  601. )
  602. self.assertResourceCalled('Execute', 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-stop.sh',
  603. environment = {'OOZIE_CONFIG': '/etc/oozie/conf'},
  604. only_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  605. user = 'oozie',
  606. )
  607. self.assertResourceCalled('File', '/var/run/oozie/oozie.pid',
  608. action = ['delete'],
  609. )
  610. self.assertNoMoreResources()
  611. def assert_configure_default(self):
  612. self.assertResourceCalled('HdfsResource', '/user/oozie',
  613. security_enabled = False,
  614. hadoop_conf_dir = '/etc/hadoop/conf',
  615. keytab = UnknownConfigurationMock(),
  616. kinit_path_local = '/usr/bin/kinit',
  617. user = 'hdfs',
  618. dfs_type = '',
  619. owner = 'oozie',
  620. hadoop_bin_dir = '/usr/bin',
  621. type = 'directory',
  622. action = ['create_on_execute'], hdfs_site=self.getConfig()['configurations']['hdfs-site'], principal_name=UnknownConfigurationMock(), default_fs='hdfs://c6401.ambari.apache.org:8020',
  623. mode = 0775,
  624. )
  625. self.assertResourceCalled('HdfsResource', None,
  626. security_enabled = False,
  627. hadoop_bin_dir = '/usr/bin',
  628. keytab = UnknownConfigurationMock(),
  629. kinit_path_local = '/usr/bin/kinit',
  630. user = 'hdfs',
  631. dfs_type = '',
  632. action = ['execute'], hdfs_site=self.getConfig()['configurations']['hdfs-site'], principal_name=UnknownConfigurationMock(), default_fs='hdfs://c6401.ambari.apache.org:8020',
  633. hadoop_conf_dir = '/etc/hadoop/conf',
  634. )
  635. self.assertResourceCalled('Directory', '/etc/oozie/conf',
  636. owner = 'oozie',
  637. group = 'hadoop',
  638. recursive = True
  639. )
  640. self.assertResourceCalled('XmlConfig', 'oozie-site.xml',
  641. owner = 'oozie',
  642. group = 'hadoop',
  643. mode = 0664,
  644. conf_dir = '/etc/oozie/conf',
  645. configurations = self.getConfig()['configurations']['oozie-site'],
  646. configuration_attributes = self.getConfig()['configuration_attributes']['oozie-site']
  647. )
  648. self.assertResourceCalled('File', '/etc/oozie/conf/oozie-env.sh',
  649. owner = 'oozie',
  650. content = InlineTemplate(self.getConfig()['configurations']['oozie-env']['content']),
  651. group = 'hadoop',
  652. )
  653. self.assertResourceCalled('File', '/etc/oozie/conf/oozie-log4j.properties',
  654. owner = 'oozie',
  655. group = 'hadoop',
  656. mode = 0644,
  657. content = 'log4jproperties\nline2'
  658. )
  659. self.assertResourceCalled('File', '/etc/oozie/conf/adminusers.txt',
  660. owner = 'oozie',
  661. group = 'hadoop',
  662. )
  663. self.assertResourceCalled('File', '/etc/oozie/conf/hadoop-config.xml',
  664. owner = 'oozie',
  665. group = 'hadoop',
  666. )
  667. self.assertResourceCalled('File', '/etc/oozie/conf/oozie-default.xml',
  668. owner = 'oozie',
  669. group = 'hadoop',
  670. )
  671. self.assertResourceCalled('Directory', '/etc/oozie/conf/action-conf',
  672. owner = 'oozie',
  673. group = 'hadoop',
  674. )
  675. self.assertResourceCalled('File', '/etc/oozie/conf/action-conf/hive.xml',
  676. owner = 'oozie',
  677. group = 'hadoop',
  678. )
  679. self.assertResourceCalled('File', '/var/run/oozie/oozie.pid',
  680. action = ['delete'],
  681. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  682. )
  683. self.assertResourceCalled('Directory', '/usr/lib/oozie//var/tmp/oozie',
  684. owner = 'oozie',
  685. group = 'hadoop',
  686. recursive = True,
  687. mode = 0755,
  688. cd_access='a'
  689. )
  690. self.assertResourceCalled('Directory', '/var/run/oozie',
  691. owner = 'oozie',
  692. group = 'hadoop',
  693. recursive = True,
  694. mode = 0755,
  695. cd_access='a'
  696. )
  697. self.assertResourceCalled('Directory', '/var/log/oozie',
  698. owner = 'oozie',
  699. group = 'hadoop',
  700. recursive = True,
  701. mode = 0755,
  702. cd_access='a'
  703. )
  704. self.assertResourceCalled('Directory', '/var/tmp/oozie',
  705. owner = 'oozie',
  706. group = 'hadoop',
  707. recursive = True,
  708. mode = 0755,
  709. cd_access='a'
  710. )
  711. self.assertResourceCalled('Directory', '/hadoop/oozie/data',
  712. owner = 'oozie',
  713. group = 'hadoop',
  714. recursive = True,
  715. mode = 0755,
  716. cd_access='a'
  717. )
  718. self.assertResourceCalled('Directory', '/var/lib/oozie',
  719. owner = 'oozie',
  720. group = 'hadoop',
  721. recursive = True,
  722. mode = 0755,
  723. cd_access='a'
  724. )
  725. self.assertResourceCalled('Directory', '/var/lib/oozie/oozie-server/webapps/',
  726. owner = 'oozie',
  727. group = 'hadoop',
  728. recursive = True,
  729. mode = 0755,
  730. cd_access='a'
  731. )
  732. self.assertResourceCalled('Directory', '/var/lib/oozie/oozie-server/conf',
  733. owner = 'oozie',
  734. group = 'hadoop',
  735. recursive = True,
  736. mode = 0755,
  737. cd_access='a'
  738. )
  739. self.assertResourceCalled('Directory', '/var/lib/oozie/oozie-server',
  740. owner = 'oozie',
  741. group = 'hadoop',
  742. recursive = True,
  743. mode = 0755,
  744. cd_access='a'
  745. )
  746. self.assertResourceCalled('Directory', '/usr/lib/oozie/libext',
  747. recursive = True,
  748. )
  749. self.assertResourceCalled('Execute', ('tar', '-xvf', '/usr/lib/oozie/oozie-sharelib.tar.gz', '-C', '/usr/lib/oozie'),
  750. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1' || test -f /usr/lib/oozie/.hashcode && test -d /usr/lib/oozie/share && [[ `cat /usr/lib/oozie/.hashcode` == 'abc123hash' ]]",
  751. sudo = True,
  752. )
  753. self.assertResourceCalled('Execute', ('cp', '/usr/share/HDP-oozie/ext-2.2.zip', '/usr/lib/oozie/libext'),
  754. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  755. sudo = True,
  756. )
  757. self.assertResourceCalled('Execute', ('chown', 'oozie:hadoop', '/usr/lib/oozie/libext/ext-2.2.zip'),
  758. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  759. sudo = True,
  760. )
  761. self.assertResourceCalled('Execute', ('chown', '-RL', 'oozie:hadoop', '/var/lib/oozie/oozie-server/conf'),
  762. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  763. sudo = True,
  764. )
  765. self.assertResourceCalled('Execute', 'ambari-sudo.sh cp /usr/lib/falcon/oozie/ext/falcon-oozie-el-extension-*.jar /usr/lib/oozie/libext',
  766. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  767. )
  768. self.assertResourceCalled('Execute', 'ambari-sudo.sh chown oozie:hadoop /usr/lib/oozie/libext/falcon-oozie-el-extension-*.jar',
  769. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  770. )
  771. self.assertResourceCalled('Execute', 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-setup.sh prepare-war ',
  772. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1' || test -f /usr/lib/oozie/.hashcode && test -d /usr/lib/oozie/share && [[ `cat /usr/lib/oozie/.hashcode` == 'abc123hash' ]] && test -f /usr/lib/oozie/.prepare_war_cmd && [[ `cat /usr/lib/oozie/.prepare_war_cmd` == 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-setup.sh prepare-war ' ]]",
  773. user = 'oozie',
  774. )
  775. self.assertResourceCalled('File', '/usr/lib/oozie/.hashcode',
  776. content = 'abc123hash',
  777. mode = 0644,
  778. )
  779. self.assertResourceCalled('File', '/usr/lib/oozie/.prepare_war_cmd',
  780. content = 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-setup.sh prepare-war ',
  781. mode = 0644,
  782. )
  783. self.assertResourceCalled('Execute', ('chown', '-R', 'oozie:hadoop', '/var/lib/oozie/oozie-server'),
  784. sudo = True,
  785. )
  786. def assert_configure_secured(self):
  787. self.assertResourceCalled('HdfsResource', '/user/oozie',
  788. security_enabled = True,
  789. hadoop_conf_dir = '/etc/hadoop/conf',
  790. keytab = '/etc/security/keytabs/hdfs.headless.keytab',
  791. kinit_path_local = '/usr/bin/kinit',
  792. user = 'hdfs',
  793. dfs_type = '',
  794. owner = 'oozie',
  795. hadoop_bin_dir = '/usr/bin',
  796. type = 'directory',
  797. action = ['create_on_execute'], hdfs_site=self.getConfig()['configurations']['hdfs-site'], principal_name='hdfs', default_fs='hdfs://c6401.ambari.apache.org:8020',
  798. mode = 0775,
  799. )
  800. self.assertResourceCalled('HdfsResource', None,
  801. security_enabled = True,
  802. hadoop_bin_dir = '/usr/bin',
  803. keytab = '/etc/security/keytabs/hdfs.headless.keytab',
  804. kinit_path_local = '/usr/bin/kinit',
  805. user = 'hdfs',
  806. dfs_type = '',
  807. action = ['execute'], hdfs_site=self.getConfig()['configurations']['hdfs-site'], principal_name='hdfs', default_fs='hdfs://c6401.ambari.apache.org:8020',
  808. hadoop_conf_dir = '/etc/hadoop/conf',
  809. )
  810. self.assertResourceCalled('Directory', '/etc/oozie/conf',
  811. owner = 'oozie',
  812. group = 'hadoop',
  813. recursive = True
  814. )
  815. self.assertResourceCalled('XmlConfig', 'oozie-site.xml',
  816. owner = 'oozie',
  817. group = 'hadoop',
  818. mode = 0664,
  819. conf_dir = '/etc/oozie/conf',
  820. configurations = self.getConfig()['configurations']['oozie-site'],
  821. configuration_attributes = self.getConfig()['configuration_attributes']['oozie-site']
  822. )
  823. self.assertResourceCalled('File', '/etc/oozie/conf/oozie-env.sh',
  824. owner = 'oozie',
  825. content = InlineTemplate(self.getConfig()['configurations']['oozie-env']['content']),
  826. group = 'hadoop',
  827. )
  828. self.assertResourceCalled('File', '/etc/oozie/conf/oozie-log4j.properties',
  829. owner = 'oozie',
  830. group = 'hadoop',
  831. mode = 0644,
  832. content = 'log4jproperties\nline2'
  833. )
  834. self.assertResourceCalled('File', '/etc/oozie/conf/adminusers.txt',
  835. owner = 'oozie',
  836. group = 'hadoop',
  837. )
  838. self.assertResourceCalled('File', '/etc/oozie/conf/hadoop-config.xml',
  839. owner = 'oozie',
  840. group = 'hadoop',
  841. )
  842. self.assertResourceCalled('File', '/etc/oozie/conf/oozie-default.xml',
  843. owner = 'oozie',
  844. group = 'hadoop',
  845. )
  846. self.assertResourceCalled('Directory', '/etc/oozie/conf/action-conf',
  847. owner = 'oozie',
  848. group = 'hadoop',
  849. )
  850. self.assertResourceCalled('File', '/etc/oozie/conf/action-conf/hive.xml',
  851. owner = 'oozie',
  852. group = 'hadoop',
  853. )
  854. self.assertResourceCalled('File', '/var/run/oozie/oozie.pid',
  855. action = ['delete'],
  856. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  857. )
  858. self.assertResourceCalled('Directory', '/usr/lib/oozie//var/tmp/oozie',
  859. owner = 'oozie',
  860. group = 'hadoop',
  861. recursive = True,
  862. mode = 0755,
  863. cd_access='a'
  864. )
  865. self.assertResourceCalled('Directory', '/var/run/oozie',
  866. owner = 'oozie',
  867. group = 'hadoop',
  868. recursive = True,
  869. mode = 0755,
  870. cd_access='a'
  871. )
  872. self.assertResourceCalled('Directory', '/var/log/oozie',
  873. owner = 'oozie',
  874. group = 'hadoop',
  875. recursive = True,
  876. mode = 0755,
  877. cd_access='a'
  878. )
  879. self.assertResourceCalled('Directory', '/var/tmp/oozie',
  880. owner = 'oozie',
  881. group = 'hadoop',
  882. recursive = True,
  883. mode = 0755,
  884. cd_access='a'
  885. )
  886. self.assertResourceCalled('Directory', '/hadoop/oozie/data',
  887. owner = 'oozie',
  888. group = 'hadoop',
  889. recursive = True,
  890. mode = 0755,
  891. cd_access='a'
  892. )
  893. self.assertResourceCalled('Directory', '/var/lib/oozie',
  894. owner = 'oozie',
  895. group = 'hadoop',
  896. recursive = True,
  897. mode = 0755,
  898. cd_access='a'
  899. )
  900. self.assertResourceCalled('Directory', '/var/lib/oozie/oozie-server/webapps/',
  901. owner = 'oozie',
  902. group = 'hadoop',
  903. recursive = True,
  904. mode = 0755,
  905. cd_access='a'
  906. )
  907. self.assertResourceCalled('Directory', '/var/lib/oozie/oozie-server/conf',
  908. owner = 'oozie',
  909. group = 'hadoop',
  910. recursive = True,
  911. mode = 0755,
  912. cd_access='a'
  913. )
  914. self.assertResourceCalled('Directory', '/var/lib/oozie/oozie-server',
  915. owner = 'oozie',
  916. group = 'hadoop',
  917. recursive = True,
  918. mode = 0755,
  919. cd_access='a'
  920. )
  921. self.assertResourceCalled('Directory', '/usr/lib/oozie/libext',
  922. recursive = True,
  923. )
  924. self.assertResourceCalled('Execute', ('tar', '-xvf', '/usr/lib/oozie/oozie-sharelib.tar.gz', '-C', '/usr/lib/oozie'),
  925. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1' || test -f /usr/lib/oozie/.hashcode && test -d /usr/lib/oozie/share && [[ `cat /usr/lib/oozie/.hashcode` == 'abc123hash' ]]",
  926. sudo = True,
  927. )
  928. self.assertResourceCalled('Execute', ('cp', '/usr/share/HDP-oozie/ext-2.2.zip', '/usr/lib/oozie/libext'),
  929. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  930. sudo = True,
  931. )
  932. self.assertResourceCalled('Execute', ('chown', 'oozie:hadoop', '/usr/lib/oozie/libext/ext-2.2.zip'),
  933. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  934. sudo = True,
  935. )
  936. self.assertResourceCalled('Execute', ('chown', '-RL', 'oozie:hadoop', '/var/lib/oozie/oozie-server/conf'),
  937. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  938. sudo = True,
  939. )
  940. self.assertResourceCalled('Execute', 'ambari-sudo.sh cp /usr/lib/falcon/oozie/ext/falcon-oozie-el-extension-*.jar /usr/lib/oozie/libext',
  941. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  942. )
  943. self.assertResourceCalled('Execute', 'ambari-sudo.sh chown oozie:hadoop /usr/lib/oozie/libext/falcon-oozie-el-extension-*.jar',
  944. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1'",
  945. )
  946. self.assertResourceCalled('Execute', 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-setup.sh prepare-war -secure',
  947. not_if = "ambari-sudo.sh su oozie -l -s /bin/bash -c '[RMF_EXPORT_PLACEHOLDER]ls /var/run/oozie/oozie.pid >/dev/null 2>&1 && ps -p `cat /var/run/oozie/oozie.pid` >/dev/null 2>&1' || test -f /usr/lib/oozie/.hashcode && test -d /usr/lib/oozie/share && [[ `cat /usr/lib/oozie/.hashcode` == 'abc123hash' ]] && test -f /usr/lib/oozie/.prepare_war_cmd && [[ `cat /usr/lib/oozie/.prepare_war_cmd` == 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-setup.sh prepare-war -secure' ]]",
  948. user = 'oozie',
  949. )
  950. self.assertResourceCalled('File', '/usr/lib/oozie/.hashcode',
  951. content = 'abc123hash',
  952. mode = 0644,
  953. )
  954. self.assertResourceCalled('File', '/usr/lib/oozie/.prepare_war_cmd',
  955. content = 'cd /var/tmp/oozie && /usr/lib/oozie/bin/oozie-setup.sh prepare-war -secure',
  956. mode = 0644,
  957. )
  958. self.assertResourceCalled('Execute', ('chown', '-R', 'oozie:hadoop', '/var/lib/oozie/oozie-server'),
  959. sudo = True,
  960. )
  961. def test_configure_default_hdp22(self):
  962. config_file = "stacks/2.0.6/configs/default.json"
  963. with open(config_file, "r") as f:
  964. default_json = json.load(f)
  965. default_json['hostLevelParams']['stack_version']= '2.2'
  966. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  967. classname = "OozieServer",
  968. command = "configure",
  969. config_file="default.json",
  970. hdp_stack_version = self.STACK_VERSION,
  971. target = RMFTestCase.TARGET_COMMON_SERVICES
  972. )
  973. self.assert_configure_default()
  974. self.assertResourceCalled('Directory', '/etc/oozie/conf/action-conf/hive',
  975. owner = 'oozie',
  976. group = 'hadoop',
  977. recursive = True
  978. )
  979. self.assertResourceCalled('XmlConfig', 'hive-site',
  980. owner = 'oozie',
  981. group = 'hadoop',
  982. mode = 0664,
  983. conf_dir = '/etc/oozie/conf/action-conf/hive',
  984. configurations = self.getConfig()['configurations']['hive-site'],
  985. configuration_attributes = self.getConfig()['configuration_attributes']['hive-site']
  986. )
  987. self.assertResourceCalled('XmlConfig', 'tez-site',
  988. owner = 'oozie',
  989. group = 'hadoop',
  990. mode = 0664,
  991. conf_dir = '/etc/oozie/conf/action-conf/hive',
  992. configurations = self.getConfig()['configurations']['tez-site'],
  993. configuration_attributes = self.getConfig()['configuration_attributes']['tez-site']
  994. )
  995. self.assertNoMoreResources()
  996. @patch("resource_management.libraries.functions.security_commons.build_expectations")
  997. @patch("resource_management.libraries.functions.security_commons.get_params_from_filesystem")
  998. @patch("resource_management.libraries.functions.security_commons.validate_security_config_properties")
  999. @patch("resource_management.libraries.functions.security_commons.cached_kinit_executor")
  1000. @patch("resource_management.libraries.script.Script.put_structured_out")
  1001. def test_security_status(self, put_structured_out_mock, cached_kinit_executor_mock, validate_security_config_mock, get_params_mock, build_exp_mock):
  1002. # Test that function works when is called with correct parameters
  1003. security_params = {
  1004. "oozie-site": {
  1005. "oozie.authentication.type": "kerberos",
  1006. "oozie.service.AuthorizationService.security.enabled": "true",
  1007. "oozie.service.HadoopAccessorService.kerberos.enabled": "true",
  1008. "local.realm": "EXAMPLE.COM",
  1009. "oozie.authentication.kerberos.principal": "principal",
  1010. "oozie.authentication.kerberos.keytab": "/path/to_keytab",
  1011. "oozie.service.HadoopAccessorService.kerberos.principal": "principal",
  1012. "oozie.service.HadoopAccessorService.keytab.file": "/path/to_keytab"}
  1013. }
  1014. result_issues = []
  1015. props_value_check = {"oozie.authentication.type": "kerberos",
  1016. "oozie.service.AuthorizationService.security.enabled": "true",
  1017. "oozie.service.HadoopAccessorService.kerberos.enabled": "true"}
  1018. props_empty_check = [ "local.realm",
  1019. "oozie.authentication.kerberos.principal",
  1020. "oozie.authentication.kerberos.keytab",
  1021. "oozie.service.HadoopAccessorService.kerberos.principal",
  1022. "oozie.service.HadoopAccessorService.keytab.file"]
  1023. props_read_check = None
  1024. get_params_mock.return_value = security_params
  1025. validate_security_config_mock.return_value = result_issues
  1026. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  1027. classname = "OozieServer",
  1028. command = "security_status",
  1029. config_file="secured.json",
  1030. hdp_stack_version = self.STACK_VERSION,
  1031. target = RMFTestCase.TARGET_COMMON_SERVICES
  1032. )
  1033. get_params_mock.assert_called_with("/etc/oozie/conf", {'oozie-site.xml': 'XML'})
  1034. build_exp_mock.assert_called_with('oozie-site', props_value_check, props_empty_check, props_read_check)
  1035. put_structured_out_mock.assert_called_with({"securityState": "SECURED_KERBEROS"})
  1036. self.assertTrue(cached_kinit_executor_mock.call_count, 2)
  1037. cached_kinit_executor_mock.assert_called_with('/usr/bin/kinit',
  1038. self.config_dict['configurations']['oozie-env']['oozie_user'],
  1039. security_params['oozie-site']['oozie.service.HadoopAccessorService.keytab.file'],
  1040. security_params['oozie-site']['oozie.service.HadoopAccessorService.kerberos.principal'],
  1041. self.config_dict['hostname'],
  1042. '/tmp')
  1043. # Testing that the exception throw by cached_executor is caught
  1044. cached_kinit_executor_mock.reset_mock()
  1045. cached_kinit_executor_mock.side_effect = Exception("Invalid command")
  1046. try:
  1047. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  1048. classname = "OozieServer",
  1049. command = "security_status",
  1050. config_file="secured.json",
  1051. hdp_stack_version = self.STACK_VERSION,
  1052. target = RMFTestCase.TARGET_COMMON_SERVICES
  1053. )
  1054. except:
  1055. self.assertTrue(True)
  1056. # Testing with a security_params which doesn't contains oozie-site
  1057. empty_security_params = {}
  1058. cached_kinit_executor_mock.reset_mock()
  1059. get_params_mock.reset_mock()
  1060. put_structured_out_mock.reset_mock()
  1061. get_params_mock.return_value = empty_security_params
  1062. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  1063. classname = "OozieServer",
  1064. command = "security_status",
  1065. config_file="secured.json",
  1066. hdp_stack_version = self.STACK_VERSION,
  1067. target = RMFTestCase.TARGET_COMMON_SERVICES
  1068. )
  1069. put_structured_out_mock.assert_called_with({"securityIssuesFound": "Keytab file or principal are not set property."})
  1070. # Testing with not empty result_issues
  1071. result_issues_with_params = {
  1072. 'oozie-site': "Something bad happened"
  1073. }
  1074. validate_security_config_mock.reset_mock()
  1075. get_params_mock.reset_mock()
  1076. validate_security_config_mock.return_value = result_issues_with_params
  1077. get_params_mock.return_value = security_params
  1078. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  1079. classname = "OozieServer",
  1080. command = "security_status",
  1081. config_file="secured.json",
  1082. hdp_stack_version = self.STACK_VERSION,
  1083. target = RMFTestCase.TARGET_COMMON_SERVICES
  1084. )
  1085. put_structured_out_mock.assert_called_with({"securityState": "UNSECURED"})
  1086. # Testing with security_enable = false
  1087. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  1088. classname = "OozieServer",
  1089. command = "security_status",
  1090. config_file="default.json",
  1091. hdp_stack_version = self.STACK_VERSION,
  1092. target = RMFTestCase.TARGET_COMMON_SERVICES
  1093. )
  1094. put_structured_out_mock.assert_called_with({"securityState": "UNSECURED"})
  1095. @patch("os.path.isdir")
  1096. @patch("os.path.exists")
  1097. @patch("os.path.isfile")
  1098. @patch("os.remove")
  1099. @patch("shutil.rmtree", new = MagicMock())
  1100. @patch("glob.iglob")
  1101. @patch("shutil.copy2", new = MagicMock())
  1102. def test_upgrade(self, glob_mock, remove_mock,
  1103. isfile_mock, exists_mock, isdir_mock):
  1104. def exists_mock_side_effect(path):
  1105. if path == '/tmp/oozie-upgrade-backup/oozie-conf-backup.tar':
  1106. return True
  1107. return False
  1108. exists_mock.side_effect = exists_mock_side_effect
  1109. isdir_mock.return_value = True
  1110. isfile_mock.return_value = True
  1111. glob_mock.return_value = ["/usr/hdp/2.2.1.0-2187/hadoop/lib/hadoop-lzo-0.6.0.2.2.1.0-2187.jar"]
  1112. prepare_war_stdout = """INFO: Adding extension: libext/mysql-connector-java.jar
  1113. New Oozie WAR file with added 'JARs' at /var/lib/oozie/oozie-server/webapps/oozie.war"""
  1114. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  1115. classname = "OozieServer", command = "pre_rolling_restart", config_file = "oozie-upgrade.json",
  1116. hdp_stack_version = self.UPGRADE_STACK_VERSION,
  1117. target = RMFTestCase.TARGET_COMMON_SERVICES,
  1118. call_mocks = [(0, prepare_war_stdout)])
  1119. self.assertTrue(isfile_mock.called)
  1120. self.assertEqual(isfile_mock.call_count,3)
  1121. isfile_mock.assert_called_with('/usr/share/HDP-oozie/ext-2.2.zip')
  1122. self.assertTrue(glob_mock.called)
  1123. self.assertEqual(glob_mock.call_count,1)
  1124. glob_mock.assert_called_with('/usr/hdp/2.2.1.0-2135/hadoop/lib/hadoop-lzo*.jar')
  1125. self.assertResourceCalled('Execute',
  1126. ('tar', '-zcvhf', '/tmp/oozie-upgrade-backup/oozie-conf-backup.tar', '/usr/hdp/current/oozie-server/conf/'),
  1127. sudo = True)
  1128. self.assertResourceCalled('Execute', ('ambari-python-wrap', 'hdp-select', 'set', 'oozie-server', u'2.2.1.0-2135'),
  1129. sudo = True )
  1130. self.assertResourceCalled('Execute',
  1131. ('tar', '-xvf', '/tmp/oozie-upgrade-backup/oozie-conf-backup.tar', '-C', '/usr/hdp/current/oozie-server/conf//'),
  1132. sudo = True)
  1133. self.assertResourceCalled('Directory', '/tmp/oozie-upgrade-backup', action = ['delete'])
  1134. self.assertResourceCalled('Directory', '/usr/hdp/current/oozie-server/libext', mode = 0777)
  1135. self.assertResourceCalled('Execute', ('cp', '/usr/share/HDP-oozie/ext-2.2.zip', '/usr/hdp/current/oozie-server/libext'), sudo=True)
  1136. self.assertResourceCalled('Execute', ('chown', 'oozie:hadoop', '/usr/hdp/current/oozie-server/libext/ext-2.2.zip'), sudo=True)
  1137. self.assertResourceCalled('File', '/usr/hdp/current/oozie-server/libext/ext-2.2.zip',
  1138. mode = 0644,
  1139. )
  1140. self.assertNoMoreResources()
  1141. @patch("os.path.isdir")
  1142. @patch("os.path.exists")
  1143. @patch("os.path.isfile")
  1144. @patch("os.remove")
  1145. @patch("shutil.rmtree", new = MagicMock())
  1146. @patch("glob.iglob")
  1147. @patch("shutil.copy2", new = MagicMock())
  1148. def test_upgrade_23(self, glob_mock, remove_mock,
  1149. isfile_mock, exists_mock, isdir_mock):
  1150. def exists_mock_side_effect(path):
  1151. if path == '/tmp/oozie-upgrade-backup/oozie-conf-backup.tar':
  1152. return True
  1153. return False
  1154. isdir_mock.return_value = True
  1155. exists_mock.side_effect = exists_mock_side_effect
  1156. isfile_mock.return_value = True
  1157. glob_mock.return_value = ["/usr/hdp/2.2.1.0-2187/hadoop/lib/hadoop-lzo-0.6.0.2.2.1.0-2187.jar"]
  1158. prepare_war_stdout = """INFO: Adding extension: libext/mysql-connector-java.jar
  1159. New Oozie WAR file with added 'JARs' at /var/lib/oozie/oozie-server/webapps/oozie.war"""
  1160. config_file = self.get_src_folder()+"/test/python/stacks/2.2/configs/oozie-upgrade.json"
  1161. with open(config_file, "r") as f:
  1162. json_content = json.load(f)
  1163. version = '2.3.0.0-1234'
  1164. json_content['commandParams']['version'] = version
  1165. mocks_dict = {}
  1166. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  1167. classname = "OozieServer", command = "pre_rolling_restart", config_dict = json_content,
  1168. hdp_stack_version = self.UPGRADE_STACK_VERSION,
  1169. target = RMFTestCase.TARGET_COMMON_SERVICES,
  1170. call_mocks = [(0, None), (0, prepare_war_stdout)],
  1171. mocks_dict = mocks_dict)
  1172. self.assertTrue(isfile_mock.called)
  1173. self.assertEqual(isfile_mock.call_count,3)
  1174. isfile_mock.assert_called_with('/usr/share/HDP-oozie/ext-2.2.zip')
  1175. self.assertTrue(glob_mock.called)
  1176. self.assertEqual(glob_mock.call_count,1)
  1177. glob_mock.assert_called_with('/usr/hdp/2.3.0.0-1234/hadoop/lib/hadoop-lzo*.jar')
  1178. self.assertResourceCalled('Execute',
  1179. ('tar', '-zcvhf', '/tmp/oozie-upgrade-backup/oozie-conf-backup.tar', '/usr/hdp/current/oozie-server/conf/'),
  1180. sudo = True)
  1181. self.assertResourceCalled('Execute', ('ambari-python-wrap', 'hdp-select', 'set', 'oozie-server', '2.3.0.0-1234'), sudo = True)
  1182. self.assertResourceCalled('Execute',
  1183. ('tar', '-xvf', '/tmp/oozie-upgrade-backup/oozie-conf-backup.tar', '-C', '/usr/hdp/current/oozie-server/conf//'),
  1184. sudo = True)
  1185. self.assertResourceCalled('Directory', '/tmp/oozie-upgrade-backup', action = ['delete'])
  1186. self.assertResourceCalled('Directory', '/usr/hdp/current/oozie-server/libext', mode = 0777)
  1187. self.assertResourceCalled('Execute', ('cp', '/usr/share/HDP-oozie/ext-2.2.zip', '/usr/hdp/current/oozie-server/libext'), sudo=True)
  1188. self.assertResourceCalled('Execute', ('chown', 'oozie:hadoop', '/usr/hdp/current/oozie-server/libext/ext-2.2.zip'), sudo=True)
  1189. self.assertResourceCalled('File', '/usr/hdp/current/oozie-server/libext/ext-2.2.zip',
  1190. mode = 0644,
  1191. )
  1192. self.assertNoMoreResources()
  1193. self.assertEquals(1, mocks_dict['call'].call_count)
  1194. self.assertEquals(1, mocks_dict['checked_call'].call_count)
  1195. self.assertEquals(
  1196. ('conf-select', 'set-conf-dir', '--package', 'oozie', '--stack-version', '2.3.0.0-1234', '--conf-version', '0'),
  1197. mocks_dict['checked_call'].call_args_list[0][0][0])
  1198. self.assertEquals(
  1199. ('conf-select', 'create-conf-dir', '--package', 'oozie', '--stack-version', '2.3.0.0-1234', '--conf-version', '0'),
  1200. mocks_dict['call'].call_args_list[0][0][0])
  1201. @patch("os.path.isdir")
  1202. @patch("os.path.exists")
  1203. @patch("os.path.isfile")
  1204. @patch("os.remove")
  1205. @patch("shutil.rmtree", new = MagicMock())
  1206. @patch("shutil.copy2", new = MagicMock())
  1207. def test_downgrade_no_compression_library_copy(self, remove_mock,
  1208. isfile_mock, exists_mock, isdir_mock):
  1209. isdir_mock.return_value = True
  1210. exists_mock.return_value = False
  1211. isfile_mock.return_value = True
  1212. prepare_war_stdout = """INFO: Adding extension: libext/mysql-connector-java.jar
  1213. New Oozie WAR file with added 'JARs' at /var/lib/oozie/oozie-server/webapps/oozie.war"""
  1214. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  1215. classname = "OozieServer", command = "pre_rolling_restart", config_file = "oozie-downgrade.json",
  1216. hdp_stack_version = self.UPGRADE_STACK_VERSION,
  1217. target = RMFTestCase.TARGET_COMMON_SERVICES,
  1218. call_mocks = [(0, prepare_war_stdout)])
  1219. self.assertTrue(isfile_mock.called)
  1220. self.assertEqual(isfile_mock.call_count,2)
  1221. isfile_mock.assert_called_with('/usr/share/HDP-oozie/ext-2.2.zip')
  1222. self.assertResourceCalled('Execute',
  1223. ('tar', '-zcvhf', '/tmp/oozie-upgrade-backup/oozie-conf-backup.tar', '/usr/hdp/current/oozie-server/conf/'),
  1224. sudo = True)
  1225. self.assertResourceCalled('Execute', ('ambari-python-wrap', 'hdp-select', 'set', 'oozie-server', u'2.2.0.0-0000'), sudo = True)
  1226. self.assertResourceCalled('Execute',
  1227. ('tar', '-xvf', '/tmp/oozie-upgrade-backup/oozie-conf-backup.tar', '-C', '/usr/hdp/current/oozie-server/conf//'),
  1228. sudo = True)
  1229. self.assertResourceCalled('Directory', '/tmp/oozie-upgrade-backup', action = ['delete'])
  1230. self.assertResourceCalled('Directory', '/usr/hdp/current/oozie-server/libext',mode = 0777)
  1231. self.assertResourceCalled('Execute', ('cp', '/usr/share/HDP-oozie/ext-2.2.zip', '/usr/hdp/current/oozie-server/libext'), sudo=True)
  1232. self.assertResourceCalled('Execute', ('chown', 'oozie:hadoop', '/usr/hdp/current/oozie-server/libext/ext-2.2.zip'), sudo=True)
  1233. self.assertResourceCalled('File', '/usr/hdp/current/oozie-server/libext/ext-2.2.zip',
  1234. mode = 0644,
  1235. )
  1236. self.assertNoMoreResources()
  1237. def test_upgrade_database_sharelib(self):
  1238. """
  1239. Tests that the upgrade script runs the proper commands before the
  1240. actual upgrade begins.
  1241. :return:
  1242. """
  1243. config_file = self.get_src_folder()+"/test/python/stacks/2.2/configs/oozie-upgrade.json"
  1244. with open(config_file, "r") as f:
  1245. json_content = json.load(f)
  1246. version = '2.3.0.0-1234'
  1247. json_content['commandParams']['version'] = version
  1248. json_content['hostLevelParams']['stack_name'] = "HDP"
  1249. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server_upgrade.py",
  1250. classname = "OozieUpgrade", command = "upgrade_oozie_database_and_sharelib",
  1251. config_dict = json_content,
  1252. hdp_stack_version = self.UPGRADE_STACK_VERSION,
  1253. target = RMFTestCase.TARGET_COMMON_SERVICES )
  1254. self.assertResourceCalled('Execute', '/usr/hdp/2.3.0.0-1234/oozie/bin/ooziedb.sh upgrade -run',
  1255. user = 'oozie', logoutput = True )
  1256. self.assertResourceCalled('HdfsResource', '/user/oozie/share',
  1257. security_enabled = False,
  1258. hadoop_bin_dir = '/usr/hdp/2.3.0.0-1234/hadoop/bin',
  1259. keytab = UnknownConfigurationMock(),
  1260. default_fs = 'hdfs://c6401.ambari.apache.org:8020',
  1261. user = 'hdfs',
  1262. dfs_type = '',
  1263. hdfs_site = UnknownConfigurationMock(),
  1264. kinit_path_local = '/usr/bin/kinit',
  1265. principal_name = UnknownConfigurationMock(),
  1266. recursive_chmod = True,
  1267. owner = 'oozie',
  1268. group = 'hadoop',
  1269. hadoop_conf_dir = '/usr/hdp/current/hadoop-client/conf',
  1270. type = 'directory',
  1271. action = ['create_on_execute'],
  1272. mode = 0755 )
  1273. self.assertResourceCalled('HdfsResource', None,
  1274. security_enabled = False,
  1275. hadoop_bin_dir = '/usr/hdp/2.3.0.0-1234/hadoop/bin',
  1276. keytab = UnknownConfigurationMock(),
  1277. default_fs = 'hdfs://c6401.ambari.apache.org:8020',
  1278. hdfs_site = UnknownConfigurationMock(),
  1279. kinit_path_local = '/usr/bin/kinit',
  1280. principal_name = UnknownConfigurationMock(),
  1281. user = 'hdfs',
  1282. dfs_type = '',
  1283. action = ['execute'],
  1284. hadoop_conf_dir = '/usr/hdp/current/hadoop-client/conf' )
  1285. self.assertResourceCalled('Execute', '/usr/hdp/2.3.0.0-1234/oozie/bin/oozie-setup.sh sharelib create -fs hdfs://c6401.ambari.apache.org:8020',
  1286. user='oozie', logoutput = True)
  1287. def test_upgrade_database_sharelib_existing_mysql(self):
  1288. """
  1289. Tests that the upgrade script runs the proper commands before the
  1290. actual upgrade begins when Oozie is using and external database. This
  1291. should ensure that the JDBC JAR is copied.
  1292. :return:
  1293. """
  1294. config_file = self.get_src_folder()+"/test/python/stacks/2.2/configs/oozie-upgrade.json"
  1295. with open(config_file, "r") as f:
  1296. json_content = json.load(f)
  1297. version = '2.3.0.0-1234'
  1298. json_content['commandParams']['version'] = version
  1299. json_content['hostLevelParams']['stack_name'] = "HDP"
  1300. # use mysql external database
  1301. json_content['configurations']['oozie-site']['oozie.service.JPAService.jdbc.driver'] = "com.mysql.jdbc.Driver"
  1302. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server_upgrade.py",
  1303. classname = "OozieUpgrade", command = "upgrade_oozie_database_and_sharelib",
  1304. config_dict = json_content,
  1305. hdp_stack_version = self.UPGRADE_STACK_VERSION,
  1306. target = RMFTestCase.TARGET_COMMON_SERVICES )
  1307. self.assertResourceCalled('File', '/tmp/mysql-connector-java.jar',
  1308. content = DownloadSource('http://c6401.ambari.apache.org:8080/resources//mysql-jdbc-driver.jar') )
  1309. self.assertResourceCalled('Execute', ('cp', '--remove-destination', '/tmp/mysql-connector-java.jar',
  1310. '/usr/hdp/2.3.0.0-1234/oozie/libext/mysql-connector-java.jar'),
  1311. path = ['/bin', '/usr/bin/'], sudo = True)
  1312. self.assertResourceCalled('File', '/usr/hdp/2.3.0.0-1234/oozie/libext/mysql-connector-java.jar',
  1313. owner = 'oozie', group = 'hadoop' )
  1314. self.assertResourceCalled('Execute', '/usr/hdp/2.3.0.0-1234/oozie/bin/ooziedb.sh upgrade -run',
  1315. user = 'oozie', logoutput = True )
  1316. self.assertResourceCalled('HdfsResource', '/user/oozie/share',
  1317. security_enabled = False,
  1318. hadoop_bin_dir = '/usr/hdp/2.3.0.0-1234/hadoop/bin',
  1319. keytab = UnknownConfigurationMock(),
  1320. default_fs = 'hdfs://c6401.ambari.apache.org:8020',
  1321. user = 'hdfs',
  1322. dfs_type = '',
  1323. hdfs_site = UnknownConfigurationMock(),
  1324. kinit_path_local = '/usr/bin/kinit',
  1325. principal_name = UnknownConfigurationMock(),
  1326. recursive_chmod = True,
  1327. owner = 'oozie',
  1328. group = 'hadoop',
  1329. hadoop_conf_dir = '/usr/hdp/current/hadoop-client/conf',
  1330. type = 'directory',
  1331. action = ['create_on_execute'],
  1332. mode = 0755 )
  1333. self.assertResourceCalled('HdfsResource', None,
  1334. security_enabled = False,
  1335. hadoop_bin_dir = '/usr/hdp/2.3.0.0-1234/hadoop/bin',
  1336. keytab = UnknownConfigurationMock(),
  1337. default_fs = 'hdfs://c6401.ambari.apache.org:8020',
  1338. hdfs_site = UnknownConfigurationMock(),
  1339. kinit_path_local = '/usr/bin/kinit',
  1340. principal_name = UnknownConfigurationMock(),
  1341. user = 'hdfs',
  1342. dfs_type = '',
  1343. action = ['execute'],
  1344. hadoop_conf_dir = '/usr/hdp/current/hadoop-client/conf' )
  1345. self.assertResourceCalled('Execute', '/usr/hdp/2.3.0.0-1234/oozie/bin/oozie-setup.sh sharelib create -fs hdfs://c6401.ambari.apache.org:8020',
  1346. user='oozie', logoutput = True)
  1347. @patch("os.path.isdir")
  1348. @patch("os.path.exists")
  1349. @patch("os.path.isfile")
  1350. @patch("os.remove")
  1351. @patch("shutil.rmtree", new = MagicMock())
  1352. @patch("glob.iglob")
  1353. @patch("shutil.copy2", new = MagicMock())
  1354. def test_upgrade_23_ensure_falcon_copied(self, glob_mock, remove_mock,
  1355. isfile_mock, exists_mock, isdir_mock):
  1356. def exists_mock_side_effect(path):
  1357. if path == '/tmp/oozie-upgrade-backup/oozie-conf-backup.tar':
  1358. return True
  1359. return False
  1360. isdir_mock.return_value = True
  1361. exists_mock.side_effect = exists_mock_side_effect
  1362. isfile_mock.return_value = True
  1363. glob_mock.return_value = ["/usr/hdp/2.2.1.0-2187/hadoop/lib/hadoop-lzo-0.6.0.2.2.1.0-2187.jar"]
  1364. prepare_war_stdout = """INFO: Adding extension: libext/mysql-connector-java.jar
  1365. New Oozie WAR file with added 'JARs' at /var/lib/oozie/oozie-server/webapps/oozie.war"""
  1366. config_file = self.get_src_folder()+"/test/python/stacks/2.2/configs/oozie-upgrade.json"
  1367. with open(config_file, "r") as f:
  1368. json_content = json.load(f)
  1369. version = '2.3.0.0-1234'
  1370. json_content['commandParams']['version'] = version
  1371. json_content['clusterHostInfo']['falcon_server_hosts'] = ['c6401.ambari.apache.org']
  1372. mocks_dict = {}
  1373. self.executeScript(self.COMMON_SERVICES_PACKAGE_DIR + "/scripts/oozie_server.py",
  1374. classname = "OozieServer", command = "pre_rolling_restart", config_dict = json_content,
  1375. hdp_stack_version = self.UPGRADE_STACK_VERSION,
  1376. target = RMFTestCase.TARGET_COMMON_SERVICES,
  1377. call_mocks = [(0, None), (0, prepare_war_stdout)],
  1378. mocks_dict = mocks_dict)
  1379. self.assertTrue(isfile_mock.called)
  1380. self.assertEqual(isfile_mock.call_count,3)
  1381. isfile_mock.assert_called_with('/usr/share/HDP-oozie/ext-2.2.zip')
  1382. self.assertTrue(glob_mock.called)
  1383. self.assertEqual(glob_mock.call_count,1)
  1384. glob_mock.assert_called_with('/usr/hdp/2.3.0.0-1234/hadoop/lib/hadoop-lzo*.jar')
  1385. self.assertResourceCalled('Execute',
  1386. ('tar', '-zcvhf', '/tmp/oozie-upgrade-backup/oozie-conf-backup.tar', '/usr/hdp/current/oozie-server/conf/'),
  1387. sudo = True)
  1388. self.assertResourceCalled('Execute', ('ambari-python-wrap', 'hdp-select', 'set', 'oozie-server', '2.3.0.0-1234'), sudo = True)
  1389. self.assertResourceCalled('Execute',
  1390. ('tar', '-xvf', '/tmp/oozie-upgrade-backup/oozie-conf-backup.tar', '-C', '/usr/hdp/current/oozie-server/conf//'),
  1391. sudo = True)
  1392. self.assertResourceCalled('Directory', '/tmp/oozie-upgrade-backup', action = ['delete'])
  1393. self.assertResourceCalled('Directory', '/usr/hdp/current/oozie-server/libext', mode = 0777)
  1394. self.assertResourceCalled('Execute', ('cp', '/usr/share/HDP-oozie/ext-2.2.zip', '/usr/hdp/current/oozie-server/libext'), sudo=True)
  1395. self.assertResourceCalled('Execute', ('chown', 'oozie:hadoop', '/usr/hdp/current/oozie-server/libext/ext-2.2.zip'), sudo=True)
  1396. self.assertResourceCalled('File', '/usr/hdp/current/oozie-server/libext/ext-2.2.zip',
  1397. mode = 0644,
  1398. )
  1399. self.assertResourceCalled('Execute', 'ambari-sudo.sh cp /usr/hdp/2.3.0.0-1234/falcon/oozie/ext/falcon-oozie-el-extension-*.jar /usr/hdp/current/oozie-server/libext')
  1400. self.assertResourceCalled('Execute', 'ambari-sudo.sh chown oozie:hadoop /usr/hdp/current/oozie-server/libext/falcon-oozie-el-extension-*.jar')
  1401. self.assertNoMoreResources()
  1402. self.assertEquals(1, mocks_dict['call'].call_count)
  1403. self.assertEquals(1, mocks_dict['checked_call'].call_count)
  1404. self.assertEquals(
  1405. ('conf-select', 'set-conf-dir', '--package', 'oozie', '--stack-version', '2.3.0.0-1234', '--conf-version', '0'),
  1406. mocks_dict['checked_call'].call_args_list[0][0][0])
  1407. self.assertEquals(
  1408. ('conf-select', 'create-conf-dir', '--package', 'oozie', '--stack-version', '2.3.0.0-1234', '--conf-version', '0'),
  1409. mocks_dict['call'].call_args_list[0][0][0])