-
Notifications
You must be signed in to change notification settings - Fork 215
130 lines (114 loc) · 5 KB
/
federated_runtime.yml
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
#---------------------------------------------------------------------------
# Workflow to run 301_MNIST_Watermarking notebook
# Authors - Noopur, Payal Chaurasiya
#---------------------------------------------------------------------------
name: Federated Runtime 301 MNIST Watermarking
on:
pull_request:
types: [opened, synchronize, reopened, ready_for_review]
workflow_dispatch:
permissions:
contents: read
jobs:
run_notebook:
if: github.event.pull_request.draft == false
runs-on: ubuntu-22.04
timeout-minutes: 10
steps:
- name: Checkout OpenFL repository
uses: actions/[email protected]
with:
fetch-depth: 2 # needed for detecting changes
submodules: "true"
token: ${{ secrets.GITHUB_TOKEN }}
- name: Set up Python
uses: actions/setup-python@v3
with:
python-version: "3.10"
- name: Install Jupyter Lab Package
run: pip install jupyterlab
- name: Install dependencies # Without this step, fx command will not work
id: install_dependencies
run: |
python -m pip install --upgrade pip
pip install .
- name: Activate and run the director in background
run: |
ps -ef| grep -e "director start" -e "envoy start"
cd openfl-tutorials/experimental/workflow/FederatedRuntime/301_MNIST_Watermaking
fx experimental activate
cd director
nohup ./start_director.sh &> director.log &
- name: Run the envoy Bangalore in background
run: |
cd openfl-tutorials/experimental/workflow/FederatedRuntime/301_MNIST_Watermaking
cd Bangalore
nohup ./start_envoy.sh Bangalore Bangalore_config.yaml &> bangalore.log &
- name: Run the envoy Chandler in background
run: |
cd openfl-tutorials/experimental/workflow/FederatedRuntime/301_MNIST_Watermaking
cd Chandler
nohup ./start_envoy.sh Chandler Chandler_config.yaml &> chandler.log &
- name: Check if envoys are connected to the director
run: |
cd openfl-tutorials/experimental/workflow/FederatedRuntime/301_MNIST_Watermaking
timeout=60
connected=false
while [ $timeout -gt 0 ]; do
if grep "Bangalore is connected to the director" ./Bangalore/bangalore.log && grep "Chandler is connected to the director" ./Chandler/chandler.log; then
connected = true
break
else
echo "Waiting for both envoys to connect to the director"
fi
sleep 5
timeout=$((timeout-5))
done
if [ $connected = false ]; then
echo "Envoys are not connected to the director in 60 seconds"
echo "| Failure Reason |" >> $GITHUB_STEP_SUMMARY
echo "| -------------- |" >> $GITHUB_STEP_SUMMARY
echo "Envoys are not connected to the director in 60 seconds" >> $GITHUB_STEP_SUMMARY
exit 1
fi
- name: Run Notebook
run: |
ps -ef| grep -e "director start" -e "envoy start"
cd openfl-tutorials/experimental/workflow/FederatedRuntime/301_MNIST_Watermaking/workspace
jupyter nbconvert --execute --to notebook ./MNIST_Watermarking.ipynb
echo "Notebook run completed"
- name: Check if the experiment was successful using logs
run: |
cd openfl-tutorials/experimental/workflow/FederatedRuntime/301_MNIST_Watermaking
if grep "End of Federation reached." ./Bangalore/bangalore.log; then
echo "Process for Bangalore envoy is successful"
else
echo "Process for Bangalore envoy failed"
fi
if grep "End of Federation reached." ./Chandler/chandler.log; then
echo "Process for Chandler envoy is successful"
else
echo "Process for Chandler envoy failed"
fi
if grep "Experiment FederatedFlow_MNIST_Watermarking was finished successfully" ./director/director.log; then
echo "Notebook run was successful"
else
echo "Notebook run failed"
fi
- name: Tar files
if: ${{ always() }} # collect artifacts regardless of failures
run: |
tar -cvf notebook.tar \
./openfl-tutorials/experimental/workflow/FederatedRuntime/301_MNIST_Watermaking/workspace/MNIST_Watermarking.nbconvert.ipynb \
./openfl-tutorials/experimental/workflow/FederatedRuntime/301_MNIST_Watermaking/workspace/MNIST_Watermarking.ipynb \
./openfl-tutorials/experimental/workflow/FederatedRuntime/301_MNIST_Watermaking/director/director.log \
./openfl-tutorials/experimental/workflow/FederatedRuntime/301_MNIST_Watermaking/Bangalore/bangalore.log \
./openfl-tutorials/experimental/workflow/FederatedRuntime/301_MNIST_Watermaking/Chandler/chandler.log \
--ignore-failed-read
echo "TAR file created"
- name: Upload Artifacts
uses: actions/upload-artifact@v4
if: ${{ always() }} # collect artifacts regardless of failures
with:
name: federated_runtime_301_watermarking_${{ github.run_id }}
path: notebook.tar