test.bats 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833
  1. #!/usr/bin/env bats
  2. load 'test_helper/bats-support/load'
  3. load 'test_helper/bats-assert/load'
  4. load 'test_helper/bats-file/load'
  5. function random() {
  6. MATRIX='0123456789'
  7. LENGTH=$1
  8. while [ ${n:=1} -le $LENGTH ]; do
  9. rand="$rand${MATRIX:$(($RANDOM%${#MATRIX})):1}"
  10. let n+=1
  11. done
  12. echo "$rand"
  13. }
  14. function setup() {
  15. # echo "# Setup_file" > &3
  16. if [ $BATS_TEST_NUMBER = 1 ]; then
  17. echo 'user=test-5285' > /tmp/hestia-test-env.sh
  18. echo 'userbk=testbk-5285' >> /tmp/hestia-test-env.sh
  19. echo 'userpass1=test-5285' >> /tmp/hestia-test-env.sh
  20. echo 'userpass2=t3st-p4ssw0rd' >> /tmp/hestia-test-env.sh
  21. echo 'HESTIA=/usr/local/hestia' >> /tmp/hestia-test-env.sh
  22. echo 'domain=test-5285.hestiacp.com' >> /tmp/hestia-test-env.sh
  23. fi
  24. source /tmp/hestia-test-env.sh
  25. source $HESTIA/func/main.sh
  26. source $HESTIA/conf/hestia.conf
  27. }
  28. function validate_web_domain() {
  29. local user=$1
  30. local domain=$2
  31. local webproof=$3
  32. refute [ -z "$user" ]
  33. refute [ -z "$domain" ]
  34. refute [ -z "$webproof" ]
  35. source $HESTIA/func/ip.sh
  36. run v-list-web-domain $user $domain
  37. assert_success
  38. USER_DATA=$HESTIA/data/users/$user
  39. local domain_ip=$(get_object_value 'web' 'DOMAIN' "$domain" '$IP')
  40. SSL=$(get_object_value 'web' 'DOMAIN' "$domain" '$SSL')
  41. domain_ip=$(get_real_ip "$domain_ip")
  42. assert_file_exist $HOMEDIR/$user/web/$domain/public_html/index.php
  43. refute [ -z "$webproof" ]
  44. # Test HTTP
  45. run curl --location --silent --show-error --insecure --resolve "${domain}:80:${domain_ip}" "http://${domain}/index.php"
  46. assert_success
  47. assert_output --partial "$webproof"
  48. # Test HTTPS
  49. if [ "$SSL" = "yes" ]; then
  50. run v-list-web-domain-ssl $user $domain
  51. assert_success
  52. run curl --location --silent --show-error --insecure --resolve "${domain}:443:${domain_ip}" "https://${domain}/index.php"
  53. assert_success
  54. assert_output --partial "$webproof"
  55. fi
  56. }
  57. #----------------------------------------------------------#
  58. # MAIN #
  59. #----------------------------------------------------------#
  60. @test "Add new userXXX" {
  61. skip
  62. run v-add-user $user $user $user@hestiacp.com default Super Test
  63. assert_success
  64. refute_output
  65. }
  66. #----------------------------------------------------------#
  67. # User #
  68. #----------------------------------------------------------#
  69. @test "Add new user" {
  70. run v-add-user $user $user $user@hestiacp.com default Super Test
  71. assert_success
  72. refute_output
  73. }
  74. @test "Change user password" {
  75. run v-change-user-password "$user" t3st-p4ssw0rd
  76. assert_success
  77. refute_output
  78. }
  79. @test "Change user email" {
  80. run v-change-user-contact "$user" tester@hestiacp.com
  81. assert_success
  82. refute_output
  83. }
  84. @test "Change user contact invalid email " {
  85. run v-change-user-contact "$user" testerhestiacp.com
  86. assert_failure $E_INVALID
  87. assert_output --partial 'Error: invalid email format'
  88. }
  89. @test "Change user shell" {
  90. run v-change-user-shell $user bash
  91. assert_success
  92. refute_output
  93. }
  94. @test "Change user invalid shell" {
  95. run v-change-user-shell $user bashinvalid
  96. assert_failure $E_INVALID
  97. assert_output --partial 'shell bashinvalid is not valid'
  98. }
  99. @test "Change user default ns" {
  100. run v-change-user-ns $user ns0.com ns1.com ns2.com ns3.com
  101. assert_success
  102. refute_output
  103. run v-list-user-ns "$user" plain
  104. assert_success
  105. assert_output --partial 'ns0.com'
  106. }
  107. #----------------------------------------------------------#
  108. # Cron #
  109. #----------------------------------------------------------#
  110. @test "Cron: Add cron job" {
  111. run v-add-cron-job $user 1 1 1 1 1 echo
  112. assert_success
  113. refute_output
  114. }
  115. @test "Cron: Suspend cron job" {
  116. run v-suspend-cron-job $user 1
  117. assert_success
  118. refute_output
  119. }
  120. @test "Cron: Unsuspend cron job" {
  121. run v-unsuspend-cron-job $user 1
  122. assert_success
  123. refute_output
  124. }
  125. @test "Cron: Delete cron job" {
  126. run v-delete-cron-job $user 1
  127. assert_success
  128. refute_output
  129. }
  130. @test "Cron: Add cron job (duplicate)" {
  131. run v-add-cron-job $user 1 1 1 1 1 echo 1
  132. assert_success
  133. refute_output
  134. run v-add-cron-job $user 1 1 1 1 1 echo 1
  135. assert_failure $E_EXISTS
  136. assert_output --partial 'JOB=1 is already exists'
  137. }
  138. @test "Cron: Second cron job" {
  139. run v-add-cron-job $user 2 2 2 2 2 echo 2
  140. assert_success
  141. refute_output
  142. }
  143. @test "Cron: Two cron jobs must be listed" {
  144. run v-list-cron-jobs $user csv
  145. assert_success
  146. assert_line --partial '1,1,1,1,1,"echo",no'
  147. assert_line --partial '2,2,2,2,2,"echo",no'
  148. }
  149. @test "Cron: rebuild" {
  150. run v-rebuild-cron-jobs $user
  151. assert_success
  152. refute_output
  153. }
  154. #----------------------------------------------------------#
  155. # IP #
  156. #----------------------------------------------------------#
  157. @test "Ip: Add new ip on first interface" {
  158. interface=$(v-list-sys-interfaces plain | head -n 1)
  159. run ip link show dev $interface
  160. assert_success
  161. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  162. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  163. # Save initial state
  164. echo "interface=${interface}" >> /tmp/hestia-test-env.sh
  165. [ -f "$a2_rpaf" ] && file_hash1=$(cat $a2_rpaf |md5sum |cut -d" " -f1) && echo "a2_rpaf_hash='${file_hash1}'" >> /tmp/hestia-test-env.sh
  166. [ -f "$a2_remoteip" ] && file_hash2=$(cat $a2_remoteip |md5sum |cut -d" " -f1) && echo "a2_remoteip_hash='${file_hash2}'" >> /tmp/hestia-test-env.sh
  167. local ip="198.18.0.12"
  168. run v-add-sys-ip $ip 255.255.255.255 $interface $user
  169. assert_success
  170. refute_output
  171. assert_file_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  172. assert_file_exist $HESTIA/data/ips/$ip
  173. assert_file_contains $HESTIA/data/ips/$ip "OWNER='$user'"
  174. assert_file_contains $HESTIA/data/ips/$ip "INTERFACE='$interface'"
  175. if [ -n "$PROXY_SYSTEM" ]; then
  176. assert_file_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  177. [ -f "$a2_rpaf" ] && assert_file_contains "$a2_rpaf" "RPAFproxy_ips.*$ip\b"
  178. [ -f "$a2_remoteip" ] && assert_file_contains "$a2_remoteip" "RemoteIPInternalProxy $ip\$"
  179. fi
  180. }
  181. @test "Ip: Add ip (duplicate)" {
  182. run v-add-sys-ip 198.18.0.12 255.255.255.255 $interface $user
  183. assert_failure $E_EXISTS
  184. }
  185. @test "Ip: Add extra ip" {
  186. local ip="198.18.0.121"
  187. run v-add-sys-ip $ip 255.255.255.255 $interface $user
  188. assert_success
  189. refute_output
  190. assert_file_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  191. assert_file_exist $HESTIA/data/ips/$ip
  192. assert_file_contains $HESTIA/data/ips/$ip "OWNER='$user'"
  193. assert_file_contains $HESTIA/data/ips/$ip "INTERFACE='$interface'"
  194. if [ -n "$PROXY_SYSTEM" ]; then
  195. assert_file_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  196. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  197. [ -f "$a2_rpaf" ] && assert_file_contains "$a2_rpaf" "RPAFproxy_ips.*$ip\b"
  198. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  199. [ -f "$a2_remoteip" ] && assert_file_contains "$a2_remoteip" "RemoteIPInternalProxy $ip\$"
  200. fi
  201. }
  202. @test "Ip: Delete ips" {
  203. local ip="198.18.0.12"
  204. run v-delete-sys-ip $ip
  205. assert_success
  206. refute_output
  207. assert_file_not_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  208. assert_file_not_exist $HESTIA/data/ips/$ip
  209. ip="198.18.0.121"
  210. run v-delete-sys-ip $ip
  211. assert_success
  212. refute_output
  213. assert_file_not_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  214. assert_file_not_exist $HESTIA/data/ips/$ip
  215. if [ -n "$PROXY_SYSTEM" ]; then
  216. assert_file_not_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  217. fi
  218. # remoteip and rpaf config hashes must match the initial one
  219. if [ ! -z "$a2_rpaf_hash" ]; then
  220. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  221. file_hash=$(cat $a2_rpaf |md5sum |cut -d" " -f1)
  222. assert_equal "$file_hash" "$a2_rpaf_hash"
  223. fi
  224. if [ ! -z "$a2_remoteip_hash" ]; then
  225. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  226. file_hash=$(cat $a2_remoteip |md5sum |cut -d" " -f1)
  227. assert_equal "$file_hash" "$a2_remoteip_hash"
  228. fi
  229. }
  230. @test "Ip: Add IP for rest of the test" {
  231. local ip="198.18.0.125"
  232. run v-add-sys-ip $ip 255.255.255.255 $interface $user
  233. assert_success
  234. refute_output
  235. assert_file_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  236. assert_file_exist $HESTIA/data/ips/$ip
  237. assert_file_contains $HESTIA/data/ips/$ip "OWNER='$user'"
  238. assert_file_contains $HESTIA/data/ips/$ip "INTERFACE='$interface'"
  239. if [ -n "$PROXY_SYSTEM" ]; then
  240. assert_file_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  241. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  242. [ -f "$a2_rpaf" ] && assert_file_contains "$a2_rpaf" "RPAFproxy_ips.*$ip\b"
  243. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  244. [ -f "$a2_remoteip" ] && assert_file_contains "$a2_remoteip" "RemoteIPInternalProxy $ip\$"
  245. fi
  246. }
  247. #----------------------------------------------------------#
  248. # WEB #
  249. #----------------------------------------------------------#
  250. @test "WEB: Add web domain" {
  251. run v-add-web-domain $user $domain 198.18.0.125
  252. assert_success
  253. refute_output
  254. }
  255. @test "WEB: Add web domain (duplicate)" {
  256. run v-add-web-domain $user $domain 198.18.0.125
  257. assert_failure $E_EXISTS
  258. }
  259. @test "WEB: Add web domain alias" {
  260. run v-add-web-domain-alias $user $domain v3.$domain
  261. assert_success
  262. refute_output
  263. }
  264. @test "WEB: Add web domain alias (duplicate)" {
  265. run v-add-web-domain-alias $user $domain v3.$domain
  266. assert_failure $E_EXISTS
  267. }
  268. @test "WEB: Add web domain stats" {
  269. run v-add-web-domain-stats $user $domain awstats
  270. assert_success
  271. refute_output
  272. }
  273. @test "WEB: Add web domain stats user" {
  274. skip
  275. run v-add-web-domain-stats-user $user $domain test m3g4p4ssw0rd
  276. assert_success
  277. refute_output
  278. }
  279. @test "WEB: Suspend web domain" {
  280. run v-suspend-web-domain $user $domain
  281. assert_success
  282. refute_output
  283. }
  284. @test "WEB: Unsuspend web domain" {
  285. run v-unsuspend-web-domain $user $domain
  286. assert_success
  287. refute_output
  288. }
  289. @test "WEB: Add ssl" {
  290. cp -f $HESTIA/ssl/certificate.crt /tmp/$domain.crt
  291. cp -f $HESTIA/ssl/certificate.key /tmp/$domain.key
  292. run v-add-web-domain-ssl $user $domain /tmp
  293. assert_success
  294. refute_output
  295. }
  296. @test "WEB: Rebuild web domain" {
  297. run v-rebuild-web-domains $user
  298. assert_success
  299. refute_output
  300. }
  301. #----------------------------------------------------------#
  302. # DNS #
  303. #----------------------------------------------------------#
  304. @test "DNS: Add domain" {
  305. run v-add-dns-domain $user $domain 198.18.0.125
  306. assert_success
  307. refute_output
  308. }
  309. @test "DNS: Add domain (duplicate)" {
  310. run v-add-dns-domain $user $domain 198.18.0.125
  311. assert_failure $E_EXISTS
  312. }
  313. @test "DNS: Add domain record" {
  314. run v-add-dns-record $user $domain test A 198.18.0.125 20
  315. assert_success
  316. refute_output
  317. }
  318. @test "DNS: Delete domain record" {
  319. run v-delete-dns-record $user $domain 20
  320. assert_success
  321. refute_output
  322. }
  323. @test "DNS: Delete missing domain record" {
  324. run v-delete-dns-record $user $domain 20
  325. assert_failure $E_NOTEXIST
  326. }
  327. @test "DNS: Change domain expire date" {
  328. run v-change-dns-domain-exp $user $domain 2020-01-01
  329. assert_success
  330. refute_output
  331. }
  332. @test "DNS: Change domain ip" {
  333. run v-change-dns-domain-ip $user $domain 127.0.0.1
  334. assert_success
  335. refute_output
  336. }
  337. @test "DNS: Suspend domain" {
  338. run v-suspend-dns-domain $user $domain
  339. assert_success
  340. refute_output
  341. }
  342. @test "DNS: Unsuspend domain" {
  343. run v-unsuspend-dns-domain $user $domain
  344. assert_success
  345. refute_output
  346. }
  347. @test "DNS: Rebuild" {
  348. run v-rebuild-dns-domains $user
  349. assert_success
  350. refute_output
  351. }
  352. #----------------------------------------------------------#
  353. # MAIL #
  354. #----------------------------------------------------------#
  355. @test "MAIL: Add domain" {
  356. run v-add-mail-domain $user $domain
  357. assert_success
  358. refute_output
  359. }
  360. @test "MAIL: Add domain (duplicate)" {
  361. run v-add-mail-domain $user $domain
  362. assert_failure $E_EXISTS
  363. }
  364. @test "MAIL: Add account" {
  365. run v-add-mail-account $user $domain test t3st-p4ssw0rd
  366. assert_success
  367. refute_output
  368. }
  369. @test "MAIL: Add account (duplicate)" {
  370. run v-add-mail-account $user $domain test t3st-p4ssw0rd
  371. assert_failure $E_EXISTS
  372. }
  373. @test "MAIL: Delete account" {
  374. run v-delete-mail-account $user $domain test
  375. assert_success
  376. refute_output
  377. }
  378. @test "MAIL: Delete missing account" {
  379. run v-delete-mail-account $user $domain test
  380. assert_failure $E_NOTEXIST
  381. }
  382. #----------------------------------------------------------#
  383. # DB #
  384. #----------------------------------------------------------#
  385. #----------------------------------------------------------#
  386. # Backup / Restore #
  387. #----------------------------------------------------------#
  388. #Test backup
  389. # Hestia v1.1.1 archive contains:
  390. # user: hestia111
  391. # web:
  392. # - test.hestia.com (+SSL self-signed)
  393. # dns:
  394. # - test.hestia.com
  395. # mail:
  396. # - test.hestia.com
  397. # mail acc:
  398. # - testaccount@test.hestia.com
  399. # db:
  400. # - hestia111_db
  401. # cron:
  402. # - 1: /bin/true
  403. #
  404. # Vesta 0.9.8-23 archive contains:
  405. # user: vesta09823
  406. # web:
  407. # - vesta09823.tld (+SSL self-signed)
  408. # dns:
  409. # - vesta09823.tld
  410. # mail:
  411. # - vesta09823.tld
  412. # mail acc:
  413. # - testaccount@vesta09823.tld
  414. # db:
  415. # - vesta09823_db
  416. # cron:
  417. # - 1: /bin/true
  418. #
  419. # Testing Hestia backups
  420. @test "Restore[1]: Hestia archive for a non-existing user" {
  421. if [ -d "$HOMEDIR/$userbk" ]; then
  422. run v-delete-user $userbk
  423. assert_success
  424. refute_output
  425. fi
  426. mkdir -p /backup
  427. local archive_name="hestia111.2020-03-26"
  428. run wget --quiet --tries=3 --timeout=15 --read-timeout=15 --waitretry=3 --no-dns-cache "https://hestiacp.com/testing/data/${archive_name}.tar" -O "/backup/${archive_name}.tar"
  429. assert_success
  430. run v-restore-user $userbk "${archive_name}.tar"
  431. assert_success
  432. rm "/backup/${archive_name}.tar"
  433. }
  434. @test "Restore[1]: From Hestia [WEB]" {
  435. local domain="test.hestia.com"
  436. validate_web_domain $userbk $domain 'Hello Hestia'
  437. }
  438. @test "Restore[1]: From Hestia [DNS]" {
  439. local domain="test.hestia.com"
  440. run v-list-dns-domain $userbk $domain
  441. assert_success
  442. run nslookup $domain 127.0.0.1
  443. assert_success
  444. }
  445. @test "Restore[1]: From Hestia [MAIL]" {
  446. local domain="test.hestia.com"
  447. run v-list-mail-domain $userbk $domain
  448. assert_success
  449. }
  450. @test "Restore[1]: From Hestia [MAIL-Account]" {
  451. local domain="test.hestia.com"
  452. run v-list-mail-account $userbk $domain testaccount
  453. assert_success
  454. }
  455. @test "Restore[1]: From Hestia [DB]" {
  456. run v-list-database $userbk "${userbk}_db"
  457. assert_success
  458. }
  459. @test "Restore[1]: From Hestia [CRON]" {
  460. run v-list-cron-job $userbk 1
  461. assert_success
  462. }
  463. @test "Restore[1]: From Hestia Cleanup" {
  464. run v-delete-user $userbk
  465. assert_success
  466. refute_output
  467. }
  468. @test "Restore[2]: Hestia archive over a existing user" {
  469. if [ -d "$HOMEDIR/$userbk" ]; then
  470. run v-delete-user $userbk
  471. assert_success
  472. refute_output
  473. fi
  474. if [ ! -d "$HOMEDIR/$userbk" ]; then
  475. run v-add-user $userbk $userbk test@hestia.com
  476. assert_success
  477. fi
  478. mkdir -p /backup
  479. local archive_name="hestia111.2020-03-26"
  480. run wget --quiet --tries=3 --timeout=15 --read-timeout=15 --waitretry=3 --no-dns-cache "https://hestiacp.com/testing/data/${archive_name}.tar" -O "/backup/${archive_name}.tar"
  481. assert_success
  482. run v-restore-user $userbk "${archive_name}.tar"
  483. assert_success
  484. rm "/backup/${archive_name}.tar"
  485. }
  486. @test "Restore[2]: From Hestia [WEB]" {
  487. local domain="test.hestia.com"
  488. validate_web_domain $userbk "${domain}" 'Hello Hestia'
  489. }
  490. @test "Restore[2]: From Hestia [DNS]" {
  491. local domain="test.hestia.com"
  492. run v-list-dns-domain $userbk $domain
  493. assert_success
  494. run nslookup $domain 127.0.0.1
  495. assert_success
  496. }
  497. @test "Restore[2]: From Hestia [MAIL]" {
  498. local domain="test.hestia.com"
  499. run v-list-mail-domain $userbk $domain
  500. assert_success
  501. }
  502. @test "Restore[2]: From Hestia [MAIL-Account]" {
  503. local domain="test.hestia.com"
  504. run v-list-mail-account $userbk $domain testaccount
  505. assert_success
  506. }
  507. @test "Restore[2]: From Hestia [DB]" {
  508. run v-list-database $userbk "${userbk}_db"
  509. assert_success
  510. }
  511. @test "Restore[2]: From Hestia [CRON]" {
  512. run v-list-cron-job $userbk 1
  513. assert_success
  514. }
  515. @test "Restore[2]: From Hestia Cleanup" {
  516. run v-delete-user $userbk
  517. assert_success
  518. refute_output
  519. }
  520. # Testing Vesta Backups
  521. @test "Restore[1]: Vesta archive for a non-existing user" {
  522. if [ -d "$HOMEDIR/$userbk" ]; then
  523. run v-delete-user $userbk
  524. assert_success
  525. refute_output
  526. fi
  527. mkdir -p /backup
  528. local archive_name="vesta09823.2018-10-18"
  529. run wget --quiet --tries=3 --timeout=15 --read-timeout=15 --waitretry=3 --no-dns-cache "https://hestiacp.com/testing/data/${archive_name}.tar" -O "/backup/${archive_name}.tar"
  530. assert_success
  531. run v-restore-user $userbk "${archive_name}.tar"
  532. assert_success
  533. rm "/backup/${archive_name}.tar"
  534. }
  535. @test "Restore[1]: From Vesta [WEB]" {
  536. local domain="vesta09823.tld"
  537. validate_web_domain $userbk $domain 'Hello Vesta'
  538. }
  539. @test "Restore[1]: From Vesta [DNS]" {
  540. local domain="vesta09823.tld"
  541. run v-list-dns-domain $userbk $domain
  542. assert_success
  543. run nslookup $domain 127.0.0.1
  544. assert_success
  545. }
  546. @test "Restore[1]: From Vesta [MAIL]" {
  547. local domain="vesta09823.tld"
  548. run v-list-mail-domain $userbk $domain
  549. assert_success
  550. }
  551. @test "Restore[1]: From Vesta [MAIL-Account]" {
  552. local domain="vesta09823.tld"
  553. run v-list-mail-account $userbk $domain testaccount
  554. assert_success
  555. }
  556. @test "Restore[1]: From Vesta [DB]" {
  557. run v-list-database $userbk "${userbk}_db"
  558. assert_success
  559. }
  560. @test "Restore[1]: From Vesta [CRON]" {
  561. run v-list-cron-job $userbk 1
  562. assert_success
  563. }
  564. @test "Restore[1]: From Vesta Cleanup" {
  565. run v-delete-user $userbk
  566. assert_success
  567. refute_output
  568. }
  569. @test "Restore[2]: Vesta archive over a existing user" {
  570. if [ -d "$HOMEDIR/$userbk" ]; then
  571. run v-delete-user $userbk
  572. assert_success
  573. refute_output
  574. fi
  575. if [ ! -d "$HOMEDIR/$userbk" ]; then
  576. run v-add-user $userbk $userbk test@hestia.com
  577. assert_success
  578. fi
  579. mkdir -p /backup
  580. local archive_name="vesta09823.2018-10-18"
  581. run wget --quiet --tries=3 --timeout=15 --read-timeout=15 --waitretry=3 --no-dns-cache "https://hestiacp.com/testing/data/${archive_name}.tar" -O "/backup/${archive_name}.tar"
  582. assert_success
  583. run v-restore-user $userbk "${archive_name}.tar"
  584. assert_success
  585. rm "/backup/${archive_name}.tar"
  586. }
  587. @test "Restore[2]: From Vesta [WEB]" {
  588. local domain="vesta09823.tld"
  589. validate_web_domain $userbk "${domain}" 'Hello Vesta'
  590. }
  591. @test "Restore[2]: From Vesta [DNS]" {
  592. local domain="vesta09823.tld"
  593. run v-list-dns-domain $userbk $domain
  594. assert_success
  595. run nslookup $domain 127.0.0.1
  596. assert_success
  597. }
  598. @test "Restore[2]: From Vesta [MAIL]" {
  599. local domain="vesta09823.tld"
  600. run v-list-mail-domain $userbk $domain
  601. assert_success
  602. }
  603. @test "Restore[2]: From Vesta [MAIL-Account]" {
  604. local domain="vesta09823.tld"
  605. run v-list-mail-account $userbk $domain testaccount
  606. assert_success
  607. }
  608. @test "Restore[2]: From Vesta [DB]" {
  609. run v-list-database $userbk "${userbk}_db"
  610. assert_success
  611. }
  612. @test "Restore[2]: From Vesta [CRON]" {
  613. run v-list-cron-job $userbk 1
  614. assert_success
  615. }
  616. @test "Restore[2]: From Vesta Cleanup" {
  617. run v-delete-user $userbk
  618. assert_success
  619. refute_output
  620. }
  621. #----------------------------------------------------------#
  622. # CLEANUP #
  623. #----------------------------------------------------------#
  624. @test "Mail: Delete domain" {
  625. # skip
  626. run v-delete-mail-domain $user $domain
  627. assert_success
  628. refute_output
  629. }
  630. @test "DNS: Delete domain" {
  631. # skip
  632. run v-delete-dns-domain $user $domain
  633. assert_success
  634. refute_output
  635. }
  636. @test "WEB: Delete domain" {
  637. # skip
  638. run v-delete-web-domain $user $domain
  639. assert_success
  640. refute_output
  641. }
  642. @test "Delete user" {
  643. # skip
  644. run v-delete-user $user
  645. assert_success
  646. refute_output
  647. }
  648. @test "Ip: Delete the test IP" {
  649. # skip
  650. run v-delete-sys-ip 198.18.0.125
  651. assert_success
  652. refute_output
  653. }
  654. @test 'assert()' {
  655. touch '/var/log/test.log'
  656. assert [ -e '/var/log/test.log' ]
  657. }