Skip to content

Commit

Permalink
try this for playwright test errors
Browse files Browse the repository at this point in the history
  • Loading branch information
lakshmimsft committed Jul 12, 2024
1 parent e755fe8 commit 3508b92
Show file tree
Hide file tree
Showing 4 changed files with 105 additions and 15 deletions.
73 changes: 73 additions & 0 deletions .github/workflows/test.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -266,6 +266,79 @@ jobs:
max_attempts: 3
retry_wait_seconds: 30
command: rad deploy ${{ matrix.path }} ${{ matrix.deployArgs }}
- name: Wait for all pods to be ready
if: steps.gen-id.outputs.RUN_TEST == 'true'
id: wait-for-pods
run: |
namespace="${{ matrix.env }}-${{ matrix.app }}"
label="radapp.io/application=${{ matrix.app }}"
kubectl rollout status deployment -l $label -n $namespace --timeout=90s
# Verify endpoint reachability
- name: Verify endpoint reachability
if: steps.gen-id.outputs.RUN_TEST == 'true' && matrix.container == ''
run: |
# Extract the endpoint using rad app status
endpoint=$(rad app status -a ${{ matrix.app }} | sed 's/ /\n/g' | grep http)
if [ -z "$endpoint" ]; then
echo "Error: Could not extract endpoint from rad app status"
exit 1
fi
echo "Extracted endpoint: $endpoint"
# Extract hostname and port from the endpoint
hostname=$(echo $endpoint | awk -F[/:] '{print $4}')
port=$(echo $endpoint | awk -F[/:] '{print $5}')
# If port is not specified, default to 80 for http
if [ -z "$port" ]; then
port=80
fi
namespace="${{ matrix.env }}-${{ matrix.app }}"
if [ "$hostname" == "localhost" ]; then
echo "Localhost detected, using Kubernetes service DNS name instead"
hostname="${{ matrix.app }}.$namespace.svc.cluster.local"
echo "New hostname: $hostname"
fi
echo "Verifying endpoint reachability: $hostname:$port"
# Get the name of an existing pod in the application
pod_name=$(kubectl get pods -n $namespace -l radapp.io/application=${{ matrix.app }} -o jsonpath='{.items[0].metadata.name}')
if [ -z "$pod_name" ]; then
echo "Error: No pods found for the application"
exit 1
fi
echo "Using pod: $pod_name"
# Try wget first
if kubectl exec $pod_name -n $namespace -- which wget > /dev/null 2>&1; then
echo "Using wget to check endpoint"
kubectl exec $pod_name -n $namespace -- wget -q -O - -T 10 http://$hostname:$port > /dev/null
# If wget is not available, try busybox wget
elif kubectl exec $pod_name -n $namespace -- /bin/busybox wget --help > /dev/null 2>&1; then
echo "Using busybox wget to check endpoint"
kubectl exec $pod_name -n $namespace -- /bin/busybox wget -q -O - -T 10 http://$hostname:$port > /dev/null
# If busybox wget is not available, use netcat as a last resort
elif kubectl exec $pod_name -n $namespace -- which nc > /dev/null 2>&1; then
echo "Using netcat to check endpoint"
kubectl exec $pod_name -n $namespace -- nc -z -w 10 $hostname $port
else
echo "Error: No suitable tool found to check endpoint reachability"
exit 1
fi
if [ $? -eq 0 ]; then
echo "Endpoint is reachable within the cluster"
else
echo "Error: Endpoint is not reachable within the cluster"
exit 1
fi
- name: Run Playwright Test
if: steps.gen-id.outputs.RUN_TEST == 'true' && matrix.uiTestFile != ''
id: run-playwright-test
Expand Down
4 changes: 2 additions & 2 deletions playwright/playwright.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,8 +47,8 @@ export default defineConfig({
use: { ...devices["Desktop Safari"] },
},
],
timeout: 1 * 60 * 1000,
timeout: 2 * 60 * 1000,
expect: {
timeout: 30 * 1000,
timeout: 60 * 1000,
},
});
41 changes: 29 additions & 12 deletions playwright/tests/eshop/eshop.app.spec.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { test, expect } from "@playwright/test";
import { expect, test } from "@playwright/test";

test("eShop on Containers App Basic UI and Functionality Checks", async ({
page,
Expand All @@ -17,17 +17,34 @@ test("eShop on Containers App Basic UI and Functionality Checks", async ({
let endpoint = process.env.ENDPOINT;
expect(endpoint).toBeDefined();

// Remove quotes from the endpoint if they exist
try {
endpoint = (endpoint as string).replace(/['"]+/g, "");
log(`Navigating to the endpoint: ${endpoint}`);
await page.goto(endpoint);
} catch (error) {
console.error(
`Attempt ${testInfo.retry}: Failed to navigate to the endpoint:`,
error
);
}
// Remove quotes from the endpoint if they exist
try {
endpoint = (endpoint as string).replace(/['"]+/g, "");
log(`Endpoint after removing quotes: ${endpoint}`);
} catch (error) {
console.error(`Error processing the endpoint:`, error);
}

// Check if the endpoint is reachable
try {
const response = await fetch(endpoint);
if (!response.ok) throw new Error(`HTTP error! Status: ${response.status}`);
log(`Endpoint is reachable: ${endpoint}`);
} catch (error) {
console.error(`Failed to reach the endpoint:`, error);
return;
}

// Navigate to the endpoint
try {
log(`Navigating to the endpoint: ${endpoint}`);
await page.goto(endpoint);
} catch (error) {
console.error(
`Attempt ${testInfo.retry}: Failed to navigate to the endpoint:`,
error
);
}

// Expect page to have proper URL
log(`Checking the URL: ${endpoint}/catalog`);
Expand Down
2 changes: 1 addition & 1 deletion playwright/tests/util/helper.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import axios from "axios";

export async function waitForWebApp(url: string | undefined, timeout = 30000) {
export async function waitForWebApp(url: string | undefined, timeout = 60000) {
if (!url) {
throw new Error("URL is not defined");
}
Expand Down

0 comments on commit 3508b92

Please sign in to comment.