[Rt-commit] rt branch, 4.4/add-postgresql-apache-fcgid-tests, created. rt-4.4.4-151-gb084168a1c

Dianne Skoll dianne at bestpractical.com
Thu Nov 5 13:30:53 EST 2020


The branch, 4.4/add-postgresql-apache-fcgid-tests has been created
        at  b084168a1c0f11cbf8cad414a8203fde1b659f4d (commit)

- Log -----------------------------------------------------------------
commit fd4601710bc4094230dd4b0a2e02e795c9fc2eb9
Author: Dianne Skoll <dianne at bestpractical.com>
Date:   Mon Aug 24 14:56:22 2020 -0400

    Add support for mod_fcgid.

diff --git a/configure.ac b/configure.ac
index e10ccf199a..005f8e09be 100755
--- a/configure.ac
+++ b/configure.ac
@@ -54,9 +54,9 @@ AC_ARG_WITH(web-handler,
         ]),
     WEB_HANDLER=$withval,
     WEB_HANDLER=fastcgi)
-my_web_handler_test=$($PERL -e 'print "ok" unless grep $_ !~ /^(modperl1|modperl2|fastcgi|standalone)$/i, grep defined && length, split /\s*,\s*/, $ARGV@<:@0@:>@' $WEB_HANDLER)
+my_web_handler_test=$($PERL -e 'print "ok" unless grep $_ !~ /^(modperl1|modperl2|fastcgi|fcgid|standalone)$/i, grep defined && length, split /\s*,\s*/, $ARGV@<:@0@:>@' $WEB_HANDLER)
 if test "$my_web_handler_test" != "ok"; then
-	AC_MSG_ERROR([Only modperl1, modperl2, fastcgi and standalone are valid web-handlers])
+	AC_MSG_ERROR([Only modperl1, modperl2, fastcgi, fcgid and standalone are valid web-handlers])
 fi
 AC_SUBST(WEB_HANDLER)
 
@@ -503,6 +503,7 @@ AC_CONFIG_FILES([
                  t/data/configs/apache2.2+mod_perl.conf
                  t/data/configs/apache2.2+fastcgi.conf
                  t/data/configs/apache2.4+mod_perl.conf
-                 t/data/configs/apache2.4+fastcgi.conf],
+                 t/data/configs/apache2.4+fastcgi.conf
+                 t/data/configs/apache2.4+fcgid.conf],
                )
 AC_OUTPUT
diff --git a/lib/RT/Test/Apache.pm b/lib/RT/Test/Apache.pm
index 2cb0df4187..3c0bfe0505 100644
--- a/lib/RT/Test/Apache.pm
+++ b/lib/RT/Test/Apache.pm
@@ -58,6 +58,7 @@ my %MODULES = (
     '2.4' => {
         "mod_perl" => [qw(mpm_worker authz_core authn_core authz_host env alias perl)],
         "fastcgi"  => [qw(mpm_worker authz_core authn_core authz_host env alias mime fastcgi)],
+        "fcgid"  => [qw(mpm_worker authz_core authn_core authz_host env alias mime fcgid)],
     },
 );
 
diff --git a/t/data/configs/apache2.4+fcgid.conf.in b/t/data/configs/apache2.4+fcgid.conf.in
new file mode 100644
index 0000000000..0ef6cf99d4
--- /dev/null
+++ b/t/data/configs/apache2.4+fcgid.conf.in
@@ -0,0 +1,47 @@
+ServerRoot %%SERVER_ROOT%%
+PidFile %%PID_FILE%%
+ServerAdmin root at localhost
+
+%%LOAD_MODULES%%
+
+<IfModule !mpm_netware_module>
+<IfModule !mpm_winnt_module>
+User @WEB_USER@
+Group @WEB_GROUP@
+</IfModule>
+</IfModule>
+
+ServerName localhost
+Listen %%LISTEN%%
+
+ErrorLog "%%LOG_FILE%%"
+LogLevel debug
+
+<Directory />
+    Options FollowSymLinks
+    AllowOverride None
+    Require all denied
+</Directory>
+
+AddDefaultCharset UTF-8
+
+FcgidConnectTimeout 20
+FcgidProcessTableFile %%tmp_dir%%/shm
+FcgidIPCDir %%tmp_dir%%
+FcgidInitialEnv RT_TESTING 1
+FcgidInitialEnv RT_SITE_CONFIG %%RT_SITE_CONFIG%%
+
+ScriptAlias / %%RT_SBIN_PATH%%/rt-server.fcgi/
+
+DocumentRoot "%%DOCUMENT_ROOT%%"
+<Location />
+
+    <RequireAll>
+        Require all granted
+%%BASIC_AUTH%%
+    </RequireAll>
+
+    Options +ExecCGI
+    AddHandler fcgid-script .fcgi
+</Location>
+

