test.bats 68 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289
  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=$(idn2 $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. if [ -n "$ANTISPAM_SYSTEM" ]; then
  103. assert_file_exist $HOMEDIR/$user/conf/mail/$domain/antispam
  104. fi
  105. if [ -n "$ANTIVIRUS_SYSTEM" ]; then
  106. assert_file_exist $HOMEDIR/$user/conf/mail/$domain/antivirus
  107. fi
  108. assert_file_exist $HOMEDIR/$user/conf/mail/$domain/fwd_only
  109. assert_file_exist $HOMEDIR/$user/conf/mail/$domain/ip
  110. assert_file_exist $HOMEDIR/$user/conf/mail/$domain/passwd
  111. }
  112. function validate_webmail_domain() {
  113. local user=$1
  114. local domain=$2
  115. local webproof=$3
  116. local webpath=${4}
  117. refute [ -z "$user" ]
  118. refute [ -z "$domain" ]
  119. refute [ -z "$webproof" ]
  120. source $HESTIA/func/ip.sh
  121. USER_DATA=$HESTIA/data/users/$user
  122. local domain_ip=$(get_object_value 'web' 'DOMAIN' "$domain" '$IP')
  123. SSL=$(get_object_value 'mail' 'DOMAIN' "$domain" '$SSL')
  124. domain_ip=$(get_real_ip "$domain_ip")
  125. if [ ! -z "$webpath" ]; then
  126. assert_file_exist /var/lib/roundcube/$webpath
  127. fi
  128. if [ "$SSL" = "no" ]; then
  129. # Test HTTP
  130. run curl --location --silent --show-error --insecure --resolve "webmail.${domain}:80:${domain_ip}" "http://webmail.${domain}/${webpath}"
  131. assert_success
  132. assert_output --partial "$webproof"
  133. # Test HTTP
  134. run curl --location --silent --show-error --insecure --resolve "mail.${domain}:80:${domain_ip}" "http://mail.${domain}/${webpath}"
  135. assert_success
  136. assert_output --partial "$webproof"
  137. fi
  138. # Test HTTPS
  139. if [ "$SSL" = "yes" ]; then
  140. # Test HTTP with 301 redirect for some reasons due to 301 redirect it fails
  141. run curl --silent --show-error --insecure --resolve "webmail.${domain}:80:${domain_ip}" "http://webmail.${domain}/${webpath}"
  142. assert_success
  143. assert_output --partial "301 Moved Permanently"
  144. # Test HTTP with 301 redirect for some reasons due to 301 redirect it fails
  145. run curl --silent --show-error --insecure --resolve "mail.${domain}:80:${domain_ip}" "http://mail.${domain}/${webpath}"
  146. assert_success
  147. assert_output --partial "301 Moved Permanently"
  148. run v-list-mail-domain-ssl $user $domain
  149. assert_success
  150. run curl --location --silent --show-error --insecure --resolve "webmail.${domain}:443:${domain_ip}" "https://webmail.${domain}/${webpath}"
  151. assert_success
  152. assert_output --partial "$webproof"
  153. run curl --location --silent --show-error --insecure --resolve "mail.${domain}:443:${domain_ip}" "https://mail.${domain}/${webpath}"
  154. assert_success
  155. assert_output --partial "$webproof"
  156. fi
  157. }
  158. function validate_database(){
  159. local type=$1
  160. local database=$2
  161. local dbuser=$3
  162. local password=$4
  163. host_str=$(grep "HOST='localhost'" $HESTIA/conf/$type.conf)
  164. parse_object_kv_list "$host_str"
  165. if [ -z $PORT ]; then PORT=3306; fi
  166. refute [ -z "$HOST" ]
  167. refute [ -z "$PORT" ]
  168. refute [ -z "$database" ]
  169. refute [ -z "$dbuser" ]
  170. refute [ -z "$password" ]
  171. if [ "$type" = "mysql" ]; then
  172. # Create an connection to verify correct username / password has been set correctly
  173. tmpfile=$(mktemp /tmp/mysql.XXXXXX)
  174. echo "[client]">$tmpfile
  175. echo "host='$HOST'" >> $tmpfile
  176. echo "user='$dbuser'" >> $tmpfile
  177. echo "password='$password'" >> $tmpfile
  178. echo "port='$PORT'" >> $tmpfile
  179. chmod 600 $tmpfile
  180. sql_tmp=$(mktemp /tmp/query.XXXXXX)
  181. echo "show databases;" > $sql_tmp
  182. run mysql --defaults-file=$tmpfile < "$sql_tmp"
  183. assert_success
  184. assert_output --partial "$database"
  185. rm -f "$sql_tmp"
  186. rm -f "$tmpfile"
  187. else
  188. echo "*:*:*:$dbuser:$password" > /root/.pgpass
  189. chmod 600 /root/.pgpass
  190. run export PGPASSWORD="$password" | psql -h $HOST -U "$dbuser" -p $PORT -d "$database" --no-password -c "\l"
  191. assert_success
  192. rm /root/.pgpass
  193. fi
  194. }
  195. function check_ip_banned(){
  196. local ip=$1
  197. local chain=$2
  198. run grep "IP='$ip' CHAIN='$chain'" $HESTIA/data/firewall/banlist.conf
  199. assert_success
  200. assert_output --partial "$ip"
  201. }
  202. function check_ip_not_banned(){
  203. local ip=$1
  204. local chain=$2
  205. run grep "IP='$ip' CHAIN='$chain'" $HESTIA/data/firewall/banlist.conf
  206. assert_failure E_ARGS
  207. refute_output
  208. }
  209. #----------------------------------------------------------#
  210. # IP #
  211. #----------------------------------------------------------#
  212. @test "RDNS: Check reverse Dns validation" {
  213. # 1. PTR record for a IP should return a hostname(reverse) which in turn must resolve to the same IP addr(forward). (Full circle)
  214. # `-> not implemented in `is_ip_rdns_valid` yet and also not tested here
  215. # 2. Reject rPTR records that match generic dynamic IP pool patterns
  216. local ip="54.200.1.22"
  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.54.200.1.22.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.22.1.200.54.us-west-2.compute.amazonaws.com"
  230. run is_ip_rdns_valid "$ip"
  231. assert_failure
  232. refute_output
  233. local rdns="ec2-200-54-1-22.us-west-2.compute.amazonaws.com"
  234. run is_ip_rdns_valid "$ip"
  235. assert_failure
  236. refute_output
  237. local rdns="panel-22.mydomain.tld"
  238. run is_ip_rdns_valid "$ip"
  239. assert_success
  240. assert_output "$rdns"
  241. local rdns="mail.mydomain.tld"
  242. run is_ip_rdns_valid "$ip"
  243. assert_success
  244. assert_output "$rdns"
  245. local rdns="mydomain.tld"
  246. run is_ip_rdns_valid "$ip"
  247. assert_success
  248. assert_output "$rdns"
  249. }
  250. #----------------------------------------------------------#
  251. # User #
  252. #----------------------------------------------------------#
  253. @test "User: Add new user" {
  254. run v-add-user $user $user $user@hestiacp.com default "Super Test"
  255. assert_success
  256. refute_output
  257. }
  258. @test "User: Add new user Failed 1" {
  259. run v-add-user 'jäap' $user $user@hestiacp2.com default "Super Test"
  260. assert_failure $E_INVALID
  261. assert_output --partial 'Error: invalid user format'
  262. }
  263. @test "User: Add new user Failed 2" {
  264. run v-add-user 'ëaap' $user $user@hestiacp2.com default "Super Test"
  265. assert_failure $E_INVALID
  266. assert_output --partial 'Error: invalid user format'
  267. }
  268. @test "User: Add new user Failed 3" {
  269. run v-add-user 'jaaẞ' $user $user@hestiacp2.com default "Super Test"
  270. assert_failure $E_INVALID
  271. assert_output --partial 'Error: invalid user format'
  272. }
  273. @test "User: Add new user Failed 4" {
  274. run v-add-user '1234' $user $user@hestiacp2.com default "Super Test"
  275. assert_failure $E_INVALID
  276. assert_output --partial 'Error: invalid user format'
  277. }
  278. @test "User: Add new user Failed 5" {
  279. run v-add-user '1aap' $user $user@hestiacp2.com default "Super Test"
  280. assert_failure $E_INVALID
  281. assert_output --partial 'Error: invalid user format'
  282. }
  283. @test "User: Add new user Failed 6" {
  284. run v-add-user 'ib_Buffer' $user $user@hestiacp2.com default "Super Test"
  285. assert_failure $E_INVALID
  286. assert_output --partial 'Error: The user name'
  287. }
  288. @test "User: Add new user Failed 7" {
  289. run v-add-user 'hello.com' $user $user@hestiacp2.com default "Super Test"
  290. assert_failure $E_INVALID
  291. assert_output --partial 'Error: invalid user format'
  292. }
  293. @test "User: Add new user Success 1" {
  294. run v-add-user 'jaap01' $user $user@hestiacp2.com default "Super Test"
  295. assert_success
  296. refute_output
  297. }
  298. @test "User: Add new user Success 1 Delete" {
  299. run v-delete-user jaap01
  300. assert_success
  301. refute_output
  302. }
  303. @test "User: Add new user Success 2" {
  304. run v-add-user 'buffer' $user $user@hestiacp2.com default "Super Test"
  305. assert_success
  306. refute_output
  307. }
  308. @test "User: Add new user Success 2 Delete" {
  309. run v-delete-user buffer
  310. assert_success
  311. refute_output
  312. }
  313. @test "User: Change user password" {
  314. run v-change-user-password "$user" "$userpass2"
  315. assert_success
  316. refute_output
  317. }
  318. @test "User: Change user email" {
  319. run v-change-user-contact "$user" tester@hestiacp.com
  320. assert_success
  321. refute_output
  322. }
  323. @test "User: Change user contact invalid email " {
  324. run v-change-user-contact "$user" testerhestiacp.com
  325. assert_failure $E_INVALID
  326. assert_output --partial 'Error: invalid email format'
  327. }
  328. @test "User: Change user name" {
  329. run v-change-user-name "$user" "New name"
  330. assert_success
  331. refute_output
  332. }
  333. @test "User: Change user shell" {
  334. run v-change-user-shell $user bash
  335. assert_success
  336. refute_output
  337. run stat -c '%U' /home/$user
  338. assert_output --partial "$user"
  339. mount_file=$(systemd-escape -p --suffix=mount "/srv/jail/$user/home")
  340. assert_file_not_exist /etc/systemd/system/$mount_file
  341. }
  342. @test "User: Change user invalid shell" {
  343. run v-change-user-shell $user bashinvalid
  344. assert_failure $E_INVALID
  345. assert_output --partial 'shell bashinvalid is not valid'
  346. }
  347. @test "User: Change user nologin" {
  348. run v-change-user-shell $user nologin
  349. assert_success
  350. refute_output
  351. run stat -c '%U' /home/$user
  352. assert_output --partial 'root'
  353. mount_file=$(systemd-escape -p --suffix=mount "/srv/jail/$user/home/$user")
  354. assert_file_exist /etc/systemd/system/$mount_file
  355. }
  356. @test "User: Change user bash with bubblewrap jail" {
  357. run v-change-user-shell $user jailbash
  358. assert_success
  359. refute_output
  360. run stat -c '%U' /home/$user
  361. assert_output --partial "$user"
  362. mount_file=$(systemd-escape -p --suffix=mount "/srv/jail/$user/home")
  363. assert_file_not_exist /etc/systemd/system/$mount_file
  364. }
  365. @test "User: Change user default ns" {
  366. run v-change-user-ns $user ns0.com ns1.com ns2.com ns3.com
  367. assert_success
  368. refute_output
  369. run v-list-user-ns "$user" plain
  370. assert_success
  371. assert_output --partial 'ns0.com'
  372. }
  373. @test "User: Change user language" {
  374. run v-change-user-language $user "nl"
  375. assert_success
  376. refute_output
  377. }
  378. @test "User: Change user language (Does not exist)" {
  379. run v-change-user-language $user "aa"
  380. assert_failure $E_NOTEXIST
  381. }
  382. @test "User: Change user sort order" {
  383. run v-change-user-sort-order $user "name"
  384. assert_success
  385. refute_output
  386. }
  387. @test "User: Change user theme" {
  388. run v-change-user-theme $user "flat"
  389. assert_success
  390. refute_output
  391. }
  392. @test "User: Change user theme (Does not exist)" {
  393. run v-change-user-theme $user "aa"
  394. assert_failure $E_NOTEXIST
  395. }
  396. @test "User: Change user login ip" {
  397. run v-change-user-config-value $user "LOGIN_USE_IPLIST" "1.2.3.4,1.2.3.5"
  398. assert_success
  399. refute_output
  400. }
  401. @test "User: Change user login ip (Failed)" {
  402. run v-change-user-config-value $user "LOGIN_USE_IPLIST" "'; echo 'jaap'; echo '"
  403. assert_failure $E_INVALID
  404. }
  405. @test "User: Add user notification" {
  406. run v-add-user-notification $user "Test message" "Message"
  407. assert_success
  408. refute_output
  409. }
  410. @test "User: Acknowledge user notification" {
  411. run v-acknowledge-user-notification $user 1
  412. assert_success
  413. refute_output
  414. }
  415. @test "User: List user notification" {
  416. run v-list-user-notifications $user csv
  417. assert_success
  418. assert_output --partial "1,\"Test message\",\"Message\",yes"
  419. }
  420. @test "User: Delete user notification" {
  421. run v-delete-user-notification $user 1
  422. assert_success
  423. refute_output
  424. }
  425. @test "User: Get User salt ipv4" {
  426. run v-get-user-salt $user 192.168.2.10
  427. assert_success
  428. }
  429. @test "User: Get User salt ipv4 invalid" {
  430. run v-get-user-salt $user 192.168.992.10
  431. assert_failure $E_INVALID
  432. }
  433. @test "User: Get User salt ipv6" {
  434. run v-get-user-salt $user "21DA:D3:0:2F3B:2AA:FF:FE28:9C5A"
  435. assert_success
  436. }
  437. @test "User: Get User salt ipv6 not exists" {
  438. run v-get-user-salt "notexists" "21DA:D3:0:2F3B:2AA:FF:FE28:9C5B"
  439. assert_failure $E_PASSWORD
  440. }
  441. @test "User: Get User salt ipv6 invalid" {
  442. run v-get-user-salt "$user" "21DA:D3:0:2F3B:ZZZ:FF:FE28:9C5B"
  443. assert_failure $E_INVALID
  444. }
  445. @test "User: Check user password" {
  446. run v-check-user-password $user "$userpass2" 192.168.2.10 'no'
  447. assert_success
  448. }
  449. @test "User: Check user password Incorrect password" {
  450. run v-check-user-password $user "$userpass1" 192.168.2.10 'no'
  451. assert_failure $E_PASSWORD
  452. }
  453. @test "User: Check user hash ipv4" {
  454. hash=$(v-check-user-password $user "$userpass2" 192.168.2.10 'yes');
  455. run v-check-user-hash $user $hash 192.168.2.10
  456. assert_success
  457. }
  458. @test "User: Check user hash ipv6" {
  459. hash=$(v-check-user-password $user "$userpass2" 21DA:D3:0:2F3B:2AA:FF:FE28:9C5A 'yes');
  460. run v-check-user-hash $user $hash 21DA:D3:0:2F3B:2AA:FF:FE28:9C5A
  461. assert_success
  462. }
  463. @test "User: Check user hash ipv6 incorrect" {
  464. run v-check-user-hash $user 'jafawefaweijawe' 21DA:D3:0:2F3B:2AA:FF:FE28:9C5A
  465. assert_failure $E_PASSWORD
  466. }
  467. #----------------------------------------------------------#
  468. # Cron #
  469. #----------------------------------------------------------#
  470. @test "Cron: Add cron job" {
  471. run v-add-cron-job $user 1 1 1 1 1 echo
  472. assert_success
  473. refute_output
  474. }
  475. @test "Cron: Suspend cron job" {
  476. run v-suspend-cron-job $user 1
  477. assert_success
  478. refute_output
  479. }
  480. @test "Cron: Unsuspend cron job" {
  481. run v-unsuspend-cron-job $user 1
  482. assert_success
  483. refute_output
  484. }
  485. @test "Cron: Delete cron job" {
  486. run v-delete-cron-job $user 1
  487. assert_success
  488. refute_output
  489. }
  490. @test "Cron: Add cron job (duplicate)" {
  491. run v-add-cron-job $user 1 1 1 1 1 echo 1
  492. assert_success
  493. refute_output
  494. run v-add-cron-job $user 1 1 1 1 1 echo 1
  495. assert_failure $E_EXISTS
  496. assert_output --partial 'JOB=1 already exists'
  497. }
  498. @test "Cron: Second cron job" {
  499. run v-add-cron-job $user 2 2 2 2 2 echo 2
  500. assert_success
  501. refute_output
  502. }
  503. @test "Cron: Two cron jobs must be listed" {
  504. run v-list-cron-jobs $user csv
  505. assert_success
  506. assert_line --partial '1,1,1,1,1,"echo",no'
  507. assert_line --partial '2,2,2,2,2,"echo",no'
  508. }
  509. @test "Cron: rebuild" {
  510. run v-rebuild-cron-jobs $user
  511. assert_success
  512. refute_output
  513. }
  514. #----------------------------------------------------------#
  515. # IP #
  516. #----------------------------------------------------------#
  517. @test "Ip: Add new ip on first interface" {
  518. interface=$(v-list-sys-interfaces plain | head -n 1)
  519. run ip link show dev $interface
  520. assert_success
  521. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  522. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  523. # Save initial state
  524. echo "interface=${interface}" >> /tmp/hestia-test-env.sh
  525. [ -f "$a2_rpaf" ] && file_hash1=$(cat $a2_rpaf |md5sum |cut -d" " -f1) && echo "a2_rpaf_hash='${file_hash1}'" >> /tmp/hestia-test-env.sh
  526. [ -f "$a2_remoteip" ] && file_hash2=$(cat $a2_remoteip |md5sum |cut -d" " -f1) && echo "a2_remoteip_hash='${file_hash2}'" >> /tmp/hestia-test-env.sh
  527. local ip="198.18.0.12"
  528. run v-add-sys-ip $ip 255.255.255.255 $interface $user
  529. assert_success
  530. refute_output
  531. assert_file_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  532. assert_file_exist $HESTIA/data/ips/$ip
  533. assert_file_contains $HESTIA/data/ips/$ip "OWNER='$user'"
  534. assert_file_contains $HESTIA/data/ips/$ip "INTERFACE='$interface'"
  535. if [ -n "$PROXY_SYSTEM" ]; then
  536. assert_file_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  537. [ -f "$a2_rpaf" ] && assert_file_contains "$a2_rpaf" "RPAFproxy_ips.*$ip\b"
  538. [ -f "$a2_remoteip" ] && assert_file_contains "$a2_remoteip" "RemoteIPInternalProxy $ip\$"
  539. fi
  540. }
  541. @test "Ip: [Ubuntu] Netplan file updated" {
  542. # Skip if Debian
  543. if [ $(lsb_release -s -i) != "Ubuntu" ]; then
  544. skip
  545. fi
  546. # Test will fail if systemd (For example Proxmox) is used for setting ip addresses. How ever there is no "decent" way to check if Netplan is used except via the method used in v-add-sys-ip and there for breaking the reason to test this. How ever if the test used in v-add-sys-ip fails it still should check if it exists!
  547. assert_file_exist /etc/netplan/60-hestia.yaml
  548. # also check if file contains the newly added ip
  549. assert_file_contains /etc/netplan/60-hestia.yaml "$ip"
  550. }
  551. @test "Ip: [Debian] Netplan file updated" {
  552. # Skip with netplan
  553. if [ $(lsb_release -s -i) = "Ubuntu" ]; then
  554. skip
  555. fi
  556. assert_file_exist /etc/network/interfaces
  557. assert_file_contains /etc/network/interfaces "$ip"
  558. }
  559. @test "Ip: Add ip (duplicate)" {
  560. run v-add-sys-ip 198.18.0.12 255.255.255.255 $interface $user
  561. assert_failure $E_EXISTS
  562. }
  563. @test "Ip: Add extra ip" {
  564. local ip="198.18.0.121"
  565. run v-add-sys-ip $ip 255.255.255.255 $interface $user
  566. assert_success
  567. refute_output
  568. assert_file_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  569. assert_file_exist $HESTIA/data/ips/$ip
  570. assert_file_contains $HESTIA/data/ips/$ip "OWNER='$user'"
  571. assert_file_contains $HESTIA/data/ips/$ip "INTERFACE='$interface'"
  572. if [ -n "$PROXY_SYSTEM" ]; then
  573. assert_file_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  574. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  575. [ -f "$a2_rpaf" ] && assert_file_contains "$a2_rpaf" "RPAFproxy_ips.*$ip\b"
  576. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  577. [ -f "$a2_remoteip" ] && assert_file_contains "$a2_remoteip" "RemoteIPInternalProxy $ip\$"
  578. fi
  579. }
  580. @test "Ip: Delete ip 198.18.0.12" {
  581. local ip="198.18.0.12"
  582. run v-delete-sys-ip $ip
  583. assert_success
  584. refute_output
  585. assert_file_not_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  586. assert_file_not_exist $HESTIA/data/ips/$ip
  587. }
  588. @test "Ip: [Ubuntu] Netplan file changed" {
  589. # Skip if Debian
  590. if [ $(lsb_release -s -i) != "Ubuntu" ]; then
  591. skip
  592. fi
  593. ip="198.18.0.121"
  594. assert_file_exist /etc/netplan/60-hestia.yaml
  595. assert_file_contains /etc/netplan/60-hestia.yaml "$ip"
  596. }
  597. @test "Ip: Delete ip 198.18.0.121" {
  598. ip="198.18.0.121"
  599. run v-delete-sys-ip $ip
  600. assert_success
  601. refute_output
  602. assert_file_not_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  603. assert_file_not_exist $HESTIA/data/ips/$ip
  604. if [ -n "$PROXY_SYSTEM" ]; then
  605. assert_file_not_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  606. fi
  607. # remoteip and rpaf config hashes must match the initial one
  608. if [ ! -z "$a2_rpaf_hash" ]; then
  609. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  610. file_hash=$(cat $a2_rpaf |md5sum |cut -d" " -f1)
  611. assert_equal "$file_hash" "$a2_rpaf_hash"
  612. fi
  613. if [ ! -z "$a2_remoteip_hash" ]; then
  614. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  615. file_hash=$(cat $a2_remoteip |md5sum |cut -d" " -f1)
  616. assert_equal "$file_hash" "$a2_remoteip_hash"
  617. fi
  618. }
  619. @test "Ip: Add IP for rest of the test" {
  620. local ip="198.18.0.125"
  621. run v-add-sys-ip $ip 255.255.255.255 $interface $user
  622. assert_success
  623. refute_output
  624. assert_file_exist /etc/$WEB_SYSTEM/conf.d/$ip.conf
  625. assert_file_exist $HESTIA/data/ips/$ip
  626. assert_file_contains $HESTIA/data/ips/$ip "OWNER='$user'"
  627. assert_file_contains $HESTIA/data/ips/$ip "INTERFACE='$interface'"
  628. if [ -n "$PROXY_SYSTEM" ]; then
  629. assert_file_exist /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  630. local a2_rpaf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
  631. [ -f "$a2_rpaf" ] && assert_file_contains "$a2_rpaf" "RPAFproxy_ips.*$ip\b"
  632. local a2_remoteip="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
  633. [ -f "$a2_remoteip" ] && assert_file_contains "$a2_remoteip" "RemoteIPInternalProxy $ip\$"
  634. fi
  635. }
  636. #----------------------------------------------------------#
  637. # WEB #
  638. #----------------------------------------------------------#
  639. @test "WEB: Add web domain" {
  640. run v-add-web-domain $user $domain 198.18.0.125
  641. assert_success
  642. refute_output
  643. echo -e "<?php\necho 'Hestia Test:'.(4*3);" > $HOMEDIR/$user/web/$domain/public_html/php-test.php
  644. validate_web_domain $user $domain 'Hestia Test:12' 'php-test.php'
  645. rm $HOMEDIR/$user/web/$domain/public_html/php-test.php
  646. }
  647. @test "WEB: Add web domain (duplicate)" {
  648. run v-add-web-domain $user $domain 198.18.0.125
  649. assert_failure $E_EXISTS
  650. }
  651. @test "WEB: Add web domain alias" {
  652. run v-add-web-domain-alias $user $domain v3.$domain
  653. assert_success
  654. refute_output
  655. }
  656. @test "WEB: Add web domain alias (duplicate)" {
  657. run v-add-web-domain-alias $user $domain v3.$domain
  658. assert_failure $E_EXISTS
  659. }
  660. @test "WEB: Add web domain wildcard alias" {
  661. run v-add-web-domain-alias $user $domain "*.$domain"
  662. assert_success
  663. refute_output
  664. }
  665. @test "WEB: Delete web domain wildcard alias" {
  666. run v-delete-web-domain-alias $user $domain "*.$domain"
  667. assert_success
  668. refute_output
  669. }
  670. @test "WEB: Add web domain stats" {
  671. run v-add-web-domain-stats $user $domain awstats
  672. assert_success
  673. refute_output
  674. }
  675. @test "WEB: Add web domain stats user" {
  676. skip
  677. run v-add-web-domain-stats-user $user $domain test m3g4p4ssw0rd
  678. assert_success
  679. refute_output
  680. }
  681. @test "WEB: Suspend web domain" {
  682. run v-suspend-web-domain $user $domain
  683. assert_success
  684. refute_output
  685. echo -e "<?php\necho 'Hestia Test:'.(4*3);" > $HOMEDIR/$user/web/$domain/public_html/php-test.php
  686. validate_web_domain $user $domain 'This site is currently suspended'
  687. validate_web_domain $user $domain 'This site is currently suspended' 'php-test.php'
  688. rm $HOMEDIR/$user/web/$domain/public_html/php-test.php
  689. }
  690. @test "WEB: Unsuspend web domain" {
  691. run v-unsuspend-web-domain $user $domain
  692. assert_success
  693. refute_output
  694. echo -e "<?php\necho 'Hestia Test:'.(4*3);" > $HOMEDIR/$user/web/$domain/public_html/php-test.php
  695. validate_web_domain $user $domain 'Hestia Test:12' 'php-test.php'
  696. rm $HOMEDIR/$user/web/$domain/public_html/php-test.php
  697. }
  698. @test "WEB: Add redirect to www.domain.com" {
  699. run v-add-web-domain-redirect $user $domain www.$domain 301
  700. assert_success
  701. refute_output
  702. run validate_headers_domain $user $domain "301"
  703. }
  704. @test "WEB: Delete redirect to www.domain.com" {
  705. run v-delete-web-domain-redirect $user $domain
  706. assert_success
  707. refute_output
  708. }
  709. @test "WEB: Enable Fast CGI Cache" {
  710. if [ "$WEB_SYSTEM" != "nginx" ]; then
  711. skip "FastCGI cache is not supported"
  712. fi
  713. run v-add-fastcgi-cache $user $domain '1m' yes
  714. assert_success
  715. refute_output
  716. echo -e "<?php\necho 'Hestia Test:'.(4*3);" > $HOMEDIR/$user/web/$domain/public_html/php-test.php
  717. run validate_headers_domain $user $domain "Miss"
  718. run validate_headers_domain $user $domain "Hit"
  719. rm $HOMEDIR/$user/web/$domain/public_html/php-test.php
  720. }
  721. @test "WEB: Disable Fast CGI Cache" {
  722. if [ "$WEB_SYSTEM" != "nginx" ]; then
  723. skip "FastCGI cache is not supported"
  724. fi
  725. run v-delete-fastcgi-cache $user $domain yes
  726. assert_success
  727. refute_output
  728. }
  729. @test "WEB: Generate Self signed certificate" {
  730. ssl=$(v-generate-ssl-cert "$domain" "info@$domain" US CA "Orange County" HestiaCP IT "mail.$domain" | tail -n1 | awk '{print $2}')
  731. echo $ssl;
  732. mv $ssl/$domain.crt /tmp/$domain.crt
  733. mv $ssl/$domain.key /tmp/$domain.key
  734. }
  735. @test "WEB: Add ssl" {
  736. # Use self signed certificates during last test
  737. run v-add-web-domain-ssl $user $domain /tmp
  738. assert_success
  739. refute_output
  740. }
  741. @test "WEB: Rebuild web domain" {
  742. run v-rebuild-web-domains $user
  743. assert_success
  744. refute_output
  745. }
  746. @test "WEB: Use quick install app on web domain" {
  747. run v-quick-install-app install $user $domain Laravel
  748. assert_success
  749. refute_output
  750. }
  751. #----------------------------------------------------------#
  752. # IDN #
  753. #----------------------------------------------------------#
  754. @test "WEB: Add IDN domain UTF idn-tést.eu" {
  755. run v-add-web-domain $user idn-tést.eu 198.18.0.125
  756. assert_success
  757. refute_output
  758. assert_file_exist /home/$user/web/idn-tést.eu/public_html/index.html
  759. }
  760. @test "WEB: Add IDN domain ASCII idn-tést.eu" {
  761. # Expected to fail due to utf exists
  762. run v-add-web-domain $user "xn--idn-tst-fya.eu" 198.18.0.125
  763. assert_failure $E_EXISTS
  764. }
  765. @test "WEB: Generate Self signed certificate ASCII idn-tést.eu" {
  766. run v-generate-ssl-cert "xn--idn-tst-fya.eu" "info@xn--idn-tst-fya.eu" US CA "Orange County" HestiaCP IT "mail.xn--idn-tst-fya.eu"
  767. assert_success
  768. }
  769. @test "WEB: Delete IDN domain idn-tést.eu" {
  770. run v-delete-web-domain $user idn-tést.eu
  771. assert_success
  772. refute_output
  773. }
  774. @test "WEB: Add IDN domain UTF bløst.рф" {
  775. run v-add-web-domain $user bløst.рф 198.18.0.125
  776. assert_success
  777. refute_output
  778. }
  779. @test "WEB: Generate Self signed certificate ASCII bløst.рф" {
  780. run v-generate-ssl-cert "xn--blst-hra.xn--p1ai" "info@xn--blst-hra.xn--p1ai" US CA "Orange County" HestiaCP IT "mail.xn--blst-hra.xn--p1ai"
  781. assert_success
  782. }
  783. @test "WEB: Delete IDN domain bløst.рф" {
  784. run v-delete-web-domain $user bløst.рф
  785. assert_success
  786. refute_output
  787. }
  788. #----------------------------------------------------------#
  789. # MULTIPHP #
  790. #----------------------------------------------------------#
  791. @test "Multiphp: Default php Backend version" {
  792. def_phpver=$(multiphp_default_version)
  793. multi_domain="multiphp.${domain}"
  794. run v-add-web-domain $user $multi_domain 198.18.0.125
  795. assert_success
  796. refute_output
  797. echo -e "<?php\necho PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  798. validate_web_domain $user $multi_domain "$def_phpver" 'php-test.php'
  799. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  800. }
  801. @test "Multiphp: Change backend version - PHP v5.6" {
  802. test_phpver='5.6'
  803. multi_domain="multiphp.${domain}"
  804. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  805. skip "PHP ${test_phpver} not installed"
  806. fi
  807. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-5_6' 'yes'
  808. assert_success
  809. refute_output
  810. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  811. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  812. # A single php-fpm pool config file must be present
  813. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  814. assert_equal "$num_fpm_config_files" '1'
  815. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  816. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  817. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  818. }
  819. @test "Multiphp: Change backend version - PHP v7.0" {
  820. test_phpver='7.0'
  821. multi_domain="multiphp.${domain}"
  822. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  823. skip "PHP ${test_phpver} not installed"
  824. fi
  825. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-7_0' 'yes'
  826. assert_success
  827. refute_output
  828. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  829. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  830. # A single php-fpm pool config file must be present
  831. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  832. assert_equal "$num_fpm_config_files" '1'
  833. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  834. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  835. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  836. }
  837. @test "Multiphp: Change backend version - PHP v7.1" {
  838. test_phpver='7.1'
  839. multi_domain="multiphp.${domain}"
  840. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  841. skip "PHP ${test_phpver} not installed"
  842. fi
  843. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-7_1' 'yes'
  844. assert_success
  845. refute_output
  846. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  847. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  848. # A single php-fpm pool config file must be present
  849. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  850. assert_equal "$num_fpm_config_files" '1'
  851. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  852. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  853. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  854. }
  855. @test "Multiphp: Change backend version - PHP v7.2" {
  856. test_phpver='7.2'
  857. multi_domain="multiphp.${domain}"
  858. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  859. skip "PHP ${test_phpver} not installed"
  860. fi
  861. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-7_2' 'yes'
  862. assert_success
  863. refute_output
  864. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  865. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  866. # A single php-fpm pool config file must be present
  867. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  868. assert_equal "$num_fpm_config_files" '1'
  869. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  870. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  871. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  872. }
  873. @test "Multiphp: Change backend version - PHP v7.3" {
  874. test_phpver='7.3'
  875. multi_domain="multiphp.${domain}"
  876. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  877. skip "PHP ${test_phpver} not installed"
  878. fi
  879. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-7_3' 'yes'
  880. assert_success
  881. refute_output
  882. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  883. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  884. # A single php-fpm pool config file must be present
  885. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  886. assert_equal "$num_fpm_config_files" '1'
  887. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  888. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  889. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  890. }
  891. @test "Multiphp: Change backend version - PHP v7.4" {
  892. test_phpver='7.4'
  893. multi_domain="multiphp.${domain}"
  894. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  895. skip "PHP ${test_phpver} not installed"
  896. fi
  897. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-7_4' 'yes'
  898. assert_success
  899. refute_output
  900. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  901. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  902. # A single php-fpm pool config file must be present
  903. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  904. assert_equal "$num_fpm_config_files" '1'
  905. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  906. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  907. rm "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  908. }
  909. @test "Multiphp: Change backend version - PHP v8.0" {
  910. test_phpver='8.0'
  911. multi_domain="multiphp.${domain}"
  912. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  913. skip "PHP ${test_phpver} not installed"
  914. fi
  915. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-8_0' 'yes'
  916. assert_success
  917. refute_output
  918. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  919. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  920. # A single php-fpm pool config file must be present
  921. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  922. assert_equal "$num_fpm_config_files" '1'
  923. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  924. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  925. rm $HOMEDIR/$user/web/$multi_domain/public_html/php-test.php
  926. }
  927. @test "Multiphp: Change backend version - PHP v8.1" {
  928. test_phpver='8.1'
  929. multi_domain="multiphp.${domain}"
  930. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  931. skip "PHP ${test_phpver} not installed"
  932. fi
  933. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-8_1' 'yes'
  934. assert_success
  935. refute_output
  936. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  937. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  938. # A single php-fpm pool config file must be present
  939. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  940. assert_equal "$num_fpm_config_files" '1'
  941. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  942. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  943. rm $HOMEDIR/$user/web/$multi_domain/public_html/php-test.php
  944. }
  945. @test "Multiphp: Change backend version - PHP v8.2" {
  946. test_phpver='8.2'
  947. multi_domain="multiphp.${domain}"
  948. if [ ! -d "/etc/php/${test_phpver}/fpm/pool.d/" ]; then
  949. skip "PHP ${test_phpver} not installed"
  950. fi
  951. run v-change-web-domain-backend-tpl $user $multi_domain 'PHP-8_2' 'yes'
  952. assert_success
  953. refute_output
  954. # Changing web backend will create a php-fpm pool config in the corresponding php folder
  955. assert_file_exist "/etc/php/${test_phpver}/fpm/pool.d/${multi_domain}.conf"
  956. # A single php-fpm pool config file must be present
  957. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  958. assert_equal "$num_fpm_config_files" '1'
  959. echo -e "<?php\necho 'hestia-multiphptest:'.PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION;" > "$HOMEDIR/$user/web/$multi_domain/public_html/php-test.php"
  960. validate_web_domain $user $multi_domain "hestia-multiphptest:$test_phpver" 'php-test.php'
  961. rm $HOMEDIR/$user/web/$multi_domain/public_html/php-test.php
  962. }
  963. @test "Multiphp: Cleanup" {
  964. multi_domain="multiphp.${domain}"
  965. run v-delete-web-domain $user $multi_domain 'yes'
  966. assert_success
  967. refute_output
  968. # No php-fpm pool config file must be present
  969. num_fpm_config_files="$(find -L /etc/php/ -name "${multi_domain}.conf" | wc -l)"
  970. assert_equal "$num_fpm_config_files" '0'
  971. }
  972. #----------------------------------------------------------#
  973. # CUSTOM DOCROOT #
  974. #----------------------------------------------------------#
  975. @test "Docroot: Self Subfolder" {
  976. docroot1_domain="docroot1.${domain}"
  977. run v-add-web-domain $user $docroot1_domain 198.18.0.125
  978. assert_success
  979. refute_output
  980. run v-add-fs-directory $user "$HOMEDIR/$user/web/$docroot1_domain/public_html/public/"
  981. assert_success
  982. refute_output
  983. run v-change-web-domain-docroot $user "$docroot1_domain" "$docroot1_domain" "/public"
  984. assert_success
  985. refute_output
  986. echo -e '<?php\necho "self-sub-".$_SERVER["HTTP_HOST"];' > "$HOMEDIR/$user/web/$docroot1_domain/public_html/public/php-test.php"
  987. validate_web_domain $user $docroot1_domain "self-sub-${docroot1_domain}" 'php-test.php'
  988. rm "$HOMEDIR/$user/web/$docroot1_domain/public_html/public/php-test.php"
  989. }
  990. @test "Docroot: Other domain subfolder" {
  991. docroot1_domain="docroot1.${domain}"
  992. docroot2_domain="docroot2.${domain}"
  993. run v-add-web-domain $user $docroot2_domain 198.18.0.125
  994. assert_success
  995. refute_output
  996. run v-add-fs-directory $user "$HOMEDIR/$user/web/$docroot2_domain/public_html/public/"
  997. assert_success
  998. refute_output
  999. run v-change-web-domain-docroot $user "$docroot1_domain" "$docroot2_domain" "/public"
  1000. assert_success
  1001. refute_output
  1002. echo -e '<?php\necho "doc2-sub-".$_SERVER["HTTP_HOST"];' > "$HOMEDIR/$user/web/$docroot2_domain/public_html/public/php-test.php"
  1003. validate_web_domain $user $docroot1_domain "doc2-sub-${docroot1_domain}" 'php-test.php'
  1004. rm "$HOMEDIR/$user/web/$docroot2_domain/public_html/public/php-test.php"
  1005. }
  1006. @test "Docroot: Other domain root folder" {
  1007. docroot1_domain="docroot1.${domain}"
  1008. docroot2_domain="docroot2.${domain}"
  1009. run v-change-web-domain-docroot $user "$docroot1_domain" "$docroot2_domain"
  1010. assert_success
  1011. refute_output
  1012. echo -e '<?php\necho "doc2-root-".$_SERVER["HTTP_HOST"];' > "$HOMEDIR/$user/web/$docroot2_domain/public_html/php-test.php"
  1013. validate_web_domain $user $docroot1_domain "doc2-root-${docroot1_domain}" 'php-test.php'
  1014. rm "$HOMEDIR/$user/web/$docroot2_domain/public_html/php-test.php"
  1015. }
  1016. @test "Docroot: Reset" {
  1017. docroot1_domain="docroot1.${domain}"
  1018. run v-change-web-domain-docroot $user "$docroot1_domain" "default"
  1019. assert_success
  1020. refute_output
  1021. echo -e '<?php\necho "doc1-root-".$_SERVER["HTTP_HOST"];' > "$HOMEDIR/$user/web/$docroot1_domain/public_html/php-test.php"
  1022. validate_web_domain $user $docroot1_domain "doc1-root-${docroot1_domain}" 'php-test.php'
  1023. rm "$HOMEDIR/$user/web/$docroot1_domain/public_html/php-test.php"
  1024. }
  1025. @test "Docroot: Cleanup" {
  1026. docroot1_domain="docroot1.${domain}"
  1027. docroot2_domain="docroot2.${domain}"
  1028. run v-delete-web-domain $user $docroot1_domain
  1029. assert_success
  1030. refute_output
  1031. run v-delete-web-domain $user $docroot2_domain
  1032. assert_success
  1033. refute_output
  1034. }
  1035. #----------------------------------------------------------#
  1036. # DNS #
  1037. #----------------------------------------------------------#
  1038. @test "DNS: Add domain" {
  1039. run v-add-dns-domain $user $domain 198.18.0.125
  1040. assert_success
  1041. refute_output
  1042. }
  1043. @test "DNS: Add domain (duplicate)" {
  1044. run v-add-dns-domain $user $domain 198.18.0.125
  1045. assert_failure $E_EXISTS
  1046. }
  1047. @test "DNS: Add domain record" {
  1048. run v-add-dns-record $user $domain test A 198.18.0.125 '' 30
  1049. assert_success
  1050. refute_output
  1051. }
  1052. @test "DNS: Add domain record *.domain.com" {
  1053. run v-add-dns-record $user $domain '*' A 198.18.0.125 '' 40
  1054. assert_success
  1055. refute_output
  1056. }
  1057. @test "DNS: Add domain record *.domain.com with ID 0" {
  1058. run v-add-dns-record $user $domain '*' A 198.18.0.125 '' 0
  1059. assert_failure $E_INVALID
  1060. }
  1061. @test "DNS: Change DNS record" {
  1062. run v-change-dns-record $user $domain 30 test A 198.18.0.125 "" "" 1500
  1063. assert_success
  1064. refute_output
  1065. }
  1066. @test "DNS: Change DNS record (no update)" {
  1067. run v-change-dns-record $user $domain 30 test A 198.18.0.125 "" "" 1500
  1068. assert_failure $E_EXSIST
  1069. }
  1070. @test "DNS: Change DNS record id" {
  1071. run v-change-dns-record-id $user $domain 30 31
  1072. assert_success
  1073. refute_output
  1074. # Change back
  1075. run v-change-dns-record-id $user $domain 31 30
  1076. }
  1077. @test "DNS: Change DNS record id (no update)" {
  1078. run v-change-dns-record-id $user $domain 30 30
  1079. assert_failure $E_EXSIST
  1080. }
  1081. @test "DNS: Delete domain record" {
  1082. run v-delete-dns-record $user $domain 30
  1083. assert_success
  1084. refute_output
  1085. }
  1086. @test "DNS: Delete missing domain record" {
  1087. run v-delete-dns-record $user $domain 30
  1088. assert_failure $E_NOTEXIST
  1089. }
  1090. @test "DNS: Change domain expire date" {
  1091. run v-change-dns-domain-exp $user $domain 2020-01-01
  1092. assert_success
  1093. refute_output
  1094. }
  1095. @test "DNS: Add domain record MX" {
  1096. run v-add-dns-record $user $domain '@' MX mx.hestiacp.com '' 50
  1097. assert_success
  1098. refute_output
  1099. assert_file_contains "$HOMEDIR/$user/conf/dns/${domain}.db" "mx.hestiacp.com."
  1100. run v-change-dns-record $user $domain 50 '@' MX mx.hestia.com
  1101. assert_success
  1102. refute_output
  1103. assert_file_contains "$HOMEDIR/$user/conf/dns/${domain}.db" "mx.hestia.com."
  1104. run v-delete-dns-record $user $domain 50
  1105. assert_success
  1106. refute_output
  1107. }
  1108. @test "DNS: Add domain record NS" {
  1109. run v-delete-dns-record $user $domain 50
  1110. run v-add-dns-record $user $domain '@' NS mx.hestiacp.com '' 50
  1111. assert_success
  1112. refute_output
  1113. assert_file_contains "$HOMEDIR/$user/conf/dns/${domain}.db" "mx.hestiacp.com."
  1114. run v-change-dns-record $user $domain 50 '@' NS mx.hestia.com
  1115. assert_success
  1116. refute_output
  1117. assert_file_contains "$HOMEDIR/$user/conf/dns/${domain}.db" "mx.hestia.com."
  1118. run v-delete-dns-record $user $domain 50
  1119. assert_success
  1120. refute_output
  1121. }
  1122. @test "DNS: Add domain record SRV" {
  1123. run v-delete-dns-record $user $domain 50
  1124. run v-add-dns-record $user $domain '_test_domain' SRV '10 5 443 mx.hestiacp.com' '' 50
  1125. assert_success
  1126. refute_output
  1127. assert_file_contains "$HOMEDIR/$user/conf/dns/${domain}.db" "mx.hestiacp.com."
  1128. run v-change-dns-record $user $domain 50 '_test.domain' SRV '10 5 443 mx.hestia.com'
  1129. assert_success
  1130. refute_output
  1131. assert_file_contains "$HOMEDIR/$user/conf/dns/${domain}.db" "mx.hestia.com."
  1132. run v-delete-dns-record $user $domain 50
  1133. assert_success
  1134. refute_output
  1135. }
  1136. @test "DNS: Add domain record CNAME" {
  1137. run v-delete-dns-record $user $domain 50
  1138. run v-add-dns-record $user $domain 'mail' CNAME mx.hestiacp.com '' 50
  1139. assert_success
  1140. refute_output
  1141. assert_file_contains "$HOMEDIR/$user/conf/dns/${domain}.db" "mx.hestiacp.com."
  1142. run v-change-dns-record $user $domain 50 'mail' CNAME mx.hestia.com
  1143. assert_success
  1144. refute_output
  1145. assert_file_contains "$HOMEDIR/$user/conf/dns/${domain}.db" "mx.hestia.com."
  1146. run v-delete-dns-record $user $domain 50
  1147. assert_success
  1148. refute_output
  1149. }
  1150. @test "DNS: Check txt dns records type1" {
  1151. [ -z "$DNS_SYSTEM" ] && skip
  1152. run v-delete-dns-record $user $domain 50
  1153. record1_in='v=DMARC1; p=quarantine; pct=100'
  1154. record2_in='v=DMARC1; p=quarantine; pct=90'
  1155. record1_out='"v=DMARC1; p=quarantine; pct=100"'
  1156. record2_in='"v=DMARC1; p=quarantine; pct=90"'
  1157. # Test Create
  1158. run v-add-dns-record $user $domain 'test-long-txt' 'TXT' "$record1_in" '' 50
  1159. assert_success
  1160. refute_output
  1161. assert_file_contains "$HOMEDIR/$user/conf/dns/${domain}.db" "$record1_out"
  1162. # Test Edit
  1163. run v-change-dns-record $user $domain 50 'test-long-txt' 'TXT' "$record2_in"
  1164. assert_success
  1165. refute_output
  1166. assert_file_contains "$HOMEDIR/$user/conf/dns/${domain}.db" "$record2_out"
  1167. # Test Cleanup
  1168. run v-delete-dns-record $user $domain 50
  1169. assert_success
  1170. refute_output
  1171. }
  1172. @test "DNS: Check txt dns records type2" {
  1173. [ -z "$DNS_SYSTEM" ] && skip
  1174. run v-delete-dns-record $user $domain 50
  1175. record3_in='k=rsa; p=MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4+VEVsoTbl6tYLJlhozqAGju3IgpSVdBAS5LMyzpHP8/L0/PlyVRJnm2xECjVk3DRqCmelyIvmraw1VtFz2aH6DRlDhHsZghj1DmGhwN+7NkwIb4hEvmytMVAz1WyiLH6Rm6Iemm/ZCt1RhrAMUYLxHA9mJgky76YCcf8/cX35xC+1vd4a5U6YofAZeVP9DBvVgQ8ung4gVrOrQrXkU8QfVNAoXz5pfJo74GB7woIBFhZXsU6SKho7KnzT5inVCIOtWp7L5hyEnbySWQPHT2vAMCCAe2AY/Vv0N3HW14o8P3b4A6OU920wFB2kA7pkQNzO5OwH+HSttwG0PaIiQxYQIDAQAB'
  1176. record3_out='"k=rsa; p=MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4+VEVsoTbl6tYLJlhozqAGju3IgpSVdBAS5LMyzpHP8/L0/PlyVRJnm2xECjVk3DRqCmelyIvmraw1VtFz2aH6DRlDhHsZghj1DmGhwN+7NkwIb4hEvmytMVAz1WyiLH6Rm6Iemm/ZCt1RhrAMUYLxHA9mJgky76YCcf8/cX35xC+1vd4a5U6YofAZeVP9DBvVgQ8ung4g""VrOrQrXkU8QfVNAoXz5pfJo74GB7woIBFhZXsU6SKho7KnzT5inVCIOtWp7L5hyEnbySWQPHT2vAMCCAe2AY/Vv0N3HW14o8P3b4A6OU920wFB2kA7pkQNzO5OwH+HSttwG0PaIiQxYQIDAQAB"'
  1177. record4_in='k=rsa; p=MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4+VEVsoTbl6tYLJlhozqAGju3IgpSVdBAS5LMyzpHP8/L0/PlyVRJnm2xECjVk3DRqCmelyIvmraw1VtFz2aH6DRlDhHsZghj1DmGhwN+7NkwIb4hEvmytMVAz1WyiLH6Rm6Iemm/ZCt1RhrAMUYLxHA9mJgky76YCcf8/cX35xC+1vd4a5U6YofAZeVP9DBvVgQ8ung4gVrOrQrXkU8QfVNAoXz5pfJo74GB7woIBFhZXsU6SKho7KnzT5inVCIOtWp7L5hyEnbySWQPHT2vAMCCAe2AY/Vv0N3HW14o8P3b4A6OU920wFB2kA7pkQNzO5OwH+HSttwG0PaIiQxYQIDAQA4'
  1178. record4_out='"k=rsa; p=MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4+VEVsoTbl6tYLJlhozqAGju3IgpSVdBAS5LMyzpHP8/L0/PlyVRJnm2xECjVk3DRqCmelyIvmraw1VtFz2aH6DRlDhHsZghj1DmGhwN+7NkwIb4hEvmytMVAz1WyiLH6Rm6Iemm/ZCt1RhrAMUYLxHA9mJgky76YCcf8/cX35xC+1vd4a5U6YofAZeVP9DBvVgQ8ung4g""VrOrQrXkU8QfVNAoXz5pfJo74GB7woIBFhZXsU6SKho7KnzT5inVCIOtWp7L5hyEnbySWQPHT2vAMCCAe2AY/Vv0N3HW14o8P3b4A6OU920wFB2kA7pkQNzO5OwH+HSttwG0PaIiQxYQIDAQA4"'
  1179. # Test Create
  1180. run v-add-dns-record $user $domain 'test-long-txt' 'TXT' "$record3_in" '' 50
  1181. assert_success
  1182. refute_output
  1183. assert_file_contains "$HOMEDIR/$user/conf/dns/${domain}.db" "$record3_out"
  1184. # Test Edit
  1185. run v-change-dns-record $user $domain 50 'test-long-txt' 'TXT' "$record4_in"
  1186. assert_success
  1187. refute_output
  1188. assert_file_contains "$HOMEDIR/$user/conf/dns/${domain}.db" "$record4_out"
  1189. # Test Cleanup
  1190. run v-delete-dns-record $user $domain 50
  1191. assert_success
  1192. refute_output
  1193. }
  1194. @test "DNS: Change domain ip" {
  1195. run v-change-dns-domain-ip $user $domain 127.0.0.1
  1196. assert_success
  1197. refute_output
  1198. }
  1199. @test "DNS: Suspend domain" {
  1200. run v-suspend-dns-domain $user $domain
  1201. assert_success
  1202. refute_output
  1203. }
  1204. @test "DNS: Unsuspend domain" {
  1205. run v-unsuspend-dns-domain $user $domain
  1206. assert_success
  1207. refute_output
  1208. }
  1209. @test "DNS: Rebuild" {
  1210. run v-rebuild-dns-domains $user
  1211. assert_success
  1212. refute_output
  1213. }
  1214. #----------------------------------------------------------#
  1215. # MAIL #
  1216. #----------------------------------------------------------#
  1217. @test "MAIL: Add domain" {
  1218. run v-add-mail-domain $user $domain
  1219. assert_success
  1220. refute_output
  1221. validate_mail_domain $user $domain
  1222. }
  1223. @test "MAIL: Add mail domain webmail client (Roundcube)" {
  1224. run v-add-mail-domain-webmail $user $domain "roundcube" "yes"
  1225. assert_success
  1226. refute_output
  1227. # echo -e "<?php\necho 'Server: ' . \$_SERVER['SERVER_SOFTWARE'];" > /var/lib/roundcube/check_server.php
  1228. validate_webmail_domain $user $domain 'Welcome to Roundcube Webmail'
  1229. # rm /var/lib/roundcube/check_server.php
  1230. }
  1231. @test "Mail: Add SSL to mail domain" {
  1232. # Use generated certificates during WEB Generate Self signed certificate
  1233. run v-add-mail-domain-ssl $user $domain /tmp
  1234. assert_success
  1235. refute_output
  1236. validate_webmail_domain $user $domain 'Welcome to Roundcube Webmail'
  1237. }
  1238. @test "MAIL: Add mail domain webmail client (SnappyMail)" {
  1239. if [ -z "$(echo $WEBMAIL_SYSTEM | grep -w "snappymail")" ]; then
  1240. skip "Webmail client SnappyMail not installed"
  1241. fi
  1242. run v-add-mail-domain-webmail $user $domain "snappymail" "yes"
  1243. assert_success
  1244. refute_output
  1245. validate_mail_domain $user $domain
  1246. validate_webmail_domain $user $domain 'SnappyMail Webmail'
  1247. }
  1248. @test "MAIL: Disable webmail client" {
  1249. run v-add-mail-domain-webmail $user $domain "disabled" "yes"
  1250. assert_success
  1251. refute_output
  1252. validate_mail_domain $user $domain
  1253. validate_webmail_domain $user $domain 'Success!'
  1254. run v-add-mail-domain-webmail $user $domain "roundcube" "yes"
  1255. assert_success
  1256. refute_output
  1257. }
  1258. @test "MAIL: Add domain (duplicate)" {
  1259. run v-add-mail-domain $user $domain
  1260. assert_failure $E_EXISTS
  1261. }
  1262. @test "MAIL: Add account" {
  1263. run v-add-mail-account $user $domain test "$userpass2"
  1264. assert_success
  1265. assert_file_contains /etc/exim4/domains/$domain/limits "test@$domain"
  1266. refute_output
  1267. }
  1268. @test "MAIL: Add account (duplicate)" {
  1269. run v-add-mail-account $user $domain test "$userpass2"
  1270. assert_failure $E_EXISTS
  1271. }
  1272. @test "MAIL: Add account 2" {
  1273. run v-add-mail-account $user $domain random "$userpass2"
  1274. assert_success
  1275. assert_file_contains /etc/exim4/domains/$domain/limits "random@$domain"
  1276. refute_output
  1277. }
  1278. @test "MAIL: Add account alias" {
  1279. run v-add-mail-account-alias $user $domain test hestiacprocks
  1280. assert_success
  1281. assert_file_contains /etc/exim4/domains/$domain/aliases "hestiacprocks@$domain"
  1282. refute_output
  1283. }
  1284. @test "MAIL: Add account alias 2" {
  1285. run v-add-mail-account-alias $user $domain test hestiacprocks2
  1286. assert_success
  1287. assert_file_contains /etc/exim4/domains/$domain/aliases "hestiacprocks2@$domain"
  1288. refute_output
  1289. }
  1290. @test "MAIL: Add account alias 3" {
  1291. run v-add-mail-account-alias $user $domain test hestiacp
  1292. assert_success
  1293. assert_file_contains /etc/exim4/domains/$domain/aliases "hestiacp@$domain"
  1294. refute_output
  1295. }
  1296. @test "MAIL: Add account 3" {
  1297. run v-add-mail-account $user $domain hestia "$userpass2"
  1298. assert_success
  1299. assert_file_contains /etc/exim4/domains/$domain/limits "hestia@$domain"
  1300. refute_output
  1301. }
  1302. @test "MAIL: Add account 4" {
  1303. run v-add-mail-account $user $domain hestiarocks3 "$userpass2"
  1304. assert_success
  1305. assert_file_contains /etc/exim4/domains/$domain/limits "hestiarocks3@$domain"
  1306. refute_output
  1307. }
  1308. @test "MAIL: Add account 5" {
  1309. run v-add-mail-account $user $domain 01 "$userpass2"
  1310. assert_success
  1311. assert_file_contains /etc/exim4/domains/$domain/limits "01@$domain"
  1312. refute_output
  1313. }
  1314. @test "MAIL: Add account 6" {
  1315. run v-add-mail-account $user $domain "0aa" "$userpass2"
  1316. assert_success
  1317. assert_file_contains /etc/exim4/domains/$domain/limits "0aa@$domain"
  1318. refute_output
  1319. }
  1320. @test "MAIL: Add account alias Invalid length" {
  1321. run v-add-mail-account-alias $user $domain test 'hestiacp-really-rocks-but-i-want-to-have-feature-xyz-and-i-want-it-now'
  1322. assert_failure $E_INVALID
  1323. }
  1324. @test "MAIL: Add account alias Invalid" {
  1325. run v-add-mail-account-alias $user $domain test 'test+123'
  1326. assert_failure $E_INVALID
  1327. }
  1328. @test "MAIL: Add account alias starting with -" {
  1329. run v-add-mail-account-alias $user $domain test '-test'
  1330. assert_success
  1331. }
  1332. @test "MAIL: Add account alias ending with -" {
  1333. run v-add-mail-account-alias $user $domain test 'test-'
  1334. assert_success
  1335. }
  1336. @test "MAIL: Add account alias Invalid 2" {
  1337. run v-add-mail-account-alias $user $domain test 'hestia@test'
  1338. assert_failure $E_INVALID
  1339. }
  1340. @test "MAIL: Add account alias (duplicate)" {
  1341. run v-add-mail-account-alias $user $domain test hestiacprocks
  1342. assert_failure $E_EXISTS
  1343. }
  1344. @test "MAIL: change mail account password" {
  1345. run curl -k -X POST -d "email=test@$domain&password=$userpass2&new=123456" https://localhost:8083/reset/mail/
  1346. assert_success
  1347. assert_output --partial "==ok=="
  1348. }
  1349. @test "MAIL: change mail account password (Incorrect PW)" {
  1350. run curl -k -X POST -d "email=test@$domain&password=$userpass2&new=123456" https://localhost:8083/reset/mail/
  1351. assert_success
  1352. assert_output --partial "error"
  1353. }
  1354. @test "MAIL: Change rate limit" {
  1355. run v-change-mail-account-rate-limit $user $domain test 10
  1356. assert_file_contains /etc/exim4/domains/$domain/limits "test@$domain:10"
  1357. }
  1358. @test "MAIL: Delete account" {
  1359. run v-delete-mail-account $user $domain test
  1360. assert_success
  1361. refute_output
  1362. }
  1363. @test "MAIL: Delete missing account" {
  1364. run v-delete-mail-account $user $domain test
  1365. assert_failure $E_NOTEXIST
  1366. }
  1367. @test "MAIL: Rebuild mail domain" {
  1368. run v-rebuild-mail-domains $user
  1369. assert_success
  1370. refute_output
  1371. }
  1372. @test "MAIL: Delete DKIM" {
  1373. run v-delete-mail-domain-dkim $user $domain
  1374. assert_success
  1375. refute_output
  1376. run grep "RECORD='mail._domainkey'" "${HESTIA}/data/users/${user}/dns/${domain}.conf"
  1377. assert_failure
  1378. refute_output
  1379. }
  1380. @test "MAIL: Add DKIM" {
  1381. run v-add-mail-domain-dkim $user $domain
  1382. assert_success
  1383. refute_output
  1384. run grep "RECORD='mail._domainkey'" "${HESTIA}/data/users/${user}/dns/${domain}.conf"
  1385. assert_success
  1386. assert_output --partial "RECORD='mail._domainkey' TYPE='TXT'"
  1387. }
  1388. @test "MAIL: Delete DKIM but preserve custom dkim records" {
  1389. run v-add-dns-record $user $domain 'k2._domainkey' 'TXT' 'v=DKIM1; k=rsa; p=123456'
  1390. assert_success
  1391. refute_output
  1392. run v-delete-mail-domain-dkim $user $domain
  1393. assert_success
  1394. refute_output
  1395. run grep "RECORD='k2._domainkey'" "${HESTIA}/data/users/${user}/dns/${domain}.conf"
  1396. assert_success
  1397. assert_output --partial "RECORD='k2._domainkey' TYPE='TXT'"
  1398. }
  1399. #----------------------------------------------------------#
  1400. # Limit possibilities adding different owner domain #
  1401. #----------------------------------------------------------#
  1402. @test "Allow Users: User can't add user.user2.com " {
  1403. # Case: admin company.tld
  1404. # users should not be allowed to add user.company.tld
  1405. run v-add-user $user2 $user2 $user@hestiacp.com default "Super Test"
  1406. assert_success
  1407. refute_output
  1408. run v-add-web-domain $user2 $rootdomain
  1409. assert_success
  1410. refute_output
  1411. run v-add-web-domain $user $subdomain
  1412. assert_failure $E_EXISTS
  1413. }
  1414. @test "Allow Users: User can't add user.user2.com as alias" {
  1415. run v-add-web-domain-alias $user $domain $subdomain
  1416. assert_failure $E_EXISTS
  1417. }
  1418. @test "Allow Users: User can't add user.user2.com as mail domain" {
  1419. run v-add-mail-domain $user $subdomain
  1420. assert_failure $E_EXISTS
  1421. }
  1422. @test "Allow Users: User can't add user.user2.com as dns domain" {
  1423. run v-add-dns-domain $user $subdomain 198.18.0.125
  1424. assert_failure $E_EXISTS
  1425. }
  1426. @test "Allow Users: Set Allow users" {
  1427. # Allow user to yes allows
  1428. # Case: admin company.tld
  1429. # users are allowed to add user.company.tld
  1430. run v-add-web-domain-allow-users $user2 $rootdomain
  1431. assert_success
  1432. refute_output
  1433. }
  1434. @test "Allow Users: User can add user.user2.com" {
  1435. run v-add-web-domain $user $subdomain
  1436. assert_success
  1437. refute_output
  1438. }
  1439. @test "Allow Users: User can add user.user2.com as alias" {
  1440. run v-delete-web-domain $user $subdomain
  1441. assert_success
  1442. refute_output
  1443. run v-add-web-domain-alias $user $domain $subdomain
  1444. assert_success
  1445. refute_output
  1446. }
  1447. @test "Allow Users: User can add user.user2.com as mail domain" {
  1448. run v-add-mail-domain $user $subdomain
  1449. assert_success
  1450. refute_output
  1451. }
  1452. @test "Allow Users: User can add user.user2.com as dns domain" {
  1453. run v-add-dns-domain $user $subdomain 198.18.0.125
  1454. assert_success
  1455. refute_output
  1456. }
  1457. @test "Allow Users: Cleanup tests" {
  1458. run v-delete-dns-domain $user $subdomain
  1459. assert_success
  1460. refute_output
  1461. run v-delete-mail-domain $user $subdomain
  1462. assert_success
  1463. refute_output
  1464. }
  1465. @test "Allow Users: Set Allow users no" {
  1466. run v-delete-web-domain-alias $user $domain $subdomain
  1467. assert_success
  1468. refute_output
  1469. run v-delete-web-domain-allow-users $user2 $rootdomain
  1470. assert_success
  1471. refute_output
  1472. }
  1473. @test "Allow Users: User can't add user.user2.com again" {
  1474. run v-add-web-domain $user $subdomain
  1475. assert_failure $E_EXISTS
  1476. }
  1477. @test "Allow Users: user2 can add user.user2.com again" {
  1478. run v-add-web-domain $user2 $subdomain
  1479. assert_success
  1480. refute_output
  1481. }
  1482. #----------------------------------------------------------#
  1483. # DB #
  1484. #----------------------------------------------------------#
  1485. @test "MYSQL: Add database" {
  1486. run v-add-database $user database dbuser 1234 mysql
  1487. assert_success
  1488. refute_output
  1489. # validate_database mysql database_name database_user password
  1490. validate_database mysql $database $dbuser 1234
  1491. }
  1492. @test "MYSQL: Add Database (Duplicate)" {
  1493. run v-add-database $user database dbuser 1234 mysql
  1494. assert_failure $E_EXISTS
  1495. }
  1496. @test "MYSQL: Rebuild Database" {
  1497. run v-rebuild-database $user $database
  1498. assert_success
  1499. refute_output
  1500. }
  1501. @test "MYSQL: Change database user password" {
  1502. run v-change-database-password $user $database 123456
  1503. assert_success
  1504. refute_output
  1505. validate_database mysql $database $dbuser 123456
  1506. }
  1507. @test "MYSQL: Change database user" {
  1508. run v-change-database-user $user $database database
  1509. assert_success
  1510. refute_output
  1511. validate_database mysql $database $database 123456
  1512. }
  1513. @test "MYSQL: Suspend database" {
  1514. run v-suspend-database $user $database
  1515. assert_success
  1516. refute_output
  1517. }
  1518. @test "MYSQL: Unsuspend database" {
  1519. run v-unsuspend-database $user $database
  1520. assert_success
  1521. refute_output
  1522. }
  1523. @test "MYSQL: Delete database" {
  1524. run v-delete-database $user $database
  1525. assert_success
  1526. refute_output
  1527. }
  1528. @test "MYSQL: Delete missing database" {
  1529. run v-delete-database $user $database
  1530. assert_failure $E_NOTEXIST
  1531. }
  1532. @test "PGSQL: Add database invalid user" {
  1533. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1534. skip "PostGreSQL is not installed"
  1535. fi
  1536. run v-add-database "$user" "database" "dbuser" "1234ABCD" "pgsql"
  1537. assert_failure $E_INVALID
  1538. }
  1539. @test "PGSQL: Add database" {
  1540. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1541. skip "PostGreSQL is not installed"
  1542. fi
  1543. run v-add-user $pguser $pguser $user@hestiacp.com default "Super Test"
  1544. run v-add-database "$pguser" "database" "dbuser" "1234ABCD" "pgsql"
  1545. assert_success
  1546. refute_output
  1547. # validate_database pgsql $pgdatabase $pgdbuser "1234ABCD"
  1548. }
  1549. @test "PGSQL: Add Database (Duplicate)" {
  1550. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1551. skip "PostGreSQL is not installed"
  1552. fi
  1553. run v-add-database "$pguser" "database" "dbuser" "1234ABCD" "pgsql"
  1554. assert_failure $E_EXISTS
  1555. }
  1556. @test "PGSQL: Rebuild Database" {
  1557. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1558. skip "PostGreSQL is not installed"
  1559. fi
  1560. run v-rebuild-database $pguser $pgdatabase
  1561. assert_success
  1562. refute_output
  1563. }
  1564. @test "PGSQL: Change database user password" {
  1565. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1566. skip "PostGreSQL is not installed"
  1567. fi
  1568. run v-change-database-password $pguser $pgdatabase "123456"
  1569. assert_success
  1570. refute_output
  1571. # validate_database pgsql $pgdatabase $pgdbuser "123456"
  1572. }
  1573. @test "PGSQL: Suspend database" {
  1574. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1575. skip "PostGreSQL is not installed"
  1576. fi
  1577. run v-suspend-database $pguser $pgdatabase
  1578. assert_success
  1579. refute_output
  1580. }
  1581. @test "PGSQL: Unsuspend database" {
  1582. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1583. skip "PostGreSQL is not installed"
  1584. fi
  1585. run v-unsuspend-database $pguser $pgdatabase
  1586. assert_success
  1587. refute_output
  1588. }
  1589. @test "PGSQL: Change database user" {
  1590. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1591. skip "PostGreSQL is not installed"
  1592. fi
  1593. skip
  1594. run v-change-database-user $pguser $pgdatabase database
  1595. assert_success
  1596. refute_output
  1597. validate_database pgsql $pgdatabase $pgdatabase 123456
  1598. }
  1599. @test "PGSQL: Delete database" {
  1600. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1601. skip "PostGreSQL is not installed"
  1602. fi
  1603. run v-delete-database $pguser $pgdatabase
  1604. assert_success
  1605. refute_output
  1606. }
  1607. @test "PGSQL: Delete missing database" {
  1608. if [ -z "$(echo $DB_SYSTEM | grep -w "pgsql")" ]; then
  1609. skip "PostGreSQL is not installed"
  1610. fi
  1611. run v-delete-database $pguser $pgdatabase
  1612. assert_failure $E_NOTEXIST
  1613. run v-delete-user $pguser
  1614. }
  1615. #----------------------------------------------------------#
  1616. # System #
  1617. #----------------------------------------------------------#
  1618. @test "System: Set/Enable SMTP account for internal mail" {
  1619. run v-add-sys-smtp $domain 587 STARTTLS info@$domain 1234-test noreply@$domain
  1620. assert_success
  1621. refute_output
  1622. }
  1623. @test "System: Disable SMTP account for internal mail" {
  1624. run v-delete-sys-smtp
  1625. assert_success
  1626. refute_output
  1627. }
  1628. @test "System: Set/Enable SMTP relay" {
  1629. run v-add-sys-smtp-relay $domain info@$domain 1234-test 587
  1630. assert_success
  1631. refute_output
  1632. assert_file_exist /etc/exim4/smtp_relay.conf
  1633. }
  1634. @test "System: Delete SMTP relay" {
  1635. run v-delete-sys-smtp-relay
  1636. assert_success
  1637. refute_output
  1638. assert_file_not_exist /etc/exim4/smtp_relay.conf
  1639. }
  1640. #----------------------------------------------------------#
  1641. # Firewall #
  1642. #----------------------------------------------------------#
  1643. @test "Firewall: Add ip to banlist" {
  1644. run v-add-firewall-ban '1.2.3.4' 'HESTIA'
  1645. assert_success
  1646. refute_output
  1647. check_ip_banned '1.2.3.4' 'HESTIA'
  1648. }
  1649. @test "Firewall: Delete ip to banlist" {
  1650. run v-delete-firewall-ban '1.2.3.4' 'HESTIA'
  1651. assert_success
  1652. refute_output
  1653. check_ip_not_banned '1.2.3.4' 'HESTIA'
  1654. }
  1655. @test "Firewall: Add ip to banlist for ALL" {
  1656. run v-add-firewall-ban '1.2.3.4' 'HESTIA'
  1657. assert_success
  1658. refute_output
  1659. run v-add-firewall-ban '1.2.3.4' 'MAIL'
  1660. assert_success
  1661. refute_output
  1662. check_ip_banned '1.2.3.4' 'HESTIA'
  1663. }
  1664. @test "Firewall: Delete ip to banlist CHAIN = ALL" {
  1665. run v-delete-firewall-ban '1.2.3.4' 'ALL'
  1666. assert_success
  1667. refute_output
  1668. check_ip_not_banned '1.2.3.4' 'HESTIA'
  1669. }
  1670. @test "Test Whitelist Fail2ban" {
  1671. echo "1.2.3.4" >> $HESTIA/data/firewall/excludes.conf
  1672. run v-add-firewall-ban '1.2.3.4' 'HESTIA'
  1673. rm $HESTIA/data/firewall/excludes.conf
  1674. check_ip_not_banned '1.2.3.4' 'HESTIA'
  1675. }
  1676. @test "Test create ipset" {
  1677. run v-add-firewall-ipset "country-nl" "https://raw.githubusercontent.com/ipverse/rir-ip/master/country/nl/ipv4-aggregated.txt" v4 yes
  1678. assert_success
  1679. refute_output
  1680. }
  1681. @test "Create firewall with Ipset" {
  1682. run v-add-firewall-rule 'DROP' 'ipset:country-nl' '8083,22' 'TCP' 'Test'
  1683. assert_success
  1684. refute_output
  1685. }
  1686. @test "List firewall rules" {
  1687. run v-list-firewall csv
  1688. assert_success
  1689. assert_line --partial '11,DROP,TCP,8083,22,ipset:country-nl'
  1690. }
  1691. @test "Delete firewall with Ipset" {
  1692. run v-delete-firewall-rule '11'
  1693. assert_success
  1694. refute_output
  1695. }
  1696. @test "Test delete ipset" {
  1697. run v-delete-firewall-ipset "country-nl"
  1698. assert_success
  1699. refute_output
  1700. }
  1701. #----------------------------------------------------------#
  1702. # PACKAGE #
  1703. #----------------------------------------------------------#
  1704. @test "Package: Create new Package" {
  1705. cp $HESTIA/data/packages/default.pkg /tmp/package
  1706. run v-add-user-package /tmp/package hestiatest
  1707. assert_success
  1708. refute_output
  1709. }
  1710. @test "Package: Assign user to new Package" {
  1711. run v-change-user-package $user hestiatest
  1712. assert_success
  1713. refute_output
  1714. }
  1715. @test "Package: Create new package (Duplicate)" {
  1716. sed -i "s/BANDWIDTH='unlimited'/BANDWIDTH='100'/g" /tmp/package
  1717. run v-add-user-package /tmp/package hestiatest
  1718. assert_failure $E_EXISTS
  1719. }
  1720. @test "Package: Update new Package" {
  1721. sed -i "s/BANDWIDTH='unlimited'/BANDWIDTH='100'/g" /tmp/package
  1722. run v-add-user-package /tmp/package hestiatest yes
  1723. assert_success
  1724. refute_output
  1725. }
  1726. @test "Package: Update package of user" {
  1727. run v-change-user-package $user hestiatest
  1728. assert_success
  1729. refute_output
  1730. run grep "BANDWIDTH='100'" $HESTIA/data/users/$user/user.conf
  1731. assert_success
  1732. assert_output --partial "100"
  1733. }
  1734. @test "Package: Copy package Not Exists" {
  1735. run v-copy-user-package hestiadoesnotexists hestiatest2
  1736. assert_failure $E_NOTEXIST
  1737. }
  1738. @test "Package: Copy package" {
  1739. run v-copy-user-package hestiatest hestiatest2
  1740. assert_success
  1741. refute_output
  1742. }
  1743. @test "Package: Copy package Exists" {
  1744. run v-copy-user-package hestiatest hestiatest2
  1745. assert_failure $E_EXISTS
  1746. }
  1747. @test "Package: Delete package" {
  1748. run v-delete-user-package hestiatest
  1749. run v-delete-user-package hestiatest2
  1750. rm /tmp/package
  1751. assert_success
  1752. refute_output
  1753. run grep "BANDWIDTH='unlimited'" $HESTIA/data/users/$user/user.conf
  1754. assert_success
  1755. assert_output --partial "unlimited"
  1756. }
  1757. #----------------------------------------------------------#
  1758. # Backup user #
  1759. #----------------------------------------------------------#
  1760. @test "Backup: Backup user" {
  1761. run v-backup-user $user
  1762. assert_success
  1763. }
  1764. @test "Backup: List Backups" {
  1765. run v-list-user-backups $user plain
  1766. assert_success
  1767. assert_output --partial "$user"
  1768. }
  1769. @test "Backup: Delete backups" {
  1770. run v-delete-user-backup $user $(v-list-user-backups $user plain | cut -f1)
  1771. assert_success
  1772. run rm /backup/$user.log
  1773. }
  1774. #----------------------------------------------------------#
  1775. # Change owner scripts #
  1776. #----------------------------------------------------------#
  1777. @test "Change: Change domain owner" {
  1778. run v-change-domain-owner $domain $user2
  1779. assert_success
  1780. run v-restart-web
  1781. run v-restart-proxy
  1782. }
  1783. @test "Change: Add database" {
  1784. run v-add-database $user database dbuser 1234 mysql
  1785. assert_success
  1786. refute_output
  1787. # validate_database mysql database_name database_user password
  1788. validate_database mysql $database $dbuser 1234
  1789. }
  1790. @test "Change: Change database owner" {
  1791. run v-change-database-owner $database $user2
  1792. assert_success
  1793. validate_database mysql test-5286_database test-5286_dbuser 1234
  1794. }
  1795. @test "Change: Delete database" {
  1796. run v-delete-database $user2 test-5286_database
  1797. assert_success
  1798. refute_output
  1799. }
  1800. #----------------------------------------------------------#
  1801. # CLEANUP #
  1802. #----------------------------------------------------------#
  1803. @test "Mail: Delete domain" {
  1804. run v-delete-mail-domain $user2 $domain
  1805. assert_success
  1806. refute_output
  1807. }
  1808. @test "DNS: Delete domain" {
  1809. run v-delete-dns-domain $user2 $domain
  1810. assert_success
  1811. refute_output
  1812. }
  1813. @test "WEB: Delete domain" {
  1814. run v-delete-web-domain $user2 $domain
  1815. assert_success
  1816. refute_output
  1817. }
  1818. @test "Delete user" {
  1819. run v-delete-user $user
  1820. assert_success
  1821. refute_output
  1822. }
  1823. @test "Delete user2" {
  1824. run v-delete-user $user2
  1825. assert_success
  1826. refute_output
  1827. }
  1828. @test "Ip: Delete the test IP" {
  1829. run v-delete-sys-ip 198.18.0.125
  1830. assert_success
  1831. refute_output
  1832. }
  1833. @test 'assert()' {
  1834. touch '/var/log/test.log'
  1835. assert [ -e '/var/log/test.log' ]
  1836. }