test.bats 45 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510
  1. #!/usr/bin/env bats
  2. if [ "${PATH#*/usr/local/hestia/bin*}" = "$PATH" ]; then
  3. . /etc/profile.d/hestia.sh
  4. fi
  5. load 'test_helper/bats-support/load'
  6. load 'test_helper/bats-assert/load'
  7. load 'test_helper/bats-file/load'
  8. function random() {
  9. head /dev/urandom | tr -dc 0-9 | head -c$1
  10. }
  11. function setup() {
  12. # echo "# Setup_file" > &3
  13. if [ $BATS_TEST_NUMBER = 1 ]; then
  14. echo 'user=test-5285' > /tmp/hestia-test-env.sh
  15. echo 'user2=test-5286' >> /tmp/hestia-test-env.sh
  16. echo 'userbk=testbk-5285' >> /tmp/hestia-test-env.sh
  17. echo 'userpass1=test-5285' >> /tmp/hestia-test-env.sh
  18. echo 'userpass2=t3st-p4ssw0rd' >> /tmp/hestia-test-env.sh
  19. echo 'HESTIA=/usr/local/hestia' >> /tmp/hestia-test-env.sh
  20. echo 'domain=test-5285.hestiacp.com' >> /tmp/hestia-test-env.sh
  21. echo 'domainuk=test-5285.hestiacp.com.uk' >> /tmp/hestia-test-env.sh
  22. echo 'rootdomain=testhestiacp.com' >> /tmp/hestia-test-env.sh
  23. echo 'subdomain=cdn.testhestiacp.com' >> /tmp/hestia-test-env.sh
  24. echo 'database=test-5285_database' >> /tmp/hestia-test-env.sh
  25. echo 'dbuser=test-5285_dbuser' >> /tmp/hestia-test-env.sh
  26. echo 'pguser=test5290' >> /tmp/hestia-test-env.sh
  27. echo 'pgdatabase=test5290_database' >> /tmp/hestia-test-env.sh
  28. echo 'pgdbuser=test5290_dbuser' >> /tmp/hestia-test-env.sh
  29. fi
  30. source /tmp/hestia-test-env.sh
  31. source $HESTIA/func/main.sh
  32. source $HESTIA/conf/hestia.conf
  33. source $HESTIA/func/ip.sh
  34. }
  35. function validate_web_domain() {
  36. local user=$1
  37. local domain=$2
  38. local webproof=$3
  39. local webpath=${4}
  40. refute [ -z "$user" ]
  41. refute [ -z "$domain" ]
  42. refute [ -z "$webproof" ]
  43. source $HESTIA/func/ip.sh
  44. run v-list-web-domain $user $domain
  45. assert_success
  46. USER_DATA=$HESTIA/data/users/$user
  47. local domain_ip=$(get_object_value 'web' 'DOMAIN' "$domain" '$IP')
  48. SSL=$(get_object_value 'web' 'DOMAIN' "$domain" '$SSL')
  49. domain_ip=$(get_real_ip "$domain_ip")
  50. if [ ! -z $webpath ]; then
  51. domain_docroot=$(get_object_value 'web' 'DOMAIN' "$domain" '$CUSTOM_DOCROOT')
  52. if [ -n "$domain_docroot" ] && [ -d "$domain_docroot" ]; then
  53. assert_file_exist "${domain_docroot}/${webpath}"
  54. else
  55. assert_file_exist "${HOMEDIR}/${user}/web/${domain}/public_html/${webpath}"
  56. fi
  57. fi
  58. # Test HTTP
  59. # Curl hates UTF domains so convert them to ascci.
  60. domain_idn=$(idn -a $domain)
  61. run curl --location --silent --show-error --insecure --resolve "${domain_idn}:80:${domain_ip}" "http://${domain_idn}/${webpath}"
  62. assert_success
  63. assert_output --partial "$webproof"
  64. # Test HTTPS
  65. if [ "$SSL" = "yes" ]; then
  66. run v-list-web-domain-ssl $user $domain
  67. assert_success
  68. run curl --location --silent --show-error --insecure --resolve "${domain_idn}:443:${domain_ip}" "https://${domain_idn}/${webpath}"
  69. assert_success
  70. assert_output --partial "$webproof"
  71. fi
  72. }
  73. function validate_headers_domain() {
  74. local user=$1
  75. local domain=$2
  76. local webproof=$3
  77. refute [ -z "$user" ]
  78. refute [ -z "$domain" ]
  79. refute [ -z "$webproof" ]
  80. source $HESTIA/func/ip.sh
  81. run v-list-web-domain $user $domain
  82. assert_success
  83. USER_DATA=$HESTIA/data/users/$user
  84. local domain_ip=$(get_object_value 'web' 'DOMAIN' "$domain" '$IP')
  85. SSL=$(get_object_value 'web' 'DOMAIN' "$domain" '$SSL')
  86. domain_ip=$(get_real_ip "$domain_ip")
  87. # Test HTTP with code redirect for some reasons due to 301 redirect it fails
  88. curl -i --resolve "${domain}:80:${domain_ip}" "http://${domain}"
  89. assert_success
  90. assert_output --partial "$webproof"
  91. }
  92. function validate_mail_domain() {
  93. local user=$1
  94. local domain=$2
  95. refute [ -z "$user" ]
  96. refute [ -z "$domain" ]
  97. run v-list-mail-domain $user $domain
  98. assert_success
  99. assert_dir_exist $HOMEDIR/$user/mail/$domain
  100. assert_dir_exist $HOMEDIR/$user/conf/mail/$domain
  101. assert_file_exist $HOMEDIR/$user/conf/mail/$domain/aliases
  102. assert_file_exist $HOMEDIR/$user/conf/mail/$domain/antispam
  103. assert_file_exist $HOMEDIR/$user/conf/mail/$domain/antivirus
  104. assert_file_exist $HOMEDIR/$user/conf/mail/$domain/fwd_only
  105. assert_file_exist $HOMEDIR/$user/conf/mail/$domain/ip
  106. assert_file_exist $HOMEDIR/$user/conf/mail/$domain/passwd
  107. }
  108. function validate_webmail_domain() {
  109. local user=$1
  110. local domain=$2
  111. local webproof=$3
  112. local webpath=${4}
  113. refute [ -z "$user" ]
  114. refute [ -z "$domain" ]
  115. refute [ -z "$webproof" ]
  116. source $HESTIA/func/ip.sh
  117. USER_DATA=$HESTIA/data/users/$user
  118. local domain_ip=$(get_object_value 'web' 'DOMAIN' "$domain" '$IP')
  119. SSL=$(get_object_value 'mail' 'DOMAIN' "$domain" '$SSL')
  120. domain_ip=$(get_real_ip "$domain_ip")
  121. if [ ! -z "$webpath" ]; then
  122. assert_file_exist /var/lib/roundcube/$webpath
  123. fi
  124. if [ "$SSL" = "no" ]; then
  125. # Test HTTP
  126. run curl --location --silent --show-error --insecure --resolve "webmail.${domain}:80:${domain_ip}" "http://webmail.${domain}/${webpath}"
  127. assert_success
  128. assert_output --partial "$webproof"
  129. # Test HTTP
  130. run curl --location --silent --show-error --insecure --resolve "mail.${domain}:80:${domain_ip}" "http://mail.${domain}/${webpath}"
  131. assert_success
  132. assert_output --partial "$webproof"
  133. fi
  134. # Test HTTPS
  135. if [ "$SSL" = "yes" ]; then
  136. # Test HTTP with 301 redirect for some reasons due to 301 redirect it fails
  137. run curl --silent --show-error --insecure --resolve "webmail.${domain}:80:${domain_ip}" "http://webmail.${domain}/${webpath}"
  138. assert_success
  139. assert_output --partial "301 Moved Permanently"
  140. # Test HTTP with 301 redirect for some reasons due to 301 redirect it fails
  141. run curl --silent --show-error --insecure --resolve "mail.${domain}:80:${domain_ip}" "http://mail.${domain}/${webpath}"
  142. assert_success
  143. assert_output --partial "301 Moved Permanently"
  144. run v-list-mail-domain-ssl $user $domain
  145. assert_success
  146. run curl --location --silent --show-error --insecure --resolve "webmail.${domain}:443:${domain_ip}" "https://webmail.${domain}/${webpath}"
  147. assert_success
  148. assert_output --partial "$webproof"
  149. run curl --location --silent --show-error --insecure --resolve "mail.${domain}:443:${domain_ip}" "https://mail.${domain}/${webpath}"
  150. assert_success
  151. assert_output --partial "$webproof"
  152. fi
  153. }
  154. function validate_database(){
  155. local type=$1
  156. local database=$2
  157. local dbuser=$3
  158. local password=$4
  159. host_str=$(grep "HOST='localhost'" $HESTIA/conf/$type.conf)
  160. parse_object_kv_list "$host_str"
  161. if [ -z $PORT ]; then PORT=3306; fi
  162. refute [ -z "$HOST" ]
  163. refute [ -z "$PORT" ]
  164. refute [ -z "$database" ]
  165. refute [ -z "$dbuser" ]
  166. refute [ -z "$password" ]
  167. if [ "$type" = "mysql" ]; then
  168. # Create an connection to verify correct username / password has been set correctly
  169. tmpfile=$(mktemp /tmp/mysql.XXXXXX)
  170. echo "[client]">$tmpfile
  171. echo "host='$HOST'" >> $tmpfile
  172. echo "user='$dbuser'" >> $tmpfile
  173. echo "password='$password'" >> $tmpfile
  174. echo "port='$PORT'" >> $tmpfile
  175. chmod 600 $tmpfile
  176. sql_tmp=$(mktemp /tmp/query.XXXXXX)
  177. echo "show databases;" > $sql_tmp
  178. run mysql --defaults-file=$tmpfile < "$sql_tmp"
  179. assert_success
  180. assert_output --partial "$database"
  181. rm -f "$sql_tmp"
  182. rm -f "$tmpfile"
  183. else
  184. echo "*:*:*:$dbuser:$password" > /root/.pgpass
  185. chmod 600 /root/.pgpass
  186. run export PGPASSWORD="$password" | psql -h $HOST -U "$dbuser" -p $PORT -d "$database" --no-password -c "\l"
  187. assert_success
  188. rm /root/.pgpass
  189. fi
  190. }
  191. function check_ip_banned(){
  192. local ip=$1
  193. local chain=$2
  194. run grep "IP='$ip' CHAIN='$chain'" $HESTIA/data/firewall/banlist.conf
  195. assert_success
  196. assert_output --partial "$ip"
  197. }
  198. function check_ip_not_banned(){
  199. local ip=$1
  200. local chain=$2
  201. run grep "IP='$ip' CHAIN='$chain'" $HESTIA/data/firewall/banlist.conf
  202. assert_failure E_ARGS
  203. refute_output
  204. }
  205. #----------------------------------------------------------#
  206. # IP #
  207. #----------------------------------------------------------#
  208. @test "Check reverse Dns validation" {
  209. # 1. PTR record for a IP should return a hostname(reverse) which in turn must resolve to the same IP addr(forward). (Full circle)
  210. # `-> not implemented in `is_ip_rdns_valid` yet and also not tested here
  211. # 2. Reject rPTR records that match generic dynamic IP pool patterns
  212. local ip="54.200.1.22"
  213. local rdns="ec2-54-200-1-22.us-west-2.compute.amazonaws.com"
  214. run is_ip_rdns_valid "$ip"
  215. assert_failure
  216. refute_output
  217. local rdns="ec2.54.200.1.22.us-west-2.compute.amazonaws.com"
  218. run is_ip_rdns_valid "$ip"
  219. assert_failure
  220. refute_output
  221. local rdns="ec2-22-1-200-54.us-west-2.compute.amazonaws.com"
  222. run is_ip_rdns_valid "$ip"
  223. assert_failure
  224. refute_output
  225. local rdns="ec2.22.1.200.54.us-west-2.compute.amazonaws.com"
  226. run is_ip_rdns_valid "$ip"
  227. assert_failure
  228. refute_output
  229. local rdns="ec2-200-54-1-22.us-west-2.compute.amazonaws.com"
  230. run is_ip_rdns_valid "$ip"
  231. assert_failure
  232. refute_output
  233. local rdns="panel-22.mydomain.tld"
  234. run is_ip_rdns_valid "$ip"
  235. assert_success
  236. assert_output "$rdns"
  237. local rdns="mail.mydomain.tld"
  238. run is_ip_rdns_valid "$ip"
  239. assert_success
  240. assert_output "$rdns"
  241. local rdns="mydomain.tld"
  242. run is_ip_rdns_valid "$ip"
  243. assert_success
  244. assert_output "$rdns"
  245. }
  246. #----------------------------------------------------------#
  247. # User #
  248. #----------------------------------------------------------#
  249. @test "Add new user" {
  250. run v-add-user $user $user $user@hestiacp.com default "Super Test"
  251. assert_success
  252. refute_output
  253. }
  254. @test "Change user password" {
  255. run v-change-user-password "$user" t3st-p4ssw0rd
  256. assert_success
  257. refute_output
  258. }
  259. @test "Change user email" {
  260. run v-change-user-contact "$user" tester@hestiacp.com
  261. assert_success
  262. refute_output
  263. }
  264. @test "Change user contact invalid email " {
  265. run v-change-user-contact "$user" testerhestiacp.com
  266. assert_failure $E_INVALID
  267. assert_output --partial 'Error: invalid email format'
  268. }
  269. @test "Change user name" {
  270. run v-change-user-name "$user" "New name"
  271. assert_success
  272. refute_output
  273. }
  274. @test "Change user shell" {
  275. run v-change-user-shell $user bash
  276. assert_success
  277. refute_output
  278. }
  279. @test "Change user invalid shell" {
  280. run v-change-user-shell $user bashinvalid
  281. assert_failure $E_INVALID
  282. assert_output --partial 'shell bashinvalid is not valid'
  283. }
  284. @test "Change user default ns" {
  285. run v-change-user-ns $user ns0.com ns1.com ns2.com ns3.com
  286. assert_success
  287. refute_output
  288. run v-list-user-ns "$user" plain
  289. assert_success
  290. assert_output --partial 'ns0.com'
  291. }
  292. #----------------------------------------------------------#
  293. # Cron #
  294. #----------------------------------------------------------#
  295. @test "Cron: Add cron job" {
  296. run v-add-cron-job $user 1 1 1 1 1 echo
  297. assert_success
  298. refute_output
  299. }
  300. @test "Cron: Suspend cron job" {
  301. run v-suspend-cron-job $user 1
  302. assert_success
  303. refute_output
  304. }
  305. @test "Cron: Unsuspend cron job" {
  306. run v-unsuspend-cron-job $user 1
  307. assert_success
  308. refute_output
  309. }
  310. @test "Cron: Delete cron job" {
  311. run v-delete-cron-job $user 1
  312. assert_success
  313. refute_output
  314. }
  315. @test "Cron: Add cron job (duplicate)" {
  316. run v-add-cron-job $user 1 1 1 1 1 echo 1
  317. assert_success
  318. refute_output
  319. run v-add-cron-job $user 1 1 1 1 1 echo 1
  320. assert_failure $E_EXISTS
  321. assert_output --partial 'JOB=1 already exists'
  322. }
  323. @test "Cron: Second cron job" {
  324. run v-add-cron-job $user 2 2 2 2 2 echo 2
  325. assert_success
  326. refute_output
  327. }
  328. @test "Cron: Two cron jobs must be listed" {
  329. run v-list-cron-jobs $user csv
  330. assert_success
  331. assert_line --partial '1,1,1,1,1,"echo",no'
  332. assert_line --partial '2,2,2,2,2,"echo",no'
  333. }
  334. @test "Cron: rebuild" {
  335. run v-rebuild-cron-jobs $user
  336. assert_success
  337. refute_output
  338. }
  339. #----------------------------------------------------------#
  340. # IP #
  341. #----------------------------------------------------------#
  342. @test "Ip: Add new ip on first interface" {
  343. interface=$(v-list-sys-interfaces plain | head -n 1)
  344. run ip link show dev $interface
  345. assert_success
  346. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  347. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  348. # Save initial state
  349. echo "interface=${interface}" >> /tmp/hestia-test-env.sh
  350. [ -f "$a2_rpaf" ] && file_hash1=$(cat $a2_rpaf |md5sum |cut -d" " -f1) && echo "a2_rpaf_hash='${file_hash1}'" >> /tmp/hestia-test-env.sh
  351. [ -f "$a2_remoteip" ] && file_hash2=$(cat $a2_remoteip |md5sum |cut -d" " -f1) && echo "a2_remoteip_hash='${file_hash2}'" >> /tmp/hestia-test-env.sh
  352. local ip="198.18.0.12"
  353. run v-add-sys-ip $ip 255.255.255.255 $interface $user
  354. assert_success
  355. refute_output
  356. assert_file_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  357. assert_file_exist $HESTIA/data/ips/$ip
  358. assert_file_contains $HESTIA/data/ips/$ip "OWNER='$user'"
  359. assert_file_contains $HESTIA/data/ips/$ip "INTERFACE='$interface'"
  360. if [ -n "$PROXY_SYSTEM" ]; then
  361. assert_file_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  362. [ -f "$a2_rpaf" ] && assert_file_contains "$a2_rpaf" "RPAFproxy_ips.*$ip\b"
  363. [ -f "$a2_remoteip" ] && assert_file_contains "$a2_remoteip" "RemoteIPInternalProxy $ip\$"
  364. fi
  365. }
  366. @test "Ip: Add ip (duplicate)" {
  367. run v-add-sys-ip 198.18.0.12 255.255.255.255 $interface $user
  368. assert_failure $E_EXISTS
  369. }
  370. @test "Ip: Add extra ip" {
  371. local ip="198.18.0.121"
  372. run v-add-sys-ip $ip 255.255.255.255 $interface $user
  373. assert_success
  374. refute_output
  375. assert_file_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  376. assert_file_exist $HESTIA/data/ips/$ip
  377. assert_file_contains $HESTIA/data/ips/$ip "OWNER='$user'"
  378. assert_file_contains $HESTIA/data/ips/$ip "INTERFACE='$interface'"
  379. if [ -n "$PROXY_SYSTEM" ]; then
  380. assert_file_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  381. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  382. [ -f "$a2_rpaf" ] && assert_file_contains "$a2_rpaf" "RPAFproxy_ips.*$ip\b"
  383. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  384. [ -f "$a2_remoteip" ] && assert_file_contains "$a2_remoteip" "RemoteIPInternalProxy $ip\$"
  385. fi
  386. }
  387. @test "Ip: Change Helo" {
  388. local ip="198.18.0.121"
  389. run v-change-sys-ip-helo 198.18.0.121 dev.hestiacp.com
  390. assert_success
  391. refute_output
  392. assert_file_contains /etc/exim4/mailhelo.conf "198.18.0.121:dev.hestiacp.com"
  393. }
  394. @test "Ip: Delete ips" {
  395. local ip="198.18.0.12"
  396. run v-delete-sys-ip $ip
  397. assert_success
  398. refute_output
  399. assert_file_not_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  400. assert_file_not_exist $HESTIA/data/ips/$ip
  401. ip="198.18.0.121"
  402. run v-delete-sys-ip $ip
  403. assert_success
  404. refute_output
  405. assert_file_not_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  406. assert_file_not_exist $HESTIA/data/ips/$ip
  407. if [ -n "$PROXY_SYSTEM" ]; then
  408. assert_file_not_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  409. fi
  410. # remoteip and rpaf config hashes must match the initial one
  411. if [ ! -z "$a2_rpaf_hash" ]; then
  412. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  413. file_hash=$(cat $a2_rpaf |md5sum |cut -d" " -f1)
  414. assert_equal "$file_hash" "$a2_rpaf_hash"
  415. fi
  416. if [ ! -z "$a2_remoteip_hash" ]; then
  417. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  418. file_hash=$(cat $a2_remoteip |md5sum |cut -d" " -f1)
  419. assert_equal "$file_hash" "$a2_remoteip_hash"
  420. fi
  421. }
  422. @test "Ip: Add IP for rest of the test" {
  423. local ip="198.18.0.125"
  424. run v-add-sys-ip $ip 255.255.255.255 $interface $user
  425. assert_success
  426. refute_output
  427. assert_file_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  428. assert_file_exist $HESTIA/data/ips/$ip
  429. assert_file_contains $HESTIA/data/ips/$ip "OWNER='$user'"
  430. assert_file_contains $HESTIA/data/ips/$ip "INTERFACE='$interface'"
  431. if [ -n "$PROXY_SYSTEM" ]; then
  432. assert_file_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  433. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  434. [ -f "$a2_rpaf" ] && assert_file_contains "$a2_rpaf" "RPAFproxy_ips.*$ip\b"
  435. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  436. [ -f "$a2_remoteip" ] && assert_file_contains "$a2_remoteip" "RemoteIPInternalProxy $ip\$"
  437. fi
  438. }
  439. #----------------------------------------------------------#
  440. # WEB #
  441. #----------------------------------------------------------#
  442. @test "WEB: Add web domain" {
  443. run v-add-web-domain $user $domain 198.18.0.125
  444. assert_success
  445. refute_output
  446. echo -e "<?php\necho 'Hestia Test:'.(4*3);" > $HOMEDIR/$user/web/$domain/public_html/php-test.php
  447. validate_web_domain $user $domain 'Hestia Test:12' 'php-test.php'
  448. rm $HOMEDIR/$user/web/$domain/public_html/php-test.php
  449. }
  450. @test "WEB: Add web domain (duplicate)" {
  451. run v-add-web-domain $user $domain 198.18.0.125
  452. assert_failure $E_EXISTS
  453. }
  454. @test "WEB: Add web domain alias" {
  455. run v-add-web-domain-alias $user $domain v3.$domain
  456. assert_success
  457. refute_output
  458. }
  459. @test "WEB: Add web domain alias (duplicate)" {
  460. run v-add-web-domain-alias $user $domain v3.$domain
  461. assert_failure $E_EXISTS
  462. }
  463. @test "WEB: Add web domain wildcard alias" {
  464. run v-add-web-domain-alias $user $domain "*.$domain"
  465. assert_success
  466. refute_output
  467. }
  468. @test "WEB: Delete web domain wildcard alias" {
  469. run v-delete-web-domain-alias $user $domain "*.$domain"
  470. assert_success
  471. refute_output
  472. }
  473. @test "WEB: Add web domain stats" {
  474. run v-add-web-domain-stats $user $domain awstats
  475. assert_success
  476. refute_output
  477. }
  478. @test "WEB: Add web domain stats user" {
  479. skip
  480. run v-add-web-domain-stats-user $user $domain test m3g4p4ssw0rd
  481. assert_success
  482. refute_output
  483. }
  484. @test "WEB: Suspend web domain" {
  485. run v-suspend-web-domain $user $domain
  486. assert_success
  487. refute_output
  488. validate_web_domain $user $domain 'This site is currently suspended'
  489. }
  490. @test "WEB: Unsuspend web domain" {
  491. run v-unsuspend-web-domain $user $domain
  492. assert_success
  493. refute_output
  494. echo -e "<?php\necho 'Hestia Test:'.(4*3);" > $HOMEDIR/$user/web/$domain/public_html/php-test.php
  495. validate_web_domain $user $domain 'Hestia Test:12' 'php-test.php'
  496. rm $HOMEDIR/$user/web/$domain/public_html/php-test.php
  497. }
  498. @test "WEB: Add redirect to www.domain.com" {
  499. run v-add-web-domain-redirect $user $domain www.$domain 301
  500. assert_success
  501. refute_output
  502. run validate_headers_domain $user $domain "301"
  503. }
  504. @test "WEB: Delete redirect to www.domain.com" {
  505. run v-delete-web-domain-redirect $user $domain
  506. assert_success
  507. refute_output
  508. }
  509. @test "WEB: Enable Fast CGI Cache" {
  510. if [ "$WEB_SYSTEM" != "nginx" ]; then
  511. skip "FastCGI cache is not supported"
  512. fi
  513. run v-add-fastcgi-cache $user $domain '1m' yes
  514. assert_success
  515. refute_output
  516. echo -e "<?php\necho 'Hestia Test:'.(4*3);" > $HOMEDIR/$user/web/$domain/public_html/php-test.php
  517. run validate_headers_domain $user $domain "Miss"
  518. run validate_headers_domain $user $domain "Hit"
  519. rm $HOMEDIR/$user/web/$domain/public_html/php-test.php
  520. }
  521. @test "WEB: Disable Fast CGI Cache" {
  522. if [ "$WEB_SYSTEM" != "nginx" ]; then
  523. skip "FastCGI cache is not supported"
  524. fi
  525. run v-delete-fastcgi-cache $user $domain '1m' yes
  526. assert_success
  527. refute_output
  528. }
  529. @test "WEB: Generate Self signed certificate" {
  530. ssl=$(v-generate-ssl-cert "$domain" "info@$domain" US CA "Orange County" HestiaCP IT "mail.$domain" | tail -n1 | awk '{print $2}')
  531. mv $ssl/$domain.crt /tmp/$domain.crt
  532. mv $ssl/$domain.key /tmp/$domain.key
  533. }
  534. @test "WEB: Add ssl" {
  535. # Use self signed certificates during last test
  536. run v-add-web-domain-ssl $user $domain /tmp
  537. assert_success
  538. refute_output
  539. }
  540. @test "WEB: Rebuild web domain" {
  541. run v-rebuild-web-domains $user
  542. assert_success
  543. refute_output
  544. }
  545. #----------------------------------------------------------#
  546. # IDN #
  547. #----------------------------------------------------------#
  548. @test "WEB: Add IDN domain UTF idn-tést.eu" {
  549. run v-add-web-domain $user idn-tést.eu 198.18.0.125
  550. assert_success
  551. refute_output
  552. echo -e "<?php\necho 'Hestia Test:'.(4*3);" > $HOMEDIR/$user/web/idn-tést.eu/public_html/php-test.php
  553. validate_web_domain $user idn-tést.eu 'Hestia Test:12' 'php-test.php'
  554. rm $HOMEDIR/$user/web/idn-tést.eu/public_html/php-test.php
  555. }
  556. @test "WEB: Add IDN domain ASCII idn-tést.eu" {
  557. # Expected to fail due to utf exists
  558. run v-add-web-domain $user $( idn -a idn-tést.eu) 198.18.0.125
  559. assert_failure $E_EXISTS
  560. }
  561. @test "WEB: Delete IDN domain idn-tést.eu" {
  562. run v-delete-web-domain $user idn-tést.eu
  563. assert_success
  564. refute_output
  565. }
  566. @test "WEB: Add IDN domain UTF bløst.com" {
  567. run v-add-web-domain $user bløst.com 198.18.0.125
  568. assert_success
  569. refute_output
  570. }
  571. @test "WEB: Delete IDN domain bløst.com" {
  572. run v-delete-web-domain $user bløst.com
  573. assert_success
  574. refute_output
  575. }
  576. #----------------------------------------------------------#
  577. # MULTIPHP #
  578. #----------------------------------------------------------#
  579. @test "Multiphp: Default php Backend version" {
  580. def_phpver=$(multiphp_default_version)
  581. multi_domain="multiphp.${domain}"
  582. run v-add-web-domain $user $multi_domain 198.18.0.125
  583. assert_success
  584. refute_output
  585. echo -e "<?php\necho PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  586. validate_web_domain $user $multi_domain "$def_phpver" 'php-test.php'
  587. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  588. }
  589. @test "Multiphp: Change backend version - PHP v5.6" {
  590. test_phpver='5.6'
  591. multi_domain="multiphp.${domain}"
  592. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  593. skip "PHP ${test_phpver} not installed"
  594. fi
  595. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-5_6' 'yes'
  596. assert_success
  597. refute_output
  598. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  599. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  600. # A single php-fpm pool config file must be present
  601. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  602. assert_equal "$num_fpm_config_files" '1'
  603. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  604. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  605. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  606. }
  607. @test "Multiphp: Change backend version - PHP v7.0" {
  608. test_phpver='7.0'
  609. multi_domain="multiphp.${domain}"
  610. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  611. skip "PHP ${test_phpver} not installed"
  612. fi
  613. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-7_0' 'yes'
  614. assert_success
  615. refute_output
  616. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  617. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  618. # A single php-fpm pool config file must be present
  619. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  620. assert_equal "$num_fpm_config_files" '1'
  621. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  622. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  623. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  624. }
  625. @test "Multiphp: Change backend version - PHP v7.1" {
  626. test_phpver='7.1'
  627. multi_domain="multiphp.${domain}"
  628. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  629. skip "PHP ${test_phpver} not installed"
  630. fi
  631. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-7_1' 'yes'
  632. assert_success
  633. refute_output
  634. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  635. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  636. # A single php-fpm pool config file must be present
  637. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  638. assert_equal "$num_fpm_config_files" '1'
  639. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  640. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  641. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  642. }
  643. @test "Multiphp: Change backend version - PHP v7.2" {
  644. test_phpver='7.2'
  645. multi_domain="multiphp.${domain}"
  646. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  647. skip "PHP ${test_phpver} not installed"
  648. fi
  649. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-7_2' 'yes'
  650. assert_success
  651. refute_output
  652. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  653. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  654. # A single php-fpm pool config file must be present
  655. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  656. assert_equal "$num_fpm_config_files" '1'
  657. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  658. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  659. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  660. }
  661. @test "Multiphp: Change backend version - PHP v7.3" {
  662. test_phpver='7.3'
  663. multi_domain="multiphp.${domain}"
  664. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  665. skip "PHP ${test_phpver} not installed"
  666. fi
  667. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-7_3' 'yes'
  668. assert_success
  669. refute_output
  670. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  671. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  672. # A single php-fpm pool config file must be present
  673. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  674. assert_equal "$num_fpm_config_files" '1'
  675. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  676. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  677. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  678. }
  679. @test "Multiphp: Change backend version - PHP v7.4" {
  680. test_phpver='7.4'
  681. multi_domain="multiphp.${domain}"
  682. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  683. skip "PHP ${test_phpver} not installed"
  684. fi
  685. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-7_4' 'yes'
  686. assert_success
  687. refute_output
  688. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  689. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  690. # A single php-fpm pool config file must be present
  691. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  692. assert_equal "$num_fpm_config_files" '1'
  693. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  694. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  695. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  696. }
  697. @test "Multiphp: Change backend version - PHP v8.0" {
  698. test_phpver='8.0'
  699. multi_domain="multiphp.${domain}"
  700. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  701. skip "PHP ${test_phpver} not installed"
  702. fi
  703. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-8_0' 'yes'
  704. assert_success
  705. refute_output
  706. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  707. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  708. # A single php-fpm pool config file must be present
  709. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  710. assert_equal "$num_fpm_config_files" '1'
  711. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  712. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  713. rm $HOMEDIR/$user/web/$multi_domain/public_html/php-test.php
  714. }
  715. @test "Multiphp: Cleanup" {
  716. multi_domain="multiphp.${domain}"
  717. run v-delete-web-domain $user $multi_domain 'yes'
  718. assert_success
  719. refute_output
  720. # No php-fpm pool config file must be present
  721. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  722. assert_equal "$num_fpm_config_files" '0'
  723. }
  724. #----------------------------------------------------------#
  725. # CUSTOM DOCROOT #
  726. #----------------------------------------------------------#
  727. @test "Docroot: Self Subfolder" {
  728. docroot1_domain="docroot1.${domain}"
  729. run v-add-web-domain $user $docroot1_domain 198.18.0.125
  730. assert_success
  731. refute_output
  732. run v-add-fs-directory $user "$HOMEDIR/$user/web/$docroot1_domain/public_html/public/"
  733. assert_success
  734. refute_output
  735. run v-change-web-domain-docroot $user "$docroot1_domain" "$docroot1_domain" "/public"
  736. assert_success
  737. refute_output
  738. echo -e '<?php\necho "self-sub-".$_SERVER["HTTP_HOST"];' > "$HOMEDIR/$user/web/$docroot1_domain/public_html/public/php-test.php"
  739. validate_web_domain $user $docroot1_domain "self-sub-${docroot1_domain}" 'php-test.php'
  740. rm "$HOMEDIR/$user/web/$docroot1_domain/public_html/public/php-test.php"
  741. }
  742. @test "Docroot: Other domain subfolder" {
  743. docroot1_domain="docroot1.${domain}"
  744. docroot2_domain="docroot2.${domain}"
  745. run v-add-web-domain $user $docroot2_domain 198.18.0.125
  746. assert_success
  747. refute_output
  748. run v-add-fs-directory $user "$HOMEDIR/$user/web/$docroot2_domain/public_html/public/"
  749. assert_success
  750. refute_output
  751. run v-change-web-domain-docroot $user "$docroot1_domain" "$docroot2_domain" "/public"
  752. assert_success
  753. refute_output
  754. echo -e '<?php\necho "doc2-sub-".$_SERVER["HTTP_HOST"];' > "$HOMEDIR/$user/web/$docroot2_domain/public_html/public/php-test.php"
  755. validate_web_domain $user $docroot1_domain "doc2-sub-${docroot1_domain}" 'php-test.php'
  756. rm "$HOMEDIR/$user/web/$docroot2_domain/public_html/public/php-test.php"
  757. }
  758. @test "Docroot: Other domain root folder" {
  759. docroot1_domain="docroot1.${domain}"
  760. docroot2_domain="docroot2.${domain}"
  761. run v-change-web-domain-docroot $user "$docroot1_domain" "$docroot2_domain"
  762. assert_success
  763. refute_output
  764. echo -e '<?php\necho "doc2-root-".$_SERVER["HTTP_HOST"];' > "$HOMEDIR/$user/web/$docroot2_domain/public_html/php-test.php"
  765. validate_web_domain $user $docroot1_domain "doc2-root-${docroot1_domain}" 'php-test.php'
  766. rm "$HOMEDIR/$user/web/$docroot2_domain/public_html/php-test.php"
  767. }
  768. @test "Docroot: Reset" {
  769. docroot1_domain="docroot1.${domain}"
  770. run v-change-web-domain-docroot $user "$docroot1_domain" "default"
  771. assert_success
  772. refute_output
  773. echo -e '<?php\necho "doc1-root-".$_SERVER["HTTP_HOST"];' > "$HOMEDIR/$user/web/$docroot1_domain/public_html/php-test.php"
  774. validate_web_domain $user $docroot1_domain "doc1-root-${docroot1_domain}" 'php-test.php'
  775. rm "$HOMEDIR/$user/web/$docroot1_domain/public_html/php-test.php"
  776. }
  777. @test "Docroot: Cleanup" {
  778. docroot1_domain="docroot1.${domain}"
  779. docroot2_domain="docroot2.${domain}"
  780. run v-delete-web-domain $user $docroot1_domain
  781. assert_success
  782. refute_output
  783. run v-delete-web-domain $user $docroot2_domain
  784. assert_success
  785. refute_output
  786. }
  787. #----------------------------------------------------------#
  788. # DNS #
  789. #----------------------------------------------------------#
  790. @test "DNS: Add domain" {
  791. run v-add-dns-domain $user $domain 198.18.0.125
  792. assert_success
  793. refute_output
  794. }
  795. @test "DNS: Add domain (duplicate)" {
  796. run v-add-dns-domain $user $domain 198.18.0.125
  797. assert_failure $E_EXISTS
  798. }
  799. @test "DNS: Add domain record" {
  800. run v-add-dns-record $user $domain test A 198.18.0.125 20
  801. assert_success
  802. refute_output
  803. }
  804. @test "DNS: Delete domain record" {
  805. run v-delete-dns-record $user $domain 20
  806. assert_success
  807. refute_output
  808. }
  809. @test "DNS: Delete missing domain record" {
  810. run v-delete-dns-record $user $domain 20
  811. assert_failure $E_NOTEXIST
  812. }
  813. @test "DNS: Change domain expire date" {
  814. run v-change-dns-domain-exp $user $domain 2020-01-01
  815. assert_success
  816. refute_output
  817. }
  818. @test "DNS: Change domain ip" {
  819. run v-change-dns-domain-ip $user $domain 127.0.0.1
  820. assert_success
  821. refute_output
  822. }
  823. @test "DNS: Suspend domain" {
  824. run v-suspend-dns-domain $user $domain
  825. assert_success
  826. refute_output
  827. }
  828. @test "DNS: Unsuspend domain" {
  829. run v-unsuspend-dns-domain $user $domain
  830. assert_success
  831. refute_output
  832. }
  833. @test "DNS: Rebuild" {
  834. run v-rebuild-dns-domains $user
  835. assert_success
  836. refute_output
  837. }
  838. #----------------------------------------------------------#
  839. # MAIL #
  840. #----------------------------------------------------------#
  841. @test "MAIL: Add domain" {
  842. run v-add-mail-domain $user $domain
  843. assert_success
  844. refute_output
  845. validate_mail_domain $user $domain
  846. }
  847. @test "MAIL: Add mail domain webmail client (Roundcube)" {
  848. run v-add-mail-domain-webmail $user $domain "roundcube" "yes"
  849. assert_success
  850. refute_output
  851. # echo -e "<?php\necho 'Server: ' . \$_SERVER['SERVER_SOFTWARE'];" > /var/lib/roundcube/check_server.php
  852. validate_webmail_domain $user $domain 'Welcome to Roundcube Webmail'
  853. # rm /var/lib/roundcube/check_server.php
  854. }
  855. @test "Mail: Add SSL to mail domain" {
  856. # Use generated certificates during WEB Generate Self signed certificate
  857. run v-add-mail-domain-ssl $user $domain /tmp
  858. assert_success
  859. refute_output
  860. validate_webmail_domain $user $domain 'Welcome to Roundcube Webmail'
  861. }
  862. @test "MAIL: Add mail domain webmail client (Rainloop)" {
  863. if [ -z "$(echo $WEBMAIL_SYSTEM | grep -w "rainloop")" ]; then
  864. skip "Webmail client Rainloop not installed"
  865. fi
  866. run v-add-mail-domain-webmail $user $domain "rainloop" "yes"
  867. assert_success
  868. refute_output
  869. validate_mail_domain $user $domain
  870. validate_webmail_domain $user $domain 'RainLoop Webmail'
  871. }
  872. @test "MAIL: Disable webmail client" {
  873. run v-add-mail-domain-webmail $user $domain "disabled" "yes"
  874. assert_success
  875. refute_output
  876. validate_mail_domain $user $domain
  877. validate_webmail_domain $user $domain 'Success!'
  878. }
  879. @test "MAIL: Add domain (duplicate)" {
  880. run v-add-mail-domain $user $domain
  881. assert_failure $E_EXISTS
  882. }
  883. @test "MAIL: Add account" {
  884. run v-add-mail-account $user $domain test t3st-p4ssw0rd
  885. assert_success
  886. refute_output
  887. }
  888. @test "MAIL: Add account (duplicate)" {
  889. run v-add-mail-account $user $domain test t3st-p4ssw0rd
  890. assert_failure $E_EXISTS
  891. }
  892. @test "MAIL: Delete account" {
  893. run v-delete-mail-account $user $domain test
  894. assert_success
  895. refute_output
  896. }
  897. @test "MAIL: Delete missing account" {
  898. run v-delete-mail-account $user $domain test
  899. assert_failure $E_NOTEXIST
  900. }
  901. @test "MAIL: Rebuild mail domain" {
  902. run v-rebuild-mail-domains $user
  903. assert_success
  904. refute_output
  905. }
  906. #----------------------------------------------------------#
  907. # Limit possibilities adding different owner domain #
  908. #----------------------------------------------------------#
  909. @test "Allow Users: User can't add user.user2.com " {
  910. # Case: admin company.ltd
  911. # users should not be allowed to add user.company.ltd
  912. run v-add-user $user2 $user2 $user@hestiacp.com default "Super Test"
  913. assert_success
  914. refute_output
  915. run v-add-web-domain $user2 $rootdomain
  916. assert_success
  917. refute_output
  918. run v-add-web-domain $user $subdomain
  919. assert_failure $E_EXISTS
  920. }
  921. @test "Allow Users: User can't add user.user2.com as alias" {
  922. run v-add-web-domain-alias $user $domain $subdomain
  923. assert_failure $E_EXISTS
  924. }
  925. @test "Allow Users: User can't add user.user2.com as mail domain" {
  926. run v-add-mail-domain $user $subdomain
  927. assert_failure $E_EXISTS
  928. }
  929. @test "Allow Users: User can't add user.user2.com as dns domain" {
  930. run v-add-dns-domain $user $subdomain 198.18.0.125
  931. assert_failure $E_EXISTS
  932. }
  933. @test "Allow Users: Set Allow users" {
  934. # Allow user to yes allows
  935. # Case: admin company.ltd
  936. # users are allowed to add user.company.ltd
  937. run v-add-web-domain-allow-users $user2 $rootdomain
  938. assert_success
  939. refute_output
  940. }
  941. @test "Allow Users: User can add user.user2.com" {
  942. run v-add-web-domain $user $subdomain
  943. assert_success
  944. refute_output
  945. }
  946. @test "Allow Users: User can add user.user2.com as alias" {
  947. run v-delete-web-domain $user $subdomain
  948. assert_success
  949. refute_output
  950. run v-add-web-domain-alias $user $domain $subdomain
  951. assert_success
  952. refute_output
  953. }
  954. @test "Allow Users: User can add user.user2.com as mail domain" {
  955. run v-add-mail-domain $user $subdomain
  956. assert_success
  957. refute_output
  958. }
  959. @test "Allow Users: User can add user.user2.com as dns domain" {
  960. run v-add-dns-domain $user $subdomain 198.18.0.125
  961. assert_success
  962. refute_output
  963. }
  964. @test "Allow Users: Cleanup tests" {
  965. run v-delete-dns-domain $user $subdomain
  966. assert_success
  967. refute_output
  968. run v-delete-mail-domain $user $subdomain
  969. assert_success
  970. refute_output
  971. }
  972. @test "Allow Users: Set Allow users no" {
  973. run v-delete-web-domain-alias $user $domain $subdomain
  974. assert_success
  975. refute_output
  976. run v-delete-web-domain-allow-users $user2 $rootdomain
  977. assert_success
  978. refute_output
  979. }
  980. @test "Allow Users: User can't add user.user2.com again" {
  981. run v-add-web-domain $user $subdomain
  982. assert_failure $E_EXISTS
  983. }
  984. @test "Allow Users: user2 can add user.user2.com again" {
  985. run v-add-web-domain $user2 $subdomain
  986. assert_success
  987. refute_output
  988. run v-delete-user $user2
  989. assert_success
  990. refute_output
  991. }
  992. #----------------------------------------------------------#
  993. # DB #
  994. #----------------------------------------------------------#
  995. @test "MYSQL: Add database" {
  996. run v-add-database $user database dbuser 1234 mysql
  997. assert_success
  998. refute_output
  999. # validate_database mysql database_name database_user password
  1000. validate_database mysql $database $dbuser 1234
  1001. }
  1002. @test "MYSQL: Add Database (Duplicate)" {
  1003. run v-add-database $user database dbuser 1234 mysql
  1004. assert_failure $E_EXISTS
  1005. }
  1006. @test "MYSQL: Rebuild Database" {
  1007. run v-rebuild-database $user $database
  1008. assert_success
  1009. refute_output
  1010. }
  1011. @test "MYSQL: Change database user password" {
  1012. run v-change-database-password $user $database 123456
  1013. assert_success
  1014. refute_output
  1015. validate_database mysql $database $dbuser 123456
  1016. }
  1017. @test "MYSQL: Change database user" {
  1018. run v-change-database-user $user $database database
  1019. assert_success
  1020. refute_output
  1021. validate_database mysql $database $database 123456
  1022. }
  1023. @test "MYSQL: Suspend database" {
  1024. run v-suspend-database $user $database
  1025. assert_success
  1026. refute_output
  1027. }
  1028. @test "MYSQL: Unsuspend database" {
  1029. run v-unsuspend-database $user $database
  1030. assert_success
  1031. refute_output
  1032. }
  1033. @test "MYSQL: Delete database" {
  1034. run v-delete-database $user $database
  1035. assert_success
  1036. refute_output
  1037. }
  1038. @test "MYSQL: Delete missing database" {
  1039. run v-delete-database $user $database
  1040. assert_failure $E_NOTEXIST
  1041. }
  1042. @test "PGSQL: Add database invalid user" {
  1043. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1044. skip "PostGreSQL is not installed"
  1045. fi
  1046. run v-add-database "$user" "database" "dbuser" "1234ABCD" "pgsql"
  1047. assert_failure $E_INVALID
  1048. }
  1049. @test "PGSQL: Add database" {
  1050. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1051. skip "PostGreSQL is not installed"
  1052. fi
  1053. run v-add-user $pguser $pguser $user@hestiacp.com default "Super Test"
  1054. run v-add-database "$pguser" "database" "dbuser" "1234ABCD" "pgsql"
  1055. assert_success
  1056. refute_output
  1057. validate_database pgsql $pgdatabase $pgdbuser "1234ABCD"
  1058. }
  1059. @test "PGSQL: Add Database (Duplicate)" {
  1060. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1061. skip "PostGreSQL is not installed"
  1062. fi
  1063. run v-add-database "$pguser" "database" "dbuser" "1234ABCD" "pgsql"
  1064. assert_failure $E_EXISTS
  1065. }
  1066. @test "PGSQL: Rebuild Database" {
  1067. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1068. skip "PostGreSQL is not installed"
  1069. fi
  1070. run v-rebuild-database $pguser $pgdatabase
  1071. assert_success
  1072. refute_output
  1073. }
  1074. @test "PGSQL: Change database user password" {
  1075. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1076. skip "PostGreSQL is not installed"
  1077. fi
  1078. run v-change-database-password $pguser $pgdatabase "123456"
  1079. assert_success
  1080. refute_output
  1081. validate_database pgsql $pgdatabase $pgdbuser "123456"
  1082. }
  1083. @test "PGSQL: Suspend database" {
  1084. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1085. skip "PostGreSQL is not installed"
  1086. fi
  1087. run v-suspend-database $pguser $pgdatabase
  1088. assert_success
  1089. refute_output
  1090. }
  1091. @test "PGSQL: Unsuspend database" {
  1092. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1093. skip "PostGreSQL is not installed"
  1094. fi
  1095. run v-unsuspend-database $pguser $pgdatabase
  1096. assert_success
  1097. refute_output
  1098. }
  1099. @test "PGSQL: Change database user" {
  1100. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1101. skip "PostGreSQL is not installed"
  1102. fi
  1103. skip
  1104. run v-change-database-user $pguser $pgdatabase database
  1105. assert_success
  1106. refute_output
  1107. validate_database pgsql $pgdatabase $pgdatabase 123456
  1108. }
  1109. @test "PGSQL: Delete database" {
  1110. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1111. skip "PostGreSQL is not installed"
  1112. fi
  1113. run v-delete-database $pguser $pgdatabase
  1114. assert_success
  1115. refute_output
  1116. }
  1117. @test "PGSQL: Delete missing database" {
  1118. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1119. skip "PostGreSQL is not installed"
  1120. fi
  1121. run v-delete-database $pguser $pgdatabase
  1122. assert_failure $E_NOTEXIST
  1123. run v-delete-user $pguser
  1124. }
  1125. #----------------------------------------------------------#
  1126. # System #
  1127. #----------------------------------------------------------#
  1128. @test "System: Set/Enable SMTP account for internal mail" {
  1129. run v-add-sys-smtp $domain 587 STARTTLS info@$domain 1234-test noreply@$domain
  1130. assert_success
  1131. refute_output
  1132. }
  1133. @test "System: Disable SMTP account for internal mail" {
  1134. run v-delete-sys-smtp
  1135. assert_success
  1136. refute_output
  1137. }
  1138. #----------------------------------------------------------#
  1139. # Firewall #
  1140. #----------------------------------------------------------#
  1141. @test "Firewall: Add ip to banlist" {
  1142. run v-add-firewall-ban '1.2.3.4' 'HESTIA'
  1143. assert_success
  1144. refute_output
  1145. check_ip_banned '1.2.3.4' 'HESTIA'
  1146. }
  1147. @test "Firewall: Delete ip to banlist" {
  1148. run v-delete-firewall-ban '1.2.3.4' 'HESTIA'
  1149. assert_success
  1150. refute_output
  1151. check_ip_not_banned '1.2.3.4' 'HESTIA'
  1152. }
  1153. @test "Firewall: Add ip to banlist for ALL" {
  1154. run v-add-firewall-ban '1.2.3.4' 'HESTIA'
  1155. assert_success
  1156. refute_output
  1157. run v-add-firewall-ban '1.2.3.4' 'MAIL'
  1158. assert_success
  1159. refute_output
  1160. check_ip_banned '1.2.3.4' 'HESTIA'
  1161. }
  1162. @test "Firewall: Delete ip to banlist CHAIN = ALL" {
  1163. run v-delete-firewall-ban '1.2.3.4' 'ALL'
  1164. assert_success
  1165. refute_output
  1166. check_ip_not_banned '1.2.3.4' 'HESTIA'
  1167. }
  1168. @test "Test Whitelist Fail2ban" {
  1169. echo "1.2.3.4" >> $HESTIA/data/firewall/excludes.conf
  1170. run v-add-firewall-ban '1.2.3.4' 'HESTIA'
  1171. rm $HESTIA/data/firewall/excludes.conf
  1172. check_ip_not_banned '1.2.3.4' 'HESTIA'
  1173. }
  1174. #----------------------------------------------------------#
  1175. # CLEANUP #
  1176. #----------------------------------------------------------#
  1177. @test "Mail: Delete domain" {
  1178. # skip
  1179. run v-delete-mail-domain $user $domain
  1180. assert_success
  1181. refute_output
  1182. }
  1183. @test "DNS: Delete domain" {
  1184. # skip
  1185. run v-delete-dns-domain $user $domain
  1186. assert_success
  1187. refute_output
  1188. }
  1189. @test "WEB: Delete domain" {
  1190. # skip
  1191. run v-delete-web-domain $user $domain
  1192. assert_success
  1193. refute_output
  1194. }
  1195. @test "Delete user" {
  1196. run v-delete-user $user
  1197. assert_success
  1198. refute_output
  1199. }
  1200. @test "Ip: Delete the test IP" {
  1201. run v-delete-sys-ip 198.18.0.125
  1202. assert_success
  1203. refute_output
  1204. }
  1205. @test 'assert()' {
  1206. touch '/var/log/test.log'
  1207. assert [ -e '/var/log/test.log' ]
  1208. }