commit 972914657708b412ea6e2ad93f6a7660883aaa74
Author: Dianne Skoll <dianne at bestpractical.com>
Date:   Mon Aug 24 15:16:46 2020 -0400

    Add PostgreSQL tests on Travis CI.

diff --git a/.travis.yml b/.travis.yml
index 9a3695ae32..044c0233c0 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -1,20 +1,42 @@
 language: bash
 services: docker
+os: linux
 
 notifications:
   slack:
     secure: ebb/6lbr1ob7wMh04C5PzM5/NNz6IstEUaUROA7BATuKKgPetl6qwmQNwvlwE5zYvJQBWQwKJ70JaCzJkXK6JVMVRRAWsXINJTzMfSqsoXEcJ59c5isf0bsnspVO7jxHTfXF/NZngR4EuPwH5v5lWp9m++j90t9nBKFFVi34WUE=
 
-env:
-  - RT_TEST_PARALLEL=1 RT_DBA_USER=root RT_DBA_PASSWORD=password DB_VERSION_TAG=10.3
+jobs:
+  include:
+  - stage: test
+    name: Test against PostgreSQL
+    env:
+      - RT_TEST_PARALLEL=1 RT_DBA_USER=postgres RT_DBA_PASSWORD=password DB_VERSION_TAG=9.6
 
 # $TRAVIS_BUILD_DIR will have a clone of the current branch
-before_install:
-  - docker run --name mariadb -e MYSQL_ROOT_PASSWORD=password -d mariadb:$DB_VERSION_TAG
-  - docker build -t rt-base .
-  - docker run -d -v $TRAVIS_BUILD_DIR:/rt --name rt --link mariadb:db rt-base
-  - docker ps -a
-  - docker exec -it rt bash -c "cd /rt && ./configure.ac --with-db-type=mysql --with-my-user-group --enable-layout=inplace --enable-developer --enable-externalauth --disable-gpg --disable-smime && mkdir -p /rt/var && make testdeps"
+    before_install:
+      - docker run --name postgresql --mount type=tmpfs,destination=/var/lib/postgresql/data -e POSTGRES_PASSWORD=password -d postgres:$DB_VERSION_TAG
+      - docker build -t rt-base .
+      - docker run -d -e RT_DBA_USER=postgres -e RT_DBA_PASSWORD=password -v $TRAVIS_BUILD_DIR:/rt --name rt --link postgresql:db rt-base
+      - docker ps -a
+      - docker exec -it rt bash -c "apt-get update && apt-get install -y libdbd-pg-perl"
+      - docker exec -it rt bash -c "cd /rt && ./configure.ac --with-db-type=Pg --with-my-user-group --enable-layout=inplace --enable-developer --enable-externalauth --disable-gpg --disable-smime && mkdir -p /rt/var && make testdeps"
 
-script:
-    - docker exec -it rt bash -c "cd /rt && prove -lj9 t/*"
+    script:
+        - docker exec -it rt bash -c "cd /rt && prove -lj9 t/*"
+
+  - stage: test
+    name: Test against MariaDB
+    env:
+      - RT_TEST_PARALLEL=1 RT_DBA_USER=root RT_DBA_PASSWORD=password DB_VERSION_TAG=10.3
+
+# $TRAVIS_BUILD_DIR will have a clone of the current branch
+    before_install:
+      - docker run --name mariadb -e MYSQL_ROOT_PASSWORD=password -d mariadb:$DB_VERSION_TAG
+      - docker build -t rt-base .
+      - docker run -d -e RT_DBA_USER=root -e RT_DBA_PASSWORD=password -v $TRAVIS_BUILD_DIR:/rt --name rt --link mariadb:db rt-base
+      - docker ps -a
+      - docker exec -it rt bash -c "cd /rt && ./configure.ac --with-db-type=mysql --with-my-user-group --enable-layout=inplace --enable-developer --enable-externalauth --disable-gpg --disable-smime && mkdir -p /rt/var && make testdeps"
+
+    script:
+        - docker exec -it rt bash -c "cd /rt && prove -lj9 t/*"
diff --git a/Dockerfile b/Dockerfile
index d77111ec6f..47ae886637 100644
--- a/Dockerfile
+++ b/Dockerfile
@@ -4,8 +4,6 @@ FROM bpssysadmin/rt-base-debian-stretch
 
 ENV RT_TEST_PARALLEL 1
 ENV RT_TEST_DEVEL 1
