diff --git a/hardware/Makefile b/hardware/Makefile index 8ca67e88116..4892e2ae376 100755 --- a/hardware/Makefile +++ b/hardware/Makefile @@ -100,6 +100,10 @@ format: dev: echo "Nothing here yet" +.PHONY: opentrons_ot3_firmware_dist +opentrons_ot3_firmware_dist: Pipfile.lock + mkdir -p dist + $(python) ../scripts/bundle_installed_package.py opentrons_ot3_firmware dist .PHONY: push-no-restart push-no-restart: wheel @@ -109,11 +113,11 @@ push-no-restart: wheel push: push-no-restart $(call restart-service,$(host),$(br_ssh_key),$(ssh_opts),"jupyter-notebook opentrons-robot-server") - .PHONY: push-no-restart-ot3 -push-no-restart-ot3: $(sdist_file) - echo $(sdist_file) +push-no-restart-ot3: $(sdist_file) Pipfile.lock + echo $(sdist_file) $(wildcard dist/opentrons_ot3_firmware-*.tar.gz) $(call push-python-sdist,$(host),,$(ssh_opts),$(sdist_file),/opt/opentrons-robot-server,"opentrons_hardware") + $(call push-python-sdist,$(host),,$(ssh_opts),$(wildcard dist/opentrons_ot3_firmware-*.tar.gz),/opt/opentrons-robot-server,"opentrons_ot3_firmware") .PHONY: push-ot3 push-ot3: push-no-restart-ot3 diff --git a/hardware/Pipfile b/hardware/Pipfile index 25afb7cd200..43cc093aeac 100644 --- a/hardware/Pipfile +++ b/hardware/Pipfile @@ -7,6 +7,7 @@ name = "pypi" python-can = "==3.3.4" pyserial = "==3.5" typing-extensions = "==3.10.0.0" +opentrons-ot3-firmware = {subdirectory = "python", git = "https://github.com/Opentrons/ot3-firmware.git", branch = "main"} [dev-packages] pytest = "==6.1.0" diff --git a/hardware/Pipfile.lock b/hardware/Pipfile.lock index 068055eb291..ee456928ad0 100644 --- a/hardware/Pipfile.lock +++ b/hardware/Pipfile.lock @@ -1,7 +1,7 @@ { "_meta": { "hash": { - "sha256": "b220b070fabfe99df61f90e3a516ef411002841e0b0c7e19182fa19ed80aada4" + "sha256": "f63671e61fb9e88b2a5cd937a3a6aac180d2edfd3b535ce4339cc7e5514fcb28" }, "pipfile-spec": 6, "requires": { @@ -18,11 +18,17 @@ "default": { "aenum": { "hashes": [ - "sha256:1f92fb906e3d745064e85f9a1937006ee341e00a35ecd8b7f899041b8e1d67d7", - "sha256:87f0e9ef4f828578ab06af30e4d7944043bf4ecd3f4b7bd1cbe37e2173cde94a", - "sha256:f8401f1a258436719ed013444ab37ff22a72517e0e3097058dd1511cf284447c" + "sha256:2ebad8590b6a0183c0d9893523b458edce987ae4533339c5ac185cfac32daf1a", + "sha256:7db6e790434baece9e14a97da69118edc89ade821f36590ce32a295f1e500e89", + "sha256:d50b9f8aa3e75c179056182820227eb09485e0bd07f968983744dfbd11958350" ], - "version": "==3.1.0" + "version": "==3.1.5" + }, + "opentrons-ot3-firmware": { + "branch": "main", + "git": "https://github.com/Opentrons/ot3-firmware.git", + "ref": "201ee38102917827d2a059e9aa8d9ca480d51f08", + "subdirectory": "python" }, "pyserial": { "hashes": [ @@ -50,54 +56,148 @@ }, "wrapt": { "hashes": [ - "sha256:b62ffa81fb85f4332a4f609cab4ac40709470da05643a082ec1eb88e6d9b97d7" + "sha256:086218a72ec7d986a3eddb7707c8c4526d677c7b35e355875a0fe2918b059179", + "sha256:0877fe981fd76b183711d767500e6b3111378ed2043c145e21816ee589d91096", + "sha256:0a017a667d1f7411816e4bf214646d0ad5b1da2c1ea13dec6c162736ff25a374", + "sha256:0cb23d36ed03bf46b894cfec777eec754146d68429c30431c99ef28482b5c1df", + "sha256:1fea9cd438686e6682271d36f3481a9f3636195578bab9ca3382e2f5f01fc185", + "sha256:220a869982ea9023e163ba915077816ca439489de6d2c09089b219f4e11b6785", + "sha256:25b1b1d5df495d82be1c9d2fad408f7ce5ca8a38085e2da41bb63c914baadff7", + "sha256:2dded5496e8f1592ec27079b28b6ad2a1ef0b9296d270f77b8e4a3a796cf6909", + "sha256:2ebdde19cd3c8cdf8df3fc165bc7827334bc4e353465048b36f7deeae8ee0918", + "sha256:43e69ffe47e3609a6aec0fe723001c60c65305784d964f5007d5b4fb1bc6bf33", + "sha256:46f7f3af321a573fc0c3586612db4decb7eb37172af1bc6173d81f5b66c2e068", + "sha256:47f0a183743e7f71f29e4e21574ad3fa95676136f45b91afcf83f6a050914829", + "sha256:498e6217523111d07cd67e87a791f5e9ee769f9241fcf8a379696e25806965af", + "sha256:4b9c458732450ec42578b5642ac53e312092acf8c0bfce140ada5ca1ac556f79", + "sha256:51799ca950cfee9396a87f4a1240622ac38973b6df5ef7a41e7f0b98797099ce", + "sha256:5601f44a0f38fed36cc07db004f0eedeaadbdcec90e4e90509480e7e6060a5bc", + "sha256:5f223101f21cfd41deec8ce3889dc59f88a59b409db028c469c9b20cfeefbe36", + "sha256:610f5f83dd1e0ad40254c306f4764fcdc846641f120c3cf424ff57a19d5f7ade", + "sha256:6a03d9917aee887690aa3f1747ce634e610f6db6f6b332b35c2dd89412912bca", + "sha256:705e2af1f7be4707e49ced9153f8d72131090e52be9278b5dbb1498c749a1e32", + "sha256:766b32c762e07e26f50d8a3468e3b4228b3736c805018e4b0ec8cc01ecd88125", + "sha256:77416e6b17926d953b5c666a3cb718d5945df63ecf922af0ee576206d7033b5e", + "sha256:778fd096ee96890c10ce96187c76b3e99b2da44e08c9e24d5652f356873f6709", + "sha256:78dea98c81915bbf510eb6a3c9c24915e4660302937b9ae05a0947164248020f", + "sha256:7dd215e4e8514004c8d810a73e342c536547038fb130205ec4bba9f5de35d45b", + "sha256:7dde79d007cd6dfa65afe404766057c2409316135cb892be4b1c768e3f3a11cb", + "sha256:81bd7c90d28a4b2e1df135bfbd7c23aee3050078ca6441bead44c42483f9ebfb", + "sha256:85148f4225287b6a0665eef08a178c15097366d46b210574a658c1ff5b377489", + "sha256:865c0b50003616f05858b22174c40ffc27a38e67359fa1495605f96125f76640", + "sha256:87883690cae293541e08ba2da22cacaae0a092e0ed56bbba8d018cc486fbafbb", + "sha256:8aab36778fa9bba1a8f06a4919556f9f8c7b33102bd71b3ab307bb3fecb21851", + "sha256:8c73c1a2ec7c98d7eaded149f6d225a692caa1bd7b2401a14125446e9e90410d", + "sha256:936503cb0a6ed28dbfa87e8fcd0a56458822144e9d11a49ccee6d9a8adb2ac44", + "sha256:944b180f61f5e36c0634d3202ba8509b986b5fbaf57db3e94df11abee244ba13", + "sha256:96b81ae75591a795d8c90edc0bfaab44d3d41ffc1aae4d994c5aa21d9b8e19a2", + "sha256:981da26722bebb9247a0601e2922cedf8bb7a600e89c852d063313102de6f2cb", + "sha256:ae9de71eb60940e58207f8e71fe113c639da42adb02fb2bcbcaccc1ccecd092b", + "sha256:b73d4b78807bd299b38e4598b8e7bd34ed55d480160d2e7fdaabd9931afa65f9", + "sha256:d4a5f6146cfa5c7ba0134249665acd322a70d1ea61732723c7d3e8cc0fa80755", + "sha256:dd91006848eb55af2159375134d724032a2d1d13bcc6f81cd8d3ed9f2b8e846c", + "sha256:e05e60ff3b2b0342153be4d1b597bbcfd8330890056b9619f4ad6b8d5c96a81a", + "sha256:e6906d6f48437dfd80464f7d7af1740eadc572b9f7a4301e7dd3d65db285cacf", + "sha256:e92d0d4fa68ea0c02d39f1e2f9cb5bc4b4a71e8c442207433d8db47ee79d7aa3", + "sha256:e94b7d9deaa4cc7bac9198a58a7240aaf87fe56c6277ee25fa5b3aa1edebd229", + "sha256:ea3e746e29d4000cd98d572f3ee2a6050a4f784bb536f4ac1f035987fc1ed83e", + "sha256:ec7e20258ecc5174029a0f391e1b948bf2906cd64c198a9b8b281b811cbc04de", + "sha256:ec9465dd69d5657b5d2fa6133b3e1e989ae27d29471a672416fd729b429eb554", + "sha256:f122ccd12fdc69628786d0c947bdd9cb2733be8f800d88b5a37c57f1f1d73c10", + "sha256:f99c0489258086308aad4ae57da9e8ecf9e1f3f30fa35d5e170b4d4896554d80", + "sha256:f9c51d9af9abb899bd34ace878fbec8bf357b3194a10c4e8e0a25512826ef056", + "sha256:fd76c47f20984b43d93de9a82011bb6e5f8325df6c9ed4d8310029a55fa361ea" ], - "version": "==1.12.1" + "markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3, 3.4'", + "version": "==1.13.3" } }, "develop": { "aiohttp": { "hashes": [ - "sha256:02f46fc0e3c5ac58b80d4d56eb0a7c7d97fcef69ace9326289fb9f1955e65cfe", - "sha256:0563c1b3826945eecd62186f3f5c7d31abb7391fedc893b7e2b26303b5a9f3fe", - "sha256:114b281e4d68302a324dd33abb04778e8557d88947875cbf4e842c2c01a030c5", - "sha256:14762875b22d0055f05d12abc7f7d61d5fd4fe4642ce1a249abdf8c700bf1fd8", - "sha256:15492a6368d985b76a2a5fdd2166cddfea5d24e69eefed4630cbaae5c81d89bd", - "sha256:17c073de315745a1510393a96e680d20af8e67e324f70b42accbd4cb3315c9fb", - "sha256:209b4a8ee987eccc91e2bd3ac36adee0e53a5970b8ac52c273f7f8fd4872c94c", - "sha256:230a8f7e24298dea47659251abc0fd8b3c4e38a664c59d4b89cca7f6c09c9e87", - "sha256:2e19413bf84934d651344783c9f5e22dee452e251cfd220ebadbed2d9931dbf0", - "sha256:393f389841e8f2dfc86f774ad22f00923fdee66d238af89b70ea314c4aefd290", - "sha256:3cf75f7cdc2397ed4442594b935a11ed5569961333d49b7539ea741be2cc79d5", - "sha256:3d78619672183be860b96ed96f533046ec97ca067fd46ac1f6a09cd9b7484287", - "sha256:40eced07f07a9e60e825554a31f923e8d3997cfc7fb31dbc1328c70826e04cde", - "sha256:493d3299ebe5f5a7c66b9819eacdcfbbaaf1a8e84911ddffcdc48888497afecf", - "sha256:4b302b45040890cea949ad092479e01ba25911a15e648429c7c5aae9650c67a8", - "sha256:515dfef7f869a0feb2afee66b957cc7bbe9ad0cdee45aec7fdc623f4ecd4fb16", - "sha256:547da6cacac20666422d4882cfcd51298d45f7ccb60a04ec27424d2f36ba3eaf", - "sha256:5df68496d19f849921f05f14f31bd6ef53ad4b00245da3195048c69934521809", - "sha256:64322071e046020e8797117b3658b9c2f80e3267daec409b350b6a7a05041213", - "sha256:7615dab56bb07bff74bc865307aeb89a8bfd9941d2ef9d817b9436da3a0ea54f", - "sha256:79ebfc238612123a713a457d92afb4096e2148be17df6c50fb9bf7a81c2f8013", - "sha256:7b18b97cf8ee5452fa5f4e3af95d01d84d86d32c5e2bfa260cf041749d66360b", - "sha256:932bb1ea39a54e9ea27fc9232163059a0b8855256f4052e776357ad9add6f1c9", - "sha256:a00bb73540af068ca7390e636c01cbc4f644961896fa9363154ff43fd37af2f5", - "sha256:a5ca29ee66f8343ed336816c553e82d6cade48a3ad702b9ffa6125d187e2dedb", - "sha256:af9aa9ef5ba1fd5b8c948bb11f44891968ab30356d65fd0cc6707d989cd521df", - "sha256:bb437315738aa441251214dad17428cafda9cdc9729499f1d6001748e1d432f4", - "sha256:bdb230b4943891321e06fc7def63c7aace16095be7d9cf3b1e01be2f10fba439", - "sha256:c6e9dcb4cb338d91a73f178d866d051efe7c62a7166653a91e7d9fb18274058f", - "sha256:cffe3ab27871bc3ea47df5d8f7013945712c46a3cc5a95b6bee15887f1675c22", - "sha256:d012ad7911653a906425d8473a1465caa9f8dea7fcf07b6d870397b774ea7c0f", - "sha256:d9e13b33afd39ddeb377eff2c1c4f00544e191e1d1dee5b6c51ddee8ea6f0cf5", - "sha256:e4b2b334e68b18ac9817d828ba44d8fcb391f6acb398bcc5062b14b2cbeac970", - "sha256:e54962802d4b8b18b6207d4a927032826af39395a3bd9196a5af43fc4e60b009", - "sha256:f705e12750171c0ab4ef2a3c76b9a4024a62c4103e3a55dd6f99265b9bc6fcfc", - "sha256:f881853d2643a29e643609da57b96d5f9c9b93f62429dcc1cbb413c7d07f0e1a", - "sha256:fe60131d21b31fd1a14bd43e6bb88256f69dfc3188b3a89d736d6c71ed43ec95" + "sha256:01d7bdb774a9acc838e6b8f1d114f45303841b89b95984cbb7d80ea41172a9e3", + "sha256:03a6d5349c9ee8f79ab3ff3694d6ce1cfc3ced1c9d36200cb8f08ba06bd3b782", + "sha256:04d48b8ce6ab3cf2097b1855e1505181bdd05586ca275f2505514a6e274e8e75", + "sha256:0770e2806a30e744b4e21c9d73b7bee18a1cfa3c47991ee2e5a65b887c49d5cf", + "sha256:07b05cd3305e8a73112103c834e91cd27ce5b4bd07850c4b4dbd1877d3f45be7", + "sha256:086f92daf51a032d062ec5f58af5ca6a44d082c35299c96376a41cbb33034675", + "sha256:099ebd2c37ac74cce10a3527d2b49af80243e2a4fa39e7bce41617fbc35fa3c1", + "sha256:0c7ebbbde809ff4e970824b2b6cb7e4222be6b95a296e46c03cf050878fc1785", + "sha256:102e487eeb82afac440581e5d7f8f44560b36cf0bdd11abc51a46c1cd88914d4", + "sha256:11691cf4dc5b94236ccc609b70fec991234e7ef8d4c02dd0c9668d1e486f5abf", + "sha256:11a67c0d562e07067c4e86bffc1553f2cf5b664d6111c894671b2b8712f3aba5", + "sha256:12de6add4038df8f72fac606dff775791a60f113a725c960f2bab01d8b8e6b15", + "sha256:13487abd2f761d4be7c8ff9080de2671e53fff69711d46de703c310c4c9317ca", + "sha256:15b09b06dae900777833fe7fc4b4aa426556ce95847a3e8d7548e2d19e34edb8", + "sha256:1c182cb873bc91b411e184dab7a2b664d4fea2743df0e4d57402f7f3fa644bac", + "sha256:1ed0b6477896559f17b9eaeb6d38e07f7f9ffe40b9f0f9627ae8b9926ae260a8", + "sha256:28d490af82bc6b7ce53ff31337a18a10498303fe66f701ab65ef27e143c3b0ef", + "sha256:2e5d962cf7e1d426aa0e528a7e198658cdc8aa4fe87f781d039ad75dcd52c516", + "sha256:2ed076098b171573161eb146afcb9129b5ff63308960aeca4b676d9d3c35e700", + "sha256:2f2f69dca064926e79997f45b2f34e202b320fd3782f17a91941f7eb85502ee2", + "sha256:31560d268ff62143e92423ef183680b9829b1b482c011713ae941997921eebc8", + "sha256:31d1e1c0dbf19ebccbfd62eff461518dcb1e307b195e93bba60c965a4dcf1ba0", + "sha256:37951ad2f4a6df6506750a23f7cbabad24c73c65f23f72e95897bb2cecbae676", + "sha256:3af642b43ce56c24d063325dd2cf20ee012d2b9ba4c3c008755a301aaea720ad", + "sha256:44db35a9e15d6fe5c40d74952e803b1d96e964f683b5a78c3cc64eb177878155", + "sha256:473d93d4450880fe278696549f2e7aed8cd23708c3c1997981464475f32137db", + "sha256:477c3ea0ba410b2b56b7efb072c36fa91b1e6fc331761798fa3f28bb224830dd", + "sha256:4a4a4e30bf1edcad13fb0804300557aedd07a92cabc74382fdd0ba6ca2661091", + "sha256:4aed991a28ea3ce320dc8ce655875e1e00a11bdd29fe9444dd4f88c30d558602", + "sha256:51467000f3647d519272392f484126aa716f747859794ac9924a7aafa86cd411", + "sha256:55c3d1072704d27401c92339144d199d9de7b52627f724a949fc7d5fc56d8b93", + "sha256:589c72667a5febd36f1315aa6e5f56dd4aa4862df295cb51c769d16142ddd7cd", + "sha256:5bfde62d1d2641a1f5173b8c8c2d96ceb4854f54a44c23102e2ccc7e02f003ec", + "sha256:5c23b1ad869653bc818e972b7a3a79852d0e494e9ab7e1a701a3decc49c20d51", + "sha256:61bfc23df345d8c9716d03717c2ed5e27374e0fe6f659ea64edcd27b4b044cf7", + "sha256:6ae828d3a003f03ae31915c31fa684b9890ea44c9c989056fea96e3d12a9fa17", + "sha256:6c7cefb4b0640703eb1069835c02486669312bf2f12b48a748e0a7756d0de33d", + "sha256:6d69f36d445c45cda7b3b26afef2fc34ef5ac0cdc75584a87ef307ee3c8c6d00", + "sha256:6f0d5f33feb5f69ddd57a4a4bd3d56c719a141080b445cbf18f238973c5c9923", + "sha256:6f8b01295e26c68b3a1b90efb7a89029110d3a4139270b24fda961893216c440", + "sha256:713ac174a629d39b7c6a3aa757b337599798da4c1157114a314e4e391cd28e32", + "sha256:718626a174e7e467f0558954f94af117b7d4695d48eb980146016afa4b580b2e", + "sha256:7187a76598bdb895af0adbd2fb7474d7f6025d170bc0a1130242da817ce9e7d1", + "sha256:71927042ed6365a09a98a6377501af5c9f0a4d38083652bcd2281a06a5976724", + "sha256:7d08744e9bae2ca9c382581f7dce1273fe3c9bae94ff572c3626e8da5b193c6a", + "sha256:7dadf3c307b31e0e61689cbf9e06be7a867c563d5a63ce9dca578f956609abf8", + "sha256:81e3d8c34c623ca4e36c46524a3530e99c0bc95ed068fd6e9b55cb721d408fb2", + "sha256:844a9b460871ee0a0b0b68a64890dae9c415e513db0f4a7e3cab41a0f2fedf33", + "sha256:8b7ef7cbd4fec9a1e811a5de813311ed4f7ac7d93e0fda233c9b3e1428f7dd7b", + "sha256:97ef77eb6b044134c0b3a96e16abcb05ecce892965a2124c566af0fd60f717e2", + "sha256:99b5eeae8e019e7aad8af8bb314fb908dd2e028b3cdaad87ec05095394cce632", + "sha256:a25fa703a527158aaf10dafd956f7d42ac6d30ec80e9a70846253dd13e2f067b", + "sha256:a2f635ce61a89c5732537a7896b6319a8fcfa23ba09bec36e1b1ac0ab31270d2", + "sha256:a79004bb58748f31ae1cbe9fa891054baaa46fb106c2dc7af9f8e3304dc30316", + "sha256:a996d01ca39b8dfe77440f3cd600825d05841088fd6bc0144cc6c2ec14cc5f74", + "sha256:b0e20cddbd676ab8a64c774fefa0ad787cc506afd844de95da56060348021e96", + "sha256:b6613280ccedf24354406caf785db748bebbddcf31408b20c0b48cb86af76866", + "sha256:b9d00268fcb9f66fbcc7cd9fe423741d90c75ee029a1d15c09b22d23253c0a44", + "sha256:bb01ba6b0d3f6c68b89fce7305080145d4877ad3acaed424bae4d4ee75faa950", + "sha256:c2aef4703f1f2ddc6df17519885dbfa3514929149d3ff900b73f45998f2532fa", + "sha256:c34dc4958b232ef6188c4318cb7b2c2d80521c9a56c52449f8f93ab7bc2a8a1c", + "sha256:c3630c3ef435c0a7c549ba170a0633a56e92629aeed0e707fec832dee313fb7a", + "sha256:c3d6a4d0619e09dcd61021debf7059955c2004fa29f48788a3dfaf9c9901a7cd", + "sha256:d15367ce87c8e9e09b0f989bfd72dc641bcd04ba091c68cd305312d00962addd", + "sha256:d2f9b69293c33aaa53d923032fe227feac867f81682f002ce33ffae978f0a9a9", + "sha256:e999f2d0e12eea01caeecb17b653f3713d758f6dcc770417cf29ef08d3931421", + "sha256:ea302f34477fda3f85560a06d9ebdc7fa41e82420e892fc50b577e35fc6a50b2", + "sha256:eaba923151d9deea315be1f3e2b31cc39a6d1d2f682f942905951f4e40200922", + "sha256:ef9612483cb35171d51d9173647eed5d0069eaa2ee812793a75373447d487aa4", + "sha256:f5315a2eb0239185af1bddb1abf472d877fede3cc8d143c6cddad37678293237", + "sha256:fa0ffcace9b3aa34d205d8130f7873fcfefcb6a4dd3dd705b0dab69af6712642", + "sha256:fc5471e1a54de15ef71c1bc6ebe80d4dc681ea600e68bfd1cbce40427f0b7578" + ], + "markers": "python_version >= '3.6'", + "version": "==3.8.1" + }, + "aiosignal": { + "hashes": [ + "sha256:26e62109036cd181df6e6ad646f91f0dcfd05fe16d0cb924138ff2ab75d64e3a", + "sha256:78ed67db6c7b7ced4f98e495e572106d5c432a93e1ddd1bf475e1dc05f5b7df2" ], "markers": "python_version >= '3.6'", - "version": "==3.7.4.post0" + "version": "==1.2.0" }, "appdirs": { "hashes": [ @@ -108,11 +208,19 @@ }, "async-timeout": { "hashes": [ - "sha256:0c3c816a028d47f659d6ff5c745cb2acf1f966da1fe5c19c77a70282b25f4c5f", - "sha256:4291ca197d287d274d0b6cb5d6f8f8f82d434ed288f962539ff18cc9012f9ea3" + "sha256:a22c0b311af23337eb05fcf05a8b51c3ea53729d46fb5460af62bee033cec690", + "sha256:b930cb161a39042f9222f6efb7301399c87eeab394727ec5437924a36d6eef51" ], - "markers": "python_full_version >= '3.5.3'", - "version": "==3.0.1" + "markers": "python_version >= '3.6'", + "version": "==4.0.1" + }, + "asynctest": { + "hashes": [ + "sha256:5da6118a7e6d6b54d83a8f7197769d046922a44d2a99c21382f0a6e4fadae676", + "sha256:c27862842d15d83e6a34eb0b2866c323880eb3a75e4485b079ea11748fd77fac" + ], + "markers": "python_version < '3.8'", + "version": "==0.13.0" }, "attrs": { "hashes": [ @@ -130,79 +238,74 @@ "index": "pypi", "version": "==21.7b0" }, - "chardet": { + "charset-normalizer": { "hashes": [ - "sha256:0d6f53a15db4120f2b08c94f11e7d93d2c911ee118b6b30a04ec3ee8310179fa", - "sha256:f864054d66fd9118f2e67044ac8981a54775ec5b67aed0441892edb553d21da5" + "sha256:1eecaa09422db5be9e29d7fc65664e6c33bd06f9ced7838578ba40d58bdf3721", + "sha256:b0b883e8e874edfdece9c28f314e3dd5badf067342e42fb162203335ae61aa2c" ], - "markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3, 3.4'", - "version": "==4.0.0" + "markers": "python_version >= '3.5'", + "version": "==2.0.9" }, "click": { "hashes": [ - "sha256:8c04c11192119b1ef78ea049e0a6f0463e4c48ef00a30160c704337586f3ad7a", - "sha256:fba402a4a47334742d782209a7c79bc448911afe1149d07bdabdf480b3e2f4b6" + "sha256:353f466495adaeb40b6b5f592f9f91cb22372351c84caeb068132442a4518ef3", + "sha256:410e932b050f5eed773c4cda94de75971c89cdb3155a72a0831139a79e5ecb5b" ], "markers": "python_version >= '3.6'", - "version": "==8.0.1" + "version": "==8.0.3" }, "coverage": { "hashes": [ - "sha256:004d1880bed2d97151facef49f08e255a20ceb6f9432df75f4eef018fdd5a78c", - "sha256:01d84219b5cdbfc8122223b39a954820929497a1cb1422824bb86b07b74594b6", - "sha256:040af6c32813fa3eae5305d53f18875bedd079960822ef8ec067a66dd8afcd45", - "sha256:06191eb60f8d8a5bc046f3799f8a07a2d7aefb9504b0209aff0b47298333302a", - "sha256:13034c4409db851670bc9acd836243aeee299949bd5673e11844befcb0149f03", - "sha256:13c4ee887eca0f4c5a247b75398d4114c37882658300e153113dafb1d76de529", - "sha256:184a47bbe0aa6400ed2d41d8e9ed868b8205046518c52464fde713ea06e3a74a", - "sha256:18ba8bbede96a2c3dde7b868de9dcbd55670690af0988713f0603f037848418a", - "sha256:1aa846f56c3d49205c952d8318e76ccc2ae23303351d9270ab220004c580cfe2", - "sha256:217658ec7187497e3f3ebd901afdca1af062b42cfe3e0dafea4cced3983739f6", - "sha256:24d4a7de75446be83244eabbff746d66b9240ae020ced65d060815fac3423759", - "sha256:2910f4d36a6a9b4214bb7038d537f015346f413a975d57ca6b43bf23d6563b53", - "sha256:2949cad1c5208b8298d5686d5a85b66aae46d73eec2c3e08c817dd3513e5848a", - "sha256:2a3859cb82dcbda1cfd3e6f71c27081d18aa251d20a17d87d26d4cd216fb0af4", - "sha256:2cafbbb3af0733db200c9b5f798d18953b1a304d3f86a938367de1567f4b5bff", - "sha256:2e0d881ad471768bf6e6c2bf905d183543f10098e3b3640fc029509530091502", - "sha256:30c77c1dc9f253283e34c27935fded5015f7d1abe83bc7821680ac444eaf7793", - "sha256:3487286bc29a5aa4b93a072e9592f22254291ce96a9fbc5251f566b6b7343cdb", - "sha256:372da284cfd642d8e08ef606917846fa2ee350f64994bebfbd3afb0040436905", - "sha256:41179b8a845742d1eb60449bdb2992196e211341818565abded11cfa90efb821", - "sha256:44d654437b8ddd9eee7d1eaee28b7219bec228520ff809af170488fd2fed3e2b", - "sha256:4a7697d8cb0f27399b0e393c0b90f0f1e40c82023ea4d45d22bce7032a5d7b81", - "sha256:51cb9476a3987c8967ebab3f0fe144819781fca264f57f89760037a2ea191cb0", - "sha256:52596d3d0e8bdf3af43db3e9ba8dcdaac724ba7b5ca3f6358529d56f7a166f8b", - "sha256:53194af30d5bad77fcba80e23a1441c71abfb3e01192034f8246e0d8f99528f3", - "sha256:5fec2d43a2cc6965edc0bb9e83e1e4b557f76f843a77a2496cbe719583ce8184", - "sha256:6c90e11318f0d3c436a42409f2749ee1a115cd8b067d7f14c148f1ce5574d701", - "sha256:74d881fc777ebb11c63736622b60cb9e4aee5cace591ce274fb69e582a12a61a", - "sha256:7501140f755b725495941b43347ba8a2777407fc7f250d4f5a7d2a1050ba8e82", - "sha256:796c9c3c79747146ebd278dbe1e5c5c05dd6b10cc3bcb8389dfdf844f3ead638", - "sha256:869a64f53488f40fa5b5b9dcb9e9b2962a66a87dab37790f3fcfb5144b996ef5", - "sha256:8963a499849a1fc54b35b1c9f162f4108017b2e6db2c46c1bed93a72262ed083", - "sha256:8d0a0725ad7c1a0bcd8d1b437e191107d457e2ec1084b9f190630a4fb1af78e6", - "sha256:900fbf7759501bc7807fd6638c947d7a831fc9fdf742dc10f02956ff7220fa90", - "sha256:92b017ce34b68a7d67bd6d117e6d443a9bf63a2ecf8567bb3d8c6c7bc5014465", - "sha256:970284a88b99673ccb2e4e334cfb38a10aab7cd44f7457564d11898a74b62d0a", - "sha256:972c85d205b51e30e59525694670de6a8a89691186012535f9d7dbaa230e42c3", - "sha256:9a1ef3b66e38ef8618ce5fdc7bea3d9f45f3624e2a66295eea5e57966c85909e", - "sha256:af0e781009aaf59e25c5a678122391cb0f345ac0ec272c7961dc5455e1c40066", - "sha256:b6d534e4b2ab35c9f93f46229363e17f63c53ad01330df9f2d6bd1187e5eaacf", - "sha256:b7895207b4c843c76a25ab8c1e866261bcfe27bfaa20c192de5190121770672b", - "sha256:c0891a6a97b09c1f3e073a890514d5012eb256845c451bd48f7968ef939bf4ae", - "sha256:c2723d347ab06e7ddad1a58b2a821218239249a9e4365eaff6649d31180c1669", - "sha256:d1f8bf7b90ba55699b3a5e44930e93ff0189aa27186e96071fac7dd0d06a1873", - "sha256:d1f9ce122f83b2305592c11d64f181b87153fc2c2bbd3bb4a3dde8303cfb1a6b", - "sha256:d314ed732c25d29775e84a960c3c60808b682c08d86602ec2c3008e1202e3bb6", - "sha256:d636598c8305e1f90b439dbf4f66437de4a5e3c31fdf47ad29542478c8508bbb", - "sha256:deee1077aae10d8fa88cb02c845cfba9b62c55e1183f52f6ae6a2df6a2187160", - "sha256:ebe78fe9a0e874362175b02371bdfbee64d8edc42a044253ddf4ee7d3c15212c", - "sha256:f030f8873312a16414c0d8e1a1ddff2d3235655a2174e3648b4fa66b3f2f1079", - "sha256:f0b278ce10936db1a37e6954e15a3730bea96a0997c26d7fee88e6c396c2086d", - "sha256:f11642dddbb0253cc8853254301b51390ba0081750a8ac03f20ea8103f0c56b6" - ], - "markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3, 3.4' and python_full_version < '4.0.0'", - "version": "==5.5" + "sha256:01774a2c2c729619760320270e42cd9e797427ecfddd32c2a7b639cdc481f3c0", + "sha256:03b20e52b7d31be571c9c06b74746746d4eb82fc260e594dc662ed48145e9efd", + "sha256:0a7726f74ff63f41e95ed3a89fef002916c828bb5fcae83b505b49d81a066884", + "sha256:1219d760ccfafc03c0822ae2e06e3b1248a8e6d1a70928966bafc6838d3c9e48", + "sha256:13362889b2d46e8d9f97c421539c97c963e34031ab0cb89e8ca83a10cc71ac76", + "sha256:174cf9b4bef0db2e8244f82059a5a72bd47e1d40e71c68ab055425172b16b7d0", + "sha256:17e6c11038d4ed6e8af1407d9e89a2904d573be29d51515f14262d7f10ef0a64", + "sha256:215f8afcc02a24c2d9a10d3790b21054b58d71f4b3c6f055d4bb1b15cecce685", + "sha256:22e60a3ca5acba37d1d4a2ee66e051f5b0e1b9ac950b5b0cf4aa5366eda41d47", + "sha256:2641f803ee9f95b1f387f3e8f3bf28d83d9b69a39e9911e5bfee832bea75240d", + "sha256:276651978c94a8c5672ea60a2656e95a3cce2a3f31e9fb2d5ebd4c215d095840", + "sha256:3f7c17209eef285c86f819ff04a6d4cbee9b33ef05cbcaae4c0b4e8e06b3ec8f", + "sha256:3feac4084291642165c3a0d9eaebedf19ffa505016c4d3db15bfe235718d4971", + "sha256:49dbff64961bc9bdd2289a2bda6a3a5a331964ba5497f694e2cbd540d656dc1c", + "sha256:4e547122ca2d244f7c090fe3f4b5a5861255ff66b7ab6d98f44a0222aaf8671a", + "sha256:5829192582c0ec8ca4a2532407bc14c2f338d9878a10442f5d03804a95fac9de", + "sha256:5d6b09c972ce9200264c35a1d53d43ca55ef61836d9ec60f0d44273a31aa9f17", + "sha256:600617008aa82032ddeace2535626d1bc212dfff32b43989539deda63b3f36e4", + "sha256:619346d57c7126ae49ac95b11b0dc8e36c1dd49d148477461bb66c8cf13bb521", + "sha256:63c424e6f5b4ab1cf1e23a43b12f542b0ec2e54f99ec9f11b75382152981df57", + "sha256:6dbc1536e105adda7a6312c778f15aaabe583b0e9a0b0a324990334fd458c94b", + "sha256:6e1394d24d5938e561fbeaa0cd3d356207579c28bd1792f25a068743f2d5b282", + "sha256:86f2e78b1eff847609b1ca8050c9e1fa3bd44ce755b2ec30e70f2d3ba3844644", + "sha256:8bdfe9ff3a4ea37d17f172ac0dff1e1c383aec17a636b9b35906babc9f0f5475", + "sha256:8e2c35a4c1f269704e90888e56f794e2d9c0262fb0c1b1c8c4ee44d9b9e77b5d", + "sha256:92b8c845527eae547a2a6617d336adc56394050c3ed8a6918683646328fbb6da", + "sha256:9365ed5cce5d0cf2c10afc6add145c5037d3148585b8ae0e77cc1efdd6aa2953", + "sha256:9a29311bd6429be317c1f3fe4bc06c4c5ee45e2fa61b2a19d4d1d6111cb94af2", + "sha256:9a2b5b52be0a8626fcbffd7e689781bf8c2ac01613e77feda93d96184949a98e", + "sha256:a4bdeb0a52d1d04123b41d90a4390b096f3ef38eee35e11f0b22c2d031222c6c", + "sha256:a9c8c4283e17690ff1a7427123ffb428ad6a52ed720d550e299e8291e33184dc", + "sha256:b637c57fdb8be84e91fac60d9325a66a5981f8086c954ea2772efe28425eaf64", + "sha256:bf154ba7ee2fd613eb541c2bc03d3d9ac667080a737449d1a3fb342740eb1a74", + "sha256:c254b03032d5a06de049ce8bca8338a5185f07fb76600afff3c161e053d88617", + "sha256:c332d8f8d448ded473b97fefe4a0983265af21917d8b0cdcb8bb06b2afe632c3", + "sha256:c7912d1526299cb04c88288e148c6c87c0df600eca76efd99d84396cfe00ef1d", + "sha256:cfd9386c1d6f13b37e05a91a8583e802f8059bebfccde61a418c5808dea6bbfa", + "sha256:d5d2033d5db1d58ae2d62f095e1aefb6988af65b4b12cb8987af409587cc0739", + "sha256:dca38a21e4423f3edb821292e97cec7ad38086f84313462098568baedf4331f8", + "sha256:e2cad8093172b7d1595b4ad66f24270808658e11acf43a8f95b41276162eb5b8", + "sha256:e3db840a4dee542e37e09f30859f1612da90e1c5239a6a2498c473183a50e781", + "sha256:edcada2e24ed68f019175c2b2af2a8b481d3d084798b8c20d15d34f5c733fa58", + "sha256:f467bbb837691ab5a8ca359199d3429a11a01e6dfb3d9dcc676dc035ca93c0a9", + "sha256:f506af4f27def639ba45789fa6fde45f9a217da0be05f8910458e4557eed020c", + "sha256:f614fc9956d76d8a88a88bb41ddc12709caa755666f580af3a688899721efecd", + "sha256:f9afb5b746781fc2abce26193d1c817b7eb0e11459510fba65d2bd77fe161d9e", + "sha256:fb8b8ee99b3fffe4fd86f4c81b35a6bf7e4462cba019997af2fe679365db0c49" + ], + "markers": "python_version >= '3.6'", + "version": "==6.2" }, "flake8": { "hashes": [ @@ -235,21 +338,99 @@ "index": "pypi", "version": "==1.1.0" }, + "frozenlist": { + "hashes": [ + "sha256:01d79515ed5aa3d699b05f6bdcf1fe9087d61d6b53882aa599a10853f0479c6c", + "sha256:0a7c7cce70e41bc13d7d50f0e5dd175f14a4f1837a8549b0936ed0cbe6170bf9", + "sha256:11ff401951b5ac8c0701a804f503d72c048173208490c54ebb8d7bb7c07a6d00", + "sha256:14a5cef795ae3e28fb504b73e797c1800e9249f950e1c964bb6bdc8d77871161", + "sha256:16eef427c51cb1203a7c0ab59d1b8abccaba9a4f58c4bfca6ed278fc896dc193", + "sha256:16ef7dd5b7d17495404a2e7a49bac1bc13d6d20c16d11f4133c757dd94c4144c", + "sha256:181754275d5d32487431a0a29add4f897968b7157204bc1eaaf0a0ce80c5ba7d", + "sha256:1cf63243bc5f5c19762943b0aa9e0d3fb3723d0c514d820a18a9b9a5ef864315", + "sha256:1cfe6fef507f8bac40f009c85c7eddfed88c1c0d38c75e72fe10476cef94e10f", + "sha256:1fef737fd1388f9b93bba8808c5f63058113c10f4e3c0763ced68431773f72f9", + "sha256:25b358aaa7dba5891b05968dd539f5856d69f522b6de0bf34e61f133e077c1a4", + "sha256:26f602e380a5132880fa245c92030abb0fc6ff34e0c5500600366cedc6adb06a", + "sha256:28e164722ea0df0cf6d48c4d5bdf3d19e87aaa6dfb39b0ba91153f224b912020", + "sha256:2de5b931701257d50771a032bba4e448ff958076380b049fd36ed8738fdb375b", + "sha256:3457f8cf86deb6ce1ba67e120f1b0128fcba1332a180722756597253c465fc1d", + "sha256:351686ca020d1bcd238596b1fa5c8efcbc21bffda9d0efe237aaa60348421e2a", + "sha256:406aeb340613b4b559db78d86864485f68919b7141dec82aba24d1477fd2976f", + "sha256:41de4db9b9501679cf7cddc16d07ac0f10ef7eb58c525a1c8cbff43022bddca4", + "sha256:41f62468af1bd4e4b42b5508a3fe8cc46a693f0cdd0ca2f443f51f207893d837", + "sha256:4766632cd8a68e4f10f156a12c9acd7b1609941525569dd3636d859d79279ed3", + "sha256:47b2848e464883d0bbdcd9493c67443e5e695a84694efff0476f9059b4cb6257", + "sha256:4a495c3d513573b0b3f935bfa887a85d9ae09f0627cf47cad17d0cc9b9ba5c38", + "sha256:4ad065b2ebd09f32511ff2be35c5dfafee6192978b5a1e9d279a5c6e121e3b03", + "sha256:4c457220468d734e3077580a3642b7f682f5fd9507f17ddf1029452450912cdc", + "sha256:4f52d0732e56906f8ddea4bd856192984650282424049c956857fed43697ea43", + "sha256:54a1e09ab7a69f843cd28fefd2bcaf23edb9e3a8d7680032c8968b8ac934587d", + "sha256:5a72eecf37eface331636951249d878750db84034927c997d47f7f78a573b72b", + "sha256:5df31bb2b974f379d230a25943d9bf0d3bc666b4b0807394b131a28fca2b0e5f", + "sha256:66a518731a21a55b7d3e087b430f1956a36793acc15912e2878431c7aec54210", + "sha256:6790b8d96bbb74b7a6f4594b6f131bd23056c25f2aa5d816bd177d95245a30e3", + "sha256:68201be60ac56aff972dc18085800b6ee07973c49103a8aba669dee3d71079de", + "sha256:6e105013fa84623c057a4381dc8ea0361f4d682c11f3816cc80f49a1f3bc17c6", + "sha256:705c184b77565955a99dc360f359e8249580c6b7eaa4dc0227caa861ef46b27a", + "sha256:72cfbeab7a920ea9e74b19aa0afe3b4ad9c89471e3badc985d08756efa9b813b", + "sha256:735f386ec522e384f511614c01d2ef9cf799f051353876b4c6fb93ef67a6d1ee", + "sha256:82d22f6e6f2916e837c91c860140ef9947e31194c82aaeda843d6551cec92f19", + "sha256:83334e84a290a158c0c4cc4d22e8c7cfe0bba5b76d37f1c2509dabd22acafe15", + "sha256:84e97f59211b5b9083a2e7a45abf91cfb441369e8bb6d1f5287382c1c526def3", + "sha256:87521e32e18a2223311afc2492ef2d99946337da0779ddcda77b82ee7319df59", + "sha256:878ebe074839d649a1cdb03a61077d05760624f36d196884a5cafb12290e187b", + "sha256:89fdfc84c6bf0bff2ff3170bb34ecba8a6911b260d318d377171429c4be18c73", + "sha256:8b4c7665a17c3a5430edb663e4ad4e1ad457614d1b2f2b7f87052e2ef4fa45ca", + "sha256:8b54cdd2fda15467b9b0bfa78cee2ddf6dbb4585ef23a16e14926f4b076dfae4", + "sha256:94728f97ddf603d23c8c3dd5cae2644fa12d33116e69f49b1644a71bb77b89ae", + "sha256:954b154a4533ef28bd3e83ffdf4eadf39deeda9e38fb8feaf066d6069885e034", + "sha256:977a1438d0e0d96573fd679d291a1542097ea9f4918a8b6494b06610dfeefbf9", + "sha256:9ade70aea559ca98f4b1b1e5650c45678052e76a8ab2f76d90f2ac64180215a2", + "sha256:9b6e21e5770df2dea06cb7b6323fbc008b13c4a4e3b52cb54685276479ee7676", + "sha256:a0d3ffa8772464441b52489b985d46001e2853a3b082c655ec5fad9fb6a3d618", + "sha256:a37594ad6356e50073fe4f60aa4187b97d15329f2138124d252a5a19c8553ea4", + "sha256:a8d86547a5e98d9edd47c432f7a14b0c5592624b496ae9880fb6332f34af1edc", + "sha256:aa44c4740b4e23fcfa259e9dd52315d2b1770064cde9507457e4c4a65a04c397", + "sha256:acc4614e8d1feb9f46dd829a8e771b8f5c4b1051365d02efb27a3229048ade8a", + "sha256:af2a51c8a381d76eabb76f228f565ed4c3701441ecec101dd18be70ebd483cfd", + "sha256:b2ae2f5e9fa10805fb1c9adbfefaaecedd9e31849434be462c3960a0139ed729", + "sha256:b46f997d5ed6d222a863b02cdc9c299101ee27974d9bbb2fd1b3c8441311c408", + "sha256:bc93f5f62df3bdc1f677066327fc81f92b83644852a31c6aa9b32c2dde86ea7d", + "sha256:bfbaa08cf1452acad9cb1c1d7b89394a41e712f88df522cea1a0f296b57782a0", + "sha256:c1e8e9033d34c2c9e186e58279879d78c94dd365068a3607af33f2bc99357a53", + "sha256:c5328ed53fdb0a73c8a50105306a3bc013e5ca36cca714ec4f7bd31d38d8a97f", + "sha256:c6a9d84ee6427b65a81fc24e6ef589cb794009f5ca4150151251c062773e7ed2", + "sha256:c98d3c04701773ad60d9545cd96df94d955329efc7743fdb96422c4b669c633b", + "sha256:cb3957c39668d10e2b486acc85f94153520a23263b6401e8f59422ef65b9520d", + "sha256:e63ad0beef6ece06475d29f47d1f2f29727805376e09850ebf64f90777962792", + "sha256:e74f8b4d8677ebb4015ac01fcaf05f34e8a1f22775db1f304f497f2f88fdc697", + "sha256:e7d0dd3e727c70c2680f5f09a0775525229809f1a35d8552b92ff10b2b14f2c2", + "sha256:ec6cf345771cdb00791d271af9a0a6fbfc2b6dd44cb753f1eeaa256e21622adb", + "sha256:ed58803563a8c87cf4c0771366cf0ad1aa265b6b0ae54cbbb53013480c7ad74d", + "sha256:f0081a623c886197ff8de9e635528fd7e6a387dccef432149e25c13946cb0cd0", + "sha256:f025f1d6825725b09c0038775acab9ae94264453a696cc797ce20c0769a7b367", + "sha256:f5f3b2942c3b8b9bfe76b408bbaba3d3bb305ee3693e8b1d631fe0a0d4f93673", + "sha256:fbd4844ff111449f3bbe20ba24fbb906b5b1c2384d0f3287c9f7da2354ce6d23" + ], + "markers": "python_version >= '3.6'", + "version": "==1.2.0" + }, "idna": { "hashes": [ - "sha256:14475042e284991034cb48e06f6851428fb14c4dc953acd9be9a5e95c7b6dd7a", - "sha256:467fbad99067910785144ce333826c71fb0e63a425657295239737f7ecd125f3" + "sha256:84d9dd047ffa80596e0f246e2eab0b391788b0503584e8945f2368256d2735ff", + "sha256:9d643ff0a55b762d5cdb124b8eaa99c66322e2157b69160bc32796e824360e6d" ], "markers": "python_version >= '3.5'", - "version": "==3.2" + "version": "==3.3" }, "importlib-metadata": { "hashes": [ - "sha256:b618b6d2d5ffa2f16add5697cf57a46c76a56229b0ed1c438322e4e95645bd15", - "sha256:f284b3e11256ad1e5d03ab86bb2ccd6f5339688ff17a4d797a0fe7df326f23b1" + "sha256:53ccfd5c134223e497627b9815d5030edf77d2ed573922f7a0b8f8bb81a1c100", + "sha256:75bdec14c397f528724c1bfd9709d660b33a4d2e77387a3358f20b848bb5e5fb" ], "markers": "python_version < '3.8'", - "version": "==4.8.1" + "version": "==4.8.2" }, "iniconfig": { "hashes": [ @@ -275,46 +456,81 @@ }, "multidict": { "hashes": [ - "sha256:018132dbd8688c7a69ad89c4a3f39ea2f9f33302ebe567a879da8f4ca73f0d0a", - "sha256:051012ccee979b2b06be928a6150d237aec75dd6bf2d1eeeb190baf2b05abc93", - "sha256:05c20b68e512166fddba59a918773ba002fdd77800cad9f55b59790030bab632", - "sha256:07b42215124aedecc6083f1ce6b7e5ec5b50047afa701f3442054373a6deb656", - "sha256:0e3c84e6c67eba89c2dbcee08504ba8644ab4284863452450520dad8f1e89b79", - "sha256:0e929169f9c090dae0646a011c8b058e5e5fb391466016b39d21745b48817fd7", - "sha256:1ab820665e67373de5802acae069a6a05567ae234ddb129f31d290fc3d1aa56d", - "sha256:25b4e5f22d3a37ddf3effc0710ba692cfc792c2b9edfb9c05aefe823256e84d5", - "sha256:2e68965192c4ea61fff1b81c14ff712fc7dc15d2bd120602e4a3494ea6584224", - "sha256:2f1a132f1c88724674271d636e6b7351477c27722f2ed789f719f9e3545a3d26", - "sha256:37e5438e1c78931df5d3c0c78ae049092877e5e9c02dd1ff5abb9cf27a5914ea", - "sha256:3a041b76d13706b7fff23b9fc83117c7b8fe8d5fe9e6be45eee72b9baa75f348", - "sha256:3a4f32116f8f72ecf2a29dabfb27b23ab7cdc0ba807e8459e59a93a9be9506f6", - "sha256:46c73e09ad374a6d876c599f2328161bcd95e280f84d2060cf57991dec5cfe76", - "sha256:46dd362c2f045095c920162e9307de5ffd0a1bfbba0a6e990b344366f55a30c1", - "sha256:4b186eb7d6ae7c06eb4392411189469e6a820da81447f46c0072a41c748ab73f", - "sha256:54fd1e83a184e19c598d5e70ba508196fd0bbdd676ce159feb412a4a6664f952", - "sha256:585fd452dd7782130d112f7ddf3473ffdd521414674c33876187e101b588738a", - "sha256:5cf3443199b83ed9e955f511b5b241fd3ae004e3cb81c58ec10f4fe47c7dce37", - "sha256:6a4d5ce640e37b0efcc8441caeea8f43a06addace2335bd11151bc02d2ee31f9", - "sha256:7df80d07818b385f3129180369079bd6934cf70469f99daaebfac89dca288359", - "sha256:806068d4f86cb06af37cd65821554f98240a19ce646d3cd24e1c33587f313eb8", - "sha256:830f57206cc96ed0ccf68304141fec9481a096c4d2e2831f311bde1c404401da", - "sha256:929006d3c2d923788ba153ad0de8ed2e5ed39fdbe8e7be21e2f22ed06c6783d3", - "sha256:9436dc58c123f07b230383083855593550c4d301d2532045a17ccf6eca505f6d", - "sha256:9dd6e9b1a913d096ac95d0399bd737e00f2af1e1594a787e00f7975778c8b2bf", - "sha256:ace010325c787c378afd7f7c1ac66b26313b3344628652eacd149bdd23c68841", - "sha256:b47a43177a5e65b771b80db71e7be76c0ba23cc8aa73eeeb089ed5219cdbe27d", - "sha256:b797515be8743b771aa868f83563f789bbd4b236659ba52243b735d80b29ed93", - "sha256:b7993704f1a4b204e71debe6095150d43b2ee6150fa4f44d6d966ec356a8d61f", - "sha256:d5c65bdf4484872c4af3150aeebe101ba560dcfb34488d9a8ff8dbcd21079647", - "sha256:d81eddcb12d608cc08081fa88d046c78afb1bf8107e6feab5d43503fea74a635", - "sha256:dc862056f76443a0db4509116c5cd480fe1b6a2d45512a653f9a855cc0517456", - "sha256:ecc771ab628ea281517e24fd2c52e8f31c41e66652d07599ad8818abaad38cda", - "sha256:f200755768dc19c6f4e2b672421e0ebb3dd54c38d5a4f262b872d8cfcc9e93b5", - "sha256:f21756997ad8ef815d8ef3d34edd98804ab5ea337feedcd62fb52d22bf531281", - "sha256:fc13a9524bc18b6fb6e0dbec3533ba0496bbed167c56d0aabefd965584557d80" + "sha256:06560fbdcf22c9387100979e65b26fba0816c162b888cb65b845d3def7a54c9b", + "sha256:067150fad08e6f2dd91a650c7a49ba65085303fcc3decbd64a57dc13a2733031", + "sha256:0a2cbcfbea6dc776782a444db819c8b78afe4db597211298dd8b2222f73e9cd0", + "sha256:0dd1c93edb444b33ba2274b66f63def8a327d607c6c790772f448a53b6ea59ce", + "sha256:0fed465af2e0eb6357ba95795d003ac0bdb546305cc2366b1fc8f0ad67cc3fda", + "sha256:116347c63ba049c1ea56e157fa8aa6edaf5e92925c9b64f3da7769bdfa012858", + "sha256:1b4ac3ba7a97b35a5ccf34f41b5a8642a01d1e55454b699e5e8e7a99b5a3acf5", + "sha256:1c7976cd1c157fa7ba5456ae5d31ccdf1479680dc9b8d8aa28afabc370df42b8", + "sha256:246145bff76cc4b19310f0ad28bd0769b940c2a49fc601b86bfd150cbd72bb22", + "sha256:25cbd39a9029b409167aa0a20d8a17f502d43f2efebfe9e3ac019fe6796c59ac", + "sha256:28e6d883acd8674887d7edc896b91751dc2d8e87fbdca8359591a13872799e4e", + "sha256:2d1d55cdf706ddc62822d394d1df53573d32a7a07d4f099470d3cb9323b721b6", + "sha256:2e77282fd1d677c313ffcaddfec236bf23f273c4fba7cdf198108f5940ae10f5", + "sha256:32fdba7333eb2351fee2596b756d730d62b5827d5e1ab2f84e6cbb287cc67fe0", + "sha256:35591729668a303a02b06e8dba0eb8140c4a1bfd4c4b3209a436a02a5ac1de11", + "sha256:380b868f55f63d048a25931a1632818f90e4be71d2081c2338fcf656d299949a", + "sha256:3822c5894c72e3b35aae9909bef66ec83e44522faf767c0ad39e0e2de11d3b55", + "sha256:38ba256ee9b310da6a1a0f013ef4e422fca30a685bcbec86a969bd520504e341", + "sha256:3bc3b1621b979621cee9f7b09f024ec76ec03cc365e638126a056317470bde1b", + "sha256:3d2d7d1fff8e09d99354c04c3fd5b560fb04639fd45926b34e27cfdec678a704", + "sha256:517d75522b7b18a3385726b54a081afd425d4f41144a5399e5abd97ccafdf36b", + "sha256:5f79c19c6420962eb17c7e48878a03053b7ccd7b69f389d5831c0a4a7f1ac0a1", + "sha256:5f841c4f14331fd1e36cbf3336ed7be2cb2a8f110ce40ea253e5573387db7621", + "sha256:637c1896497ff19e1ee27c1c2c2ddaa9f2d134bbb5e0c52254361ea20486418d", + "sha256:6ee908c070020d682e9b42c8f621e8bb10c767d04416e2ebe44e37d0f44d9ad5", + "sha256:77f0fb7200cc7dedda7a60912f2059086e29ff67cefbc58d2506638c1a9132d7", + "sha256:7878b61c867fb2df7a95e44b316f88d5a3742390c99dfba6c557a21b30180cac", + "sha256:78c106b2b506b4d895ddc801ff509f941119394b89c9115580014127414e6c2d", + "sha256:8b911d74acdc1fe2941e59b4f1a278a330e9c34c6c8ca1ee21264c51ec9b67ef", + "sha256:93de39267c4c676c9ebb2057e98a8138bade0d806aad4d864322eee0803140a0", + "sha256:9416cf11bcd73c861267e88aea71e9fcc35302b3943e45e1dbb4317f91a4b34f", + "sha256:94b117e27efd8e08b4046c57461d5a114d26b40824995a2eb58372b94f9fca02", + "sha256:9815765f9dcda04921ba467957be543423e5ec6a1136135d84f2ae092c50d87b", + "sha256:98ec9aea6223adf46999f22e2c0ab6cf33f5914be604a404f658386a8f1fba37", + "sha256:a37e9a68349f6abe24130846e2f1d2e38f7ddab30b81b754e5a1fde32f782b23", + "sha256:a43616aec0f0d53c411582c451f5d3e1123a68cc7b3475d6f7d97a626f8ff90d", + "sha256:a4771d0d0ac9d9fe9e24e33bed482a13dfc1256d008d101485fe460359476065", + "sha256:a5635bcf1b75f0f6ef3c8a1ad07b500104a971e38d3683167b9454cb6465ac86", + "sha256:a9acb76d5f3dd9421874923da2ed1e76041cb51b9337fd7f507edde1d86535d6", + "sha256:ac42181292099d91217a82e3fa3ce0e0ddf3a74fd891b7c2b347a7f5aa0edded", + "sha256:b227345e4186809d31f22087d0265655114af7cda442ecaf72246275865bebe4", + "sha256:b61f85101ef08cbbc37846ac0e43f027f7844f3fade9b7f6dd087178caedeee7", + "sha256:b70913cbf2e14275013be98a06ef4b412329fe7b4f83d64eb70dce8269ed1e1a", + "sha256:b9aad49466b8d828b96b9e3630006234879c8d3e2b0a9d99219b3121bc5cdb17", + "sha256:baf1856fab8212bf35230c019cde7c641887e3fc08cadd39d32a421a30151ea3", + "sha256:bd6c9c50bf2ad3f0448edaa1a3b55b2e6866ef8feca5d8dbec10ec7c94371d21", + "sha256:c1ff762e2ee126e6f1258650ac641e2b8e1f3d927a925aafcfde943b77a36d24", + "sha256:c30ac9f562106cd9e8071c23949a067b10211917fdcb75b4718cf5775356a940", + "sha256:c9631c642e08b9fff1c6255487e62971d8b8e821808ddd013d8ac058087591ac", + "sha256:cdd68778f96216596218b4e8882944d24a634d984ee1a5a049b300377878fa7c", + "sha256:ce8cacda0b679ebc25624d5de66c705bc53dcc7c6f02a7fb0f3ca5e227d80422", + "sha256:cfde464ca4af42a629648c0b0d79b8f295cf5b695412451716531d6916461628", + "sha256:d3def943bfd5f1c47d51fd324df1e806d8da1f8e105cc7f1c76a1daf0f7e17b0", + "sha256:d9b668c065968c5979fe6b6fa6760bb6ab9aeb94b75b73c0a9c1acf6393ac3bf", + "sha256:da7d57ea65744d249427793c042094c4016789eb2562576fb831870f9c878d9e", + "sha256:dc3a866cf6c13d59a01878cd806f219340f3e82eed514485e094321f24900677", + "sha256:df23c83398715b26ab09574217ca21e14694917a0c857e356fd39e1c64f8283f", + "sha256:dfc924a7e946dd3c6360e50e8f750d51e3ef5395c95dc054bc9eab0f70df4f9c", + "sha256:e4a67f1080123de76e4e97a18d10350df6a7182e243312426d508712e99988d4", + "sha256:e5283c0a00f48e8cafcecadebfa0ed1dac8b39e295c7248c44c665c16dc1138b", + "sha256:e58a9b5cc96e014ddf93c2227cbdeca94b56a7eb77300205d6e4001805391747", + "sha256:e6453f3cbeb78440747096f239d282cc57a2997a16b5197c9bc839099e1633d0", + "sha256:e6c4fa1ec16e01e292315ba76eb1d012c025b99d22896bd14a66628b245e3e01", + "sha256:e7d81ce5744757d2f05fc41896e3b2ae0458464b14b5a2c1e87a6a9d69aefaa8", + "sha256:ea21d4d5104b4f840b91d9dc8cbc832aba9612121eaba503e54eaab1ad140eb9", + "sha256:ecc99bce8ee42dcad15848c7885197d26841cb24fa2ee6e89d23b8993c871c64", + "sha256:f0bb0973f42ffcb5e3537548e0767079420aefd94ba990b61cf7bb8d47f4916d", + "sha256:f19001e790013ed580abfde2a4465388950728861b52f0da73e8e8a9418533c0", + "sha256:f76440e480c3b2ca7f843ff8a48dc82446b86ed4930552d736c0bac507498a52", + "sha256:f9bef5cff994ca3026fcc90680e326d1a19df9841c5e3d224076407cc21471a1", + "sha256:fc66d4016f6e50ed36fb39cd287a3878ffcebfa90008535c62e0e90a7ab713ae", + "sha256:fd77c8f3cba815aa69cb97ee2b2ef385c7c12ada9c734b0f3b32e26bb88bbf1d" ], "markers": "python_version >= '3.6'", - "version": "==5.1.0" + "version": "==5.2.0" }, "mypy": { "hashes": [ @@ -354,11 +570,11 @@ }, "packaging": { "hashes": [ - "sha256:7dc96269f53a4ccec5c0670940a4281106dd0bb343f47b7471f779df49c2fbe7", - "sha256:c86254f9220d55e31cc94d69bade760f0847da8000def4dfe1c6b872fd14ff14" + "sha256:dd47c42927d89ab911e606518907cc2d3a1f38bbd026385970643f9c5b8ecfeb", + "sha256:ef103e05f519cdc783ae24ea4e2e0f508a9c99b2d4969652eed6a2e1ea5bd522" ], "markers": "python_version >= '3.6'", - "version": "==21.0" + "version": "==21.3" }, "pathspec": { "hashes": [ @@ -377,11 +593,11 @@ }, "py": { "hashes": [ - "sha256:21b81bda15b66ef5e1a777a21c4dcd9c20ad3efd0b3f817e7a809035269e1bd3", - "sha256:3b80836aa6d1feeaa108e046da6423ab8f6ceda6468545ae8d02d9d58d18818a" + "sha256:51c75c4126074b472f746a24399ad32f6053d1b34b68d2fa41e558e6f4a98719", + "sha256:607c53218732647dff4acdfcd50cb62615cedf612e72d1724fb1a0cc6405b378" ], - "markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3'", - "version": "==1.10.0" + "markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3, 3.4'", + "version": "==1.11.0" }, "pycodestyle": { "hashes": [ @@ -409,11 +625,11 @@ }, "pyparsing": { "hashes": [ - "sha256:c203ec8783bf771a155b207279b9bccb8dea02d8f0c9e5f8ead507bc3246ecc1", - "sha256:ef9d7589ef3c200abe66653d3f1ab1033c3c419ae9b9bdb1240a85b024efc88b" + "sha256:04ff808a5b90911829c55c4e26f75fa5ca8a2f5f36aa3a51f68e27033341d3e4", + "sha256:d9bdec0013ef1eb5a84ab39a3b3868911598afa494f5faa038647101504e2b81" ], - "markers": "python_version >= '2.6' and python_version not in '3.0, 3.1, 3.2, 3.3'", - "version": "==2.4.7" + "markers": "python_version >= '3.6'", + "version": "==3.0.6" }, "pytest": { "hashes": [ @@ -441,56 +657,89 @@ }, "regex": { "hashes": [ - "sha256:0de8ad66b08c3e673b61981b9e3626f8784d5564f8c3928e2ad408c0eb5ac38c", - "sha256:1f1125bc5172ab3a049bc6f4b9c0aae95a2a2001a77e6d6e4239fa3653e202b5", - "sha256:255791523f80ea8e48e79af7120b4697ef3b74f6886995dcdb08c41f8e516be0", - "sha256:28040e89a04b60d579c69095c509a4f6a1a5379cd865258e3a186b7105de72c6", - "sha256:37868075eda024470bd0feab872c692ac4ee29db1e14baec103257bf6cc64346", - "sha256:3b71213ec3bad9a5a02e049f2ec86b3d7c3e350129ae0f4e2f99c12b5da919ed", - "sha256:3be40f720af170a6b20ddd2ad7904c58b13d2b56f6734ee5d09bbdeed2fa4816", - "sha256:42952d325439ef223e4e9db7ee6d9087b5c68c5c15b1f9de68e990837682fc7b", - "sha256:470f2c882f2672d8eeda8ab27992aec277c067d280b52541357e1acd7e606dae", - "sha256:4907fb0f9b9309a5bded72343e675a252c2589a41871874feace9a05a540241e", - "sha256:4d87459ad3ab40cd8493774f8a454b2e490d8e729e7e402a0625867a983e4e02", - "sha256:4fa7ba9ab2eba7284e0d7d94f61df7af86015b0398e123331362270d71fab0b9", - "sha256:5b34d2335d6aedec7dcadd3f8283b9682fadad8b9b008da8788d2fce76125ebe", - "sha256:6348a7ab2a502cbdd0b7fd0496d614007489adb7361956b38044d1d588e66e04", - "sha256:638e98d069b14113e8afba6a54d1ca123f712c0d105e67c1f9211b2a825ef926", - "sha256:66696c8336a1b5d1182464f3af3427cc760118f26d0b09a2ddc16a976a4d2637", - "sha256:78cf6a1e023caf5e9a982f5377414e1aeac55198831b852835732cfd0a0ca5ff", - "sha256:81e125d9ba54c34579e4539a967e976a3c56150796674aec318b1b2f49251be7", - "sha256:81fdc90f999b2147fc62e303440c424c47e5573a9b615ed5d43a5b832efcca9e", - "sha256:87e9c489aa98f50f367fb26cc9c8908d668e9228d327644d7aa568d47e456f47", - "sha256:8c1ad61fa024195136a6b7b89538030bd00df15f90ac177ca278df9b2386c96f", - "sha256:9910869c472e5a6728680ca357b5846546cbbd2ab3ad5bef986ef0bc438d0aa6", - "sha256:9925985be05d54b3d25fd6c1ea8e50ff1f7c2744c75bdc4d3b45c790afa2bcb3", - "sha256:9a0b0db6b49da7fa37ca8eddf9f40a8dbc599bad43e64f452284f37b6c34d91c", - "sha256:9c065d95a514a06b92a5026766d72ac91bfabf581adb5b29bc5c91d4b3ee9b83", - "sha256:a6f08187136f11e430638c2c66e1db091105d7c2e9902489f0dbc69b44c222b4", - "sha256:ad0517df22a97f1da20d8f1c8cb71a5d1997fa383326b81f9cf22c9dadfbdf34", - "sha256:b345ecde37c86dd7084c62954468a4a655fd2d24fd9b237949dd07a4d0dd6f4c", - "sha256:b55442650f541d195a535ccec33078c78a9521973fb960923da7515e9ed78fa6", - "sha256:c2b180ed30856dfa70cfe927b0fd38e6b68198a03039abdbeb1f2029758d87e7", - "sha256:c9e30838df7bfd20db6466fd309d9b580d32855f8e2c2e6d74cf9da27dcd9b63", - "sha256:cae4099031d80703954c39680323dabd87a69b21262303160776aa0e55970ca0", - "sha256:ce7b1cca6c23f19bee8dc40228d9c314d86d1e51996b86f924aca302fc8f8bf9", - "sha256:d0861e7f6325e821d5c40514c551fd538b292f8cc3960086e73491b9c5d8291d", - "sha256:d331f238a7accfbbe1c4cd1ba610d4c087b206353539331e32a8f05345c74aec", - "sha256:e07049cece3462c626d650e8bf42ddbca3abf4aa08155002c28cb6d9a5a281e2", - "sha256:e2cb7d4909ed16ed35729d38af585673f1f0833e73dfdf0c18e5be0061107b99", - "sha256:e3770781353a4886b68ef10cec31c1f61e8e3a0be5f213c2bb15a86efd999bc4", - "sha256:e502f8d4e5ef714bcc2c94d499684890c94239526d61fdf1096547db91ca6aa6", - "sha256:e6f2d2f93001801296fe3ca86515eb04915472b5380d4d8752f09f25f0b9b0ed", - "sha256:f588209d3e4797882cd238195c175290dbc501973b10a581086b5c6bcd095ffb" - ], - "version": "==2021.9.30" + "sha256:0416f7399e918c4b0e074a0f66e5191077ee2ca32a0f99d4c187a62beb47aa05", + "sha256:05b7d6d7e64efe309972adab77fc2af8907bb93217ec60aa9fe12a0dad35874f", + "sha256:0617383e2fe465732af4509e61648b77cbe3aee68b6ac8c0b6fe934db90be5cc", + "sha256:07856afef5ffcc052e7eccf3213317fbb94e4a5cd8177a2caa69c980657b3cb4", + "sha256:0f594b96fe2e0821d026365f72ac7b4f0b487487fb3d4aaf10dd9d97d88a9737", + "sha256:139a23d1f5d30db2cc6c7fd9c6d6497872a672db22c4ae1910be22d4f4b2068a", + "sha256:162abfd74e88001d20cb73ceaffbfe601469923e875caf9118333b1a4aaafdc4", + "sha256:2207ae4f64ad3af399e2d30dde66f0b36ae5c3129b52885f1bffc2f05ec505c8", + "sha256:2409b5c9cef7054dde93a9803156b411b677affc84fca69e908b1cb2c540025d", + "sha256:2fee3ed82a011184807d2127f1733b4f6b2ff6ec7151d83ef3477f3b96a13d03", + "sha256:30ab804ea73972049b7a2a5c62d97687d69b5a60a67adca07eb73a0ddbc9e29f", + "sha256:3598893bde43091ee5ca0a6ad20f08a0435e93a69255eeb5f81b85e81e329264", + "sha256:3b5df18db1fccd66de15aa59c41e4f853b5df7550723d26aa6cb7f40e5d9da5a", + "sha256:3c5fb32cc6077abad3bbf0323067636d93307c9fa93e072771cf9a64d1c0f3ef", + "sha256:416c5f1a188c91e3eb41e9c8787288e707f7d2ebe66e0a6563af280d9b68478f", + "sha256:42b50fa6666b0d50c30a990527127334d6b96dd969011e843e726a64011485da", + "sha256:432bd15d40ed835a51617521d60d0125867f7b88acf653e4ed994a1f8e4995dc", + "sha256:473e67837f786404570eae33c3b64a4b9635ae9f00145250851a1292f484c063", + "sha256:4aaa4e0705ef2b73dd8e36eeb4c868f80f8393f5f4d855e94025ce7ad8525f50", + "sha256:50a7ddf3d131dc5633dccdb51417e2d1910d25cbcf842115a3a5893509140a3a", + "sha256:529801a0d58809b60b3531ee804d3e3be4b412c94b5d267daa3de7fadef00f49", + "sha256:537ca6a3586931b16a85ac38c08cc48f10fc870a5b25e51794c74df843e9966d", + "sha256:53db2c6be8a2710b359bfd3d3aa17ba38f8aa72a82309a12ae99d3c0c3dcd74d", + "sha256:5537f71b6d646f7f5f340562ec4c77b6e1c915f8baae822ea0b7e46c1f09b733", + "sha256:563d5f9354e15e048465061509403f68424fef37d5add3064038c2511c8f5e00", + "sha256:5d408a642a5484b9b4d11dea15a489ea0928c7e410c7525cd892f4d04f2f617b", + "sha256:61600a7ca4bcf78a96a68a27c2ae9389763b5b94b63943d5158f2a377e09d29a", + "sha256:6650f16365f1924d6014d2ea770bde8555b4a39dc9576abb95e3cd1ff0263b36", + "sha256:666abff54e474d28ff42756d94544cdfd42e2ee97065857413b72e8a2d6a6345", + "sha256:68a067c11463de2a37157930d8b153005085e42bcb7ad9ca562d77ba7d1404e0", + "sha256:6e1d2cc79e8dae442b3fa4a26c5794428b98f81389af90623ffcc650ce9f6732", + "sha256:74cbeac0451f27d4f50e6e8a8f3a52ca074b5e2da9f7b505c4201a57a8ed6286", + "sha256:780b48456a0f0ba4d390e8b5f7c661fdd218934388cde1a974010a965e200e12", + "sha256:788aef3549f1924d5c38263104dae7395bf020a42776d5ec5ea2b0d3d85d6646", + "sha256:7ee1227cf08b6716c85504aebc49ac827eb88fcc6e51564f010f11a406c0a667", + "sha256:7f301b11b9d214f83ddaf689181051e7f48905568b0c7017c04c06dfd065e244", + "sha256:83ee89483672b11f8952b158640d0c0ff02dc43d9cb1b70c1564b49abe92ce29", + "sha256:85bfa6a5413be0ee6c5c4a663668a2cad2cbecdee367630d097d7823041bdeec", + "sha256:9345b6f7ee578bad8e475129ed40123d265464c4cfead6c261fd60fc9de00bcf", + "sha256:93a5051fcf5fad72de73b96f07d30bc29665697fb8ecdfbc474f3452c78adcf4", + "sha256:962b9a917dd7ceacbe5cd424556914cb0d636001e393b43dc886ba31d2a1e449", + "sha256:96fc32c16ea6d60d3ca7f63397bff5c75c5a562f7db6dec7d412f7c4d2e78ec0", + "sha256:98ba568e8ae26beb726aeea2273053c717641933836568c2a0278a84987b2a1a", + "sha256:a3feefd5e95871872673b08636f96b61ebef62971eab044f5124fb4dea39919d", + "sha256:a955b747d620a50408b7fdf948e04359d6e762ff8a85f5775d907ceced715129", + "sha256:b43c2b8a330a490daaef5a47ab114935002b13b3f9dc5da56d5322ff218eeadb", + "sha256:b483c9d00a565633c87abd0aaf27eb5016de23fed952e054ecc19ce32f6a9e7e", + "sha256:b9ed0b1e5e0759d6b7f8e2f143894b2a7f3edd313f38cf44e1e15d360e11749b", + "sha256:ba05430e819e58544e840a68b03b28b6d328aff2e41579037e8bab7653b37d83", + "sha256:ca49e1ab99593438b204e00f3970e7a5f70d045267051dfa6b5f4304fcfa1dbf", + "sha256:ca5f18a75e1256ce07494e245cdb146f5a9267d3c702ebf9b65c7f8bd843431e", + "sha256:cd410a1cbb2d297c67d8521759ab2ee3f1d66206d2e4328502a487589a2cb21b", + "sha256:ce298e3d0c65bd03fa65ffcc6db0e2b578e8f626d468db64fdf8457731052942", + "sha256:d5ca078bb666c4a9d1287a379fe617a6dccd18c3e8a7e6c7e1eb8974330c626a", + "sha256:d5fd67df77bab0d3f4ea1d7afca9ef15c2ee35dfb348c7b57ffb9782a6e4db6e", + "sha256:da1a90c1ddb7531b1d5ff1e171b4ee61f6345119be7351104b67ff413843fe94", + "sha256:dba70f30fd81f8ce6d32ddeef37d91c8948e5d5a4c63242d16a2b2df8143aafc", + "sha256:dc07f021ee80510f3cd3af2cad5b6a3b3a10b057521d9e6aaeb621730d320c5a", + "sha256:dd33eb9bdcfbabab3459c9ee651d94c842bc8a05fabc95edf4ee0c15a072495e", + "sha256:e0538c43565ee6e703d3a7c3bdfe4037a5209250e8502c98f20fea6f5fdf2965", + "sha256:e1f54b9b4b6c53369f40028d2dd07a8c374583417ee6ec0ea304e710a20f80a0", + "sha256:e32d2a2b02ccbef10145df9135751abea1f9f076e67a4e261b05f24b94219e36", + "sha256:e6096b0688e6e14af6a1b10eaad86b4ff17935c49aa774eac7c95a57a4e8c296", + "sha256:e71255ba42567d34a13c03968736c5d39bb4a97ce98188fafb27ce981115beec", + "sha256:ed2e07c6a26ed4bea91b897ee2b0835c21716d9a469a96c3e878dc5f8c55bb23", + "sha256:eef2afb0fd1747f33f1ee3e209bce1ed582d1896b240ccc5e2697e3275f037c7", + "sha256:f23222527b307970e383433daec128d769ff778d9b29343fb3496472dc20dabe", + "sha256:f341ee2df0999bfdf7a95e448075effe0db212a59387de1a70690e4acb03d4c6", + "sha256:f5be7805e53dafe94d295399cfbe5227f39995a997f4fd8539bf3cbdc8f47ca8", + "sha256:f7f325be2804246a75a4f45c72d4ce80d2443ab815063cdf70ee8fb2ca59ee1b", + "sha256:f8af619e3be812a2059b212064ea7a640aff0568d972cd1b9e920837469eb3cb", + "sha256:fa8c626d6441e2d04b6ee703ef2d1e17608ad44c7cb75258c09dd42bacdfc64b", + "sha256:fbb9dc00e39f3e6c0ef48edee202f9520dafb233e8b51b06b8428cfcb92abd30", + "sha256:fff55f3ce50a3ff63ec8e2a8d3dd924f1941b250b0aac3d3d42b687eeff07a8e" + ], + "version": "==2021.11.10" }, "snowballstemmer": { "hashes": [ - "sha256:b51b447bea85f9968c13b650126a888aabd4cb4463fca868ec596826325dedc2", - "sha256:e997baa4f2e9139951b6f4c631bad912dfd3c792467e2f03d7239464af90e914" + "sha256:09b16deb8547d3412ad7b590689584cd0fe25ec8db3be37788be3810cbf19cb1", + "sha256:c8e1716e83cc398ae16824e5572ae04e0d9fc2c6b985fb0f900f5f0c96ecba1a" ], - "version": "==2.1.0" + "version": "==2.2.0" }, "toml": { "hashes": [ @@ -502,11 +751,11 @@ }, "tomli": { "hashes": [ - "sha256:8dd0e9524d6f386271a36b41dbf6c57d8e32fd96fd22b6584679dc569d20899f", - "sha256:a5b75cb6f3968abb47af1b40c1819dc519ea82bcc065776a866e8d74c5ca9442" + "sha256:c6ce0015eb38820eaf32b5db832dbc26deb3dd427bd5f6556cf0acac2c214fee", + "sha256:f04066f68f5554911363063a30b108d2b5a5b1a010aa8b6132af78489fe3aade" ], "markers": "python_version >= '3.6'", - "version": "==1.2.1" + "version": "==1.2.2" }, "typed-ast": { "hashes": [ @@ -563,46 +812,81 @@ }, "yarl": { "hashes": [ - "sha256:00d7ad91b6583602eb9c1d085a2cf281ada267e9a197e8b7cae487dadbfa293e", - "sha256:0355a701b3998dcd832d0dc47cc5dedf3874f966ac7f870e0f3a6788d802d434", - "sha256:15263c3b0b47968c1d90daa89f21fcc889bb4b1aac5555580d74565de6836366", - "sha256:2ce4c621d21326a4a5500c25031e102af589edb50c09b321049e388b3934eec3", - "sha256:31ede6e8c4329fb81c86706ba8f6bf661a924b53ba191b27aa5fcee5714d18ec", - "sha256:324ba3d3c6fee56e2e0b0d09bf5c73824b9f08234339d2b788af65e60040c959", - "sha256:329412812ecfc94a57cd37c9d547579510a9e83c516bc069470db5f75684629e", - "sha256:4736eaee5626db8d9cda9eb5282028cc834e2aeb194e0d8b50217d707e98bb5c", - "sha256:4953fb0b4fdb7e08b2f3b3be80a00d28c5c8a2056bb066169de00e6501b986b6", - "sha256:4c5bcfc3ed226bf6419f7a33982fb4b8ec2e45785a0561eb99274ebbf09fdd6a", - "sha256:547f7665ad50fa8563150ed079f8e805e63dd85def6674c97efd78eed6c224a6", - "sha256:5b883e458058f8d6099e4420f0cc2567989032b5f34b271c0827de9f1079a424", - "sha256:63f90b20ca654b3ecc7a8d62c03ffa46999595f0167d6450fa8383bab252987e", - "sha256:68dc568889b1c13f1e4745c96b931cc94fdd0defe92a72c2b8ce01091b22e35f", - "sha256:69ee97c71fee1f63d04c945f56d5d726483c4762845400a6795a3b75d56b6c50", - "sha256:6d6283d8e0631b617edf0fd726353cb76630b83a089a40933043894e7f6721e2", - "sha256:72a660bdd24497e3e84f5519e57a9ee9220b6f3ac4d45056961bf22838ce20cc", - "sha256:73494d5b71099ae8cb8754f1df131c11d433b387efab7b51849e7e1e851f07a4", - "sha256:7356644cbed76119d0b6bd32ffba704d30d747e0c217109d7979a7bc36c4d970", - "sha256:8a9066529240171b68893d60dca86a763eae2139dd42f42106b03cf4b426bf10", - "sha256:8aa3decd5e0e852dc68335abf5478a518b41bf2ab2f330fe44916399efedfae0", - "sha256:97b5bdc450d63c3ba30a127d018b866ea94e65655efaf889ebeabc20f7d12406", - "sha256:9ede61b0854e267fd565e7527e2f2eb3ef8858b301319be0604177690e1a3896", - "sha256:b2e9a456c121e26d13c29251f8267541bd75e6a1ccf9e859179701c36a078643", - "sha256:b5dfc9a40c198334f4f3f55880ecf910adebdcb2a0b9a9c23c9345faa9185721", - "sha256:bafb450deef6861815ed579c7a6113a879a6ef58aed4c3a4be54400ae8871478", - "sha256:c49ff66d479d38ab863c50f7bb27dee97c6627c5fe60697de15529da9c3de724", - "sha256:ce3beb46a72d9f2190f9e1027886bfc513702d748047b548b05dab7dfb584d2e", - "sha256:d26608cf178efb8faa5ff0f2d2e77c208f471c5a3709e577a7b3fd0445703ac8", - "sha256:d597767fcd2c3dc49d6eea360c458b65643d1e4dbed91361cf5e36e53c1f8c96", - "sha256:d5c32c82990e4ac4d8150fd7652b972216b204de4e83a122546dce571c1bdf25", - "sha256:d8d07d102f17b68966e2de0e07bfd6e139c7c02ef06d3a0f8d2f0f055e13bb76", - "sha256:e46fba844f4895b36f4c398c5af062a9808d1f26b2999c58909517384d5deda2", - "sha256:e6b5460dc5ad42ad2b36cca524491dfcaffbfd9c8df50508bddc354e787b8dc2", - "sha256:f040bcc6725c821a4c0665f3aa96a4d0805a7aaf2caf266d256b8ed71b9f041c", - "sha256:f0b059678fd549c66b89bed03efcabb009075bd131c248ecdf087bdb6faba24a", - "sha256:fcbb48a93e8699eae920f8d92f7160c03567b421bc17362a9ffbbd706a816f71" + "sha256:044daf3012e43d4b3538562da94a88fb12a6490652dbc29fb19adfa02cf72eac", + "sha256:0cba38120db72123db7c58322fa69e3c0efa933040ffb586c3a87c063ec7cae8", + "sha256:167ab7f64e409e9bdd99333fe8c67b5574a1f0495dcfd905bc7454e766729b9e", + "sha256:1be4bbb3d27a4e9aa5f3df2ab61e3701ce8fcbd3e9846dbce7c033a7e8136746", + "sha256:1ca56f002eaf7998b5fcf73b2421790da9d2586331805f38acd9997743114e98", + "sha256:1d3d5ad8ea96bd6d643d80c7b8d5977b4e2fb1bab6c9da7322616fd26203d125", + "sha256:1eb6480ef366d75b54c68164094a6a560c247370a68c02dddb11f20c4c6d3c9d", + "sha256:1edc172dcca3f11b38a9d5c7505c83c1913c0addc99cd28e993efeaafdfaa18d", + "sha256:211fcd65c58bf250fb994b53bc45a442ddc9f441f6fec53e65de8cba48ded986", + "sha256:29e0656d5497733dcddc21797da5a2ab990c0cb9719f1f969e58a4abac66234d", + "sha256:368bcf400247318382cc150aaa632582d0780b28ee6053cd80268c7e72796dec", + "sha256:39d5493c5ecd75c8093fa7700a2fb5c94fe28c839c8e40144b7ab7ccba6938c8", + "sha256:3abddf0b8e41445426d29f955b24aeecc83fa1072be1be4e0d194134a7d9baee", + "sha256:3bf8cfe8856708ede6a73907bf0501f2dc4e104085e070a41f5d88e7faf237f3", + "sha256:3ec1d9a0d7780416e657f1e405ba35ec1ba453a4f1511eb8b9fbab81cb8b3ce1", + "sha256:45399b46d60c253327a460e99856752009fcee5f5d3c80b2f7c0cae1c38d56dd", + "sha256:52690eb521d690ab041c3919666bea13ab9fbff80d615ec16fa81a297131276b", + "sha256:534b047277a9a19d858cde163aba93f3e1677d5acd92f7d10ace419d478540de", + "sha256:580c1f15500e137a8c37053e4cbf6058944d4c114701fa59944607505c2fe3a0", + "sha256:59218fef177296451b23214c91ea3aba7858b4ae3306dde120224cfe0f7a6ee8", + "sha256:5ba63585a89c9885f18331a55d25fe81dc2d82b71311ff8bd378fc8004202ff6", + "sha256:5bb7d54b8f61ba6eee541fba4b83d22b8a046b4ef4d8eb7f15a7e35db2e1e245", + "sha256:6152224d0a1eb254f97df3997d79dadd8bb2c1a02ef283dbb34b97d4f8492d23", + "sha256:67e94028817defe5e705079b10a8438b8cb56e7115fa01640e9c0bb3edf67332", + "sha256:695ba021a9e04418507fa930d5f0704edbce47076bdcfeeaba1c83683e5649d1", + "sha256:6a1a9fe17621af43e9b9fcea8bd088ba682c8192d744b386ee3c47b56eaabb2c", + "sha256:6ab0c3274d0a846840bf6c27d2c60ba771a12e4d7586bf550eefc2df0b56b3b4", + "sha256:6feca8b6bfb9eef6ee057628e71e1734caf520a907b6ec0d62839e8293e945c0", + "sha256:737e401cd0c493f7e3dd4db72aca11cfe069531c9761b8ea474926936b3c57c8", + "sha256:788713c2896f426a4e166b11f4ec538b5736294ebf7d5f654ae445fd44270832", + "sha256:797c2c412b04403d2da075fb93c123df35239cd7b4cc4e0cd9e5839b73f52c58", + "sha256:8300401dc88cad23f5b4e4c1226f44a5aa696436a4026e456fe0e5d2f7f486e6", + "sha256:87f6e082bce21464857ba58b569370e7b547d239ca22248be68ea5d6b51464a1", + "sha256:89ccbf58e6a0ab89d487c92a490cb5660d06c3a47ca08872859672f9c511fc52", + "sha256:8b0915ee85150963a9504c10de4e4729ae700af11df0dc5550e6587ed7891e92", + "sha256:8cce6f9fa3df25f55521fbb5c7e4a736683148bcc0c75b21863789e5185f9185", + "sha256:95a1873b6c0dd1c437fb3bb4a4aaa699a48c218ac7ca1e74b0bee0ab16c7d60d", + "sha256:9b4c77d92d56a4c5027572752aa35082e40c561eec776048330d2907aead891d", + "sha256:9bfcd43c65fbb339dc7086b5315750efa42a34eefad0256ba114cd8ad3896f4b", + "sha256:9c1f083e7e71b2dd01f7cd7434a5f88c15213194df38bc29b388ccdf1492b739", + "sha256:a1d0894f238763717bdcfea74558c94e3bc34aeacd3351d769460c1a586a8b05", + "sha256:a467a431a0817a292121c13cbe637348b546e6ef47ca14a790aa2fa8cc93df63", + "sha256:aa32aaa97d8b2ed4e54dc65d241a0da1c627454950f7d7b1f95b13985afd6c5d", + "sha256:ac10bbac36cd89eac19f4e51c032ba6b412b3892b685076f4acd2de18ca990aa", + "sha256:ac35ccde589ab6a1870a484ed136d49a26bcd06b6a1c6397b1967ca13ceb3913", + "sha256:bab827163113177aee910adb1f48ff7af31ee0289f434f7e22d10baf624a6dfe", + "sha256:baf81561f2972fb895e7844882898bda1eef4b07b5b385bcd308d2098f1a767b", + "sha256:bf19725fec28452474d9887a128e98dd67eee7b7d52e932e6949c532d820dc3b", + "sha256:c01a89a44bb672c38f42b49cdb0ad667b116d731b3f4c896f72302ff77d71656", + "sha256:c0910c6b6c31359d2f6184828888c983d54d09d581a4a23547a35f1d0b9484b1", + "sha256:c10ea1e80a697cf7d80d1ed414b5cb8f1eec07d618f54637067ae3c0334133c4", + "sha256:c1164a2eac148d85bbdd23e07dfcc930f2e633220f3eb3c3e2a25f6148c2819e", + "sha256:c145ab54702334c42237a6c6c4cc08703b6aa9b94e2f227ceb3d477d20c36c63", + "sha256:c17965ff3706beedafd458c452bf15bac693ecd146a60a06a214614dc097a271", + "sha256:c19324a1c5399b602f3b6e7db9478e5b1adf5cf58901996fc973fe4fccd73eed", + "sha256:c2a1ac41a6aa980db03d098a5531f13985edcb451bcd9d00670b03129922cd0d", + "sha256:c6ddcd80d79c96eb19c354d9dca95291589c5954099836b7c8d29278a7ec0bda", + "sha256:c9c6d927e098c2d360695f2e9d38870b2e92e0919be07dbe339aefa32a090265", + "sha256:cc8b7a7254c0fc3187d43d6cb54b5032d2365efd1df0cd1749c0c4df5f0ad45f", + "sha256:cff3ba513db55cc6a35076f32c4cdc27032bd075c9faef31fec749e64b45d26c", + "sha256:d260d4dc495c05d6600264a197d9d6f7fc9347f21d2594926202fd08cf89a8ba", + "sha256:d6f3d62e16c10e88d2168ba2d065aa374e3c538998ed04996cd373ff2036d64c", + "sha256:da6df107b9ccfe52d3a48165e48d72db0eca3e3029b5b8cb4fe6ee3cb870ba8b", + "sha256:dfe4b95b7e00c6635a72e2d00b478e8a28bfb122dc76349a06e20792eb53a523", + "sha256:e39378894ee6ae9f555ae2de332d513a5763276a9265f8e7cbaeb1b1ee74623a", + "sha256:ede3b46cdb719c794427dcce9d8beb4abe8b9aa1e97526cc20de9bd6583ad1ef", + "sha256:f2a8508f7350512434e41065684076f640ecce176d262a7d54f0da41d99c5a95", + "sha256:f44477ae29025d8ea87ec308539f95963ffdc31a82f42ca9deecf2d505242e72", + "sha256:f64394bd7ceef1237cc604b5a89bf748c95982a84bcd3c4bbeb40f685c810794", + "sha256:fc4dd8b01a8112809e6b636b00f487846956402834a7fd59d46d4f4267181c41", + "sha256:fce78593346c014d0d986b7ebc80d782b7f5e19843ca798ed62f8e3ba8728576", + "sha256:fd547ec596d90c8676e369dd8a581a21227fe9b4ad37d0dc7feb4ccf544c2d59" ], "markers": "python_version >= '3.6'", - "version": "==1.6.3" + "version": "==1.7.2" }, "zipp": { "hashes": [ diff --git a/hardware/opentrons_hardware/drivers/can_bus/__init__.py b/hardware/opentrons_hardware/drivers/can_bus/__init__.py index 7a46196fb64..9affb1e2f4e 100644 --- a/hardware/opentrons_hardware/drivers/can_bus/__init__.py +++ b/hardware/opentrons_hardware/drivers/can_bus/__init__.py @@ -1,13 +1,13 @@ """Can bus drivers package.""" from .driver import CanDriver -from .message import CanMessage -from .arbitration_id import ( +from .can_messenger import CanMessenger +from opentrons_ot3_firmware.message import CanMessage +from opentrons_ot3_firmware.arbitration_id import ( ArbitrationId, ArbitrationIdParts, ) -from .constants import NodeId, FunctionCode, MessageId -from .can_messenger import CanMessenger +from opentrons_ot3_firmware.constants import NodeId, FunctionCode, MessageId __all__ = [ diff --git a/hardware/opentrons_hardware/drivers/can_bus/arbitration_id.py b/hardware/opentrons_hardware/drivers/can_bus/arbitration_id.py deleted file mode 100644 index 66bf53a3824..00000000000 --- a/hardware/opentrons_hardware/drivers/can_bus/arbitration_id.py +++ /dev/null @@ -1,51 +0,0 @@ -"""Can bus arbitration id.""" -from __future__ import annotations -import ctypes - - -class ArbitrationIdParts(ctypes.Structure): - """A bit field of the arbitration id parts.""" - - _fields_ = ( - ("function_code", ctypes.c_uint, 7), - ("node_id", ctypes.c_uint, 8), - ("message_id", ctypes.c_uint, 14), - ("padding", ctypes.c_uint, 3), - ) - - def __eq__(self, other: object) -> bool: - """Check equality.""" - if isinstance(other, ArbitrationIdParts): - return bool( - other.function_code == self.function_code - and other.node_id == self.node_id - and other.message_id == self.message_id - ) - return False - - def __repr__(self) -> str: - """Return string representation of class.""" - return ( - f"function_code: 0x{self.function_code:x}, " - f"node_id: 0x{self.node_id:x}, " - f"message_id: 0x{self.message_id:x}" - ) - - -class ArbitrationId(ctypes.Union): - """Arbitration id union.""" - - _fields_ = ( - ("parts", ArbitrationIdParts), - ("id", ctypes.c_uint32), - ) - - def __eq__(self, other: object) -> bool: - """Check equality.""" - if isinstance(other, ArbitrationId): - return bool(other.id == self.id) - return False - - def __repr__(self) -> str: - """Return string representation of class.""" - return f"id: 0x{self.id:x}, " f"parts: {self.parts}" diff --git a/hardware/opentrons_hardware/drivers/can_bus/can_messenger.py b/hardware/opentrons_hardware/drivers/can_bus/can_messenger.py index c69cd7b4959..0a7ed088990 100644 --- a/hardware/opentrons_hardware/drivers/can_bus/can_messenger.py +++ b/hardware/opentrons_hardware/drivers/can_bus/can_messenger.py @@ -5,19 +5,22 @@ from opentrons_hardware.drivers.can_bus import ( CanDriver, - NodeId, + +) +from opentrons_ot3_firmware.arbitration_id import ( ArbitrationId, ArbitrationIdParts, - CanMessage, - MessageId, + ) +from opentrons_ot3_firmware.message import CanMessage +from opentrons_ot3_firmware.constants import NodeId, MessageId from abc import ABC, abstractmethod -from opentrons_hardware.drivers.can_bus.messages.messages import ( +from opentrons_ot3_firmware.messages.messages import ( MessageDefinition, get_definition, ) -from opentrons_hardware.utils import BinarySerializableException +from opentrons_ot3_firmware.utils import BinarySerializableException log = logging.getLogger(__name__) diff --git a/hardware/opentrons_hardware/drivers/can_bus/constants.py b/hardware/opentrons_hardware/drivers/can_bus/constants.py deleted file mode 100644 index b3187a4dd76..00000000000 --- a/hardware/opentrons_hardware/drivers/can_bus/constants.py +++ /dev/null @@ -1,64 +0,0 @@ -"""Constants for can bus.""" -from enum import Enum - - -class NodeId(int, Enum): - """Can bus arbitration id node id.""" - - broadcast = 0x00 - host = 0x10 - pipette = 0x20 - gantry_x = 0x30 - gantry_y = 0x40 - head = 0x50 - head_l = 0x51 - head_r = 0x52 - - -class FunctionCode(int, Enum): - """Can bus arbitration id function code.""" - - network_management = 0x0 - sync = 0x2 - error = 0x4 - command = 0x10 - status = 0x12 - parameters = 0x14 - bootloader = 0x7C - heartbeat = 0x7E - - -class MessageId(int, Enum): - """Can bus arbitration id message id.""" - - heartbeat_request = 0x3FFF - heartbeat_response = 0x3FFE - - device_info_request = 0x3002 - device_info_response = 0x3003 - - stop_request = 0x00 - - enable_motor_request = 0x06 - disable_motor_request = 0x07 - - setup_request = 0x02 - - set_speed_request = 0x03 - - get_speed_request = 0x04 - get_speed_response = 0x11 - write_eeprom = 0x2001 - read_eeprom_request = 0x2002 - read_eeprom_response = 0x2003 - - add_move_request = 0x15 - get_move_group_request = 0x16 - get_move_group_response = 0x17 - execute_move_group_request = 0x18 - clear_all_move_groups_request = 0x19 - move_completed = 0x13 - - write_motor_driver_register_request = 0x30 - read_motor_driver_register_request = 0x31 - read_motor_driver_register_response = 0x32 diff --git a/hardware/opentrons_hardware/drivers/can_bus/driver.py b/hardware/opentrons_hardware/drivers/can_bus/driver.py index 9788e408cd0..01d48f6671c 100644 --- a/hardware/opentrons_hardware/drivers/can_bus/driver.py +++ b/hardware/opentrons_hardware/drivers/can_bus/driver.py @@ -7,8 +7,8 @@ from can import Notifier, Bus, AsyncBufferedReader, Message, util -from .arbitration_id import ArbitrationId -from .message import CanMessage +from opentrons_ot3_firmware.arbitration_id import ArbitrationId +from opentrons_ot3_firmware.message import CanMessage from .errors import ErrorFrameCanError log = logging.getLogger(__name__) diff --git a/hardware/opentrons_hardware/drivers/can_bus/message.py b/hardware/opentrons_hardware/drivers/can_bus/message.py deleted file mode 100644 index e0973d9a0b1..00000000000 --- a/hardware/opentrons_hardware/drivers/can_bus/message.py +++ /dev/null @@ -1,13 +0,0 @@ -"""Can message.""" -from __future__ import annotations - -from dataclasses import dataclass -from .arbitration_id import ArbitrationId - - -@dataclass(frozen=True) -class CanMessage: - """A can message.""" - - arbitration_id: ArbitrationId - data: bytes diff --git a/hardware/opentrons_hardware/drivers/can_bus/messages/__init__.py b/hardware/opentrons_hardware/drivers/can_bus/messages/__init__.py deleted file mode 100644 index ca2fa266739..00000000000 --- a/hardware/opentrons_hardware/drivers/can_bus/messages/__init__.py +++ /dev/null @@ -1,7 +0,0 @@ -"""Can bus message definitions.""" -from .messages import MessageDefinition, get_definition - -__all__ = [ - "MessageDefinition", - "get_definition", -] diff --git a/hardware/opentrons_hardware/drivers/can_bus/messages/message_definitions.py b/hardware/opentrons_hardware/drivers/can_bus/messages/message_definitions.py deleted file mode 100644 index e2613e758af..00000000000 --- a/hardware/opentrons_hardware/drivers/can_bus/messages/message_definitions.py +++ /dev/null @@ -1,181 +0,0 @@ -"""Definition of CAN messages.""" -from dataclasses import dataclass -from typing import Type - -from typing_extensions import Literal - -from opentrons_hardware.utils import BinarySerializable -from ..constants import MessageId -from . import payloads - - -@dataclass -class HeartbeatRequest: # noqa: D101 - payload: payloads.EmptyPayload - payload_type: Type[BinarySerializable] = payloads.EmptyPayload - message_id: Literal[MessageId.heartbeat_request] = MessageId.heartbeat_request - - -@dataclass -class HeartbeatResponse: # noqa: D101 - payload: payloads.EmptyPayload - payload_type: Type[BinarySerializable] = payloads.EmptyPayload - message_id: Literal[MessageId.heartbeat_response] = MessageId.heartbeat_response - - -@dataclass -class DeviceInfoRequest: # noqa: D101 - payload: payloads.EmptyPayload - payload_type: Type[BinarySerializable] = payloads.EmptyPayload - message_id: Literal[MessageId.device_info_request] = MessageId.device_info_request - - -@dataclass -class DeviceInfoResponse: # noqa: D101 - payload: payloads.DeviceInfoResponsePayload - payload_type: Type[BinarySerializable] = payloads.DeviceInfoResponsePayload - message_id: Literal[MessageId.device_info_response] = MessageId.device_info_response - - -@dataclass -class StopRequest: # noqa: D101 - payload: payloads.EmptyPayload - payload_type: Type[BinarySerializable] = payloads.EmptyPayload - message_id: Literal[MessageId.stop_request] = MessageId.stop_request - - -@dataclass -class EnableMotorRequest: # noqa: D101 - payload: payloads.EmptyPayload - payload_type: Type[BinarySerializable] = payloads.EmptyPayload - message_id: Literal[MessageId.enable_motor_request] = MessageId.enable_motor_request - - -@dataclass -class DisableMotorRequest: # noqa: D101 - payload: payloads.EmptyPayload - payload_type: Type[BinarySerializable] = payloads.EmptyPayload - message_id: Literal[ - MessageId.disable_motor_request - ] = MessageId.disable_motor_request - - -@dataclass -class SetupRequest: # noqa: D101 - payload: payloads.EmptyPayload - payload_type: Type[BinarySerializable] = payloads.EmptyPayload - message_id: Literal[MessageId.setup_request] = MessageId.setup_request - - -@dataclass -class GetSpeedRequest: # noqa: D101 - payload: payloads.EmptyPayload - payload_type: Type[BinarySerializable] = payloads.EmptyPayload - message_id: Literal[MessageId.get_speed_request] = MessageId.get_speed_request - - -@dataclass -class GetSpeedResponse: # noqa: D101 - payload: payloads.GetSpeedResponsePayload - payload_type: Type[BinarySerializable] = payloads.GetSpeedResponsePayload - message_id: Literal[MessageId.get_speed_response] = MessageId.get_speed_response - - -@dataclass -class WriteToEEPromRequest: # noqa: D101 - payload: payloads.WriteToEEPromRequestPayload - payload_type: Type[BinarySerializable] = payloads.WriteToEEPromRequestPayload - message_id: Literal[MessageId.write_eeprom] = MessageId.write_eeprom - - -@dataclass -class ReadFromEEPromRequest: # noqa: D101 - payload: payloads.EmptyPayload - payload_type: Type[BinarySerializable] = payloads.EmptyPayload - message_id: Literal[MessageId.read_eeprom_request] = MessageId.read_eeprom_request - - -@dataclass -class ReadFromEEPromResponse: # noqa: D101 - payload: payloads.ReadFromEEPromResponsePayload - payload_type: Type[BinarySerializable] = payloads.ReadFromEEPromResponsePayload - message_id: Literal[MessageId.read_eeprom_response] = MessageId.read_eeprom_response - - -@dataclass -class AddLinearMoveRequest: # noqa: D101 - payload: payloads.AddLinearMoveRequestPayload - payload_type: Type[BinarySerializable] = payloads.AddLinearMoveRequestPayload - message_id: Literal[MessageId.add_move_request] = MessageId.add_move_request - - -@dataclass -class GetMoveGroupRequest: # noqa: D101 - payload: payloads.MoveGroupRequestPayload - payload_type: Type[BinarySerializable] = payloads.MoveGroupRequestPayload - message_id: Literal[ - MessageId.get_move_group_request - ] = MessageId.get_move_group_request - - -@dataclass -class GetMoveGroupResponse: # noqa: D101 - payload: payloads.GetMoveGroupResponsePayload - payload_type: Type[BinarySerializable] = payloads.GetMoveGroupResponsePayload - message_id: Literal[ - MessageId.get_move_group_response - ] = MessageId.get_move_group_response - - -@dataclass -class ExecuteMoveGroupRequest: # noqa: D101 - payload: payloads.ExecuteMoveGroupRequestPayload - payload_type: Type[BinarySerializable] = payloads.ExecuteMoveGroupRequestPayload - message_id: Literal[ - MessageId.execute_move_group_request - ] = MessageId.execute_move_group_request - - -@dataclass -class ClearAllMoveGroupsRequest: # noqa: D101 - payload: payloads.EmptyPayload - payload_type: Type[BinarySerializable] = payloads.EmptyPayload - message_id: Literal[ - MessageId.clear_all_move_groups_request - ] = MessageId.clear_all_move_groups_request - - -@dataclass -class MoveCompleted: # noqa: D101 - payload: payloads.MoveCompletedPayload - payload_type: Type[BinarySerializable] = payloads.MoveCompletedPayload - message_id: Literal[MessageId.move_completed] = MessageId.move_completed - - -@dataclass -class WriteMotorDriverRegister: # noqa: D101 - payload: payloads.MotorDriverRegisterDataPayload - payload_type: Type[BinarySerializable] = payloads.MotorDriverRegisterDataPayload - message_id: Literal[ - MessageId.write_motor_driver_register_request - ] = MessageId.write_motor_driver_register_request - - -@dataclass -class ReadMotorDriverRequest: # noqa: D101 - payload: payloads.MotorDriverRegisterPayload - payload_type: Type[BinarySerializable] = payloads.MotorDriverRegisterPayload - message_id: Literal[ - MessageId.read_motor_driver_register_request - ] = MessageId.read_motor_driver_register_request - - -@dataclass -class ReadMotorDriverResponse: # noqa: D101 - payload: payloads.ReadMotorDriverRegisterResponsePayload - payload_type: Type[ - BinarySerializable - ] = payloads.ReadMotorDriverRegisterResponsePayload - message_id: Literal[ - MessageId.read_motor_driver_register_response - ] = MessageId.read_motor_driver_register_response diff --git a/hardware/opentrons_hardware/drivers/can_bus/messages/messages.py b/hardware/opentrons_hardware/drivers/can_bus/messages/messages.py deleted file mode 100644 index 79e80292cba..00000000000 --- a/hardware/opentrons_hardware/drivers/can_bus/messages/messages.py +++ /dev/null @@ -1,52 +0,0 @@ -"""Message types.""" -from functools import lru_cache -from typing import Union, Optional, Type - -from typing_extensions import get_args - -from opentrons_hardware.drivers.can_bus.messages import message_definitions as defs -from opentrons_hardware.drivers.can_bus.constants import MessageId - -MessageDefinition = Union[ - defs.HeartbeatRequest, - defs.HeartbeatResponse, - defs.DeviceInfoRequest, - defs.DeviceInfoResponse, - defs.StopRequest, - defs.EnableMotorRequest, - defs.DisableMotorRequest, - defs.SetupRequest, - defs.GetSpeedRequest, - defs.GetSpeedResponse, - defs.WriteToEEPromRequest, - defs.ReadFromEEPromRequest, - defs.ReadFromEEPromResponse, - defs.AddLinearMoveRequest, - defs.GetMoveGroupRequest, - defs.GetMoveGroupResponse, - defs.ExecuteMoveGroupRequest, - defs.ClearAllMoveGroupsRequest, - defs.MoveCompleted, - defs.WriteMotorDriverRegister, - defs.ReadMotorDriverRequest, - defs.ReadMotorDriverResponse, -] - - -@lru_cache(maxsize=None) -def get_definition(message_id: MessageId) -> Optional[Type[MessageDefinition]]: - """Get the message type for a message id. - - Args: - message_id: A message id - - Returns: The message definition for a type - - """ - # Dumb linear search, but the result is memoized. - for i in get_args(MessageDefinition): - if i.message_id == message_id: - # get args returns Tuple[Any...] - return i # type: ignore[no-any-return] - - return None diff --git a/hardware/opentrons_hardware/drivers/can_bus/messages/payloads.py b/hardware/opentrons_hardware/drivers/can_bus/messages/payloads.py deleted file mode 100644 index 8d57bc70198..00000000000 --- a/hardware/opentrons_hardware/drivers/can_bus/messages/payloads.py +++ /dev/null @@ -1,123 +0,0 @@ -"""Payloads of can bus messages.""" -from dataclasses import dataclass - -from opentrons_hardware import utils - - -@dataclass -class ResponsePayload(utils.BinarySerializable): - """A response payload.""" - - node_id: utils.UInt8Field - - -@dataclass -class EmptyPayload(utils.BinarySerializable): - """An empty payload.""" - - pass - - -@dataclass -class DeviceInfoResponsePayload(ResponsePayload): - """Device info response.""" - - version: utils.UInt32Field - - -@dataclass -class GetSpeedResponsePayload(ResponsePayload): - """Get speed response.""" - - mm_sec: utils.UInt32Field - - -@dataclass -class WriteToEEPromRequestPayload(utils.BinarySerializable): - """Write to eeprom request.""" - - serial_number: utils.UInt8Field - - -@dataclass -class ReadFromEEPromResponsePayload(ResponsePayload): - """Read from ee prom response.""" - - serial_number: utils.UInt8Field - - -@dataclass -class MoveGroupRequestPayload(utils.BinarySerializable): - """A payload with a group id.""" - - group_id: utils.UInt8Field - - -@dataclass -class MoveGroupResponsePayload(ResponsePayload): - """A response payload with a group id.""" - - group_id: utils.UInt8Field - - -@dataclass -class AddToMoveGroupRequestPayload(MoveGroupRequestPayload): - """Base of add to move group request to a message group.""" - - seq_id: utils.UInt8Field - duration: utils.UInt32Field - - -@dataclass -class AddLinearMoveRequestPayload(AddToMoveGroupRequestPayload): - """Add a linear move request to a message group.""" - - acceleration: utils.Int32Field - velocity: utils.Int32Field - - -@dataclass -class GetMoveGroupResponsePayload(MoveGroupResponsePayload): - """Response to request to get a move group.""" - - num_moves: utils.UInt8Field - total_duration: utils.UInt32Field - - -@dataclass -class ExecuteMoveGroupRequestPayload(MoveGroupRequestPayload): - """Start executing a move group.""" - - start_trigger: utils.UInt8Field - cancel_trigger: utils.UInt8Field - - -@dataclass -class MoveCompletedPayload(MoveGroupResponsePayload): - """Notification of a completed move group.""" - - seq_id: utils.UInt8Field - current_position: utils.UInt32Field - ack_id: utils.UInt8Field - - -@dataclass -class MotorDriverRegisterPayload(utils.BinarySerializable): - """Read motor driver register request payload.""" - - reg_addr: utils.UInt8Field - - -@dataclass -class MotorDriverRegisterDataPayload(MotorDriverRegisterPayload): - """Write motor driver register request payload.""" - - data: utils.UInt32Field - - -@dataclass -class ReadMotorDriverRegisterResponsePayload(ResponsePayload): - """Read motor driver register response payload.""" - - reg_addr: utils.UInt8Field - data: utils.UInt32Field diff --git a/hardware/opentrons_hardware/hardware_control/move_group_runner.py b/hardware/opentrons_hardware/hardware_control/move_group_runner.py index 942d4bea359..611c46d6ec0 100644 --- a/hardware/opentrons_hardware/hardware_control/move_group_runner.py +++ b/hardware/opentrons_hardware/hardware_control/move_group_runner.py @@ -1,26 +1,26 @@ """Class that schedules motion on can bus.""" import asyncio import logging -from opentrons_hardware.drivers.can_bus import NodeId +from opentrons_ot3_firmware.constants import NodeId from opentrons_hardware.drivers.can_bus.can_messenger import ( CanMessenger, MessageListener, ) -from opentrons_hardware.drivers.can_bus.messages import MessageDefinition -from opentrons_hardware.drivers.can_bus.messages.message_definitions import ( +from opentrons_ot3_firmware.messages import MessageDefinition +from opentrons_ot3_firmware.messages.message_definitions import ( ClearAllMoveGroupsRequest, AddLinearMoveRequest, MoveCompleted, ExecuteMoveGroupRequest, ) -from opentrons_hardware.drivers.can_bus.messages.payloads import ( +from opentrons_ot3_firmware.messages.payloads import ( AddLinearMoveRequestPayload, ExecuteMoveGroupRequestPayload, EmptyPayload, ) -from opentrons_hardware.hardware_control.constants import interrupts_per_sec +from .constants import interrupts_per_sec from opentrons_hardware.hardware_control.motion import MoveGroups -from opentrons_hardware.utils import UInt8Field, UInt32Field, Int32Field +from opentrons_ot3_firmware.utils import UInt8Field, UInt32Field, Int32Field log = logging.getLogger(__name__) diff --git a/hardware/opentrons_hardware/scripts/can_comm.py b/hardware/opentrons_hardware/scripts/can_comm.py index 38ac8e18a4f..aa2e3340ef2 100644 --- a/hardware/opentrons_hardware/scripts/can_comm.py +++ b/hardware/opentrons_hardware/scripts/can_comm.py @@ -9,16 +9,20 @@ from opentrons_hardware.drivers.can_bus import ( CanDriver, +) +from opentrons_ot3_firmware.constants import ( MessageId, NodeId, - CanMessage, + FunctionCode, +) +from opentrons_ot3_firmware.message import CanMessage +from opentrons_ot3_firmware.arbitration_id import ( ArbitrationId, ArbitrationIdParts, - FunctionCode, ) -from opentrons_hardware.drivers.can_bus.messages.messages import get_definition +from opentrons_ot3_firmware.messages.messages import get_definition from opentrons_hardware.scripts.can_args import add_can_args -from opentrons_hardware.utils import BinarySerializable, BinarySerializableException +from opentrons_ot3_firmware.utils import BinarySerializable, BinarySerializableException log = logging.getLogger(__name__) diff --git a/hardware/opentrons_hardware/scripts/generate_header.py b/hardware/opentrons_hardware/scripts/generate_header.py deleted file mode 100644 index bbef7a8590e..00000000000 --- a/hardware/opentrons_hardware/scripts/generate_header.py +++ /dev/null @@ -1,96 +0,0 @@ -"""Script to generate c++ header file of canbus constants.""" -from __future__ import annotations -import argparse -import io -from enum import Enum -from pathlib import Path -from typing import Type, Any - -from opentrons_hardware.drivers.can_bus import ( - MessageId, - FunctionCode, - NodeId, -) - - -class block: - """C block generator.""" - - def __init__(self, output: io.StringIO, start: str, terminate: str) -> None: - """Construct a code block context manager. - - Args: - output: the buffer in which to write - start: the text that begins the block - terminate: the text that ends the block - """ - self._output = output - self._start = start - self._terminate = terminate - - def __enter__(self) -> block: - """Enter the context manager.""" - self._output.write(self._start) - return self - - def __exit__(self, *exc: Any) -> None: - """Exit the context manager.""" - self._output.write(self._terminate) - - -def run(file: Path) -> None: - """Entry point for script.""" - with io.StringIO() as output: - generate(output) - - output_string = output.getvalue() - file.write_text(output_string) - - print(output_string) - - -def generate(output: io.StringIO) -> None: - """Generate source code into output.""" - output.write("/********************************************\n") - output.write("* This is a generated file. Do not modify. *\n") - output.write("********************************************/\n") - output.write("#pragma once\n\n") - with block( - output=output, - start="namespace can_ids {\n\n", - terminate="} // namespace can_ids\n\n", - ): - write_enum(FunctionCode, output) - write_enum(MessageId, output) - write_enum(NodeId, output) - - -def write_enum(e: Type[Enum], output: io.StringIO) -> None: - """Generate enum class from enumeration.""" - output.write(f"/** {e.__doc__} */\n") - with block( - output=output, start=f"enum class {e.__name__} {{\n", terminate="};\n\n" - ): - for i in e: - output.write(f" {i.name} = 0x{i.value:x},\n") - - -def main() -> None: - """Entry point.""" - parser = argparse.ArgumentParser( - description="Generate a C++ header file defining CANBUS constants." - ) - parser.add_argument( - "--target", - type=str, - required=True, - help="path of header file to generate", - ) - - args = parser.parse_args() - - run(Path(args.target)) - - -if __name__ == "__main__": - main() diff --git a/hardware/opentrons_hardware/scripts/move.py b/hardware/opentrons_hardware/scripts/move.py index d69a8c25311..a74f600c6d3 100644 --- a/hardware/opentrons_hardware/scripts/move.py +++ b/hardware/opentrons_hardware/scripts/move.py @@ -5,13 +5,15 @@ from logging.config import dictConfig from typing import Optional -from opentrons_hardware.drivers.can_bus import CanDriver, NodeId +from opentrons_hardware.drivers.can_bus import CanDriver from opentrons_hardware.drivers.can_bus.can_messenger import CanMessenger -from opentrons_hardware.drivers.can_bus.messages.message_definitions import ( +from opentrons_ot3_firmware.constants import NodeId + +from opentrons_ot3_firmware.messages.message_definitions import ( SetupRequest, EnableMotorRequest, ) -from opentrons_hardware.drivers.can_bus.messages.payloads import EmptyPayload +from opentrons_ot3_firmware.messages.payloads import EmptyPayload from opentrons_hardware.hardware_control.motion import MoveGroupSingleAxisStep from opentrons_hardware.hardware_control.move_group_runner import MoveGroupRunner from opentrons_hardware.scripts.can_args import add_can_args diff --git a/hardware/opentrons_hardware/utils/__init__.py b/hardware/opentrons_hardware/utils/__init__.py deleted file mode 100644 index 0ae8356956c..00000000000 --- a/hardware/opentrons_hardware/utils/__init__.py +++ /dev/null @@ -1,33 +0,0 @@ -"""Utils package.""" - -from .binary_serializable import ( - BinarySerializable, - LittleEndianBinarySerializable, - Int8Field, - Int16Field, - Int32Field, - Int64Field, - UInt8Field, - UInt16Field, - UInt32Field, - UInt64Field, - BinaryFieldBase, - BinarySerializableException, - InvalidFieldException, -) - -__all__ = [ - "BinarySerializable", - "LittleEndianBinarySerializable", - "Int8Field", - "Int16Field", - "Int32Field", - "Int64Field", - "UInt8Field", - "UInt16Field", - "UInt32Field", - "UInt64Field", - "BinaryFieldBase", - "BinarySerializableException", - "InvalidFieldException", -] diff --git a/hardware/opentrons_hardware/utils/binary_serializable.py b/hardware/opentrons_hardware/utils/binary_serializable.py deleted file mode 100644 index 0267cabdbb6..00000000000 --- a/hardware/opentrons_hardware/utils/binary_serializable.py +++ /dev/null @@ -1,201 +0,0 @@ -"""BinarySerializable dataclass.""" - -from __future__ import annotations -import struct -from dataclasses import dataclass, fields, astuple -from typing import TypeVar, Generic - - -class BinarySerializableException(BaseException): - """Exception.""" - - pass - - -class InvalidFieldException(BinarySerializableException): - """Field is wrong type.""" - - pass - - -class SerializationException(BinarySerializableException): - """Serialization error.""" - - pass - - -T = TypeVar("T") - - -class BinaryFieldBase(Generic[T]): - """Binary serializable field.""" - - FORMAT = "" - """The struct format string for this field.""" - - def __init__(self, t: T) -> None: - """Constructor.""" - self._t = t - - @classmethod - def build(cls, t: T) -> BinaryFieldBase[T]: - """Factory method. - - Args: - t: The value. - - Returns: - New instance. - """ - return cls(t) - - @property - def value(self) -> T: - """The value.""" - return self._t - - def __eq__(self, other: object) -> bool: - """Comparison.""" - return isinstance(other, BinaryFieldBase) and other.value == self.value - - def __repr__(self) -> str: - """Representation string.""" - return f"{self.__class__.__name__}(value={repr(self.value)})" - - -class UInt64Field(BinaryFieldBase[int]): - """Unsigned 64 bit integer field.""" - - FORMAT = "Q" - - -class Int64Field(BinaryFieldBase[int]): - """Signed 64 bit integer field.""" - - FORMAT = "q" - - -class UInt32Field(BinaryFieldBase[int]): - """Unsigned 32 bit integer field.""" - - FORMAT = "L" - - -class Int32Field(BinaryFieldBase[int]): - """Signed 32 bit integer field.""" - - FORMAT = "l" - - -class UInt16Field(BinaryFieldBase[int]): - """Unsigned 16 bit integer field.""" - - FORMAT = "H" - - -class Int16Field(BinaryFieldBase[int]): - """Signed 16 bit integer field.""" - - FORMAT = "h" - - -class UInt8Field(BinaryFieldBase[int]): - """Unsigned 8 bit integer field.""" - - FORMAT = "B" - - -class Int8Field(BinaryFieldBase[int]): - """Signed 8 bit integer field.""" - - FORMAT = "b" - - -@dataclass -class BinarySerializable: - """Base class of a dataclass that can be serialized/deserialized into bytes. - - Each field must have the FieldMetaData metadata value defining the format string - used by `struct` package to pack/unpack the field. - - Data will be packed big endian. - """ - - ENDIAN = ">" - """The big endian format string""" - - def serialize(self) -> bytes: - """Serialize into a byte buffer. - - Returns: - Byte buffer - """ - string = self._get_format_string() - vals = [x.value for x in astuple(self)] - try: - return struct.pack(string, *vals) - except struct.error as e: - raise SerializationException(str(e)) - - @classmethod - def build(cls, data: bytes) -> BinarySerializable: - """Create a BinarySerializable from a byte buffer. - - The byte buffer must be at least enough bytes to satisfy all fields. - - Extra bytes will be ignored. This is for two reasons: - - CANFD requires padding to round byte lengths to fixed sizes. - - To accommodate extracting multiple BinarySerializable objects - from a stream of bytes. - - Args: - data: Byte buffer - - Returns: - cls - """ - try: - format_string = cls._get_format_string() - size = cls.get_size() - # ignore bytes beyond the size of message. - b = struct.unpack(format_string, data[:size]) - args = {v.name: v.type.build(b[i]) for i, v in enumerate(fields(cls))} - # Mypy is not liking constructing the derived types. - return cls(**args) # type: ignore[call-arg] - except struct.error as e: - raise InvalidFieldException(str(e)) - - @classmethod - def _get_format_string(cls) -> str: - """Get the `struct` format string for this class. - - Returns: - a string - """ - dataclass_fields = fields(cls) - try: - format_string = ( - f"{cls.ENDIAN}{''.join(v.type.FORMAT for v in dataclass_fields)}" - ) - except AttributeError: - raise InvalidFieldException(f"All fields must be of type {BinaryFieldBase}") - - return format_string - - @classmethod - def get_size(cls) -> int: - """Get the size of the serializable in bytes.""" - return struct.calcsize(cls._get_format_string()) - - -class LittleEndianMixIn: - """Mix in to use with BinarySerializable to use little endian packing.""" - - ENDIAN = "<" - """The little endian format string""" - - -class LittleEndianBinarySerializable(LittleEndianMixIn, BinarySerializable): - """Little endian binary serializable.""" - - ... diff --git a/hardware/setup.py b/hardware/setup.py index b6bf38cbaf2..3dc69c6cbb8 100644 --- a/hardware/setup.py +++ b/hardware/setup.py @@ -78,7 +78,6 @@ def read(*parts: str) -> str: include_package_data=True, entry_points={ "console_scripts": [ - "opentrons_generate_header = opentrons_hardware.scripts.generate_header:main", # noqa: E501 "opentrons_can_comm = opentrons_hardware.scripts.can_comm:main", ] }, diff --git a/hardware/tests/firmware_integration/test_echo.py b/hardware/tests/firmware_integration/test_echo.py index 1c3948496ed..96ea58cfaca 100644 --- a/hardware/tests/firmware_integration/test_echo.py +++ b/hardware/tests/firmware_integration/test_echo.py @@ -2,7 +2,8 @@ import pytest import asyncio from typing import AsyncGenerator -from opentrons_hardware.drivers.can_bus import CanDriver, ArbitrationId, CanMessage +from opentrons_hardware.drivers.can_bus import CanDriver, CanMessage +from opentrons_ot3_firmware.arbitration_id import ArbitrationId @pytest.fixture diff --git a/hardware/tests/opentrons_hardware/drivers/can_bus/test_arbitration_id.py b/hardware/tests/opentrons_hardware/drivers/can_bus/test_arbitration_id.py deleted file mode 100644 index 9f94f6939d5..00000000000 --- a/hardware/tests/opentrons_hardware/drivers/can_bus/test_arbitration_id.py +++ /dev/null @@ -1,39 +0,0 @@ -"""Arbitration id tests.""" -import pytest -from opentrons_hardware.drivers.can_bus import ArbitrationId, ArbitrationIdParts - - -@pytest.mark.parametrize( - argnames=["arbitration_id", "expected"], - argvalues=[ - [0x0, ArbitrationIdParts(function_code=0x0, node_id=0x0, message_id=0)], - [ - 0xFFFFFFFF, - ArbitrationIdParts(function_code=0x7F, node_id=0xFF, message_id=0x3FFF), - ], - [0x20181, ArbitrationIdParts(function_code=0x1, node_id=0x3, message_id=0x4)], - ], -) -def test_arbitration_id_parts( - arbitration_id: int, expected: ArbitrationIdParts -) -> None: - """It should convert arbitration id to its parts.""" - c = ArbitrationId(id=arbitration_id) - assert c.parts == expected - - -@pytest.mark.parametrize( - argnames=["expected", "parts"], - argvalues=[ - [0x0, ArbitrationIdParts(function_code=0x0, node_id=0x0, message_id=0)], - [ - 0x1FFFFFFF, - ArbitrationIdParts(function_code=0x7F, node_id=0xFF, message_id=0x3FFF), - ], - [0x20181, ArbitrationIdParts(function_code=0x1, node_id=0x3, message_id=0x4)], - ], -) -def test_arbitration_id_integer(expected: int, parts: ArbitrationIdParts) -> None: - """It should convert parts to an arbitration id.""" - c = ArbitrationId(parts=parts) - assert c.id == expected diff --git a/hardware/tests/opentrons_hardware/drivers/can_bus/test_can_messenger.py b/hardware/tests/opentrons_hardware/drivers/can_bus/test_can_messenger.py index 72e81306bb7..f06d66a3649 100644 --- a/hardware/tests/opentrons_hardware/drivers/can_bus/test_can_messenger.py +++ b/hardware/tests/opentrons_hardware/drivers/can_bus/test_can_messenger.py @@ -6,29 +6,33 @@ import pytest from mock import AsyncMock, Mock -from opentrons_hardware.drivers.can_bus import ( +from opentrons_ot3_firmware.constants import ( NodeId, - CanMessage, + + MessageId, +) + +from opentrons_ot3_firmware.message import CanMessage +from opentrons_ot3_firmware.arbitration_id import ( ArbitrationId, ArbitrationIdParts, - MessageId, ) from opentrons_hardware.drivers.can_bus.can_messenger import ( CanMessenger, MessageListener, ) -from opentrons_hardware.drivers.can_bus.messages import MessageDefinition -from opentrons_hardware.drivers.can_bus.messages.message_definitions import ( +from opentrons_ot3_firmware.messages import MessageDefinition +from opentrons_ot3_firmware.messages.message_definitions import ( HeartbeatRequest, MoveCompleted, GetMoveGroupRequest, ) -from opentrons_hardware.drivers.can_bus.messages.payloads import ( +from opentrons_ot3_firmware.messages.payloads import ( EmptyPayload, MoveCompletedPayload, MoveGroupRequestPayload, ) -from opentrons_hardware.utils import UInt8Field, UInt32Field +from opentrons_ot3_firmware.utils import UInt8Field, UInt32Field @pytest.fixture diff --git a/hardware/tests/opentrons_hardware/drivers/can_bus/test_messages/__init__.py b/hardware/tests/opentrons_hardware/drivers/can_bus/test_messages/__init__.py deleted file mode 100644 index caa58f71928..00000000000 --- a/hardware/tests/opentrons_hardware/drivers/can_bus/test_messages/__init__.py +++ /dev/null @@ -1 +0,0 @@ -"""Tests for messages package.""" diff --git a/hardware/tests/opentrons_hardware/drivers/can_bus/test_messages/test_message_definitions.py b/hardware/tests/opentrons_hardware/drivers/can_bus/test_messages/test_message_definitions.py deleted file mode 100644 index cf973cc4c8c..00000000000 --- a/hardware/tests/opentrons_hardware/drivers/can_bus/test_messages/test_message_definitions.py +++ /dev/null @@ -1,25 +0,0 @@ -"""Test for message definitions.""" -import pytest -from typing_extensions import get_args -from dataclasses import fields - -from opentrons_hardware.drivers.can_bus.messages.messages import MessageDefinition - - -@pytest.mark.parametrize("message_definition", get_args(MessageDefinition)) -def test_payload_types(message_definition: MessageDefinition) -> None: - """Its payload_type and payload typing should match.""" - all_fields = fields(message_definition) - payload_type_type = None - payload_type = None - for f in all_fields: - if f.name == "payload_type": - payload_type_type = f.default - elif f.name == "payload": - payload_type = f.type - if payload_type and payload_type_type: - break - - assert payload_type_type is not None - assert payload_type is not None - assert payload_type == payload_type_type diff --git a/hardware/tests/opentrons_hardware/hardware_control/test_move_group_runner.py b/hardware/tests/opentrons_hardware/hardware_control/test_move_group_runner.py index 26923c809b9..a3c3fb5125b 100644 --- a/hardware/tests/opentrons_hardware/hardware_control/test_move_group_runner.py +++ b/hardware/tests/opentrons_hardware/hardware_control/test_move_group_runner.py @@ -2,12 +2,12 @@ import pytest from mock import AsyncMock, call, MagicMock -from opentrons_hardware.drivers.can_bus import NodeId +from opentrons_ot3_firmware.constants import NodeId from opentrons_hardware.drivers.can_bus.can_messenger import MessageListener -from opentrons_hardware.drivers.can_bus.messages.message_definitions import ( +from opentrons_ot3_firmware.messages.message_definitions import ( AddLinearMoveRequest, ) -from opentrons_hardware.drivers.can_bus.messages.payloads import ( +from opentrons_ot3_firmware.messages.payloads import ( AddLinearMoveRequestPayload, MoveCompletedPayload, EmptyPayload, @@ -22,11 +22,11 @@ MoveGroupRunner, MoveScheduler, ) -from opentrons_hardware.drivers.can_bus.messages import ( +from opentrons_ot3_firmware.messages import ( message_definitions as md, MessageDefinition, ) -from opentrons_hardware.utils import UInt8Field, Int32Field, UInt32Field +from opentrons_ot3_firmware.utils import UInt8Field, Int32Field, UInt32Field @pytest.fixture diff --git a/hardware/tests/test_scripts/test_can_comm.py b/hardware/tests/test_scripts/test_can_comm.py index ec35d7dd5c7..e1a6faf90a9 100644 --- a/hardware/tests/test_scripts/test_can_comm.py +++ b/hardware/tests/test_scripts/test_can_comm.py @@ -5,16 +5,19 @@ import pytest -from opentrons_hardware.drivers.can_bus import ( +from opentrons_ot3_firmware.message import ( CanMessage, +) +from opentrons_ot3_firmware.arbitration_id import ( ArbitrationId, ArbitrationIdParts, + ) -from opentrons_hardware.drivers.can_bus.messages.payloads import ( +from opentrons_ot3_firmware.messages.payloads import ( DeviceInfoResponsePayload, ) from opentrons_hardware.scripts import can_comm -from opentrons_hardware.drivers.can_bus.constants import MessageId, NodeId +from opentrons_ot3_firmware.constants import MessageId, NodeId @pytest.fixture @@ -33,7 +36,7 @@ def test_prompt_message_without_payload( mock_get_input: MagicMock, mock_output: MagicMock ) -> None: """It should create a message without payload.""" - message_id = MessageId.get_speed_request + message_id = MessageId.get_status_request node_id = NodeId.pipette mock_get_input.side_effect = [ str(list(MessageId).index(message_id)), diff --git a/hardware/tests/utils/__init__.py b/hardware/tests/utils/__init__.py deleted file mode 100644 index d4576e7684a..00000000000 --- a/hardware/tests/utils/__init__.py +++ /dev/null @@ -1 +0,0 @@ -"""Utils package tests.""" diff --git a/hardware/tests/utils/test_binary_serializable.py b/hardware/tests/utils/test_binary_serializable.py deleted file mode 100644 index 0ff57c97783..00000000000 --- a/hardware/tests/utils/test_binary_serializable.py +++ /dev/null @@ -1,132 +0,0 @@ -"""Binary serializable tests.""" - -import pytest -from dataclasses import dataclass -from opentrons_hardware import utils - - -def test_fields_must_be_binary_fields() -> None: - """It should raise an error when a field is not BinaryFieldBase type.""" - - @dataclass - class Failing(utils.BinarySerializable): - """Test class type.""" - - a: int - - with pytest.raises(utils.InvalidFieldException): - Failing(a=123).serialize() - - -@dataclass -class TestClass(utils.BinarySerializable): - """Test class type.""" - - ub: utils.UInt8Field - b: utils.Int8Field - us: utils.UInt16Field - s: utils.Int16Field - ul: utils.UInt32Field - l: utils.Int32Field - ull: utils.UInt64Field - ll: utils.Int64Field - - -@pytest.fixture -def subject() -> TestClass: - """The test subject.""" - return TestClass( - # 1 bytes each - ub=utils.UInt8Field(8), - b=utils.Int8Field(-8), - # 2 bytes each - us=utils.UInt16Field(16), - s=utils.Int16Field(-16), - # 4 bytes each - ul=utils.UInt32Field(32), - l=utils.Int32Field(-32), - # 8 bytes each - ull=utils.UInt64Field(32), - ll=utils.Int64Field(-32), - ) - - -def test_get_size(subject: TestClass) -> None: - """It should return the data size in bytes.""" - assert subject.get_size() == 30 - - -def test_get_length(subject: TestClass) -> None: - """It should serialize with correct data length in bytes.""" - assert len(subject.serialize()) == 30 - - -def test_deserialize() -> None: - """It should deserialize data correctly.""" - data = ( - b"\x01\x02\x00\x03\x00\x04\x00\x00\x00\x05\x00\x00\x00\x06" - b"\x00\x00\x00\x00\x00\x00\x00\x07\x00\x00\x00\x00\x00\x00\x00\x08" - ) - assert TestClass.build(data) == TestClass( - ub=utils.UInt8Field(1), - b=utils.Int8Field(2), - us=utils.UInt16Field(3), - s=utils.Int16Field(4), - ul=utils.UInt32Field(5), - l=utils.Int32Field(6), - ull=utils.UInt64Field(7), - ll=utils.Int64Field(8), - ) - - -def test_deserialize_ignore_extra(subject: TestClass) -> None: - """It should ignore extra bytes when deserializing.""" - data = subject.serialize() - data += b"123212521" - new = TestClass.build(data) - assert new == subject - - -def test_deserialize_not_enough_data(subject: TestClass) -> None: - """It should ignore extra bytes when deserializing.""" - data = b"123212521" - with pytest.raises(utils.InvalidFieldException): - TestClass.build(data) - - -def test_serdes(subject: TestClass) -> None: - """It should serialize a deserialized instance correctly.""" - # Deserialize a serialized instance. They should be the same. - new = TestClass.build(subject.serialize()) - assert new == subject - - -@dataclass -class LittleEndianTestClass(utils.LittleEndianBinarySerializable): - """Little endian test class.""" - - ul: utils.UInt32Field - l: utils.Int32Field - - -@pytest.fixture -def little_endian_data() -> bytes: - """Little endian data fixture.""" - return b"\x00\x00\x00\x05\x00\x00\x00\x06" - - -def test_deserialize_little_endian(little_endian_data: bytes) -> None: - """It should deserialize little endian data correctly.""" - assert LittleEndianTestClass.build(little_endian_data) == LittleEndianTestClass( - ul=utils.UInt32Field(0x05000000), l=utils.Int32Field(0x06000000) - ) - - -def test_serialize_little_endian(little_endian_data: bytes) -> None: - """It should serialize little endian data correctly.""" - assert ( - LittleEndianTestClass( - ul=utils.UInt32Field(0x05000000), l=utils.Int32Field(0x06000000) - ).serialize() - == little_endian_data - ) diff --git a/scripts/bundle_installed_package.py b/scripts/bundle_installed_package.py new file mode 100644 index 00000000000..cd419abf776 --- /dev/null +++ b/scripts/bundle_installed_package.py @@ -0,0 +1,35 @@ +#!/usr/bin/env python3 +""" +Bundle into an sdist-like tar.gz an installed python module suitable +for unzipping into a robot's python site-packages directory. +""" + +import argparse +import io +import os +import tarfile +import pkg_resources + +def build_tar(pkgname: str, outdir: str): + os.makedirs(outdir, exist_ok=True) + pkg = pkg_resources.get_distribution(pkgname) + with tarfile.open( + name=os.path.join(outdir, f'{pkgname}-{pkg.version}.tar.gz'), + mode='w:gz') as tar: + tar.add(os.path.join(pkg.location, pkgname), pkgname, recursive=True) + tar.add(os.path.join(pkg.location, f'{pkgname}-{pkg.version}.dist-info'), + f'{pkgname}-{pkg.version}.dist-info', + recursive=True) + +def main(): + parser = argparse.ArgumentParser(description=__doc__) + parser.add_argument(metavar='PACKAGE', type=str, dest='package', + help='the python-importable (as opposed to pypi) name of the package to zip') + parser.add_argument(metavar='OUTPUT_DIR', type=str, dest='outdir', + help='directory to emit the tar to, named PACKAGE-version.tar.gz') + args = parser.parse_args() + tar = build_tar(args.package, args.outdir) + + +if __name__ == '__main__': + main()