1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
name: IronCrypt CI/CD
on:
push:
branches:
pull_request:
branches:
env:
CARGO_TERM_COLOR: always
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
# Installer Rust
- name: Set up Rust
uses: actions-rs/toolchain@v1
with:
toolchain: stable
override: true
# Installer les dépendances système
- name: Install Dependencies
run: sudo apt-get update && sudo apt-get install -y pkg-config libssl-dev
# Mettre en cache le dossier cargo registry
- name: Cache cargo registry
uses: actions/cache@v3
with:
path: ~/.cargo/registry
key: ${{ runner.os }}-cargo-registry-${{ hashFiles('**/Cargo.lock') }}
restore-keys: |
${{ runner.os }}-cargo-registry-
# Mettre en cache le dossier target
- name: Cache cargo build
uses: actions/cache@v3
with:
path: target
key: ${{ runner.os }}-cargo-build-${{ hashFiles('**/Cargo.lock') }}
restore-keys: |
${{ runner.os }}-cargo-build-
# Construire et tester l'application
- name: Build and Test
run: |
cargo build --release
cargo test --release
# Construire l'image Docker
- name: Build Docker Image
run: docker build -t ironcrypt.
# Pousser l'image Docker vers DockerHub
- name: Push Docker Image to DockerHub
if: success()
env:
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }}
run: |
echo "${DOCKER_PASSWORD}" | docker login -u "${DOCKER_USERNAME}" --password-stdin
docker tag ironcrypt ${{ secrets.DOCKER_USERNAME }}/ironcrypt:latest
docker push ${{ secrets.DOCKER_USERNAME }}/ironcrypt:latest