-ENV RT_DBA_USER root
-ENV RT_DBA_PASSWORD password
 ENV RT_TEST_DB_HOST=172.17.0.2
 ENV RT_TEST_RT_HOST=172.17.0.3
 

commit 3049e89c0177c34775844b8edbe5e4d61c17b5b6
Author: Dianne Skoll <dianne at bestpractical.com>
Date:   Mon Aug 24 15:32:54 2020 -0400

    Add three parallel test configurations:
    
    1) RT web handler + SQLite
    2) MariaDB + Apache/mod_fcgid
    3) PostgreSQL + Apache/mod_fcgid

diff --git a/.travis.yml b/.travis.yml
index 044c0233c0..7faa64faad 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -9,34 +9,47 @@ notifications:
 jobs:
   include:
   - stage: test
-    name: Test against PostgreSQL
+    name: Test against SQLite with default web handler
     env:
-      - RT_TEST_PARALLEL=1 RT_DBA_USER=postgres RT_DBA_PASSWORD=password DB_VERSION_TAG=9.6
+      - RT_TEST_PARALLEL=1 RT_DBA_USER=root RT_DBA_PASSWORD=password DB_VERSION_TAG=10.3
 
-# $TRAVIS_BUILD_DIR will have a clone of the current branch
     before_install:
-      - docker run --name postgresql --mount type=tmpfs,destination=/var/lib/postgresql/data -e POSTGRES_PASSWORD=password -d postgres:$DB_VERSION_TAG
       - docker build -t rt-base .
-      - docker run -d -e RT_DBA_USER=postgres -e RT_DBA_PASSWORD=password -v $TRAVIS_BUILD_DIR:/rt --name rt --link postgresql:db rt-base
+      - docker run -d -e RT_DBA_USER=root -e RT_DBA_PASSWORD=password -v $TRAVIS_BUILD_DIR:/rt --name rt rt-base
       - docker ps -a
-      - docker exec -it rt bash -c "apt-get update && apt-get install -y libdbd-pg-perl"
-      - docker exec -it rt bash -c "cd /rt && ./configure.ac --with-db-type=Pg --with-my-user-group --enable-layout=inplace --enable-developer --enable-externalauth --disable-gpg --disable-smime && mkdir -p /rt/var && make testdeps"
+      - docker exec -it rt bash -c "cd /rt && ./configure.ac --with-db-type=SQLite --with-my-user-group --enable-layout=inplace --enable-developer --enable-externalauth --disable-gpg --disable-smime && mkdir -p /rt/var && make testdeps"
 
     script:
         - docker exec -it rt bash -c "cd /rt && prove -lj9 t/*"
 
   - stage: test
-    name: Test against MariaDB
+    name: Test against MariaDB and Apache with mod_fcgid
     env:
       - RT_TEST_PARALLEL=1 RT_DBA_USER=root RT_DBA_PASSWORD=password DB_VERSION_TAG=10.3
 
-# $TRAVIS_BUILD_DIR will have a clone of the current branch
     before_install:
       - docker run --name mariadb -e MYSQL_ROOT_PASSWORD=password -d mariadb:$DB_VERSION_TAG
       - docker build -t rt-base .
-      - docker run -d -e RT_DBA_USER=root -e RT_DBA_PASSWORD=password -v $TRAVIS_BUILD_DIR:/rt --name rt --link mariadb:db rt-base
+      - docker run -d -e RT_DBA_USER=root -e RT_DBA_PASSWORD=password -e RT_TEST_WEB_HANDLER=apache+fcgid -e HTTPD_ROOT=/etc/apache2 -e RT_TEST_APACHE=/usr/sbin/apache2 -e RT_TEST_APACHE_MODULES=/usr/lib/apache2/modules -v $TRAVIS_BUILD_DIR:/rt --name rt --link mariadb:db rt-base
       - docker ps -a
-      - docker exec -it rt bash -c "cd /rt && ./configure.ac --with-db-type=mysql --with-my-user-group --enable-layout=inplace --enable-developer --enable-externalauth --disable-gpg --disable-smime && mkdir -p /rt/var && make testdeps"
+      - docker exec -it rt bash -c "chown -R rt-test /rt; touch /etc/apache2/mime.types"
+      - docker exec -e USER=rt-test -u rt-test -it rt bash -c "cd /rt && ./configure.ac --with-db-type=mysql --enable-layout=inplace --with-my-user-group --enable-developer --enable-externalauth --disable-gpg --disable-smime --with-web-handler=fcgid && mkdir -p /rt/var && make testdeps && chmod a+rX /rt/sbin/*"
 
     script:
