|
18 | 18 | @test mlf.baseuri == mlflowbaseuri
|
19 | 19 | @test mlf.apiversion == 2.0
|
20 | 20 |
|
21 |
| - if mlflow_server_is_running(mlf) |
22 |
| - |
23 |
| - exptags = [:key => "val"] |
24 |
| - expname = "expname-$(UUIDs.uuid4())" |
25 |
| - |
26 |
| - @test ismissing(getexperiment(mlf, "$(UUIDs.uuid4()) - $(UUIDs.uuid4())")) |
27 |
| - |
28 |
| - experiment_id = createexperiment(mlf; name=expname, tags=exptags) |
29 |
| - experiment = getexperiment(mlf, experiment_id) |
30 |
| - @test experiment.experiment_id == experiment_id |
31 |
| - experimentbyname = getexperiment(mlf, expname) |
32 |
| - @test experimentbyname.name == experiment.name |
33 |
| - |
34 |
| - |
35 |
| - exprun = createrun(mlf, experiment_id) |
36 |
| - @test exprun.info.experiment_id == experiment_id |
37 |
| - @test exprun.info.lifecycle_stage == "active" |
38 |
| - @test exprun.info.status == MLFlowRunStatus("RUNNING") |
39 |
| - exprunid = exprun.info.run_id |
40 |
| - |
41 |
| - logparam(mlf, exprunid, "paramkey", "paramval") |
42 |
| - logparam(mlf, exprunid, Dict("k" => "v", "k1" => "v1")) |
43 |
| - logparam(mlf, exprun, Dict("test1" => "test2")) |
44 |
| - |
45 |
| - logmetric(mlf, exprun, "metrickeyrun", 1.0) |
46 |
| - logmetric(mlf, exprun.info, "metrickeyrun", 2.0) |
47 |
| - logmetric(mlf, exprun.info, "metrickeyrun", [2.5, 3.5]) |
48 |
| - logmetric(mlf, exprunid, "metrickey", 1.0) |
49 |
| - logmetric(mlf, exprunid, "metrickey2", [1.0, 1.5, 2.0]) |
50 |
| - |
51 |
| - retrieved_run = getrun(mlf, exprunid) |
52 |
| - @test exprun.info == retrieved_run.info |
53 |
| - |
54 |
| - tmpfiletoupload = tempname() |
55 |
| - f = open(tmpfiletoupload, "w") |
56 |
| - write(f, "samplecontents") |
57 |
| - close(f) |
58 |
| - logartifact(mlf, retrieved_run, tmpfiletoupload) |
59 |
| - rm(tmpfiletoupload) |
| 21 | + if !mlflow_server_is_running(mlf) |
| 22 | + return nothing |
| 23 | + end |
60 | 24 |
|
61 |
| - running_run = updaterun(mlf, exprunid, "RUNNING") |
62 |
| - @test running_run.info.experiment_id == experiment_id |
63 |
| - @test running_run.info.status == MLFlowRunStatus("RUNNING") |
64 |
| - finished_run = updaterun(mlf, exprun, MLFlowRunStatus("FINISHED")) |
65 |
| - finishedrun = getrun(mlf, finished_run.info.run_id) |
| 25 | + exptags = [:key => "val"] |
| 26 | + expname = "expname-$(UUIDs.uuid4())" |
| 27 | + |
| 28 | + @test ismissing(getexperiment(mlf, "$(UUIDs.uuid4()) - $(UUIDs.uuid4())")) |
| 29 | + |
| 30 | + experiment_id = createexperiment(mlf; name=expname, tags=exptags) |
| 31 | + experiment = getexperiment(mlf, experiment_id) |
| 32 | + @test experiment.experiment_id == experiment_id |
| 33 | + experimentbyname = getexperiment(mlf, expname) |
| 34 | + @test experimentbyname.name == experiment.name |
| 35 | + |
| 36 | + exprun = createrun(mlf, experiment_id) |
| 37 | + @test exprun.info.experiment_id == experiment_id |
| 38 | + @test exprun.info.lifecycle_stage == "active" |
| 39 | + @test exprun.info.status == MLFlowRunStatus("RUNNING") |
| 40 | + exprunid = exprun.info.run_id |
| 41 | + |
| 42 | + logparam(mlf, exprunid, "paramkey", "paramval") |
| 43 | + logparam(mlf, exprunid, Dict("k" => "v", "k1" => "v1")) |
| 44 | + logparam(mlf, exprun, Dict("test1" => "test2")) |
| 45 | + |
| 46 | + logmetric(mlf, exprun, "metrickeyrun", 1.0) |
| 47 | + logmetric(mlf, exprun.info, "metrickeyrun", 2.0) |
| 48 | + logmetric(mlf, exprun.info, "metrickeyrun", [2.5, 3.5]) |
| 49 | + logmetric(mlf, exprunid, "metrickey", 1.0) |
| 50 | + logmetric(mlf, exprunid, "metrickey2", [1.0, 1.5, 2.0]) |
| 51 | + |
| 52 | + retrieved_run = getrun(mlf, exprunid) |
| 53 | + @test exprun.info == retrieved_run.info |
| 54 | + |
| 55 | + tmpfiletoupload = tempname() |
| 56 | + f = open(tmpfiletoupload, "w") |
| 57 | + write(f, "samplecontents") |
| 58 | + close(f) |
| 59 | + logartifact(mlf, retrieved_run, tmpfiletoupload) |
| 60 | + rm(tmpfiletoupload) |
| 61 | + |
| 62 | + running_run = updaterun(mlf, exprunid, "RUNNING") |
| 63 | + @test running_run.info.experiment_id == experiment_id |
| 64 | + @test running_run.info.status == MLFlowRunStatus("RUNNING") |
| 65 | + finished_run = updaterun(mlf, exprun, MLFlowRunStatus("FINISHED")) |
| 66 | + finishedrun = getrun(mlf, finished_run.info.run_id) |
66 | 67 |
|
67 |
| - # NOTE: seems like MLFlow API never returns `end_time` as documented in https://mlflow.org/docs/latest/rest-api.html#runinfo |
68 |
| - # Consider raising an issue with MLFlow itself. |
69 |
| - @test_broken !ismissing(finishedrun.info.end_time) |
70 |
| - |
71 |
| - runs = searchrun(mlf, experiment_id, "params.\"paramkey\" == \"paramval\"") |
72 |
| - |
73 |
| - deleterun(mlf, exprunid) |
74 |
| - |
75 |
| - deleteexperiment(mlf, experiment_id) |
76 |
| - experiment = getexperiment(mlf, experiment_id) |
77 |
| - @test experiment.experiment_id == experiment_id |
78 |
| - @test experiment.lifecycle_stage == "deleted" |
79 |
| - end |
| 68 | + # NOTE: seems like MLFlow API never returns `end_time` as documented in https://mlflow.org/docs/latest/rest-api.html#runinfo |
| 69 | + # Consider raising an issue with MLFlow itself. |
| 70 | + @test_broken !ismissing(finishedrun.info.end_time) |
| 71 | + |
| 72 | + exprun2 = createrun(mlf, experiment_id) |
| 73 | + exprun2id = exprun.info.run_id |
| 74 | + logparam(mlf, exprun2, "param2", "key2") |
| 75 | + logmetric(mlf, exprun2, "metric2", [1.0, 2.0]) |
| 76 | + updaterun(mlf, exprun2, "FINISHED") |
| 77 | + |
| 78 | + @show experiment_id |
| 79 | + runs = searchruns(mlf, experiment_id) |
| 80 | + @test length(runs) == 2 |
| 81 | + # , "params.\"paramkey\" == \"paramval\"") |
| 82 | + # deleterun(mlf, exprunid) |
| 83 | + |
| 84 | + # deleteexperiment(mlf, experiment_id) |
| 85 | + # experiment = getexperiment(mlf, experiment_id) |
| 86 | + # @test experiment.experiment_id == experiment_id |
| 87 | + # @test experiment.lifecycle_stage == "deleted" |
80 | 88 | end
|
0 commit comments