==> Building on ceruledge ==> Checking for remote environment... ==> Syncing package to remote host... sending incremental file list created directory packages/python-traitlets ./ .SRCINFO 643 100% 0.00kB/s 0:00:00 643 100% 0.00kB/s 0:00:00 (xfr#1, to-chk=3/5) .nvchecker.toml 54 100% 52.73kB/s 0:00:00 54 100% 52.73kB/s 0:00:00 (xfr#2, to-chk=2/5) PKGBUILD 1,102 100% 1.05MB/s 0:00:00 1,102 100% 1.05MB/s 0:00:00 (xfr#3, to-chk=1/5) python-traitlets-5.14.3-3.log 240 100% 234.38kB/s 0:00:00 240 100% 234.38kB/s 0:00:00 (xfr#4, to-chk=0/5) sent 1,441 bytes received 143 bytes 3,168.00 bytes/sec total size is 1,995 speedup is 1.26 ==> Running extra-riscv64-build -- -d /home/felix/packages/riscv64-pkg-cache:/var/cache/pacman/pkg -l root3 on remote host... ]2;🔵 Container arch-nspawn-1011926 on ceruledge.felixc.at[?25l:: Synchronizing package databases... core downloading... extra downloading... :: Starting full system upgrade... there is nothing to do [?25h==> Building in chroot for [extra] (riscv64)... ==> Synchronizing chroot copy [/var/lib/archbuild/extra-riscv64/root] -> [root3]...done ==> Making package: python-traitlets 5.14.3-3 (Wed Jan 1 08:00:53 2025) ==> Retrieving sources...  -> Cloning traitlets git repo... Cloning into bare repository '/home/felix/packages/python-traitlets/traitlets'... remote: Enumerating objects: 15392, done. remote: Counting objects: 0% (1/1765) remote: Counting objects: 1% (18/1765) remote: Counting objects: 2% (36/1765) remote: Counting objects: 3% (53/1765) remote: Counting objects: 4% (71/1765) remote: Counting objects: 5% (89/1765) remote: Counting objects: 6% (106/1765) remote: Counting objects: 7% (124/1765) remote: Counting objects: 8% (142/1765) remote: Counting objects: 9% (159/1765) remote: Counting objects: 10% (177/1765) remote: Counting objects: 11% (195/1765) remote: Counting objects: 12% (212/1765) remote: Counting objects: 13% (230/1765) remote: Counting objects: 14% (248/1765) remote: Counting objects: 15% (265/1765) remote: Counting objects: 16% (283/1765) remote: Counting objects: 17% (301/1765) remote: Counting objects: 18% (318/1765) remote: Counting objects: 19% (336/1765) remote: Counting objects: 20% (353/1765) remote: Counting objects: 21% (371/1765) remote: Counting objects: 22% (389/1765) remote: Counting objects: 23% (406/1765) remote: Counting objects: 24% (424/1765) remote: Counting objects: 25% (442/1765) remote: Counting objects: 26% (459/1765) remote: Counting objects: 27% (477/1765) remote: Counting objects: 28% (495/1765) remote: Counting objects: 29% (512/1765) remote: Counting objects: 30% (530/1765) remote: Counting objects: 31% (548/1765) remote: Counting objects: 32% (565/1765) remote: Counting objects: 33% (583/1765) remote: Counting objects: 34% (601/1765) remote: Counting objects: 35% (618/1765) remote: Counting objects: 36% (636/1765) remote: Counting objects: 37% (654/1765) remote: Counting objects: 38% (671/1765) remote: Counting objects: 39% (689/1765) remote: Counting objects: 40% (706/1765) remote: Counting objects: 41% (724/1765) remote: Counting objects: 42% (742/1765) remote: Counting objects: 43% (759/1765) remote: Counting objects: 44% (777/1765) remote: Counting objects: 45% (795/1765) remote: Counting objects: 46% (812/1765) remote: Counting objects: 47% (830/1765) remote: Counting objects: 48% (848/1765) remote: Counting objects: 49% (865/1765) remote: Counting objects: 50% (883/1765) remote: Counting objects: 51% (901/1765) remote: Counting objects: 52% (918/1765) remote: Counting objects: 53% (936/1765) remote: Counting objects: 54% (954/1765) remote: Counting objects: 55% (971/1765) remote: Counting objects: 56% (989/1765) remote: Counting objects: 57% (1007/1765) remote: Counting objects: 58% (1024/1765) remote: Counting objects: 59% (1042/1765) remote: Counting objects: 60% (1059/1765) remote: Counting objects: 61% (1077/1765) remote: Counting objects: 62% (1095/1765) remote: Counting objects: 63% (1112/1765) remote: Counting objects: 64% (1130/1765) remote: Counting objects: 65% (1148/1765) remote: Counting objects: 66% (1165/1765) remote: Counting objects: 67% (1183/1765) remote: Counting objects: 68% (1201/1765) remote: Counting objects: 69% (1218/1765) remote: Counting objects: 70% (1236/1765) remote: Counting objects: 71% (1254/1765) remote: Counting objects: 72% (1271/1765) remote: Counting objects: 73% (1289/1765) remote: Counting objects: 74% (1307/1765) remote: Counting objects: 75% (1324/1765) remote: Counting objects: 76% (1342/1765) remote: Counting objects: 77% (1360/1765) remote: Counting objects: 78% (1377/1765) remote: Counting objects: 79% (1395/1765) remote: Counting objects: 80% (1412/1765) remote: Counting objects: 81% (1430/1765) remote: Counting objects: 82% (1448/1765) remote: Counting objects: 83% (1465/1765) remote: Counting objects: 84% (1483/1765) remote: Counting objects: 85% (1501/1765) remote: Counting objects: 86% (1518/1765) remote: Counting objects: 87% (1536/1765) remote: Counting objects: 88% (1554/1765) remote: Counting objects: 89% (1571/1765) remote: Counting objects: 90% (1589/1765) remote: Counting objects: 91% (1607/1765) remote: Counting objects: 92% (1624/1765) remote: Counting objects: 93% (1642/1765) remote: Counting objects: 94% (1660/1765) remote: Counting objects: 95% (1677/1765) remote: Counting objects: 96% (1695/1765) remote: Counting objects: 97% (1713/1765) remote: Counting objects: 98% (1730/1765) remote: Counting objects: 99% (1748/1765) remote: Counting objects: 100% (1765/1765) remote: Counting objects: 100% (1765/1765), done. remote: Compressing objects: 0% (1/605) remote: Compressing objects: 1% (7/605) remote: Compressing objects: 2% (13/605) remote: Compressing objects: 3% (19/605) remote: Compressing objects: 4% (25/605) remote: Compressing objects: 5% (31/605) remote: Compressing objects: 6% (37/605) remote: Compressing objects: 7% (43/605) remote: Compressing objects: 8% (49/605) remote: Compressing objects: 9% (55/605) remote: Compressing objects: 10% (61/605) remote: Compressing objects: 11% (67/605) remote: Compressing objects: 12% (73/605) remote: Compressing objects: 13% (79/605) remote: Compressing objects: 14% (85/605) remote: Compressing objects: 15% (91/605) remote: Compressing objects: 16% (97/605) remote: Compressing objects: 17% (103/605) remote: Compressing objects: 18% (109/605) remote: Compressing objects: 19% (115/605) remote: Compressing objects: 20% (121/605) remote: Compressing objects: 21% (128/605) remote: Compressing objects: 22% (134/605) remote: Compressing objects: 23% (140/605) remote: Compressing objects: 24% (146/605) remote: Compressing objects: 25% (152/605) remote: Compressing objects: 26% (158/605) remote: Compressing objects: 27% (164/605) remote: Compressing objects: 28% (170/605) remote: Compressing objects: 29% (176/605) remote: Compressing objects: 30% (182/605) remote: Compressing objects: 31% (188/605) remote: Compressing objects: 32% (194/605) remote: Compressing objects: 33% (200/605) remote: Compressing objects: 34% (206/605) remote: Compressing objects: 35% (212/605) remote: Compressing objects: 36% (218/605) remote: Compressing objects: 37% (224/605) remote: Compressing objects: 38% (230/605) remote: Compressing objects: 39% (236/605) remote: Compressing objects: 40% (242/605) remote: Compressing objects: 41% (249/605) remote: Compressing objects: 42% (255/605) remote: Compressing objects: 43% (261/605) remote: Compressing objects: 44% (267/605) remote: Compressing objects: 45% (273/605) remote: Compressing objects: 46% (279/605) remote: Compressing objects: 47% (285/605) remote: Compressing objects: 48% (291/605) remote: Compressing objects: 49% (297/605) remote: Compressing objects: 50% (303/605) remote: Compressing objects: 51% (309/605) remote: Compressing objects: 52% (315/605) remote: Compressing objects: 53% (321/605) remote: Compressing objects: 54% (327/605) remote: Compressing objects: 55% (333/605) remote: Compressing objects: 56% (339/605) remote: Compressing objects: 57% (345/605) remote: Compressing objects: 58% (351/605) remote: Compressing objects: 59% (357/605) remote: Compressing objects: 60% (363/605) remote: Compressing objects: 61% (370/605) remote: Compressing objects: 62% (376/605) remote: Compressing objects: 63% (382/605) remote: Compressing objects: 64% (388/605) remote: Compressing objects: 65% (394/605) remote: Compressing objects: 66% (400/605) remote: Compressing objects: 67% (406/605) remote: Compressing objects: 68% (412/605) remote: Compressing objects: 69% (418/605) remote: Compressing objects: 70% (424/605) remote: Compressing objects: 71% (430/605) remote: Compressing objects: 72% (436/605) remote: Compressing objects: 73% (442/605) remote: Compressing objects: 74% (448/605) remote: Compressing objects: 75% (454/605) remote: Compressing objects: 76% (460/605) remote: Compressing objects: 77% (466/605) remote: Compressing objects: 78% (472/605) remote: Compressing objects: 79% (478/605) remote: Compressing objects: 80% (484/605) remote: Compressing objects: 81% (491/605) remote: Compressing objects: 82% (497/605) remote: Compressing objects: 83% (503/605) remote: Compressing objects: 84% (509/605) remote: Compressing objects: 85% (515/605) remote: Compressing objects: 86% (521/605) remote: Compressing objects: 87% (527/605) remote: Compressing objects: 88% (533/605) remote: Compressing objects: 89% (539/605) remote: Compressing objects: 90% (545/605) remote: Compressing objects: 91% (551/605) remote: Compressing objects: 92% (557/605) remote: Compressing objects: 93% (563/605) remote: Compressing objects: 94% (569/605) remote: Compressing objects: 95% (575/605) remote: Compressing objects: 96% (581/605) remote: Compressing objects: 97% (587/605) remote: Compressing objects: 98% (593/605) remote: Compressing objects: 99% (599/605) remote: Compressing objects: 100% (605/605) remote: Compressing objects: 100% (605/605), done. Receiving objects: 0% (1/15392) Receiving objects: 1% (154/15392) Receiving objects: 2% (308/15392) Receiving objects: 3% (462/15392) Receiving objects: 4% (616/15392) Receiving objects: 5% (770/15392) Receiving objects: 6% (924/15392) Receiving objects: 7% (1078/15392) Receiving objects: 8% (1232/15392) Receiving objects: 9% (1386/15392) Receiving objects: 10% (1540/15392) Receiving objects: 11% (1694/15392) Receiving objects: 12% (1848/15392) Receiving objects: 13% (2001/15392) Receiving objects: 14% (2155/15392) Receiving objects: 15% (2309/15392) Receiving objects: 16% (2463/15392) Receiving objects: 17% (2617/15392) Receiving objects: 18% (2771/15392) Receiving objects: 19% (2925/15392) Receiving objects: 20% (3079/15392) Receiving objects: 21% (3233/15392) Receiving objects: 22% (3387/15392) Receiving objects: 23% (3541/15392) Receiving objects: 24% (3695/15392) Receiving objects: 25% (3848/15392) Receiving objects: 26% (4002/15392) Receiving objects: 27% (4156/15392) Receiving objects: 28% (4310/15392) Receiving objects: 29% (4464/15392) Receiving objects: 30% (4618/15392) Receiving objects: 31% (4772/15392) Receiving objects: 32% (4926/15392) Receiving objects: 33% (5080/15392) Receiving objects: 34% (5234/15392) Receiving objects: 35% (5388/15392) Receiving objects: 36% (5542/15392) Receiving objects: 37% (5696/15392) Receiving objects: 38% (5849/15392) Receiving objects: 39% (6003/15392) Receiving objects: 40% (6157/15392) Receiving objects: 41% (6311/15392) Receiving objects: 42% (6465/15392) Receiving objects: 43% (6619/15392) Receiving objects: 44% (6773/15392) Receiving objects: 45% (6927/15392) Receiving objects: 46% (7081/15392) Receiving objects: 47% (7235/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 48% (7389/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 49% (7543/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 50% (7696/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 51% (7850/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 52% (8004/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 53% (8158/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 54% (8312/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 55% (8466/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 56% (8620/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 57% (8774/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 58% (8928/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 59% (9082/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 60% (9236/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 61% (9390/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 62% (9544/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 63% (9697/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 64% (9851/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 65% (10005/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 66% (10159/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 67% (10313/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 68% (10467/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 69% (10621/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 70% (10775/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 71% (10929/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 72% (11083/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 73% (11237/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 74% (11391/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 75% (11544/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 76% (11698/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 77% (11852/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 78% (12006/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 79% (12160/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 80% (12314/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 81% (12468/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 82% (12622/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 83% (12776/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 84% (12930/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 85% (13084/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 86% (13238/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 87% (13392/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 88% (13545/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 89% (13699/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 90% (13853/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 91% (14007/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 92% (14161/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 93% (14315/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 94% (14469/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 95% (14623/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 96% (14777/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 97% (14931/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 98% (15085/15392), 2.10 MiB | 4.18 MiB/s remote: Total 15392 (delta 1277), reused 1588 (delta 1159), pack-reused 13627 (from 1) Receiving objects: 99% (15239/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 100% (15392/15392), 2.10 MiB | 4.18 MiB/s Receiving objects: 100% (15392/15392), 4.14 MiB | 5.04 MiB/s, done. Resolving deltas: 0% (0/7973) Resolving deltas: 1% (80/7973) Resolving deltas: 2% (160/7973) Resolving deltas: 3% (240/7973) Resolving deltas: 4% (319/7973) Resolving deltas: 5% (399/7973) Resolving deltas: 6% (479/7973) Resolving deltas: 7% (560/7973) Resolving deltas: 8% (638/7973) Resolving deltas: 9% (719/7973) Resolving deltas: 10% (798/7973) Resolving deltas: 11% (878/7973) Resolving deltas: 12% (957/7973) Resolving deltas: 13% (1037/7973) Resolving deltas: 14% (1117/7973) Resolving deltas: 15% (1196/7973) Resolving deltas: 16% (1276/7973) Resolving deltas: 17% (1356/7973) Resolving deltas: 18% (1437/7973) Resolving deltas: 19% (1515/7973) Resolving deltas: 20% (1595/7973) Resolving deltas: 21% (1675/7973) Resolving deltas: 22% (1755/7973) Resolving deltas: 23% (1834/7973) Resolving deltas: 24% (1914/7973) Resolving deltas: 25% (1994/7973) Resolving deltas: 26% (2073/7973) Resolving deltas: 27% (2153/7973) Resolving deltas: 28% (2233/7973) Resolving deltas: 29% (2313/7973) Resolving deltas: 30% (2392/7973) Resolving deltas: 31% (2473/7973) Resolving deltas: 32% (2552/7973) Resolving deltas: 33% (2632/7973) Resolving deltas: 34% (2711/7973) Resolving deltas: 35% (2791/7973) Resolving deltas: 36% (2871/7973) Resolving deltas: 37% (2951/7973) Resolving deltas: 38% (3030/7973) Resolving deltas: 39% (3110/7973) Resolving deltas: 40% (3190/7973) Resolving deltas: 41% (3269/7973) Resolving deltas: 42% (3349/7973) Resolving deltas: 43% (3429/7973) Resolving deltas: 44% (3509/7973) Resolving deltas: 45% (3588/7973) Resolving deltas: 46% (3668/7973) Resolving deltas: 47% (3748/7973) Resolving deltas: 48% (3828/7973) Resolving deltas: 49% (3907/7973) Resolving deltas: 50% (3987/7973) Resolving deltas: 51% (4067/7973) Resolving deltas: 52% (4146/7973) Resolving deltas: 53% (4227/7973) Resolving deltas: 54% (4306/7973) Resolving deltas: 55% (4386/7973) Resolving deltas: 56% (4465/7973) Resolving deltas: 57% (4545/7973) Resolving deltas: 58% (4625/7973) Resolving deltas: 59% (4705/7973) Resolving deltas: 60% (4784/7973) Resolving deltas: 61% (4864/7973) Resolving deltas: 62% (4944/7973) Resolving deltas: 63% (5023/7973) Resolving deltas: 64% (5103/7973) Resolving deltas: 65% (5183/7973) Resolving deltas: 66% (5263/7973) Resolving deltas: 67% (5342/7973) Resolving deltas: 68% (5422/7973) Resolving deltas: 69% (5502/7973) Resolving deltas: 70% (5582/7973) Resolving deltas: 71% (5661/7973) Resolving deltas: 72% (5741/7973) Resolving deltas: 73% (5821/7973) Resolving deltas: 74% (5901/7973) Resolving deltas: 75% (5981/7973) Resolving deltas: 76% (6060/7973) Resolving deltas: 77% (6140/7973) Resolving deltas: 78% (6219/7973) Resolving deltas: 79% (6299/7973) Resolving deltas: 80% (6379/7973) Resolving deltas: 81% (6459/7973) Resolving deltas: 82% (6538/7973) Resolving deltas: 83% (6618/7973) Resolving deltas: 84% (6698/7973) Resolving deltas: 85% (6778/7973) Resolving deltas: 86% (6857/7973) Resolving deltas: 87% (6937/7973) Resolving deltas: 88% (7017/7973) Resolving deltas: 89% (7096/7973) Resolving deltas: 90% (7176/7973) Resolving deltas: 91% (7256/7973) Resolving deltas: 92% (7336/7973) Resolving deltas: 93% (7415/7973) Resolving deltas: 94% (7495/7973) Resolving deltas: 95% (7576/7973) Resolving deltas: 96% (7655/7973) Resolving deltas: 97% (7734/7973) Resolving deltas: 98% (7814/7973) Resolving deltas: 99% (7894/7973) Resolving deltas: 100% (7973/7973) Resolving deltas: 100% (7973/7973), done. ==> Validating source files with sha256sums... traitlets ... Passed ]2;🔵 Container arch-nspawn-1012893 on ceruledge.felixc.at==> Making package: python-traitlets 5.14.3-3 (Wed Jan 1 08:01:16 2025) ==> Checking runtime dependencies... ==> Installing missing dependencies... [?25lresolving dependencies... looking for conflicting packages... Package (2) New Version Net Change Download Size extra/python-argcomplete 3.4.0-2 0.27 MiB 0.06 MiB extra/python-typing_extensions 4.12.2-3 0.42 MiB Total Download Size: 0.06 MiB Total Installed Size: 0.69 MiB :: Proceed with installation? [Y/n] :: Retrieving packages... python-argcomplete-3.4.0-2-any downloading... checking keyring... checking package integrity... loading package files... checking for file conflicts... :: Processing package changes... installing python-argcomplete... installing python-typing_extensions... :: Running post-transaction hooks... (1/1) Arming ConditionNeedsUpdate... [?25h==> Checking buildtime dependencies... ==> Installing missing dependencies... [?25lresolving dependencies... looking for conflicting packages... Package (20) New Version Net Change Download Size extra/mypy 1.14.0-1 21.60 MiB 3.33 MiB extra/perl-error 0.17029-7 0.04 MiB extra/perl-mailtools 2.22-1 0.10 MiB extra/perl-timedate 2.33-7 0.08 MiB extra/python-editables 0.5-5 0.03 MiB 0.01 MiB extra/python-iniconfig 2.0.0-6 0.04 MiB extra/python-mypy_extensions 1.0.0-5 0.03 MiB 0.01 MiB extra/python-orjson 3.10.13-1 0.65 MiB 0.28 MiB extra/python-packaging 24.2-3 0.66 MiB extra/python-pathspec 0.12.1-3 0.23 MiB 0.05 MiB extra/python-pluggy 1.5.0-3 0.20 MiB extra/python-pyproject-hooks 1.2.0-3 0.10 MiB extra/python-pytest 1:8.3.4-1 3.92 MiB extra/python-trove-classifiers 2024.10.21.16-3 0.12 MiB 0.02 MiB extra/git 2.47.1-1 27.20 MiB extra/python-build 1.2.2-3 0.20 MiB extra/python-hatchling 1.25.0-2 1.07 MiB 0.17 MiB extra/python-installer 0.7.0-10 0.17 MiB extra/python-pytest-mock 3.14.0-2 0.09 MiB 0.02 MiB extra/python-pytest-mypy-testing 0.1.3-3 0.15 MiB 0.04 MiB Total Download Size: 3.93 MiB Total Installed Size: 56.68 MiB :: Proceed with installation? [Y/n] :: Retrieving packages... mypy-1.14.0-1-any downloading... python-orjson-3.10.13-1-riscv64 downloading... python-hatchling-1.25.0-2-any downloading... python-pathspec-0.12.1-3-any downloading... python-pytest-mypy-testing-0.1.3-3-any downloading... python-pytest-mock-3.14.0-2-any downloading... python-trove-classifiers-2024.10.21.16-3-any downloading... python-editables-0.5-5-any downloading... python-mypy_extensions-1.0.0-5-any downloading... checking keyring... checking package integrity... loading package files... checking for file conflicts... :: Processing package changes... installing perl-error... installing perl-timedate... installing perl-mailtools... installing git... Optional dependencies for git tk: gitk and git gui openssh: ssh transport and crypto perl-libwww: git svn perl-term-readkey: git svn and interactive.singlekey setting perl-io-socket-ssl: git send-email TLS support perl-authen-sasl: git send-email TLS support perl-mediawiki-api: git mediawiki support perl-datetime-format-iso8601: git mediawiki support perl-lwp-protocol-https: git mediawiki https support perl-cgi: gitweb (web interface) support python: git svn & git p4 [installed] subversion: git svn org.freedesktop.secrets: keyring credential helper libsecret: libsecret credential helper [installed] installing python-packaging... installing python-pyproject-hooks... installing python-build... Optional dependencies for python-build python-pip: to use as the Python package installer (default) python-uv: to use as the Python package installer python-virtualenv: to use virtualenv for build isolation installing python-pathspec... installing python-pluggy... installing python-editables... installing python-trove-classifiers... installing python-hatchling... installing python-installer... installing python-iniconfig... installing python-pytest... installing python-pytest-mock... installing python-mypy_extensions... installing python-orjson... installing mypy... Optional dependencies for mypy python-lxml: for reports python-pip: for installing missing types python-psutil: for dmypy python-setuptools: for mypyc installing python-pytest-mypy-testing... :: Running post-transaction hooks... (1/4) Creating system user accounts... Creating group 'git' with GID 972. Creating user 'git' (git daemon user) with UID 972 and GID 972. (2/4) Reloading system manager configuration... Skipped: Current root is not booted. (3/4) Arming ConditionNeedsUpdate... (4/4) Warn about old perl modules [?25h==> Retrieving sources... ==> WARNING: Skipping all source file integrity checks. ==> Extracting sources...  -> Creating working copy of traitlets git repo... Cloning into 'traitlets'... done. Switched to a new branch 'makepkg' ==> Starting build()... * Getting build dependencies for wheel... * Building wheel... Successfully built traitlets-5.14.3-py3-none-any.whl ==> Starting check()... ============================= test session starts ============================== platform linux -- Python 3.13.1, pytest-8.3.4, pluggy-1.5.0 -- /build/python-traitlets/src/traitlets/test-env/bin/python cachedir: .pytest_cache rootdir: /build/python-traitlets/src/traitlets configfile: pyproject.toml testpaths: tests, examples plugins: mock-3.14.0, mypy-testing-0.1.3 collecting ... collected 588 items / 1 deselected / 587 selected tests/_warnings.py::tests._warnings.all_warnings PASSED [ 0%] tests/_warnings.py::tests._warnings.expected_warnings SKIPPED (all t...) [ 0%] tests/config/test_application.py::TestApplication::test_alias_unrecognized PASSED [ 0%] tests/config/test_application.py::TestApplication::test_aliases PASSED [ 0%] tests/config/test_application.py::TestApplication::test_aliases_help_msg PASSED [ 0%] tests/config/test_application.py::TestApplication::test_aliases_multiple PASSED [ 1%] tests/config/test_application.py::TestApplication::test_app_name_set_via_constructor PASSED [ 1%] tests/config/test_application.py::TestApplication::test_basic PASSED [ 1%] tests/config/test_application.py::TestApplication::test_cli_allow_none PASSED [ 1%] tests/config/test_application.py::TestApplication::test_cli_priority PASSED [ 1%] tests/config/test_application.py::TestApplication::test_config PASSED [ 1%] tests/config/test_application.py::TestApplication::test_config_dict_args PASSED [ 2%] tests/config/test_application.py::TestApplication::test_config_propagation PASSED [ 2%] tests/config/test_application.py::TestApplication::test_config_seq_args PASSED [ 2%] tests/config/test_application.py::TestApplication::test_document_config_option PASSED [ 2%] tests/config/test_application.py::TestApplication::test_extra_args PASSED [ 2%] tests/config/test_application.py::TestApplication::test_flag_clobber PASSED [ 2%] tests/config/test_application.py::TestApplication::test_flags PASSED [ 3%] tests/config/test_application.py::TestApplication::test_flags_help_msg PASSED [ 3%] tests/config/test_application.py::TestApplication::test_flatten_aliases PASSED [ 3%] tests/config/test_application.py::TestApplication::test_flatten_flags PASSED [ 3%] tests/config/test_application.py::TestApplication::test_generate_config_file PASSED [ 3%] tests/config/test_application.py::TestApplication::test_generate_config_file_classes_to_include PASSED [ 3%] tests/config/test_application.py::TestApplication::test_ipython_cli_priority PASSED [ 4%] tests/config/test_application.py::TestApplication::test_loaded_config_files PASSED [ 4%] tests/config/test_application.py::TestApplication::test_log PASSED [ 4%] tests/config/test_application.py::TestApplication::test_log_bad_config PASSED [ 4%] tests/config/test_application.py::TestApplication::test_log_collisions PASSED [ 4%] tests/config/test_application.py::TestApplication::test_mro_discovery PASSED [ 4%] tests/config/test_application.py::TestApplication::test_multi_file PASSED [ 5%] tests/config/test_application.py::TestApplication::test_no_eval_cli_text PASSED [ 5%] tests/config/test_application.py::TestApplication::test_raise_on_bad_config PASSED [ 5%] tests/config/test_application.py::TestApplication::test_subcommands_instantiation PASSED [ 5%] tests/config/test_application.py::TestApplication::test_unicode_argv PASSED [ 5%] tests/config/test_application.py::TestApplication::test_warn_autocorrect PASSED [ 5%] tests/config/test_application.py::test_cli_multi_scalar PASSED [ 6%] tests/config/test_application.py::test_deprecated_notifier PASSED [ 6%] tests/config/test_application.py::test_help_output PASSED [ 6%] tests/config/test_application.py::test_help_all_output PASSED [ 6%] tests/config/test_application.py::test_show_config_cli PASSED [ 6%] tests/config/test_application.py::test_show_config_json_cli PASSED [ 6%] tests/config/test_application.py::test_show_config PASSED [ 7%] tests/config/test_application.py::test_show_config_json PASSED [ 7%] tests/config/test_application.py::test_deep_alias PASSED [ 7%] tests/config/test_application.py::test_logging_config PASSED [ 7%] tests/config/test_application.py::test_get_default_logging_config_pythonw PASSED [ 7%] tests/config/test_application.py::test_logging_teardown_on_error PASSED [ 8%] tests/config/test_argcomplete.py::TestArgcomplete::test_complete_simple_app FAILED [ 8%] tests/config/test_argcomplete.py::TestArgcomplete::test_complete_custom_completers FAILED [ 8%] tests/config/test_argcomplete.py::TestArgcomplete::test_complete_subcommands FAILED [ 8%] tests/config/test_argcomplete.py::TestArgcomplete::test_complete_subcommands_subapp1 FAILED [ 8%] tests/config/test_argcomplete.py::TestArgcomplete::test_complete_subcommands_subapp2 FAILED [ 8%] tests/config/test_argcomplete.py::TestArgcomplete::test_complete_subcommands_main FAILED [ 9%] tests/config/test_configurable.py::TestConfigurable::test_custom PASSED [ 9%] tests/config/test_configurable.py::TestConfigurable::test_default PASSED [ 9%] tests/config/test_configurable.py::TestConfigurable::test_generated_config_enum_comments PASSED [ 9%] tests/config/test_configurable.py::TestConfigurable::test_generated_config_strenum_comments PASSED [ 9%] tests/config/test_configurable.py::TestConfigurable::test_help PASSED [ 9%] tests/config/test_configurable.py::TestConfigurable::test_help_inst PASSED [ 10%] tests/config/test_configurable.py::TestConfigurable::test_inheritance PASSED [ 10%] tests/config/test_configurable.py::TestConfigurable::test_override1 PASSED [ 10%] tests/config/test_configurable.py::TestConfigurable::test_override2 PASSED [ 10%] tests/config/test_configurable.py::TestConfigurable::test_parent PASSED [ 10%] tests/config/test_configurable.py::TestSingletonConfigurable::test_inheritance PASSED [ 10%] tests/config/test_configurable.py::TestSingletonConfigurable::test_instance PASSED [ 11%] tests/config/test_configurable.py::TestLoggingConfigurable::test_parent_logger PASSED [ 11%] tests/config/test_configurable.py::TestLoggingConfigurable::test_parent_not_logging_configurable PASSED [ 11%] tests/config/test_configurable.py::TestParentConfigurable::test_multi_parent PASSED [ 11%] tests/config/test_configurable.py::TestParentConfigurable::test_multi_parent_priority PASSED [ 11%] tests/config/test_configurable.py::TestParentConfigurable::test_parent_config PASSED [ 11%] tests/config/test_configurable.py::TestParentConfigurable::test_parent_inheritance PASSED [ 12%] tests/config/test_configurable.py::TestParentConfigurable::test_parent_priority PASSED [ 12%] tests/config/test_configurable.py::TestConfigContainers::test_append_extend PASSED [ 12%] tests/config/test_configurable.py::TestConfigContainers::test_config_default PASSED [ 12%] tests/config/test_configurable.py::TestConfigContainers::test_config_default_deprecated PASSED [ 12%] tests/config/test_configurable.py::TestConfigContainers::test_dict_update PASSED [ 12%] tests/config/test_configurable.py::TestConfigContainers::test_extend PASSED [ 13%] tests/config/test_configurable.py::TestConfigContainers::test_extend_append PASSED [ 13%] tests/config/test_configurable.py::TestConfigContainers::test_insert PASSED [ 13%] tests/config/test_configurable.py::TestConfigContainers::test_insert_extend PASSED [ 13%] tests/config/test_configurable.py::TestConfigContainers::test_kwarg_config_priority PASSED [ 13%] tests/config/test_configurable.py::TestConfigContainers::test_prepend PASSED [ 13%] tests/config/test_configurable.py::TestConfigContainers::test_prepend_extend PASSED [ 14%] tests/config/test_configurable.py::TestConfigContainers::test_set_update PASSED [ 14%] tests/config/test_configurable.py::TestConfigContainers::test_update_self PASSED [ 14%] tests/config/test_configurable.py::TestConfigContainers::test_update_twice PASSED [ 14%] tests/config/test_configurable.py::TestLogger::test_warn_match PASSED [ 14%] tests/config/test_configurable.py::test_logger_adapter PASSED [ 14%] tests/config/test_loader.py::TestFileCL::test_collision PASSED [ 15%] tests/config/test_loader.py::TestFileCL::test_context_manager PASSED [ 15%] tests/config/test_loader.py::TestFileCL::test_json PASSED [ 15%] tests/config/test_loader.py::TestFileCL::test_json_context_bad_write PASSED [ 15%] tests/config/test_loader.py::TestFileCL::test_python PASSED [ 15%] tests/config/test_loader.py::TestFileCL::test_v2raise PASSED [ 16%] tests/config/test_loader.py::TestArgParseCL::test_add_arguments PASSED [ 16%] tests/config/test_loader.py::TestArgParseCL::test_argv PASSED [ 16%] tests/config/test_loader.py::TestArgParseCL::test_basic PASSED [ 16%] tests/config/test_loader.py::TestArgParseCL::test_list_args PASSED [ 16%] tests/config/test_loader.py::TestKeyValueCL::test_basic PASSED [ 16%] tests/config/test_loader.py::TestKeyValueCL::test_dict PASSED [ 17%] tests/config/test_loader.py::TestKeyValueCL::test_dict_key_traits PASSED [ 17%] tests/config/test_loader.py::TestKeyValueCL::test_eval PASSED [ 17%] tests/config/test_loader.py::TestKeyValueCL::test_expanduser PASSED [ 17%] tests/config/test_loader.py::TestKeyValueCL::test_extra_args PASSED [ 17%] tests/config/test_loader.py::TestKeyValueCL::test_list_append PASSED [ 17%] tests/config/test_loader.py::TestKeyValueCL::test_list_single_item PASSED [ 18%] tests/config/test_loader.py::TestKeyValueCL::test_unicode_args PASSED [ 18%] tests/config/test_loader.py::TestArgParseKVCL::test_basic PASSED [ 18%] tests/config/test_loader.py::TestArgParseKVCL::test_dict PASSED [ 18%] tests/config/test_loader.py::TestArgParseKVCL::test_dict_key_traits PASSED [ 18%] tests/config/test_loader.py::TestArgParseKVCL::test_dict_traits PASSED [ 18%] tests/config/test_loader.py::TestArgParseKVCL::test_eval PASSED [ 19%] tests/config/test_loader.py::TestArgParseKVCL::test_expanduser PASSED [ 19%] tests/config/test_loader.py::TestArgParseKVCL::test_expanduser2 PASSED [ 19%] tests/config/test_loader.py::TestArgParseKVCL::test_extra_args PASSED [ 19%] tests/config/test_loader.py::TestArgParseKVCL::test_int_literals PASSED [ 19%] tests/config/test_loader.py::TestArgParseKVCL::test_list_append PASSED [ 19%] tests/config/test_loader.py::TestArgParseKVCL::test_list_single_item PASSED [ 20%] tests/config/test_loader.py::TestArgParseKVCL::test_mixed_seq_positional PASSED [ 20%] tests/config/test_loader.py::TestArgParseKVCL::test_no_cast_literals PASSED [ 20%] tests/config/test_loader.py::TestArgParseKVCL::test_seq_traits PASSED [ 20%] tests/config/test_loader.py::TestArgParseKVCL::test_seq_traits_single_empty_string PASSED [ 20%] tests/config/test_loader.py::TestArgParseKVCL::test_split_positional PASSED [ 20%] tests/config/test_loader.py::TestArgParseKVCL::test_unicode_alias PASSED [ 21%] tests/config/test_loader.py::TestArgParseKVCL::test_unicode_args PASSED [ 21%] tests/config/test_loader.py::TestConfig::test_auto_section PASSED [ 21%] tests/config/test_loader.py::TestConfig::test_builtin PASSED [ 21%] tests/config/test_loader.py::TestConfig::test_contains PASSED [ 21%] tests/config/test_loader.py::TestConfig::test_deepcopy PASSED [ 21%] tests/config/test_loader.py::TestConfig::test_fromdict PASSED [ 22%] tests/config/test_loader.py::TestConfig::test_fromdictmerge PASSED [ 22%] tests/config/test_loader.py::TestConfig::test_fromdictmerge2 PASSED [ 22%] tests/config/test_loader.py::TestConfig::test_getattr_not_section PASSED [ 22%] tests/config/test_loader.py::TestConfig::test_getattr_private_missing PASSED [ 22%] tests/config/test_loader.py::TestConfig::test_getattr_section PASSED [ 22%] tests/config/test_loader.py::TestConfig::test_getitem_not_section PASSED [ 23%] tests/config/test_loader.py::TestConfig::test_getitem_section PASSED [ 23%] tests/config/test_loader.py::TestConfig::test_lazy_config_repr PASSED [ 23%] tests/config/test_loader.py::TestConfig::test_merge_doesnt_exist PASSED [ 23%] tests/config/test_loader.py::TestConfig::test_merge_exists PASSED [ 23%] tests/config/test_loader.py::TestConfig::test_merge_multi_lazy PASSED [ 24%] tests/config/test_loader.py::TestConfig::test_merge_multi_lazyII PASSED [ 24%] tests/config/test_loader.py::TestConfig::test_merge_multi_lazy_III PASSED [ 24%] tests/config/test_loader.py::TestConfig::test_merge_multi_lazy_IV PASSED [ 24%] tests/config/test_loader.py::TestConfig::test_merge_multi_lazy_update_I PASSED [ 24%] tests/config/test_loader.py::TestConfig::test_merge_multi_lazy_update_II PASSED [ 24%] tests/config/test_loader.py::TestConfig::test_merge_multi_lazy_update_III PASSED [ 25%] tests/config/test_loader.py::TestConfig::test_merge_no_copies PASSED [ 25%] tests/config/test_loader.py::TestConfig::test_pickle_config PASSED [ 25%] tests/config/test_loader.py::TestConfig::test_setget PASSED [ 25%] tests/test_traitlets.py::TestTraitType::test_default_validate PASSED [ 25%] tests/test_traitlets.py::TestTraitType::test_deprecated_dynamic_initializer PASSED [ 25%] tests/test_traitlets.py::TestTraitType::test_deprecated_metadata_access PASSED [ 26%] tests/test_traitlets.py::TestTraitType::test_deprecated_method_warnings PASSED [ 26%] tests/test_traitlets.py::TestTraitType::test_dynamic_initializer PASSED [ 26%] tests/test_traitlets.py::TestTraitType::test_error PASSED [ 26%] tests/test_traitlets.py::TestTraitType::test_get_undefined PASSED [ 26%] tests/test_traitlets.py::TestTraitType::test_info PASSED [ 26%] tests/test_traitlets.py::TestTraitType::test_metadata_localized_instance PASSED [ 27%] tests/test_traitlets.py::TestTraitType::test_set PASSED [ 27%] tests/test_traitlets.py::TestTraitType::test_tag_metadata PASSED [ 27%] tests/test_traitlets.py::TestTraitType::test_trait_types_deprecated PASSED [ 27%] tests/test_traitlets.py::TestTraitType::test_trait_types_dict_deprecated PASSED [ 27%] tests/test_traitlets.py::TestTraitType::test_trait_types_list_deprecated PASSED [ 27%] tests/test_traitlets.py::TestTraitType::test_trait_types_tuple_deprecated PASSED [ 28%] tests/test_traitlets.py::TestTraitType::test_union_default_value PASSED [ 28%] tests/test_traitlets.py::TestTraitType::test_union_metadata PASSED [ 28%] tests/test_traitlets.py::TestTraitType::test_union_trait_default_value PASSED [ 28%] tests/test_traitlets.py::TestTraitType::test_union_validation_priority PASSED [ 28%] tests/test_traitlets.py::TestTraitType::test_validate PASSED [ 28%] tests/test_traitlets.py::TestHasDescriptorsMeta::test_metaclass PASSED [ 29%] tests/test_traitlets.py::TestHasDescriptorsMeta::test_this_class PASSED [ 29%] tests/test_traitlets.py::TestHasDescriptors::test_setup_instance PASSED [ 29%] tests/test_traitlets.py::TestHasTraitsNotify::test_notify_all PASSED [ 29%] tests/test_traitlets.py::TestHasTraitsNotify::test_notify_args PASSED [ 29%] tests/test_traitlets.py::TestHasTraitsNotify::test_notify_one PASSED [ 29%] tests/test_traitlets.py::TestHasTraitsNotify::test_notify_only_once PASSED [ 30%] tests/test_traitlets.py::TestHasTraitsNotify::test_notify_subclass PASSED [ 30%] tests/test_traitlets.py::TestHasTraitsNotify::test_static_notify PASSED [ 30%] tests/test_traitlets.py::TestHasTraitsNotify::test_subclass PASSED [ 30%] tests/test_traitlets.py::TestObserveDecorator::test_notify_all PASSED [ 30%] tests/test_traitlets.py::TestObserveDecorator::test_notify_args PASSED [ 31%] tests/test_traitlets.py::TestObserveDecorator::test_notify_one PASSED [ 31%] tests/test_traitlets.py::TestObserveDecorator::test_notify_only_once PASSED [ 31%] tests/test_traitlets.py::TestObserveDecorator::test_notify_subclass PASSED [ 31%] tests/test_traitlets.py::TestObserveDecorator::test_static_notify PASSED [ 31%] tests/test_traitlets.py::TestObserveDecorator::test_subclass PASSED [ 31%] tests/test_traitlets.py::TestHasTraits::test_init PASSED [ 32%] tests/test_traitlets.py::TestHasTraits::test_positional_args PASSED [ 32%] tests/test_traitlets.py::TestHasTraits::test_trait_has_value PASSED [ 32%] tests/test_traitlets.py::TestHasTraits::test_trait_metadata PASSED [ 32%] tests/test_traitlets.py::TestHasTraits::test_trait_metadata_default PASSED [ 32%] tests/test_traitlets.py::TestHasTraits::test_trait_metadata_deprecated PASSED [ 32%] tests/test_traitlets.py::TestHasTraits::test_trait_names PASSED [ 33%] tests/test_traitlets.py::TestHasTraits::test_traits PASSED [ 33%] tests/test_traitlets.py::TestHasTraits::test_traits_metadata PASSED [ 33%] tests/test_traitlets.py::TestHasTraits::test_traits_metadata_deprecated PASSED [ 33%] tests/test_traitlets.py::TestType::test_allow_none PASSED [ 33%] tests/test_traitlets.py::TestType::test_default PASSED [ 33%] tests/test_traitlets.py::TestType::test_default_options PASSED [ 34%] tests/test_traitlets.py::TestType::test_set_str_klass PASSED [ 34%] tests/test_traitlets.py::TestType::test_str_klass PASSED [ 34%] tests/test_traitlets.py::TestType::test_validate_default PASSED [ 34%] tests/test_traitlets.py::TestType::test_validate_klass PASSED [ 34%] tests/test_traitlets.py::TestType::test_value PASSED [ 34%] tests/test_traitlets.py::TestInstance::test_args_kw PASSED [ 35%] tests/test_traitlets.py::TestInstance::test_bad_default PASSED [ 35%] tests/test_traitlets.py::TestInstance::test_basic PASSED [ 35%] tests/test_traitlets.py::TestInstance::test_default_klass PASSED [ 35%] tests/test_traitlets.py::TestInstance::test_instance PASSED [ 35%] tests/test_traitlets.py::TestInstance::test_unique_default_value PASSED [ 35%] tests/test_traitlets.py::TestThis::test_subclass PASSED [ 36%] tests/test_traitlets.py::TestThis::test_subclass_override PASSED [ 36%] tests/test_traitlets.py::TestThis::test_this_class PASSED [ 36%] tests/test_traitlets.py::TestThis::test_this_in_container PASSED [ 36%] tests/test_traitlets.py::TestThis::test_this_inst PASSED [ 36%] tests/test_traitlets.py::TraitTestBase::test_allow_none PASSED [ 36%] tests/test_traitlets.py::TraitTestBase::test_bad_values PASSED [ 37%] tests/test_traitlets.py::TraitTestBase::test_default_value PASSED [ 37%] tests/test_traitlets.py::TraitTestBase::test_good_values PASSED [ 37%] tests/test_traitlets.py::AnyTraitTest::test_allow_none PASSED [ 37%] tests/test_traitlets.py::AnyTraitTest::test_bad_values PASSED [ 37%] tests/test_traitlets.py::AnyTraitTest::test_default_value PASSED [ 37%] tests/test_traitlets.py::AnyTraitTest::test_good_values PASSED [ 38%] tests/test_traitlets.py::UnionTraitTest::test_allow_none PASSED [ 38%] tests/test_traitlets.py::UnionTraitTest::test_bad_values PASSED [ 38%] tests/test_traitlets.py::UnionTraitTest::test_default_value PASSED [ 38%] tests/test_traitlets.py::UnionTraitTest::test_good_values PASSED [ 38%] tests/test_traitlets.py::CallableTraitTest::test_allow_none PASSED [ 39%] tests/test_traitlets.py::CallableTraitTest::test_bad_values PASSED [ 39%] tests/test_traitlets.py::CallableTraitTest::test_default_value PASSED [ 39%] tests/test_traitlets.py::CallableTraitTest::test_good_values PASSED [ 39%] tests/test_traitlets.py::OrTraitTest::test_allow_none PASSED [ 39%] tests/test_traitlets.py::OrTraitTest::test_bad_values PASSED [ 39%] tests/test_traitlets.py::OrTraitTest::test_default_value PASSED [ 40%] tests/test_traitlets.py::OrTraitTest::test_good_values PASSED [ 40%] tests/test_traitlets.py::TestInt::test_allow_none PASSED [ 40%] tests/test_traitlets.py::TestInt::test_bad_values PASSED [ 40%] tests/test_traitlets.py::TestInt::test_default_value PASSED [ 40%] tests/test_traitlets.py::TestInt::test_good_values PASSED [ 40%] tests/test_traitlets.py::TestCInt::test_allow_none PASSED [ 41%] tests/test_traitlets.py::TestCInt::test_bad_values PASSED [ 41%] tests/test_traitlets.py::TestCInt::test_default_value PASSED [ 41%] tests/test_traitlets.py::TestCInt::test_good_values PASSED [ 41%] tests/test_traitlets.py::TestMinBoundCInt::test_allow_none PASSED [ 41%] tests/test_traitlets.py::TestMinBoundCInt::test_bad_values PASSED [ 41%] tests/test_traitlets.py::TestMinBoundCInt::test_default_value PASSED [ 42%] tests/test_traitlets.py::TestMinBoundCInt::test_good_values PASSED [ 42%] tests/test_traitlets.py::TestLong::test_allow_none PASSED [ 42%] tests/test_traitlets.py::TestLong::test_bad_values PASSED [ 42%] tests/test_traitlets.py::TestLong::test_default_value PASSED [ 42%] tests/test_traitlets.py::TestLong::test_good_values PASSED [ 42%] tests/test_traitlets.py::TestMinBoundLong::test_allow_none PASSED [ 43%] tests/test_traitlets.py::TestMinBoundLong::test_bad_values PASSED [ 43%] tests/test_traitlets.py::TestMinBoundLong::test_default_value PASSED [ 43%] tests/test_traitlets.py::TestMinBoundLong::test_good_values PASSED [ 43%] tests/test_traitlets.py::TestMaxBoundLong::test_allow_none PASSED [ 43%] tests/test_traitlets.py::TestMaxBoundLong::test_bad_values PASSED [ 43%] tests/test_traitlets.py::TestMaxBoundLong::test_default_value PASSED [ 44%] tests/test_traitlets.py::TestMaxBoundLong::test_good_values PASSED [ 44%] tests/test_traitlets.py::TestCLong::test_allow_none PASSED [ 44%] tests/test_traitlets.py::TestCLong::test_bad_values PASSED [ 44%] tests/test_traitlets.py::TestCLong::test_default_value PASSED [ 44%] tests/test_traitlets.py::TestCLong::test_good_values PASSED [ 44%] tests/test_traitlets.py::TestMaxBoundCLong::test_allow_none PASSED [ 45%] tests/test_traitlets.py::TestMaxBoundCLong::test_bad_values PASSED [ 45%] tests/test_traitlets.py::TestMaxBoundCLong::test_default_value PASSED [ 45%] tests/test_traitlets.py::TestMaxBoundCLong::test_good_values PASSED [ 45%] tests/test_traitlets.py::TestInteger::test_allow_none PASSED [ 45%] tests/test_traitlets.py::TestInteger::test_bad_values PASSED [ 45%] tests/test_traitlets.py::TestInteger::test_default_value PASSED [ 46%] tests/test_traitlets.py::TestInteger::test_good_values PASSED [ 46%] tests/test_traitlets.py::TestMinBoundInteger::test_allow_none PASSED [ 46%] tests/test_traitlets.py::TestMinBoundInteger::test_bad_values PASSED [ 46%] tests/test_traitlets.py::TestMinBoundInteger::test_default_value PASSED [ 46%] tests/test_traitlets.py::TestMinBoundInteger::test_good_values PASSED [ 47%] tests/test_traitlets.py::TestMaxBoundInteger::test_allow_none PASSED [ 47%] tests/test_traitlets.py::TestMaxBoundInteger::test_bad_values PASSED [ 47%] tests/test_traitlets.py::TestMaxBoundInteger::test_default_value PASSED [ 47%] tests/test_traitlets.py::TestMaxBoundInteger::test_good_values PASSED [ 47%] tests/test_traitlets.py::TestFloat::test_allow_none PASSED [ 47%] tests/test_traitlets.py::TestFloat::test_bad_values PASSED [ 48%] tests/test_traitlets.py::TestFloat::test_default_value PASSED [ 48%] tests/test_traitlets.py::TestFloat::test_good_values PASSED [ 48%] tests/test_traitlets.py::TestCFloat::test_allow_none PASSED [ 48%] tests/test_traitlets.py::TestCFloat::test_bad_values PASSED [ 48%] tests/test_traitlets.py::TestCFloat::test_default_value PASSED [ 48%] tests/test_traitlets.py::TestCFloat::test_good_values PASSED [ 49%] tests/test_traitlets.py::TestComplex::test_allow_none PASSED [ 49%] tests/test_traitlets.py::TestComplex::test_bad_values PASSED [ 49%] tests/test_traitlets.py::TestComplex::test_default_value PASSED [ 49%] tests/test_traitlets.py::TestComplex::test_good_values PASSED [ 49%] tests/test_traitlets.py::TestBytes::test_allow_none PASSED [ 49%] tests/test_traitlets.py::TestBytes::test_bad_values PASSED [ 50%] tests/test_traitlets.py::TestBytes::test_default_value PASSED [ 50%] tests/test_traitlets.py::TestBytes::test_good_values PASSED [ 50%] tests/test_traitlets.py::TestUnicode::test_allow_none PASSED [ 50%] tests/test_traitlets.py::TestUnicode::test_bad_values PASSED [ 50%] tests/test_traitlets.py::TestUnicode::test_default_value PASSED [ 50%] tests/test_traitlets.py::TestUnicode::test_good_values PASSED [ 51%] tests/test_traitlets.py::TestObjectName::test_allow_none PASSED [ 51%] tests/test_traitlets.py::TestObjectName::test_bad_values PASSED [ 51%] tests/test_traitlets.py::TestObjectName::test_default_value PASSED [ 51%] tests/test_traitlets.py::TestObjectName::test_good_values PASSED [ 51%] tests/test_traitlets.py::TestDottedObjectName::test_allow_none PASSED [ 51%] tests/test_traitlets.py::TestDottedObjectName::test_bad_values PASSED [ 52%] tests/test_traitlets.py::TestDottedObjectName::test_default_value PASSED [ 52%] tests/test_traitlets.py::TestDottedObjectName::test_good_values PASSED [ 52%] tests/test_traitlets.py::TestTCPAddress::test_allow_none PASSED [ 52%] tests/test_traitlets.py::TestTCPAddress::test_bad_values PASSED [ 52%] tests/test_traitlets.py::TestTCPAddress::test_default_value PASSED [ 52%] tests/test_traitlets.py::TestTCPAddress::test_good_values PASSED [ 53%] tests/test_traitlets.py::TestList::test_allow_none PASSED [ 53%] tests/test_traitlets.py::TestList::test_bad_values PASSED [ 53%] tests/test_traitlets.py::TestList::test_default_value PASSED [ 53%] tests/test_traitlets.py::TestList::test_good_values PASSED [ 53%] tests/test_traitlets.py::TestSet::test_allow_none PASSED [ 54%] tests/test_traitlets.py::TestSet::test_bad_values PASSED [ 54%] tests/test_traitlets.py::TestSet::test_default_value PASSED [ 54%] tests/test_traitlets.py::TestSet::test_good_values PASSED [ 54%] tests/test_traitlets.py::TestNoneInstanceList::test_allow_none PASSED [ 54%] tests/test_traitlets.py::TestNoneInstanceList::test_bad_values PASSED [ 54%] tests/test_traitlets.py::TestNoneInstanceList::test_default_value PASSED [ 55%] tests/test_traitlets.py::TestNoneInstanceList::test_good_values PASSED [ 55%] tests/test_traitlets.py::TestInstanceList::test_allow_none PASSED [ 55%] tests/test_traitlets.py::TestInstanceList::test_bad_values PASSED [ 55%] tests/test_traitlets.py::TestInstanceList::test_default_value PASSED [ 55%] tests/test_traitlets.py::TestInstanceList::test_good_values PASSED [ 55%] tests/test_traitlets.py::TestInstanceList::test_klass PASSED [ 56%] tests/test_traitlets.py::TestUnionListTrait::test_allow_none PASSED [ 56%] tests/test_traitlets.py::TestUnionListTrait::test_bad_values PASSED [ 56%] tests/test_traitlets.py::TestUnionListTrait::test_default_value PASSED [ 56%] tests/test_traitlets.py::TestUnionListTrait::test_good_values PASSED [ 56%] tests/test_traitlets.py::TestLenList::test_allow_none PASSED [ 56%] tests/test_traitlets.py::TestLenList::test_bad_values PASSED [ 57%] tests/test_traitlets.py::TestLenList::test_default_value PASSED [ 57%] tests/test_traitlets.py::TestLenList::test_good_values PASSED [ 57%] tests/test_traitlets.py::TestTupleTrait::test_allow_none PASSED [ 57%] tests/test_traitlets.py::TestTupleTrait::test_bad_values PASSED [ 57%] tests/test_traitlets.py::TestTupleTrait::test_default_value PASSED [ 57%] tests/test_traitlets.py::TestTupleTrait::test_good_values PASSED [ 58%] tests/test_traitlets.py::TestTupleTrait::test_invalid_args PASSED [ 58%] tests/test_traitlets.py::TestLooseTupleTrait::test_allow_none PASSED [ 58%] tests/test_traitlets.py::TestLooseTupleTrait::test_bad_values PASSED [ 58%] tests/test_traitlets.py::TestLooseTupleTrait::test_default_value PASSED [ 58%] tests/test_traitlets.py::TestLooseTupleTrait::test_good_values PASSED [ 58%] tests/test_traitlets.py::TestLooseTupleTrait::test_invalid_args PASSED [ 59%] tests/test_traitlets.py::TestMultiTuple::test_allow_none PASSED [ 59%] tests/test_traitlets.py::TestMultiTuple::test_bad_values PASSED [ 59%] tests/test_traitlets.py::TestMultiTuple::test_default_value PASSED [ 59%] tests/test_traitlets.py::TestMultiTuple::test_good_values PASSED [ 59%] tests/test_traitlets.py::test_allow_none_default_value[List] PASSED [ 59%] tests/test_traitlets.py::test_allow_none_default_value[Tuple] PASSED [ 60%] tests/test_traitlets.py::test_allow_none_default_value[Set] PASSED [ 60%] tests/test_traitlets.py::test_allow_none_default_value[Dict] PASSED [ 60%] tests/test_traitlets.py::test_allow_none_default_value[Int] PASSED [ 60%] tests/test_traitlets.py::test_allow_none_default_value[Unicode] PASSED [ 60%] tests/test_traitlets.py::test_default_value[List-default_value0] PASSED [ 60%] tests/test_traitlets.py::test_default_value[Tuple-default_value1] PASSED [ 61%] tests/test_traitlets.py::test_default_value[Set-default_value2] PASSED [ 61%] tests/test_traitlets.py::test_default_value[Dict-default_value3] PASSED [ 61%] tests/test_traitlets.py::test_default_value[Int-0] PASSED [ 61%] tests/test_traitlets.py::test_default_value[Unicode-] PASSED [ 61%] tests/test_traitlets.py::test_subclass_default_value[List-default_value0] PASSED [ 62%] tests/test_traitlets.py::test_subclass_default_value[Tuple-default_value1] PASSED [ 62%] tests/test_traitlets.py::test_subclass_default_value[Set-default_value2] PASSED [ 62%] tests/test_traitlets.py::TestCRegExp::test_allow_none PASSED [ 62%] tests/test_traitlets.py::TestCRegExp::test_bad_values PASSED [ 62%] tests/test_traitlets.py::TestCRegExp::test_default_value PASSED [ 62%] tests/test_traitlets.py::TestCRegExp::test_good_values PASSED [ 63%] tests/test_traitlets.py::test_dict_assignment PASSED [ 63%] tests/test_traitlets.py::TestInstanceUniformlyValueValidatedDict::test_allow_none PASSED [ 63%] tests/test_traitlets.py::TestInstanceUniformlyValueValidatedDict::test_bad_values PASSED [ 63%] tests/test_traitlets.py::TestInstanceUniformlyValueValidatedDict::test_default_value PASSED [ 63%] tests/test_traitlets.py::TestInstanceUniformlyValueValidatedDict::test_good_values PASSED [ 63%] tests/test_traitlets.py::TestInstanceNonuniformlyValueValidatedDict::test_allow_none PASSED [ 64%] tests/test_traitlets.py::TestInstanceNonuniformlyValueValidatedDict::test_bad_values PASSED [ 64%] tests/test_traitlets.py::TestInstanceNonuniformlyValueValidatedDict::test_default_value PASSED [ 64%] tests/test_traitlets.py::TestInstanceNonuniformlyValueValidatedDict::test_good_values PASSED [ 64%] tests/test_traitlets.py::TestInstanceKeyValidatedDict::test_allow_none PASSED [ 64%] tests/test_traitlets.py::TestInstanceKeyValidatedDict::test_bad_values PASSED [ 64%] tests/test_traitlets.py::TestInstanceKeyValidatedDict::test_default_value PASSED [ 65%] tests/test_traitlets.py::TestInstanceKeyValidatedDict::test_good_values PASSED [ 65%] tests/test_traitlets.py::TestInstanceFullyValidatedDict::test_allow_none PASSED [ 65%] tests/test_traitlets.py::TestInstanceFullyValidatedDict::test_bad_values PASSED [ 65%] tests/test_traitlets.py::TestInstanceFullyValidatedDict::test_default_value PASSED [ 65%] tests/test_traitlets.py::TestInstanceFullyValidatedDict::test_good_values PASSED [ 65%] tests/test_traitlets.py::test_dict_default_value PASSED [ 66%] tests/test_traitlets.py::TestValidationHook::test_multiple_validate PASSED [ 66%] tests/test_traitlets.py::TestValidationHook::test_parity_trait PASSED [ 66%] tests/test_traitlets.py::TestValidationHook::test_validate_used PASSED [ 66%] tests/test_traitlets.py::TestLink::test_callbacks PASSED [ 66%] tests/test_traitlets.py::TestLink::test_connect_same PASSED [ 66%] tests/test_traitlets.py::TestLink::test_link_broken_at_source PASSED [ 67%] tests/test_traitlets.py::TestLink::test_link_broken_at_target PASSED [ 67%] tests/test_traitlets.py::TestLink::test_link_different PASSED [ 67%] tests/test_traitlets.py::TestLink::test_tranform PASSED [ 67%] tests/test_traitlets.py::TestLink::test_unlink_link PASSED [ 67%] tests/test_traitlets.py::TestDirectionalLink::test_connect_same PASSED [ 67%] tests/test_traitlets.py::TestDirectionalLink::test_link_different PASSED [ 68%] tests/test_traitlets.py::TestDirectionalLink::test_tranform PASSED [ 68%] tests/test_traitlets.py::TestDirectionalLink::test_unlink_link PASSED [ 68%] tests/test_traitlets.py::test_pickle_hastraits PASSED [ 68%] tests/test_traitlets.py::test_hold_trait_notifications PASSED [ 68%] tests/test_traitlets.py::TestRollback::test_roll_back PASSED [ 68%] tests/test_traitlets.py::test_cache_modification PASSED [ 69%] tests/test_traitlets.py::test_notification_order PASSED [ 69%] tests/test_traitlets.py::TestForwardDeclaredInstanceTrait::test_allow_none PASSED [ 69%] tests/test_traitlets.py::TestForwardDeclaredInstanceTrait::test_bad_values PASSED [ 69%] tests/test_traitlets.py::TestForwardDeclaredInstanceTrait::test_default_value PASSED [ 69%] tests/test_traitlets.py::TestForwardDeclaredInstanceTrait::test_good_values PASSED [ 70%] tests/test_traitlets.py::TestForwardDeclaredTypeTrait::test_allow_none PASSED [ 70%] tests/test_traitlets.py::TestForwardDeclaredTypeTrait::test_bad_values PASSED [ 70%] tests/test_traitlets.py::TestForwardDeclaredTypeTrait::test_default_value PASSED [ 70%] tests/test_traitlets.py::TestForwardDeclaredTypeTrait::test_good_values PASSED [ 70%] tests/test_traitlets.py::TestForwardDeclaredInstanceList::test_allow_none PASSED [ 70%] tests/test_traitlets.py::TestForwardDeclaredInstanceList::test_bad_values PASSED [ 71%] tests/test_traitlets.py::TestForwardDeclaredInstanceList::test_default_value PASSED [ 71%] tests/test_traitlets.py::TestForwardDeclaredInstanceList::test_good_values PASSED [ 71%] tests/test_traitlets.py::TestForwardDeclaredInstanceList::test_klass PASSED [ 71%] tests/test_traitlets.py::TestForwardDeclaredTypeList::test_allow_none PASSED [ 71%] tests/test_traitlets.py::TestForwardDeclaredTypeList::test_bad_values PASSED [ 71%] tests/test_traitlets.py::TestForwardDeclaredTypeList::test_default_value PASSED [ 72%] tests/test_traitlets.py::TestForwardDeclaredTypeList::test_good_values PASSED [ 72%] tests/test_traitlets.py::TestForwardDeclaredTypeList::test_klass PASSED [ 72%] tests/test_traitlets.py::TestDynamicTraits::test_notify_all PASSED [ 72%] tests/test_traitlets.py::test_enum_no_default PASSED [ 72%] tests/test_traitlets.py::test_default_value_repr PASSED [ 72%] tests/test_traitlets.py::test_subclass_compat PASSED [ 73%] tests/test_traitlets.py::test_subclass_override_observer PASSED [ 73%] tests/test_traitlets.py::test_subclass_override_not_registered PASSED [ 73%] tests/test_traitlets.py::test_subclass_add_observer PASSED [ 73%] tests/test_traitlets.py::test_observe_iterables PASSED [ 73%] tests/test_traitlets.py::test_super_args PASSED [ 73%] tests/test_traitlets.py::test_super_bad_args PASSED [ 74%] tests/test_traitlets.py::test_default_mro PASSED [ 74%] tests/test_traitlets.py::test_cls_self_argument PASSED [ 74%] tests/test_traitlets.py::test_override_default PASSED [ 74%] tests/test_traitlets.py::test_override_default_decorator PASSED [ 74%] tests/test_traitlets.py::test_override_default_instance PASSED [ 74%] tests/test_traitlets.py::test_copy_HasTraits PASSED [ 75%] tests/test_traitlets.py::test_unicode_from_string[xyz-xyz] PASSED [ 75%] tests/test_traitlets.py::test_unicode_from_string[1-1] PASSED [ 75%] tests/test_traitlets.py::test_unicode_from_string["xx"-xx] PASSED [ 75%] tests/test_traitlets.py::test_unicode_from_string['abc'-abc] PASSED [ 75%] tests/test_traitlets.py::test_unicode_from_string[None-None] PASSED [ 75%] tests/test_traitlets.py::test_cunicode_from_string[xyz-xyz] PASSED [ 76%] tests/test_traitlets.py::test_cunicode_from_string[1-1] PASSED [ 76%] tests/test_traitlets.py::test_cunicode_from_string["xx"-xx] PASSED [ 76%] tests/test_traitlets.py::test_cunicode_from_string['abc'-abc] PASSED [ 76%] tests/test_traitlets.py::test_cunicode_from_string[None-None] PASSED [ 76%] tests/test_traitlets.py::test_bytes_from_string[xyz-xyz] PASSED [ 77%] tests/test_traitlets.py::test_bytes_from_string[1-1] PASSED [ 77%] tests/test_traitlets.py::test_bytes_from_string[b"xx"-xx] PASSED [ 77%] tests/test_traitlets.py::test_bytes_from_string[b'abc'-abc] PASSED [ 77%] tests/test_traitlets.py::test_bytes_from_string[None-None] PASSED [ 77%] tests/test_traitlets.py::test_cbytes_from_string[xyz-xyz] PASSED [ 77%] tests/test_traitlets.py::test_cbytes_from_string[1-1] PASSED [ 78%] tests/test_traitlets.py::test_cbytes_from_string[b"xx"-xx] PASSED [ 78%] tests/test_traitlets.py::test_cbytes_from_string[b'abc'-abc] PASSED [ 78%] tests/test_traitlets.py::test_cbytes_from_string[None-None] PASSED [ 78%] tests/test_traitlets.py::test_int_from_string[x-ValueError] PASSED [ 78%] tests/test_traitlets.py::test_int_from_string[1-1] PASSED [ 78%] tests/test_traitlets.py::test_int_from_string[123-123] PASSED [ 79%] tests/test_traitlets.py::test_int_from_string[2.0-ValueError] PASSED [ 79%] tests/test_traitlets.py::test_int_from_string[None-None] PASSED [ 79%] tests/test_traitlets.py::test_float_from_string[x-ValueError] PASSED [ 79%] tests/test_traitlets.py::test_float_from_string[1-1.0] PASSED [ 79%] tests/test_traitlets.py::test_float_from_string[123.5-123.5] PASSED [ 79%] tests/test_traitlets.py::test_float_from_string[2.5-2.5] PASSED [ 80%] tests/test_traitlets.py::test_float_from_string[None-None] PASSED [ 80%] tests/test_traitlets.py::test_complex_from_string[x-ValueError] PASSED [ 80%] tests/test_traitlets.py::test_complex_from_string[1-1.0] PASSED [ 80%] tests/test_traitlets.py::test_complex_from_string[123.5-123.5] PASSED [ 80%] tests/test_traitlets.py::test_complex_from_string[2.5-2.5] PASSED [ 80%] tests/test_traitlets.py::test_complex_from_string[1+2j-(1+2j)] PASSED [ 81%] tests/test_traitlets.py::test_complex_from_string[None-None] PASSED [ 81%] tests/test_traitlets.py::test_bool_from_string[true-True] PASSED [ 81%] tests/test_traitlets.py::test_bool_from_string[TRUE-True] PASSED [ 81%] tests/test_traitlets.py::test_bool_from_string[1-True] PASSED [ 81%] tests/test_traitlets.py::test_bool_from_string[0-False] PASSED [ 81%] tests/test_traitlets.py::test_bool_from_string[False-False] PASSED [ 82%] tests/test_traitlets.py::test_bool_from_string[false-False] PASSED [ 82%] tests/test_traitlets.py::test_bool_from_string[1.0-ValueError] PASSED [ 82%] tests/test_traitlets.py::test_bool_from_string[None-None] PASSED [ 82%] tests/test_traitlets.py::test_dict_from_string[{}-expected0] PASSED [ 82%] tests/test_traitlets.py::test_dict_from_string[1-TraitError] PASSED [ 82%] tests/test_traitlets.py::test_dict_from_string[{1: 2}-expected2] PASSED [ 83%] tests/test_traitlets.py::test_dict_from_string[{"key": "value"}-expected3] PASSED [ 83%] tests/test_traitlets.py::test_dict_from_string[x-TraitError] PASSED [ 83%] tests/test_traitlets.py::test_dict_from_string[None-None] PASSED [ 83%] tests/test_traitlets.py::test_list_from_string[[]-expected0] PASSED [ 83%] tests/test_traitlets.py::test_list_from_string[[1, 2, "x"]-expected1] PASSED [ 83%] tests/test_traitlets.py::test_list_from_string[s2-expected2] PASSED [ 84%] tests/test_traitlets.py::test_list_from_string[s3-None] PASSED [ 84%] tests/test_traitlets.py::test_list_items_from_string[s0-expected0-value_trait0] PASSED [ 84%] tests/test_traitlets.py::test_list_items_from_string[s1-ValueError-value_trait1] PASSED [ 84%] tests/test_traitlets.py::test_list_items_from_string[s2-expected2-value_trait2] PASSED [ 84%] tests/test_traitlets.py::test_list_items_from_string[s3-expected3-value_trait3] PASSED [ 85%] tests/test_traitlets.py::test_list_items_from_string[s4-expected4-value_trait4] PASSED [ 85%] tests/test_traitlets.py::test_set_from_string[[]-expected0] PASSED [ 85%] tests/test_traitlets.py::test_set_from_string[[1, 2, "x"]-expected1] PASSED [ 85%] tests/test_traitlets.py::test_set_from_string[{1, 2, "x"}-expected2] PASSED [ 85%] tests/test_traitlets.py::test_set_from_string[s3-expected3] PASSED [ 85%] tests/test_traitlets.py::test_set_from_string[s4-None] PASSED [ 86%] tests/test_traitlets.py::test_set_items_from_string[s0-expected0-value_trait0] PASSED [ 86%] tests/test_traitlets.py::test_set_items_from_string[s1-ValueError-value_trait1] PASSED [ 86%] tests/test_traitlets.py::test_set_items_from_string[s2-expected2-value_trait2] PASSED [ 86%] tests/test_traitlets.py::test_set_items_from_string[s3-expected3-value_trait3] PASSED [ 86%] tests/test_traitlets.py::test_tuple_from_string[[]-expected0] PASSED [ 86%] tests/test_traitlets.py::test_tuple_from_string[()-expected1] PASSED [ 87%] tests/test_traitlets.py::test_tuple_from_string[[1, 2, "x"]-expected2] PASSED [ 87%] tests/test_traitlets.py::test_tuple_from_string[(1, 2, "x")-expected3] PASSED [ 87%] tests/test_traitlets.py::test_tuple_from_string[s4-expected4] PASSED [ 87%] tests/test_traitlets.py::test_tuple_from_string[s5-None] PASSED [ 87%] tests/test_traitlets.py::test_tuple_items_from_string[s0-expected0-value_traits0] PASSED [ 87%] tests/test_traitlets.py::test_tuple_items_from_string[s1-ValueError-value_traits1] PASSED [ 88%] tests/test_traitlets.py::test_tuple_items_from_string[s2-expected2-value_traits2] PASSED [ 88%] tests/test_traitlets.py::test_tuple_items_from_string[s3-expected3-value_traits3] PASSED [ 88%] tests/test_traitlets.py::test_tuple_items_from_string[s4-expected4-value_traits4] PASSED [ 88%] tests/test_traitlets.py::test_object_from_string[x-x] PASSED [ 88%] tests/test_traitlets.py::test_object_from_string[mod.submod-mod.submod] PASSED [ 88%] tests/test_traitlets.py::test_object_from_string[not an identifier-TraitError] PASSED [ 89%] tests/test_traitlets.py::test_object_from_string[1-1] PASSED [ 89%] tests/test_traitlets.py::test_object_from_string[None-None] PASSED [ 89%] tests/test_traitlets.py::test_tcp_from_string[127.0.0.1:8000-expected0] PASSED [ 89%] tests/test_traitlets.py::test_tcp_from_string[host.tld:80-expected1] PASSED [ 89%] tests/test_traitlets.py::test_tcp_from_string[host:notaport-ValueError] PASSED [ 89%] tests/test_traitlets.py::test_tcp_from_string[127.0.0.1-ValueError] PASSED [ 90%] tests/test_traitlets.py::test_tcp_from_string[None-None] PASSED [ 90%] tests/test_traitlets.py::test_union_of_list_and_unicode_from_string[[]-expected0] PASSED [ 90%] tests/test_traitlets.py::test_union_of_list_and_unicode_from_string[{}-{}] PASSED [ 90%] tests/test_traitlets.py::test_union_of_int_and_float_from_string[1-1] PASSED [ 90%] tests/test_traitlets.py::test_union_of_int_and_float_from_string[1.5-1.5] PASSED [ 90%] tests/test_traitlets.py::test_union_of_list_and_dict_from_string[[]-expected0-False] PASSED [ 91%] tests/test_traitlets.py::test_union_of_list_and_dict_from_string[{}-expected1-False] PASSED [ 91%] tests/test_traitlets.py::test_union_of_list_and_dict_from_string[None-TraitError-False] PASSED [ 91%] tests/test_traitlets.py::test_union_of_list_and_dict_from_string[None-None-True] PASSED [ 91%] tests/test_traitlets.py::test_all_attribute PASSED [ 91%] tests/test_traitlets_docstring.py::test_handle_docstring PASSED [ 91%] tests/test_traitlets_enum.py::TestUseEnum::test_assign_all_enum_values PASSED [ 92%] tests/test_traitlets_enum.py::TestUseEnum::test_assign_bad_enum_value_name__raises_error PASSED [ 92%] tests/test_traitlets_enum.py::TestUseEnum::test_assign_bad_enum_value_number__raises_error PASSED [ 92%] tests/test_traitlets_enum.py::TestUseEnum::test_assign_bad_value_with_to_enum_or_none PASSED [ 92%] tests/test_traitlets_enum.py::TestUseEnum::test_assign_enum_name_1 PASSED [ 92%] tests/test_traitlets_enum.py::TestUseEnum::test_assign_enum_value PASSED [ 93%] tests/test_traitlets_enum.py::TestUseEnum::test_assign_enum_value__with_other_enum_raises_error PASSED [ 93%] tests/test_traitlets_enum.py::TestUseEnum::test_assign_enum_value_name PASSED [ 93%] tests/test_traitlets_enum.py::TestUseEnum::test_assign_enum_value_number PASSED [ 93%] tests/test_traitlets_enum.py::TestUseEnum::test_assign_enum_value_number_1 PASSED [ 93%] tests/test_traitlets_enum.py::TestUseEnum::test_assign_none_to_enum_or_none PASSED [ 93%] tests/test_traitlets_enum.py::TestUseEnum::test_assign_none_without_allow_none_resets_to_default_value PASSED [ 94%] tests/test_traitlets_enum.py::TestUseEnum::test_assign_scoped_enum_value_name PASSED [ 94%] tests/test_traitlets_enum.py::TestUseEnum::test_ctor_with_default_value_as_enum_value PASSED [ 94%] tests/test_traitlets_enum.py::TestUseEnum::test_ctor_with_default_value_none_and_allow_none PASSED [ 94%] tests/test_traitlets_enum.py::TestUseEnum::test_ctor_with_default_value_none_and_not_allow_none PASSED [ 94%] tests/test_traitlets_enum.py::TestUseEnum::test_ctor_without_default_value PASSED [ 94%] tests/test_traitlets_enum.py::TestUseEnum::test_info PASSED [ 95%] tests/test_traitlets_enum.py::TestFuzzyEnum::test_assign_other_raises PASSED [ 95%] tests/test_traitlets_enum.py::TestFuzzyEnum::test_ctor_with_default_value PASSED [ 95%] tests/test_traitlets_enum.py::TestFuzzyEnum::test_search_all_prefixes__ctor PASSED [ 95%] tests/test_traitlets_enum.py::TestFuzzyEnum::test_search_all_prefixes__overwrite PASSED [ 95%] tests/test_traitlets_enum.py::TestFuzzyEnum::test_search_substrings__ctor PASSED [ 95%] tests/test_traitlets_enum.py::TestFuzzyEnum::test_search_substrings__overwrite PASSED [ 96%] tests/test_typing.py::[mypy]mypy_decorator_typing PASSED [ 96%] tests/test_typing.py::[mypy]mypy_config_typing PASSED [ 96%] tests/test_typing.py::[mypy]mypy_union_typing PASSED [ 96%] tests/test_typing.py::[mypy]mypy_list_typing PASSED [ 96%] tests/test_typing.py::[mypy]mypy_type_typing PASSED [ 96%] tests/test_typing.py::[mypy]mypy_unicode_typing PASSED [ 97%] tests/test_typing.py::[mypy]mypy_enum_typing PASSED [ 97%] tests/test_typing.py::[mypy]mypy_set_typing PASSED [ 97%] tests/test_typing.py::[mypy]mypy_any_typing PASSED [ 97%] tests/test_typing.py::[mypy]mypy_bool_typing PASSED [ 97%] tests/test_typing.py::[mypy]mypy_int_typing PASSED [ 97%] tests/test_typing.py::[mypy]mypy_cint_typing PASSED [ 98%] tests/test_typing.py::[mypy]mypy_tcp_typing PASSED [ 98%] tests/test_typing.py::[mypy]mypy_instance_typing PASSED [ 98%] tests/utils/test_bunch.py::test_bunch PASSED [ 98%] tests/utils/test_bunch.py::test_bunch_dir PASSED [ 98%] tests/utils/test_decorators.py::TestExpandSignature::test_duplicate_init PASSED [ 98%] tests/utils/test_decorators.py::TestExpandSignature::test_full_init PASSED [ 99%] tests/utils/test_decorators.py::TestExpandSignature::test_no_init PASSED [ 99%] tests/utils/test_decorators.py::TestExpandSignature::test_no_kwargs PASSED [ 99%] tests/utils/test_decorators.py::TestExpandSignature::test_partial_init PASSED [ 99%] tests/utils/test_importstring.py::TestImportItem::test_bad_input PASSED [ 99%] tests/utils/test_importstring.py::TestImportItem::test_import_unicode PASSED [100%] =================================== FAILURES =================================== ___________________ TestArgcomplete.test_complete_simple_app ___________________ self = argcomplete_on = None def test_complete_simple_app(self, argcomplete_on): app = ArgcompleteApp() expected = [ "--help", "--debug", "--show-config", "--show-config-json", "--log-level", "--Application.", "--ArgcompleteApp.", ] > assert set(self.run_completer(app, "app --")) == set(expected) app = argcomplete_on = None expected = ['--help', '--debug', '--show-config', '--show-config-json', '--log-level', '--Application.', ...] self = tests/config/test_argcomplete.py:145: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ tests/config/test_argcomplete.py:127: in run_completer app.initialize() app = cm = command = 'app --' kwargs = {} point = '6' self = strio = <_io.StringIO object at 0x3fb14a0a00> traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = () kwargs = {} method = traitlets/config/application.py:465: in initialize self.parse_command_line(argv) argv = None self = traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = (None,) kwargs = {} method = traitlets/config/application.py:881: in parse_command_line self.cli_config = deepcopy(loader.load_config()) aliases = {'log-level': 'ArgcompleteApp.log_level'} argv = ['-v', '-k', 'not mypy_dict_typing'] classes = [, ] flags = {'debug': ({'ArgcompleteApp': {'log_level': 10}}, 'Set log-level to debug, for the most verbose logging.'), 'show-conf...w-config-json': ({'ArgcompleteApp': {'show_config_json': True}}, "Show the application's configuration (json format)")} interpreted_argv = ['-v', '-k', 'not mypy_dict_typing'] loader = self = traitlets/config/loader.py:894: in load_config self._argcomplete(self.classes, self.subcommands) aliases = None argv = ['-v', '-k', 'not mypy_dict_typing'] classes = None flags = self = traitlets/config/loader.py:1139: in _argcomplete finder(self.parser, **getattr(self, "_argcomplete_kwargs", {})) argcomplete = argcomplete_config = classes = [, ] finder = self = subcommands = {} /usr/lib/python3.13/site-packages/argcomplete/finders.py:172: in __call__ completions = self._get_completions(comp_words, cword_prefix, cword_prequote, last_wordbreak_pos) always_complete_options = True append_space = None argument_parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) comp_line = 'app --' comp_point = 6 comp_words = ['app'] cword_prefix = '--' cword_prequote = '' cword_suffix = '' default_completer = dfs = None exclude = None exit_method = > ifs = '\x0b' last_wordbreak_pos = None output_stream = <_io.StringIO object at 0x3fb14a0a00> print_suppressed = False self = start = 0 validator = None traitlets/config/argcomplete_config.py:191: in _get_completions completions = super()._get_completions(comp_words, cword_prefix, *args) # type:ignore[no-untyped-call] __class__ = args = ('', None) comp_words = ['app'] cword_prefix = '--' is_option = True matched_completions = [(, '--Application.'), (, '--ArgcompleteApp.')] prefix_chars = '-' self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:221: in _get_completions completions = self.collect_completions(active_parsers, parsed_args, cword_prefix) active_parsers = [MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True)] comp_words = ['app'] cword_prefix = '--' cword_prequote = '' last_wordbreak_pos = None parsed_args = Namespace(_flags=[]) self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:438: in collect_completions completions += self._get_option_completions(active_parser, cword_prefix) active_parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) active_parsers = [MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True)] completions = [] cword_prefix = '--' parsed_args = Namespace(_flags=[]) self = traitlets/config/argcomplete_config.py:209: in _get_option_completions completions = super()._get_option_completions(parser, cword_prefix) # type:ignore[no-untyped-call] __class__ = cword_prefix = '--' parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:324: in _get_option_completions if not self._action_allowed(action, parser): action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) completer = None cword_prefix = '--' option_completions = [] option_string = '--log-level' parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) self = _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) @staticmethod def _action_allowed(action, parser): # Logic adapted from take_action in ArgumentParser._parse_known_args # (members are saved by vendor._argparse.IntrospectiveArgumentParser) > for conflict_action in parser._action_conflicts.get(action, []): E AttributeError: 'MonkeyPatchedIntrospectiveArgumentParser' object has no attribute '_action_conflicts' action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) /usr/lib/python3.13/site-packages/argcomplete/finders.py:334: AttributeError _______________ TestArgcomplete.test_complete_custom_completers ________________ self = argcomplete_on = None def test_complete_custom_completers(self, argcomplete_on): app = ArgcompleteApp() # test pre-defined completers for Bool/Enum > assert set(self.run_completer(app, "app --Application.log_level=")) > {"DEBUG", "INFO"} app = argcomplete_on = None self = tests/config/test_argcomplete.py:157: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ tests/config/test_argcomplete.py:127: in run_completer app.initialize() app = cm = command = 'app --Application.log_level=' kwargs = {} point = '28' self = strio = <_io.StringIO object at 0x3fb14a2800> traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = () kwargs = {} method = traitlets/config/application.py:465: in initialize self.parse_command_line(argv) argv = None self = traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = (None,) kwargs = {} method = traitlets/config/application.py:881: in parse_command_line self.cli_config = deepcopy(loader.load_config()) aliases = {'log-level': 'ArgcompleteApp.log_level'} argv = ['-v', '-k', 'not mypy_dict_typing'] classes = [, ] flags = {'debug': ({'ArgcompleteApp': {'log_level': 10}}, 'Set log-level to debug, for the most verbose logging.'), 'show-conf...w-config-json': ({'ArgcompleteApp': {'show_config_json': True}}, "Show the application's configuration (json format)")} interpreted_argv = ['-v', '-k', 'not mypy_dict_typing'] loader = self = traitlets/config/loader.py:894: in load_config self._argcomplete(self.classes, self.subcommands) aliases = None argv = ['-v', '-k', 'not mypy_dict_typing'] classes = None flags = self = traitlets/config/loader.py:1139: in _argcomplete finder(self.parser, **getattr(self, "_argcomplete_kwargs", {})) argcomplete = argcomplete_config = classes = [, ] finder = self = subcommands = {} /usr/lib/python3.13/site-packages/argcomplete/finders.py:172: in __call__ completions = self._get_completions(comp_words, cword_prefix, cword_prequote, last_wordbreak_pos) always_complete_options = True append_space = None argument_parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) comp_line = 'app --Application.log_level=' comp_point = 28 comp_words = ['app', '--Application.log_level'] cword_prefix = '--Application.log_level=' cword_prequote = '' cword_suffix = '' default_completer = dfs = None exclude = None exit_method = > ifs = '\x0b' last_wordbreak_pos = 23 output_stream = <_io.StringIO object at 0x3fb14a2800> print_suppressed = False self = start = 0 validator = None traitlets/config/argcomplete_config.py:191: in _get_completions completions = super()._get_completions(comp_words, cword_prefix, *args) # type:ignore[no-untyped-call] __class__ = args = ('', 23) comp_words = ['app', '--Application.log_level'] cword_prefix = '--Application.log_level=' is_option = True matched_cls = matched_completions = [(, '--Application.')] prefix_chars = '-' self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:221: in _get_completions completions = self.collect_completions(active_parsers, parsed_args, cword_prefix) active_parsers = [MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True)] comp_words = ['app', '--Application.log_level'] cword_prefix = '--Application.log_level=' cword_prequote = '' last_wordbreak_pos = 23 parsed_args = Namespace(_flags=[]) self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:438: in collect_completions completions += self._get_option_completions(active_parser, cword_prefix) active_parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) active_parsers = [MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True)] completions = [] cword_prefix = '--Application.log_level=' parsed_args = Namespace(_flags=[]) self = traitlets/config/argcomplete_config.py:209: in _get_option_completions completions = super()._get_option_completions(parser, cword_prefix) # type:ignore[no-untyped-call] __class__ = cword_prefix = '--Application.log_level=' parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:324: in _get_option_completions if not self._action_allowed(action, parser): action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) completer = None cword_prefix = '--Application.log_level=' option_completions = [] option_string = '--Application.show_config_json' parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) self = _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) @staticmethod def _action_allowed(action, parser): # Logic adapted from take_action in ArgumentParser._parse_known_args # (members are saved by vendor._argparse.IntrospectiveArgumentParser) > for conflict_action in parser._action_conflicts.get(action, []): E AttributeError: 'MonkeyPatchedIntrospectiveArgumentParser' object has no attribute '_action_conflicts' action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) /usr/lib/python3.13/site-packages/argcomplete/finders.py:334: AttributeError __________________ TestArgcomplete.test_complete_subcommands ___________________ self = argcomplete_on = None def test_complete_subcommands(self, argcomplete_on): app = MainApp() > assert set(self.run_completer(app, "app ")) >= {"subapp1", "subapp2"} app = argcomplete_on = None self = tests/config/test_argcomplete.py:189: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ tests/config/test_argcomplete.py:127: in run_completer app.initialize() app = cm = command = 'app ' kwargs = {} point = '4' self = strio = <_io.StringIO object at 0x3fb14a2440> traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = () kwargs = {} method = traitlets/config/application.py:465: in initialize self.parse_command_line(argv) argv = None self = traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = (None,) kwargs = {} method = traitlets/config/application.py:881: in parse_command_line self.cli_config = deepcopy(loader.load_config()) aliases = {'log-level': 'MainApp.log_level'} argv = [] classes = [, , ] flags = {'debug': ({'MainApp': {'log_level': 10}}, 'Set log-level to debug, for the most verbose logging.'), 'show-config': ({...), 'show-config-json': ({'MainApp': {'show_config_json': True}}, "Show the application's configuration (json format)")} interpreted_argv = [] loader = self = traitlets/config/loader.py:894: in load_config self._argcomplete(self.classes, self.subcommands) aliases = None argv = [] classes = None flags = self = traitlets/config/loader.py:1139: in _argcomplete finder(self.parser, **getattr(self, "_argcomplete_kwargs", {})) argcomplete = argcomplete_config = classes = [, , ] finder = self = subcommands = {'subapp1': (, 'First subapp'), 'subapp2': (>, 'Second subapp')} /usr/lib/python3.13/site-packages/argcomplete/finders.py:172: in __call__ completions = self._get_completions(comp_words, cword_prefix, cword_prequote, last_wordbreak_pos) always_complete_options = True append_space = None argument_parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) comp_line = 'app ' comp_point = 4 comp_words = ['app'] cword_prefix = '' cword_prequote = '' cword_suffix = '' default_completer = dfs = None exclude = None exit_method = > ifs = '\x0b' last_wordbreak_pos = None output_stream = <_io.StringIO object at 0x3fb14a2440> print_suppressed = False self = start = 0 validator = None traitlets/config/argcomplete_config.py:191: in _get_completions completions = super()._get_completions(comp_words, cword_prefix, *args) # type:ignore[no-untyped-call] __class__ = args = ('', None) comp_words = ['app'] cword_prefix = '' is_option = False prefix_chars = '-' self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:221: in _get_completions completions = self.collect_completions(active_parsers, parsed_args, cword_prefix) active_parsers = [MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True)] comp_words = ['app'] cword_prefix = '' cword_prequote = '' last_wordbreak_pos = None parsed_args = Namespace(_flags=[]) self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:438: in collect_completions completions += self._get_option_completions(active_parser, cword_prefix) active_parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) active_parsers = [MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True)] completions = [] cword_prefix = '' parsed_args = Namespace(_flags=[]) self = traitlets/config/argcomplete_config.py:209: in _get_option_completions completions = super()._get_option_completions(parser, cword_prefix) # type:ignore[no-untyped-call] __class__ = cword_prefix = '' parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:324: in _get_option_completions if not self._action_allowed(action, parser): action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) completer = None cword_prefix = '' option_completions = [] option_string = '--log-level' parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) self = _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) @staticmethod def _action_allowed(action, parser): # Logic adapted from take_action in ArgumentParser._parse_known_args # (members are saved by vendor._argparse.IntrospectiveArgumentParser) > for conflict_action in parser._action_conflicts.get(action, []): E AttributeError: 'MonkeyPatchedIntrospectiveArgumentParser' object has no attribute '_action_conflicts' action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) /usr/lib/python3.13/site-packages/argcomplete/finders.py:334: AttributeError ______________ TestArgcomplete.test_complete_subcommands_subapp1 _______________ self = argcomplete_on = None def test_complete_subcommands_subapp1(self, argcomplete_on): # subcommand handling modifies _ARGCOMPLETE env var global state, so # only can test one completion per unit test app = MainApp() try: > assert set(self.run_completer(app, "app subapp1 --Sub")) > { "--SubApp1.show_config", "--SubApp1.log_level", "--SubApp1.log_format", } app = argcomplete_on = None self = tests/config/test_argcomplete.py:198: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ tests/config/test_argcomplete.py:127: in run_completer app.initialize() app = cm = command = 'app subapp1 --Sub' kwargs = {} point = '17' self = strio = <_io.StringIO object at 0x3fb14a3f40> traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = () kwargs = {} method = traitlets/config/application.py:465: in initialize self.parse_command_line(argv) argv = None self = traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = (None,) kwargs = {} method = traitlets/config/application.py:857: in parse_command_line return self.initialize_subcommand(subc, subargv) argv = ['subapp1'] self = subargv = [] subc = 'subapp1' traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = ('subapp1', []) kwargs = {} method = traitlets/config/application.py:721: in initialize_subcommand self.subapp.initialize(argv) _ = 'First subapp' argv = [] self = subapp = subc = 'subapp1' val = (, 'First subapp') traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = ([],) kwargs = {} method = traitlets/config/application.py:465: in initialize self.parse_command_line(argv) argv = [] self = traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = ([],) kwargs = {} method = traitlets/config/application.py:881: in parse_command_line self.cli_config = deepcopy(loader.load_config()) aliases = {'log-level': 'SubApp1.log_level'} argv = [] classes = [, , ] flags = {'debug': ({'SubApp1': {'log_level': 10}}, 'Set log-level to debug, for the most verbose logging.'), 'show-config': ({...), 'show-config-json': ({'SubApp1': {'show_config_json': True}}, "Show the application's configuration (json format)")} interpreted_argv = [] loader = self = traitlets/config/loader.py:894: in load_config self._argcomplete(self.classes, self.subcommands) aliases = None argv = [] classes = None flags = self = traitlets/config/loader.py:1139: in _argcomplete finder(self.parser, **getattr(self, "_argcomplete_kwargs", {})) argcomplete = argcomplete_config = classes = [, , ] finder = self = subcommands = {} /usr/lib/python3.13/site-packages/argcomplete/finders.py:172: in __call__ completions = self._get_completions(comp_words, cword_prefix, cword_prequote, last_wordbreak_pos) always_complete_options = True append_space = None argument_parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) comp_line = 'app subapp1 --Sub' comp_point = 17 comp_words = ['subapp1'] cword_prefix = '--Sub' cword_prequote = '' cword_suffix = '' default_completer = dfs = None exclude = None exit_method = > ifs = '\x0b' last_wordbreak_pos = None output_stream = <_io.StringIO object at 0x3fb14a3f40> print_suppressed = False self = start = 1 validator = None traitlets/config/argcomplete_config.py:191: in _get_completions completions = super()._get_completions(comp_words, cword_prefix, *args) # type:ignore[no-untyped-call] __class__ = args = ('', None) comp_words = ['subapp1'] cword_prefix = '--Sub' is_option = True matched_cls = matched_completions = [(, '--SubApp1.')] prefix_chars = '-' self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:221: in _get_completions completions = self.collect_completions(active_parsers, parsed_args, cword_prefix) active_parsers = [MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True)] comp_words = ['subapp1'] cword_prefix = '--Sub' cword_prequote = '' last_wordbreak_pos = None parsed_args = Namespace(_flags=[]) self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:438: in collect_completions completions += self._get_option_completions(active_parser, cword_prefix) active_parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) active_parsers = [MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True)] completions = [] cword_prefix = '--Sub' parsed_args = Namespace(_flags=[]) self = traitlets/config/argcomplete_config.py:209: in _get_option_completions completions = super()._get_option_completions(parser, cword_prefix) # type:ignore[no-untyped-call] __class__ = cword_prefix = '--Sub' parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:324: in _get_option_completions if not self._action_allowed(action, parser): action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) completer = None cword_prefix = '--Sub' option_completions = [] option_string = '--SubApp1.show_config_json' parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) self = _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) @staticmethod def _action_allowed(action, parser): # Logic adapted from take_action in ArgumentParser._parse_known_args # (members are saved by vendor._argparse.IntrospectiveArgumentParser) > for conflict_action in parser._action_conflicts.get(action, []): E AttributeError: 'MonkeyPatchedIntrospectiveArgumentParser' object has no attribute '_action_conflicts' action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) /usr/lib/python3.13/site-packages/argcomplete/finders.py:334: AttributeError ______________ TestArgcomplete.test_complete_subcommands_subapp2 _______________ self = argcomplete_on = None def test_complete_subcommands_subapp2(self, argcomplete_on): app = MainApp() try: > assert set(self.run_completer(app, "app subapp2 --")) > { "--Application.", "--SubApp2.", } app = argcomplete_on = None self = tests/config/test_argcomplete.py:209: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ tests/config/test_argcomplete.py:127: in run_completer app.initialize() app = cm = command = 'app subapp2 --' kwargs = {} point = '14' self = strio = <_io.StringIO object at 0x3fb14a3940> traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = () kwargs = {} method = traitlets/config/application.py:465: in initialize self.parse_command_line(argv) argv = None self = traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = (None,) kwargs = {} method = traitlets/config/application.py:857: in parse_command_line return self.initialize_subcommand(subc, subargv) argv = ['subapp2'] self = subargv = [] subc = 'subapp2' traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = ('subapp2', []) kwargs = {} method = traitlets/config/application.py:721: in initialize_subcommand self.subapp.initialize(argv) _ = 'Second subapp' argv = [] self = subapp = > subc = 'subapp2' val = (>, 'Second subapp') traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = ([],) kwargs = {} method = traitlets/config/application.py:465: in initialize self.parse_command_line(argv) argv = [] self = traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = ([],) kwargs = {} method = traitlets/config/application.py:881: in parse_command_line self.cli_config = deepcopy(loader.load_config()) aliases = {'log-level': 'SubApp2.log_level'} argv = [] classes = [, , ] flags = {'debug': ({'SubApp2': {'log_level': 10}}, 'Set log-level to debug, for the most verbose logging.'), 'show-config': ({...), 'show-config-json': ({'SubApp2': {'show_config_json': True}}, "Show the application's configuration (json format)")} interpreted_argv = [] loader = self = traitlets/config/loader.py:894: in load_config self._argcomplete(self.classes, self.subcommands) aliases = None argv = [] classes = None flags = self = traitlets/config/loader.py:1139: in _argcomplete finder(self.parser, **getattr(self, "_argcomplete_kwargs", {})) argcomplete = argcomplete_config = classes = [, , ] finder = self = subcommands = {} /usr/lib/python3.13/site-packages/argcomplete/finders.py:172: in __call__ completions = self._get_completions(comp_words, cword_prefix, cword_prequote, last_wordbreak_pos) always_complete_options = True append_space = None argument_parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) comp_line = 'app subapp2 --' comp_point = 14 comp_words = ['subapp2'] cword_prefix = '--' cword_prequote = '' cword_suffix = '' default_completer = dfs = None exclude = None exit_method = > ifs = '\x0b' last_wordbreak_pos = None output_stream = <_io.StringIO object at 0x3fb14a3940> print_suppressed = False self = start = 1 validator = None traitlets/config/argcomplete_config.py:191: in _get_completions completions = super()._get_completions(comp_words, cword_prefix, *args) # type:ignore[no-untyped-call] __class__ = args = ('', None) comp_words = ['subapp2'] cword_prefix = '--' is_option = True matched_completions = [(, '--Application.'), (, '--ArgcompleteApp.'), (, '--SubApp2.')] prefix_chars = '-' self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:221: in _get_completions completions = self.collect_completions(active_parsers, parsed_args, cword_prefix) active_parsers = [MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True)] comp_words = ['subapp2'] cword_prefix = '--' cword_prequote = '' last_wordbreak_pos = None parsed_args = Namespace(_flags=[]) self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:438: in collect_completions completions += self._get_option_completions(active_parser, cword_prefix) active_parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) active_parsers = [MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True)] completions = [] cword_prefix = '--' parsed_args = Namespace(_flags=[]) self = traitlets/config/argcomplete_config.py:209: in _get_option_completions completions = super()._get_option_completions(parser, cword_prefix) # type:ignore[no-untyped-call] __class__ = cword_prefix = '--' parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:324: in _get_option_completions if not self._action_allowed(action, parser): action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) completer = None cword_prefix = '--' option_completions = [] option_string = '--log-level' parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) self = _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) @staticmethod def _action_allowed(action, parser): # Logic adapted from take_action in ArgumentParser._parse_known_args # (members are saved by vendor._argparse.IntrospectiveArgumentParser) > for conflict_action in parser._action_conflicts.get(action, []): E AttributeError: 'MonkeyPatchedIntrospectiveArgumentParser' object has no attribute '_action_conflicts' action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) /usr/lib/python3.13/site-packages/argcomplete/finders.py:334: AttributeError ________________ TestArgcomplete.test_complete_subcommands_main ________________ self = argcomplete_on = None def test_complete_subcommands_main(self, argcomplete_on): app = MainApp() > completions = set(self.run_completer(app, "app --")) app = argcomplete_on = None self = tests/config/test_argcomplete.py:218: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ tests/config/test_argcomplete.py:127: in run_completer app.initialize() app = cm = command = 'app --' kwargs = {} point = '6' self = strio = <_io.StringIO object at 0x3fb14a2440> traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = () kwargs = {} method = traitlets/config/application.py:465: in initialize self.parse_command_line(argv) argv = None self = traitlets/config/application.py:118: in inner return method(app, *args, **kwargs) app = args = (None,) kwargs = {} method = traitlets/config/application.py:881: in parse_command_line self.cli_config = deepcopy(loader.load_config()) aliases = {'log-level': 'MainApp.log_level'} argv = [] classes = [, , ] flags = {'debug': ({'MainApp': {'log_level': 10}}, 'Set log-level to debug, for the most verbose logging.'), 'show-config': ({...), 'show-config-json': ({'MainApp': {'show_config_json': True}}, "Show the application's configuration (json format)")} interpreted_argv = [] loader = self = traitlets/config/loader.py:894: in load_config self._argcomplete(self.classes, self.subcommands) aliases = None argv = [] classes = None flags = self = traitlets/config/loader.py:1139: in _argcomplete finder(self.parser, **getattr(self, "_argcomplete_kwargs", {})) argcomplete = argcomplete_config = classes = [, , ] finder = self = subcommands = {'subapp1': (, 'First subapp'), 'subapp2': (>, 'Second subapp')} /usr/lib/python3.13/site-packages/argcomplete/finders.py:172: in __call__ completions = self._get_completions(comp_words, cword_prefix, cword_prequote, last_wordbreak_pos) always_complete_options = True append_space = None argument_parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) comp_line = 'app --' comp_point = 6 comp_words = ['app'] cword_prefix = '--' cword_prequote = '' cword_suffix = '' default_completer = dfs = None exclude = None exit_method = > ifs = '\x0b' last_wordbreak_pos = None output_stream = <_io.StringIO object at 0x3fb14a2440> print_suppressed = False self = start = 0 validator = None traitlets/config/argcomplete_config.py:191: in _get_completions completions = super()._get_completions(comp_words, cword_prefix, *args) # type:ignore[no-untyped-call] __class__ = args = ('', None) comp_words = ['app'] cword_prefix = '--' is_option = True matched_completions = [(, '--Application.'), (, '--ArgcompleteApp.'), (, '--MainApp.')] prefix_chars = '-' self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:221: in _get_completions completions = self.collect_completions(active_parsers, parsed_args, cword_prefix) active_parsers = [MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True)] comp_words = ['app'] cword_prefix = '--' cword_prequote = '' last_wordbreak_pos = None parsed_args = Namespace(_flags=[]) self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:438: in collect_completions completions += self._get_option_completions(active_parser, cword_prefix) active_parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) active_parsers = [MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True)] completions = [] cword_prefix = '--' parsed_args = Namespace(_flags=[]) self = traitlets/config/argcomplete_config.py:209: in _get_option_completions completions = super()._get_option_completions(parser, cword_prefix) # type:ignore[no-untyped-call] __class__ = cword_prefix = '--' parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) self = /usr/lib/python3.13/site-packages/argcomplete/finders.py:324: in _get_option_completions if not self._action_allowed(action, parser): action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) completer = None cword_prefix = '--' option_completions = [] option_string = '--log-level' parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) self = _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) @staticmethod def _action_allowed(action, parser): # Logic adapted from take_action in ArgumentParser._parse_known_args # (members are saved by vendor._argparse.IntrospectiveArgumentParser) > for conflict_action in parser._action_conflicts.get(action, []): E AttributeError: 'MonkeyPatchedIntrospectiveArgumentParser' object has no attribute '_action_conflicts' action = IntrospectAction(option_strings=['-h', '--help'], dest='help', nargs=0, const=None, default='==SUPPRESS==', type=None, choices=None, required=False, help='show this help message and exit', metavar=None, deprecated=False) parser = MonkeyPatchedIntrospectiveArgumentParser(prog='__main__.py', usage=None, description=None, formatter_class=, conflict_handler='error', add_help=True) /usr/lib/python3.13/site-packages/argcomplete/finders.py:334: AttributeError =============================== warnings summary =============================== tests/_warnings.py::tests._warnings.all_warnings :2: RuntimeWarning: bar -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html ============================= slowest 10 durations ============================= 167.90s call tests/test_typing.py::[mypy]mypy_decorator_typing 1.17s call tests/config/test_application.py::test_help_output 1.13s call tests/config/test_application.py::test_show_config_json_cli 1.12s call tests/config/test_application.py::test_show_config_cli 1.11s call tests/config/test_application.py::test_help_all_output 0.05s call tests/config/test_configurable.py::TestConfigurable::test_override2 0.04s call tests/test_traitlets.py::TestTraitType::test_deprecated_method_warnings 0.04s call tests/test_traitlets.py::TestTraitType::test_deprecated_metadata_access 0.03s call tests/config/test_application.py::TestApplication::test_flags 0.03s call tests/config/test_application.py::TestApplication::test_aliases =========================== short test summary info ============================ SKIPPED [1] ../../../../usr/lib/python3.13/site-packages/_pytest/doctest.py:458: all tests skipped by +SKIP option FAILED tests/config/test_argcomplete.py::TestArgcomplete::test_complete_simple_app - AttributeError: 'MonkeyPatchedIntrospectiveArgumentParser' object has no at... FAILED tests/config/test_argcomplete.py::TestArgcomplete::test_complete_custom_completers - AttributeError: 'MonkeyPatchedIntrospectiveArgumentParser' object has no at... FAILED tests/config/test_argcomplete.py::TestArgcomplete::test_complete_subcommands - AttributeError: 'MonkeyPatchedIntrospectiveArgumentParser' object has no at... FAILED tests/config/test_argcomplete.py::TestArgcomplete::test_complete_subcommands_subapp1 - AttributeError: 'MonkeyPatchedIntrospectiveArgumentParser' object has no at... FAILED tests/config/test_argcomplete.py::TestArgcomplete::test_complete_subcommands_subapp2 - AttributeError: 'MonkeyPatchedIntrospectiveArgumentParser' object has no at... FAILED tests/config/test_argcomplete.py::TestArgcomplete::test_complete_subcommands_main - AttributeError: 'MonkeyPatchedIntrospectiveArgumentParser' object has no at... = 6 failed, 580 passed, 1 skipped, 1 deselected, 1 warning in 184.64s (0:03:04) = ==> ERROR: A failure occurred in check().  Aborting... ==> ERROR: Build failed, check /var/lib/archbuild/extra-riscv64/root3/build [?25h[?25hreceiving incremental file list python-traitlets-5.14.3-3-riscv64-build.log python-traitlets-5.14.3-3-riscv64-check.log sent 62 bytes received 10,373 bytes 20,870.00 bytes/sec total size is 129,278 speedup is 12.39