test.bats 25 KB

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