From 4cc0debbe4f3781f849e45a31fca0912198bea97 Mon Sep 17 00:00:00 2001 From: Simon Murray Date: Thu, 5 Dec 2024 11:14:43 +0000 Subject: [PATCH] Status Propagation (Part 2) (#18) Make it so the reconciler loops until everything is healthy, and thus requires roll up of individual machine statuses. --- go.mod | 4 +- go.sum | 8 +- pkg/openapi/schema.go | 181 +++++++++--------- .../managers/cluster/provisioner.go | 27 ++- pkg/provisioners/managers/cluster/server.go | 14 +- 5 files changed, 129 insertions(+), 105 deletions(-) diff --git a/go.mod b/go.mod index 0572e27..230096a 100644 --- a/go.mod +++ b/go.mod @@ -7,9 +7,10 @@ require ( github.com/go-chi/chi/v5 v5.1.0 github.com/oapi-codegen/runtime v1.1.1 github.com/spf13/pflag v1.0.5 + github.com/spjmurray/go-util v0.1.3 github.com/unikorn-cloud/core v0.1.85 github.com/unikorn-cloud/identity v0.2.45 - github.com/unikorn-cloud/region v0.1.47-rc2 + github.com/unikorn-cloud/region v0.1.47-rc4 go.opentelemetry.io/otel/sdk v1.31.0 k8s.io/api v0.31.1 k8s.io/apimachinery v0.31.1 @@ -61,7 +62,6 @@ require ( github.com/prometheus/client_model v0.6.1 // indirect github.com/prometheus/common v0.60.0 // indirect github.com/prometheus/procfs v0.15.1 // indirect - github.com/spjmurray/go-util v0.1.3 // indirect github.com/x448/float16 v0.8.4 // indirect go.opentelemetry.io/otel v1.31.0 // indirect go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.31.0 // indirect diff --git a/go.sum b/go.sum index c2a60d7..a59abe7 100644 --- a/go.sum +++ b/go.sum @@ -131,16 +131,16 @@ github.com/spjmurray/go-util v0.1.3/go.mod h1:fARcBeaHio/6h9H7Ht+egZPBZMNxEwxmHC github.com/spkg/bom v0.0.0-20160624110644-59b7046e48ad/go.mod h1:qLr4V1qq6nMqFKkMo8ZTx3f+BZEkzsRUY10Xsm2mwU0= github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= -github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg= -github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= +github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA= +github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= github.com/ugorji/go/codec v1.2.12 h1:9LC83zGrHhuUA9l16C9AHXAqEV/2wBQ4nkvumAE65EE= github.com/ugorji/go/codec v1.2.12/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg= github.com/unikorn-cloud/core v0.1.85 h1:S4B0nr0jhxF8SCsKyCRVwcx8+kJsI8fQVONLJDf9aic= github.com/unikorn-cloud/core v0.1.85/go.mod h1:wEKzCwAnIyTbo27l++Wl+gK95TAxMsFS3y3jbFB03aw= github.com/unikorn-cloud/identity v0.2.45 h1:YFmw3uunwdZMuYiimv4lfU6s7iTtYoc22xJqLTrlOVg= github.com/unikorn-cloud/identity v0.2.45/go.mod h1:WzNNv05ReDMLfWsOtq53uzhX2GU2nXDw76Bdsf3BPnM= -github.com/unikorn-cloud/region v0.1.47-rc2 h1:eIwFHSoMojjg7MSFirDuNEnaNSWCygtKQRdNhqFIqzw= -github.com/unikorn-cloud/region v0.1.47-rc2/go.mod h1:cofPuJjseRKE95xAqNa23nSL7/+LDXOBxNIHwwODpys= +github.com/unikorn-cloud/region v0.1.47-rc4 h1:rS5vyND9vqMCib5Vd+IktHB4+erRp/+oWzHO20quqsI= +github.com/unikorn-cloud/region v0.1.47-rc4/go.mod h1:cofPuJjseRKE95xAqNa23nSL7/+LDXOBxNIHwwODpys= github.com/x448/float16 v0.8.4 h1:qLwI1I70+NjRFUR3zs1JPUCgaCXSh3SW62uAKT1mSBM= github.com/x448/float16 v0.8.4/go.mod h1:14CWIYCyZA/cWjXOioeEpHeN/83MdbZDRQHoFcYsOfg= github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= diff --git a/pkg/openapi/schema.go b/pkg/openapi/schema.go index 84af67d..218d162 100644 --- a/pkg/openapi/schema.go +++ b/pkg/openapi/schema.go @@ -20,96 +20,97 @@ import ( // Base64 encoded, gzipped, json marshaled Swagger object var swaggerSpec = []string{ - "H4sIAAAAAAAC/+w9a3PbNrZ/BcO7M9vOpSRKlmVLX3bcZJv1tGk8cZLeu7GvBySPJNQkwAVA24pH//0O", - "HqRIEXrL6babaWdiicDBwXnhvEA9exFLM0aBSuGNnr0Mc5yCBK4/RUkuJPDL11fF1+rbGETESSYJo97I", - "+zAFZMchilNoo7e5kCgEhNEDTkiMXv9yjSJGJSaU0AliNJmhhD0CRxEWgKIp5jhSS/o3lOZpCFwgxtF0", - "lk2BCh8JiblEmMYIaIweiZwivJilhppZvh6jFpYoZULe0MFJBToiFCVAJ3La9nyPKNwzLKee7ym0vdFi", - "t57vcfhXTjjE3kjyHHxPRFNIsdr9XziMvZH3X50F4Trmqejc5yFwChLELziFBdHmc99jfIIp+YIV2TYS", - "tDrYUNWNch3oi+CdcfYbRHIjynbcOmxLUC+CKIfJNqQ1wxCJgUoyJsBXIFuAewFc5wYkCPkDiwkYVeOA", - "JbxiaZZLeGUk8b0ZpB8zKoHqP3GWJSTSLO/8JtS+nj14wmmWgPozBYljLDV6dcH25r4nMojUE7u72Bt5", - "YXA6DE9g0BpiOG31e+FZa9gP+61xvzcOz/AgxACe7z0yfp8wHF8xlghv9PnZGxMOjzhJFDxCJxyE+T4i", - "MfdGn73usNfuDs7b3XbQ6fW9W9/LGNdbMPrqjc4DI2CSRSzxRp6MMm/uVyAEbf1f59zzve6ZAqc/dntV", - "aBzTid460NgbdYfDoe9pm+GNusFgMHescTv3PZJiM40Jb+TlYU5l7vneA3ChpaUXtIP+3PdSHE0J1SPH", - "CX5gXFMtOjsdnEMvbo2HOGz1T0/i1hCf4NZp9+TsdHx23u8NQq+ySEyE5My5kNfrt4O+p6VCs1Z4o5N5", - "KYgxjHGeSM/3sjxMSHR5dZEkzAiA2TUOk0I45/Nbtd/tJDSqSduvnEgw0lnXGiuUpZW3sosWZ0W7oSRG", - "xkXGqLDyvSTZ5tH+oq31hTD6gWgi9YLeSSs4a510P3SDUf901D/9pyL/DqxaUpYli60Axf1BEMQDaMFw", - "cNrqh/1+C58H563z/jjsjfHJ4CzoeQuLqdfG0OsO47NWN1DKNQi6rfOoF7UAziAYDMLhSQRmygNR0kDo", - "5FpimQtjLs2XEH9TXbfqNrVqjFOSzLTahARTz/fulRVW0xNC86e64gVW8f5wOq7JpMXk2cFeux3zYcqE", - "tMvY71tdLXLkAUu4vPJGBbO6lfXVtwXXlFALp1TeOnaw2GB3f2P0HnDsskUXaMkatRVN63PFPtbl8zfz", - "8s28NMyLIAeYlz+sA/HHMS63+1kX4TYtCRESsfGyiRHaxuSU3DNOW1HC8vguYhzuUkzoXXY/uWMZUJyR", - "u4ilKaN3OIogkxBX7ZArEDFu1BQLFAJQVEzTYewjSRIVy47zZEySRH0rZjSackZZLpJZ+4b+L8tRimco", - "Y0mCpIYoWM4j0ABSRolkHBEpkKEvGjOOFCESUGjsuqsQxzYg2c97A84Z90YeoTotcGf37/nmyV2dQgV1", - "QhbPkJ3ibX2Y7LAtg5ZDHt5XMRhjonhg4Ju8ht6ojxi3tDejYwYCUSaLjMcNxSV3jIOMxgSSeGehihgd", - "JyQ6kPgFlBVUxwsZ0nkWhbfAKeioHuGEA45nCJ6IkOJrc8PiVexA2EwQZXIK3Ee5yHGSzJCcEoFSwFQo", - "7Gdoih+gvo9dKT9mPCRxDPQw0pdgVtA+F8BRxEEnJnAiUMy0IJUbKAVIWVeSwATE76MRj1igGCiBGIUz", - "hHM5ZZwIqw+G/nimjFeEc2EGKfxrA2+oZPdAix0SOqnvUUQsA22xMEUXV5elomkyKS2jf13Q5oZSiEAI", - "zGcV6iBG9RR9qsTAUZZgOWY83VUCCJXAKU6ugT8A/7uiz2GyIDQgS2m3OFiLIxkyhIoSTNKvy+8LinIK", - "TxlE6lTSwxCLopxziOuMxrWRkmMqCFBp52Aa31A1UuRRBBArvihLI/msjS7HBhLRDFXsirAAH2UJYKEE", - "QjlziEiEhVqGCJHvrMGUyR9ZTuPDmEaZvBsrMCs4VjkGIF4Y0vJE0Gbz63Lwo3btlBCNCY3RwrzvSsGc", - "Wu39AgdSUXk5QtwZ+7HqGMrlVFlBA80evl9Z9l0oFDbI7MEqpvLf4ClTVstBVRNONde3FsAEBC8QsXaH", - "Z0Er6LaC7ocgGOn/y4h1iM+jwclZ0OoHKtCM+7g1jHHQOhucncfjfhDFw3gRsU7a/faUTKYppG3cDYJ2", - "d9LuBpOwGjRGWf5jERldUgkJ+h9gFF0lWBKap+i8Owg+oO+u72cJvofvPV/NEN6o76u45l7FSr43yXIF", - "K2ETEuHkFcsVEXq+l0LK+MwbDfq+l7JYB1uXVEhCI4neXvZOAxVaTGeiMq2rwiMaa4m7ePta53gsmJPe", - "DnHDPsxcH1zYQbuLio4EXyy30Wv1eh+6vVHQH3VPSknBg/542BsMWycDCFr9k26vFZ7H3dZpLx6exKeD", - "YXhWyW3kYd7rBf3WQ7fdO20PWpMsb532Ttvnp+3gtHUWQdzvnvarcmNZHnPyoKJ+rxztWVarKNO76AaK", - "xf+w//SCQAX5JX9/+XT5+vJCgWU21RyDxYiyMAHP3zNPiDnBirz2uHaH3IKN5SPm8Mk80hgsSj/eyLPU", - "UGMfCJc5TmzSRz0rvlDm7YWk0sjNeqE0Y5CcYokwBx0lYknU2WHjACKq3lNpih25/bcmD3BdphDWVxNs", - "2sDGqG2TrcqAS1sYW2QYliHZhVAxQs2Vs0zxXUhO6MSb1zIRq+bbIejyCuE45iCEG1KZvFgJSI/YBGeR", - "WznSGVac6VfNLF9RajSFmc8LYpZo3JYYsvA3iGQznWp3J1YxdGXepGCtqPCWSEjFbsmaujzNS3wx53jW", - "RFdnjjdKnQpkm7JWtZJHYo7N1l6rcCYugliF49tirYo53J4o12rG1sK0NNctG+XmLT6bJePaor2e1MVx", - "s1QvrFN+kXVeU7OXDJUJQhMp2CUIdWraUu5yp2JobeoyqUpsl9fYgmZbmsVV5vBYe6oIwQaMq9Nc2r+M", - "eYEhyhhLHDq2yIavQ90O04uWqezlxX+tLoVWnAFLvLPmr0Djdqf9b8u9Gg1W8nKRSd/DHoqFQTyAONWM", - "+jKAX3QtRhn2AtEKAEIlTMrOmwZ5S6i70Xen46VG5H1Pl5p0qyiB0EsDpbvppHHp097oH3ZGOmR040Fp", - "+j22M9+gIt88i7GEr3JqFi7NMQ7Jg4+5Xbi6LwNNvbvJsmoldWVEaccgnicgkA4FTeYQbzLGZXF2Pa7F", - "Cu/VAu4zozrEhWwNyZ1wNCXfNRy4fP0ehQmL7oWGlyTs0UdEopRMpqYRlc7Q5dVDXwnx5dXDABFqZlEm", - "sSmFVZjWsJDLPCmqy9tS7EqNr5WaV/RP6qflHhRSQPNUCa2MMs/38jiriOuK861cxSLqGwLebuDZld2U", - "AzHGJYphTCiR1gvT+CHJ8XhMoibHiiL+SmjVLS6fJ/6iar8Lgd/rSRtFczF0NXZ6/S22qZsKXFCAxkow", - "ZQ2ge6+2G8EFxbQ9bwVnSQQMUF8juInv4miWZSurVzMTDt3SiYhrSCCSzKn1JqlhEhZI2IFN3hQJnyPm", - "UZh4bYDOK6khZ/N2BhxLQidIzISEFNnRTverzChtB8mMVhzIBfiIjHVlQWsnxMro6b6BXJiKYYIlCLnZ", - "J7bUcsnKqi7mNYHAobcA0DEvAaA1dwBS/PSz/uCNBifa9Ss+dh2cqkYkW4RBdrhTNO83CeYDS/IUlh2A", - "bRRLzym7jJbR/FE/QZev9fbX77fsPFq3bF1f56tajNaBcMzYMSwxZWLtQZNINwEI8gVs4GNLNil+Imme", - "FhVlnEvWEhFOYGHAmtY5F8BfW892qbBmnxQiLVCIBQz6LaARiyHWbQpkknOT+iB0zHhq/mYcGUjCqjHK", - "M0ZRgnMaabE0Q72RF84kbNTdklAVvhfMcym0m0HL0lxJZZbjkACpjJFwHYW2hWwZ0t9NAdIFrkLykLEE", - "MG3srQDr2sfORb4Gbm+AAieRLVKnIASegN/IfTOcy2nPsWc31AukDA1YqIZpCJ4yTGNj97Q4/uPDhys7", - "RMlLG+mmAqGT70qS4mLguwu1OlKhChnbCo+Pwtzk6Q1csAZR4ccJSMxnRcuXAm704+LqUiDdK4PkFCvg", - "TEAB1zRpmLWqfmezV6taCL6LEgJUfbtc1M2pyDPls4CaaypWd5qFfglTd3ioKKzeCyEhzRjHnCSzu5zi", - "B0wSbIo4xcRy1eKLCcdULq2qvyuWrFbuKx1QKcgpi+/UU+3qNVBPISa4ALLo37l1WEtHGXtZMj4BDxXN", - "raQh8zQsWl80hM1n9eqekQO1ZHHS/4xDSD7hJHdGcuY4/ykPQQ9GiRqtvs3BR3KWWROsO3+U4JWNEMov", - "sDWmCFMUwg0lNIYn5bgYYVdxuZJ+rWxYSuBqyf/7HLSGF61/4taX2+/+Nlp8at21b58Df9CdV0Z8/7e/", - "uPysHQhRbcxek7cfPXs4Sd6NdX31yHmPpQLB85LpWW4d33iFcHHbrd4oGkLC6EQdRJsFb2nRprTd7kbm", - "zZWRl6Dwlsxt0rzSdr/u+uMxKL1Y6mAiNxJpDeTLxsoiMWYVXDtKSaLOjcUuOOBYmP5kTiQ4PIG1FvBD", - "lSKVR7aZjOkP2nrgfJIqFmsi6uZTfcKlTBenqYQndzhVpMKPJC1Om6jCVjw5ZgVX4snPujfMlUzfk+OO", - "avAqwS3Haa8BlGtd7RRbuAM5vafskS7dKKl+1EdoDEuPzZl1e5hZ5l/LRJg44n0zBf3ckHXTSW8aaVzE", - "lSSFuh0wvbMJSIhrvn6MJbTUcHcTg4uXX799wIGHw0L5O1oYbVR2bUgUkD7AigxRiqkkUZEsWXImHm5u", - "4v++uWlX/jnUYVghMC/pIKyRSlOwiX+YuUVS908/Tpkt7MQ18XTa1Hq/2PZibhfYXszJirM1p+RfeQW4", - "SV80EzQs1qHMxp2bQtYWOy8gbtg5ru/bgt9230s6RnSQUiX5Fir2wVx6sOpFRM3xtj73b7mwPcgmRxYz", - "+ldZNNzfUExn9bNAjZkCTuTUBpMm7FRu/5hINOYsNUkXGmMdDt7QEgOz7/YN9Q6LSSSeOFScIsxDIrmK", - "cyWe2MspNDZBiKMe4ayPXxRyVYBw52fdYZDivX5UJOglnmzde2Bg3h5MGu0zrEnfKy9l68z8jlxx5O73", - "6JV1Vgr1k69SZl550m9VbN5jv3tXpPddawf6hpiDQsWR3f51CjZxBHZ6YWMwiiEmkTanlYz3cl7Pr3aI", - "O1DioO/6pOjV1UdkWnOr8QGC9qSNdEPwIs3PoymREMmcrzi2slUuLy0zyK+uPgp36rfI0jdn45TlVOsX", - "ZFNIgeMEqdGIUPTmBzc02+d8NGmaZHnRAVi0ta9H1YzSKJIftighauKVwC05jiSY60uORXv8XmZrO6Nz", - "qO2aZPlbcw+huY83Vx9rgtre7Ftuudoma7+88gvRsNz8EajoNlFqI7V8d9NW1e+IuETfjqjo+purjwKV", - "+WSEBRIAtEg9vrt2a+4q9dLU3qRU5X2VNXLi7jWv32Zxxu12yPIOv4swj8X3i526EStuTxxXMj4ZqMvW", - "xC5WkKNiV+ob9euMPdjeLDByklDxwKBWTXLY6yS+vjd0e6j2Lt7fsOzD6id/NjfH1IO/ipejl3pjLxA5", - "eWuuFSEyRoQKiZMEHD3/xd2jDUBsMsEvLqtawSkN1ar4EZKXMb8/27ukv48eW6Idh4fvrp360Wh+qYxw", - "dAmWl77WuZdqlAkXtUf5iLmcdUIV8LoZ+MJtROPSIz4ieOtmzxc32o4K/icDdF0TVJXidpChdwziXrKs", - "Y4Dt1g9l79cV8XZDOvQCN+Ze3o23ORa3xCmZUDJ7gcNxxHtFHLbyADh2rFDayfKC5HFBv7tedQ3yaOs0", - "gDvuUh57W5/q8BumsP5Yk/Y48vKpsbHlYBxLpNaptEBplTA9kSYwrzo01UumfiXM9z1MZ0fycNbGdDve", - "Ln2JqMW4YYeGLKXtdmxWWw8S5rVX9hYs4Cy6VybGXj8+mOallXfZXpM+YeOGjRRthHSmeNGlYTpHTZk1", - "w9G9kiCbvK2iD/EUS13Z05elj4D/T+XZtIy/Mcxawqs4mFvZB6/sslN1DC61GmUcSqexbLst/i182abx", - "rt78Pp7/bmpdzuZ22ynq6tPRT5ooCvLFMf41Efe6bXL7HJEG1LR56jCAKOdEzq7VXm3Liu6iq79Vo4nF", - "OyOxjBZ1CVE0wIWAOXD7yo36+0F0oSVhj3qdojtNP3nFYmh8+ZEn3sibSpmJUadj+jXkrF3jR5vxSceg", - "3HnodWrzVQATsUxvS3FEYbQHTD2vxlP9yNzTJ3TM3CFJ0WZ8DfyBRKDbM+z7jYRujidlwUf3tIlmUSch", - "Y0DRLErghqaY4gmkQN2XmZB95ZNAaS6kDXZmtoPx7c/IvoFCK+sNnQKOrVtHZAKVy2QVbGtvUQja3Xag", - "HRMj8d7IO2kH7RNTsp1qjnZwRjoP3U61c0d0nuuvPp93opWXtV4VV2otdRSCE3D4rSqm0hXpApY+nmyC", - "qLqegsAKUdVvc3wD8iIjn7rvqki+q6FY3iZbejNyLwhW2YpyXGfVG07nvtffZv5h7/nTq3SPuorzhUJ6", - "nZOjrtN8eZtepH/URRrvl5r73umR2bLuHWRVm6u7DdzW9vOtbh+r/sbDis6ExZDOqt8t0KC21E3b0CY6", - "z+VPAOyqsEdC2t841fF7B3P9SllX9v2VbnEQCCMKj4ubvQurYW4oQVy5FqIMLm9akCsmNpqQK0vHqwLH", - "mk0pflFgtlruKj860Fn3iwPzho3q7WqjvpmoA03U8KiLNF4f+m9top5aMYty5Zbo71sTzvJMv2OY6Gry", - "MexO57n8wZd52c3n8oz19wiXKqw7X6yO4x213ADbW89f1X6iZlcFPeQVxt+0+JujsasW/5uf6ptnOX7/", - "SvsCucMV+Ki7/ipmYj8vIJdHMg6/tzfwzdh8MzZ/QJfBpA9F57n4/a95Z2XXUpHdsC1xW+UXhEkwFImW", - "RSbcrmJSN+WLrqdYLN42u1fa4b3Z0Hu7nR/tZvZJQhz0Zts/nU7/6QP8zedj8yf3dskKOFRtVS2p0LTi", - "tR+HKFq1GvVyenZpdvLiarb0VuBvWvYfomXz+f8HAAD//4k6KO+7dQAA", + "H4sIAAAAAAAC/+x9e3PbNrb4V8HwtzO7nR8lUbIs2/pnx022WU+bxhMn6b0b+3og4khCTQJcALSjevTd", + "7+BBihSht5xuezPtTCwRODg4L5wXqOcg5mnGGTAlg+FzkGGBU1AgzKc4yaUCcfX6uvhaf0tAxoJminIW", + "DIMPU0BuHGI4hTZ6m0uFRoAwesQJJej1zzco5kxhyiibIM6SGUr4EwgUYwkonmKBY71keMtYno5ASMQF", + "ms6yKTAZIqmwUAgzgoAR9ETVFOHFLD3UzgrNGL2wQimX6pYNTirQEWUoATZR03YQBlTjnmE1DcJAox0M", + "F7sNwkDAv3MqgARDJXIIAxlPIcV6938RMA6Gwf/rLAjXsU9l5yEfgWCgQP6MU1gQbT4PAy4mmNHfsCbb", + "RoJWB1uq+lGuA30RvDPBf4VYbUTZjVuHbQnqRRAVMNmGtHYYogSYomMKYgWyBbgXwHVuQYJU33NCwaqa", + "AKzgFU+zXMErK4nv7SDzmDMFzPyJsyyhsWF551ep9/UcwBecZgnoP1NQmGBl0KsLdjAPA5lBrJ+43ZFg", + "GIyi04vRCQxaFxhOW/3e6Kx10R/1W+N+bzw6w4MRBgjC4ImLh4Rjcs15IoPh5+dgTAU84STR8CibCJD2", + "+5gSEQw/B92LXrs7OG9321Gn1w/uwiDjwmzB6mswPI+sgCke8yQYBirOgnlYgRC1zX+d8yAMumcanPnY", + "7VWhCcwmZuvASDDsXlxchIGxGcGwGw0Gc88ad/MwoCm207gMhkE+ypnKgzB4BCGNtPSidtSfh0GK4yll", + "ZuQ4wY9cGKrFZ6eDc+iR1vgCj1r90xPSusAnuHXaPTk7HZ+d93uDUVBZhFCpBPcuFPT67agfGKkwrJXB", + "8GReCiKBMc4TFYRBlo8SGl9dXyYJtwJgd41HSSGc8/md3u92EhrXpO0XQRVY6axrjRPK0so72UWLs6Ld", + "UBIr4zLjTDr5XpJs+2h/0Tb6Qjn7QA2RelHvpBWdtU66H7rRsH867J/+S5N/B1YtKcuSxdaASH8QRWQA", + "LbgYnLb6o36/hc+j89Z5fzzqjfHJ4CzqBQuLadbG0OtekLNWN9LKNYi6rfO4F7cAziAaDEYXJzHYKY9U", + "SwNlkxuFVS6tubRfAvmmun7VbWrVGKc0mRm1GVHMgjB40FZYT08oy7/UFS9yiveH03FDJiMmzx72uu3Y", + "D1MulVvGfd/qGpGjj1jB1XUwLJjVrayvvy24poVaeqXyzrODxQa7+xuj94CJzxZdoiVr1NY0rc+V+1iX", + "z9/Myzfz0jAvkh5gXv6wDsQfx7jc7WddpN+0JFQqxMfLJkYaG5Mz+sAFa8UJz8l9zAXcp5iy++xhcs8z", + "YDij9zFPU87ucRxDpoBU7ZAvELFu1BRLNAJgqJhmwtgnmiQ6lh3nyZgmif5Wzlg8FZzxXCaz9i37b56j", + "FM9QxpMEKQNR8lzEYACknFHFBaJKIktfNOYCaUIkoNHYdVcjTFxAsp/3BkJwEQwDykxa4N7tPwjtk/s6", + "hQrqjDiZITcl2Pow2WFbFi2PPLyvYjDGVPPAwrd5DbPREHHhaG9HEw4SMa6KjMctwyV3rIOMxhQSsrNQ", + "xZyNExofSPwCygqq44UMmTyLxlviFExUj3AiAJMZgi9UKvm1ueHwKnYgXSaIcTUFEaJc5jhJZkhNqUQp", + "YCY19jM0xY9Q38eulB9zMaKEADuM9CWYFbTPJQgUCzCJCZxIRLgRpHIDpQBp60oTmID8fTTiCUtEgFEg", + "aDRDOFdTLqh0+mDpj2faeMU4l3aQxr828JYp/gCs2CFlk/oeZcwzMBYLM3R5fVUqmiGT1jL21wVtbhmD", + "GKTEYlahDuLMTDGnCgGBsgSrMRfprhJAmQLBcHID4hHEPzR9DpMFaQA5SvvFwVkcxZElVJxgmn5dfl8y", + "lDP4kkGsTyUzDPE4zoUAUmc0ro1UAjNJgSk3BzNyy/RImccxANF80ZZGiVkbXY0tJGoYqtkVYwkhyhLA", + "UguEduYQVQhLvQyVMt9ZgxlXP/CckcOYxri6H2swKzhWOQaALAxpeSIYs/l1OfjRuHZaiMaUEbQw77tS", + "MGdOe3+DA6movRwp7639WHUM5WqqraCF5g7fryz7PhQKG2T34BRT+2/wJdNWy0NVG04113cWwAYELxCx", + "di/OolbUbUXdD1E0NP+XEesFPo8HJ2dRqx/pQJP0ceuC4Kh1Njg7J+N+FJMLsohYJ+1+e0on0xTSNu5G", + "Ubs7aXejyagaNMZZ/kMRGV0xBQn6L+AMXSdYUZan6Lw7iD6gv908zBL8AN8FoZ4hg2E/1HHNg46VwmCS", + "5RpWwic0xskrnmsi9MIghZSLWTAc9MMg5cQEW1dMKspihd5e9U4jHVpMZ7IyravDI0aMxF2+fW1yPA7M", + "SW+HuGEfZq4PLtyg3UXFRIIvltvotXq9D93eMOoPuyelpOBBf3zRG1y0TgYQtfon3V5rdE66rdMeuTgh", + "p4OL0Vklt5GP8l4v6rceu+3eaXvQmmR567R32j4/bUenrbMYSL972q/KjWM5EfRRR/1BOTpwrNZRZnDZ", + "jTSL/+n+6UWRDvJL/v786er11aUGy12qmYDDiPFRAkG4Z54QC4o1ed1x7Q+5Jf0N3tDvg2E3CgPJx+oJ", + "C/hkxxl0FnWgYBg40uiJj1SoHCcuA6SfFV9oW/dCImqFaL2E2jFITbFCWIAJGbGi+iBxQQGVVVeqtMue", + "RP9bmxS4KfMJ60sLLofgAta2TV1lIJSrki3SDcuQ3EKoGKHnqlmmhUAqQdkkmNfSEqvmuyHo6hphQgRI", + "6YdUZjJWAjIjNsFZJFqOdKAVB/x1M+VX1B1tlebzgpglGnclhnz0K8SqmVt1u5OrGLoyiVKwVlZ4SxWk", + "crfMTV2e5iW+WAg8a6Jr0sgbpU5HtU1Zq5rMIzHHpW5vdGxDiohW4/i2WKtiG7cnyo2esbUwLc31y0a5", + "eYfPZsm4cWivJ3Vx9iwVD+uUX6Sg1xTwFUdlttCGDW4JyryatpTI3KkyWpu6TKoS2+U1tqDZlmZxlTk8", + "1p4qQrAB4+o0n/YvY15giDLOE4+OLVLj61B3w8yiZV57efFfqkuhFWfAEu+c+SvQuNtp/9tyr0aDlbxc", + "pNX3sIdyYRAPIE41vb4M4GdTmNGGvUC0AoAyBZOyDadB3hLqbvTd6XipEXnf06Um3TpkoOzKQuluOml8", + "+rQ3+oedkR4Z3XhQ2uaP7cw36DA4zwhW8FVOzcKlOcYhefAxtwtX92WgLX43WVYtq64ML90YJPIEJDJx", + "oU0j4k3GuKzUrse1WOG9XsB/ZlSH+JCtIbkTjrb+u4YDV6/fo1HC4wdp4CUJfwoRVSilk6ntSmUzdHX9", + "2NdCfHX9OECU2VmMK2zrYhWmNSzkMk+KUvO2FLvW42t15xXNlOZpuQeNFLA81UKr4iwIg5xkFXFdcb6V", + "qzhEQ0vAuw08u3ab8iDGhUIExpRR5bwwgx9SAo/HNG5yrKjor4RW3eLyeRIuSvi7EPi9mbRRNBdDV2Nn", + "1t9im6bDwAcFGNGCqWoA/Xt1rQk+KLYHeis4SyJggYYGwU18l0ezLFtZvZqZ8OiWSUTcQAKx4l6tt0kN", + "m7BA0g1s8qbI/hwxj8Llawt0XskTeTu5MxBYUTZBciYVpMiN9rpfZXppO0h2tOZALiFEdGzKDEY7gWij", + "Z5oIcmnLhwlWINVmn9hRyycrq1qa1wQCh14JQMe8EYDWXAhI8ZefzIdgODgxrl/xsevhVDUi2SIMcsO9", + "ovmwSTAfeZKnsOwAbKNYZk7ZcrSM5g/mCbp6bba/fr9lG9K6Zev6Ol/Vb7QOhGfGjmGJrRkbD5rGpiNA", + "0t/ABT6ufpPiLzTN06K8jHPFWzLGCSwMWNM65xLEa+fZLlXZ3JNCpCUaYQmDfgtYzAkQ07NAJ7mwqQ/K", + "xlyk9m8ukIUknRqjPOMMJThnsRFLOzQYBqOZgo26WxKqwveCeT6F9jNoWZorqcxyHJKgtDGSvqPQ9ZMt", + "Q/qHrUb6wFVIPuI8AcwaeyvA+vaxc8WvgdsbYCBo7CrWKUiJJxA2ct8c52ra8+zZD/USaUMDDqplGoIv", + "GWbE2j0jjv/88OHaDdHy0kamw0Ca5LuWJFIMfHepV0c6VKFjV+4J0Si3eXoLF5xB1PgJCgqLWdH/pYFb", + "/bi8vpLINM4gNcUaOJdQwLUdG3atqt/ZbNyqVoXv44QC098uV3hzJvNM+yyg59ry1b1hYVjCNO0eOgqr", + "N0YoSDMusKDJ7D5n+BHTBNuKTjGxXLX4YiIwU0urmu+KJatl/Eo7VApqysm9fmpcvQbqKRCKCyCLZp47", + "j7X01LSXJeMTiJGmuZM0ZJ+Oij4YA2HzWb26geRALVmc9D/hESSfcJJ7Izl7nP+Yj8AMRokerb/NIURq", + "ljkTbNqAtOCVXRHaL3A1phgzNIJbRhmBL9pxscKu43It/UbZsFIg9JL/8zlqXVy2/oVbv9397e/DxafW", + "ffvuOQoH3XllxHd//4vPz9qBENUu7TV5++FzgJPk3dgUW4+c91gqEDwvmZ7lPvKN9wkXV9/qXaMjSDib", + "6INos+AtLdqUtrvdyLy5MvISFN6SuU2aV3rw192FPAalF0sdTORGIq2BfNllWSTGnIIbRylJ9Lmx2IUA", + "TKRtVhZUgccTWGsBP1QpUnnkOsu4+WCsB84nqWaxIaLpRDUnXMpNcZop+OIPp4pU+JGkxWsTddiKJ8es", + "4Co8+ck0ivmS6Xty3FMNXiW45TjjNYB2rattYwt3IGcPjD+xpesl1Y/mCCWw9NieWXeHmWXxtUyEjSPe", + "N1PQzw1Zt231tqvGR1xFU6jbAdtIm4ACUvP1CVbQ0sP9TQw+Xn799gEPHh4LFe5oYYxR2bU7UUL6CCsy", + "RClmisZFsmTJmXi8vSX///a2XfnnUIdhhcC8pIOwRiptwYZ8P/OLpGmmfppyV9ghNfH02tR689j2Yu4W", + "2F7M6YqzNWf033kFuE1fNBM0nJhQZuPObSFri50XEDfsHNf37cBvu+8lHaMmSKmSfAsV+2BvQDj1orLm", + "eDuf+9dcuoZkmyMjnP1VFd33twyzWf0s0GOmgBM1dcGkDTu12z+mCo0FT23ShRFswsFbVmJg992+ZcFh", + "MYnCE4+KM4TFiCqh41yFJ+6mCiM2CPHUI7z18ctCrgoQ/vysPwzSvDePigS9wpOtew8szLuDSWN8hjXp", + "e+2lbJ2Z35Erntz9Ho2z3kqhefJVyswrT/qtis177HfvivS+a+1A3xEWoFHxZLd/mYJLHIGbXtgYjAgQ", + "GhtzWsl4L+f1wmq7uAclAebiT4peXX9Etk+3Gh8gaE/ayHQHL9L8Ip5SBbHKxYpjK1vl8rIyg/zq+qP0", + "p36LLH1zNk55zox+QTaFFAROkB6NKENvvvdDc03PR5OmSZYXHYBFj/t6VO0ogyL9fosSoiFeCdyR40iC", + "ub7kWPTK72W2tjM6h9quSZa/tZcSmvt4c/2xJqjtzb7llqttsvbLK78QDcvNH4GKfhOlN1LLdzdtVf3C", + "iE/03YiKrr+5/ihRmU9GWCIJwIrU47sbv+auUi9D7U1KVV5eWSMn/l7z+tUWb9zuhizv8G8xFkR+t9ip", + "H7HiKsVxJeOThbpsTdxiBTkqdqW+0bDO2IPtzQIjLwk1Dyxq1SSHu1sSmktEd4dq7+JlDss+rHnyZ3Nz", + "bD34q3g5Zqk37jaRl7f2jhGiY0SZVDhJwNPzX1xE2gDEJRPC4uaqE5zSUK2KHyF5GfP7k7tY+vvosSPa", + "cXj47sarH43ml8oIT5dgeQNsnXupR9lw0XiUT1ioWWekA14/A1+4jWhcesRHBO/c7PniettRwf9oga5r", + "gqpS3A2y9CYgHxTPOhbYbv1Q7n5dEW83pMMscGsv6d0Gm2NxR5ySCSWzFzgcR7xXxGErD4BjxwqlnSxv", + "Sx4X9Lub2p3IxuU4ykzjjQmR9KjFCx9c+4tmp+3nW+dJ+e5ZHm0jDeCey5rHptunOvxGE6cjaAMRw8Xj", + "iOanxhaX436skF6n0m1VZZfJAVR9p+p91rCSUQgDzGZHcqbWho87XmR9iQDJenyHRkflMeHZrDFUdJTX", + "XhVcsEDw+EFbM3ft+WCalweKz8zbTA0fN8yxbCNkktKLhhDbpGoruhmOH7QEuTxxFX0gU6xMEdFc0j4C", + "/j+Wx+Ay/vYMMBJexcHeBj94ZZ/FwoRQW+S+rhn9Y3n6tirWuOl9ZfQ1E1A6wmUrcfFv4Z+3fSl714/q", + "6wYyT5qnmDZfzfGvy0Ng60yUAdQ0d/pEgDgXVM1uNJ1cY4zp1au/yKOJxTsrrJwVR5Es2uxGgAUI95aP", + "+itJTDkn4U+Wja4Hzjx5xQk0vvwokmAYTJXK5LDTsV0hatau8bLNxaRjUe489jq1+TpMinlmtqVticZo", + "D5hmXu1ahHlk3wZA2Zj7A5+imfkGxCONwTSBuFcqSdOCT8uykumck83SUULHgOJZnMAtSzHDE0iB+a9M", + "IfeWKYnSXCoXUs1cn+Tbn5B76YXR01s2BUyc80hVApUraxVsay9uiNrddmTcH6stwTA4aUftE1sYnhqO", + "dnBGO4/dTrU/SHae629bn3filVfCXhUXdx11NIIT8HjHOnIzde8CljmZXBqqup6GwAtRNS+QfAPqMqOf", + "uu+qSL6roVjeWVt6GXMvilbZmXJcZ9VLVedh0N9m/mGvFjSrdI+6ivcdRmadk6Ou03xfnFmkf9RFGq+0", + "mofB6ZHZsu61Z1Wba3oa/Nb2851pUqv+rMSK/ofFkM6qn0owoLbUTdc2JzvP5a8O7KqwR0I63DjV8xML", + "c/MWW1+O/5VppJAIIwZPi/vDC6th70EBqVw+0QZXNC3INZcbTci1o+N1gWPNphQ/YjBbLXeV3znorPuR", + "g3nDRvV2tVHfTNSBJuriqIs03lj6H22ivrQIj3PtlpjvWxPB88y81piamvUx7E7nufyNmXnZM+jzjM33", + "CJcqbPprnI7jHbXcAttbz1/VfhVnVwU95K3J37T4m6Oxqxb/h5/qm2d5fnLL+AK5xxX4aHoLK2ZiPy8g", + "V0cyDr+3N/DN2HwzNn9Al8FmDmXnufjJsXlnZW9Ukd1wjXdb5RekTTAUiZZFEtytYlM35bu1p1guXnC7", + "V9rhvd3Qe7edH9xm9klCHPQy3T+dTv/pA/zN52PzV/52yQp4VG1VGanQtOLlIocoWrUQ9XJ6dmV38uJq", + "tvQi4m9a9n9Ey+bz/w0AAP//avq/US52AAA=", } // GetSwagger returns the content of the embedded swagger specification file diff --git a/pkg/provisioners/managers/cluster/provisioner.go b/pkg/provisioners/managers/cluster/provisioner.go index f0f73cb..df80daf 100644 --- a/pkg/provisioners/managers/cluster/provisioner.go +++ b/pkg/provisioners/managers/cluster/provisioner.go @@ -21,6 +21,8 @@ import ( "errors" "fmt" "net/http" + "slices" + "strings" "github.com/spf13/pflag" @@ -83,6 +85,9 @@ type Provisioner struct { // options are documented for the type. options *Options + + // resourceProvisioning tells whether any sub resource is in a provisioning state. + resourceProvisioning bool } // New returns a new initialized provisioner object. @@ -269,11 +274,23 @@ func (p *Provisioner) Provision(ctx context.Context) error { } } - // TODO: if any of the machine statuses are not provisioned, we should return - // the correct error status here or a yield to force reconcilliation until - // the desired state. - // TODO: we need to sort the status stuff so it doesn't move around all the - // time for determinism on both the CLI and UI. + // Sort the statuses so they have a deterministic order up the stack, especially + // to things like the UI. + slices.SortFunc(p.cluster.Status.WorkloadPools, func(a, b unikornv1.WorkloadPoolStatus) int { + return strings.Compare(a.Name, b.Name) + }) + + for _, pool := range p.cluster.Status.WorkloadPools { + slices.SortFunc(pool.Machines, func(a, b unikornv1.MachineStatus) int { + return strings.Compare(a.Hostname, b.Hostname) + }) + } + + // Now once the UX is sorted, roll up any non-healthy statuses to the top level. + if p.resourceProvisioning { + return provisioners.ErrYield + } + return nil } diff --git a/pkg/provisioners/managers/cluster/server.go b/pkg/provisioners/managers/cluster/server.go index bc3e16f..d6dda70 100644 --- a/pkg/provisioners/managers/cluster/server.go +++ b/pkg/provisioners/managers/cluster/server.go @@ -81,17 +81,23 @@ func (p *Provisioner) deleteServer(ctx context.Context, client regionapi.ClientW return nil } -func convertStatusCondition(in coreapi.ResourceProvisioningStatus) unikornv1core.ConditionReason { +func (p *Provisioner) convertStatusCondition(in coreapi.ResourceProvisioningStatus) unikornv1core.ConditionReason { //nolint:exhaustive switch in { + case coreapi.ResourceProvisioningStatusProvisioning: + p.resourceProvisioning = true + + return unikornv1core.ConditionReasonProvisioning case coreapi.ResourceProvisioningStatusDeprovisioning: + p.resourceProvisioning = true + return unikornv1core.ConditionReasonDeprovisioning case coreapi.ResourceProvisioningStatusProvisioned: return unikornv1core.ConditionReasonProvisioned - case coreapi.ResourceProvisioningStatusProvisioning: - return unikornv1core.ConditionReasonProvisioning } + p.resourceProvisioning = true + return unikornv1core.ConditionReasonErrored } @@ -105,7 +111,7 @@ func (p *Provisioner) updateServerStatus(pool *unikornv1.ComputeClusterWorkloadP PublicIP: server.Status.PublicIP, } - unikornv1core.UpdateCondition(&status.Conditions, unikornv1core.ConditionAvailable, corev1.ConditionFalse, convertStatusCondition(server.Metadata.ProvisioningStatus), "server provisioning") + unikornv1core.UpdateCondition(&status.Conditions, unikornv1core.ConditionAvailable, corev1.ConditionFalse, p.convertStatusCondition(server.Metadata.ProvisioningStatus), "server provisioning") poolStatus.Machines = append(poolStatus.Machines, status) }