testing of example
All checks were successful
continuous-integration/drone/push Build is passing

This commit is contained in:
2024-11-28 17:26:06 +01:00
parent 24196605c7
commit fd0b0f8840
10 changed files with 11 additions and 149 deletions

View File

@@ -1,71 +1,18 @@
---
kind: pipeline
type: docker
name: default
name: hello-world-pipeline
steps:
# Step 1: Install dependencies and run server tests
- name: server_test
image: node:18-alpine
commands:
- echo "Running server tests..."
- cd services/server || echo "services/server directory not found!"
- if [ -f package.json ]; then
yarn install --frozen-lockfile;
yarn test;
else
echo "package.json not found! Skipping server tests.";
fi
# Step 2: Install dependencies and run client tests
- name: client_test
image: node:18-alpine
commands:
- echo "Running tests for React client..."
- cd services/client || echo "services/client directory not found!"
- if [ -f package.json ]; then
yarn install --frozen-lockfile;
yarn add --dev @babel/plugin-proposal-private-property-in-object @testing-library/jest-dom;
yarn test --coverage --detectOpenHandles;
else
echo "package.json not found! Skipping client tests.";
fi
# Step 3: Lint and static analysis (optional)
- name: lint
image: node:18-alpine
commands:
- echo "Running linter..."
- cd services/client || echo "services/client directory not found!"
- yarn lint || echo "Linting failed! Please fix lint errors."
# Step 4: Build the React client
- name: client_build
image: node:18-alpine
commands:
- echo "Building React client..."
- cd services/client || echo "services/client directory not found!"
- if [ -f package.json ]; then
yarn install --frozen-lockfile;
yarn build;
else
echo "package.json not found! Skipping build.";
fi
# Step 5: Deploy (example step)
- name: deploy
# Step 1: Run Hello World
- name: hello-world
image: alpine:latest
environment:
DEPLOY_KEY:
from_secret: deploy_key
commands:
- echo "Deploying application..."
- # Add deployment commands here (e.g., SSH, Rsync, Kubernetes, etc.)
- echo "Hello, World! Everything is running fine!"
# Specify trigger conditions
trigger:
branch:
- main
event:
- push
- pull_request
# Step 2: Cleanup
- name: cleanup
image: alpine:latest
commands:
- echo "Cleaning up any created data..."
- rm -rf /tmp/* # Example cleanup, adjust based on what needs cleanup
- echo "Cleanup complete!"

View File

@@ -1,20 +0,0 @@
{
"name": "client",
"version": "1.0.0",
"private": true,
"scripts": {
"start": "react-scripts start",
"build": "react-scripts build",
"test": "react-scripts test --watchAll=false",
"eject": "react-scripts eject"
},
"dependencies": {
"react": "^18.0.0",
"react-dom": "^18.0.0",
"react-scripts": "5.0.1"
},
"devDependencies": {
"@testing-library/react": "^13.0.0",
"jest": "^29.0.0"
}
}

View File

@@ -1,11 +0,0 @@
import React from 'react';
function App() {
return (
<div>
<h1>Hello, World!</h1>
</div>
);
}
export default App;

View File

@@ -1,8 +0,0 @@
import { render, screen } from '@testing-library/react';
import App from './App';
test('renders Hello, World!', () => {
render(<App />);
const headingElement = screen.getByText(/Hello, World!/i);
expect(headingElement).toBeInTheDocument();
});

View File

@@ -1,10 +0,0 @@
from flask import Flask
def create_app():
app = Flask(__name__)
@app.route("/")
def hello_world():
return "Hello, World!"
return app

View File

@@ -1,4 +0,0 @@
import os
class Config:
SECRET_KEY = os.environ.get("SECRET_KEY", "default_secret_key")

View File

@@ -1,3 +0,0 @@
from . import create_app
app = create_app()

View File

@@ -1,6 +0,0 @@
from app import create_app
app = create_app()
if __name__ == "__main__":
app.run()

View File

@@ -1,4 +0,0 @@
Flask==2.2.2
pytest==7.2.0
gunicorn==20.1.0
psycopg2-binary==2.9.6

View File

@@ -1,19 +0,0 @@
import pytest
from app import create_app
@pytest.fixture
def app():
app = create_app()
app.config.update({
"TESTING": True,
})
return app
@pytest.fixture
def client(app):
return app.test_client()
def test_hello_world(client):
response = client.get("/")
assert response.status_code == 200
assert response.data == b"Hello, World!"