Compare commits

..

1 Commits

Author SHA1 Message Date
b8e8c90498 feat: initial version
Some checks failed
Test Stalwart Installation Action / Error Handling Tests (pull_request) Successful in 22s
Test Stalwart Installation Action / Basic Installation (No Config) (pull_request) Successful in 45s
Test Stalwart Installation Action / Full Configuration (Domains + Users) (pull_request) Successful in 45s
Test Stalwart Installation Action / Test on Ubuntu ubuntu-20.04 (pull_request) Has been cancelled
Test Stalwart Installation Action / Test on Ubuntu ubuntu-22.04 (pull_request) Has been cancelled
Test Stalwart Installation Action / Test on Ubuntu ubuntu-24.04 (pull_request) Has been cancelled
Test Stalwart Installation Action / Test Summary (pull_request) Has been cancelled
Signed-off-by: Sebastian Krupinski <krupinski01@gmail.com>
2026-02-15 01:01:58 -05:00

View File

@@ -78,69 +78,6 @@ jobs:
echo "::error::Web admin not accessible after 60 seconds"
exit 1
# Test installation with admin password
test-with-password:
name: Installation with Admin Password
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Install dependencies
run: |
sudo apt-get update
sudo apt-get install -y jq curl
- name: Install with admin password
uses: ./
with:
admin_password: 'TestPassword123!@#'
- name: Wait for service to fully start
run: |
echo "Waiting for Stalwart to fully initialize..."
sleep 15
- name: Verify service is running
run: |
# Check process
if ! pgrep -x stalwart >/dev/null; then
echo "::error::Stalwart process is not running"
echo "Process list:"
ps aux | grep stalwart || true
echo "PID file:"
cat /var/run/stalwart.pid 2>/dev/null || echo "No PID file"
echo "Logs:"
tail -50 /opt/stalwart/logs/*.log 2>/dev/null || echo "No logs"
exit 1
fi
echo "✓ Stalwart is running"
- name: Test authentication with new password
run: |
# Wait for API to be ready
echo "Waiting for Stalwart API..."
for i in {1..30}; do
if curl -sf http://localhost:8080/login >/dev/null 2>&1; then
echo "✓ API is ready"
break
fi
sleep 2
done
# Test authentication with Basic Auth (the actual method Stalwart uses)
HTTP_CODE=$(curl -s -o /dev/null -w "%{http_code}" \
-u "admin:TestPassword123!@#" \
http://localhost:8080/api/principal?types=domain&limit=1)
if [ "$HTTP_CODE" != "200" ]; then
echo "::error::Authentication failed with HTTP $HTTP_CODE"
exit 1
fi
echo "✓ Successfully authenticated with new password"
# Test full configuration with domains and users
test-full-config:
name: Full Configuration (Domains + Users)
@@ -158,7 +95,6 @@ jobs:
- name: Install with full configuration
uses: ./
with:
admin_password: 'AdminPass123!@#'
domains: |
[
{
@@ -212,63 +148,19 @@ jobs:
fi
echo "✓ Stalwart is running"
- name: Verify admin password was changed
- name: Verify service is accessible
run: |
# Wait for API to be ready
echo "Waiting for Stalwart API..."
for i in {1..30}; do
if curl -sf http://localhost:8080/login >/dev/null 2>&1; then
echo "✓ API is ready"
break
exit 0
fi
sleep 2
done
# Test authentication with Basic Auth
HTTP_CODE=$(curl -s -o /dev/null -w "%{http_code}" \
-u "admin:AdminPass123!@#" \
http://localhost:8080/api/principal?types=domain&limit=1)
if [ "$HTTP_CODE" != "200" ]; then
echo "::error::Authentication failed with HTTP $HTTP_CODE"
exit 1
fi
echo "✓ Admin authentication successful"
- name: Verify domains were created
run: |
# List domains via API (using discovered endpoint structure)
DOMAINS=$(curl -sf \
-u "admin:AdminPass123!@#" \
"http://localhost:8080/api/principal?types=domain&limit=100")
echo "Domains response: $DOMAINS"
# Check if our test domains exist in data.items array
if echo "$DOMAINS" | jq -e '.data.items[] | select(.name == "test1.local")' >/dev/null; then
echo "✓ Domain test1.local found"
else
echo "::warning::Domain test1.local not found"
echo "$DOMAINS" | jq '.data.items[].name' || true
fi
- name: Verify users were created
run: |
# List accounts via API (using discovered endpoint structure)
ACCOUNTS=$(curl -sf \
-u "admin:AdminPass123!@#" \
"http://localhost:8080/api/principal?types=individual&limit=100")
echo "Accounts response: $ACCOUNTS"
# Check if users exist in data.items array
if echo "$ACCOUNTS" | jq -e '.data.items[] | select(.emails[] == "user1@test1.local")' >/dev/null; then
echo "✓ User user1@test1.local found"
else
echo "::warning::User user1@test1.local not found"
echo "$ACCOUNTS" | jq '.data.items[].emails[]' || true
fi
echo "::error::API not accessible after 60 seconds"
exit 1
- name: Show logs on failure
if: failure()
@@ -309,7 +201,6 @@ jobs:
continue-on-error: true
uses: ./
with:
admin_password: 'TestPass123'
domains: 'invalid json string'
- name: Verify invalid JSON was caught
@@ -355,8 +246,6 @@ jobs:
- name: Install Stalwart
uses: ./
with:
admin_password: 'TestPassword123'
- name: Wait for service to fully start
run: |
@@ -394,7 +283,7 @@ jobs:
test-summary:
name: Test Summary
runs-on: ubuntu-latest
needs: [test-basic-install, test-with-password, test-full-config, test-ubuntu-versions]
needs: [test-basic-install, test-full-config, test-ubuntu-versions]
if: always()
steps:
@@ -403,13 +292,11 @@ jobs:
echo "## Test Results Summary" >> $GITHUB_STEP_SUMMARY
echo "" >> $GITHUB_STEP_SUMMARY
echo "- Basic Install: ${{ needs.test-basic-install.result }}" >> $GITHUB_STEP_SUMMARY
echo "- With Password: ${{ needs.test-with-password.result }}" >> $GITHUB_STEP_SUMMARY
echo "- Full Config: ${{ needs.test-full-config.result }}" >> $GITHUB_STEP_SUMMARY
echo "- Ubuntu Versions: ${{ needs.test-ubuntu-versions.result }}" >> $GITHUB_STEP_SUMMARY
# Fail if any required test failed
if [ "${{ needs.test-basic-install.result }}" != "success" ] || \
[ "${{ needs.test-with-password.result }}" != "success" ] || \
[ "${{ needs.test-full-config.result }}" != "success" ]; then
echo "::error::One or more tests failed"
exit 1