.vscode | ||
src | ||
.dockerignore | ||
.gitignore | ||
data.txt | ||
Dockerfile | ||
house-price-dataset.zip | ||
Jenkinsfile | ||
Jenkinsfile2 | ||
Jenkinsfile3 | ||
Jenkinsfile.eval | ||
README.md | ||
result.txt | ||
startscript1.sh | ||
startscript2.sh |
Projekt na przedmiot inżynieria oprogramowania
IUM_6 opis sposobu rozwiązania zadań i podpunktów
Zadanie 1
- stworzono job s444417-training
- s444417-training uruchamia się automatycznie po zakończeniu joba s444417-create-dataset, plik Jenkinsfile, przy pomocy build job. Kopiuje zbiór danych przy pomocy copyArtifact w pliku Jenkinsfile3
- Jenkinsfile3 przy pomocy archiveArtifacts
- powiadomienia, Jenkinsfile3 przy pomocy post emailext
- parametr EPOCH_NUMBER zadekalarowany w Jenkinsfile3, oznaczaj ilość epok, wykorzystywany przy wołaniu skryptu uczącego
Zadanie 2
- stworzono job s444417-evaluation
- evaluacja modelu metodą evaluate zawołana na modelu w pliku trainScript.py.Zapisanie wyniku do pliku trainResults.csv, w Jenkinsfile.eval archiveArtifact
- Jenkinsfile.eval w stagu "Copy prev build artifact" kopiuje trainResults.csv a jeśli go nie ma to catch łapie error, skrypt trainScript.py też obsługuje brak takiego pliku, bo otwiera go w trybie "a+"
- skrypt trainScript.py tworzy plota z wczytanych wartości odczytanych z pliku trainResults.csv, natomiast nei ma jak tego podejrzeć w Jenkins
- projekt odpala się po zakończeniu trenowania jenkinsfile3 build job oraz kopiuje sobie model copyArtifacts z uwzględnieniem brancha master
- copyArtifacts z s444417-create-dataset
- parametr BRANCH do wyboru konkretnej gałęzi, buildselector do wybrania builda
- powiadomenie mail wysyłane w pliku Jenkinsfile.eval post emailext