test.bats 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899
  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. source $HESTIA/func/ip.sh
  28. }
  29. function validate_web_domain() {
  30. local user=$1
  31. local domain=$2
  32. local webproof=$3
  33. local webpath=${4}
  34. refute [ -z "$user" ]
  35. refute [ -z "$domain" ]
  36. refute [ -z "$webproof" ]
  37. source $HESTIA/func/ip.sh
  38. run v-list-web-domain $user $domain
  39. assert_success
  40. USER_DATA=$HESTIA/data/users/$user
  41. local domain_ip=$(get_object_value 'web' 'DOMAIN' "$domain" '$IP')
  42. SSL=$(get_object_value 'web' 'DOMAIN' "$domain" '$SSL')
  43. domain_ip=$(get_real_ip "$domain_ip")
  44. if [ ! -z $webpath ]; then
  45. assert_file_exist $HOMEDIR/$user/web/$domain/public_html/$webpath
  46. fi
  47. refute [ -z "$webproof" ]
  48. # Test HTTP
  49. run curl --location --silent --show-error --insecure --resolve "${domain}:80:${domain_ip}" "http://${domain}/${webpath}"
  50. assert_success
  51. assert_output --partial "$webproof"
  52. # Test HTTPS
  53. if [ "$SSL" = "yes" ]; then
  54. run v-list-web-domain-ssl $user $domain
  55. assert_success
  56. run curl --location --silent --show-error --insecure --resolve "${domain}:443:${domain_ip}" "https://${domain}/${webpath}"
  57. assert_success
  58. assert_output --partial "$webproof"
  59. fi
  60. }
  61. #----------------------------------------------------------#
  62. # MAIN #
  63. #----------------------------------------------------------#
  64. @test "Add new userXXX" {
  65. skip
  66. run v-add-user $user $user $user@hestiacp.com default Super Test
  67. assert_success
  68. refute_output
  69. }
  70. #----------------------------------------------------------#
  71. # IP #
  72. #----------------------------------------------------------#
  73. @test "Check reverse Dns validation" {
  74. # 1. PTR record for a IP should return a hostname(reverse) which in turn must resolve to the same IP addr(forward). (Full circle)
  75. # `-> not implemented in `is_ip_rdns_valid` yet and also not tested here
  76. # 2. Reject rPTR records that match generic dynamic IP pool patterns
  77. local ip="54.200.1.22"
  78. local rdns="ec2-54-200-1-22.us-west-2.compute.amazonaws.com"
  79. run is_ip_rdns_valid "$ip"
  80. assert_failure
  81. refute_output
  82. local rdns="ec2.54.200.1.22.us-west-2.compute.amazonaws.com"
  83. run is_ip_rdns_valid "$ip"
  84. assert_failure
  85. refute_output
  86. local rdns="ec2-22-1-200-54.us-west-2.compute.amazonaws.com"
  87. run is_ip_rdns_valid "$ip"
  88. assert_failure
  89. refute_output
  90. local rdns="ec2.22.1.200.54.us-west-2.compute.amazonaws.com"
  91. run is_ip_rdns_valid "$ip"
  92. assert_failure
  93. refute_output
  94. local rdns="ec2-200-54-1-22.us-west-2.compute.amazonaws.com"
  95. run is_ip_rdns_valid "$ip"
  96. assert_failure
  97. refute_output
  98. local rdns="panel-22.mydomain.tld"
  99. run is_ip_rdns_valid "$ip"
  100. assert_success
  101. assert_output "$rdns"
  102. local rdns="mail.mydomain.tld"
  103. run is_ip_rdns_valid "$ip"
  104. assert_success
  105. assert_output "$rdns"
  106. local rdns="mydomain.tld"
  107. run is_ip_rdns_valid "$ip"
  108. assert_success
  109. assert_output "$rdns"
  110. }
  111. #----------------------------------------------------------#
  112. # User #
  113. #----------------------------------------------------------#
  114. @test "Add new user" {
  115. run v-add-user $user $user $user@hestiacp.com default Super Test
  116. assert_success
  117. refute_output
  118. }
  119. @test "Change user password" {
  120. run v-change-user-password "$user" t3st-p4ssw0rd
  121. assert_success
  122. refute_output
  123. }
  124. @test "Change user email" {
  125. run v-change-user-contact "$user" tester@hestiacp.com
  126. assert_success
  127. refute_output
  128. }
  129. @test "Change user contact invalid email " {
  130. run v-change-user-contact "$user" testerhestiacp.com
  131. assert_failure $E_INVALID
  132. assert_output --partial 'Error: invalid email format'
  133. }
  134. @test "Change user shell" {
  135. run v-change-user-shell $user bash
  136. assert_success
  137. refute_output
  138. }
  139. @test "Change user invalid shell" {
  140. run v-change-user-shell $user bashinvalid
  141. assert_failure $E_INVALID
  142. assert_output --partial 'shell bashinvalid is not valid'
  143. }
  144. @test "Change user default ns" {
  145. run v-change-user-ns $user ns0.com ns1.com ns2.com ns3.com
  146. assert_success
  147. refute_output
  148. run v-list-user-ns "$user" plain
  149. assert_success
  150. assert_output --partial 'ns0.com'
  151. }
  152. #----------------------------------------------------------#
  153. # Cron #
  154. #----------------------------------------------------------#
  155. @test "Cron: Add cron job" {
  156. run v-add-cron-job $user 1 1 1 1 1 echo
  157. assert_success
  158. refute_output
  159. }
  160. @test "Cron: Suspend cron job" {
  161. run v-suspend-cron-job $user 1
  162. assert_success
  163. refute_output
  164. }
  165. @test "Cron: Unsuspend cron job" {
  166. run v-unsuspend-cron-job $user 1
  167. assert_success
  168. refute_output
  169. }
  170. @test "Cron: Delete cron job" {
  171. run v-delete-cron-job $user 1
  172. assert_success
  173. refute_output
  174. }
  175. @test "Cron: Add cron job (duplicate)" {
  176. run v-add-cron-job $user 1 1 1 1 1 echo 1
  177. assert_success
  178. refute_output
  179. run v-add-cron-job $user 1 1 1 1 1 echo 1
  180. assert_failure $E_EXISTS
  181. assert_output --partial 'JOB=1 is already exists'
  182. }
  183. @test "Cron: Second cron job" {
  184. run v-add-cron-job $user 2 2 2 2 2 echo 2
  185. assert_success
  186. refute_output
  187. }
  188. @test "Cron: Two cron jobs must be listed" {
  189. run v-list-cron-jobs $user csv
  190. assert_success
  191. assert_line --partial '1,1,1,1,1,"echo",no'
  192. assert_line --partial '2,2,2,2,2,"echo",no'
  193. }
  194. @test "Cron: rebuild" {
  195. run v-rebuild-cron-jobs $user
  196. assert_success
  197. refute_output
  198. }
  199. #----------------------------------------------------------#
  200. # IP #
  201. #----------------------------------------------------------#
  202. @test "Ip: Add new ip on first interface" {
  203. interface=$(v-list-sys-interfaces plain | head -n 1)
  204. run ip link show dev $interface
  205. assert_success
  206. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  207. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  208. # Save initial state
  209. echo "interface=${interface}" >> /tmp/hestia-test-env.sh
  210. [ -f "$a2_rpaf" ] && file_hash1=$(cat $a2_rpaf |md5sum |cut -d" " -f1) && echo "a2_rpaf_hash='${file_hash1}'" >> /tmp/hestia-test-env.sh
  211. [ -f "$a2_remoteip" ] && file_hash2=$(cat $a2_remoteip |md5sum |cut -d" " -f1) && echo "a2_remoteip_hash='${file_hash2}'" >> /tmp/hestia-test-env.sh
  212. local ip="198.18.0.12"
  213. run v-add-sys-ip $ip 255.255.255.255 $interface $user
  214. assert_success
  215. refute_output
  216. assert_file_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  217. assert_file_exist $HESTIA/data/ips/$ip
  218. assert_file_contains $HESTIA/data/ips/$ip "OWNER='$user'"
  219. assert_file_contains $HESTIA/data/ips/$ip "INTERFACE='$interface'"
  220. if [ -n "$PROXY_SYSTEM" ]; then
  221. assert_file_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  222. [ -f "$a2_rpaf" ] && assert_file_contains "$a2_rpaf" "RPAFproxy_ips.*$ip\b"
  223. [ -f "$a2_remoteip" ] && assert_file_contains "$a2_remoteip" "RemoteIPInternalProxy $ip\$"
  224. fi
  225. }
  226. @test "Ip: Add ip (duplicate)" {
  227. run v-add-sys-ip 198.18.0.12 255.255.255.255 $interface $user
  228. assert_failure $E_EXISTS
  229. }
  230. @test "Ip: Add extra ip" {
  231. local ip="198.18.0.121"
  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. @test "Ip: Delete ips" {
  248. local ip="198.18.0.12"
  249. run v-delete-sys-ip $ip
  250. assert_success
  251. refute_output
  252. assert_file_not_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  253. assert_file_not_exist $HESTIA/data/ips/$ip
  254. ip="198.18.0.121"
  255. run v-delete-sys-ip $ip
  256. assert_success
  257. refute_output
  258. assert_file_not_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  259. assert_file_not_exist $HESTIA/data/ips/$ip
  260. if [ -n "$PROXY_SYSTEM" ]; then
  261. assert_file_not_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  262. fi
  263. # remoteip and rpaf config hashes must match the initial one
  264. if [ ! -z "$a2_rpaf_hash" ]; then
  265. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  266. file_hash=$(cat $a2_rpaf |md5sum |cut -d" " -f1)
  267. assert_equal "$file_hash" "$a2_rpaf_hash"
  268. fi
  269. if [ ! -z "$a2_remoteip_hash" ]; then
  270. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  271. file_hash=$(cat $a2_remoteip |md5sum |cut -d" " -f1)
  272. assert_equal "$file_hash" "$a2_remoteip_hash"
  273. fi
  274. }
  275. @test "Ip: Add IP for rest of the test" {
  276. local ip="198.18.0.125"
  277. run v-add-sys-ip $ip 255.255.255.255 $interface $user
  278. assert_success
  279. refute_output
  280. assert_file_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  281. assert_file_exist $HESTIA/data/ips/$ip
  282. assert_file_contains $HESTIA/data/ips/$ip "OWNER='$user'"
  283. assert_file_contains $HESTIA/data/ips/$ip "INTERFACE='$interface'"
  284. if [ -n "$PROXY_SYSTEM" ]; then
  285. assert_file_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  286. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  287. [ -f "$a2_rpaf" ] && assert_file_contains "$a2_rpaf" "RPAFproxy_ips.*$ip\b"
  288. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  289. [ -f "$a2_remoteip" ] && assert_file_contains "$a2_remoteip" "RemoteIPInternalProxy $ip\$"
  290. fi
  291. }
  292. #----------------------------------------------------------#
  293. # WEB #
  294. #----------------------------------------------------------#
  295. @test "WEB: Add web domain" {
  296. run v-add-web-domain $user $domain 198.18.0.125
  297. assert_success
  298. refute_output
  299. echo -e "<?php\necho 'Hestia Test:'.(4*3);" > $HOMEDIR/$user/web/$domain/public_html/php-test.php
  300. validate_web_domain $user $domain 'Hestia Test:12' 'php-test.php'
  301. rm $HOMEDIR/$user/web/$domain/public_html/php-test.php
  302. }
  303. @test "WEB: Add web domain (duplicate)" {
  304. run v-add-web-domain $user $domain 198.18.0.125
  305. assert_failure $E_EXISTS
  306. }
  307. @test "WEB: Add web domain alias" {
  308. run v-add-web-domain-alias $user $domain v3.$domain
  309. assert_success
  310. refute_output
  311. }
  312. @test "WEB: Add web domain alias (duplicate)" {
  313. run v-add-web-domain-alias $user $domain v3.$domain
  314. assert_failure $E_EXISTS
  315. }
  316. @test "WEB: Add web domain stats" {
  317. run v-add-web-domain-stats $user $domain awstats
  318. assert_success
  319. refute_output
  320. }
  321. @test "WEB: Add web domain stats user" {
  322. skip
  323. run v-add-web-domain-stats-user $user $domain test m3g4p4ssw0rd
  324. assert_success
  325. refute_output
  326. }
  327. @test "WEB: Suspend web domain" {
  328. run v-suspend-web-domain $user $domain
  329. assert_success
  330. refute_output
  331. validate_web_domain $user $domain 'This site is currently suspended'
  332. }
  333. @test "WEB: Unsuspend web domain" {
  334. run v-unsuspend-web-domain $user $domain
  335. assert_success
  336. refute_output
  337. echo -e "<?php\necho 'Hestia Test:'.(4*3);" > $HOMEDIR/$user/web/$domain/public_html/php-test.php
  338. validate_web_domain $user $domain 'Hestia Test:12' 'php-test.php'
  339. rm $HOMEDIR/$user/web/$domain/public_html/php-test.php
  340. }
  341. @test "WEB: Add ssl" {
  342. cp -f $HESTIA/ssl/certificate.crt /tmp/$domain.crt
  343. cp -f $HESTIA/ssl/certificate.key /tmp/$domain.key
  344. run v-add-web-domain-ssl $user $domain /tmp
  345. assert_success
  346. refute_output
  347. }
  348. @test "WEB: Rebuild web domain" {
  349. run v-rebuild-web-domains $user
  350. assert_success
  351. refute_output
  352. }
  353. #----------------------------------------------------------#
  354. # DNS #
  355. #----------------------------------------------------------#
  356. @test "DNS: Add domain" {
  357. run v-add-dns-domain $user $domain 198.18.0.125
  358. assert_success
  359. refute_output
  360. }
  361. @test "DNS: Add domain (duplicate)" {
  362. run v-add-dns-domain $user $domain 198.18.0.125
  363. assert_failure $E_EXISTS
  364. }
  365. @test "DNS: Add domain record" {
  366. run v-add-dns-record $user $domain test A 198.18.0.125 20
  367. assert_success
  368. refute_output
  369. }
  370. @test "DNS: Delete domain record" {
  371. run v-delete-dns-record $user $domain 20
  372. assert_success
  373. refute_output
  374. }
  375. @test "DNS: Delete missing domain record" {
  376. run v-delete-dns-record $user $domain 20
  377. assert_failure $E_NOTEXIST
  378. }
  379. @test "DNS: Change domain expire date" {
  380. run v-change-dns-domain-exp $user $domain 2020-01-01
  381. assert_success
  382. refute_output
  383. }
  384. @test "DNS: Change domain ip" {
  385. run v-change-dns-domain-ip $user $domain 127.0.0.1
  386. assert_success
  387. refute_output
  388. }
  389. @test "DNS: Suspend domain" {
  390. run v-suspend-dns-domain $user $domain
  391. assert_success
  392. refute_output
  393. }
  394. @test "DNS: Unsuspend domain" {
  395. run v-unsuspend-dns-domain $user $domain
  396. assert_success
  397. refute_output
  398. }
  399. @test "DNS: Rebuild" {
  400. run v-rebuild-dns-domains $user
  401. assert_success
  402. refute_output
  403. }
  404. #----------------------------------------------------------#
  405. # MAIL #
  406. #----------------------------------------------------------#
  407. @test "MAIL: Add domain" {
  408. run v-add-mail-domain $user $domain
  409. assert_success
  410. refute_output
  411. }
  412. @test "MAIL: Add domain (duplicate)" {
  413. run v-add-mail-domain $user $domain
  414. assert_failure $E_EXISTS
  415. }
  416. @test "MAIL: Add account" {
  417. run v-add-mail-account $user $domain test t3st-p4ssw0rd
  418. assert_success
  419. refute_output
  420. }
  421. @test "MAIL: Add account (duplicate)" {
  422. run v-add-mail-account $user $domain test t3st-p4ssw0rd
  423. assert_failure $E_EXISTS
  424. }
  425. @test "MAIL: Delete account" {
  426. run v-delete-mail-account $user $domain test
  427. assert_success
  428. refute_output
  429. }
  430. @test "MAIL: Delete missing account" {
  431. run v-delete-mail-account $user $domain test
  432. assert_failure $E_NOTEXIST
  433. }
  434. #----------------------------------------------------------#
  435. # DB #
  436. #----------------------------------------------------------#
  437. #----------------------------------------------------------#
  438. # Backup / Restore #
  439. #----------------------------------------------------------#
  440. #Test backup
  441. # Hestia v1.1.1 archive contains:
  442. # user: hestia111
  443. # web:
  444. # - test.hestia.com (+SSL self-signed)
  445. # dns:
  446. # - test.hestia.com
  447. # mail:
  448. # - test.hestia.com
  449. # mail acc:
  450. # - testaccount@test.hestia.com
  451. # db:
  452. # - hestia111_db
  453. # cron:
  454. # - 1: /bin/true
  455. #
  456. # Vesta 0.9.8-23 archive contains:
  457. # user: vesta09823
  458. # web:
  459. # - vesta09823.tld (+SSL self-signed)
  460. # dns:
  461. # - vesta09823.tld
  462. # mail:
  463. # - vesta09823.tld
  464. # mail acc:
  465. # - testaccount@vesta09823.tld
  466. # db:
  467. # - vesta09823_db
  468. # cron:
  469. # - 1: /bin/true
  470. #
  471. # Testing Hestia backups
  472. @test "Restore[1]: Hestia archive for a non-existing user" {
  473. if [ -d "$HOMEDIR/$userbk" ]; then
  474. run v-delete-user $userbk
  475. assert_success
  476. refute_output
  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[1]: From Hestia [WEB]" {
  487. local domain="test.hestia.com"
  488. validate_web_domain $userbk $domain 'Hello Hestia'
  489. }
  490. @test "Restore[1]: 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[1]: From Hestia [MAIL]" {
  498. local domain="test.hestia.com"
  499. run v-list-mail-domain $userbk $domain
  500. assert_success
  501. }
  502. @test "Restore[1]: 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[1]: From Hestia [DB]" {
  508. run v-list-database $userbk "${userbk}_db"
  509. assert_success
  510. }
  511. @test "Restore[1]: From Hestia [CRON]" {
  512. run v-list-cron-job $userbk 1
  513. assert_success
  514. }
  515. @test "Restore[1]: From Hestia Cleanup" {
  516. run v-delete-user $userbk
  517. assert_success
  518. refute_output
  519. }
  520. @test "Restore[2]: Hestia archive over a existing user" {
  521. if [ -d "$HOMEDIR/$userbk" ]; then
  522. run v-delete-user $userbk
  523. assert_success
  524. refute_output
  525. fi
  526. if [ ! -d "$HOMEDIR/$userbk" ]; then
  527. run v-add-user $userbk $userbk test@hestia.com
  528. assert_success
  529. fi
  530. mkdir -p /backup
  531. local archive_name="hestia111.2020-03-26"
  532. 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"
  533. assert_success
  534. run v-restore-user $userbk "${archive_name}.tar"
  535. assert_success
  536. rm "/backup/${archive_name}.tar"
  537. }
  538. @test "Restore[2]: From Hestia [WEB]" {
  539. local domain="test.hestia.com"
  540. validate_web_domain $userbk "${domain}" 'Hello Hestia'
  541. }
  542. @test "Restore[2]: From Hestia [DNS]" {
  543. local domain="test.hestia.com"
  544. run v-list-dns-domain $userbk $domain
  545. assert_success
  546. run nslookup $domain 127.0.0.1
  547. assert_success
  548. }
  549. @test "Restore[2]: From Hestia [MAIL]" {
  550. local domain="test.hestia.com"
  551. run v-list-mail-domain $userbk $domain
  552. assert_success
  553. }
  554. @test "Restore[2]: From Hestia [MAIL-Account]" {
  555. local domain="test.hestia.com"
  556. run v-list-mail-account $userbk $domain testaccount
  557. assert_success
  558. }
  559. @test "Restore[2]: From Hestia [DB]" {
  560. run v-list-database $userbk "${userbk}_db"
  561. assert_success
  562. }
  563. @test "Restore[2]: From Hestia [CRON]" {
  564. run v-list-cron-job $userbk 1
  565. assert_success
  566. }
  567. @test "Restore[2]: From Hestia Cleanup" {
  568. run v-delete-user $userbk
  569. assert_success
  570. refute_output
  571. }
  572. # Testing Vesta Backups
  573. @test "Restore[1]: Vesta archive for a non-existing user" {
  574. if [ -d "$HOMEDIR/$userbk" ]; then
  575. run v-delete-user $userbk
  576. assert_success
  577. refute_output
  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[1]: From Vesta [WEB]" {
  588. local domain="vesta09823.tld"
  589. validate_web_domain $userbk $domain 'Hello Vesta'
  590. }
  591. @test "Restore[1]: 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[1]: From Vesta [MAIL]" {
  599. local domain="vesta09823.tld"
  600. run v-list-mail-domain $userbk $domain
  601. assert_success
  602. }
  603. @test "Restore[1]: 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[1]: From Vesta [DB]" {
  609. run v-list-database $userbk "${userbk}_db"
  610. assert_success
  611. }
  612. @test "Restore[1]: From Vesta [CRON]" {
  613. run v-list-cron-job $userbk 1
  614. assert_success
  615. }
  616. @test "Restore[1]: From Vesta Cleanup" {
  617. run v-delete-user $userbk
  618. assert_success
  619. refute_output
  620. }
  621. @test "Restore[2]: Vesta archive over a existing user" {
  622. if [ -d "$HOMEDIR/$userbk" ]; then
  623. run v-delete-user $userbk
  624. assert_success
  625. refute_output
  626. fi
  627. if [ ! -d "$HOMEDIR/$userbk" ]; then
  628. run v-add-user $userbk $userbk test@hestia.com
  629. assert_success
  630. fi
  631. mkdir -p /backup
  632. local archive_name="vesta09823.2018-10-18"
  633. 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"
  634. assert_success
  635. run v-restore-user $userbk "${archive_name}.tar"
  636. assert_success
  637. rm "/backup/${archive_name}.tar"
  638. }
  639. @test "Restore[2]: From Vesta [WEB]" {
  640. local domain="vesta09823.tld"
  641. validate_web_domain $userbk "${domain}" 'Hello Vesta'
  642. }
  643. @test "Restore[2]: From Vesta [DNS]" {
  644. local domain="vesta09823.tld"
  645. run v-list-dns-domain $userbk $domain
  646. assert_success
  647. run nslookup $domain 127.0.0.1
  648. assert_success
  649. }
  650. @test "Restore[2]: From Vesta [MAIL]" {
  651. local domain="vesta09823.tld"
  652. run v-list-mail-domain $userbk $domain
  653. assert_success
  654. }
  655. @test "Restore[2]: From Vesta [MAIL-Account]" {
  656. local domain="vesta09823.tld"
  657. run v-list-mail-account $userbk $domain testaccount
  658. assert_success
  659. }
  660. @test "Restore[2]: From Vesta [DB]" {
  661. run v-list-database $userbk "${userbk}_db"
  662. assert_success
  663. }
  664. @test "Restore[2]: From Vesta [CRON]" {
  665. run v-list-cron-job $userbk 1
  666. assert_success
  667. }
  668. @test "Restore[2]: From Vesta Cleanup" {
  669. run v-delete-user $userbk
  670. assert_success
  671. refute_output
  672. }
  673. #----------------------------------------------------------#
  674. # CLEANUP #
  675. #----------------------------------------------------------#
  676. @test "Mail: Delete domain" {
  677. # skip
  678. run v-delete-mail-domain $user $domain
  679. assert_success
  680. refute_output
  681. }
  682. @test "DNS: Delete domain" {
  683. # skip
  684. run v-delete-dns-domain $user $domain
  685. assert_success
  686. refute_output
  687. }
  688. @test "WEB: Delete domain" {
  689. # skip
  690. run v-delete-web-domain $user $domain
  691. assert_success
  692. refute_output
  693. }
  694. @test "Delete user" {
  695. # skip
  696. run v-delete-user $user
  697. assert_success
  698. refute_output
  699. }
  700. @test "Ip: Delete the test IP" {
  701. # skip
  702. run v-delete-sys-ip 198.18.0.125
  703. assert_success
  704. refute_output
  705. }
  706. @test 'assert()' {
  707. touch '/var/log/test.log'
  708. assert [ -e '/var/log/test.log' ]
  709. }