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