test.bats 22 KB

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