From e249a905c60c006e9299b06f57495ca6236bd494 Mon Sep 17 00:00:00 2001 From: adam Date: Fri, 10 Mar 2023 12:01:01 -0700 Subject: [PATCH] Freshen; remove obsolete docs --- docs/config.yaml | 1 - docs/russ-notes.txt | 100 ------------------------------------------ requirements/dev.txt | 6 +-- requirements/main.txt | 80 ++++++++++++++++----------------- 4 files changed, 43 insertions(+), 144 deletions(-) delete mode 120000 docs/config.yaml delete mode 100644 docs/russ-notes.txt diff --git a/docs/config.yaml b/docs/config.yaml deleted file mode 120000 index f5dffc9e6..000000000 --- a/docs/config.yaml +++ /dev/null @@ -1 +0,0 @@ -../tests/configs/standard/config.yaml \ No newline at end of file diff --git a/docs/russ-notes.txt b/docs/russ-notes.txt deleted file mode 100644 index 4123d6c3d..000000000 --- a/docs/russ-notes.txt +++ /dev/null @@ -1,100 +0,0 @@ -Some overall comments: - -The Kubernetes stuff seems to be a bunch of functions rather than -methods on an object. Take a look at storage/kubernetes.py in -Gafaelfawr, which I think is a better pattern (and in general I think -using a storage layer to talk to things like Kubernetes and Docker would -be a benefit for this). The prepuller would probably be a separate -storage object since it's conceptually entirely separate from lab -creation. - -#Client management seems overly complicated (I don't -#understand why there's a cache with cancellation handling and -#whatnot). I think you can just create a client and manage it in a -#FastAPI dependency. - -#You probably want aiojobs to manage the background -#lab creation and deletion -#jobs. https://aiojobs.readthedocs.io/en/stable/ - -The watcher seems much -more complicated than I would have expected (and I'm also not sure why -it's a Pydantic model). I was expecting something more like -https://github.com/lsst-sqre/gafaelfawr/blob/55610b7833030831c308702ae5695c0321783f30/src/gafaelfawr/storage/kubernetes.py#L470 - -#I would not manage CoreV1Api as a dependency; instead, just manage -#ApiClient as a dependency and create the API-specific objects on demand -#(all the state is in the ApiClient object and that's the only thing you -#need to share). - -#Putting the routes in separate files means managing the -#global router variable, which is fine, but I'm not sure it's worth -#it. The routes should all be very short functions of about four or five -#lines apart from the annotations for FastAPI. I tend to put them all in -#one file. Failing that, though, I'd not keep the external directory; I -#don't think that distinction is important enough to warrant a directory -#level. - -#get_user_from_token should be a dependency so that the user is -#just an additional function argument. I'm not sure I understand the -#runtime directory. It would match our other services a bit better if the -#config stuff was in a top-level config module, the enums should be -#actual enums and usually are grouped with the models, the Docker -#credentials should probably be a dependency, I'm hoping we don't need to -#escape the names of users, and there seem to be a mix of global state -#(which should be managed by objects via dependencies since eventually it -#will be in Redis) and various utility functions. - -I didn't look at the -prepuller stuff yet, since I know that's still in progress, just the lab -creation stuff. Feel free to make a pull request too if a more -structured commentary would be useful instead of a super-long Slack -message. - -... - -Take a look at what Gafaelfawr does. I suspect you don't want to get any -configuration from the environment. (I think it's confusing when -applications get some configuration from the environment and some from -files; if the configuration is complex enough to require a file, may as -well move everything into the file.) - -... - -#So, what I'm getting at there is that I think you probably want a -#factory pattern, which is what Gafaelfawr uses as well. Basically, at -#some level of complexity you want a piece of code that's responsible for -#creating and managing the objects that everything else uses, and it's -#easier to put all of that in one place. Gafaelfawr does that: you create -#a long-lived factory object that holds all the in-memory data stores and -#whatnot and builds service objects for you when you need them with -#dependency injection. That lets you manage state a bit more cleanly than -#using a bunch of global variables. (The global variables are going to -#bite you when you start trying to write tests, because they will persist -#from one test to the next.) - -[Going to try this as FastAPI dependencies and see how that goes. I may -adopt the factory later] - -... - -#It doesn't hurt to also manage CoreV1Api as a dependency if you want, -#but you do want to have a dependency managing ApiClient because that's -#where the connection cache is, so if you do have a CoreV1Api dependency -#you'll want it to use the ApiClient dependency under the hood to get its -#ApiClient. - -#Otherwise if you need any other API later you lose the connection cache. - -#Oh, when I say that the docker credentials should probably be a -#dependency, I didn't mean the Docker client for each artifact -#repository, I meant -#https://github.com/lsst-sqre/jupyterlab-controller/blob/tickets/DM-36570/src/j#upyterlabcontroller/runtime/docker.py - -#That's the sort of thing that you generally want to model as a -#dependency in FastAPI so that it loads the credentials when needed and -#caches them and injects them as a function argument so you don't have to -#keep calling this function in various places. - -#And the data is then kept in the dependency object rather than a global -#variable, which is a bit cleaner. diff --git a/requirements/dev.txt b/requirements/dev.txt index 414902448..ea761f46c 100644 --- a/requirements/dev.txt +++ b/requirements/dev.txt @@ -168,9 +168,9 @@ packaging==23.0 \ --hash=sha256:714ac14496c3e68c99c29b00845f7a2b85f3bb6f1078fd9f72fd20f0570002b2 \ --hash=sha256:b6ad297f8907de0fa2fe1ccbd26fdaf387f5f47c7275fedf8cce89f99446cf97 # via pytest -platformdirs==3.1.0 \ - --hash=sha256:13b08a53ed71021350c9e300d4ea8668438fb0046ab3937ac9a29913a1a1350a \ - --hash=sha256:accc3665857288317f32c7bebb5a8e482ba717b474f3fc1d18ca7f9214be0cef +platformdirs==3.1.1 \ + --hash=sha256:024996549ee88ec1a9aa99ff7f8fc819bb59e2c3477b410d90a16d32d6e707aa \ + --hash=sha256:e5986afb596e4bb5bde29a79ac9061aa955b94fca2399b7aaac4090860920dd8 # via virtualenv pluggy==1.0.0 \ --hash=sha256:4224373bacce55f955a878bf9cfa763c1e360858e330072059e10bad68531159 \ diff --git a/requirements/main.txt b/requirements/main.txt index 80d9c5339..2bf1c2308 100644 --- a/requirements/main.txt +++ b/requirements/main.txt @@ -599,43 +599,43 @@ multidict==6.0.4 \ # via # aiohttp # yarl -pydantic==1.10.5 \ - --hash=sha256:1fd326aff5d6c36f05735c7c9b3d5b0e933b4ca52ad0b6e4b38038d82703d35b \ - --hash=sha256:2185a3b3d98ab4506a3f6707569802d2d92c3a7ba3a9a35683a7709ea6c2aaa2 \ - --hash=sha256:261f357f0aecda005934e413dfd7aa4077004a174dafe414a8325e6098a8e419 \ - --hash=sha256:305d0376c516b0dfa1dbefeae8c21042b57b496892d721905a6ec6b79494a66d \ - --hash=sha256:3257bd714de9db2102b742570a56bf7978e90441193acac109b1f500290f5718 \ - --hash=sha256:3353072625ea2a9a6c81ad01b91e5c07fa70deb06368c71307529abf70d23325 \ - --hash=sha256:36e44a4de37b8aecffa81c081dbfe42c4d2bf9f6dff34d03dce157ec65eb0f15 \ - --hash=sha256:3bb99cf9655b377db1a9e47fa4479e3330ea96f4123c6c8200e482704bf1eda2 \ - --hash=sha256:3f9d9b2be177c3cb6027cd67fbf323586417868c06c3c85d0d101703136e6b31 \ - --hash=sha256:45edea10b75d3da43cfda12f3792833a3fa70b6eee4db1ed6aed528cef17c74e \ - --hash=sha256:51782fd81f09edcf265823c3bf43ff36d00db246eca39ee765ef58dc8421a642 \ - --hash=sha256:532e97c35719f137ee5405bd3eeddc5c06eb91a032bc755a44e34a712420daf3 \ - --hash=sha256:58e41dd1e977531ac6073b11baac8c013f3cd8706a01d3dc74e86955be8b2c0c \ - --hash=sha256:5920824fe1e21cbb3e38cf0f3dd24857c8959801d1031ce1fac1d50857a03bfb \ - --hash=sha256:5f3bc8f103b56a8c88021d481410874b1f13edf6e838da607dcb57ecff9b4594 \ - --hash=sha256:63200cd8af1af2c07964546b7bc8f217e8bda9d0a2ef0ee0c797b36353914984 \ - --hash=sha256:663d2dd78596c5fa3eb996bc3f34b8c2a592648ad10008f98d1348be7ae212fb \ - --hash=sha256:6a4b0aab29061262065bbdede617ef99cc5914d1bf0ddc8bcd8e3d7928d85bd6 \ - --hash=sha256:6bb0452d7b8516178c969d305d9630a3c9b8cf16fcf4713261c9ebd465af0d73 \ - --hash=sha256:72ef3783be8cbdef6bca034606a5de3862be6b72415dc5cb1fb8ddbac110049a \ - --hash=sha256:76c930ad0746c70f0368c4596020b736ab65b473c1f9b3872310a835d852eb19 \ - --hash=sha256:7c5b94d598c90f2f46b3a983ffb46ab806a67099d118ae0da7ef21a2a4033b28 \ - --hash=sha256:7ce1612e98c6326f10888df951a26ec1a577d8df49ddcaea87773bfbe23ba5cc \ - --hash=sha256:8481dca324e1c7b715ce091a698b181054d22072e848b6fc7895cd86f79b4449 \ - --hash=sha256:87f831e81ea0589cd18257f84386bf30154c5f4bed373b7b75e5cb0b5d53ea87 \ - --hash=sha256:9a9d9155e2a9f38b2eb9374c88f02fd4d6851ae17b65ee786a87d032f87008f8 \ - --hash=sha256:9e337ac83686645a46db0e825acceea8e02fca4062483f40e9ae178e8bd1103a \ - --hash=sha256:b429f7c457aebb7fbe7cd69c418d1cd7c6fdc4d3c8697f45af78b8d5a7955760 \ - --hash=sha256:b473d00ccd5c2061fd896ac127b7755baad233f8d996ea288af14ae09f8e0d1e \ - --hash=sha256:bd46a0e6296346c477e59a954da57beaf9c538da37b9df482e50f836e4a7d4bb \ - --hash=sha256:c428c0f64a86661fb4873495c4fac430ec7a7cef2b8c1c28f3d1a7277f9ea5ab \ - --hash=sha256:c9e5b778b6842f135902e2d82624008c6a79710207e28e86966cd136c621bfee \ - --hash=sha256:ca9075ab3de9e48b75fa8ccb897c34ccc1519177ad8841d99f7fd74cf43be5bf \ - --hash=sha256:f582cac9d11c227c652d3ce8ee223d94eb06f4228b52a8adaafa9fa62e73d5c9 \ - --hash=sha256:f5bee6c523d13944a1fdc6f0525bc86dbbd94372f17b83fa6331aabacc8fd08e \ - --hash=sha256:f836444b4c5ece128b23ec36a446c9ab7f9b0f7981d0d27e13a7c366ee163f8a +pydantic==1.10.6 \ + --hash=sha256:012c99a9c0d18cfde7469aa1ebff922e24b0c706d03ead96940f5465f2c9cf62 \ + --hash=sha256:0abd9c60eee6201b853b6c4be104edfba4f8f6c5f3623f8e1dba90634d63eb35 \ + --hash=sha256:12e837fd320dd30bd625be1b101e3b62edc096a49835392dcf418f1a5ac2b832 \ + --hash=sha256:163e79386c3547c49366e959d01e37fc30252285a70619ffc1b10ede4758250a \ + --hash=sha256:189318051c3d57821f7233ecc94708767dd67687a614a4e8f92b4a020d4ffd06 \ + --hash=sha256:1c84583b9df62522829cbc46e2b22e0ec11445625b5acd70c5681ce09c9b11c4 \ + --hash=sha256:3091d2eaeda25391405e36c2fc2ed102b48bac4b384d42b2267310abae350ca6 \ + --hash=sha256:32937835e525d92c98a1512218db4eed9ddc8f4ee2a78382d77f54341972c0e7 \ + --hash=sha256:3a2be0a0f32c83265fd71a45027201e1278beaa82ea88ea5b345eea6afa9ac7f \ + --hash=sha256:3ac1cd4deed871dfe0c5f63721e29debf03e2deefa41b3ed5eb5f5df287c7b70 \ + --hash=sha256:3ce13a558b484c9ae48a6a7c184b1ba0e5588c5525482681db418268e5f86186 \ + --hash=sha256:415a3f719ce518e95a92effc7ee30118a25c3d032455d13e121e3840985f2efd \ + --hash=sha256:43cdeca8d30de9a897440e3fb8866f827c4c31f6c73838e3a01a14b03b067b1d \ + --hash=sha256:476f6674303ae7965730a382a8e8d7fae18b8004b7b69a56c3d8fa93968aa21c \ + --hash=sha256:4c19eb5163167489cb1e0161ae9220dadd4fc609a42649e7e84a8fa8fff7a80f \ + --hash=sha256:4ca83739c1263a044ec8b79df4eefc34bbac87191f0a513d00dd47d46e307a65 \ + --hash=sha256:528dcf7ec49fb5a84bf6fe346c1cc3c55b0e7603c2123881996ca3ad79db5bfc \ + --hash=sha256:53de12b4608290992a943801d7756f18a37b7aee284b9ffa794ee8ea8153f8e2 \ + --hash=sha256:587d92831d0115874d766b1f5fddcdde0c5b6c60f8c6111a394078ec227fca6d \ + --hash=sha256:60184e80aac3b56933c71c48d6181e630b0fbc61ae455a63322a66a23c14731a \ + --hash=sha256:6195ca908045054dd2d57eb9c39a5fe86409968b8040de8c2240186da0769da7 \ + --hash=sha256:61f1f08adfaa9cc02e0cbc94f478140385cbd52d5b3c5a657c2fceb15de8d1fb \ + --hash=sha256:72cb30894a34d3a7ab6d959b45a70abac8a2a93b6480fc5a7bfbd9c935bdc4fb \ + --hash=sha256:751f008cd2afe812a781fd6aa2fb66c620ca2e1a13b6a2152b1ad51553cb4b77 \ + --hash=sha256:89f15277d720aa57e173954d237628a8d304896364b9de745dcb722f584812c7 \ + --hash=sha256:8c32b6bba301490d9bb2bf5f631907803135e8085b6aa3e5fe5a770d46dd0160 \ + --hash=sha256:acc6783751ac9c9bc4680379edd6d286468a1dc8d7d9906cd6f1186ed682b2b0 \ + --hash=sha256:b1eb6610330a1dfba9ce142ada792f26bbef1255b75f538196a39e9e90388bf4 \ + --hash=sha256:b243b564cea2576725e77aeeda54e3e0229a168bc587d536cd69941e6797543d \ + --hash=sha256:b41822064585fea56d0116aa431fbd5137ce69dfe837b599e310034171996084 \ + --hash=sha256:bbd5c531b22928e63d0cb1868dee76123456e1de2f1cb45879e9e7a3f3f1779b \ + --hash=sha256:cf95adb0d1671fc38d8c43dd921ad5814a735e7d9b4d9e437c088002863854fd \ + --hash=sha256:e277bd18339177daa62a294256869bbe84df1fb592be2716ec62627bb8d7c81d \ + --hash=sha256:ea4e2a7cb409951988e79a469f609bba998a576e6d7b9791ae5d1e0619e1c0f2 \ + --hash=sha256:f9289065611c48147c1dd1fd344e9d57ab45f1d99b0fb26c51f1cf72cd9bcd31 \ + --hash=sha256:fd9b9e98068fa1068edfc9eabde70a7132017bdd4f362f8b4fd0abed79c33083 # via # fastapi # safir @@ -741,9 +741,9 @@ urllib3==1.26.14 \ --hash=sha256:076907bf8fd355cde77728471316625a4d2f7e713c125f51953bb5b3eecf4f72 \ --hash=sha256:75edcdc2f7d85b137124a6c3c9fc3933cdeaa12ecb9a6a959f22797a0feca7e1 # via kubernetes-asyncio -uvicorn[standard]==0.20.0 \ - --hash=sha256:a4e12017b940247f836bc90b72e725d7dfd0c8ed1c51eb365f5ba30d9f5127d8 \ - --hash=sha256:c3ed1598a5668208723f2bb49336f4509424ad198d6ab2615b7783db58d919fd +uvicorn[standard]==0.21.0 \ + --hash=sha256:8635a388062222082f4b06225b867b74a7e4ef942124453d4d1d1a5cb3750932 \ + --hash=sha256:e69e955cb621ae7b75f5590a814a4fcbfb14cb8f44a36dfe3c5c75ab8aee3ad5 # via -r requirements/main.in uvloop==0.17.0 \ --hash=sha256:0949caf774b9fcefc7c5756bacbbbd3fc4c05a6b7eebc7c7ad6f825b23998d6d \