-        - docker exec -it rt bash -c "cd /rt && prove -lj9 t/*"
+        - docker exec -e USER=rt-test -u rt-test -it rt bash -c "cd /rt &&prove -lj9 t/*"
+
+  - stage: test
+    name: Test against PostgreSQL and Apache with mod_fcgid
+    env:
+      - RT_TEST_PARALLEL=1 RT_DBA_USER=postgres RT_DBA_PASSWORD=password DB_VERSION_TAG=9.6
+
+    before_install:
+      - docker run --name postgresql --mount type=tmpfs,destination=/var/lib/postgresql/data -e POSTGRES_PASSWORD=password -d postgres:$DB_VERSION_TAG
+      - docker build -t rt-base .
+      - docker run -d -e RT_DBA_USER=postgres -e RT_DBA_PASSWORD=password -e RT_TEST_WEB_HANDLER=apache+fcgid -e HTTPD_ROOT=/etc/apache2 -e RT_TEST_APACHE=/usr/sbin/apache2 -e RT_TEST_APACHE_MODULES=/usr/lib/apache2/modules -v $TRAVIS_BUILD_DIR:/rt --name rt --link postgresql:db rt-base
+      - docker ps -a
+      - docker exec -it rt bash -c "chown -R rt-test /rt; touch /etc/apache2/mime.types"
+      - docker exec -e USER=rt-test -u rt-test -it rt bash -c "cd /rt && ./configure.ac --with-db-type=Pg --enable-layout=inplace --with-my-user-group --enable-developer --enable-externalauth --disable-gpg --disable-smime --with-web-handler=fcgid && mkdir -p /rt/var && make testdeps && chmod a+rX /rt/sbin/*"
+
+    script:
+        - docker exec -e USER=rt-test -u rt-test -it rt bash -c "cd /rt && prove -lj9 t/*"

commit 48e369edec997f24fe8836b055feff4646a6cedc
Author: Dianne Skoll <dianne at bestpractical.com>
Date:   Mon Aug 31 15:35:21 2020 -0400

    Add the "rt-test" user in the RT Dockerfile rather than in the base image.
    
    The rt-test user is only used for the RT tests, so there's no reason to
    have it in the base image.

diff --git a/Dockerfile b/Dockerfile
index 47ae886637..eb09644b18 100644
--- a/Dockerfile
+++ b/Dockerfile
@@ -10,4 +10,7 @@ ENV RT_TEST_RT_HOST=172.17.0.3
 # Skip gpg tests until we update to gpg 2.2
 ENV SKIP_GPG_TESTS=1
 
+# Add the rt_test user (required by mod_fcgid tests)
+RUN adduser rt-test < /dev/null
+
 CMD tail -f /dev/null

commit 39d5882874504b149b7ffdc2068b360c315e9922
Author: Dianne Skoll <dianne at bestpractical.com>
Date:   Thu Nov 5 13:26:24 2020 -0500

    Remove unnecessary environment variable setting.

diff --git a/.travis.yml b/.travis.yml
index 7faa64faad..7bdb76098c 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -11,7 +11,7 @@ jobs:
   - stage: test
     name: Test against SQLite with default web handler
     env:
-      - RT_TEST_PARALLEL=1 RT_DBA_USER=root RT_DBA_PASSWORD=password DB_VERSION_TAG=10.3
+      - RT_TEST_PARALLEL=1 RT_DBA_USER=root RT_DBA_PASSWORD=password
 
     before_install:
       - docker build -t rt-base .

commit b084168a1c0f11cbf8cad414a8203fde1b659f4d
Author: Dianne Skoll <dianne at bestpractical.com>
Date:   Thu Nov 5 13:29:36 2020 -0500

    Explain in more detail why the rt-test user is needed.

diff --git a/Dockerfile b/Dockerfile
index eb09644b18..4dfc016de5 100644
--- a/Dockerfile
+++ b/Dockerfile
@@ -10,7 +10,8 @@ ENV RT_TEST_RT_HOST=172.17.0.3
 # Skip gpg tests until we update to gpg 2.2
 ENV SKIP_GPG_TESTS=1
 
-# Add the rt_test user (required by mod_fcgid tests)
+# Add the rt_test user.  Apache/mod_fcgid refuses to run as root... so we
+# create a non-root user and run the mod_fcgid tests as that user.
 RUN adduser rt-test < /dev/null
 
 CMD tail -f /dev/null

-----------------------------------------------------------------------


More information about the rt-commit mailing list