import {delay} from "redux-saga"; import {call, put, select} from "redux-saga/effects"; import {addPropToStoreObject, addToStore} from "../actions/objects"; import {setLastSimulatedTick} from "../actions/simulation/tick"; import {addToStates} from "../actions/states"; import { deleteExperiment, getAllMachineStates, getAllRackStates, getAllRoomStates, getAllTaskStates, getExperiment, getLastSimulatedTick } from "../api/routes/experiments"; import {getTasksOfJob} from "../api/routes/jobs"; import {addExperiment, getExperimentsOfSimulation, getSimulation} from "../api/routes/simulations"; import {getJobsOfTrace} from "../api/routes/traces"; import {fetchAndStoreAllSchedulers, fetchAndStoreAllTraces, fetchAndStorePathsOfSimulation} from "./objects"; import {fetchAllDatacentersOfExperiment} from "./topology"; export function* onOpenExperimentSucceeded(action) { try { const simulation = yield call(getSimulation, action.simulationId); yield put(addToStore("simulation", simulation)); const experiment = yield call(getExperiment, action.experimentId); yield put(addToStore("experiment", experiment)); yield fetchExperimentSpecifications(); yield fetchWorkloadOfTrace(experiment.traceId); yield fetchAllDatacentersOfExperiment(experiment); yield startStateFetchLoop(action.experimentId); } catch (error) { console.error(error); } } function* startStateFetchLoop(experimentId) { try { while (true) { const lastSimulatedTick = (yield call(getLastSimulatedTick, experimentId)).lastSimulatedTick; if (lastSimulatedTick !== (yield select(state => state.lastSimulatedTick))) { yield put(setLastSimulatedTick(lastSimulatedTick)); const taskStates = yield call(getAllTaskStates, experimentId); const machineStates = yield call(getAllMachineStates, experimentId); const rackStates = yield call(getAllRackStates, experimentId); const roomStates = yield call(getAllRoomStates, experimentId); yield addAllStates("task", taskStates); yield addAllStates("machine", machineStates); yield addAllStates("rack", rackStates); yield addAllStates("room", roomStates); yield delay(5000); } else { yield delay(10000); } } } catch (error) { console.error(error); } } function* addAllStates(objectType, states) { for (let i in states) { yield put(addToStates(objectType, states[i].tick, states[i])); } } export function* onFetchExperimentsOfSimulation() { try { const currentSimulationId = yield select(state => state.currentSimulationId); yield fetchExperimentSpecifications(); const experiments = yield call(getExperimentsOfSimulation, currentSimulationId); for (let i in experiments) { yield put(addToStore("experiment", experiments[i])); } yield put(addPropToStoreObject("simulation", currentSimulationId, {experimentIds: experiments.map(experiment => experiment.id)})); } catch (error) { console.error(error); } } function* fetchExperimentSpecifications() { try { const currentSimulationId = yield select(state => state.currentSimulationId); yield fetchAndStorePathsOfSimulation(currentSimulationId); yield fetchAndStoreAllTraces(); yield fetchAndStoreAllSchedulers(); } catch (error) { console.error(error); } } function* fetchWorkloadOfTrace(traceId) { try { const jobs = yield call(getJobsOfTrace, traceId); for (let i in jobs) { const job = jobs[i]; const tasks = yield call(getTasksOfJob, job.id); job.taskIds = tasks.map(task => task.id); for (let j in tasks) { yield put(addToStore("task", tasks[j])); } yield put(addToStore("job", job)); } yield put(addPropToStoreObject("trace", traceId, {jobIds: jobs.map(job => job.id)})) } catch (error) { console.error(error); } } export function* onAddExperiment(action) { try { const currentSimulationId = yield select(state => state.currentSimulationId); const experiment = yield call(addExperiment, currentSimulationId, Object.assign({}, action.experiment, { id: -1, simulationId: currentSimulationId }) ); yield put(addToStore("experiment", experiment)); const experimentIds = yield select(state => state.objects.simulation[currentSimulationId].experimentIds); yield put(addPropToStoreObject("simulation", currentSimulationId, {experimentIds: experimentIds.concat([experiment.id])})); } catch (error) { console.error(error); } } export function* onDeleteExperiment(action) { try { yield call(deleteExperiment, action.id); const currentSimulationId = yield select(state => state.currentSimulationId); const experimentIds = yield select(state => state.objects.simulation[currentSimulationId].experimentIds); yield put(addPropToStoreObject("simulation", currentSimulationId, {experimentIds: experimentIds.filter(id => id !== action.id)})); } catch (error) { console.error(error); } }