mirror of
				https://github.com/gradle/gradle-build-action.git
				synced 2025-10-25 12:09:31 +08:00 
			
		
		
		
	Compare commits
	
		
			785 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 3fbe033aaa | ||
|  | 0842a550d1 | ||
|  | 3b959539de | ||
|  | c267ad1fcb | ||
|  | fab7664a6a | ||
|  | a5b34e05de | ||
|  | a4b5212a9d | ||
|  | ad59e53998 | ||
|  | c224a16628 | ||
|  | ec783957f3 | ||
|  | 6b08b7d2b5 | ||
|  | fd32ae9081 | ||
|  | 8545e5aed7 | ||
|  | d92395703c | ||
|  | af916fa394 | ||
|  | 3d9f1fdd28 | ||
|  | 387c8bc97a | ||
|  | 31c4390f56 | ||
|  | 05b706c1e7 | ||
|  | b9a8697f71 | ||
|  | 394498f89f | ||
|  | c295a4096e | ||
|  | 74a56b60ce | ||
|  | aeb3e0fcd7 | ||
|  | 8a17724c3e | ||
|  | 76ed799d26 | ||
|  | dd8493d4f2 | ||
|  | 66061a0409 | ||
|  | 1a66a38284 | ||
|  | bf471096d3 | ||
|  | e8a7e1402f | ||
|  | 0e3ce37aac | ||
|  | 8d2472536e | ||
|  | 832889a6eb | ||
|  | 61f7cb1f75 | ||
|  | e440eaf750 | ||
|  | 570f67893a | ||
|  | 402732a560 | ||
|  | a6f860c57c | ||
|  | 657d21ac23 | ||
|  | 688380a438 | ||
|  | cce16c4e36 | ||
|  | b50380a07d | ||
|  | aa2854e6ea | ||
|  | 471bcda20a | ||
|  | 91306f47ea | ||
|  | 65c865a172 | ||
|  | 1761dcff13 | ||
|  | 356abb47e7 | ||
|  | fc9e8feb61 | ||
|  | 0e4b100458 | ||
|  | 82bc72e1e7 | ||
|  | 8be955ee80 | ||
|  | 531cc21aeb | ||
|  | 164712adb1 | ||
|  | 535b494721 | ||
|  | d6110ecac2 | ||
|  | cc60593845 | ||
|  | fb549a8417 | ||
|  | c64fe31590 | ||
|  | 6e56b59601 | ||
|  | c77676cc69 | ||
|  | f39ea084f9 | ||
|  | 27a2f232f6 | ||
|  | b4c3d51488 | ||
|  | 99ec710825 | ||
|  | d427a379a8 | ||
|  | ed5f3e6998 | ||
|  | 11c5fa73ac | ||
|  | 3e3c80e9b4 | ||
|  | 25ec178747 | ||
|  | 3cc0a8f6bb | ||
|  | 915123c493 | ||
|  | ef638c00fd | ||
|  | 05257c7a5f | ||
|  | c1a6f51e61 | ||
|  | 865815e1b6 | ||
|  | eb22e65b5b | ||
|  | 8a386f6915 | ||
|  | 84bc83e639 | ||
|  | cd579d970f | ||
|  | f0ec7fb780 | ||
|  | bf2a15ee94 | ||
|  | c85b5e1be7 | ||
|  | 330980897f | ||
|  | 9411346324 | ||
|  | 8f9b7c7d7f | ||
|  | 8df5664474 | ||
|  | 25e9b4d3f6 | ||
|  | b49446f8e1 | ||
|  | cbebff71e9 | ||
|  | e4e8267f88 | ||
|  | 1e61c9a322 | ||
|  | 1a981dbaeb | ||
|  | 58e9059de1 | ||
|  | a62a2e6297 | ||
|  | daa635c20c | ||
|  | 9ee08ff30d | ||
|  | f4ef189a47 | ||
|  | 8e9c25766c | ||
|  | 8ca744f938 | ||
|  | f1b090783c | ||
|  | 8624823510 | ||
|  | 203397ae27 | ||
|  | 2aee3e724e | ||
|  | a1707fcc88 | ||
|  | b173558d72 | ||
|  | d1ddcc2b6a | ||
|  | 1f2d557283 | ||
|  | 544b84f77b | ||
|  | 23d17c1372 | ||
|  | ba3953a01d | ||
|  | 02e50e0dcd | ||
|  | cd48d2d9f1 | ||
|  | a81a96bcb6 | ||
|  | 7a5430f22f | ||
|  | 6b46ca579b | ||
|  | 933706c9f3 | ||
|  | f524932f69 | ||
|  | 115127d4c2 | ||
|  | 115f70f942 | ||
|  | 1c23b66302 | ||
|  | 7a714ca5cb | ||
|  | f559e1b425 | ||
|  | 5c38a9cbe9 | ||
|  | ede6deb03b | ||
|  | e3c7fbbbf0 | ||
|  | a5bedc5d4f | ||
|  | 97590ddc37 | ||
|  | 41839de420 | ||
|  | ad8dc7ef6a | ||
|  | 35da154adf | ||
|  | 3e0e3a6dea | ||
|  | 25d3ae13f9 | ||
|  | 5db8d22748 | ||
|  | 86acd2a1fd | ||
|  | 3f1275846c | ||
|  | ef1e109eb6 | ||
|  | 5c54c52839 | ||
|  | 89ea1bd733 | ||
|  | 444dfef7d6 | ||
|  | 957e1cc621 | ||
|  | 731c4e9bf4 | ||
|  | 6700f3a162 | ||
|  | 1691ab51b6 | ||
|  | 27f9f12663 | ||
|  | 474cf85207 | ||
|  | 37c9711406 | ||
|  | cd3cedc781 | ||
|  | e54bfe60d4 | ||
|  | d70ff19b06 | ||
|  | 45417006b1 | ||
|  | 925e60d017 | ||
|  | 47a028a7f5 | ||
|  | 7df347a3ca | ||
|  | d742f2f6db | ||
|  | e4c0d1d512 | ||
|  | 64a1064eca | ||
|  | bc57473979 | ||
|  | 11ea84dec5 | ||
|  | 5a614fb332 | ||
|  | d3a8ea948b | ||
|  | fba23f26a1 | ||
|  | 683f9d4247 | ||
|  | f87d5a33c9 | ||
|  | 42014fb4fa | ||
|  | 2da06d5689 | ||
|  | 792a93a5e3 | ||
|  | 86da5e6c4e | ||
|  | 6daf446e27 | ||
|  | 8a8f74b15c | ||
|  | 15453523bd | ||
|  | b1b0eab63d | ||
|  | f580ce7b99 | ||
|  | 2a7ffc9c95 | ||
|  | ff6b0e0388 | ||
|  | 71e1e1b52b | ||
|  | 02b67b8bfe | ||
|  | 5ce69a34b6 | ||
|  | e7f3e4d839 | ||
|  | 7645d3e274 | ||
|  | be13141ec7 | ||
|  | db33711f5a | ||
|  | 84dee23dd9 | ||
|  | a603ab7405 | ||
|  | bc41b8f654 | ||
|  | 32923891b5 | ||
|  | fecf3693b5 | ||
|  | 6965e8ed4c | ||
|  | 884bca012f | ||
|  | 7f46dbd76f | ||
|  | ea4554d4d2 | ||
|  | d8b58e3519 | ||
|  | 4cb86e9712 | ||
|  | eaed5520c4 | ||
|  | ec939a8c10 | ||
|  | 6594e9d359 | ||
|  | 52e6e7d89f | ||
|  | 2bf1894aa3 | ||
|  | 795895fc71 | ||
|  | 98376690f1 | ||
|  | 67421db6bd | ||
|  | ce3874fec9 | ||
|  | 67f42d16a1 | ||
|  | 56036f8577 | ||
|  | 1903bd4674 | ||
|  | df4c1902a6 | ||
|  | 132237ba05 | ||
|  | 2335d51128 | ||
|  | 2f7e5c0d4b | ||
|  | 2248b3f239 | ||
|  | 7d8a9a65e5 | ||
|  | bc39e4abaa | ||
|  | 26cd1c9794 | ||
|  | 5ccc7fa6a6 | ||
|  | badf18c0a6 | ||
|  | 1ee84620f9 | ||
|  | f1c1269910 | ||
|  | c09f41c4bd | ||
|  | 829c7a236d | ||
|  | c1ed8b1925 | ||
|  | 3d091fa7a8 | ||
|  | a8d44c9749 | ||
|  | 6125b490f2 | ||
|  | f75a77b009 | ||
|  | 3510b43886 | ||
|  | 61ba2ad220 | ||
|  | 4b449e5b54 | ||
|  | b8f0ecc408 | ||
|  | c2bd86551b | ||
|  | 92087b6bb6 | ||
|  | 9355458b6c | ||
|  | 4ec1021d58 | ||
|  | f3e4903860 | ||
|  | c5d80a628f | ||
|  | ee54c1fd71 | ||
|  | f33d84950e | ||
|  | d20c5c0356 | ||
|  | c207cf448f | ||
|  | a534572737 | ||
|  | acf6027bd2 | ||
|  | f6ab09b0bf | ||
|  | 55ddd21594 | ||
|  | 33ed11e54c | ||
|  | 93c31ca3b5 | ||
|  | 7a15005377 | ||
|  | e88ed3e650 | ||
|  | de51428ba5 | ||
|  | 8096e65e0a | ||
|  | 9cd70b5460 | ||
|  | 63bcd47c1b | ||
|  | 306a7e4bb2 | ||
|  | c34d4a9731 | ||
|  | 213bb63776 | ||
|  | 4ca4968624 | ||
|  | fd1882690a | ||
|  | 0b5047ec4d | ||
|  | a4a9a30e86 | ||
|  | 865c16699a | ||
|  | 52ebf2721a | ||
|  | aea6ddad5b | ||
|  | a7f880172e | ||
|  | e644288a42 | ||
|  | e234151ec9 | ||
|  | 44e1837ae3 | ||
|  | b400dc555d | ||
|  | 3f2d9cde44 | ||
|  | 6001bc9edc | ||
|  | 5203a0b09d | ||
|  | 500607bc35 | ||
|  | 754892d4ae | ||
|  | ea24a0ad75 | ||
|  | 748dc30fdc | ||
|  | e4ed35bcaf | ||
|  | ece69c52b2 | ||
|  | 14c898b500 | ||
|  | 00cdd4dcf9 | ||
|  | b02f4f1968 | ||
|  | 0a36ca9fb8 | ||
|  | fe92974cdf | ||
|  | 6aa41b32df | ||
|  | 4fa0803854 | ||
|  | 9ab4abd18c | ||
|  | f375a232f2 | ||
|  | 85daf96c6d | ||
|  | 8b56c4af06 | ||
|  | 4da299730b | ||
|  | dff0fe1b20 | ||
|  | ae74c01440 | ||
|  | cde0632795 | ||
|  | 6cc033f2b3 | ||
|  | 8aaf080d68 | ||
|  | 4378b83ae3 | ||
|  | d3a78eb55f | ||
|  | f4d1e351c0 | ||
|  | 7b79b2a752 | ||
|  | 143774290e | ||
|  | a9a5bcf180 | ||
|  | f9c8fcf79f | ||
|  | 86e82987ba | ||
|  | 5fe4df6233 | ||
|  | d79b3ba8ae | ||
|  | 8f3c97e3f1 | ||
|  | d95713bd5d | ||
|  | bdf9736c53 | ||
|  | 7e85212f59 | ||
|  | 0c692feedb | ||
|  | 78da7b9646 | ||
|  | 992ccebeea | ||
|  | c13dc6c789 | ||
|  | 5e6af67a5e | ||
|  | e32d23f291 | ||
|  | a880eab216 | ||
|  | 6c8fe00271 | ||
|  | c37c1fb693 | ||
|  | 0c3292abfb | ||
|  | 66050d88b2 | ||
|  | 1771c6f669 | ||
|  | acc77da702 | ||
|  | bdb9f7fd28 | ||
|  | f9e15febb7 | ||
|  | 1ba2a63e58 | ||
|  | c838a38ea1 | ||
|  | 2e34e4f80f | ||
|  | 2bb20697b4 | ||
|  | 28b774ebdb | ||
|  | 12be8b4772 | ||
|  | be62f7d934 | ||
|  | 9b814496b5 | ||
|  | f2bb19b43a | ||
|  | e3ceb00204 | ||
|  | c48eef1c6e | ||
|  | 544da49fda | ||
|  | 26ea4afa08 | ||
|  | a0f1efaaad | ||
|  | 7645e6e536 | ||
|  | c21b4ec861 | ||
|  | 30a933bf94 | ||
|  | 646074d659 | ||
|  | d63db6a05e | ||
|  | dc49976071 | ||
|  | 52bee6e472 | ||
|  | 57ec230092 | ||
|  | 549804ea2d | ||
|  | fd7acd5c1e | ||
|  | fb99e07d58 | ||
|  | 557c94c831 | ||
|  | 64508494d5 | ||
|  | c0b2cb764a | ||
|  | 71be92f02d | ||
|  | 08fb6c874a | ||
|  | 94d04eaa0d | ||
|  | 116ac10f81 | ||
|  | 9f1e4d5588 | ||
|  | f1c309a163 | ||
|  | 202e4e0271 | ||
|  | c3afc518f5 | ||
|  | 1072fff97e | ||
|  | 04df35b994 | ||
|  | 0fa1a8d680 | ||
|  | 78039b1f7f | ||
|  | b147a594b1 | ||
|  | 5298cab81e | ||
|  | f0a35701c4 | ||
|  | 477313b699 | ||
|  | 90fd69fffb | ||
|  | 7bf980c8dd | ||
|  | 27c4618d3e | ||
|  | 9f79f97603 | ||
|  | fdce5083a7 | ||
|  | f62c9ea5ea | ||
|  | 52fbfb7d9e | ||
|  | 9230b19200 | ||
|  | 503956ef9b | ||
|  | 3ad927eab1 | ||
|  | 1b2936fed4 | ||
|  | f313ba7cbe | ||
|  | 191094ccb5 | ||
|  | a748ca2efa | ||
|  | 501cd3b4dc | ||
|  | 9b724c303e | ||
|  | 3c3fdfcc0c | ||
|  | 3317bc450c | ||
|  | 0e24fa1975 | ||
|  | bd717aced6 | ||
|  | 3b14e1426f | ||
|  | cde360986c | ||
|  | ff8a687227 | ||
|  | f78055c629 | ||
|  | 72e45fe25b | ||
|  | cfe0b72a03 | ||
|  | a6bb0f87a3 | ||
|  | a1bb3349df | ||
|  | aabb2db775 | ||
|  | 01def677bf | ||
|  | 73602de30a | ||
|  | aeb23a4bdd | ||
|  | 0a03a96401 | ||
|  | 3793ab6467 | ||
|  | 295371713e | ||
|  | c616a64390 | ||
|  | f9f94e6203 | ||
|  | 512233d0e6 | ||
|  | 685c78279d | ||
|  | 41740501eb | ||
|  | 6e17ebd67e | ||
|  | f2b17e4179 | ||
|  | fec4a42eb0 | ||
|  | 50d833aa5b | ||
|  | df274d47a3 | ||
|  | 0241d94e72 | ||
|  | e9f450e1ba | ||
|  | ba0737b352 | ||
|  | 09f46b2da6 | ||
|  | d7b4f42aa6 | ||
|  | be330a1b19 | ||
|  | 32663c1b4d | ||
|  | 0d0b1b386e | ||
|  | c75c228a38 | ||
|  | cbc83428b4 | ||
|  | 8a7ba1315b | ||
|  | 0d13054264 | ||
|  | f1d0d15603 | ||
|  | 857b1415c7 | ||
|  | 9edc64b62f | ||
|  | 8ee841e541 | ||
|  | fd236b26bd | ||
|  | b886042d0a | ||
|  | c6a5c06827 | ||
|  | 92de6969aa | ||
|  | 4b12eb719d | ||
|  | f64fe7765c | ||
|  | b64a252d1c | ||
|  | d700906a15 | ||
|  | e706aba73c | ||
|  | 53af4d4f57 | ||
|  | b10e7caf66 | ||
|  | 3f03131b48 | ||
|  | adcc4faa55 | ||
|  | db5c425004 | ||
|  | 52e5a688fb | ||
|  | 8827545ceb | ||
|  | 971ff49395 | ||
|  | 937999e9cc | ||
|  | a0998071eb | ||
|  | 53e57a851c | ||
|  | 800e52f373 | ||
|  | 6dd3b19f8f | ||
|  | 6f4fa19a5b | ||
|  | d97141a29c | ||
|  | bc3340afc5 | ||
|  | 5f1def5815 | ||
|  | 5a7191522f | ||
|  | 893f0e10c7 | ||
|  | d5e58c8a04 | ||
|  | 2920a48bbc | ||
|  | 1904e7e80d | ||
|  | 702bb97ecb | ||
|  | b9c806c75d | ||
|  | d2799e6f98 | ||
|  | 2734714920 | ||
|  | f75a3e8436 | ||
|  | c349fa5b1f | ||
|  | 08d5b40ca5 | ||
|  | 0a5ede19a9 | ||
|  | a23ac1d61c | ||
|  | a8da4e5ca3 | ||
|  | 4f616f683a | ||
|  | 222b714890 | ||
|  | 7dee0f45c2 | ||
|  | 50ca2bca83 | ||
|  | 3aa7bfe163 | ||
|  | 755aebc7d1 | ||
|  | 06d64212d3 | ||
|  | 97a4d7a5fd | ||
|  | a7260b277e | ||
|  | f4e053dda1 | ||
|  | a7c463b44a | ||
|  | 42faf281e6 | ||
|  | 13d93c1ca1 | ||
|  | 3edb3cb004 | ||
|  | 3609b7787a | ||
|  | f804351b51 | ||
|  | 39e51526fb | ||
|  | 76ea8a76b2 | ||
|  | 12fc52a49a | ||
|  | c157d0a332 | ||
|  | c61f5d87b4 | ||
|  | c208b4c1f7 | ||
|  | b4e6c2b28a | ||
|  | b84b650c31 | ||
|  | eda0038770 | ||
|  | ed5b4ae5dc | ||
|  | d50632cfd1 | ||
|  | 40c0a12211 | ||
|  | e977669c8c | ||
|  | 0e8b9655a0 | ||
|  | 367ce74a5f | ||
|  | 3814d56740 | ||
|  | e1f84aa44d | ||
|  | 1041604f29 | ||
|  | 253d6427fd | ||
|  | 69aad1f173 | ||
|  | 887e1a09ab | ||
|  | f344e25b84 | ||
|  | 574cf0ddce | ||
|  | 37f2880a8a | ||
|  | b88c4086b9 | ||
|  | aa9bf7774e | ||
|  | ed2ff1a448 | ||
|  | ddee3ca933 | ||
|  | 03d1894080 | ||
|  | 322805e800 | ||
|  | 92a1f98d35 | ||
|  | fdfc5bf12f | ||
|  | a25c0ce6cb | ||
|  | 76f85a724c | ||
|  | 45ef022607 | ||
|  | a72af0b6a6 | ||
|  | b0c29bffb7 | ||
|  | 996094e8e8 | ||
|  | 4137be6a8b | ||
|  | 4e899835b3 | ||
|  | 3812292b26 | ||
|  | c12283ec57 | ||
|  | f2dc0d8256 | ||
|  | 717db318c1 | ||
|  | 2a57ddf74a | ||
|  | 230fd6b47f | ||
|  | 472ac8a356 | ||
|  | 3ba05ede1f | ||
|  | d785346c8c | ||
|  | 6ca4d4ade2 | ||
|  | 75cec40e58 | ||
|  | c317ccac62 | ||
|  | a74bb0fad6 | ||
|  | 6ff2065a12 | ||
|  | 727b4612ba | ||
|  | 613f4ec588 | ||
|  | db6202adcd | ||
|  | f0f68e07c3 | ||
|  | 8ba5a0033b | ||
|  | 9edc2a11bd | ||
|  | 079e4844d6 | ||
|  | 4ebd000afd | ||
|  | 063fc6a872 | ||
|  | e3ada7e5c2 | ||
|  | d61e5be06a | ||
|  | db2b34260f | ||
|  | c031dc946b | ||
|  | 0eb881f067 | ||
|  | 27f2dc276c | ||
|  | cba1833dde | ||
|  | 39db90e99b | ||
|  | 947a893558 | ||
|  | b99e9f0bc3 | ||
|  | 4cf255df10 | ||
|  | 614d8770a4 | ||
|  | 69453dbfc5 | ||
|  | 1113cb87cb | ||
|  | 9c95294209 | ||
|  | f901ec9c20 | ||
|  | a94b9252d5 | ||
|  | 25672bf196 | ||
|  | cb6a0acca4 | ||
|  | aa2ed2e033 | ||
|  | 263f84178a | ||
|  | 0eb5996567 | ||
|  | fe55bf4667 | ||
|  | 709ded51a5 | ||
|  | 8b1f1a3817 | ||
|  | 7abf13ee48 | ||
|  | da64595ccc | ||
|  | 29b14c7fca | ||
|  | d1ab42cddf | ||
|  | 422726cec5 | ||
|  | 4bc52c85c3 | ||
|  | e7b5fd0b28 | ||
|  | 53ccc3e0d7 | ||
|  | 8ab7c9d8dd | ||
|  | 0cf00ed767 | ||
|  | aedc5fc8f9 | ||
|  | 78e25cd233 | ||
|  | 29894757f3 | ||
|  | 5328161026 | ||
|  | 4968d2280b | ||
|  | c000a0b58f | ||
|  | 6ff498182a | ||
|  | 60b1ffac6b | ||
|  | 9b7c81f8f6 | ||
|  | b650771559 | ||
|  | 17f624cb5b | ||
|  | 21dee71590 | ||
|  | 83e2129213 | ||
|  | b16787d530 | ||
|  | 204870af89 | ||
|  | 0918f5f2a4 | ||
|  | 1b1a3c48ad | ||
|  | a7174b82a2 | ||
|  | 3de71f2c52 | ||
|  | 5576baa56b | ||
|  | 1026c62889 | ||
|  | 1fb8644035 | ||
|  | 5a5a5b4387 | ||
|  | cc5cdb7fe0 | ||
|  | e0d37eb073 | ||
|  | bdd89aa34f | ||
|  | 18cdc8bf28 | ||
|  | 656ad4b5f2 | ||
|  | bebb162342 | ||
|  | 6084a4eb65 | ||
|  | dbb485d80d | ||
|  | 9bfa003014 | ||
|  | fe64d05f86 | ||
|  | decca791c5 | ||
|  | bd08e7b7cd | ||
|  | cca55d0890 | ||
|  | a802a3c0ce | ||
|  | d06e19f862 | ||
|  | bbe1574290 | ||
|  | 4264cda558 | ||
|  | 3390540145 | ||
|  | 1c72a31463 | ||
|  | 7dfbe33bba | ||
|  | e63ddf9c00 | ||
|  | d5cd9d86a1 | ||
|  | cae99bf6d9 | ||
|  | 5a90152b1f | ||
|  | 4b92b8d013 | ||
|  | 693293c29a | ||
|  | ac5d8920dd | ||
|  | e833360307 | ||
|  | b5a08466b4 | ||
|  | 4032438d2b | ||
|  | 9b3abaad52 | ||
|  | d20d631365 | ||
|  | 378bd0b6f8 | ||
|  | 6d1455a33e | ||
|  | c44ebadf6f | ||
|  | 4d37378696 | ||
|  | 777a6fc967 | ||
|  | d7ed6d7e8d | ||
|  | 0ecbac99f3 | ||
|  | 436390bd4e | ||
|  | a587e93714 | ||
|  | 75e00ee3d1 | ||
|  | c01af7a6f6 | ||
|  | c79d4172e0 | ||
|  | b85ac67c9a | ||
|  | fa0c026e07 | ||
|  | 986024f0b7 | ||
|  | 6fca6b3929 | ||
|  | d9cc0aeccf | ||
|  | 5340f6e816 | ||
|  | c211be411e | ||
|  | b3afdc78a7 | ||
|  | e0c2736e35 | ||
|  | a63892c289 | ||
|  | d432f2086c | ||
|  | eaad2cd2bb | ||
|  | a148b21183 | ||
|  | e7422f245c | ||
|  | c86093d76a | ||
|  | a693ccda4b | ||
|  | 543cacb256 | ||
|  | 3f3947669a | ||
|  | 579711fd3c | ||
|  | 7336529ec5 | ||
|  | 88af98fab4 | ||
|  | 01bfa29846 | ||
|  | 0206df026c | ||
|  | 41aebc770d | ||
|  | bc4d6bddd4 | ||
|  | 1f57b4dd2d | ||
|  | 02d4f46354 | ||
|  | b9684c0cf5 | ||
|  | 5423935c9b | ||
|  | 41ca2299a5 | ||
|  | 33e91b639d | ||
|  | e4ec586f46 | ||
|  | 15a8123fbc | ||
|  | f0c6ac01d3 | ||
|  | 63fea55da4 | ||
|  | 26b92e3f5c | ||
|  | 643092d2fc | ||
|  | 18c8a679dc | ||
|  | 13d33a88ca | ||
|  | 738bda9866 | ||
|  | 47c9af9d7d | ||
|  | 3fba6132b4 | ||
|  | 127b9b6624 | ||
|  | 8189d29e96 | ||
|  | eb7aa853fa | ||
|  | 15bf8034d6 | ||
|  | 6bf2690b23 | ||
|  | ced6c34563 | ||
|  | 2efcc22ff5 | ||
|  | cb2742a00b | ||
|  | c8c53f54bb | ||
|  | 863daedf86 | ||
|  | 55871cbb47 | ||
|  | e3d60b3873 | ||
|  | 2dd6cc1801 | ||
|  | f11e7d60d7 | ||
|  | 7137b09ae2 | ||
|  | 053f389907 | ||
|  | 4f9b5202aa | ||
|  | 466a737d16 | ||
|  | eb7eb78d95 | ||
|  | 682d7347f7 | ||
|  | 3c43b6525f | ||
|  | aefd8348d2 | ||
|  | f2de61db4e | ||
|  | 4c7d97cca4 | ||
|  | 806543fb3a | ||
|  | 2afa86ca9f | ||
|  | ae50675399 | ||
|  | d7a54a26c7 | ||
|  | 02a8a21e55 | ||
|  | 3abad5567a | ||
|  | 7c8cc1a9ef | ||
|  | 355e9c1f86 | ||
|  | 26dd4cb9bb | ||
|  | 317ca35dca | ||
|  | 053762c1c1 | ||
|  | 95e20daa83 | ||
|  | fcc1683d01 | ||
|  | 059f2e7791 | ||
|  | 692fda9de7 | ||
|  | e8885a31b8 | ||
|  | 12e24e843d | ||
|  | b35e929b1d | ||
|  | c839ac993c | ||
|  | 83e6d042d7 | ||
|  | b995a7b937 | ||
|  | 1c1db193aa | ||
|  | 9675f09de6 | ||
|  | 392bcac1c1 | ||
|  | a2ba1beedb | ||
|  | 42e2fed267 | ||
|  | 8e2fd532f1 | ||
|  | 2bf5eec3b6 | ||
|  | 43efc20423 | ||
|  | 4a9a0a05a3 | ||
|  | 1647b85e82 | ||
|  | 6cee865aea | ||
|  | 5c61ab77ec | ||
|  | a31de8476d | ||
|  | b2c379621c | ||
|  | 04a5ee4df2 | ||
|  | a188e7cd61 | ||
|  | e0644c97f9 | ||
|  | 9cc76cdea7 | ||
|  | b55d63f1f8 | ||
|  | 8f6be44bf5 | ||
|  | 469bf6123e | ||
|  | 9cbb22e130 | ||
|  | 4c65920ab9 | ||
|  | bad0f7d376 | ||
|  | ab09ae8fad | ||
|  | 2f66fb5679 | ||
|  | 1a6a8efda2 | ||
|  | e5b01ed062 | ||
|  | 3d5e31b7a4 | ||
|  | 4336c6b886 | ||
|  | f25026ba74 | ||
|  | 9f5ce3593a | ||
|  | a5009d1aec | ||
|  | ae5079ecac | ||
|  | 38fdc3f684 | ||
|  | 0821518fd9 | ||
|  | c8b76ea3f7 | ||
|  | bf26498bc4 | ||
|  | 15e064da79 | ||
|  | c5e1979a6b | ||
|  | dc882d2669 | ||
|  | f9f0422c72 | ||
|  | 38eaee068d | ||
|  | 0a56b592f2 | ||
|  | 091093ee61 | ||
|  | 7a4f128c22 | ||
|  | f943246fd9 | ||
|  | 8337949d80 | ||
|  | 76166f0035 | ||
|  | a9718db8ba | 
							
								
								
									
										3
									
								
								.eslintignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.eslintignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | dist/ | ||||||
|  | lib/ | ||||||
|  | node_modules/ | ||||||
							
								
								
									
										54
									
								
								.eslintrc.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								.eslintrc.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | |||||||
|  | { | ||||||
|  |     "plugins": ["jest", "@typescript-eslint"], | ||||||
|  |     "extends": ["plugin:github/recommended"], | ||||||
|  |     "parser": "@typescript-eslint/parser", | ||||||
|  |     "parserOptions": { | ||||||
|  |       "ecmaVersion": 9, | ||||||
|  |       "sourceType": "module", | ||||||
|  |       "project": "./tsconfig.json" | ||||||
|  |     }, | ||||||
|  |     "rules": { | ||||||
|  |       "eslint-comments/no-use": "off", | ||||||
|  |       "import/no-namespace": "off", | ||||||
|  |       "i18n-text/no-en": "off", | ||||||
|  |       "no-unused-vars": "off", | ||||||
|  |       "sort-imports": "off", | ||||||
|  |       "@typescript-eslint/no-unused-vars": ["error", { "argsIgnorePattern": "^_" }], | ||||||
|  |       "@typescript-eslint/explicit-member-accessibility": ["error", {"accessibility": "no-public"}], | ||||||
|  |       "@typescript-eslint/no-require-imports": "error", | ||||||
|  |       "@typescript-eslint/array-type": "error", | ||||||
|  |       "@typescript-eslint/await-thenable": "error", | ||||||
|  |       "camelcase": "off", | ||||||
|  |       "@typescript-eslint/explicit-function-return-type": ["error", {"allowExpressions": true}], | ||||||
|  |       "@typescript-eslint/func-call-spacing": ["error", "never"], | ||||||
|  |       "@typescript-eslint/no-array-constructor": "error", | ||||||
|  |       "@typescript-eslint/no-empty-interface": "error", | ||||||
|  |       "@typescript-eslint/no-explicit-any": "error", | ||||||
|  |       "@typescript-eslint/no-extraneous-class": "error", | ||||||
|  |       "@typescript-eslint/no-for-in-array": "error", | ||||||
|  |       "@typescript-eslint/no-inferrable-types": "error", | ||||||
|  |       "@typescript-eslint/no-misused-new": "error", | ||||||
|  |       "@typescript-eslint/no-namespace": "error",  | ||||||
|  |       "@typescript-eslint/no-non-null-assertion": "off", | ||||||
|  |       "@typescript-eslint/no-unnecessary-qualifier": "error", | ||||||
|  |       "@typescript-eslint/no-unnecessary-type-assertion": "error", | ||||||
|  |       "@typescript-eslint/no-useless-constructor": "error", | ||||||
|  |       "@typescript-eslint/no-var-requires": "error", | ||||||
|  |       "@typescript-eslint/prefer-for-of": "warn", | ||||||
|  |       "@typescript-eslint/prefer-function-type": "warn", | ||||||
|  |       "@typescript-eslint/prefer-includes": "error", | ||||||
|  |       "@typescript-eslint/prefer-string-starts-ends-with": "error", | ||||||
|  |       "@typescript-eslint/promise-function-async": "error", | ||||||
|  |       "@typescript-eslint/require-array-sort-compare": ["error", {"ignoreStringArrays":  true}], | ||||||
|  |       "@typescript-eslint/restrict-plus-operands": "error", | ||||||
|  |       "semi": "off", | ||||||
|  |       "@typescript-eslint/semi": ["error", "never"], | ||||||
|  |       "@typescript-eslint/type-annotation-spacing": "error", | ||||||
|  |       "@typescript-eslint/unbound-method": "error" | ||||||
|  |     }, | ||||||
|  |     "env": { | ||||||
|  |       "node": true, | ||||||
|  |       "es6": true, | ||||||
|  |       "jest/globals": true | ||||||
|  |     } | ||||||
|  |   } | ||||||
							
								
								
									
										16
									
								
								.github/actions/build-dist/action.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								.github/actions/build-dist/action.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | name: 'Build and upload distribution' | ||||||
|  | # Builds the action distribution an uploads as an artifact for later download | ||||||
|  | runs: | ||||||
|  |   using: "composite" | ||||||
|  |   steps:  | ||||||
|  |     - name: Build distribution | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         npm install | ||||||
|  |         npm run build | ||||||
|  |     - name: Upload distribution | ||||||
|  |       uses: actions/upload-artifact@v3 | ||||||
|  |       with: | ||||||
|  |         name: dist | ||||||
|  |         path: dist/ | ||||||
|  |  | ||||||
							
								
								
									
										12
									
								
								.github/actions/download-dist/action.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								.github/actions/download-dist/action.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | name: 'Download dist' | ||||||
|  | # Downloads a 'dist' directory artifact that was uploaded in an earlier step | ||||||
|  | # We control this with an environment variable to allow for easier global configuration. | ||||||
|  | runs: | ||||||
|  |   using: "composite" | ||||||
|  |   steps:  | ||||||
|  |     - name: Download dist | ||||||
|  |       if: ${{ env.DOWNLOAD_DIST == 'true' }} | ||||||
|  |       uses: actions/download-artifact@v3 | ||||||
|  |       with: | ||||||
|  |         name: dist | ||||||
|  |         path: dist/ | ||||||
							
								
								
									
										3
									
								
								.github/dco.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.github/dco.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | # Disable sign-off checking for members of the Gradle GitHub organization | ||||||
|  | require: | ||||||
|  |   members: false | ||||||
							
								
								
									
										57
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | |||||||
|  | version: 2 | ||||||
|  | registries: | ||||||
|  |   gradle-plugin-portal: | ||||||
|  |     type: maven-repository | ||||||
|  |     url: https://plugins.gradle.org/m2 | ||||||
|  |     username: dummy # Required by dependabot | ||||||
|  |     password: dummy # Required by dependabot | ||||||
|  | updates: | ||||||
|  |   - package-ecosystem: "npm" | ||||||
|  |     directory: "/" | ||||||
|  |     schedule: | ||||||
|  |       interval: "weekly" | ||||||
|  |     open-pull-requests-limit: 10 | ||||||
|  |     ignore: | ||||||
|  |       - dependency-name: "@types/node" | ||||||
|  |   - package-ecosystem: "gradle" | ||||||
|  |     directory: ".github/workflow-samples/gradle-plugin" | ||||||
|  |     registries: | ||||||
|  |       - gradle-plugin-portal | ||||||
|  |     schedule: | ||||||
|  |       interval: "daily" | ||||||
|  |   - package-ecosystem: "gradle" | ||||||
|  |     directory: ".github/workflow-samples/groovy-dsl" | ||||||
|  |     registries: | ||||||
|  |       - gradle-plugin-portal | ||||||
|  |     schedule: | ||||||
|  |       interval: "daily" | ||||||
|  |   - package-ecosystem: "gradle" | ||||||
|  |     directory: ".github/workflow-samples/java-toolchain" | ||||||
|  |     registries: | ||||||
|  |       - gradle-plugin-portal | ||||||
|  |     schedule: | ||||||
|  |       interval: "daily" | ||||||
|  |   - package-ecosystem: "gradle" | ||||||
|  |     directory: ".github/workflow-samples/kotlin-dsl" | ||||||
|  |     registries: | ||||||
|  |       - gradle-plugin-portal | ||||||
|  |     schedule: | ||||||
|  |       interval: "daily" | ||||||
|  |   - package-ecosystem: "gradle" | ||||||
|  |     directory: ".github/workflow-samples/no-wrapper" | ||||||
|  |     registries: | ||||||
|  |       - gradle-plugin-portal | ||||||
|  |     schedule: | ||||||
|  |       interval: "daily" | ||||||
|  |   - package-ecosystem: "gradle" | ||||||
|  |     directory: ".github/workflow-samples/no-wrapper-gradle-5" | ||||||
|  |     registries: | ||||||
|  |       - gradle-plugin-portal | ||||||
|  |     schedule: | ||||||
|  |       interval: "daily" | ||||||
|  |   - package-ecosystem: "gradle" | ||||||
|  |     directory: "test/init-scripts" | ||||||
|  |     registries: | ||||||
|  |       - gradle-plugin-portal | ||||||
|  |     schedule: | ||||||
|  |       interval: "daily" | ||||||
							
								
								
									
										5
									
								
								.github/workflow-samples/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.github/workflow-samples/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | # Ignore Gradle project-specific cache directory | ||||||
|  | .gradle | ||||||
|  |  | ||||||
|  | # Ignore Gradle build output directory | ||||||
|  | build | ||||||
							
								
								
									
										
											BIN
										
									
								
								.github/workflow-samples/gradle-plugin/gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								.github/workflow-samples/gradle-plugin/gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										6
									
								
								.github/workflow-samples/gradle-plugin/gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								.github/workflow-samples/gradle-plugin/gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | distributionBase=GRADLE_USER_HOME | ||||||
|  | distributionPath=wrapper/dists | ||||||
|  | distributionSha256Sum=f6b8596b10cce501591e92f229816aa4046424f3b24d771751b06779d58c8ec4 | ||||||
|  | distributionUrl=https\://services.gradle.org/distributions/gradle-7.5.1-bin.zip | ||||||
|  | zipStoreBase=GRADLE_USER_HOME | ||||||
|  | zipStorePath=wrapper/dists | ||||||
							
								
								
									
										240
									
								
								.github/workflow-samples/gradle-plugin/gradlew
									
									
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										240
									
								
								.github/workflow-samples/gradle-plugin/gradlew
									
									
									
									
										vendored
									
									
										Executable file
									
								
							| @@ -0,0 +1,240 @@ | |||||||
|  | #!/bin/sh | ||||||
|  |  | ||||||
|  | # | ||||||
|  | # Copyright © 2015-2021 the original authors. | ||||||
|  | # | ||||||
|  | # Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | # you may not use this file except in compliance with the License. | ||||||
|  | # You may obtain a copy of the License at | ||||||
|  | # | ||||||
|  | #      https://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | # | ||||||
|  | # Unless required by applicable law or agreed to in writing, software | ||||||
|  | # distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | # See the License for the specific language governing permissions and | ||||||
|  | # limitations under the License. | ||||||
|  | # | ||||||
|  |  | ||||||
|  | ############################################################################## | ||||||
|  | # | ||||||
|  | #   Gradle start up script for POSIX generated by Gradle. | ||||||
|  | # | ||||||
|  | #   Important for running: | ||||||
|  | # | ||||||
|  | #   (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is | ||||||
|  | #       noncompliant, but you have some other compliant shell such as ksh or | ||||||
|  | #       bash, then to run this script, type that shell name before the whole | ||||||
|  | #       command line, like: | ||||||
|  | # | ||||||
|  | #           ksh Gradle | ||||||
|  | # | ||||||
|  | #       Busybox and similar reduced shells will NOT work, because this script | ||||||
|  | #       requires all of these POSIX shell features: | ||||||
|  | #         * functions; | ||||||
|  | #         * expansions «$var», «${var}», «${var:-default}», «${var+SET}», | ||||||
|  | #           «${var#prefix}», «${var%suffix}», and «$( cmd )»; | ||||||
|  | #         * compound commands having a testable exit status, especially «case»; | ||||||
|  | #         * various built-in commands including «command», «set», and «ulimit». | ||||||
|  | # | ||||||
|  | #   Important for patching: | ||||||
|  | # | ||||||
|  | #   (2) This script targets any POSIX shell, so it avoids extensions provided | ||||||
|  | #       by Bash, Ksh, etc; in particular arrays are avoided. | ||||||
|  | # | ||||||
|  | #       The "traditional" practice of packing multiple parameters into a | ||||||
|  | #       space-separated string is a well documented source of bugs and security | ||||||
|  | #       problems, so this is (mostly) avoided, by progressively accumulating | ||||||
|  | #       options in "$@", and eventually passing that to Java. | ||||||
|  | # | ||||||
|  | #       Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS, | ||||||
|  | #       and GRADLE_OPTS) rely on word-splitting, this is performed explicitly; | ||||||
|  | #       see the in-line comments for details. | ||||||
|  | # | ||||||
|  | #       There are tweaks for specific operating systems such as AIX, CygWin, | ||||||
|  | #       Darwin, MinGW, and NonStop. | ||||||
|  | # | ||||||
|  | #   (3) This script is generated from the Groovy template | ||||||
|  | #       https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt | ||||||
|  | #       within the Gradle project. | ||||||
|  | # | ||||||
|  | #       You can find Gradle at https://github.com/gradle/gradle/. | ||||||
|  | # | ||||||
|  | ############################################################################## | ||||||
|  |  | ||||||
|  | # Attempt to set APP_HOME | ||||||
|  |  | ||||||
|  | # Resolve links: $0 may be a link | ||||||
|  | app_path=$0 | ||||||
|  |  | ||||||
|  | # Need this for daisy-chained symlinks. | ||||||
|  | while | ||||||
|  |     APP_HOME=${app_path%"${app_path##*/}"}  # leaves a trailing /; empty if no leading path | ||||||
|  |     [ -h "$app_path" ] | ||||||
|  | do | ||||||
|  |     ls=$( ls -ld "$app_path" ) | ||||||
|  |     link=${ls#*' -> '} | ||||||
|  |     case $link in             #( | ||||||
|  |       /*)   app_path=$link ;; #( | ||||||
|  |       *)    app_path=$APP_HOME$link ;; | ||||||
|  |     esac | ||||||
|  | done | ||||||
|  |  | ||||||
|  | APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit | ||||||
|  |  | ||||||
|  | APP_NAME="Gradle" | ||||||
|  | APP_BASE_NAME=${0##*/} | ||||||
|  |  | ||||||
|  | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
|  | DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' | ||||||
|  |  | ||||||
|  | # Use the maximum available, or set MAX_FD != -1 to use that value. | ||||||
|  | MAX_FD=maximum | ||||||
|  |  | ||||||
|  | warn () { | ||||||
|  |     echo "$*" | ||||||
|  | } >&2 | ||||||
|  |  | ||||||
|  | die () { | ||||||
|  |     echo | ||||||
|  |     echo "$*" | ||||||
|  |     echo | ||||||
|  |     exit 1 | ||||||
|  | } >&2 | ||||||
|  |  | ||||||
|  | # OS specific support (must be 'true' or 'false'). | ||||||
|  | cygwin=false | ||||||
|  | msys=false | ||||||
|  | darwin=false | ||||||
|  | nonstop=false | ||||||
|  | case "$( uname )" in                #( | ||||||
|  |   CYGWIN* )         cygwin=true  ;; #( | ||||||
|  |   Darwin* )         darwin=true  ;; #( | ||||||
|  |   MSYS* | MINGW* )  msys=true    ;; #( | ||||||
|  |   NONSTOP* )        nonstop=true ;; | ||||||
|  | esac | ||||||
|  |  | ||||||
|  | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # Determine the Java command to use to start the JVM. | ||||||
|  | if [ -n "$JAVA_HOME" ] ; then | ||||||
|  |     if [ -x "$JAVA_HOME/jre/sh/java" ] ; then | ||||||
|  |         # IBM's JDK on AIX uses strange locations for the executables | ||||||
|  |         JAVACMD=$JAVA_HOME/jre/sh/java | ||||||
|  |     else | ||||||
|  |         JAVACMD=$JAVA_HOME/bin/java | ||||||
|  |     fi | ||||||
|  |     if [ ! -x "$JAVACMD" ] ; then | ||||||
|  |         die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME | ||||||
|  |  | ||||||
|  | Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | location of your Java installation." | ||||||
|  |     fi | ||||||
|  | else | ||||||
|  |     JAVACMD=java | ||||||
|  |     which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||||||
|  |  | ||||||
|  | Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | location of your Java installation." | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Increase the maximum file descriptors if we can. | ||||||
|  | if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then | ||||||
|  |     case $MAX_FD in #( | ||||||
|  |       max*) | ||||||
|  |         MAX_FD=$( ulimit -H -n ) || | ||||||
|  |             warn "Could not query maximum file descriptor limit" | ||||||
|  |     esac | ||||||
|  |     case $MAX_FD in  #( | ||||||
|  |       '' | soft) :;; #( | ||||||
|  |       *) | ||||||
|  |         ulimit -n "$MAX_FD" || | ||||||
|  |             warn "Could not set maximum file descriptor limit to $MAX_FD" | ||||||
|  |     esac | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Collect all arguments for the java command, stacking in reverse order: | ||||||
|  | #   * args from the command line | ||||||
|  | #   * the main class name | ||||||
|  | #   * -classpath | ||||||
|  | #   * -D...appname settings | ||||||
|  | #   * --module-path (only if needed) | ||||||
|  | #   * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables. | ||||||
|  |  | ||||||
|  | # For Cygwin or MSYS, switch paths to Windows format before running java | ||||||
|  | if "$cygwin" || "$msys" ; then | ||||||
|  |     APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) | ||||||
|  |     CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) | ||||||
|  |  | ||||||
|  |     JAVACMD=$( cygpath --unix "$JAVACMD" ) | ||||||
|  |  | ||||||
|  |     # Now convert the arguments - kludge to limit ourselves to /bin/sh | ||||||
|  |     for arg do | ||||||
|  |         if | ||||||
|  |             case $arg in                                #( | ||||||
|  |               -*)   false ;;                            # don't mess with options #( | ||||||
|  |               /?*)  t=${arg#/} t=/${t%%/*}              # looks like a POSIX filepath | ||||||
|  |                     [ -e "$t" ] ;;                      #( | ||||||
|  |               *)    false ;; | ||||||
|  |             esac | ||||||
|  |         then | ||||||
|  |             arg=$( cygpath --path --ignore --mixed "$arg" ) | ||||||
|  |         fi | ||||||
|  |         # Roll the args list around exactly as many times as the number of | ||||||
|  |         # args, so each arg winds up back in the position where it started, but | ||||||
|  |         # possibly modified. | ||||||
|  |         # | ||||||
|  |         # NB: a `for` loop captures its iteration list before it begins, so | ||||||
|  |         # changing the positional parameters here affects neither the number of | ||||||
|  |         # iterations, nor the values presented in `arg`. | ||||||
|  |         shift                   # remove old arg | ||||||
|  |         set -- "$@" "$arg"      # push replacement arg | ||||||
|  |     done | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Collect all arguments for the java command; | ||||||
|  | #   * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of | ||||||
|  | #     shell script including quotes and variable substitutions, so put them in | ||||||
|  | #     double quotes to make sure that they get re-expanded; and | ||||||
|  | #   * put everything else in single quotes, so that it's not re-expanded. | ||||||
|  |  | ||||||
|  | set -- \ | ||||||
|  |         "-Dorg.gradle.appname=$APP_BASE_NAME" \ | ||||||
|  |         -classpath "$CLASSPATH" \ | ||||||
|  |         org.gradle.wrapper.GradleWrapperMain \ | ||||||
|  |         "$@" | ||||||
|  |  | ||||||
|  | # Stop when "xargs" is not available. | ||||||
|  | if ! command -v xargs >/dev/null 2>&1 | ||||||
|  | then | ||||||
|  |     die "xargs is not available" | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Use "xargs" to parse quoted args. | ||||||
|  | # | ||||||
|  | # With -n1 it outputs one arg per line, with the quotes and backslashes removed. | ||||||
|  | # | ||||||
|  | # In Bash we could simply go: | ||||||
|  | # | ||||||
|  | #   readarray ARGS < <( xargs -n1 <<<"$var" ) && | ||||||
|  | #   set -- "${ARGS[@]}" "$@" | ||||||
|  | # | ||||||
|  | # but POSIX shell has neither arrays nor command substitution, so instead we | ||||||
|  | # post-process each arg (as a line of input to sed) to backslash-escape any | ||||||
|  | # character that might be a shell metacharacter, then use eval to reverse | ||||||
|  | # that process (while maintaining the separation between arguments), and wrap | ||||||
|  | # the whole thing up as a single "set" statement. | ||||||
|  | # | ||||||
|  | # This will of course break if any of these variables contains a newline or | ||||||
|  | # an unmatched quote. | ||||||
|  | # | ||||||
|  |  | ||||||
|  | eval "set -- $( | ||||||
|  |         printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" | | ||||||
|  |         xargs -n1 | | ||||||
|  |         sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' | | ||||||
|  |         tr '\n' ' ' | ||||||
|  |     )" '"$@"' | ||||||
|  |  | ||||||
|  | exec "$JAVACMD" "$@" | ||||||
							
								
								
									
										91
									
								
								.github/workflow-samples/gradle-plugin/gradlew.bat
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								.github/workflow-samples/gradle-plugin/gradlew.bat
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | |||||||
|  | @rem | ||||||
|  | @rem Copyright 2015 the original author or authors. | ||||||
|  | @rem | ||||||
|  | @rem Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | @rem you may not use this file except in compliance with the License. | ||||||
|  | @rem You may obtain a copy of the License at | ||||||
|  | @rem | ||||||
|  | @rem      https://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | @rem | ||||||
|  | @rem Unless required by applicable law or agreed to in writing, software | ||||||
|  | @rem distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | @rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | @rem See the License for the specific language governing permissions and | ||||||
|  | @rem limitations under the License. | ||||||
|  | @rem | ||||||
|  |  | ||||||
|  | @if "%DEBUG%"=="" @echo off | ||||||
|  | @rem ########################################################################## | ||||||
|  | @rem | ||||||
|  | @rem  Gradle startup script for Windows | ||||||
|  | @rem | ||||||
|  | @rem ########################################################################## | ||||||
|  |  | ||||||
|  | @rem Set local scope for the variables with windows NT shell | ||||||
|  | if "%OS%"=="Windows_NT" setlocal | ||||||
|  |  | ||||||
|  | set DIRNAME=%~dp0 | ||||||
|  | if "%DIRNAME%"=="" set DIRNAME=. | ||||||
|  | set APP_BASE_NAME=%~n0 | ||||||
|  | set APP_HOME=%DIRNAME% | ||||||
|  |  | ||||||
|  | @rem Resolve any "." and ".." in APP_HOME to make it shorter. | ||||||
|  | for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi | ||||||
|  |  | ||||||
|  | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
|  | set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" | ||||||
|  |  | ||||||
|  | @rem Find java.exe | ||||||
|  | if defined JAVA_HOME goto findJavaFromJavaHome | ||||||
|  |  | ||||||
|  | set JAVA_EXE=java.exe | ||||||
|  | %JAVA_EXE% -version >NUL 2>&1 | ||||||
|  | if %ERRORLEVEL% equ 0 goto execute | ||||||
|  |  | ||||||
|  | echo. | ||||||
|  | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||||||
|  | echo. | ||||||
|  | echo Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | echo location of your Java installation. | ||||||
|  |  | ||||||
|  | goto fail | ||||||
|  |  | ||||||
|  | :findJavaFromJavaHome | ||||||
|  | set JAVA_HOME=%JAVA_HOME:"=% | ||||||
|  | set JAVA_EXE=%JAVA_HOME%/bin/java.exe | ||||||
|  |  | ||||||
|  | if exist "%JAVA_EXE%" goto execute | ||||||
|  |  | ||||||
|  | echo. | ||||||
|  | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | ||||||
|  | echo. | ||||||
|  | echo Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | echo location of your Java installation. | ||||||
|  |  | ||||||
|  | goto fail | ||||||
|  |  | ||||||
|  | :execute | ||||||
|  | @rem Setup the command line | ||||||
|  |  | ||||||
|  | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @rem Execute Gradle | ||||||
|  | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* | ||||||
|  |  | ||||||
|  | :end | ||||||
|  | @rem End local scope for the variables with windows NT shell | ||||||
|  | if %ERRORLEVEL% equ 0 goto mainEnd | ||||||
|  |  | ||||||
|  | :fail | ||||||
|  | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | ||||||
|  | rem the _cmd.exe /c_ return code! | ||||||
|  | set EXIT_CODE=%ERRORLEVEL% | ||||||
|  | if %EXIT_CODE% equ 0 set EXIT_CODE=1 | ||||||
|  | if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE% | ||||||
|  | exit /b %EXIT_CODE% | ||||||
|  |  | ||||||
|  | :mainEnd | ||||||
|  | if "%OS%"=="Windows_NT" endlocal | ||||||
|  |  | ||||||
|  | :omega | ||||||
							
								
								
									
										60
									
								
								.github/workflow-samples/gradle-plugin/plugin/build.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								.github/workflow-samples/gradle-plugin/plugin/build.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | |||||||
|  | /* | ||||||
|  |  * This file was generated by the Gradle 'init' task. | ||||||
|  |  * | ||||||
|  |  * This generated file contains a sample Gradle plugin project to get you started. | ||||||
|  |  * For more details take a look at the Writing Custom Plugins chapter in the Gradle | ||||||
|  |  * User Manual available at https://docs.gradle.org/7.3/userguide/custom_plugins.html | ||||||
|  |  * This project uses @Incubating APIs which are subject to change. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | plugins { | ||||||
|  |     // Apply the Java Gradle plugin development plugin to add support for developing Gradle plugins | ||||||
|  |     id 'java-gradle-plugin' | ||||||
|  | } | ||||||
|  |  | ||||||
|  | repositories { | ||||||
|  |     // Use Maven Central for resolving dependencies. | ||||||
|  |     mavenCentral() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | testing { | ||||||
|  |     suites { | ||||||
|  |         // Configure the built-in test suite | ||||||
|  |         test { | ||||||
|  |             // Use JUnit Jupiter test framework | ||||||
|  |             useJUnitJupiter('5.7.2') | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // Create a new test suite | ||||||
|  |         functionalTest(JvmTestSuite) { | ||||||
|  |             dependencies { | ||||||
|  |                 // functionalTest test suite depends on the production code in tests | ||||||
|  |                 implementation project | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             targets { | ||||||
|  |                 all { | ||||||
|  |                     // This test suite should run after the built-in test suite has run its tests | ||||||
|  |                     testTask.configure { shouldRunAfter(test) }  | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | gradlePlugin { | ||||||
|  |     // Define the plugin | ||||||
|  |     plugins { | ||||||
|  |         greeting { | ||||||
|  |             id = 'org.example.gradle.plugin.greeting' | ||||||
|  |             implementationClass = 'org.example.gradle.plugin.GradlePluginPlugin' | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | gradlePlugin.testSourceSets(sourceSets.functionalTest) | ||||||
|  |  | ||||||
|  | tasks.named('check') { | ||||||
|  |     // Include functionalTest as part of the check lifecycle | ||||||
|  |     dependsOn(testing.suites.functionalTest) | ||||||
|  | } | ||||||
| @@ -0,0 +1,57 @@ | |||||||
|  | /* | ||||||
|  |  * This Java source file was generated by the Gradle 'init' task. | ||||||
|  |  */ | ||||||
|  | package org.example.gradle.plugin; | ||||||
|  |  | ||||||
|  | import java.io.File; | ||||||
|  | import java.io.IOException; | ||||||
|  | import java.io.Writer; | ||||||
|  | import java.io.FileWriter; | ||||||
|  | import java.nio.file.Files; | ||||||
|  | import org.gradle.testkit.runner.GradleRunner; | ||||||
|  | import org.gradle.testkit.runner.BuildResult; | ||||||
|  | import org.junit.jupiter.api.Test; | ||||||
|  | import org.junit.jupiter.api.io.TempDir; | ||||||
|  | import static org.junit.jupiter.api.Assertions.*; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * A simple functional test for the 'org.example.gradle.plugin.greeting' plugin. | ||||||
|  |  */ | ||||||
|  | class GradlePluginPluginFunctionalTest { | ||||||
|  |     @TempDir | ||||||
|  |     File projectDir; | ||||||
|  |  | ||||||
|  |     private File getBuildFile() { | ||||||
|  |         return new File(projectDir, "build.gradle"); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private File getSettingsFile() { | ||||||
|  |         return new File(projectDir, "settings.gradle"); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Test void canRunTaskWithGradle691() throws IOException { | ||||||
|  |         writeString(getSettingsFile(), ""); | ||||||
|  |         writeString(getBuildFile(), | ||||||
|  |             "plugins {" + | ||||||
|  |             "  id('org.example.gradle.plugin.greeting')" + | ||||||
|  |             "}"); | ||||||
|  |  | ||||||
|  |         // Run the build | ||||||
|  |         GradleRunner runner = GradleRunner.create(); | ||||||
|  |         runner.forwardOutput(); | ||||||
|  |         runner.withGradleVersion("6.9.1"); | ||||||
|  |         runner.withPluginClasspath(); | ||||||
|  |         runner.withArguments("greeting"); | ||||||
|  |         runner.withProjectDir(projectDir); | ||||||
|  |         BuildResult result = runner.build(); | ||||||
|  |  | ||||||
|  |         // Verify the result | ||||||
|  |         assertTrue(result.getOutput().contains("Hello from plugin 'org.example.gradle.plugin.greeting'")); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private void writeString(File file, String string) throws IOException { | ||||||
|  |         try (Writer writer = new FileWriter(file)) { | ||||||
|  |             writer.write(string); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,19 @@ | |||||||
|  | /* | ||||||
|  |  * This Java source file was generated by the Gradle 'init' task. | ||||||
|  |  */ | ||||||
|  | package org.example.gradle.plugin; | ||||||
|  |  | ||||||
|  | import org.gradle.api.Project; | ||||||
|  | import org.gradle.api.Plugin; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * A simple 'hello world' plugin. | ||||||
|  |  */ | ||||||
|  | public class GradlePluginPlugin implements Plugin<Project> { | ||||||
|  |     public void apply(Project project) { | ||||||
|  |         // Register a task | ||||||
|  |         project.getTasks().register("greeting", task -> { | ||||||
|  |             task.doLast(s -> System.out.println("Hello from plugin 'org.example.gradle.plugin.greeting'")); | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,23 @@ | |||||||
|  | /* | ||||||
|  |  * This Java source file was generated by the Gradle 'init' task. | ||||||
|  |  */ | ||||||
|  | package org.example.gradle.plugin; | ||||||
|  |  | ||||||
|  | import org.gradle.testfixtures.ProjectBuilder; | ||||||
|  | import org.gradle.api.Project; | ||||||
|  | import org.junit.jupiter.api.Test; | ||||||
|  | import static org.junit.jupiter.api.Assertions.*; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * A simple unit test for the 'org.example.gradle.plugin.greeting' plugin. | ||||||
|  |  */ | ||||||
|  | class GradlePluginPluginTest { | ||||||
|  |     @Test void pluginRegistersATask() { | ||||||
|  |         // Create a test project and apply the plugin | ||||||
|  |         Project project = ProjectBuilder.builder().build(); | ||||||
|  |         project.getPlugins().apply("org.example.gradle.plugin.greeting"); | ||||||
|  |  | ||||||
|  |         // Verify the result | ||||||
|  |         assertNotNull(project.getTasks().findByName("greeting")); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										12
									
								
								.github/workflow-samples/gradle-plugin/settings.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								.github/workflow-samples/gradle-plugin/settings.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | /* | ||||||
|  |  * This file was generated by the Gradle 'init' task. | ||||||
|  |  * | ||||||
|  |  * The settings file is used to specify which projects to include in your build. | ||||||
|  |  * | ||||||
|  |  * Detailed information about configuring a multi-project build in Gradle can be found | ||||||
|  |  * in the user manual at https://docs.gradle.org/7.3/userguide/multi_project_builds.html | ||||||
|  |  * This project uses @Incubating APIs which are subject to change. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | rootProject.name = 'gradle-plugin' | ||||||
|  | include('plugin') | ||||||
							
								
								
									
										22
									
								
								.github/workflow-samples/groovy-dsl/build.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								.github/workflow-samples/groovy-dsl/build.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | plugins { | ||||||
|  |     id 'java' | ||||||
|  | } | ||||||
|  |  | ||||||
|  | repositories { | ||||||
|  |     mavenCentral() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | dependencies { | ||||||
|  |     testImplementation('junit:junit:4.13.2') | ||||||
|  | } | ||||||
|  |  | ||||||
|  | tasks.named("test").configure { | ||||||
|  |     // Write marker file so we can detect if task was configured | ||||||
|  |     file("task-configured.txt").text = "true" | ||||||
|  |  | ||||||
|  |     doLast { | ||||||
|  |         if (System.properties.verifyCachedBuild) { | ||||||
|  |             throw new RuntimeException("Build was not cached: unexpected execution of test task") | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										1
									
								
								.github/workflow-samples/groovy-dsl/gradle.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.github/workflow-samples/groovy-dsl/gradle.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | org.gradle.caching=true | ||||||
							
								
								
									
										
											BIN
										
									
								
								.github/workflow-samples/groovy-dsl/gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								.github/workflow-samples/groovy-dsl/gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										6
									
								
								.github/workflow-samples/groovy-dsl/gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								.github/workflow-samples/groovy-dsl/gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | distributionBase=GRADLE_USER_HOME | ||||||
|  | distributionPath=wrapper/dists | ||||||
|  | distributionSha256Sum=f6b8596b10cce501591e92f229816aa4046424f3b24d771751b06779d58c8ec4 | ||||||
|  | distributionUrl=https\://services.gradle.org/distributions/gradle-7.5.1-bin.zip | ||||||
|  | zipStoreBase=GRADLE_USER_HOME | ||||||
|  | zipStorePath=wrapper/dists | ||||||
							
								
								
									
										240
									
								
								.github/workflow-samples/groovy-dsl/gradlew
									
									
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										240
									
								
								.github/workflow-samples/groovy-dsl/gradlew
									
									
									
									
										vendored
									
									
										Executable file
									
								
							| @@ -0,0 +1,240 @@ | |||||||
|  | #!/bin/sh | ||||||
|  |  | ||||||
|  | # | ||||||
|  | # Copyright © 2015-2021 the original authors. | ||||||
|  | # | ||||||
|  | # Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | # you may not use this file except in compliance with the License. | ||||||
|  | # You may obtain a copy of the License at | ||||||
|  | # | ||||||
|  | #      https://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | # | ||||||
|  | # Unless required by applicable law or agreed to in writing, software | ||||||
|  | # distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | # See the License for the specific language governing permissions and | ||||||
|  | # limitations under the License. | ||||||
|  | # | ||||||
|  |  | ||||||
|  | ############################################################################## | ||||||
|  | # | ||||||
|  | #   Gradle start up script for POSIX generated by Gradle. | ||||||
|  | # | ||||||
|  | #   Important for running: | ||||||
|  | # | ||||||
|  | #   (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is | ||||||
|  | #       noncompliant, but you have some other compliant shell such as ksh or | ||||||
|  | #       bash, then to run this script, type that shell name before the whole | ||||||
|  | #       command line, like: | ||||||
|  | # | ||||||
|  | #           ksh Gradle | ||||||
|  | # | ||||||
|  | #       Busybox and similar reduced shells will NOT work, because this script | ||||||
|  | #       requires all of these POSIX shell features: | ||||||
|  | #         * functions; | ||||||
|  | #         * expansions «$var», «${var}», «${var:-default}», «${var+SET}», | ||||||
|  | #           «${var#prefix}», «${var%suffix}», and «$( cmd )»; | ||||||
|  | #         * compound commands having a testable exit status, especially «case»; | ||||||
|  | #         * various built-in commands including «command», «set», and «ulimit». | ||||||
|  | # | ||||||
|  | #   Important for patching: | ||||||
|  | # | ||||||
|  | #   (2) This script targets any POSIX shell, so it avoids extensions provided | ||||||
|  | #       by Bash, Ksh, etc; in particular arrays are avoided. | ||||||
|  | # | ||||||
|  | #       The "traditional" practice of packing multiple parameters into a | ||||||
|  | #       space-separated string is a well documented source of bugs and security | ||||||
|  | #       problems, so this is (mostly) avoided, by progressively accumulating | ||||||
|  | #       options in "$@", and eventually passing that to Java. | ||||||
|  | # | ||||||
|  | #       Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS, | ||||||
|  | #       and GRADLE_OPTS) rely on word-splitting, this is performed explicitly; | ||||||
|  | #       see the in-line comments for details. | ||||||
|  | # | ||||||
|  | #       There are tweaks for specific operating systems such as AIX, CygWin, | ||||||
|  | #       Darwin, MinGW, and NonStop. | ||||||
|  | # | ||||||
|  | #   (3) This script is generated from the Groovy template | ||||||
|  | #       https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt | ||||||
|  | #       within the Gradle project. | ||||||
|  | # | ||||||
|  | #       You can find Gradle at https://github.com/gradle/gradle/. | ||||||
|  | # | ||||||
|  | ############################################################################## | ||||||
|  |  | ||||||
|  | # Attempt to set APP_HOME | ||||||
|  |  | ||||||
|  | # Resolve links: $0 may be a link | ||||||
|  | app_path=$0 | ||||||
|  |  | ||||||
|  | # Need this for daisy-chained symlinks. | ||||||
|  | while | ||||||
|  |     APP_HOME=${app_path%"${app_path##*/}"}  # leaves a trailing /; empty if no leading path | ||||||
|  |     [ -h "$app_path" ] | ||||||
|  | do | ||||||
|  |     ls=$( ls -ld "$app_path" ) | ||||||
|  |     link=${ls#*' -> '} | ||||||
|  |     case $link in             #( | ||||||
|  |       /*)   app_path=$link ;; #( | ||||||
|  |       *)    app_path=$APP_HOME$link ;; | ||||||
|  |     esac | ||||||
|  | done | ||||||
|  |  | ||||||
|  | APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit | ||||||
|  |  | ||||||
|  | APP_NAME="Gradle" | ||||||
|  | APP_BASE_NAME=${0##*/} | ||||||
|  |  | ||||||
|  | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
|  | DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' | ||||||
|  |  | ||||||
|  | # Use the maximum available, or set MAX_FD != -1 to use that value. | ||||||
|  | MAX_FD=maximum | ||||||
|  |  | ||||||
|  | warn () { | ||||||
|  |     echo "$*" | ||||||
|  | } >&2 | ||||||
|  |  | ||||||
|  | die () { | ||||||
|  |     echo | ||||||
|  |     echo "$*" | ||||||
|  |     echo | ||||||
|  |     exit 1 | ||||||
|  | } >&2 | ||||||
|  |  | ||||||
|  | # OS specific support (must be 'true' or 'false'). | ||||||
|  | cygwin=false | ||||||
|  | msys=false | ||||||
|  | darwin=false | ||||||
|  | nonstop=false | ||||||
|  | case "$( uname )" in                #( | ||||||
|  |   CYGWIN* )         cygwin=true  ;; #( | ||||||
|  |   Darwin* )         darwin=true  ;; #( | ||||||
|  |   MSYS* | MINGW* )  msys=true    ;; #( | ||||||
|  |   NONSTOP* )        nonstop=true ;; | ||||||
|  | esac | ||||||
|  |  | ||||||
|  | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # Determine the Java command to use to start the JVM. | ||||||
|  | if [ -n "$JAVA_HOME" ] ; then | ||||||
|  |     if [ -x "$JAVA_HOME/jre/sh/java" ] ; then | ||||||
|  |         # IBM's JDK on AIX uses strange locations for the executables | ||||||
|  |         JAVACMD=$JAVA_HOME/jre/sh/java | ||||||
|  |     else | ||||||
|  |         JAVACMD=$JAVA_HOME/bin/java | ||||||
|  |     fi | ||||||
|  |     if [ ! -x "$JAVACMD" ] ; then | ||||||
|  |         die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME | ||||||
|  |  | ||||||
|  | Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | location of your Java installation." | ||||||
|  |     fi | ||||||
|  | else | ||||||
|  |     JAVACMD=java | ||||||
|  |     which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||||||
|  |  | ||||||
|  | Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | location of your Java installation." | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Increase the maximum file descriptors if we can. | ||||||
|  | if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then | ||||||
|  |     case $MAX_FD in #( | ||||||
|  |       max*) | ||||||
|  |         MAX_FD=$( ulimit -H -n ) || | ||||||
|  |             warn "Could not query maximum file descriptor limit" | ||||||
|  |     esac | ||||||
|  |     case $MAX_FD in  #( | ||||||
|  |       '' | soft) :;; #( | ||||||
|  |       *) | ||||||
|  |         ulimit -n "$MAX_FD" || | ||||||
|  |             warn "Could not set maximum file descriptor limit to $MAX_FD" | ||||||
|  |     esac | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Collect all arguments for the java command, stacking in reverse order: | ||||||
|  | #   * args from the command line | ||||||
|  | #   * the main class name | ||||||
|  | #   * -classpath | ||||||
|  | #   * -D...appname settings | ||||||
|  | #   * --module-path (only if needed) | ||||||
|  | #   * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables. | ||||||
|  |  | ||||||
|  | # For Cygwin or MSYS, switch paths to Windows format before running java | ||||||
|  | if "$cygwin" || "$msys" ; then | ||||||
|  |     APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) | ||||||
|  |     CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) | ||||||
|  |  | ||||||
|  |     JAVACMD=$( cygpath --unix "$JAVACMD" ) | ||||||
|  |  | ||||||
|  |     # Now convert the arguments - kludge to limit ourselves to /bin/sh | ||||||
|  |     for arg do | ||||||
|  |         if | ||||||
|  |             case $arg in                                #( | ||||||
|  |               -*)   false ;;                            # don't mess with options #( | ||||||
|  |               /?*)  t=${arg#/} t=/${t%%/*}              # looks like a POSIX filepath | ||||||
|  |                     [ -e "$t" ] ;;                      #( | ||||||
|  |               *)    false ;; | ||||||
|  |             esac | ||||||
|  |         then | ||||||
|  |             arg=$( cygpath --path --ignore --mixed "$arg" ) | ||||||
|  |         fi | ||||||
|  |         # Roll the args list around exactly as many times as the number of | ||||||
|  |         # args, so each arg winds up back in the position where it started, but | ||||||
|  |         # possibly modified. | ||||||
|  |         # | ||||||
|  |         # NB: a `for` loop captures its iteration list before it begins, so | ||||||
|  |         # changing the positional parameters here affects neither the number of | ||||||
|  |         # iterations, nor the values presented in `arg`. | ||||||
|  |         shift                   # remove old arg | ||||||
|  |         set -- "$@" "$arg"      # push replacement arg | ||||||
|  |     done | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Collect all arguments for the java command; | ||||||
|  | #   * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of | ||||||
|  | #     shell script including quotes and variable substitutions, so put them in | ||||||
|  | #     double quotes to make sure that they get re-expanded; and | ||||||
|  | #   * put everything else in single quotes, so that it's not re-expanded. | ||||||
|  |  | ||||||
|  | set -- \ | ||||||
|  |         "-Dorg.gradle.appname=$APP_BASE_NAME" \ | ||||||
|  |         -classpath "$CLASSPATH" \ | ||||||
|  |         org.gradle.wrapper.GradleWrapperMain \ | ||||||
|  |         "$@" | ||||||
|  |  | ||||||
|  | # Stop when "xargs" is not available. | ||||||
|  | if ! command -v xargs >/dev/null 2>&1 | ||||||
|  | then | ||||||
|  |     die "xargs is not available" | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Use "xargs" to parse quoted args. | ||||||
|  | # | ||||||
|  | # With -n1 it outputs one arg per line, with the quotes and backslashes removed. | ||||||
|  | # | ||||||
|  | # In Bash we could simply go: | ||||||
|  | # | ||||||
|  | #   readarray ARGS < <( xargs -n1 <<<"$var" ) && | ||||||
|  | #   set -- "${ARGS[@]}" "$@" | ||||||
|  | # | ||||||
|  | # but POSIX shell has neither arrays nor command substitution, so instead we | ||||||
|  | # post-process each arg (as a line of input to sed) to backslash-escape any | ||||||
|  | # character that might be a shell metacharacter, then use eval to reverse | ||||||
|  | # that process (while maintaining the separation between arguments), and wrap | ||||||
|  | # the whole thing up as a single "set" statement. | ||||||
|  | # | ||||||
|  | # This will of course break if any of these variables contains a newline or | ||||||
|  | # an unmatched quote. | ||||||
|  | # | ||||||
|  |  | ||||||
|  | eval "set -- $( | ||||||
|  |         printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" | | ||||||
|  |         xargs -n1 | | ||||||
|  |         sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' | | ||||||
|  |         tr '\n' ' ' | ||||||
|  |     )" '"$@"' | ||||||
|  |  | ||||||
|  | exec "$JAVACMD" "$@" | ||||||
							
								
								
									
										91
									
								
								.github/workflow-samples/groovy-dsl/gradlew.bat
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								.github/workflow-samples/groovy-dsl/gradlew.bat
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | |||||||
|  | @rem | ||||||
|  | @rem Copyright 2015 the original author or authors. | ||||||
|  | @rem | ||||||
|  | @rem Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | @rem you may not use this file except in compliance with the License. | ||||||
|  | @rem You may obtain a copy of the License at | ||||||
|  | @rem | ||||||
|  | @rem      https://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | @rem | ||||||
|  | @rem Unless required by applicable law or agreed to in writing, software | ||||||
|  | @rem distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | @rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | @rem See the License for the specific language governing permissions and | ||||||
|  | @rem limitations under the License. | ||||||
|  | @rem | ||||||
|  |  | ||||||
|  | @if "%DEBUG%"=="" @echo off | ||||||
|  | @rem ########################################################################## | ||||||
|  | @rem | ||||||
|  | @rem  Gradle startup script for Windows | ||||||
|  | @rem | ||||||
|  | @rem ########################################################################## | ||||||
|  |  | ||||||
|  | @rem Set local scope for the variables with windows NT shell | ||||||
|  | if "%OS%"=="Windows_NT" setlocal | ||||||
|  |  | ||||||
|  | set DIRNAME=%~dp0 | ||||||
|  | if "%DIRNAME%"=="" set DIRNAME=. | ||||||
|  | set APP_BASE_NAME=%~n0 | ||||||
|  | set APP_HOME=%DIRNAME% | ||||||
|  |  | ||||||
|  | @rem Resolve any "." and ".." in APP_HOME to make it shorter. | ||||||
|  | for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi | ||||||
|  |  | ||||||
|  | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
|  | set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" | ||||||
|  |  | ||||||
|  | @rem Find java.exe | ||||||
|  | if defined JAVA_HOME goto findJavaFromJavaHome | ||||||
|  |  | ||||||
|  | set JAVA_EXE=java.exe | ||||||
|  | %JAVA_EXE% -version >NUL 2>&1 | ||||||
|  | if %ERRORLEVEL% equ 0 goto execute | ||||||
|  |  | ||||||
|  | echo. | ||||||
|  | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||||||
|  | echo. | ||||||
|  | echo Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | echo location of your Java installation. | ||||||
|  |  | ||||||
|  | goto fail | ||||||
|  |  | ||||||
|  | :findJavaFromJavaHome | ||||||
|  | set JAVA_HOME=%JAVA_HOME:"=% | ||||||
|  | set JAVA_EXE=%JAVA_HOME%/bin/java.exe | ||||||
|  |  | ||||||
|  | if exist "%JAVA_EXE%" goto execute | ||||||
|  |  | ||||||
|  | echo. | ||||||
|  | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | ||||||
|  | echo. | ||||||
|  | echo Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | echo location of your Java installation. | ||||||
|  |  | ||||||
|  | goto fail | ||||||
|  |  | ||||||
|  | :execute | ||||||
|  | @rem Setup the command line | ||||||
|  |  | ||||||
|  | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @rem Execute Gradle | ||||||
|  | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* | ||||||
|  |  | ||||||
|  | :end | ||||||
|  | @rem End local scope for the variables with windows NT shell | ||||||
|  | if %ERRORLEVEL% equ 0 goto mainEnd | ||||||
|  |  | ||||||
|  | :fail | ||||||
|  | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | ||||||
|  | rem the _cmd.exe /c_ return code! | ||||||
|  | set EXIT_CODE=%ERRORLEVEL% | ||||||
|  | if %EXIT_CODE% equ 0 set EXIT_CODE=1 | ||||||
|  | if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE% | ||||||
|  | exit /b %EXIT_CODE% | ||||||
|  |  | ||||||
|  | :mainEnd | ||||||
|  | if "%OS%"=="Windows_NT" endlocal | ||||||
|  |  | ||||||
|  | :omega | ||||||
							
								
								
									
										14
									
								
								.github/workflow-samples/groovy-dsl/settings.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								.github/workflow-samples/groovy-dsl/settings.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | plugins { | ||||||
|  |     id "com.gradle.enterprise" version "3.11.2" | ||||||
|  |     id "com.gradle.common-custom-user-data-gradle-plugin" version "1.8.2" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | gradleEnterprise { | ||||||
|  |     buildScan { | ||||||
|  |         termsOfServiceUrl = "https://gradle.com/terms-of-service" | ||||||
|  |         termsOfServiceAgree = "yes" | ||||||
|  |         publishAlways() | ||||||
|  |         uploadInBackground = false | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | rootProject.name = 'groovy-dsl' | ||||||
							
								
								
									
										10
									
								
								.github/workflow-samples/groovy-dsl/src/test/java/basic/BasicTest.java
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								.github/workflow-samples/groovy-dsl/src/test/java/basic/BasicTest.java
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | |||||||
|  | package basic; | ||||||
|  |  | ||||||
|  | import org.junit.Test; | ||||||
|  |  | ||||||
|  | public class BasicTest { | ||||||
|  |     @Test | ||||||
|  |     public void test() { | ||||||
|  |         assert true; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										17
									
								
								.github/workflow-samples/java-toolchain/build.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								.github/workflow-samples/java-toolchain/build.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | plugins { | ||||||
|  |     id 'java' | ||||||
|  | } | ||||||
|  |  | ||||||
|  | java { | ||||||
|  |     toolchain { | ||||||
|  |         languageVersion = JavaLanguageVersion.of(16) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | repositories { | ||||||
|  |     mavenCentral() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | dependencies { | ||||||
|  |     testImplementation('junit:junit:4.13.2') | ||||||
|  | } | ||||||
							
								
								
									
										1
									
								
								.github/workflow-samples/java-toolchain/gradle.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.github/workflow-samples/java-toolchain/gradle.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | org.gradle.caching=true | ||||||
							
								
								
									
										
											BIN
										
									
								
								.github/workflow-samples/java-toolchain/gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								.github/workflow-samples/java-toolchain/gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										6
									
								
								.github/workflow-samples/java-toolchain/gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								.github/workflow-samples/java-toolchain/gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | distributionBase=GRADLE_USER_HOME | ||||||
|  | distributionPath=wrapper/dists | ||||||
|  | distributionSha256Sum=f6b8596b10cce501591e92f229816aa4046424f3b24d771751b06779d58c8ec4 | ||||||
|  | distributionUrl=https\://services.gradle.org/distributions/gradle-7.5.1-bin.zip | ||||||
|  | zipStoreBase=GRADLE_USER_HOME | ||||||
|  | zipStorePath=wrapper/dists | ||||||
							
								
								
									
										240
									
								
								.github/workflow-samples/java-toolchain/gradlew
									
									
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										240
									
								
								.github/workflow-samples/java-toolchain/gradlew
									
									
									
									
										vendored
									
									
										Executable file
									
								
							| @@ -0,0 +1,240 @@ | |||||||
|  | #!/bin/sh | ||||||
|  |  | ||||||
|  | # | ||||||
|  | # Copyright © 2015-2021 the original authors. | ||||||
|  | # | ||||||
|  | # Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | # you may not use this file except in compliance with the License. | ||||||
|  | # You may obtain a copy of the License at | ||||||
|  | # | ||||||
|  | #      https://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | # | ||||||
|  | # Unless required by applicable law or agreed to in writing, software | ||||||
|  | # distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | # See the License for the specific language governing permissions and | ||||||
|  | # limitations under the License. | ||||||
|  | # | ||||||
|  |  | ||||||
|  | ############################################################################## | ||||||
|  | # | ||||||
|  | #   Gradle start up script for POSIX generated by Gradle. | ||||||
|  | # | ||||||
|  | #   Important for running: | ||||||
|  | # | ||||||
|  | #   (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is | ||||||
|  | #       noncompliant, but you have some other compliant shell such as ksh or | ||||||
|  | #       bash, then to run this script, type that shell name before the whole | ||||||
|  | #       command line, like: | ||||||
|  | # | ||||||
|  | #           ksh Gradle | ||||||
|  | # | ||||||
|  | #       Busybox and similar reduced shells will NOT work, because this script | ||||||
|  | #       requires all of these POSIX shell features: | ||||||
|  | #         * functions; | ||||||
|  | #         * expansions «$var», «${var}», «${var:-default}», «${var+SET}», | ||||||
|  | #           «${var#prefix}», «${var%suffix}», and «$( cmd )»; | ||||||
|  | #         * compound commands having a testable exit status, especially «case»; | ||||||
|  | #         * various built-in commands including «command», «set», and «ulimit». | ||||||
|  | # | ||||||
|  | #   Important for patching: | ||||||
|  | # | ||||||
|  | #   (2) This script targets any POSIX shell, so it avoids extensions provided | ||||||
|  | #       by Bash, Ksh, etc; in particular arrays are avoided. | ||||||
|  | # | ||||||
|  | #       The "traditional" practice of packing multiple parameters into a | ||||||
|  | #       space-separated string is a well documented source of bugs and security | ||||||
|  | #       problems, so this is (mostly) avoided, by progressively accumulating | ||||||
|  | #       options in "$@", and eventually passing that to Java. | ||||||
|  | # | ||||||
|  | #       Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS, | ||||||
|  | #       and GRADLE_OPTS) rely on word-splitting, this is performed explicitly; | ||||||
|  | #       see the in-line comments for details. | ||||||
|  | # | ||||||
|  | #       There are tweaks for specific operating systems such as AIX, CygWin, | ||||||
|  | #       Darwin, MinGW, and NonStop. | ||||||
|  | # | ||||||
|  | #   (3) This script is generated from the Groovy template | ||||||
|  | #       https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt | ||||||
|  | #       within the Gradle project. | ||||||
|  | # | ||||||
|  | #       You can find Gradle at https://github.com/gradle/gradle/. | ||||||
|  | # | ||||||
|  | ############################################################################## | ||||||
|  |  | ||||||
|  | # Attempt to set APP_HOME | ||||||
|  |  | ||||||
|  | # Resolve links: $0 may be a link | ||||||
|  | app_path=$0 | ||||||
|  |  | ||||||
|  | # Need this for daisy-chained symlinks. | ||||||
|  | while | ||||||
|  |     APP_HOME=${app_path%"${app_path##*/}"}  # leaves a trailing /; empty if no leading path | ||||||
|  |     [ -h "$app_path" ] | ||||||
|  | do | ||||||
|  |     ls=$( ls -ld "$app_path" ) | ||||||
|  |     link=${ls#*' -> '} | ||||||
|  |     case $link in             #( | ||||||
|  |       /*)   app_path=$link ;; #( | ||||||
|  |       *)    app_path=$APP_HOME$link ;; | ||||||
|  |     esac | ||||||
|  | done | ||||||
|  |  | ||||||
|  | APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit | ||||||
|  |  | ||||||
|  | APP_NAME="Gradle" | ||||||
|  | APP_BASE_NAME=${0##*/} | ||||||
|  |  | ||||||
|  | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
|  | DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' | ||||||
|  |  | ||||||
|  | # Use the maximum available, or set MAX_FD != -1 to use that value. | ||||||
|  | MAX_FD=maximum | ||||||
|  |  | ||||||
|  | warn () { | ||||||
|  |     echo "$*" | ||||||
|  | } >&2 | ||||||
|  |  | ||||||
|  | die () { | ||||||
|  |     echo | ||||||
|  |     echo "$*" | ||||||
|  |     echo | ||||||
|  |     exit 1 | ||||||
|  | } >&2 | ||||||
|  |  | ||||||
|  | # OS specific support (must be 'true' or 'false'). | ||||||
|  | cygwin=false | ||||||
|  | msys=false | ||||||
|  | darwin=false | ||||||
|  | nonstop=false | ||||||
|  | case "$( uname )" in                #( | ||||||
|  |   CYGWIN* )         cygwin=true  ;; #( | ||||||
|  |   Darwin* )         darwin=true  ;; #( | ||||||
|  |   MSYS* | MINGW* )  msys=true    ;; #( | ||||||
|  |   NONSTOP* )        nonstop=true ;; | ||||||
|  | esac | ||||||
|  |  | ||||||
|  | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # Determine the Java command to use to start the JVM. | ||||||
|  | if [ -n "$JAVA_HOME" ] ; then | ||||||
|  |     if [ -x "$JAVA_HOME/jre/sh/java" ] ; then | ||||||
|  |         # IBM's JDK on AIX uses strange locations for the executables | ||||||
|  |         JAVACMD=$JAVA_HOME/jre/sh/java | ||||||
|  |     else | ||||||
|  |         JAVACMD=$JAVA_HOME/bin/java | ||||||
|  |     fi | ||||||
|  |     if [ ! -x "$JAVACMD" ] ; then | ||||||
|  |         die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME | ||||||
|  |  | ||||||
|  | Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | location of your Java installation." | ||||||
|  |     fi | ||||||
|  | else | ||||||
|  |     JAVACMD=java | ||||||
|  |     which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||||||
|  |  | ||||||
|  | Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | location of your Java installation." | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Increase the maximum file descriptors if we can. | ||||||
|  | if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then | ||||||
|  |     case $MAX_FD in #( | ||||||
|  |       max*) | ||||||
|  |         MAX_FD=$( ulimit -H -n ) || | ||||||
|  |             warn "Could not query maximum file descriptor limit" | ||||||
|  |     esac | ||||||
|  |     case $MAX_FD in  #( | ||||||
|  |       '' | soft) :;; #( | ||||||
|  |       *) | ||||||
|  |         ulimit -n "$MAX_FD" || | ||||||
|  |             warn "Could not set maximum file descriptor limit to $MAX_FD" | ||||||
|  |     esac | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Collect all arguments for the java command, stacking in reverse order: | ||||||
|  | #   * args from the command line | ||||||
|  | #   * the main class name | ||||||
|  | #   * -classpath | ||||||
|  | #   * -D...appname settings | ||||||
|  | #   * --module-path (only if needed) | ||||||
|  | #   * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables. | ||||||
|  |  | ||||||
|  | # For Cygwin or MSYS, switch paths to Windows format before running java | ||||||
|  | if "$cygwin" || "$msys" ; then | ||||||
|  |     APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) | ||||||
|  |     CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) | ||||||
|  |  | ||||||
|  |     JAVACMD=$( cygpath --unix "$JAVACMD" ) | ||||||
|  |  | ||||||
|  |     # Now convert the arguments - kludge to limit ourselves to /bin/sh | ||||||
|  |     for arg do | ||||||
|  |         if | ||||||
|  |             case $arg in                                #( | ||||||
|  |               -*)   false ;;                            # don't mess with options #( | ||||||
|  |               /?*)  t=${arg#/} t=/${t%%/*}              # looks like a POSIX filepath | ||||||
|  |                     [ -e "$t" ] ;;                      #( | ||||||
|  |               *)    false ;; | ||||||
|  |             esac | ||||||
|  |         then | ||||||
|  |             arg=$( cygpath --path --ignore --mixed "$arg" ) | ||||||
|  |         fi | ||||||
|  |         # Roll the args list around exactly as many times as the number of | ||||||
|  |         # args, so each arg winds up back in the position where it started, but | ||||||
|  |         # possibly modified. | ||||||
|  |         # | ||||||
|  |         # NB: a `for` loop captures its iteration list before it begins, so | ||||||
|  |         # changing the positional parameters here affects neither the number of | ||||||
|  |         # iterations, nor the values presented in `arg`. | ||||||
|  |         shift                   # remove old arg | ||||||
|  |         set -- "$@" "$arg"      # push replacement arg | ||||||
|  |     done | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Collect all arguments for the java command; | ||||||
|  | #   * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of | ||||||
|  | #     shell script including quotes and variable substitutions, so put them in | ||||||
|  | #     double quotes to make sure that they get re-expanded; and | ||||||
|  | #   * put everything else in single quotes, so that it's not re-expanded. | ||||||
|  |  | ||||||
|  | set -- \ | ||||||
|  |         "-Dorg.gradle.appname=$APP_BASE_NAME" \ | ||||||
|  |         -classpath "$CLASSPATH" \ | ||||||
|  |         org.gradle.wrapper.GradleWrapperMain \ | ||||||
|  |         "$@" | ||||||
|  |  | ||||||
|  | # Stop when "xargs" is not available. | ||||||
|  | if ! command -v xargs >/dev/null 2>&1 | ||||||
|  | then | ||||||
|  |     die "xargs is not available" | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Use "xargs" to parse quoted args. | ||||||
|  | # | ||||||
|  | # With -n1 it outputs one arg per line, with the quotes and backslashes removed. | ||||||
|  | # | ||||||
|  | # In Bash we could simply go: | ||||||
|  | # | ||||||
|  | #   readarray ARGS < <( xargs -n1 <<<"$var" ) && | ||||||
|  | #   set -- "${ARGS[@]}" "$@" | ||||||
|  | # | ||||||
|  | # but POSIX shell has neither arrays nor command substitution, so instead we | ||||||
|  | # post-process each arg (as a line of input to sed) to backslash-escape any | ||||||
|  | # character that might be a shell metacharacter, then use eval to reverse | ||||||
|  | # that process (while maintaining the separation between arguments), and wrap | ||||||
|  | # the whole thing up as a single "set" statement. | ||||||
|  | # | ||||||
|  | # This will of course break if any of these variables contains a newline or | ||||||
|  | # an unmatched quote. | ||||||
|  | # | ||||||
|  |  | ||||||
|  | eval "set -- $( | ||||||
|  |         printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" | | ||||||
|  |         xargs -n1 | | ||||||
|  |         sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' | | ||||||
|  |         tr '\n' ' ' | ||||||
|  |     )" '"$@"' | ||||||
|  |  | ||||||
|  | exec "$JAVACMD" "$@" | ||||||
							
								
								
									
										91
									
								
								.github/workflow-samples/java-toolchain/gradlew.bat
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								.github/workflow-samples/java-toolchain/gradlew.bat
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | |||||||
|  | @rem | ||||||
|  | @rem Copyright 2015 the original author or authors. | ||||||
|  | @rem | ||||||
|  | @rem Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | @rem you may not use this file except in compliance with the License. | ||||||
|  | @rem You may obtain a copy of the License at | ||||||
|  | @rem | ||||||
|  | @rem      https://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | @rem | ||||||
|  | @rem Unless required by applicable law or agreed to in writing, software | ||||||
|  | @rem distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | @rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | @rem See the License for the specific language governing permissions and | ||||||
|  | @rem limitations under the License. | ||||||
|  | @rem | ||||||
|  |  | ||||||
|  | @if "%DEBUG%"=="" @echo off | ||||||
|  | @rem ########################################################################## | ||||||
|  | @rem | ||||||
|  | @rem  Gradle startup script for Windows | ||||||
|  | @rem | ||||||
|  | @rem ########################################################################## | ||||||
|  |  | ||||||
|  | @rem Set local scope for the variables with windows NT shell | ||||||
|  | if "%OS%"=="Windows_NT" setlocal | ||||||
|  |  | ||||||
|  | set DIRNAME=%~dp0 | ||||||
|  | if "%DIRNAME%"=="" set DIRNAME=. | ||||||
|  | set APP_BASE_NAME=%~n0 | ||||||
|  | set APP_HOME=%DIRNAME% | ||||||
|  |  | ||||||
|  | @rem Resolve any "." and ".." in APP_HOME to make it shorter. | ||||||
|  | for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi | ||||||
|  |  | ||||||
|  | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
|  | set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" | ||||||
|  |  | ||||||
|  | @rem Find java.exe | ||||||
|  | if defined JAVA_HOME goto findJavaFromJavaHome | ||||||
|  |  | ||||||
|  | set JAVA_EXE=java.exe | ||||||
|  | %JAVA_EXE% -version >NUL 2>&1 | ||||||
|  | if %ERRORLEVEL% equ 0 goto execute | ||||||
|  |  | ||||||
|  | echo. | ||||||
|  | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||||||
|  | echo. | ||||||
|  | echo Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | echo location of your Java installation. | ||||||
|  |  | ||||||
|  | goto fail | ||||||
|  |  | ||||||
|  | :findJavaFromJavaHome | ||||||
|  | set JAVA_HOME=%JAVA_HOME:"=% | ||||||
|  | set JAVA_EXE=%JAVA_HOME%/bin/java.exe | ||||||
|  |  | ||||||
|  | if exist "%JAVA_EXE%" goto execute | ||||||
|  |  | ||||||
|  | echo. | ||||||
|  | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | ||||||
|  | echo. | ||||||
|  | echo Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | echo location of your Java installation. | ||||||
|  |  | ||||||
|  | goto fail | ||||||
|  |  | ||||||
|  | :execute | ||||||
|  | @rem Setup the command line | ||||||
|  |  | ||||||
|  | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @rem Execute Gradle | ||||||
|  | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* | ||||||
|  |  | ||||||
|  | :end | ||||||
|  | @rem End local scope for the variables with windows NT shell | ||||||
|  | if %ERRORLEVEL% equ 0 goto mainEnd | ||||||
|  |  | ||||||
|  | :fail | ||||||
|  | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | ||||||
|  | rem the _cmd.exe /c_ return code! | ||||||
|  | set EXIT_CODE=%ERRORLEVEL% | ||||||
|  | if %EXIT_CODE% equ 0 set EXIT_CODE=1 | ||||||
|  | if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE% | ||||||
|  | exit /b %EXIT_CODE% | ||||||
|  |  | ||||||
|  | :mainEnd | ||||||
|  | if "%OS%"=="Windows_NT" endlocal | ||||||
|  |  | ||||||
|  | :omega | ||||||
							
								
								
									
										1
									
								
								.github/workflow-samples/java-toolchain/settings.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.github/workflow-samples/java-toolchain/settings.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | rootProject.name = 'basic' | ||||||
							
								
								
									
										10
									
								
								.github/workflow-samples/java-toolchain/src/test/java/basic/BasicTest.java
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								.github/workflow-samples/java-toolchain/src/test/java/basic/BasicTest.java
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | |||||||
|  | package basic; | ||||||
|  |  | ||||||
|  | import org.junit.Test; | ||||||
|  |  | ||||||
|  | public class BasicTest { | ||||||
|  |     @Test | ||||||
|  |     public void test() { | ||||||
|  |         assert true; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										29
									
								
								.github/workflow-samples/kotlin-dsl/build.gradle.kts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								.github/workflow-samples/kotlin-dsl/build.gradle.kts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | |||||||
|  | plugins { | ||||||
|  |     `java-library` | ||||||
|  | } | ||||||
|  |  | ||||||
|  | repositories { | ||||||
|  |     mavenCentral() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | dependencies { | ||||||
|  |     api("org.apache.commons:commons-math3:3.6.1") | ||||||
|  |     implementation("com.google.guava:guava:31.1-jre") | ||||||
|  |  | ||||||
|  |     testImplementation("org.junit.jupiter:junit-jupiter:5.9.1") | ||||||
|  | } | ||||||
|  |  | ||||||
|  | tasks.test { | ||||||
|  |     useJUnitPlatform() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | tasks.named("test").configure { | ||||||
|  |     // Write marker file so we can detect if task was configured | ||||||
|  |     file("task-configured.txt").writeText("true") | ||||||
|  |  | ||||||
|  |     doLast { | ||||||
|  |         if (System.getProperties().containsKey("verifyCachedBuild")) { | ||||||
|  |             throw RuntimeException("Build was not cached: unexpected execution of test task") | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										1
									
								
								.github/workflow-samples/kotlin-dsl/gradle.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.github/workflow-samples/kotlin-dsl/gradle.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | org.gradle.caching=true | ||||||
							
								
								
									
										
											BIN
										
									
								
								.github/workflow-samples/kotlin-dsl/gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								.github/workflow-samples/kotlin-dsl/gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										6
									
								
								.github/workflow-samples/kotlin-dsl/gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								.github/workflow-samples/kotlin-dsl/gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | distributionBase=GRADLE_USER_HOME | ||||||
|  | distributionPath=wrapper/dists | ||||||
|  | distributionSha256Sum=f6b8596b10cce501591e92f229816aa4046424f3b24d771751b06779d58c8ec4 | ||||||
|  | distributionUrl=https\://services.gradle.org/distributions/gradle-7.5.1-bin.zip | ||||||
|  | zipStoreBase=GRADLE_USER_HOME | ||||||
|  | zipStorePath=wrapper/dists | ||||||
							
								
								
									
										240
									
								
								.github/workflow-samples/kotlin-dsl/gradlew
									
									
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										240
									
								
								.github/workflow-samples/kotlin-dsl/gradlew
									
									
									
									
										vendored
									
									
										Executable file
									
								
							| @@ -0,0 +1,240 @@ | |||||||
|  | #!/bin/sh | ||||||
|  |  | ||||||
|  | # | ||||||
|  | # Copyright © 2015-2021 the original authors. | ||||||
|  | # | ||||||
|  | # Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | # you may not use this file except in compliance with the License. | ||||||
|  | # You may obtain a copy of the License at | ||||||
|  | # | ||||||
|  | #      https://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | # | ||||||
|  | # Unless required by applicable law or agreed to in writing, software | ||||||
|  | # distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | # See the License for the specific language governing permissions and | ||||||
|  | # limitations under the License. | ||||||
|  | # | ||||||
|  |  | ||||||
|  | ############################################################################## | ||||||
|  | # | ||||||
|  | #   Gradle start up script for POSIX generated by Gradle. | ||||||
|  | # | ||||||
|  | #   Important for running: | ||||||
|  | # | ||||||
|  | #   (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is | ||||||
|  | #       noncompliant, but you have some other compliant shell such as ksh or | ||||||
|  | #       bash, then to run this script, type that shell name before the whole | ||||||
|  | #       command line, like: | ||||||
|  | # | ||||||
|  | #           ksh Gradle | ||||||
|  | # | ||||||
|  | #       Busybox and similar reduced shells will NOT work, because this script | ||||||
|  | #       requires all of these POSIX shell features: | ||||||
|  | #         * functions; | ||||||
|  | #         * expansions «$var», «${var}», «${var:-default}», «${var+SET}», | ||||||
|  | #           «${var#prefix}», «${var%suffix}», and «$( cmd )»; | ||||||
|  | #         * compound commands having a testable exit status, especially «case»; | ||||||
|  | #         * various built-in commands including «command», «set», and «ulimit». | ||||||
|  | # | ||||||
|  | #   Important for patching: | ||||||
|  | # | ||||||
|  | #   (2) This script targets any POSIX shell, so it avoids extensions provided | ||||||
|  | #       by Bash, Ksh, etc; in particular arrays are avoided. | ||||||
|  | # | ||||||
|  | #       The "traditional" practice of packing multiple parameters into a | ||||||
|  | #       space-separated string is a well documented source of bugs and security | ||||||
|  | #       problems, so this is (mostly) avoided, by progressively accumulating | ||||||
|  | #       options in "$@", and eventually passing that to Java. | ||||||
|  | # | ||||||
|  | #       Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS, | ||||||
|  | #       and GRADLE_OPTS) rely on word-splitting, this is performed explicitly; | ||||||
|  | #       see the in-line comments for details. | ||||||
|  | # | ||||||
|  | #       There are tweaks for specific operating systems such as AIX, CygWin, | ||||||
|  | #       Darwin, MinGW, and NonStop. | ||||||
|  | # | ||||||
|  | #   (3) This script is generated from the Groovy template | ||||||
|  | #       https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt | ||||||
|  | #       within the Gradle project. | ||||||
|  | # | ||||||
|  | #       You can find Gradle at https://github.com/gradle/gradle/. | ||||||
|  | # | ||||||
|  | ############################################################################## | ||||||
|  |  | ||||||
|  | # Attempt to set APP_HOME | ||||||
|  |  | ||||||
|  | # Resolve links: $0 may be a link | ||||||
|  | app_path=$0 | ||||||
|  |  | ||||||
|  | # Need this for daisy-chained symlinks. | ||||||
|  | while | ||||||
|  |     APP_HOME=${app_path%"${app_path##*/}"}  # leaves a trailing /; empty if no leading path | ||||||
|  |     [ -h "$app_path" ] | ||||||
|  | do | ||||||
|  |     ls=$( ls -ld "$app_path" ) | ||||||
|  |     link=${ls#*' -> '} | ||||||
|  |     case $link in             #( | ||||||
|  |       /*)   app_path=$link ;; #( | ||||||
|  |       *)    app_path=$APP_HOME$link ;; | ||||||
|  |     esac | ||||||
|  | done | ||||||
|  |  | ||||||
|  | APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit | ||||||
|  |  | ||||||
|  | APP_NAME="Gradle" | ||||||
|  | APP_BASE_NAME=${0##*/} | ||||||
|  |  | ||||||
|  | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
|  | DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' | ||||||
|  |  | ||||||
|  | # Use the maximum available, or set MAX_FD != -1 to use that value. | ||||||
|  | MAX_FD=maximum | ||||||
|  |  | ||||||
|  | warn () { | ||||||
|  |     echo "$*" | ||||||
|  | } >&2 | ||||||
|  |  | ||||||
|  | die () { | ||||||
|  |     echo | ||||||
|  |     echo "$*" | ||||||
|  |     echo | ||||||
|  |     exit 1 | ||||||
|  | } >&2 | ||||||
|  |  | ||||||
|  | # OS specific support (must be 'true' or 'false'). | ||||||
|  | cygwin=false | ||||||
|  | msys=false | ||||||
|  | darwin=false | ||||||
|  | nonstop=false | ||||||
|  | case "$( uname )" in                #( | ||||||
|  |   CYGWIN* )         cygwin=true  ;; #( | ||||||
|  |   Darwin* )         darwin=true  ;; #( | ||||||
|  |   MSYS* | MINGW* )  msys=true    ;; #( | ||||||
|  |   NONSTOP* )        nonstop=true ;; | ||||||
|  | esac | ||||||
|  |  | ||||||
|  | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # Determine the Java command to use to start the JVM. | ||||||
|  | if [ -n "$JAVA_HOME" ] ; then | ||||||
|  |     if [ -x "$JAVA_HOME/jre/sh/java" ] ; then | ||||||
|  |         # IBM's JDK on AIX uses strange locations for the executables | ||||||
|  |         JAVACMD=$JAVA_HOME/jre/sh/java | ||||||
|  |     else | ||||||
|  |         JAVACMD=$JAVA_HOME/bin/java | ||||||
|  |     fi | ||||||
|  |     if [ ! -x "$JAVACMD" ] ; then | ||||||
|  |         die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME | ||||||
|  |  | ||||||
|  | Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | location of your Java installation." | ||||||
|  |     fi | ||||||
|  | else | ||||||
|  |     JAVACMD=java | ||||||
|  |     which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||||||
|  |  | ||||||
|  | Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | location of your Java installation." | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Increase the maximum file descriptors if we can. | ||||||
|  | if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then | ||||||
|  |     case $MAX_FD in #( | ||||||
|  |       max*) | ||||||
|  |         MAX_FD=$( ulimit -H -n ) || | ||||||
|  |             warn "Could not query maximum file descriptor limit" | ||||||
|  |     esac | ||||||
|  |     case $MAX_FD in  #( | ||||||
|  |       '' | soft) :;; #( | ||||||
|  |       *) | ||||||
|  |         ulimit -n "$MAX_FD" || | ||||||
|  |             warn "Could not set maximum file descriptor limit to $MAX_FD" | ||||||
|  |     esac | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Collect all arguments for the java command, stacking in reverse order: | ||||||
|  | #   * args from the command line | ||||||
|  | #   * the main class name | ||||||
|  | #   * -classpath | ||||||
|  | #   * -D...appname settings | ||||||
|  | #   * --module-path (only if needed) | ||||||
|  | #   * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables. | ||||||
|  |  | ||||||
|  | # For Cygwin or MSYS, switch paths to Windows format before running java | ||||||
|  | if "$cygwin" || "$msys" ; then | ||||||
|  |     APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) | ||||||
|  |     CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) | ||||||
|  |  | ||||||
|  |     JAVACMD=$( cygpath --unix "$JAVACMD" ) | ||||||
|  |  | ||||||
|  |     # Now convert the arguments - kludge to limit ourselves to /bin/sh | ||||||
|  |     for arg do | ||||||
|  |         if | ||||||
|  |             case $arg in                                #( | ||||||
|  |               -*)   false ;;                            # don't mess with options #( | ||||||
|  |               /?*)  t=${arg#/} t=/${t%%/*}              # looks like a POSIX filepath | ||||||
|  |                     [ -e "$t" ] ;;                      #( | ||||||
|  |               *)    false ;; | ||||||
|  |             esac | ||||||
|  |         then | ||||||
|  |             arg=$( cygpath --path --ignore --mixed "$arg" ) | ||||||
|  |         fi | ||||||
|  |         # Roll the args list around exactly as many times as the number of | ||||||
|  |         # args, so each arg winds up back in the position where it started, but | ||||||
|  |         # possibly modified. | ||||||
|  |         # | ||||||
|  |         # NB: a `for` loop captures its iteration list before it begins, so | ||||||
|  |         # changing the positional parameters here affects neither the number of | ||||||
|  |         # iterations, nor the values presented in `arg`. | ||||||
|  |         shift                   # remove old arg | ||||||
|  |         set -- "$@" "$arg"      # push replacement arg | ||||||
|  |     done | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Collect all arguments for the java command; | ||||||
|  | #   * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of | ||||||
|  | #     shell script including quotes and variable substitutions, so put them in | ||||||
|  | #     double quotes to make sure that they get re-expanded; and | ||||||
|  | #   * put everything else in single quotes, so that it's not re-expanded. | ||||||
|  |  | ||||||
|  | set -- \ | ||||||
|  |         "-Dorg.gradle.appname=$APP_BASE_NAME" \ | ||||||
|  |         -classpath "$CLASSPATH" \ | ||||||
|  |         org.gradle.wrapper.GradleWrapperMain \ | ||||||
|  |         "$@" | ||||||
|  |  | ||||||
|  | # Stop when "xargs" is not available. | ||||||
|  | if ! command -v xargs >/dev/null 2>&1 | ||||||
|  | then | ||||||
|  |     die "xargs is not available" | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Use "xargs" to parse quoted args. | ||||||
|  | # | ||||||
|  | # With -n1 it outputs one arg per line, with the quotes and backslashes removed. | ||||||
|  | # | ||||||
|  | # In Bash we could simply go: | ||||||
|  | # | ||||||
|  | #   readarray ARGS < <( xargs -n1 <<<"$var" ) && | ||||||
|  | #   set -- "${ARGS[@]}" "$@" | ||||||
|  | # | ||||||
|  | # but POSIX shell has neither arrays nor command substitution, so instead we | ||||||
|  | # post-process each arg (as a line of input to sed) to backslash-escape any | ||||||
|  | # character that might be a shell metacharacter, then use eval to reverse | ||||||
|  | # that process (while maintaining the separation between arguments), and wrap | ||||||
|  | # the whole thing up as a single "set" statement. | ||||||
|  | # | ||||||
|  | # This will of course break if any of these variables contains a newline or | ||||||
|  | # an unmatched quote. | ||||||
|  | # | ||||||
|  |  | ||||||
|  | eval "set -- $( | ||||||
|  |         printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" | | ||||||
|  |         xargs -n1 | | ||||||
|  |         sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' | | ||||||
|  |         tr '\n' ' ' | ||||||
|  |     )" '"$@"' | ||||||
|  |  | ||||||
|  | exec "$JAVACMD" "$@" | ||||||
							
								
								
									
										91
									
								
								.github/workflow-samples/kotlin-dsl/gradlew.bat
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								.github/workflow-samples/kotlin-dsl/gradlew.bat
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | |||||||
|  | @rem | ||||||
|  | @rem Copyright 2015 the original author or authors. | ||||||
|  | @rem | ||||||
|  | @rem Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | @rem you may not use this file except in compliance with the License. | ||||||
|  | @rem You may obtain a copy of the License at | ||||||
|  | @rem | ||||||
|  | @rem      https://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | @rem | ||||||
|  | @rem Unless required by applicable law or agreed to in writing, software | ||||||
|  | @rem distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | @rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | @rem See the License for the specific language governing permissions and | ||||||
|  | @rem limitations under the License. | ||||||
|  | @rem | ||||||
|  |  | ||||||
|  | @if "%DEBUG%"=="" @echo off | ||||||
|  | @rem ########################################################################## | ||||||
|  | @rem | ||||||
|  | @rem  Gradle startup script for Windows | ||||||
|  | @rem | ||||||
|  | @rem ########################################################################## | ||||||
|  |  | ||||||
|  | @rem Set local scope for the variables with windows NT shell | ||||||
|  | if "%OS%"=="Windows_NT" setlocal | ||||||
|  |  | ||||||
|  | set DIRNAME=%~dp0 | ||||||
|  | if "%DIRNAME%"=="" set DIRNAME=. | ||||||
|  | set APP_BASE_NAME=%~n0 | ||||||
|  | set APP_HOME=%DIRNAME% | ||||||
|  |  | ||||||
|  | @rem Resolve any "." and ".." in APP_HOME to make it shorter. | ||||||
|  | for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi | ||||||
|  |  | ||||||
|  | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
|  | set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" | ||||||
|  |  | ||||||
|  | @rem Find java.exe | ||||||
|  | if defined JAVA_HOME goto findJavaFromJavaHome | ||||||
|  |  | ||||||
|  | set JAVA_EXE=java.exe | ||||||
|  | %JAVA_EXE% -version >NUL 2>&1 | ||||||
|  | if %ERRORLEVEL% equ 0 goto execute | ||||||
|  |  | ||||||
|  | echo. | ||||||
|  | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||||||
|  | echo. | ||||||
|  | echo Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | echo location of your Java installation. | ||||||
|  |  | ||||||
|  | goto fail | ||||||
|  |  | ||||||
|  | :findJavaFromJavaHome | ||||||
|  | set JAVA_HOME=%JAVA_HOME:"=% | ||||||
|  | set JAVA_EXE=%JAVA_HOME%/bin/java.exe | ||||||
|  |  | ||||||
|  | if exist "%JAVA_EXE%" goto execute | ||||||
|  |  | ||||||
|  | echo. | ||||||
|  | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | ||||||
|  | echo. | ||||||
|  | echo Please set the JAVA_HOME variable in your environment to match the | ||||||
|  | echo location of your Java installation. | ||||||
|  |  | ||||||
|  | goto fail | ||||||
|  |  | ||||||
|  | :execute | ||||||
|  | @rem Setup the command line | ||||||
|  |  | ||||||
|  | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @rem Execute Gradle | ||||||
|  | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* | ||||||
|  |  | ||||||
|  | :end | ||||||
|  | @rem End local scope for the variables with windows NT shell | ||||||
|  | if %ERRORLEVEL% equ 0 goto mainEnd | ||||||
|  |  | ||||||
|  | :fail | ||||||
|  | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | ||||||
|  | rem the _cmd.exe /c_ return code! | ||||||
|  | set EXIT_CODE=%ERRORLEVEL% | ||||||
|  | if %EXIT_CODE% equ 0 set EXIT_CODE=1 | ||||||
|  | if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE% | ||||||
|  | exit /b %EXIT_CODE% | ||||||
|  |  | ||||||
|  | :mainEnd | ||||||
|  | if "%OS%"=="Windows_NT" endlocal | ||||||
|  |  | ||||||
|  | :omega | ||||||
							
								
								
									
										16
									
								
								.github/workflow-samples/kotlin-dsl/settings.gradle.kts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								.github/workflow-samples/kotlin-dsl/settings.gradle.kts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | plugins { | ||||||
|  |     id("com.gradle.enterprise") version "3.11.2" | ||||||
|  |     id("com.gradle.common-custom-user-data-gradle-plugin") version "1.8.2" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | gradleEnterprise { | ||||||
|  |     buildScan { | ||||||
|  |         termsOfServiceUrl = "https://gradle.com/terms-of-service" | ||||||
|  |         termsOfServiceAgree = "yes" | ||||||
|  |         publishAlways() | ||||||
|  |         isUploadInBackground = false | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | rootProject.name = "kotlin-dsl" | ||||||
|  |  | ||||||
							
								
								
									
										10
									
								
								.github/workflow-samples/kotlin-dsl/src/main/java/com/example/Library.java
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								.github/workflow-samples/kotlin-dsl/src/main/java/com/example/Library.java
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | |||||||
|  | /* | ||||||
|  |  * This Java source file was generated by the Gradle 'init' task. | ||||||
|  |  */ | ||||||
|  | package com.example; | ||||||
|  |  | ||||||
|  | public class Library { | ||||||
|  |     public boolean someLibraryMethod() { | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								.github/workflow-samples/kotlin-dsl/src/test/java/com/example/LibraryTest.java
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								.github/workflow-samples/kotlin-dsl/src/test/java/com/example/LibraryTest.java
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | /* | ||||||
|  |  * This Java source file was generated by the Gradle 'init' task. | ||||||
|  |  */ | ||||||
|  | package com.example; | ||||||
|  |  | ||||||
|  | import org.junit.jupiter.api.Test; | ||||||
|  | import static org.junit.jupiter.api.Assertions.*; | ||||||
|  |  | ||||||
|  | class LibraryTest { | ||||||
|  |     @Test void someLibraryMethodReturnsTrue() { | ||||||
|  |         Library classUnderTest = new Library(); | ||||||
|  |         assertTrue(classUnderTest.someLibraryMethod(), "someLibraryMethod should return 'true'"); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										10
									
								
								.github/workflow-samples/no-wrapper-gradle-4/build.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								.github/workflow-samples/no-wrapper-gradle-4/build.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | |||||||
|  | plugins { | ||||||
|  |     id "com.gradle.build-scan" version "1.16" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | buildScan { | ||||||
|  |     termsOfServiceUrl = "https://gradle.com/terms-of-service" | ||||||
|  |     termsOfServiceAgree = "yes" | ||||||
|  |     publishAlways() | ||||||
|  | } | ||||||
|  |  | ||||||
							
								
								
									
										8
									
								
								.github/workflow-samples/no-wrapper-gradle-4/settings.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								.github/workflow-samples/no-wrapper-gradle-4/settings.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | rootProject.name = 'no-wrapper' | ||||||
|  |  | ||||||
|  | println "Using Gradle version: ${gradle.gradleVersion}" | ||||||
|  |  | ||||||
|  | def gradleVersionCheck = System.properties.gradleVersionCheck | ||||||
|  | if (gradleVersionCheck && gradle.gradleVersion != gradleVersionCheck) { | ||||||
|  |     throw new RuntimeException("Got the wrong version: expected ${gradleVersionCheck} but was ${gradle.gradleVersion}") | ||||||
|  | } | ||||||
							
								
								
									
										12
									
								
								.github/workflow-samples/no-wrapper-gradle-5/build.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								.github/workflow-samples/no-wrapper-gradle-5/build.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | plugins { | ||||||
|  |     id "com.gradle.build-scan" version "3.11.2"  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | gradleEnterprise { | ||||||
|  |     buildScan { | ||||||
|  |         termsOfServiceUrl = "https://gradle.com/terms-of-service" | ||||||
|  |         termsOfServiceAgree = "yes" | ||||||
|  |         publishAlways() | ||||||
|  |         uploadInBackground = false | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										8
									
								
								.github/workflow-samples/no-wrapper-gradle-5/settings.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								.github/workflow-samples/no-wrapper-gradle-5/settings.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | rootProject.name = 'no-wrapper' | ||||||
|  |  | ||||||
|  | println "Using Gradle version: ${gradle.gradleVersion}" | ||||||
|  |  | ||||||
|  | def gradleVersionCheck = System.properties.gradleVersionCheck | ||||||
|  | if (gradleVersionCheck && gradle.gradleVersion != gradleVersionCheck) { | ||||||
|  |     throw new RuntimeException("Got the wrong version: expected ${gradleVersionCheck} but was ${gradle.gradleVersion}") | ||||||
|  | } | ||||||
							
								
								
									
										1
									
								
								.github/workflow-samples/no-wrapper/build.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.github/workflow-samples/no-wrapper/build.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | // Required to keep dependabot happy | ||||||
							
								
								
									
										21
									
								
								.github/workflow-samples/no-wrapper/settings.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								.github/workflow-samples/no-wrapper/settings.gradle
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | plugins { | ||||||
|  |     id "com.gradle.enterprise" version "3.11.2" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | gradleEnterprise { | ||||||
|  |     buildScan { | ||||||
|  |         termsOfServiceUrl = "https://gradle.com/terms-of-service" | ||||||
|  |         termsOfServiceAgree = "yes" | ||||||
|  |         publishAlways() | ||||||
|  |         uploadInBackground = false | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | rootProject.name = 'no-wrapper' | ||||||
|  |  | ||||||
|  | println "Using Gradle version: ${gradle.gradleVersion}" | ||||||
|  |  | ||||||
|  | def gradleVersionCheck = System.properties.gradleVersionCheck | ||||||
|  | if (gradleVersionCheck && gradle.gradleVersion != gradleVersionCheck) { | ||||||
|  |     throw new RuntimeException("Got the wrong version: expected ${gradleVersionCheck} but was ${gradle.gradleVersion}") | ||||||
|  | } | ||||||
							
								
								
									
										25
									
								
								.github/workflows/checkin.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										25
									
								
								.github/workflows/checkin.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,25 +0,0 @@ | |||||||
| name: "PR Checks" |  | ||||||
| on: [pull_request, push] |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   check_pr: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - uses: actions/checkout@v1 |  | ||||||
|  |  | ||||||
|     - name: "npm ci" |  | ||||||
|       run: npm ci |  | ||||||
|  |  | ||||||
|     - name: "npm run build" |  | ||||||
|       run: npm run build |  | ||||||
|  |  | ||||||
|     - name: "npm run test" |  | ||||||
|       run: npm run test |  | ||||||
|  |  | ||||||
|     - name: "check for uncommitted changes" |  | ||||||
|       # Ensure no changes, but ignore node_modules dir since dev/fresh ci deps installed. |  | ||||||
|       run: | |  | ||||||
|         git diff --exit-code --stat -- . ':!node_modules' \ |  | ||||||
|         || (echo "##[error] found changed files after build. please 'npm run build && npm run format'" \ |  | ||||||
|                  "and check in all changes" \ |  | ||||||
|             && exit 1) |  | ||||||
							
								
								
									
										70
									
								
								.github/workflows/ci-codeql.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								.github/workflows/ci-codeql.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | |||||||
|  | # For most projects, this workflow file will not need changing; you simply need | ||||||
|  | # to commit it to your repository. | ||||||
|  | # | ||||||
|  | # You may wish to alter this file to override the set of languages analyzed, | ||||||
|  | # or to provide custom queries or build logic. | ||||||
|  | # | ||||||
|  | # ******** NOTE ******** | ||||||
|  | # We have attempted to detect the languages in your repository. Please check | ||||||
|  | # the `language` matrix defined below to confirm you have the correct set of | ||||||
|  | # supported CodeQL languages. | ||||||
|  | # | ||||||
|  | name: CI-codeql | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: [ main ] | ||||||
|  |   pull_request: | ||||||
|  |     # The branches below must be a subset of the branches above | ||||||
|  |     branches: [ main ] | ||||||
|  |   schedule: | ||||||
|  |     - cron: '25 23 * * 2' | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   analyze: | ||||||
|  |     name: Analyze | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     permissions: | ||||||
|  |       actions: read | ||||||
|  |       contents: read | ||||||
|  |       security-events: write | ||||||
|  |  | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         language: [ 'javascript' ] | ||||||
|  |         # CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python', 'ruby' ] | ||||||
|  |         # Learn more about CodeQL language support at https://git.io/codeql-language-support | ||||||
|  |  | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout repository | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|  |     # Initializes the CodeQL tools for scanning. | ||||||
|  |     - name: Initialize CodeQL | ||||||
|  |       uses: github/codeql-action/init@v2 | ||||||
|  |       with: | ||||||
|  |         languages: ${{ matrix.language }} | ||||||
|  |         # If you wish to specify custom queries, you can do so here or in a config file. | ||||||
|  |         # By default, queries listed here will override any specified in a config file. | ||||||
|  |         # Prefix the list here with "+" to use these queries and those in the config file. | ||||||
|  |         # queries: ./path/to/local/query, your-org/your-repo/queries@main | ||||||
|  |  | ||||||
|  |     # Autobuild attempts to build any compiled languages  (C/C++, C#, or Java). | ||||||
|  |     # If this step fails, then you should remove it and run the build manually (see below) | ||||||
|  |     - name: Autobuild | ||||||
|  |       uses: github/codeql-action/autobuild@v2 | ||||||
|  |  | ||||||
|  |     # ℹ️ Command-line programs to run using the OS shell. | ||||||
|  |     # 📚 https://git.io/JvXDl | ||||||
|  |  | ||||||
|  |     # ✏️ If the Autobuild fails above, remove it and uncomment the following three lines | ||||||
|  |     #    and modify them (or add more) to build your code if your project | ||||||
|  |     #    uses a compiled language | ||||||
|  |  | ||||||
|  |     #- run: | | ||||||
|  |     #   make bootstrap | ||||||
|  |     #   make release | ||||||
|  |  | ||||||
|  |     - name: Perform CodeQL Analysis | ||||||
|  |       uses: github/codeql-action/analyze@v2 | ||||||
							
								
								
									
										20
									
								
								.github/workflows/ci-dependency-review.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								.github/workflows/ci-dependency-review.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | # Dependency Review Action | ||||||
|  | # | ||||||
|  | # This Action will scan dependency manifest files that change as part of a Pull Request, surfacing known-vulnerable versions of the packages declared or updated in the PR. Once installed, if the workflow run is marked as required, PRs introducing known-vulnerable packages will be blocked from merging. | ||||||
|  | # | ||||||
|  | # Source repository: https://github.com/actions/dependency-review-action | ||||||
|  | # Public documentation: https://docs.github.com/en/code-security/supply-chain-security/understanding-your-software-supply-chain/about-dependency-review#dependency-review-enforcement | ||||||
|  | name: CI-dependency-review | ||||||
|  | on: [pull_request] | ||||||
|  |  | ||||||
|  | permissions: | ||||||
|  |   contents: read | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   dependency-review: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - name: 'Checkout Repository' | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |       - name: 'Dependency Review' | ||||||
|  |         uses: actions/dependency-review-action@v2 | ||||||
							
								
								
									
										80
									
								
								.github/workflows/ci-full-check.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										80
									
								
								.github/workflows/ci-full-check.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,80 @@ | |||||||
|  | name: CI-full-check | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_dispatch: | ||||||
|  |   pull_request: | ||||||
|  |     types: | ||||||
|  |       - assigned | ||||||
|  |       - review_requested | ||||||
|  |   push: | ||||||
|  |     branches:  | ||||||
|  |       - main | ||||||
|  |     paths: | ||||||
|  |       - '.github/**' | ||||||
|  |       - 'dist/**' | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   action-inputs: | ||||||
|  |     uses: ./.github/workflows/integ-test-action-inputs.yml | ||||||
|  |     with: | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- | ||||||
|  |  | ||||||
|  |   cache-cleanup: | ||||||
|  |     uses: ./.github/workflows/integ-test-cache-cleanup.yml | ||||||
|  |     with: | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- | ||||||
|  |  | ||||||
|  |   caching-config: | ||||||
|  |     uses: ./.github/workflows/integ-test-action-inputs-caching.yml | ||||||
|  |     with: | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- | ||||||
|  |  | ||||||
|  |   execution-with-caching: | ||||||
|  |     uses: ./.github/workflows/integ-test-execution-with-caching.yml | ||||||
|  |     with: | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- | ||||||
|  |  | ||||||
|  |   execution: | ||||||
|  |     uses: ./.github/workflows/integ-test-execution.yml | ||||||
|  |     with: | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- | ||||||
|  |  | ||||||
|  |   provision-gradle-versions: | ||||||
|  |     uses: ./.github/workflows/integ-test-provision-gradle-versions.yml | ||||||
|  |     with: | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- | ||||||
|  |  | ||||||
|  |   restore-configuration-cache: | ||||||
|  |     uses: ./.github/workflows/integ-test-restore-configuration-cache.yml | ||||||
|  |     with: | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- | ||||||
|  |  | ||||||
|  |   restore-custom-gradle-home: | ||||||
|  |     uses: ./.github/workflows/integ-test-restore-custom-gradle-home.yml | ||||||
|  |     with: | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- | ||||||
|  |  | ||||||
|  |   restore-containerized-gradle-home: | ||||||
|  |     uses: ./.github/workflows/integ-test-restore-containerized-gradle-home.yml | ||||||
|  |     with: | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- | ||||||
|  |  | ||||||
|  |   restore-gradle-home: | ||||||
|  |     uses: ./.github/workflows/integ-test-restore-gradle-home.yml | ||||||
|  |     with: | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- | ||||||
|  |  | ||||||
|  |   restore-java-toolchain: | ||||||
|  |     uses: ./.github/workflows/integ-test-restore-java-toolchain.yml | ||||||
|  |     with: | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- | ||||||
|  |  | ||||||
|  |   sample-kotlin-dsl: | ||||||
|  |     uses: ./.github/workflows/integ-test-sample-kotlin-dsl.yml | ||||||
|  |     with: | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- | ||||||
|  |  | ||||||
|  |   sample-gradle-plugin: | ||||||
|  |     uses: ./.github/workflows/integ-test-sample-gradle-plugin.yml | ||||||
|  |     with: | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- | ||||||
							
								
								
									
										26
									
								
								.github/workflows/ci-init-script-check.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								.github/workflows/ci-init-script-check.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | |||||||
|  | name: CI-init-script-check | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     paths: | ||||||
|  |       - '.github/workflows/ci-init-script-check.yml' | ||||||
|  |       - 'src/resources/init-scripts/**' | ||||||
|  |       - 'test/init-scripts/**' | ||||||
|  |   workflow_dispatch: | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   test-init-scripts: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Setup Java | ||||||
|  |       uses: actions/setup-java@v3 | ||||||
|  |       with: | ||||||
|  |         distribution: temurin | ||||||
|  |         java-version: 8 | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: gradle/gradle-build-action@v2 # Use a released version to avoid breakages | ||||||
|  |     - name: Run integration tests | ||||||
|  |       working-directory: test/init-scripts | ||||||
|  |       run: ./gradlew check | ||||||
							
								
								
									
										115
									
								
								.github/workflows/ci-quick-check.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										115
									
								
								.github/workflows/ci-quick-check.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,115 @@ | |||||||
|  | name: CI-quick-check | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_dispatch: | ||||||
|  |   push: | ||||||
|  |     branches-ignore: main | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   build-distribution: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Build and upload distribution | ||||||
|  |       uses: ./.github/actions/build-dist | ||||||
|  |  | ||||||
|  |   run-unit-tests: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Run tests | ||||||
|  |       run: | | ||||||
|  |         npm install | ||||||
|  |         npm run all | ||||||
|  |  | ||||||
|  |   action-inputs: | ||||||
|  |     needs: build-distribution | ||||||
|  |     uses: ./.github/workflows/integ-test-action-inputs.yml | ||||||
|  |     with: | ||||||
|  |       runner-os: '["ubuntu-latest"]' | ||||||
|  |       download-dist: true | ||||||
|  |  | ||||||
|  |   cache-cleanup: | ||||||
|  |     needs: build-distribution | ||||||
|  |     uses: ./.github/workflows/integ-test-cache-cleanup.yml | ||||||
|  |     with: | ||||||
|  |       runner-os: '["ubuntu-latest"]' | ||||||
|  |       download-dist: true | ||||||
|  |       cache-key-prefix: ${{github.run_number}}- # Requires a fresh cache entry each run | ||||||
|  |  | ||||||
|  |   caching-config: | ||||||
|  |     needs: build-distribution | ||||||
|  |     uses: ./.github/workflows/integ-test-action-inputs-caching.yml | ||||||
|  |     with: | ||||||
|  |       runner-os: '["ubuntu-latest"]' | ||||||
|  |       download-dist: true | ||||||
|  |  | ||||||
|  |   execution-with-caching: | ||||||
|  |     needs: build-distribution | ||||||
|  |     uses: ./.github/workflows/integ-test-execution-with-caching.yml | ||||||
|  |     with: | ||||||
|  |       runner-os: '["ubuntu-latest"]' | ||||||
|  |       download-dist: true | ||||||
|  |  | ||||||
|  |   execution: | ||||||
|  |     needs: build-distribution | ||||||
|  |     uses: ./.github/workflows/integ-test-execution.yml | ||||||
|  |     with: | ||||||
|  |       runner-os: '["ubuntu-latest"]' | ||||||
|  |       download-dist: true | ||||||
|  |  | ||||||
|  |   provision-gradle-versions: | ||||||
|  |     needs: build-distribution | ||||||
|  |     uses: ./.github/workflows/integ-test-provision-gradle-versions.yml | ||||||
|  |     with: | ||||||
|  |       runner-os: '["ubuntu-latest"]' | ||||||
|  |       download-dist: true | ||||||
|  |  | ||||||
|  |   restore-configuration-cache: | ||||||
|  |     needs: build-distribution | ||||||
|  |     uses: ./.github/workflows/integ-test-restore-configuration-cache.yml | ||||||
|  |     with: | ||||||
|  |       runner-os: '["ubuntu-latest"]' | ||||||
|  |       download-dist: true | ||||||
|  |  | ||||||
|  |   restore-containerized-gradle-home: | ||||||
|  |     needs: build-distribution | ||||||
|  |     uses: ./.github/workflows/integ-test-restore-containerized-gradle-home.yml | ||||||
|  |     with: | ||||||
|  |       download-dist: true | ||||||
|  |  | ||||||
|  |   restore-custom-gradle-home: | ||||||
|  |     needs: build-distribution | ||||||
|  |     uses: ./.github/workflows/integ-test-restore-custom-gradle-home.yml | ||||||
|  |     with: | ||||||
|  |       download-dist: true | ||||||
|  |  | ||||||
|  |   restore-gradle-home: | ||||||
|  |     needs: build-distribution | ||||||
|  |     uses: ./.github/workflows/integ-test-restore-gradle-home.yml | ||||||
|  |     with: | ||||||
|  |       runner-os: '["ubuntu-latest"]' | ||||||
|  |       download-dist: true | ||||||
|  |  | ||||||
|  |   restore-java-toolchain: | ||||||
|  |     needs: build-distribution | ||||||
|  |     uses: ./.github/workflows/integ-test-restore-java-toolchain.yml | ||||||
|  |     with: | ||||||
|  |       runner-os: '["ubuntu-latest"]' | ||||||
|  |       download-dist: true | ||||||
|  |  | ||||||
|  |   sample-kotlin-dsl: | ||||||
|  |     needs: build-distribution | ||||||
|  |     uses: ./.github/workflows/integ-test-sample-kotlin-dsl.yml | ||||||
|  |     with: | ||||||
|  |       runner-os: '["ubuntu-latest"]' | ||||||
|  |       download-dist: true | ||||||
|  |  | ||||||
|  |   sample-gradle-plugin: | ||||||
|  |     needs: build-distribution | ||||||
|  |     uses: ./.github/workflows/integ-test-sample-gradle-plugin.yml | ||||||
|  |     with: | ||||||
|  |       runner-os: '["ubuntu-latest"]' | ||||||
|  |       download-dist: true | ||||||
							
								
								
									
										38
									
								
								.github/workflows/ci-verify-outputs.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								.github/workflows/ci-verify-outputs.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | |||||||
|  | name: CI-verify-outputs | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   pull_request: | ||||||
|  |     types: | ||||||
|  |       - assigned | ||||||
|  |       - review_requested | ||||||
|  |   push: | ||||||
|  |     branches:  | ||||||
|  |       - main | ||||||
|  |       - dependabot/** | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   check: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Build | ||||||
|  |       run: | | ||||||
|  |         npm install | ||||||
|  |         npm run build | ||||||
|  |  | ||||||
|  |     - name: Compare the expected and actual dist/ directories | ||||||
|  |       run: | | ||||||
|  |         if [ "$(git diff --ignore-space-at-eol dist/ | wc -l)" -gt "0" ]; then | ||||||
|  |           echo "Detected uncommitted changes after build.  See status below:" | ||||||
|  |           git diff | ||||||
|  |           exit 1 | ||||||
|  |         fi | ||||||
|  |       id: diff | ||||||
|  |  | ||||||
|  |     # If index.js was different than expected, upload the expected version as an artifact | ||||||
|  |     - uses: actions/upload-artifact@v3 | ||||||
|  |       if: ${{ failure() && steps.diff.conclusion == 'failure' }} | ||||||
|  |       with: | ||||||
|  |         name: dist | ||||||
|  |         path: dist/ | ||||||
							
								
								
									
										43
									
								
								.github/workflows/demo-failure-cases.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								.github/workflows/demo-failure-cases.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | |||||||
|  | name: demo-failure-cases | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_dispatch: | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |  | ||||||
|  |   failing-build: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Test build failure | ||||||
|  |       uses: ./ | ||||||
|  |       continue-on-error: true | ||||||
|  |       with: | ||||||
|  |         build-root-directory: .github/workflow-samples/kotlin-dsl | ||||||
|  |         arguments: not-a-valid-task | ||||||
|  |  | ||||||
|  |   wrapper-missing: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Test wrapper missing | ||||||
|  |       uses: ./ | ||||||
|  |       continue-on-error: true | ||||||
|  |       with: | ||||||
|  |         build-root-directory: .github/workflow-samples/no-wrapper | ||||||
|  |         arguments: help | ||||||
|  |  | ||||||
|  |   bad-configuration: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Test bad config value | ||||||
|  |       uses: ./ | ||||||
|  |       continue-on-error: true | ||||||
|  |       with: | ||||||
|  |         build-root-directory: .github/workflow-samples/no-wrapper | ||||||
|  |         arguments: help | ||||||
|  |         cache-disabled: yes | ||||||
							
								
								
									
										43
									
								
								.github/workflows/demo-job-summary.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								.github/workflows/demo-job-summary.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | |||||||
|  | name: Demo Job Summary for Gradle builds | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_dispatch: | ||||||
|  |   push: | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   run-gradle-builds: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Build distribution | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         npm install | ||||||
|  |         npm run build | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |     - name: Build kotlin-dsl project | ||||||
|  |       working-directory: .github/workflow-samples/kotlin-dsl | ||||||
|  |       run: ./gradlew assemble | ||||||
|  |     - name: Build kotlin-dsl project without build scan | ||||||
|  |       working-directory: .github/workflow-samples/kotlin-dsl | ||||||
|  |       run: ./gradlew assemble check --no-scan | ||||||
|  |     - name: Build kotlin-dsl project with build scan publish failure | ||||||
|  |       working-directory: .github/workflow-samples/kotlin-dsl | ||||||
|  |       run: ./gradlew check -Dgradle.enterprise.url=https://not.valid.server | ||||||
|  |     - name: Build groovy-dsl project | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew assemble | ||||||
|  |     - name: Build kotlin-dsl project with multiple gradle invocations | ||||||
|  |       working-directory: .github/workflow-samples/kotlin-dsl | ||||||
|  |       run: |  | ||||||
|  |          ./gradlew tasks --no-daemon | ||||||
|  |          ./gradlew help check | ||||||
|  |     - name: Fail groovy-dsl project | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       continue-on-error: true | ||||||
|  |       run: ./gradlew not-a-real-task | ||||||
							
								
								
									
										27
									
								
								.github/workflows/demo-pr-build-scan-comment.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								.github/workflows/demo-pr-build-scan-comment.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | name: Demo adding build scan comment to PR | ||||||
|  | on: | ||||||
|  |   pull_request: | ||||||
|  |     types: [assigned, review_requested] | ||||||
|  | jobs: | ||||||
|  |   gradle: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout project sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |     - name: Run build with Gradle wrapper | ||||||
|  |       id: gradle | ||||||
|  |       working-directory: .github/workflow-samples/kotlin-dsl | ||||||
|  |       run: ./gradlew build --scan | ||||||
|  |     - name: "Add build scan URL as PR comment" | ||||||
|  |       uses: actions/github-script@v6 | ||||||
|  |       with: | ||||||
|  |         github-token: ${{secrets.GITHUB_TOKEN}} | ||||||
|  |         script: | | ||||||
|  |           github.rest.issues.createComment({ | ||||||
|  |             issue_number: context.issue.number, | ||||||
|  |             owner: context.repo.owner, | ||||||
|  |             repo: context.repo.repo, | ||||||
|  |             body: 'PR ready for review: ${{ steps.gradle.outputs.build-scan-url }}' | ||||||
|  |           }) | ||||||
							
								
								
									
										162
									
								
								.github/workflows/integ-test-action-inputs-caching.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										162
									
								
								.github/workflows/integ-test-action-inputs-caching.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,162 @@ | |||||||
|  | name: Test action inputs for caching | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_call: | ||||||
|  |     inputs: | ||||||
|  |       cache-key-prefix: | ||||||
|  |         type: string | ||||||
|  |       runner-os: | ||||||
|  |         type: string | ||||||
|  |         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' | ||||||
|  |       download-dist: | ||||||
|  |         type: boolean | ||||||
|  |         default: false | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   DOWNLOAD_DIST: ${{ inputs.download-dist }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: action-inputs-caching-${{ inputs.cache-key-prefix }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   seed-build: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |         # Add "enterprise" to main cache entry but omit "notifications" | ||||||
|  |         gradle-home-cache-includes: | | ||||||
|  |             caches | ||||||
|  |             enterprise | ||||||
|  |         # Exclude build-cache from main cache entry | ||||||
|  |         gradle-home-cache-excludes: | | ||||||
|  |             caches/build-cache-1 | ||||||
|  |     - name: Build using Gradle wrapper | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test | ||||||
|  |  | ||||||
|  |   # Test that the gradle-user-home cache will cache dependencies, by running build with --offline | ||||||
|  |   verify-build: | ||||||
|  |     needs: seed-build | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         # Use the same configuration as used in the seed build | ||||||
|  |         gradle-home-cache-includes: | | ||||||
|  |             caches | ||||||
|  |             enterprise | ||||||
|  |         gradle-home-cache-excludes: | | ||||||
|  |             caches/build-cache-1 | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Execute Gradle build with --offline | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test --offline | ||||||
|  |  | ||||||
|  |   # Test that build scans are captured when caching is explicitly disabled | ||||||
|  |   cache-disabled: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-disabled: true | ||||||
|  |     - name: Run Gradle build | ||||||
|  |       id: gradle | ||||||
|  |       working-directory: .github/workflow-samples/no-wrapper${{ matrix.build-root-suffix }} | ||||||
|  |       run: gradle help "-DgradleVersionCheck=${{matrix.gradle}}" | ||||||
|  |     - name: Check build scan url is captured | ||||||
|  |       if: ${{ !steps.gradle.outputs.build-scan-url }} | ||||||
|  |       uses: actions/github-script@v6 | ||||||
|  |       with: | ||||||
|  |         script: | | ||||||
|  |           core.setFailed('No build scan detected') | ||||||
|  |  | ||||||
|  |   # Test that build scans are captured when caching is disabled because Gradle User Home already exists | ||||||
|  |   cache-disabled-pre-existing-gradle-home: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Create dummy Gradle User Home | ||||||
|  |       run: mkdir -p ~/.gradle/caches | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |     - name: Run Gradle build | ||||||
|  |       id: gradle | ||||||
|  |       working-directory: .github/workflow-samples/no-wrapper${{ matrix.build-root-suffix }} | ||||||
|  |       run: gradle help "-DgradleVersionCheck=${{matrix.gradle}}" | ||||||
|  |     - name: Check build scan url is captured | ||||||
|  |       if: ${{ !steps.gradle.outputs.build-scan-url }} | ||||||
|  |       uses: actions/github-script@v6 | ||||||
|  |       with: | ||||||
|  |         script: | | ||||||
|  |           core.setFailed('No build scan detected') | ||||||
|  |  | ||||||
|  |   # Test seed the cache with cache-write-only and verify with cache-read-only | ||||||
|  |   seed-build-write-only: | ||||||
|  |     env: | ||||||
|  |       GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: ${{ inputs.cache-key-prefix }}-write-only- | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-write-only: true | ||||||
|  |     - name: Build using Gradle wrapper | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test | ||||||
|  |  | ||||||
|  |   verify-write-only-build: | ||||||
|  |     env: | ||||||
|  |       GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: ${{ inputs.cache-key-prefix }}-write-only- | ||||||
|  |     needs: seed-build-write-only | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Execute Gradle build with --offline | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test --offline | ||||||
|  |  | ||||||
							
								
								
									
										41
									
								
								.github/workflows/integ-test-action-inputs.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								.github/workflows/integ-test-action-inputs.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | |||||||
|  | name: Test action inputs | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_call: | ||||||
|  |     inputs: | ||||||
|  |       cache-key-prefix: | ||||||
|  |         type: string | ||||||
|  |       runner-os: | ||||||
|  |         type: string | ||||||
|  |         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' | ||||||
|  |       download-dist: | ||||||
|  |         type: boolean | ||||||
|  |         default: false | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   DOWNLOAD_DIST: ${{ inputs.download-dist }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: action-inputs-${{ inputs.cache-key-prefix }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   action-inputs: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Invoke with multi-line arguments | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         build-root-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |         arguments: | | ||||||
|  |             --configuration-cache | ||||||
|  |             --build-cache | ||||||
|  |             -DsystemProperty=FOO | ||||||
|  |             -PgradleProperty=BAR | ||||||
|  |             test | ||||||
|  |             jar | ||||||
							
								
								
									
										87
									
								
								.github/workflows/integ-test-cache-cleanup.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								.github/workflows/integ-test-cache-cleanup.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,87 @@ | |||||||
|  | name: Test cache cleanup | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_call: | ||||||
|  |     inputs: | ||||||
|  |       cache-key-prefix: | ||||||
|  |         type: string | ||||||
|  |       runner-os: | ||||||
|  |         type: string | ||||||
|  |         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' | ||||||
|  |       download-dist: | ||||||
|  |         type: boolean | ||||||
|  |         default: false | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   DOWNLOAD_DIST: ${{ inputs.download-dist }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: integ-test-cache-cleanup-${{ inputs.cache-key-prefix }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   full-build: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |     - name: Build with 3.1 | ||||||
|  |       working-directory: test/jest/resources/cache-cleanup | ||||||
|  |       run: gradle --no-daemon --build-cache -Dcommons_math3_version="3.1" build | ||||||
|  |  | ||||||
|  |   # Second build will use the cache from the first build, but cleanup should remove unused artifacts | ||||||
|  |   assemble-build: | ||||||
|  |     needs: full-build | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false | ||||||
|  |         gradle-home-cache-cleanup: true | ||||||
|  |     - name: Build with 3.1.1 | ||||||
|  |       working-directory: test/jest/resources/cache-cleanup | ||||||
|  |       run: gradle --no-daemon --build-cache -Dcommons_math3_version="3.1.1" build | ||||||
|  |  | ||||||
|  |   check-clean-cache: | ||||||
|  |     needs: assemble-build | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Report Gradle User Home | ||||||
|  |       run: du -hc ~/.gradle/caches/modules-2 | ||||||
|  |     - name: Verify cleaned cache | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         if [ ! -e ~/.gradle/caches/modules-2/files-2.1/org.apache.commons/commons-math3/3.1.1 ]; then | ||||||
|  |           echo "::error ::Should find commons-math3 3.1.1 in cache" | ||||||
|  |           exit 1 | ||||||
|  |         fi | ||||||
|  |         if [ -e ~/.gradle/caches/modules-2/files-2.1/org.apache.commons/commons-math3/3.1 ]; then | ||||||
|  |           echo "::error ::Should NOT find commons-math3 3.1 in cache" | ||||||
|  |           exit 1 | ||||||
|  |         fi | ||||||
							
								
								
									
										56
									
								
								.github/workflows/integ-test-execution-with-caching.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								.github/workflows/integ-test-execution-with-caching.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | |||||||
|  | name: Test execution with caching | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_call: | ||||||
|  |     inputs: | ||||||
|  |       cache-key-prefix: | ||||||
|  |         type: string | ||||||
|  |       runner-os: | ||||||
|  |         type: string | ||||||
|  |         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' | ||||||
|  |       download-dist: | ||||||
|  |         type: boolean | ||||||
|  |         default: false | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   DOWNLOAD_DIST: ${{ inputs.download-dist }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: execution-with-caching-${{ inputs.cache-key-prefix }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   seed-build: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Execute Gradle build | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |         build-root-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |         arguments: test | ||||||
|  |  | ||||||
|  |   # Test that the gradle-user-home is restored | ||||||
|  |   verify-build: | ||||||
|  |     needs: seed-build | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Execute Gradle build | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |         build-root-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |         arguments: test --offline -DverifyCachedBuild=true | ||||||
|  |  | ||||||
							
								
								
									
										94
									
								
								.github/workflows/integ-test-execution.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										94
									
								
								.github/workflows/integ-test-execution.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,94 @@ | |||||||
|  | name: Test execution | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_call: | ||||||
|  |     inputs: | ||||||
|  |       cache-key-prefix: | ||||||
|  |         type: string | ||||||
|  |       runner-os: | ||||||
|  |         type: string | ||||||
|  |         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' | ||||||
|  |       download-dist: | ||||||
|  |         type: boolean | ||||||
|  |         default: false | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   DOWNLOAD_DIST: ${{ inputs.download-dist }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: execution-${{ inputs.cache-key-prefix }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs:    | ||||||
|  |   # Tests for executing with different Gradle versions.  | ||||||
|  |   # Each build verifies that it is executed with the expected Gradle version. | ||||||
|  |   gradle-execution: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |         include: | ||||||
|  |           - os: windows-latest | ||||||
|  |             script-suffix: '.bat' | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Test use defined Gradle version | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |         gradle-version: 6.9 | ||||||
|  |         build-root-directory: .github/workflow-samples/no-wrapper | ||||||
|  |         arguments: help -DgradleVersionCheck=6.9 | ||||||
|  |     - name: Test use Gradle version alias | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         gradle-version: release-candidate | ||||||
|  |         build-root-directory: .github/workflow-samples/no-wrapper | ||||||
|  |         arguments: help | ||||||
|  |     - name: Test use defined Gradle executable | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         gradle-executable: .github/workflow-samples/groovy-dsl/gradlew${{ matrix.script-suffix }} | ||||||
|  |         build-root-directory: .github/workflow-samples/no-wrapper | ||||||
|  |         arguments: help | ||||||
|  |  | ||||||
|  |   gradle-versions: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         gradle: [7.5.1, 6.9.2, 5.6.4, 4.10.3, 3.5.1] | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |         include: | ||||||
|  |           - gradle: 5.6.4 | ||||||
|  |             build-root-suffix: -gradle-5 | ||||||
|  |           - gradle: 4.10.3 | ||||||
|  |             build-root-suffix: -gradle-4 | ||||||
|  |           - gradle: 3.5.1 | ||||||
|  |             build-root-suffix: -gradle-4 | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Java | ||||||
|  |       uses: actions/setup-java@v3 | ||||||
|  |       with: | ||||||
|  |         distribution: temurin | ||||||
|  |         java-version: 8 | ||||||
|  |     - name: Run Gradle build | ||||||
|  |       uses: ./ | ||||||
|  |       id: gradle | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |         gradle-version: ${{matrix.gradle}} | ||||||
|  |         build-root-directory: .github/workflow-samples/no-wrapper${{ matrix.build-root-suffix }} | ||||||
|  |         arguments: help -DgradleVersionCheck=${{matrix.gradle}} | ||||||
|  |     - name: Check build scan url | ||||||
|  |       if: ${{ !steps.gradle.outputs.build-scan-url }} | ||||||
|  |       uses: actions/github-script@v6 | ||||||
|  |       with: | ||||||
|  |         script: | | ||||||
|  |           core.setFailed('No build scan detected')     | ||||||
|  |    | ||||||
|  |     | ||||||
							
								
								
									
										98
									
								
								.github/workflows/integ-test-provision-gradle-versions.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										98
									
								
								.github/workflows/integ-test-provision-gradle-versions.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,98 @@ | |||||||
|  | name: Test provision Gradle versions | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_call: | ||||||
|  |     inputs: | ||||||
|  |       cache-key-prefix: | ||||||
|  |         type: string | ||||||
|  |       runner-os: | ||||||
|  |         type: string | ||||||
|  |         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' | ||||||
|  |       download-dist: | ||||||
|  |         type: boolean | ||||||
|  |         default: false | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   DOWNLOAD_DIST: ${{ inputs.download-dist }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: provision-gradle-versions-${{ inputs.cache-key-prefix }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs:    | ||||||
|  |   # Tests for executing with different Gradle versions.  | ||||||
|  |   # Each build verifies that it is executed with the expected Gradle version. | ||||||
|  |   provision-gradle: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |         include: | ||||||
|  |           - os: windows-latest | ||||||
|  |             script-suffix: '.bat' | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle with v6.9 | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |         gradle-version: 6.9 | ||||||
|  |     - name: Test uses Gradle v6.9 | ||||||
|  |       working-directory: .github/workflow-samples/no-wrapper | ||||||
|  |       run: gradle help "-DgradleVersionCheck=6.9" | ||||||
|  |     - name: Setup Gradle with v7.1.1 | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         gradle-version: 7.1.1 | ||||||
|  |     - name: Test uses Gradle v7.1.1 | ||||||
|  |       working-directory: .github/workflow-samples/no-wrapper | ||||||
|  |       run: gradle help "-DgradleVersionCheck=7.1.1" | ||||||
|  |     - name: Setup Gradle with release-candidate | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         gradle-version: release-candidate | ||||||
|  |     - name: Test use release-candidate | ||||||
|  |       working-directory: .github/workflow-samples/no-wrapper | ||||||
|  |       run: gradle help | ||||||
|  |    | ||||||
|  |   gradle-versions: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         gradle: [7.3, 6.9, 5.6.4, 4.10.3, 3.5.1] | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |         include: | ||||||
|  |           - gradle: 5.6.4 | ||||||
|  |             build-root-suffix: -gradle-5 | ||||||
|  |           - gradle: 4.10.3 | ||||||
|  |             build-root-suffix: -gradle-4 | ||||||
|  |           - gradle: 3.5.1 | ||||||
|  |             build-root-suffix: -gradle-4 | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Java | ||||||
|  |       uses: actions/setup-java@v3 | ||||||
|  |       with: | ||||||
|  |         distribution: temurin | ||||||
|  |         java-version: 8 | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |         gradle-version: ${{ matrix.gradle }} | ||||||
|  |     - name: Run Gradle build | ||||||
|  |       id: gradle | ||||||
|  |       working-directory: .github/workflow-samples/no-wrapper${{ matrix.build-root-suffix }} | ||||||
|  |       run: gradle help "-DgradleVersionCheck=${{matrix.gradle}}" | ||||||
|  |     - name: Check build scan url | ||||||
|  |       if: ${{ !steps.gradle.outputs.build-scan-url }} | ||||||
|  |       uses: actions/github-script@v6 | ||||||
|  |       with: | ||||||
|  |         script: | | ||||||
|  |           core.setFailed('No build scan detected')     | ||||||
|  |    | ||||||
|  |     | ||||||
							
								
								
									
										166
									
								
								.github/workflows/integ-test-restore-configuration-cache.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										166
									
								
								.github/workflows/integ-test-restore-configuration-cache.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,166 @@ | |||||||
|  | name: Test restore configuration-cache | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_call: | ||||||
|  |     inputs: | ||||||
|  |       cache-key-prefix: | ||||||
|  |         type: string | ||||||
|  |       runner-os: | ||||||
|  |         type: string | ||||||
|  |         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' | ||||||
|  |       download-dist: | ||||||
|  |         type: boolean | ||||||
|  |         default: false | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   DOWNLOAD_DIST: ${{ inputs.download-dist }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: restore-configuration-cache-${{ inputs.cache-key-prefix }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   seed-build-groovy: | ||||||
|  |     env: | ||||||
|  |       GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-cc-groovy | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |     - name: Groovy build with configuration-cache enabled | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test --configuration-cache | ||||||
|  |  | ||||||
|  |   verify-build-groovy: | ||||||
|  |     env: | ||||||
|  |       GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-cc-groovy | ||||||
|  |     needs: seed-build-groovy | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Groovy build with configuration-cache enabled | ||||||
|  |       id: execute | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test --configuration-cache | ||||||
|  |     - name: Check that configuration-cache was used | ||||||
|  |       uses: actions/github-script@v6 | ||||||
|  |       with: | ||||||
|  |         script: | | ||||||
|  |           const fs = require('fs') | ||||||
|  |           if (fs.existsSync('.github/workflow-samples/groovy-dsl/task-configured.txt')) { | ||||||
|  |             core.setFailed('Configuration cache was not used - task was configured unexpectedly') | ||||||
|  |           } | ||||||
|  |  | ||||||
|  |   # Check that the build can run when no extracted cache entries are restored | ||||||
|  |   gradle-user-home-not-fully-restored: | ||||||
|  |     env: | ||||||
|  |       GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-cc-groovy | ||||||
|  |     needs: seed-build-groovy | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle with no extracted cache entries restored | ||||||
|  |       uses: ./ | ||||||
|  |       env:  | ||||||
|  |         GRADLE_BUILD_ACTION_SKIP_RESTORE: "generated-gradle-jars|wrapper-zips|java-toolchains|instrumented-jars|dependencies|kotlin-dsl" | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Check execute Gradle build with configuration cache enabled (but not restored) | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test --configuration-cache | ||||||
|  |  | ||||||
|  |   seed-build-kotlin: | ||||||
|  |     env: | ||||||
|  |       GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-cc-kotlin | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |     - name: Execute 'help' with configuration-cache enabled | ||||||
|  |       working-directory: .github/workflow-samples/kotlin-dsl | ||||||
|  |       run: ./gradlew help --configuration-cache | ||||||
|  |  | ||||||
|  |   modify-build-kotlin: | ||||||
|  |     env: | ||||||
|  |       GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-cc-kotlin-modified | ||||||
|  |     needs: seed-build-kotlin | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |     - name: Execute 'test' with configuration-cache enabled | ||||||
|  |       working-directory: .github/workflow-samples/kotlin-dsl | ||||||
|  |       run: ./gradlew test --configuration-cache | ||||||
|  |  | ||||||
|  |   # Test restore configuration-cache from the third build invocation | ||||||
|  |   verify-build-kotlin: | ||||||
|  |     env: | ||||||
|  |       GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-cc-kotlin-modified | ||||||
|  |     needs: modify-build-kotlin | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Execute 'test' again with configuration-cache enabled | ||||||
|  |       id: execute | ||||||
|  |       working-directory: .github/workflow-samples/kotlin-dsl | ||||||
|  |       run: ./gradlew test --configuration-cache | ||||||
|  |     - name: Check that configuration-cache was used | ||||||
|  |       uses: actions/github-script@v6 | ||||||
|  |       with: | ||||||
|  |         script: | | ||||||
|  |           const fs = require('fs') | ||||||
|  |           if (fs.existsSync('.github/workflow-samples/kotlin-dsl/task-configured.txt')) { | ||||||
|  |             core.setFailed('Configuration cache was not used - task was configured unexpectedly') | ||||||
|  |           } | ||||||
|  |  | ||||||
							
								
								
									
										60
									
								
								.github/workflows/integ-test-restore-containerized-gradle-home.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								.github/workflows/integ-test-restore-containerized-gradle-home.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | |||||||
|  | name: Test restore custom Gradle Home | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_call: | ||||||
|  |     inputs: | ||||||
|  |       cache-key-prefix: | ||||||
|  |         type: string | ||||||
|  |       download-dist: | ||||||
|  |         type: boolean | ||||||
|  |         default: false | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   DOWNLOAD_DIST: ${{ inputs.download-dist }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: restore-custom-gradle-home-${{ inputs.cache-key-prefix }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   seed-build: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     container: fedora:latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Java | ||||||
|  |       uses: actions/setup-java@v3 | ||||||
|  |       with: | ||||||
|  |         java-version: 11 | ||||||
|  |         distribution: temurin | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |     - name: Build using Gradle wrapper | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test | ||||||
|  |  | ||||||
|  |   # Test that the gradle-user-home cache will cache dependencies, by running build with --offline | ||||||
|  |   dependencies-cache: | ||||||
|  |     needs: seed-build | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     container: fedora:latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Java | ||||||
|  |       uses: actions/setup-java@v3 | ||||||
|  |       with: | ||||||
|  |         java-version: 11 | ||||||
|  |         distribution: temurin | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Execute Gradle build with --offline | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test --offline | ||||||
							
								
								
									
										77
									
								
								.github/workflows/integ-test-restore-custom-gradle-home.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								.github/workflows/integ-test-restore-custom-gradle-home.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,77 @@ | |||||||
|  | name: Test restore custom Gradle Home | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_call: | ||||||
|  |     inputs: | ||||||
|  |       cache-key-prefix: | ||||||
|  |         type: string | ||||||
|  |       download-dist: | ||||||
|  |         type: boolean | ||||||
|  |         default: false | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   DOWNLOAD_DIST: ${{ inputs.download-dist }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: restore-custom-gradle-home-${{ inputs.cache-key-prefix }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   seed-build: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Set Gradle User Home | ||||||
|  |       run: | | ||||||
|  |         mkdir -p $GITHUB_WORKSPACE/gradle-user-home | ||||||
|  |         echo "GRADLE_USER_HOME=$GITHUB_WORKSPACE/gradle-user-home" >> $GITHUB_ENV | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |     - name: Build using Gradle wrapper | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test --info | ||||||
|  |  | ||||||
|  |   # Test that the gradle-user-home cache will cache dependencies, by running build with --offline | ||||||
|  |   dependencies-cache: | ||||||
|  |     needs: seed-build | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Set Gradle User Home | ||||||
|  |       run: | | ||||||
|  |         mkdir -p $GITHUB_WORKSPACE/gradle-user-home | ||||||
|  |         echo "GRADLE_USER_HOME=$GITHUB_WORKSPACE/gradle-user-home" >> $GITHUB_ENV | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Execute Gradle build with --offline | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test --offline --info | ||||||
|  |  | ||||||
|  |   # Test that the gradle-user-home cache will cache and restore local build-cache | ||||||
|  |   build-cache: | ||||||
|  |     needs: seed-build | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Set Gradle User Home | ||||||
|  |       run: | | ||||||
|  |         mkdir -p $GITHUB_WORKSPACE/gradle-user-home | ||||||
|  |         echo "GRADLE_USER_HOME=$GITHUB_WORKSPACE/gradle-user-home" >> $GITHUB_ENV | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Execute Gradle build and verify tasks from cache | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test -DverifyCachedBuild=true --info | ||||||
							
								
								
									
										101
									
								
								.github/workflows/integ-test-restore-gradle-home.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								.github/workflows/integ-test-restore-gradle-home.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,101 @@ | |||||||
|  | name: Test restore Gradle Home | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_call: | ||||||
|  |     inputs: | ||||||
|  |       cache-key-prefix: | ||||||
|  |         type: string | ||||||
|  |       runner-os: | ||||||
|  |         type: string | ||||||
|  |         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' | ||||||
|  |       download-dist: | ||||||
|  |         type: boolean | ||||||
|  |         default: false | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   DOWNLOAD_DIST: ${{ inputs.download-dist }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: restore-gradle-home-${{ inputs.cache-key-prefix }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_JOB: restore-gradle-home | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   seed-build: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |     - name: Build using Gradle wrapper | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test | ||||||
|  |  | ||||||
|  |   # Test that the gradle-user-home cache will cache dependencies, by running build with --offline | ||||||
|  |   dependencies-cache: | ||||||
|  |     needs: seed-build | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Execute Gradle build with --offline | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test --offline | ||||||
|  |  | ||||||
|  |   # Test that the gradle-user-home cache will cache and restore local build-cache | ||||||
|  |   build-cache: | ||||||
|  |     needs: seed-build | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Execute Gradle build and verify tasks from cache | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test -DverifyCachedBuild=true | ||||||
|  |  | ||||||
|  |   # Check that the build can run when Gradle User Home is not fully restored | ||||||
|  |   no-extracted-cache-entries-restored: | ||||||
|  |     needs: seed-build | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle with no extracted cache entries restored | ||||||
|  |       uses: ./ | ||||||
|  |       env:  | ||||||
|  |         GRADLE_BUILD_ACTION_SKIP_RESTORE: "generated-gradle-jars|wrapper-zips|java-toolchains|instrumented-jars|dependencies|kotlin-dsl" | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Check executee Gradle build | ||||||
|  |       working-directory: .github/workflow-samples/groovy-dsl | ||||||
|  |       run: ./gradlew test | ||||||
|  |  | ||||||
							
								
								
									
										57
									
								
								.github/workflows/integ-test-restore-java-toolchain.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								.github/workflows/integ-test-restore-java-toolchain.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | |||||||
|  | name: Test restore java toolchains | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_call: | ||||||
|  |     inputs: | ||||||
|  |       cache-key-prefix: | ||||||
|  |         type: string | ||||||
|  |       runner-os: | ||||||
|  |         type: string | ||||||
|  |         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' | ||||||
|  |       download-dist: | ||||||
|  |         type: boolean | ||||||
|  |         default: false | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   DOWNLOAD_DIST: ${{ inputs.download-dist }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: restore-java-toolchain-${{ inputs.cache-key-prefix }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   seed-build: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |     - name: Build using Gradle wrapper | ||||||
|  |       working-directory: .github/workflow-samples/java-toolchain | ||||||
|  |       run: ./gradlew test --info | ||||||
|  |  | ||||||
|  |   # Test that the gradle-user-home cache will cache the toolchain, by running build with --offline | ||||||
|  |   toolchain-cache: | ||||||
|  |     needs: seed-build | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Execute Gradle build with --offline | ||||||
|  |       working-directory: .github/workflow-samples/java-toolchain | ||||||
|  |       run: ./gradlew test --info --offline | ||||||
							
								
								
									
										56
									
								
								.github/workflows/integ-test-sample-gradle-plugin.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								.github/workflows/integ-test-sample-gradle-plugin.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | |||||||
|  | name: Test sample Gradle Plugin project | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_call: | ||||||
|  |     inputs: | ||||||
|  |       cache-key-prefix: | ||||||
|  |         type: string | ||||||
|  |       runner-os: | ||||||
|  |         type: string | ||||||
|  |         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' | ||||||
|  |       download-dist: | ||||||
|  |         type: boolean | ||||||
|  |         default: false | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   DOWNLOAD_DIST: ${{ inputs.download-dist }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: sample-gradle-plugin-${{ inputs.cache-key-prefix }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   seed-build: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |     - name: Build gradle-plugin project | ||||||
|  |       working-directory: .github/workflow-samples/gradle-plugin | ||||||
|  |       run: ./gradlew build | ||||||
|  |  | ||||||
|  |   verify-build: | ||||||
|  |     needs: seed-build | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Build gradle-plugin project | ||||||
|  |       working-directory: .github/workflow-samples/gradle-plugin | ||||||
|  |       run: ./gradlew build --offline | ||||||
							
								
								
									
										56
									
								
								.github/workflows/integ-test-sample-kotlin-dsl.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								.github/workflows/integ-test-sample-kotlin-dsl.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | |||||||
|  | name: Test sample Kotlin DSL project | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_call: | ||||||
|  |     inputs: | ||||||
|  |       cache-key-prefix: | ||||||
|  |         type: string | ||||||
|  |       runner-os: | ||||||
|  |         type: string | ||||||
|  |         default: '["ubuntu-latest", "windows-latest", "macos-latest"]' | ||||||
|  |       download-dist: | ||||||
|  |         type: boolean | ||||||
|  |         default: false | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   DOWNLOAD_DIST: ${{ inputs.download-dist }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX: sample-kotlin-dsl-${{ inputs.cache-key-prefix }} | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   seed-build: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: false # For testing, allow writing cache entries on non-default branches | ||||||
|  |     - name: Build kotlin-dsl project | ||||||
|  |       working-directory: .github/workflow-samples/kotlin-dsl | ||||||
|  |       run: ./gradlew build | ||||||
|  |  | ||||||
|  |   verify-build: | ||||||
|  |     needs: seed-build | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: ${{fromJSON(inputs.runner-os)}} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Download distribution if required | ||||||
|  |       uses: ./.github/actions/download-dist | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: ./ | ||||||
|  |       with: | ||||||
|  |         cache-read-only: true | ||||||
|  |     - name: Build kotlin-dsl project | ||||||
|  |       working-directory: .github/workflow-samples/kotlin-dsl | ||||||
|  |       run: ./gradlew build --offline | ||||||
							
								
								
									
										28
									
								
								.github/workflows/purge-old-workflow-runs.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								.github/workflows/purge-old-workflow-runs.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | |||||||
|  | name: Purge old workflow runs | ||||||
|  | on: | ||||||
|  |   workflow_dispatch: | ||||||
|  |     inputs: | ||||||
|  |       days: | ||||||
|  |         description: 'Purge runs older than days' | ||||||
|  |         required: true | ||||||
|  |         default: 30 | ||||||
|  |       minimum_runs: | ||||||
|  |         description: 'The minimum runs to keep for each workflow.' | ||||||
|  |         required: true | ||||||
|  |         default: 6 | ||||||
|  |       delete_workflow_pattern: | ||||||
|  |         description: 'The name of the workflow. if not set then it will target all workflows.' | ||||||
|  |         required: false | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   del_runs: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - name: Purge workflow runs | ||||||
|  |         uses: Mattraks/delete-workflow-runs@v2 | ||||||
|  |         with: | ||||||
|  |           token: ${{ github.token }} | ||||||
|  |           repository: ${{ github.repository }} | ||||||
|  |           retain_days: ${{ github.event.inputs.days }} | ||||||
|  |           keep_minimum_runs: ${{ github.event.inputs.minimum_runs }} | ||||||
|  |           delete_workflow_pattern: ${{ github.event.inputs.delete_workflow_pattern }} | ||||||
							
								
								
									
										20
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,5 +1,5 @@ | |||||||
| __tests__/runner/* | # Dependency directory | ||||||
| lib/ | node_modules | ||||||
|  |  | ||||||
| # Rest pulled from https://github.com/github/gitignore/blob/master/Node.gitignore | # Rest pulled from https://github.com/github/gitignore/blob/master/Node.gitignore | ||||||
| # Logs | # Logs | ||||||
| @@ -42,7 +42,6 @@ bower_components | |||||||
| build/Release | build/Release | ||||||
|  |  | ||||||
| # Dependency directories | # Dependency directories | ||||||
| node_modules/ |  | ||||||
| jspm_packages/ | jspm_packages/ | ||||||
|  |  | ||||||
| # TypeScript v1 declaration files | # TypeScript v1 declaration files | ||||||
| @@ -90,3 +89,18 @@ typings/ | |||||||
|  |  | ||||||
| # DynamoDB Local files | # DynamoDB Local files | ||||||
| .dynamodb/ | .dynamodb/ | ||||||
|  |  | ||||||
|  | # OS metadata | ||||||
|  | .DS_Store | ||||||
|  | Thumbs.db | ||||||
|  |  | ||||||
|  | # Ignore built ts files | ||||||
|  | __tests__/runner/* | ||||||
|  | # lib/**/* | ||||||
|  |  | ||||||
|  | # IntelliJ IDEA config files | ||||||
|  | .idea/ | ||||||
|  | *.iml | ||||||
|  |  | ||||||
|  | # ASDF tool configuration | ||||||
|  | .tool-versions | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								.prettierignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.prettierignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | dist/ | ||||||
|  | lib/ | ||||||
|  | node_modules/ | ||||||
							
								
								
									
										11
									
								
								.prettierrc.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								.prettierrc.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | { | ||||||
|  |     "printWidth": 120, | ||||||
|  |     "tabWidth": 4, | ||||||
|  |     "useTabs": false, | ||||||
|  |     "semi": false, | ||||||
|  |     "singleQuote": true, | ||||||
|  |     "trailingComma": "none", | ||||||
|  |     "bracketSpacing": false, | ||||||
|  |     "arrowParens": "avoid", | ||||||
|  |     "parser": "typescript" | ||||||
|  |   } | ||||||
							
								
								
									
										76
									
								
								CODE_OF_CONDUCT.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								CODE_OF_CONDUCT.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,76 @@ | |||||||
|  | # Contributor Covenant Code of Conduct | ||||||
|  |  | ||||||
|  | ## Our Pledge | ||||||
|  |  | ||||||
|  | In the interest of fostering an open and welcoming environment, we as | ||||||
|  | contributors and maintainers pledge to making participation in our project and | ||||||
|  | our community a harassment-free experience for everyone, regardless of age, body | ||||||
|  | size, disability, ethnicity, sex characteristics, gender identity and expression, | ||||||
|  | level of experience, education, socio-economic status, nationality, personal | ||||||
|  | appearance, race, religion, or sexual identity and orientation. | ||||||
|  |  | ||||||
|  | ## Our Standards | ||||||
|  |  | ||||||
|  | Examples of behavior that contributes to creating a positive environment | ||||||
|  | include: | ||||||
|  |  | ||||||
|  | * Using welcoming and inclusive language | ||||||
|  | * Being respectful of differing viewpoints and experiences | ||||||
|  | * Gracefully accepting constructive criticism | ||||||
|  | * Focusing on what is best for the community | ||||||
|  | * Showing empathy towards other community members | ||||||
|  |  | ||||||
|  | Examples of unacceptable behavior by participants include: | ||||||
|  |  | ||||||
|  | * The use of sexualized language or imagery and unwelcome sexual attention or | ||||||
|  |  advances | ||||||
|  | * Trolling, insulting/derogatory comments, and personal or political attacks | ||||||
|  | * Public or private harassment | ||||||
|  | * Publishing others' private information, such as a physical or electronic | ||||||
|  |  address, without explicit permission | ||||||
|  | * Other conduct which could reasonably be considered inappropriate in a | ||||||
|  |  professional setting | ||||||
|  |  | ||||||
|  | ## Our Responsibilities | ||||||
|  |  | ||||||
|  | Project maintainers are responsible for clarifying the standards of acceptable | ||||||
|  | behavior and are expected to take appropriate and fair corrective action in | ||||||
|  | response to any instances of unacceptable behavior. | ||||||
|  |  | ||||||
|  | Project maintainers have the right and responsibility to remove, edit, or | ||||||
|  | reject comments, commits, code, wiki edits, issues, and other contributions | ||||||
|  | that are not aligned to this Code of Conduct, or to ban temporarily or | ||||||
|  | permanently any contributor for other behaviors that they deem inappropriate, | ||||||
|  | threatening, offensive, or harmful. | ||||||
|  |  | ||||||
|  | ## Scope | ||||||
|  |  | ||||||
|  | This Code of Conduct applies both within project spaces and in public spaces | ||||||
|  | when an individual is representing the project or its community. Examples of | ||||||
|  | representing a project or community include using an official project e-mail | ||||||
|  | address, posting via an official social media account, or acting as an appointed | ||||||
|  | representative at an online or offline event. Representation of a project may be | ||||||
|  | further defined and clarified by project maintainers. | ||||||
|  |  | ||||||
|  | ## Enforcement | ||||||
|  |  | ||||||
|  | Instances of abusive, harassing, or otherwise unacceptable behavior may be | ||||||
|  | reported by contacting the project team at paul@nosphere.org. All | ||||||
|  | complaints will be reviewed and investigated and will result in a response that | ||||||
|  | is deemed necessary and appropriate to the circumstances. The project team is | ||||||
|  | obligated to maintain confidentiality with regard to the reporter of an incident. | ||||||
|  | Further details of specific enforcement policies may be posted separately. | ||||||
|  |  | ||||||
|  | Project maintainers who do not follow or enforce the Code of Conduct in good | ||||||
|  | faith may face temporary or permanent repercussions as determined by other | ||||||
|  | members of the project's leadership. | ||||||
|  |  | ||||||
|  | ## Attribution | ||||||
|  |  | ||||||
|  | This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, | ||||||
|  | available at https://www.contributor-covenant.org/version/1/4/code-of-conduct.html | ||||||
|  |  | ||||||
|  | [homepage]: https://www.contributor-covenant.org | ||||||
|  |  | ||||||
|  | For answers to common questions about this code of conduct, see | ||||||
|  | https://www.contributor-covenant.org/faq | ||||||
							
								
								
									
										14
									
								
								CONTRIBUTING.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								CONTRIBUTING.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | ### How to merge a Dependabot PR | ||||||
|  |  | ||||||
|  | The "distribution" for a GitHub Action is checked into the repository itself.  | ||||||
|  | In the case of the `gradle-build-action`, the transpiled sources are committed to the `dist` directory.  | ||||||
|  | Any production dependencies are inlined into the distribution.  | ||||||
|  | So if a Dependabot PR updates a production dependency (or a dev dependency that changes the distribution, like the Typescript compiler),  | ||||||
|  | then a manual step is required to rebuild the dist and commit. | ||||||
|  |  | ||||||
|  | The simplest process to follow is: | ||||||
|  | 1. Checkout the dependabot branch locally eg: `git checkout dependabot/npm_and_yarn/actions/github-5.1.0` | ||||||
|  | 2. Run `npm install` to download and the new dependencies and install locally | ||||||
|  | 3. Run `npm run build` to regenerate the distribution | ||||||
|  | 4. Push the changes to the dependabot branch | ||||||
|  | 5. If/when the checks pass, you can merge the dependabot PR | ||||||
							
								
								
									
										416
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										416
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,16 +1,17 @@ | |||||||
| # Execute Gradle commands in Github Actions workflows | # Execute Gradle builds in GitHub Actions workflows | ||||||
|  |  | ||||||
| This Github Action can be used to run arbitrary Gradle commands on any platform supported by Github Actions. | This GitHub Action can be used to configure Gradle and optionally execute a Gradle build on any platform supported by GitHub Actions. | ||||||
|  |  | ||||||
|  | ## Use the action to setup Gradle | ||||||
|  |  | ||||||
| ## Usage | If you have an existing workflow invoking Gradle, you can add an initial "Setup Gradle" Step to benefit from caching,  | ||||||
|  | build-scan capture and other features of the gradle-build-action. | ||||||
|  |  | ||||||
| The following workflow will run `gradle build` using the wrapper from the repository on ubuntu, macos and windows: | All subsequent Gradle invocations will benefit from this initial setup, via `init` scripts added to the Gradle User Home. | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| // .github/workflows/gradle-build-pr.yml |  | ||||||
| name: Run Gradle on PRs | name: Run Gradle on PRs | ||||||
| on: pull-request | on: pull_request | ||||||
| jobs: | jobs: | ||||||
|   gradle: |   gradle: | ||||||
|     strategy: |     strategy: | ||||||
| @@ -18,86 +19,61 @@ jobs: | |||||||
|         os: [ubuntu-latest, macos-latest, windows-latest] |         os: [ubuntu-latest, macos-latest, windows-latest] | ||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
|     steps: |     steps: | ||||||
|     - uses: actions/checkout@v1 |     - uses: actions/checkout@v3 | ||||||
|     - uses: actions/setup-java@v1 |     - uses: actions/setup-java@v3 | ||||||
|       with: |       with: | ||||||
|  |         distribution: temurin | ||||||
|         java-version: 11 |         java-version: 11 | ||||||
|     - uses: eskatos/gradle-command-action@v1 |          | ||||||
|       with: |     - name: Setup Gradle | ||||||
|         arguments: build |       uses: gradle/gradle-build-action@v2 | ||||||
|  |      | ||||||
|  |     - name: Execute Gradle build | ||||||
|  |       run: ./gradlew build | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ## Gradle arguments | ## Why use the `gradle-build-action`? | ||||||
|  |  | ||||||
| The `arguments` input can used to pass arbitrary arguments to the `gradle` command line. | It is possible to directly invoke Gradle in your workflow, and the `actions/setup-java@v3` action provides a simple way to cache Gradle dependencies.  | ||||||
|  |  | ||||||
| Here are some valid examples: | However, the `gradle-build-action` offers a number of advantages over this approach: | ||||||
| ```yaml |  | ||||||
| arguments: build |  | ||||||
| arguments: check --scan |  | ||||||
| arguments: some arbitrary tasks |  | ||||||
| arguments: build -PgradleProperty=foo |  | ||||||
| arguments: build -DsystemProperty=bar |  | ||||||
| .... |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| See `gradle --help` for more information. | - Easily [run the build with different versions of Gradle](#download-install-and-use-a-specific-gradle-version) using the `gradle-version` parameter. Gradle distributions are automatically downloaded and cached.  | ||||||
|  | - More sophisticated and more efficient caching of Gradle User Home between invocations, compared to `setup-java` and most custom configurations using `actions/cache`. [More details below](#caching). | ||||||
|  | - Detailed reporting of cache usage and cache configuration options allow you to [optimize the use of the GitHub actions cache](#optimizing-cache-effectiveness). | ||||||
|  | - [Automatic capture of build scan links](#build-scans) from the build, making these easier to locate for workflow run. | ||||||
|  |  | ||||||
| If you need to pass environment variables, simply use the Github Actions workflow syntax: | The `gradle-build-action` is designed to provide these benefits with minimal configuration.  | ||||||
|  | These features work both when Gradle is executed via the `gradle-build-action` and for any Gradle execution in subsequent steps. | ||||||
|  |  | ||||||
|  | When using `gradle-build-action` we recommend that you _not_ use `actions/cache` or `actions/setup-java@v3` to explicitly cache the Gradle User Home. Doing so may interfere with the caching provided by this action. | ||||||
|  |  | ||||||
|  | ## Use a specific Gradle version | ||||||
|  |  | ||||||
|  | The `gradle-build-action` can download and install a specified Gradle version, adding this installed version to the PATH. | ||||||
|  | Downloaded Gradle versions are stored in the GitHub Actions cache, to avoid requiring downloading again later. | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: eskatos/gradle-command-action@v1 |  - uses: gradle/gradle-build-action@v2 | ||||||
|   env: |  | ||||||
|     CI: true |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Run a build from a different directory |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
| - uses: eskatos/gradle-command-action@v1 |  | ||||||
|   with: |  | ||||||
|     build-root-directory: some/subdirectory |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Use a Gradle wrapper from a different directory |  | ||||||
|   |  | ||||||
| ```yaml |  | ||||||
|  - uses: eskatos/gradle-command-action@v1 |  | ||||||
|    with: |    with: | ||||||
|      wrapper-directory: path/to/wrapper-directory |      gradle-version: 6.5 | ||||||
|  ``` |  | ||||||
|  |  | ||||||
| ## Use a specific `gradle` executable |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
|  - uses: eskatos/gradle-command-action@v1 |  | ||||||
|    with: |  | ||||||
|      gradle-executable: path/to/gradle |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ## Setup and use a declared Gradle version | The `gradle-version` parameter can be set to any valid Gradle version. | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
|  - uses: eskatos/gradle-command-action@v1 |  | ||||||
|    with: |  | ||||||
|      gradle-version: 5.6.2 |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| `gradle-version` can be set to any valid Gradle version. |  | ||||||
|  |  | ||||||
| Moreover, you can use the following aliases: | Moreover, you can use the following aliases: | ||||||
|  |  | ||||||
| | Alias | Selects | | | Alias | Selects | | ||||||
| | --- |---| | | --- |---| | ||||||
| | `current`      | The current [stable release](https://gradle.org/install/) | | | `wrapper`           | The Gradle wrapper's version (default, useful for matrix builds) | | ||||||
| | `rc`      | The current [release candidate](https://gradle.org/release-candidate/) if any, otherwise fallback to `current` | | | `current`           | The current [stable release](https://gradle.org/install/) | | ||||||
| | `nightly` | The latest [nightly](https://gradle.org/nightly/), fails if none. | | | `release-candidate` | The current [release candidate](https://gradle.org/release-candidate/) if any, otherwise fallback to `current` | | ||||||
| | `release-nightly` | The latest [release nightly](https://gradle.org/release-nightly/), fails if none.      | | | `nightly`           | The latest [nightly](https://gradle.org/nightly/), fails if none. | | ||||||
|  | | `release-nightly`   | The latest [release nightly](https://gradle.org/release-nightly/), fails if none.      | | ||||||
|  |  | ||||||
| This can be handy to automatically test your build with the next Gradle version once a release candidate is out: | This can be handy to automatically verify your build works with the latest release candidate of Gradle: | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| // .github/workflows/test-gradle-rc.yml |  | ||||||
| name: Test latest Gradle RC | name: Test latest Gradle RC | ||||||
| on: | on: | ||||||
|   schedule: |   schedule: | ||||||
| @@ -106,18 +82,312 @@ jobs: | |||||||
|   gradle-rc: |   gradle-rc: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|     - uses: actions/checkout@v1 |     - uses: actions/checkout@v3 | ||||||
|     - uses: actions/setup-java@v1 |     - uses: actions/setup-java@v3 | ||||||
|       with: |       with: | ||||||
|  |         distribution: temurin | ||||||
|         java-version: 11 |         java-version: 11 | ||||||
|     - uses: eskatos/gradle-command-action@v1 |     - uses: gradle/gradle-build-action@v2 | ||||||
|       with: |       with: | ||||||
|         gradle-version: rc |         gradle-version: release-candidate | ||||||
|         arguments: build --dry-run # just test build configuration |     - run: gradle build --dry-run # just test build configuration | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| # Build scans | ## Gradle Execution | ||||||
|  |  | ||||||
| If your build publishes a [build scan](https://gradle.com/build-scans/) the `gradle-command-action` action will emit the link to the published build scan as an output named `build-scan-url`. | If the action is configured with an `arguments` input, then Gradle will execute a Gradle build with the arguments provided. | ||||||
|  |  | ||||||
| You can then use that link in subsequent actions of your workflow. | If no `arguments` are provided, the action will not execute Gradle, but will still cache Gradle state and configure build-scan capture for all subsequent Gradle executions. | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | name: Run Gradle on PRs | ||||||
|  | on: pull_request | ||||||
|  | jobs: | ||||||
|  |   gradle: | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: [ubuntu-latest, macos-latest, windows-latest] | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     steps: | ||||||
|  |     - uses: actions/checkout@v3 | ||||||
|  |     - uses: actions/setup-java@v3 | ||||||
|  |       with: | ||||||
|  |         distribution: temurin | ||||||
|  |         java-version: 11 | ||||||
|  |      | ||||||
|  |     - name: Setup and execute Gradle 'test' task | ||||||
|  |       uses: gradle/gradle-build-action@v2 | ||||||
|  |       with: | ||||||
|  |         arguments: test | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### Multiple Gradle executions in the same Job | ||||||
|  |  | ||||||
|  | It is possible to configure multiple Gradle executions to run sequentially in the same job.  | ||||||
|  | The initial Action step will perform the Gradle setup. | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | - uses: gradle/gradle-build-action@v2 | ||||||
|  |   with: | ||||||
|  |     arguments: assemble | ||||||
|  | - uses: gradle/gradle-build-action@v2 | ||||||
|  |   with: | ||||||
|  |     arguments: check | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### Gradle command-line arguments | ||||||
|  |  | ||||||
|  | The `arguments` input can be used to pass arbitrary arguments to the `gradle` command line. | ||||||
|  | Arguments can be supplied in a single line, or as a multi-line input. | ||||||
|  |  | ||||||
|  | Here are some valid examples: | ||||||
|  | ```yaml | ||||||
|  | arguments: build | ||||||
|  | arguments: check --scan | ||||||
|  | arguments: some arbitrary tasks | ||||||
|  | arguments: build -PgradleProperty=foo | ||||||
|  | arguments: | | ||||||
|  |     build | ||||||
|  |     --scan | ||||||
|  |     -PgradleProperty=foo | ||||||
|  |     -DsystemProperty=bar | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | If you need to pass environment variables, use the GitHub Actions workflow syntax: | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | - uses: gradle/gradle-build-action@v2 | ||||||
|  |   env: | ||||||
|  |     CI: true | ||||||
|  |   with: | ||||||
|  |     arguments: build | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### Gradle build located in a subdirectory | ||||||
|  |  | ||||||
|  | By default, the action will execute Gradle in the root directory of your project.  | ||||||
|  | Use the `build-root-directory` input to target a Gradle build in a subdirectory. | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | - uses: gradle/gradle-build-action@v2 | ||||||
|  |   with: | ||||||
|  |     arguments: build | ||||||
|  |     build-root-directory: some/subdirectory | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### Using a specific Gradle executable | ||||||
|  |  | ||||||
|  | The action will first look for a Gradle wrapper script in the root directory of your project.  | ||||||
|  | If not found, `gradle` will be executed from the PATH. | ||||||
|  | Use the `gradle-executable` input to execute using a specific Gradle installation. | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  |  - uses: gradle/gradle-build-action@v2 | ||||||
|  |    with: | ||||||
|  |      arguments: build | ||||||
|  |      gradle-executable: /path/to/installed/gradle | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | This mechanism can also be used to target a Gradle wrapper script that is located in a non-default location. | ||||||
|  |  | ||||||
|  | ## Caching | ||||||
|  |  | ||||||
|  | By default, this action aims to cache any and all reusable state that may be speed up a subsequent build invocation.  | ||||||
|  |  | ||||||
|  | The state that is cached includes: | ||||||
|  | - Any distributions downloaded to satisfy a `gradle-version` parameter ; | ||||||
|  | - A subset of the Gradle User Home directory, including downloaded dependencies, wrapper distributions, and the local build cache ; | ||||||
|  | - Any [configuration-cache](https://docs.gradle.org/nightly/userguide/configuration_cache.html) data stored in the project `.gradle` directory. (Only supported for Gradle 7 or higher.) | ||||||
|  |  | ||||||
|  | To reduce the space required for caching, this action makes a best effort to reduce duplication in cache entries. | ||||||
|  |  | ||||||
|  | Caching is enabled by default. You can disable caching for the action as follows: | ||||||
|  | ```yaml | ||||||
|  | cache-disabled: true | ||||||
|  | ``` | ||||||
|  | ### Cache keys | ||||||
|  |  | ||||||
|  | Distributions downloaded to satisfy a `gradle-version` parameter are stored outside of Gradle User Home and cached separately. The cache key is unique to the downloaded distribution and will not change over time. | ||||||
|  |  | ||||||
|  | The state of the Gradle User Home and configuration-cache are highly dependent on the Gradle execution, so the cache key is composed of the current commit hash and the GitHub actions job id. | ||||||
|  | As such, the cache key is likely to change on each subsequent run of GitHub actions.  | ||||||
|  | This allows the most recent state to always be available in the GitHub actions cache. | ||||||
|  |  | ||||||
|  | To reduce duplication between cache entries, certain artifacts are cached independently based on their identity. | ||||||
|  | Artifacts that are cached independently include downloaded dependencies, downloaded wrapper distributions and generated Gradle API jars. | ||||||
|  | For example, this means that all jobs executing a particular version of the Gradle wrapper will share common entries for wrapper distributions and for generated Gradle API jars. | ||||||
|  |  | ||||||
|  | ### Using the caches read-only | ||||||
|  |  | ||||||
|  | By default, the `gradle-build-action` will only write to the cache from Jobs on the default (`main`/`master`) branch. | ||||||
|  | Jobs on other branches will read entries from the cache but will not write updated entries.  | ||||||
|  | See [Optimizing cache effectiveness](#optimizing-cache-effectiveness) for a more detailed explanation. | ||||||
|  |  | ||||||
|  | In some circumstances it makes sense to change this default, and to configure a workflow Job to read existing cache entries but not to write changes back. | ||||||
|  |  | ||||||
|  | You can configure read-only caching for the `gradle-build-action` as follows: | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | # Only write to the cache for builds on the 'main' and 'release' branches. (Default is 'main' only.) | ||||||
|  | # Builds on other branches will only read existing entries from the cache. | ||||||
|  | cache-read-only: ${{ github.ref != 'refs/heads/main' && github.ref != 'refs/heads/release' }} | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### Stopping the Gradle daemon | ||||||
|  |  | ||||||
|  | By default, the action will stop all running Gradle daemons in the post-action step, prior to saving the Gradle User Home state.  | ||||||
|  | This allows for any Gradle User Home cleanup to occur, and avoid file-locking issues on Windows. | ||||||
|  |  | ||||||
|  | If caching is unavailable or the cache is in read-only mode, the daemon will not be stopped and will continue running after the job is completed. | ||||||
|  |  | ||||||
|  | ### Gradle User Home cache tuning | ||||||
|  |  | ||||||
|  | As well as any wrapper distributions, the action will attempt to save and restore the `caches` and `notifications` directories from Gradle User Home. | ||||||
|  |  | ||||||
|  | The contents to be cached can be fine tuned by including and excluding certain paths with Gradle User Home. | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | # Cache downloaded JDKs in addition to the default directories. | ||||||
|  | gradle-home-cache-includes: | | ||||||
|  |     caches | ||||||
|  |     notifications | ||||||
|  |     jdks | ||||||
|  | # Exclude the local build-cache from the directories cached. | ||||||
|  | gradle-home-cache-excludes: | | ||||||
|  |     caches/build-cache-1 | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | You can specify any number of fixed paths or patterns to include or exclude.  | ||||||
|  | File pattern support is documented at https://docs.github.com/en/actions/learn-github-actions/workflow-syntax-for-github-actions#patterns-to-match-file-paths. | ||||||
|  |  | ||||||
|  | ### Cache debugging and analysis | ||||||
|  |  | ||||||
|  | Gradle User Home state will be restored from the cache during the first `gradle-build-action` step for any workflow job.  | ||||||
|  | This state will be saved back to the cache at the end of the job, after all Gradle executions have completed. | ||||||
|  | A report of all cache entries restored and saved is printed to the Job Summary when saving the cache entries.  | ||||||
|  | This report can provide valuable insignt into how much cache space is being used. | ||||||
|  |  | ||||||
|  | It is possible to enable additional debug logging for cache operations. You do via the `GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED` environment variable: | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | env: | ||||||
|  |   GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED: true | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Note that this setting will also prevent certain cache operations from running in parallel, further assisting with debugging. | ||||||
|  |  | ||||||
|  | ### Optimizing cache effectiveness | ||||||
|  |  | ||||||
|  | Cache storage space for GitHub actions is limited, and writing new cache entries can trigger the deletion of existing entries. | ||||||
|  | Eviction of shared cache entries can reduce cache effectiveness, slowing down your `gradle-build-action` steps. | ||||||
|  |  | ||||||
|  | There are a number of actions you can take if your cache use is less effective due to entry eviction. | ||||||
|  |  | ||||||
|  | #### Select branches that should write to the cache | ||||||
|  |  | ||||||
|  | GitHub cache entries are not shared between builds on different branches.  | ||||||
|  | This means that each PR branch will have it's own Gradle User Home cache, and will not benefit from cache entries written by other PR branches. | ||||||
|  | An exception to this is that cache entries written in parent and upstream branches are visible to child branches, and cache entries for the default (`master`/`main`) branch can be read by actions invoked for any other branch. | ||||||
|  |  | ||||||
|  | By default, the `gradle-build-action` will only _write_ to the cache for builds run on the default (`master`/`main`) branch.  | ||||||
|  | Jobs run on other branches will only read from the cache. In most cases, this is the desired behaviour,  | ||||||
|  | because Jobs run against other branches will benefit from the cache Gradle User Home from `main`,  | ||||||
|  | without writing private cache entries that could lead to evicting shared entries. | ||||||
|  |  | ||||||
|  | If you have other long-lived development branches that would benefit from writing to the cache,  | ||||||
|  | you can configure these by overriding the `cache-read-only` action parameter.  | ||||||
|  | See [Using the caches read-only](#using-the-caches-read-only) for more details. | ||||||
|  |  | ||||||
|  | Similarly, you could use `cache-read-only` for certain jobs in the workflow, and instead have these jobs reuse the cache content from upstream jobs. | ||||||
|  |  | ||||||
|  | #### Exclude content from Gradle User Home cache | ||||||
|  |  | ||||||
|  | Each build is different, and some builds produce more Gradle User Home content than others. | ||||||
|  | [Cache debugging ](#cache-debugging-and-analysis) can provide insight into which cache entries are the largest, | ||||||
|  | and you can selectively [exclude content using `gradle-home-cache-exclude`](#gradle-user-home-cache-tuning). | ||||||
|  |  | ||||||
|  | #### Removing unused files from Gradle User Home before saving to cache | ||||||
|  |  | ||||||
|  | The Gradle User Home directory has a tendency to grow over time. When you switch to a new Gradle wrapper version or upgrade a dependency version | ||||||
|  | the old files are not automatically and immediately removed. While this can make sense in a local environment, in a GitHub Actions environment | ||||||
|  | it can lead to ever-larger Gradle User Home cache entries being saved and restored. | ||||||
|  |  | ||||||
|  | In order to avoid this situation, the `gradle-build-action` supports the `gradle-home-cache-cleanup` parameter.  | ||||||
|  | When enabled, this feature will attempt to delete any files in the Gradle User Home that were not used by Gradle during the GitHub Actions workflow,  | ||||||
|  | prior to saving the Gradle User Home to the GitHub Actions cache. | ||||||
|  |  | ||||||
|  | Gradle Home cache cleanup is disabled by default.  You can enable this feature for the action as follows: | ||||||
|  | ```yaml | ||||||
|  | gradle-home-cache-cleanup: true | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Saving build outputs | ||||||
|  |  | ||||||
|  | By default, a GitHub Actions workflow using `gradle-build-action` will record the log output and any Build Scan links for your build, | ||||||
|  | but any output files generated by the build will not be saved. | ||||||
|  |  | ||||||
|  | To save selected files from your build execution, you can use the core [Upload-Artifact](https://github.com/actions/upload-artifact) action. | ||||||
|  | For example: | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | jobs:    | ||||||
|  |   gradle: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout project sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: gradle/gradle-build-action@v2 | ||||||
|  |     - name: Run build with Gradle wrapper | ||||||
|  |       run: ./gradlew build --scan | ||||||
|  |     - name: Upload build reports | ||||||
|  |       uses: actions/upload-artifact@v3 | ||||||
|  |       with: | ||||||
|  |         name: build-reports | ||||||
|  |         path: build/reports/ | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Build scans | ||||||
|  |  | ||||||
|  | If your build publishes a [build scan](https://gradle.com/build-scans/) the `gradle-build-action` action will: | ||||||
|  | - Add a notice with the link to the GitHub Actions user interface | ||||||
|  | - For each step that executes Gradle, adds the link to the published build scan as a Step output named `build-scan-url`. | ||||||
|  |  | ||||||
|  | You can then use that link in subsequent actions of your workflow. For example: | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | # .github/workflows/gradle-build-pr.yml | ||||||
|  | name: Run Gradle on PRs | ||||||
|  | on: pull_request | ||||||
|  | jobs: | ||||||
|  |   gradle: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout project sources | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Setup Gradle | ||||||
|  |       uses: gradle/gradle-build-action@v2 | ||||||
|  |     - name: Run build with Gradle wrapper | ||||||
|  |       id: gradle | ||||||
|  |       run: ./gradlew build --scan | ||||||
|  |     - name: "Add build scan URL as PR comment" | ||||||
|  |       uses: actions/github-script@v5 | ||||||
|  |       if: github.event_name == 'pull_request' && failure() | ||||||
|  |       with: | ||||||
|  |         github-token: ${{secrets.GITHUB_TOKEN}} | ||||||
|  |         script: | | ||||||
|  |           github.rest.issues.createComment({ | ||||||
|  |             issue_number: context.issue.number, | ||||||
|  |             owner: context.repo.owner, | ||||||
|  |             repo: context.repo.repo, | ||||||
|  |             body: '❌ ${{ github.workflow }} failed: ${{ steps.gradle.outputs.build-scan-url }}' | ||||||
|  |           }) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Support for GitHub Enterprise Server (GHES) | ||||||
|  |  | ||||||
|  | You can use the `gradle-build-action` on GitHub Enterprise Server, and benefit from the improved integration with Gradle. Depending on the version of GHES you are running, certain features may be limited: | ||||||
|  | - Build scan links are captured and displayed in the GitHub Actions UI | ||||||
|  | - Easily run your build with different versions of Gradle | ||||||
|  | - Save/restore of Gradle User Home (requires GHES v3.5+ : GitHub Actions cache was introduced in GHES 3.5) | ||||||
|  | - Support for GitHub Actions Job Summary is not yet available in any version of GHES. Instead of producing a Job Summary, the build-results summary and caching report will be written to the workflow log, as part of the post-action step. | ||||||
|   | |||||||
| @@ -1,3 +0,0 @@ | |||||||
| describe('TODO - Add a test suite', () => { |  | ||||||
|   it('TODO - Add a test', async () => {}); |  | ||||||
| }); |  | ||||||
							
								
								
									
										81
									
								
								action.yml
									
									
									
									
									
								
							
							
						
						
									
										81
									
								
								action.yml
									
									
									
									
									
								
							| @@ -1,33 +1,88 @@ | |||||||
| name: "Gradle Command" | name: "Gradle Build Action" | ||||||
| description: 'Execute Gradle Command Line' | description: 'Configures Gradle for use in GitHub actions, caching useful state in the GitHub actions cache' | ||||||
| author: 'Paul Merlin <paul@nospere.org>' |  | ||||||
|  |  | ||||||
| # https://help.github.com/en/articles/metadata-syntax-for-github-actions | # https://help.github.com/en/articles/metadata-syntax-for-github-actions | ||||||
|  |  | ||||||
| inputs: | inputs: | ||||||
|   wrapper-directory: |  | ||||||
|     description: Path to the Gradle Wrapper directory |  | ||||||
|     required: false |  | ||||||
|   gradle-executable: |  | ||||||
|     description: Path to the Gradle executable |  | ||||||
|     required: false |  | ||||||
|   gradle-version: |   gradle-version: | ||||||
|     description: Gradle version to use |     description: Gradle version to use | ||||||
|     required: false |     required: false | ||||||
|  |  | ||||||
|  |   cache-disabled: | ||||||
|  |     description: When 'true', all caching is disabled. No entries will be written to or read from the cache. | ||||||
|  |     required: false | ||||||
|  |     default: false | ||||||
|  |  | ||||||
|  |   cache-read-only: | ||||||
|  |     description: | | ||||||
|  |       When 'true', existing entries will be read from the cache but no entries will be written. | ||||||
|  |       By default this value is 'false' for workflows on the GitHub default branch and 'true' for workflows on other branches. | ||||||
|  |     required: false | ||||||
|  |     default: ${{ github.event.repository != null && github.ref_name != github.event.repository.default_branch }} | ||||||
|  |  | ||||||
|  |   cache-write-only: | ||||||
|  |     description: | | ||||||
|  |       When 'true', entries will not be restored from the cache but will be saved at the end of the Job.  | ||||||
|  |       Setting this to 'true' implies cache-read-only will be 'false'. | ||||||
|  |     required: false | ||||||
|  |     default: false | ||||||
|  |  | ||||||
|  |   gradle-home-cache-includes: | ||||||
|  |     description: Paths within Gradle User Home to cache. | ||||||
|  |     required: false | ||||||
|  |     default: | | ||||||
|  |         caches | ||||||
|  |         notifications | ||||||
|  |  | ||||||
|  |   gradle-home-cache-excludes: | ||||||
|  |     description: Paths within Gradle User Home to exclude from cache. | ||||||
|  |     required: false | ||||||
|  |   # e.g. Use the following setting to prevent the local build cache from being saved/restored | ||||||
|  |   #      gradle-home-cache-excludes: | | ||||||
|  |   #           caches/build-cache-1 | ||||||
|  |  | ||||||
|  |   arguments: | ||||||
|  |     description: Gradle command line arguments (supports multi-line input) | ||||||
|  |     required: false | ||||||
|  |  | ||||||
|   build-root-directory: |   build-root-directory: | ||||||
|     description: Path to the root directory of the build |     description: Path to the root directory of the build | ||||||
|     required: false |     required: false | ||||||
|   arguments: |  | ||||||
|     description: Gradle command line arguments, see gradle --help |   gradle-executable: | ||||||
|  |     description: Path to the Gradle executable | ||||||
|     required: false |     required: false | ||||||
|  |  | ||||||
|  |   generate-job-summary: | ||||||
|  |     description: When 'false', no Job Summary will be generated for the Job. | ||||||
|  |     required: false | ||||||
|  |     default: true | ||||||
|  |  | ||||||
|  |   # EXPERIMENTAL & INTERNAL ACTION INPUTS | ||||||
|  |   # The following action properties allow fine-grained tweaking of the action caching behaviour. | ||||||
|  |   # These properties are experimental and not (yet) designed for production use, and may change without notice in a subsequent release of `gradle-build-action`. | ||||||
|  |   # Use at your own risk! | ||||||
|  |   gradle-home-cache-strict-match: | ||||||
|  |     description: When 'true', the action will not attempt to restore the Gradle User Home entries from other Jobs. | ||||||
|  |     required: false | ||||||
|  |     default: false | ||||||
|  |   workflow-job-context: | ||||||
|  |     description: Used to uniquely identify the current job invocation. Defaults to the matrix values for this job; this should not be overridden by users (INTERNAL). | ||||||
|  |     required: false | ||||||
|  |     default: ${{ toJSON(matrix) }} | ||||||
|  |   gradle-home-cache-cleanup: | ||||||
|  |     description: When 'true', the action will attempt to remove any stale/unused entries from the Gradle User Home prior to saving to the GitHub Actions cache. | ||||||
|  |     required: false | ||||||
|  |     default: false | ||||||
|  |  | ||||||
| outputs: | outputs: | ||||||
|   build-scan-url: |   build-scan-url: | ||||||
|     description: Link to the build scan if any |     description: Link to the build scan if any | ||||||
|  |  | ||||||
| runs: | runs: | ||||||
|   using: 'node12' |   using: 'node16' | ||||||
|   main: 'lib/main.js' |   main: 'dist/main/index.js' | ||||||
|  |   post: 'dist/post/index.js' | ||||||
|  |  | ||||||
| branding: | branding: | ||||||
|   icon: 'box' |   icon: 'box' | ||||||
|   | |||||||
							
								
								
									
										67472
									
								
								dist/main/index.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										67472
									
								
								dist/main/index.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										1
									
								
								dist/main/index.js.map
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								dist/main/index.js.map
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										66156
									
								
								dist/post/index.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										66156
									
								
								dist/post/index.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										1
									
								
								dist/post/index.js.map
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								dist/post/index.js.map
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @@ -1,11 +1,10 @@ | |||||||
| module.exports = { | module.exports = { | ||||||
|   clearMocks: true, |   clearMocks: true, | ||||||
|   moduleFileExtensions: ['js', 'ts'], |   moduleFileExtensions: ['js', 'ts', 'json'], | ||||||
|   testEnvironment: 'node', |   testEnvironment: 'node', | ||||||
|   testMatch: ['**/*.test.ts'], |   testMatch: ['**/*.test.ts'], | ||||||
|   testRunner: 'jest-circus/runner', |  | ||||||
|   transform: { |   transform: { | ||||||
|     '^.+\\.ts$': 'ts-jest' |     '^.+\\.ts$': 'ts-jest' | ||||||
|   }, |   }, | ||||||
|   verbose: true |   verbose: true | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										15022
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										15022
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										56
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										56
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,15 +1,22 @@ | |||||||
| { | { | ||||||
|   "name": "gradle-command-action", |   "name": "gradle-build-action", | ||||||
|   "version": "1.0.0", |   "version": "1.0.0", | ||||||
|   "description": "Execute Gradle Command Line", |   "private": true, | ||||||
|   "main": "lib/main.js", |   "description": "Execute Gradle Build", | ||||||
|   "scripts": { |   "scripts": { | ||||||
|     "build": "tsc", |     "postinstall": "patch-package", | ||||||
|     "test": "jest" |     "format": "prettier --write **/*.ts", | ||||||
|  |     "format-check": "prettier --check **/*.ts", | ||||||
|  |     "lint": "eslint src/**/*.ts", | ||||||
|  |     "compile": "ncc build src/main.ts --out dist/main --source-map --no-source-map-register && ncc build src/post.ts --out dist/post --source-map --no-source-map-register", | ||||||
|  |     "test": "jest", | ||||||
|  |     "check": "npm run format && npm run lint", | ||||||
|  |     "build": "npm run check && npm run compile", | ||||||
|  |     "all": "npm run build && npm test" | ||||||
|   }, |   }, | ||||||
|   "repository": { |   "repository": { | ||||||
|     "type": "git", |     "type": "git", | ||||||
|     "url": "git+https://github.com/eskatos/gradle-command-action.git" |     "url": "git+https://github.com/gradle/gradle-build-action.git" | ||||||
|   }, |   }, | ||||||
|   "keywords": [ |   "keywords": [ | ||||||
|     "github", |     "github", | ||||||
| @@ -17,24 +24,31 @@ | |||||||
|     "github-actions", |     "github-actions", | ||||||
|     "gradle" |     "gradle" | ||||||
|   ], |   ], | ||||||
|   "author": "Paul Merlin <paul@nosphere.org>", |  | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@actions/core": "1.1.1", |     "@actions/cache": "3.0.6", | ||||||
|     "@actions/exec": "1.0.1", |     "@actions/core": "1.10.0", | ||||||
|     "@actions/io": "1.0.1", |     "@actions/exec": "1.1.1", | ||||||
|     "@actions/tool-cache": "1.1.1", |     "@actions/github": "5.1.1", | ||||||
|     "string-argv": "0.3.1", |     "@actions/glob": "0.3.0", | ||||||
|     "typed-rest-client": "1.5.0", |     "@actions/http-client": "2.0.1", | ||||||
|     "unzipper": "0.10.5" |     "@actions/tool-cache": "2.0.1", | ||||||
|  |     "string-argv": "0.3.1" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@types/jest": "24.0.18", |     "@types/jest": "28.1.7", | ||||||
|     "@types/node": "12.7.5", |     "@types/node": "16.11.21", | ||||||
|     "@types/unzipper": "0.10.0", |     "@types/unzipper": "0.10.5", | ||||||
|     "jest": "24.9.0", |     "@typescript-eslint/parser": "5.40.1", | ||||||
|     "jest-circus": "24.9.0", |     "@vercel/ncc": "0.34.0", | ||||||
|     "ts-jest": "24.1.0", |     "eslint": "8.25.0", | ||||||
|     "typescript": "3.6.3" |     "eslint-plugin-github": "4.4.0", | ||||||
|  |     "eslint-plugin-jest": "27.1.3", | ||||||
|  |     "jest": "28.1.3", | ||||||
|  |     "js-yaml": "4.1.0",  | ||||||
|  |     "patch-package": "6.4.7", | ||||||
|  |     "prettier": "2.7.1", | ||||||
|  |     "ts-jest": "28.0.8", | ||||||
|  |     "typescript": "4.8.4" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										114
									
								
								patches/@actions+cache+3.0.6.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										114
									
								
								patches/@actions+cache+3.0.6.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,114 @@ | |||||||
|  | diff --git a/node_modules/@actions/cache/lib/cache.d.ts b/node_modules/@actions/cache/lib/cache.d.ts | ||||||
|  | index 16b20f7..aea77ba 100644 | ||||||
|  | --- a/node_modules/@actions/cache/lib/cache.d.ts | ||||||
|  | +++ b/node_modules/@actions/cache/lib/cache.d.ts | ||||||
|  | @@ -20,7 +20,7 @@ export declare function isFeatureAvailable(): boolean; | ||||||
|  |   * @param downloadOptions cache download options | ||||||
|  |   * @returns string returns the key for the cache hit, otherwise returns undefined | ||||||
|  |   */ | ||||||
|  | -export declare function restoreCache(paths: string[], primaryKey: string, restoreKeys?: string[], options?: DownloadOptions): Promise<string | undefined>; | ||||||
|  | +export declare function restoreCache(paths: string[], primaryKey: string, restoreKeys?: string[], options?: DownloadOptions): Promise<CacheEntry | undefined>; | ||||||
|  |  /** | ||||||
|  |   * Saves a list of files with the specified key | ||||||
|  |   * | ||||||
|  | @@ -29,4 +29,12 @@ export declare function restoreCache(paths: string[], primaryKey: string, restor | ||||||
|  |   * @param options cache upload options | ||||||
|  |   * @returns number returns cacheId if the cache was saved successfully and throws an error if save fails | ||||||
|  |   */ | ||||||
|  | -export declare function saveCache(paths: string[], key: string, options?: UploadOptions): Promise<number>; | ||||||
|  | +export declare function saveCache(paths: string[], key: string, options?: UploadOptions): Promise<CacheEntry>; | ||||||
|  | + | ||||||
|  | +// PATCHED: Add `CacheEntry` as return type for save/restore functions | ||||||
|  | +// This allows us to track and report on cache entry sizes. | ||||||
|  | +export declare class CacheEntry { | ||||||
|  | +    key: string; | ||||||
|  | +    size?: number; | ||||||
|  | +    constructor(key: string, size?: number); | ||||||
|  | +} | ||||||
|  | diff --git a/node_modules/@actions/cache/lib/cache.js b/node_modules/@actions/cache/lib/cache.js | ||||||
|  | index 4dc5e88..92d99d5 100644 | ||||||
|  | --- a/node_modules/@actions/cache/lib/cache.js | ||||||
|  | +++ b/node_modules/@actions/cache/lib/cache.js | ||||||
|  | @@ -95,26 +95,18 @@ function restoreCache(paths, primaryKey, restoreKeys, options) { | ||||||
|  |              } | ||||||
|  |              archivePath = path.join(yield utils.createTempDirectory(), utils.getCacheFileName(compressionMethod)); | ||||||
|  |              core.debug(`Archive Path: ${archivePath}`); | ||||||
|  | +            const restoredEntry = new CacheEntry(cacheEntry.cacheKey); | ||||||
|  |              // Download the cache from the cache entry | ||||||
|  |              yield cacheHttpClient.downloadCache(cacheEntry.archiveLocation, archivePath, options); | ||||||
|  |              if (core.isDebug()) { | ||||||
|  |                  yield tar_1.listTar(archivePath, compressionMethod); | ||||||
|  |              } | ||||||
|  |              const archiveFileSize = utils.getArchiveFileSizeInBytes(archivePath); | ||||||
|  | +            restoredEntry.size = archiveFileSize; | ||||||
|  |              core.info(`Cache Size: ~${Math.round(archiveFileSize / (1024 * 1024))} MB (${archiveFileSize} B)`); | ||||||
|  |              yield tar_1.extractTar(archivePath, compressionMethod); | ||||||
|  |              core.info('Cache restored successfully'); | ||||||
|  | -            return cacheEntry.cacheKey; | ||||||
|  | -        } | ||||||
|  | -        catch (error) { | ||||||
|  | -            const typedError = error; | ||||||
|  | -            if (typedError.name === ValidationError.name) { | ||||||
|  | -                throw error; | ||||||
|  | -            } | ||||||
|  | -            else { | ||||||
|  | -                // Supress all non-validation cache related errors because caching should be optional | ||||||
|  | -                core.warning(`Failed to restore: ${error.message}`); | ||||||
|  | -            } | ||||||
|  | +            return restoredEntry; | ||||||
|  |          } | ||||||
|  |          finally { | ||||||
|  |              // Try to delete the archive to save space | ||||||
|  | @@ -153,6 +145,7 @@ function saveCache(paths, key, options) { | ||||||
|  |          const archiveFolder = yield utils.createTempDirectory(); | ||||||
|  |          const archivePath = path.join(archiveFolder, utils.getCacheFileName(compressionMethod)); | ||||||
|  |          core.debug(`Archive Path: ${archivePath}`); | ||||||
|  | +        const savedEntry = new CacheEntry(key); | ||||||
|  |          try { | ||||||
|  |              yield tar_1.createTar(archiveFolder, cachePaths, compressionMethod); | ||||||
|  |              if (core.isDebug()) { | ||||||
|  | @@ -160,6 +153,7 @@ function saveCache(paths, key, options) { | ||||||
|  |              } | ||||||
|  |              const fileSizeLimit = 10 * 1024 * 1024 * 1024; // 10GB per repo limit | ||||||
|  |              const archiveFileSize = utils.getArchiveFileSizeInBytes(archivePath); | ||||||
|  | +            savedEntry.size = archiveFileSize; | ||||||
|  |              core.debug(`File Size: ${archiveFileSize}`); | ||||||
|  |              // For GHES, this check will take place in ReserveCache API with enterprise file size limit | ||||||
|  |              if (archiveFileSize > fileSizeLimit && !utils.isGhes()) { | ||||||
|  | @@ -182,18 +176,6 @@ function saveCache(paths, key, options) { | ||||||
|  |              core.debug(`Saving Cache (ID: ${cacheId})`); | ||||||
|  |              yield cacheHttpClient.saveCache(cacheId, archivePath, options); | ||||||
|  |          } | ||||||
|  | -        catch (error) { | ||||||
|  | -            const typedError = error; | ||||||
|  | -            if (typedError.name === ValidationError.name) { | ||||||
|  | -                throw error; | ||||||
|  | -            } | ||||||
|  | -            else if (typedError.name === ReserveCacheError.name) { | ||||||
|  | -                core.info(`Failed to save: ${typedError.message}`); | ||||||
|  | -            } | ||||||
|  | -            else { | ||||||
|  | -                core.warning(`Failed to save: ${typedError.message}`); | ||||||
|  | -            } | ||||||
|  | -        } | ||||||
|  |          finally { | ||||||
|  |              // Try to delete the archive to save space | ||||||
|  |              try { | ||||||
|  | @@ -203,8 +185,15 @@ function saveCache(paths, key, options) { | ||||||
|  |                  core.debug(`Failed to delete archive: ${error}`); | ||||||
|  |              } | ||||||
|  |          } | ||||||
|  | -        return cacheId; | ||||||
|  | +        return savedEntry; | ||||||
|  |      }); | ||||||
|  |  } | ||||||
|  |  exports.saveCache = saveCache; | ||||||
|  | +class CacheEntry { | ||||||
|  | +    constructor(key, size) { | ||||||
|  | +        this.key = key; | ||||||
|  | +        this.size = size; | ||||||
|  | +    } | ||||||
|  | +} | ||||||
|  | +exports.CacheEntry = CacheEntry; | ||||||
|  |  //# sourceMappingURL=cache.js.map | ||||||
|  | \ No newline at end of file | ||||||
							
								
								
									
										29
									
								
								patches/@azure+logger+1.0.3.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								patches/@azure+logger+1.0.3.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | |||||||
|  | # Patch removes logging of the AZURE_LOG_LEVEL env var value | ||||||
|  | # This logging triggers a high severity Warning from CodeQL, which can prevent organizational users from adopting the action. | ||||||
|  |  | ||||||
|  | diff --git a/node_modules/@azure/logger/dist-esm/src/index.js b/node_modules/@azure/logger/dist-esm/src/index.js | ||||||
|  | index 116b59e..cf87f3c 100644 | ||||||
|  | --- a/node_modules/@azure/logger/dist-esm/src/index.js | ||||||
|  | +++ b/node_modules/@azure/logger/dist-esm/src/index.js | ||||||
|  | @@ -20,7 +20,7 @@ if (logLevelFromEnv) { | ||||||
|  |          setLogLevel(logLevelFromEnv); | ||||||
|  |      } | ||||||
|  |      else { | ||||||
|  | -        console.error(`AZURE_LOG_LEVEL set to unknown log level '${logLevelFromEnv}'; logging is not enabled. Acceptable values: ${AZURE_LOG_LEVELS.join(", ")}.`); | ||||||
|  | +        console.error(`AZURE_LOG_LEVEL set to unknown log level; logging is not enabled. Acceptable values: ${AZURE_LOG_LEVELS.join(", ")}.`); | ||||||
|  |      } | ||||||
|  |  } | ||||||
|  |  /** | ||||||
|  | diff --git a/node_modules/@azure/logger/dist/index.js b/node_modules/@azure/logger/dist/index.js | ||||||
|  | index 327fbdb..4432d73 100644 | ||||||
|  | --- a/node_modules/@azure/logger/dist/index.js | ||||||
|  | +++ b/node_modules/@azure/logger/dist/index.js | ||||||
|  | @@ -122,7 +122,7 @@ if (logLevelFromEnv) { | ||||||
|  |          setLogLevel(logLevelFromEnv); | ||||||
|  |      } | ||||||
|  |      else { | ||||||
|  | -        console.error(`AZURE_LOG_LEVEL set to unknown log level '${logLevelFromEnv}'; logging is not enabled. Acceptable values: ${AZURE_LOG_LEVELS.join(", ")}.`); | ||||||
|  | +        console.error(`AZURE_LOG_LEVEL set to unknown log level; logging is not enabled. Acceptable values: ${AZURE_LOG_LEVELS.join(", ")}.`); | ||||||
|  |      } | ||||||
|  |  } | ||||||
|  |  /** | ||||||
							
								
								
									
										0
									
								
								release/changes.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								release/changes.md
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										27
									
								
								src/build-results.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								src/build-results.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | import * as fs from 'fs' | ||||||
|  | import * as path from 'path' | ||||||
|  |  | ||||||
|  | export interface BuildResult { | ||||||
|  |     get rootProjectName(): string | ||||||
|  |     get rootProjectDir(): string | ||||||
|  |     get requestedTasks(): string | ||||||
|  |     get gradleVersion(): string | ||||||
|  |     get gradleHomeDir(): string | ||||||
|  |     get buildFailed(): boolean | ||||||
|  |     get buildScanUri(): string | ||||||
|  |     get buildScanFailed(): boolean | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function loadBuildResults(): BuildResult[] { | ||||||
|  |     const buildResultsDir = path.resolve(process.env['RUNNER_TEMP']!, '.build-results') | ||||||
|  |     if (!fs.existsSync(buildResultsDir)) { | ||||||
|  |         return [] | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return fs.readdirSync(buildResultsDir).map(file => { | ||||||
|  |         // Every file in the .build-results dir should be a BuildResults JSON | ||||||
|  |         const filePath = path.join(buildResultsDir, file) | ||||||
|  |         const content = fs.readFileSync(filePath, 'utf8') | ||||||
|  |         return JSON.parse(content) as BuildResult | ||||||
|  |     }) | ||||||
|  | } | ||||||
							
								
								
									
										222
									
								
								src/cache-base.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										222
									
								
								src/cache-base.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,222 @@ | |||||||
|  | import * as core from '@actions/core' | ||||||
|  | import * as exec from '@actions/exec' | ||||||
|  | import path from 'path' | ||||||
|  | import fs from 'fs' | ||||||
|  | import {CacheListener} from './cache-reporting' | ||||||
|  | import {saveCache, restoreCache, cacheDebug, isCacheDebuggingEnabled, tryDelete, generateCacheKey} from './cache-utils' | ||||||
|  | import {ConfigurationCacheEntryExtractor, GradleHomeEntryExtractor} from './cache-extract-entries' | ||||||
|  |  | ||||||
|  | const RESTORED_CACHE_KEY_KEY = 'restored-cache-key' | ||||||
|  |  | ||||||
|  | export const META_FILE_DIR = '.gradle-build-action' | ||||||
|  | const INCLUDE_PATHS_PARAMETER = 'gradle-home-cache-includes' | ||||||
|  | const EXCLUDE_PATHS_PARAMETER = 'gradle-home-cache-excludes' | ||||||
|  |  | ||||||
|  | export class GradleStateCache { | ||||||
|  |     private cacheName: string | ||||||
|  |     private cacheDescription: string | ||||||
|  |  | ||||||
|  |     protected readonly gradleUserHome: string | ||||||
|  |  | ||||||
|  |     constructor(gradleUserHome: string) { | ||||||
|  |         this.gradleUserHome = gradleUserHome | ||||||
|  |         this.cacheName = 'gradle' | ||||||
|  |         this.cacheDescription = 'Gradle User Home' | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     init(): void { | ||||||
|  |         const actionCacheDir = path.resolve(this.gradleUserHome, '.gradle-build-action') | ||||||
|  |         fs.mkdirSync(actionCacheDir, {recursive: true}) | ||||||
|  |  | ||||||
|  |         const initScriptsDir = path.resolve(this.gradleUserHome, 'init.d') | ||||||
|  |         fs.mkdirSync(initScriptsDir, {recursive: true}) | ||||||
|  |  | ||||||
|  |         this.initializeGradleUserHome(this.gradleUserHome, initScriptsDir) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     cacheOutputExists(): boolean { | ||||||
|  |         const cachesDir = path.resolve(this.gradleUserHome, 'caches') | ||||||
|  |         if (fs.existsSync(cachesDir)) { | ||||||
|  |             cacheDebug(`Cache output exists at ${cachesDir}`) | ||||||
|  |             return true | ||||||
|  |         } | ||||||
|  |         return false | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Restores the cache entry, finding the closest match to the currently running job. | ||||||
|  |      */ | ||||||
|  |     async restore(listener: CacheListener): Promise<void> { | ||||||
|  |         const entryListener = listener.entry(this.cacheDescription) | ||||||
|  |  | ||||||
|  |         const cacheKey = generateCacheKey(this.cacheName) | ||||||
|  |  | ||||||
|  |         cacheDebug( | ||||||
|  |             `Requesting ${this.cacheDescription} with | ||||||
|  |     key:${cacheKey.key} | ||||||
|  |     restoreKeys:[${cacheKey.restoreKeys}]` | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |         const cacheResult = await restoreCache(this.getCachePath(), cacheKey.key, cacheKey.restoreKeys, entryListener) | ||||||
|  |         if (!cacheResult) { | ||||||
|  |             core.info(`${this.cacheDescription} cache not found. Will initialize empty.`) | ||||||
|  |             return | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         core.saveState(RESTORED_CACHE_KEY_KEY, cacheResult.key) | ||||||
|  |  | ||||||
|  |         core.info(`Restored ${this.cacheDescription} from cache key: ${cacheResult.key}`) | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             await this.afterRestore(listener) | ||||||
|  |         } catch (error) { | ||||||
|  |             core.warning(`Restore ${this.cacheDescription} failed in 'afterRestore': ${error}`) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Restore any extracted cache entries after the main Gradle User Home entry is restored. | ||||||
|  |      */ | ||||||
|  |     async afterRestore(listener: CacheListener): Promise<void> { | ||||||
|  |         await this.debugReportGradleUserHomeSize('as restored from cache') | ||||||
|  |         await new GradleHomeEntryExtractor(this.gradleUserHome).restore(listener) | ||||||
|  |         await new ConfigurationCacheEntryExtractor(this.gradleUserHome).restore(listener) | ||||||
|  |         await this.debugReportGradleUserHomeSize('after restoring common artifacts') | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Saves the cache entry based on the current cache key unless the cache was restored with the exact key, | ||||||
|  |      * in which case we cannot overwrite it. | ||||||
|  |      * | ||||||
|  |      * If the cache entry was restored with a partial match on a restore key, then | ||||||
|  |      * it is saved with the exact key. | ||||||
|  |      */ | ||||||
|  |     async save(listener: CacheListener): Promise<void> { | ||||||
|  |         const cacheKey = generateCacheKey(this.cacheName).key | ||||||
|  |         const restoredCacheKey = core.getState(RESTORED_CACHE_KEY_KEY) | ||||||
|  |         const gradleHomeEntryListener = listener.entry(this.cacheDescription) | ||||||
|  |  | ||||||
|  |         if (restoredCacheKey && cacheKey === restoredCacheKey) { | ||||||
|  |             core.info(`Cache hit occurred on the cache key ${cacheKey}, not saving cache.`) | ||||||
|  |  | ||||||
|  |             for (const entryListener of listener.cacheEntries) { | ||||||
|  |                 if (entryListener === gradleHomeEntryListener) { | ||||||
|  |                     entryListener.markNotSaved('cache key not changed') | ||||||
|  |                 } else { | ||||||
|  |                     entryListener.markNotSaved(`referencing '${this.cacheDescription}' cache entry not saved`) | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             return | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             await this.beforeSave(listener) | ||||||
|  |         } catch (error) { | ||||||
|  |             core.warning(`Save ${this.cacheDescription} failed in 'beforeSave': ${error}`) | ||||||
|  |             return | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         core.info(`Caching ${this.cacheDescription} with cache key: ${cacheKey}`) | ||||||
|  |         const cachePath = this.getCachePath() | ||||||
|  |         await saveCache(cachePath, cacheKey, gradleHomeEntryListener) | ||||||
|  |  | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Extract and save any defined extracted cache entries prior to the main Gradle User Home entry being saved. | ||||||
|  |      */ | ||||||
|  |     async beforeSave(listener: CacheListener): Promise<void> { | ||||||
|  |         await this.debugReportGradleUserHomeSize('before saving common artifacts') | ||||||
|  |         this.deleteExcludedPaths() | ||||||
|  |         await Promise.all([ | ||||||
|  |             new GradleHomeEntryExtractor(this.gradleUserHome).extract(listener), | ||||||
|  |             new ConfigurationCacheEntryExtractor(this.gradleUserHome).extract(listener) | ||||||
|  |         ]) | ||||||
|  |         await this.debugReportGradleUserHomeSize( | ||||||
|  |             "after extracting common artifacts (only 'caches' and 'notifications' will be stored)" | ||||||
|  |         ) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Delete any file paths that are excluded by the `gradle-home-cache-excludes` parameter. | ||||||
|  |      */ | ||||||
|  |     private deleteExcludedPaths(): void { | ||||||
|  |         const rawPaths: string[] = core.getMultilineInput(EXCLUDE_PATHS_PARAMETER) | ||||||
|  |         const resolvedPaths = rawPaths.map(x => path.resolve(this.gradleUserHome, x)) | ||||||
|  |  | ||||||
|  |         for (const p of resolvedPaths) { | ||||||
|  |             cacheDebug(`Deleting excluded path: ${p}`) | ||||||
|  |             tryDelete(p) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Determines the paths within Gradle User Home to cache. | ||||||
|  |      * By default, this is the 'caches' and 'notifications' directories, | ||||||
|  |      * but this can be overridden by the `gradle-home-cache-includes` parameter. | ||||||
|  |      */ | ||||||
|  |     protected getCachePath(): string[] { | ||||||
|  |         const rawPaths: string[] = core.getMultilineInput(INCLUDE_PATHS_PARAMETER) | ||||||
|  |         rawPaths.push(META_FILE_DIR) | ||||||
|  |         const resolvedPaths = rawPaths.map(x => this.resolveCachePath(x)) | ||||||
|  |         cacheDebug(`Using cache paths: ${resolvedPaths}`) | ||||||
|  |         return resolvedPaths | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private resolveCachePath(rawPath: string): string { | ||||||
|  |         if (rawPath.startsWith('!')) { | ||||||
|  |             const resolved = this.resolveCachePath(rawPath.substring(1)) | ||||||
|  |             return `!${resolved}` | ||||||
|  |         } | ||||||
|  |         return path.resolve(this.gradleUserHome, rawPath) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private initializeGradleUserHome(gradleUserHome: string, initScriptsDir: string): void { | ||||||
|  |         const initScriptFilenames = ['build-result-capture.init.gradle', 'build-result-capture-service.plugin.groovy'] | ||||||
|  |         for (const initScriptFilename of initScriptFilenames) { | ||||||
|  |             const initScriptContent = this.readInitScriptAsString(initScriptFilename) | ||||||
|  |             const initScriptPath = path.resolve(initScriptsDir, initScriptFilename) | ||||||
|  |             fs.writeFileSync(initScriptPath, initScriptContent) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private readInitScriptAsString(resource: string): string { | ||||||
|  |         // Resolving relative to __dirname will allow node to find the resource at runtime | ||||||
|  |         const absolutePath = path.resolve(__dirname, '..', '..', 'src', 'resources', 'init-scripts', resource) | ||||||
|  |         return fs.readFileSync(absolutePath, 'utf8') | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * When cache debugging is enabled, this method will give a detailed report | ||||||
|  |      * of the Gradle User Home contents. | ||||||
|  |      */ | ||||||
|  |     private async debugReportGradleUserHomeSize(label: string): Promise<void> { | ||||||
|  |         if (!isCacheDebuggingEnabled()) { | ||||||
|  |             return | ||||||
|  |         } | ||||||
|  |         if (!fs.existsSync(this.gradleUserHome)) { | ||||||
|  |             return | ||||||
|  |         } | ||||||
|  |         const result = await exec.getExecOutput('du', ['-h', '-c', '-t', '5M'], { | ||||||
|  |             cwd: this.gradleUserHome, | ||||||
|  |             silent: true, | ||||||
|  |             ignoreReturnCode: true | ||||||
|  |         }) | ||||||
|  |  | ||||||
|  |         core.info(`Gradle User Home (directories >5M): ${label}`) | ||||||
|  |  | ||||||
|  |         core.info( | ||||||
|  |             result.stdout | ||||||
|  |                 .trimEnd() | ||||||
|  |                 .replace(/\t/g, '    ') | ||||||
|  |                 .split('\n') | ||||||
|  |                 .map(it => { | ||||||
|  |                     return `  ${it}` | ||||||
|  |                 }) | ||||||
|  |                 .join('\n') | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |         core.info('-----------------------') | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										68
									
								
								src/cache-cleaner.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								src/cache-cleaner.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | |||||||
|  | import * as core from '@actions/core' | ||||||
|  | import * as exec from '@actions/exec' | ||||||
|  | import * as glob from '@actions/glob' | ||||||
|  | import fs from 'fs' | ||||||
|  | import path from 'path' | ||||||
|  |  | ||||||
|  | export class CacheCleaner { | ||||||
|  |     private readonly gradleUserHome: string | ||||||
|  |     private readonly tmpDir: string | ||||||
|  |  | ||||||
|  |     constructor(gradleUserHome: string, tmpDir: string) { | ||||||
|  |         this.gradleUserHome = gradleUserHome | ||||||
|  |         this.tmpDir = tmpDir | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     async prepare(): Promise<void> { | ||||||
|  |         // Reset the file-access journal so that files appear not to have been used recently | ||||||
|  |         fs.rmSync(path.resolve(this.gradleUserHome, 'caches/journal-1'), {recursive: true, force: true}) | ||||||
|  |         fs.mkdirSync(path.resolve(this.gradleUserHome, 'caches/journal-1'), {recursive: true}) | ||||||
|  |         fs.writeFileSync( | ||||||
|  |             path.resolve(this.gradleUserHome, 'caches/journal-1/file-access.properties'), | ||||||
|  |             'inceptionTimestamp=0' | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |         // Set the modification time of all files to the past: this timestamp is used when there is no matching entry in the journal | ||||||
|  |         await this.ageAllFiles() | ||||||
|  |  | ||||||
|  |         // Touch all 'gc' files so that cache cleanup won't run immediately. | ||||||
|  |         await this.touchAllFiles('gc.properties') | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     async forceCleanup(): Promise<void> { | ||||||
|  |         // Age all 'gc' files so that cache cleanup will run immediately. | ||||||
|  |         await this.ageAllFiles('gc.properties') | ||||||
|  |  | ||||||
|  |         // Run a dummy Gradle build to trigger cache cleanup | ||||||
|  |         const cleanupProjectDir = path.resolve(this.tmpDir, 'dummy-cleanup-project') | ||||||
|  |         fs.mkdirSync(cleanupProjectDir, {recursive: true}) | ||||||
|  |         fs.writeFileSync( | ||||||
|  |             path.resolve(cleanupProjectDir, 'settings.gradle'), | ||||||
|  |             'rootProject.name = "dummy-cleanup-project"' | ||||||
|  |         ) | ||||||
|  |         fs.writeFileSync(path.resolve(cleanupProjectDir, 'build.gradle'), 'task("noop") {}') | ||||||
|  |  | ||||||
|  |         await exec.exec(`gradle -g ${this.gradleUserHome} --no-daemon --build-cache --no-scan --quiet noop`, [], { | ||||||
|  |             cwd: cleanupProjectDir | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private async ageAllFiles(fileName = '*'): Promise<void> { | ||||||
|  |         core.debug(`Aging all files in Gradle User Homee with name ${fileName}`) | ||||||
|  |         await this.setUtimes(`${this.gradleUserHome}/**/${fileName}`, new Date(0)) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private async touchAllFiles(fileName = '*'): Promise<void> { | ||||||
|  |         core.debug(`Touching all files in Gradle User Home with name ${fileName}`) | ||||||
|  |         await this.setUtimes(`${this.gradleUserHome}/**/${fileName}`, new Date()) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private async setUtimes(pattern: string, timestamp: Date): Promise<void> { | ||||||
|  |         const globber = await glob.create(pattern, { | ||||||
|  |             implicitDescendants: false | ||||||
|  |         }) | ||||||
|  |         for await (const file of globber.globGenerator()) { | ||||||
|  |             fs.utimesSync(file, timestamp, timestamp) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										393
									
								
								src/cache-extract-entries.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										393
									
								
								src/cache-extract-entries.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,393 @@ | |||||||
|  | import path from 'path' | ||||||
|  | import fs from 'fs' | ||||||
|  | import * as core from '@actions/core' | ||||||
|  | import * as glob from '@actions/glob' | ||||||
|  |  | ||||||
|  | import {META_FILE_DIR} from './cache-base' | ||||||
|  | import {CacheEntryListener, CacheListener} from './cache-reporting' | ||||||
|  | import { | ||||||
|  |     cacheDebug, | ||||||
|  |     getCacheKeyPrefix, | ||||||
|  |     hashFileNames, | ||||||
|  |     isCacheDebuggingEnabled, | ||||||
|  |     restoreCache, | ||||||
|  |     saveCache, | ||||||
|  |     tryDelete | ||||||
|  | } from './cache-utils' | ||||||
|  | import {loadBuildResults} from './build-results' | ||||||
|  |  | ||||||
|  | const SKIP_RESTORE_VAR = 'GRADLE_BUILD_ACTION_SKIP_RESTORE' | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Represents the result of attempting to load or store an extracted cache entry. | ||||||
|  |  * An undefined cacheKey indicates that the operation did not succeed. | ||||||
|  |  * The collected results are then used to populate the `cache-metadata.json` file for later use. | ||||||
|  |  */ | ||||||
|  | class ExtractedCacheEntry { | ||||||
|  |     artifactType: string | ||||||
|  |     pattern: string | ||||||
|  |     cacheKey: string | undefined | ||||||
|  |  | ||||||
|  |     constructor(artifactType: string, pattern: string, cacheKey: string | undefined) { | ||||||
|  |         this.artifactType = artifactType | ||||||
|  |         this.pattern = pattern | ||||||
|  |         this.cacheKey = cacheKey | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Representation of all of the extracted cache entries for this Gradle User Home. | ||||||
|  |  * This object is persisted to JSON file in the Gradle User Home directory for storing, | ||||||
|  |  * and subsequently used to restore the Gradle User Home. | ||||||
|  |  */ | ||||||
|  | class ExtractedCacheEntryMetadata { | ||||||
|  |     entries: ExtractedCacheEntry[] = [] | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * The specification for a type of extracted cache entry. | ||||||
|  |  */ | ||||||
|  | class ExtractedCacheEntryDefinition { | ||||||
|  |     artifactType: string | ||||||
|  |     pattern: string | ||||||
|  |     bundle: boolean | ||||||
|  |     uniqueFileNames = true | ||||||
|  |  | ||||||
|  |     constructor(artifactType: string, pattern: string, bundle: boolean) { | ||||||
|  |         this.artifactType = artifactType | ||||||
|  |         this.pattern = pattern | ||||||
|  |         this.bundle = bundle | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     withNonUniqueFileNames(): ExtractedCacheEntryDefinition { | ||||||
|  |         this.uniqueFileNames = false | ||||||
|  |         return this | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Caches and restores the entire Gradle User Home directory, extracting entries containing common artifacts | ||||||
|  |  * for more efficient storage. | ||||||
|  |  */ | ||||||
|  | abstract class AbstractEntryExtractor { | ||||||
|  |     protected readonly gradleUserHome: string | ||||||
|  |     private extractorName: string | ||||||
|  |  | ||||||
|  |     constructor(gradleUserHome: string, extractorName: string) { | ||||||
|  |         this.gradleUserHome = gradleUserHome | ||||||
|  |         this.extractorName = extractorName | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Restores any artifacts that were cached separately, based on the information in the `cache-metadata.json` file. | ||||||
|  |      * Each extracted cache entry is restored in parallel, except when debugging is enabled. | ||||||
|  |      */ | ||||||
|  |     async restore(listener: CacheListener): Promise<void> { | ||||||
|  |         const previouslyExtractedCacheEntries = this.loadExtractedCacheEntries() | ||||||
|  |  | ||||||
|  |         const processes: Promise<ExtractedCacheEntry>[] = [] | ||||||
|  |  | ||||||
|  |         for (const cacheEntry of previouslyExtractedCacheEntries) { | ||||||
|  |             const artifactType = cacheEntry.artifactType | ||||||
|  |             const entryListener = listener.entry(cacheEntry.pattern) | ||||||
|  |  | ||||||
|  |             // Handle case where the extracted-cache-entry definitions have been changed | ||||||
|  |             const skipRestore = process.env[SKIP_RESTORE_VAR] || '' | ||||||
|  |             if (skipRestore.includes(artifactType)) { | ||||||
|  |                 core.info(`Not restoring extracted cache entry for ${artifactType}`) | ||||||
|  |                 entryListener.markRequested('SKIP_RESTORE') | ||||||
|  |             } else { | ||||||
|  |                 processes.push( | ||||||
|  |                     this.awaitForDebugging( | ||||||
|  |                         this.restoreExtractedCacheEntry( | ||||||
|  |                             artifactType, | ||||||
|  |                             cacheEntry.cacheKey!, | ||||||
|  |                             cacheEntry.pattern, | ||||||
|  |                             entryListener | ||||||
|  |                         ) | ||||||
|  |                     ) | ||||||
|  |                 ) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         this.saveMetadataForCacheResults(await Promise.all(processes)) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private async restoreExtractedCacheEntry( | ||||||
|  |         artifactType: string, | ||||||
|  |         cacheKey: string, | ||||||
|  |         pattern: string, | ||||||
|  |         listener: CacheEntryListener | ||||||
|  |     ): Promise<ExtractedCacheEntry> { | ||||||
|  |         const restoredEntry = await restoreCache([pattern], cacheKey, [], listener) | ||||||
|  |         if (restoredEntry) { | ||||||
|  |             core.info(`Restored ${artifactType} with key ${cacheKey} to ${pattern}`) | ||||||
|  |             return new ExtractedCacheEntry(artifactType, pattern, cacheKey) | ||||||
|  |         } else { | ||||||
|  |             core.info(`Did not restore ${artifactType} with key ${cacheKey} to ${pattern}`) | ||||||
|  |             return new ExtractedCacheEntry(artifactType, pattern, undefined) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Saves any artifacts that are configured to be cached separately, based on the extracted cache entry definitions. | ||||||
|  |      * Each entry is extracted and saved in parallel, except when debugging is enabled. | ||||||
|  |      */ | ||||||
|  |     async extract(listener: CacheListener): Promise<void> { | ||||||
|  |         // Load the cache entry definitions (from config) and the previously restored entries (from persisted metadata file) | ||||||
|  |         const cacheEntryDefinitions = this.getExtractedCacheEntryDefinitions() | ||||||
|  |         cacheDebug( | ||||||
|  |             `Extracting cache entries for ${this.extractorName}: ${JSON.stringify(cacheEntryDefinitions, null, 2)}` | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |         const previouslyRestoredEntries = this.loadExtractedCacheEntries() | ||||||
|  |         const cacheActions: Promise<ExtractedCacheEntry>[] = [] | ||||||
|  |  | ||||||
|  |         // For each cache entry definition, determine if it has already been restored, and if not, extract it | ||||||
|  |         for (const cacheEntryDefinition of cacheEntryDefinitions) { | ||||||
|  |             const artifactType = cacheEntryDefinition.artifactType | ||||||
|  |             const pattern = cacheEntryDefinition.pattern | ||||||
|  |  | ||||||
|  |             // Find all matching files for this cache entry definition | ||||||
|  |             const globber = await glob.create(pattern, { | ||||||
|  |                 implicitDescendants: false | ||||||
|  |             }) | ||||||
|  |             const matchingFiles = await globber.glob() | ||||||
|  |  | ||||||
|  |             if (matchingFiles.length === 0) { | ||||||
|  |                 cacheDebug(`No files found to cache for ${artifactType}`) | ||||||
|  |                 continue | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             if (cacheEntryDefinition.bundle) { | ||||||
|  |                 // For an extracted "bundle", use the defined pattern and cache all matching files in a single entry. | ||||||
|  |                 cacheActions.push( | ||||||
|  |                     this.awaitForDebugging( | ||||||
|  |                         this.saveExtractedCacheEntry( | ||||||
|  |                             matchingFiles, | ||||||
|  |                             artifactType, | ||||||
|  |                             pattern, | ||||||
|  |                             cacheEntryDefinition.uniqueFileNames, | ||||||
|  |                             previouslyRestoredEntries, | ||||||
|  |                             listener.entry(pattern) | ||||||
|  |                         ) | ||||||
|  |                     ) | ||||||
|  |                 ) | ||||||
|  |             } else { | ||||||
|  |                 // Otherwise cache each matching file in a separate entry, using the complete file path as the cache pattern. | ||||||
|  |                 for (const cacheFile of matchingFiles) { | ||||||
|  |                     cacheActions.push( | ||||||
|  |                         this.awaitForDebugging( | ||||||
|  |                             this.saveExtractedCacheEntry( | ||||||
|  |                                 [cacheFile], | ||||||
|  |                                 artifactType, | ||||||
|  |                                 cacheFile, | ||||||
|  |                                 cacheEntryDefinition.uniqueFileNames, | ||||||
|  |                                 previouslyRestoredEntries, | ||||||
|  |                                 listener.entry(cacheFile) | ||||||
|  |                             ) | ||||||
|  |                         ) | ||||||
|  |                     ) | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         this.saveMetadataForCacheResults(await Promise.all(cacheActions)) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private async saveExtractedCacheEntry( | ||||||
|  |         matchingFiles: string[], | ||||||
|  |         artifactType: string, | ||||||
|  |         pattern: string, | ||||||
|  |         uniqueFileNames: boolean, | ||||||
|  |         previouslyRestoredEntries: ExtractedCacheEntry[], | ||||||
|  |         entryListener: CacheEntryListener | ||||||
|  |     ): Promise<ExtractedCacheEntry> { | ||||||
|  |         const cacheKey = uniqueFileNames | ||||||
|  |             ? this.createCacheKeyFromFileNames(artifactType, matchingFiles) | ||||||
|  |             : await this.createCacheKeyFromFileContents(artifactType, pattern) | ||||||
|  |         const previouslyRestoredKey = previouslyRestoredEntries.find( | ||||||
|  |             x => x.artifactType === artifactType && x.pattern === pattern | ||||||
|  |         )?.cacheKey | ||||||
|  |  | ||||||
|  |         if (previouslyRestoredKey === cacheKey) { | ||||||
|  |             cacheDebug(`No change to previously restored ${artifactType}. Not saving.`) | ||||||
|  |             entryListener.markNotSaved('contents unchanged') | ||||||
|  |         } else { | ||||||
|  |             core.info(`Caching ${artifactType} with path '${pattern}' and cache key: ${cacheKey}`) | ||||||
|  |             await saveCache([pattern], cacheKey, entryListener) | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         for (const file of matchingFiles) { | ||||||
|  |             tryDelete(file) | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return new ExtractedCacheEntry(artifactType, pattern, cacheKey) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     protected createCacheKeyFromFileNames(artifactType: string, files: string[]): string { | ||||||
|  |         const cacheKeyPrefix = getCacheKeyPrefix() | ||||||
|  |         const relativeFiles = files.map(x => path.relative(this.gradleUserHome, x)) | ||||||
|  |         const key = hashFileNames(relativeFiles) | ||||||
|  |  | ||||||
|  |         cacheDebug(`Generating cache key for ${artifactType} from file names: ${relativeFiles}`) | ||||||
|  |  | ||||||
|  |         return `${cacheKeyPrefix}${artifactType}-${key}` | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     protected async createCacheKeyFromFileContents(artifactType: string, pattern: string): Promise<string> { | ||||||
|  |         const cacheKeyPrefix = getCacheKeyPrefix() | ||||||
|  |         const key = await glob.hashFiles(pattern) | ||||||
|  |  | ||||||
|  |         cacheDebug(`Generating cache key for ${artifactType} from files matching: ${pattern}`) | ||||||
|  |  | ||||||
|  |         return `${cacheKeyPrefix}${artifactType}-${key}` | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // Run actions sequentially if debugging is enabled | ||||||
|  |     private async awaitForDebugging(p: Promise<ExtractedCacheEntry>): Promise<ExtractedCacheEntry> { | ||||||
|  |         if (isCacheDebuggingEnabled()) { | ||||||
|  |             await p | ||||||
|  |         } | ||||||
|  |         return p | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Load information about the extracted cache entries previously restored/saved. This is loaded from the 'cache-metadata.json' file. | ||||||
|  |      */ | ||||||
|  |     protected loadExtractedCacheEntries(): ExtractedCacheEntry[] { | ||||||
|  |         const cacheMetadataFile = this.getCacheMetadataFile() | ||||||
|  |         if (!fs.existsSync(cacheMetadataFile)) { | ||||||
|  |             return [] | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         const filedata = fs.readFileSync(cacheMetadataFile, 'utf-8') | ||||||
|  |         cacheDebug(`Loaded cache metadata: ${filedata}`) | ||||||
|  |         const extractedCacheEntryMetadata = JSON.parse(filedata) as ExtractedCacheEntryMetadata | ||||||
|  |         return extractedCacheEntryMetadata.entries | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Saves information about the extracted cache entries into the 'cache-metadata.json' file. | ||||||
|  |      */ | ||||||
|  |     private saveMetadataForCacheResults(results: ExtractedCacheEntry[]): void { | ||||||
|  |         const extractedCacheEntryMetadata = new ExtractedCacheEntryMetadata() | ||||||
|  |         extractedCacheEntryMetadata.entries = results.filter(x => x.cacheKey !== undefined) | ||||||
|  |  | ||||||
|  |         const filedata = JSON.stringify(extractedCacheEntryMetadata) | ||||||
|  |         cacheDebug(`Saving cache metadata: ${filedata}`) | ||||||
|  |  | ||||||
|  |         fs.writeFileSync(this.getCacheMetadataFile(), filedata, 'utf-8') | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private getCacheMetadataFile(): string { | ||||||
|  |         const actionMetadataDirectory = path.resolve(this.gradleUserHome, META_FILE_DIR) | ||||||
|  |         fs.mkdirSync(actionMetadataDirectory, {recursive: true}) | ||||||
|  |  | ||||||
|  |         return path.resolve(actionMetadataDirectory, `${this.extractorName}-entry-metadata.json`) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     protected abstract getExtractedCacheEntryDefinitions(): ExtractedCacheEntryDefinition[] | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export class GradleHomeEntryExtractor extends AbstractEntryExtractor { | ||||||
|  |     constructor(gradleUserHome: string) { | ||||||
|  |         super(gradleUserHome, 'gradle-home') | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     async extract(listener: CacheListener): Promise<void> { | ||||||
|  |         await this.deleteWrapperZips() | ||||||
|  |         return super.extract(listener) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Delete any downloaded wrapper zip files that are not needed after extraction. | ||||||
|  |      * These files are cleaned up by Gradle >= 7.5, but for older versions we remove them manually. | ||||||
|  |      */ | ||||||
|  |     private async deleteWrapperZips(): Promise<void> { | ||||||
|  |         const wrapperZips = path.resolve(this.gradleUserHome, 'wrapper/dists/*/*/*.zip') | ||||||
|  |         const globber = await glob.create(wrapperZips, { | ||||||
|  |             implicitDescendants: false | ||||||
|  |         }) | ||||||
|  |  | ||||||
|  |         for (const wrapperZip of await globber.glob()) { | ||||||
|  |             cacheDebug(`Deleting wrapper zip: ${wrapperZip}`) | ||||||
|  |             await tryDelete(wrapperZip) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Return the extracted cache entry definitions, which determine which artifacts will be cached | ||||||
|  |      * separately from the rest of the Gradle User Home cache entry. | ||||||
|  |      */ | ||||||
|  |     protected getExtractedCacheEntryDefinitions(): ExtractedCacheEntryDefinition[] { | ||||||
|  |         const entryDefinition = ( | ||||||
|  |             artifactType: string, | ||||||
|  |             patterns: string[], | ||||||
|  |             bundle: boolean | ||||||
|  |         ): ExtractedCacheEntryDefinition => { | ||||||
|  |             const resolvedPatterns = patterns | ||||||
|  |                 .map(x => { | ||||||
|  |                     const isDir = x.endsWith('/') | ||||||
|  |                     const resolved = path.resolve(this.gradleUserHome, x) | ||||||
|  |                     return isDir ? `${resolved}/` : resolved // Restore trailing '/' removed by path.resolve() | ||||||
|  |                 }) | ||||||
|  |                 .join('\n') | ||||||
|  |             return new ExtractedCacheEntryDefinition(artifactType, resolvedPatterns, bundle) | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return [ | ||||||
|  |             entryDefinition('generated-gradle-jars', ['caches/*/generated-gradle-jars/*.jar'], false), | ||||||
|  |             entryDefinition('wrapper-zips', ['wrapper/dists/*/*/'], false), // Entire wrapper directory cached together | ||||||
|  |             entryDefinition('java-toolchains', ['jdks/*.zip', 'jdks/*.tar.gz'], false), | ||||||
|  |             entryDefinition('dependencies', ['caches/modules-*/files-*/*/*/*/*'], true), | ||||||
|  |             entryDefinition('instrumented-jars', ['caches/jars-*/*'], true), | ||||||
|  |             entryDefinition('kotlin-dsl', ['caches/*/kotlin-dsl/*/*'], true) | ||||||
|  |         ] | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export class ConfigurationCacheEntryExtractor extends AbstractEntryExtractor { | ||||||
|  |     constructor(gradleUserHome: string) { | ||||||
|  |         super(gradleUserHome, 'configuration-cache') | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Handle the case where Gradle User Home has not been fully restored, so that the configuration-cache | ||||||
|  |      * entry is not reusable. | ||||||
|  |      */ | ||||||
|  |     async restore(listener: CacheListener): Promise<void> { | ||||||
|  |         if (listener.fullyRestored) { | ||||||
|  |             return super.restore(listener) | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         core.info('Not restoring configuration-cache state, as Gradle User Home was not fully restored') | ||||||
|  |         for (const cacheEntry of this.loadExtractedCacheEntries()) { | ||||||
|  |             listener.entry(cacheEntry.pattern).markRequested('NOT_RESTORED') | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Extract cache entries for the configuration cache in each project. | ||||||
|  |      */ | ||||||
|  |     protected getExtractedCacheEntryDefinitions(): ExtractedCacheEntryDefinition[] { | ||||||
|  |         return this.getProjectRoots().map(projectRoot => { | ||||||
|  |             const configCachePath = path.resolve(projectRoot, '.gradle/configuration-cache') | ||||||
|  |             return new ExtractedCacheEntryDefinition( | ||||||
|  |                 'configuration-cache', | ||||||
|  |                 configCachePath, | ||||||
|  |                 true | ||||||
|  |             ).withNonUniqueFileNames() | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * For every Gradle invocation, we record the project root directory. This method returns the entire | ||||||
|  |      * set of project roots, to allow saving of configuration-cache entries for each. | ||||||
|  |      */ | ||||||
|  |     private getProjectRoots(): string[] { | ||||||
|  |         const buildResults = loadBuildResults() | ||||||
|  |         const projectRootDirs = buildResults.map(x => x.rootProjectDir) | ||||||
|  |         return [...new Set(projectRootDirs)] // Remove duplicates | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										228
									
								
								src/cache-reporting.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										228
									
								
								src/cache-reporting.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,228 @@ | |||||||
|  | import * as core from '@actions/core' | ||||||
|  | import * as cache from '@actions/cache' | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Collects information on what entries were saved and restored during the action. | ||||||
|  |  * This information is used to generate a summary of the cache usage. | ||||||
|  |  */ | ||||||
|  | export class CacheListener { | ||||||
|  |     cacheEntries: CacheEntryListener[] = [] | ||||||
|  |     cacheReadOnly = false | ||||||
|  |     cacheWriteOnly = false | ||||||
|  |     cacheDisabled = false | ||||||
|  |  | ||||||
|  |     get fullyRestored(): boolean { | ||||||
|  |         return this.cacheEntries.every(x => !x.wasRequestedButNotRestored()) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     get cacheStatus(): string { | ||||||
|  |         if (!cache.isFeatureAvailable()) return 'not available' | ||||||
|  |         if (this.cacheDisabled) return 'disabled' | ||||||
|  |         if (this.cacheWriteOnly) return 'write-only' | ||||||
|  |         if (this.cacheReadOnly) return 'read-only' | ||||||
|  |         return 'enabled' | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     entry(name: string): CacheEntryListener { | ||||||
|  |         for (const entry of this.cacheEntries) { | ||||||
|  |             if (entry.entryName === name) { | ||||||
|  |                 return entry | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         const newEntry = new CacheEntryListener(name) | ||||||
|  |         this.cacheEntries.push(newEntry) | ||||||
|  |         return newEntry | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     stringify(): string { | ||||||
|  |         return JSON.stringify(this) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     static rehydrate(stringRep: string): CacheListener { | ||||||
|  |         if (stringRep === '') { | ||||||
|  |             return new CacheListener() | ||||||
|  |         } | ||||||
|  |         const rehydrated: CacheListener = Object.assign(new CacheListener(), JSON.parse(stringRep)) | ||||||
|  |         const entries = rehydrated.cacheEntries | ||||||
|  |         for (let index = 0; index < entries.length; index++) { | ||||||
|  |             const rawEntry = entries[index] | ||||||
|  |             entries[index] = Object.assign(new CacheEntryListener(rawEntry.entryName), rawEntry) | ||||||
|  |         } | ||||||
|  |         return rehydrated | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Collects information on the state of a single cache entry. | ||||||
|  |  */ | ||||||
|  | export class CacheEntryListener { | ||||||
|  |     entryName: string | ||||||
|  |     requestedKey: string | undefined | ||||||
|  |     requestedRestoreKeys: string[] | undefined | ||||||
|  |     restoredKey: string | undefined | ||||||
|  |     restoredSize: number | undefined | ||||||
|  |     notRestored: string | undefined | ||||||
|  |  | ||||||
|  |     savedKey: string | undefined | ||||||
|  |     savedSize: number | undefined | ||||||
|  |     notSaved: string | undefined | ||||||
|  |  | ||||||
|  |     constructor(entryName: string) { | ||||||
|  |         this.entryName = entryName | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     wasRequestedButNotRestored(): boolean { | ||||||
|  |         return this.requestedKey !== undefined && this.restoredKey === undefined | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     markRequested(key: string, restoreKeys: string[] = []): CacheEntryListener { | ||||||
|  |         this.requestedKey = key | ||||||
|  |         this.requestedRestoreKeys = restoreKeys | ||||||
|  |         return this | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     markRestored(key: string, size: number | undefined): CacheEntryListener { | ||||||
|  |         this.restoredKey = key | ||||||
|  |         this.restoredSize = size | ||||||
|  |         return this | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     markNotRestored(message: string): CacheEntryListener { | ||||||
|  |         this.notRestored = message | ||||||
|  |         return this | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     markSaved(key: string, size: number | undefined): CacheEntryListener { | ||||||
|  |         this.savedKey = key | ||||||
|  |         this.savedSize = size | ||||||
|  |         return this | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     markAlreadyExists(key: string): CacheEntryListener { | ||||||
|  |         this.savedKey = key | ||||||
|  |         this.savedSize = 0 | ||||||
|  |         return this | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     markNotSaved(message: string): CacheEntryListener { | ||||||
|  |         this.notSaved = message | ||||||
|  |         return this | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function writeCachingReport(listener: CacheListener): void { | ||||||
|  |     const entries = listener.cacheEntries | ||||||
|  |  | ||||||
|  |     core.summary.addRaw( | ||||||
|  |         `\n<details><summary><h4>Caching for gradle-build-action was ${listener.cacheStatus} - expand for details</h4></summary>\n` | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |     core.summary.addTable([ | ||||||
|  |         [ | ||||||
|  |             {data: '', header: true}, | ||||||
|  |             {data: 'Count', header: true}, | ||||||
|  |             {data: 'Total Size (Mb)', header: true} | ||||||
|  |         ], | ||||||
|  |         ['Entries Restored', `${getCount(entries, e => e.restoredSize)}`, `${getSize(entries, e => e.restoredSize)}`], | ||||||
|  |         ['Entries Saved', `${getCount(entries, e => e.savedSize)}`, `${getSize(entries, e => e.savedSize)}`] | ||||||
|  |     ]) | ||||||
|  |  | ||||||
|  |     core.summary.addHeading('Cache Entry Details', 5) | ||||||
|  |  | ||||||
|  |     const entryDetails = renderEntryDetails(listener) | ||||||
|  |     core.summary.addRaw(`<pre> | ||||||
|  | ${entryDetails} | ||||||
|  | </pre> | ||||||
|  | </details> | ||||||
|  | `) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function logCachingReport(listener: CacheListener): void { | ||||||
|  |     const entries = listener.cacheEntries | ||||||
|  |  | ||||||
|  |     core.startGroup(`Caching for gradle-build-action was ${listener.cacheStatus} - expand for details`) | ||||||
|  |  | ||||||
|  |     core.info( | ||||||
|  |         `Entries Restored: ${getCount(entries, e => e.restoredSize)} (${getSize(entries, e => e.restoredSize)} Mb)` | ||||||
|  |     ) | ||||||
|  |     core.info(`Entries Saved   : ${getCount(entries, e => e.savedSize)} (${getSize(entries, e => e.savedSize)} Mb)`) | ||||||
|  |  | ||||||
|  |     core.info(`Cache Entry Details`) | ||||||
|  |     core.info(renderEntryDetails(listener)) | ||||||
|  |  | ||||||
|  |     core.endGroup() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function renderEntryDetails(listener: CacheListener): string { | ||||||
|  |     return listener.cacheEntries | ||||||
|  |         .map( | ||||||
|  |             entry => `Entry: ${entry.entryName} | ||||||
|  |     Requested Key : ${entry.requestedKey ?? ''} | ||||||
|  |     Restored  Key : ${entry.restoredKey ?? ''} | ||||||
|  |               Size: ${formatSize(entry.restoredSize)} | ||||||
|  |               ${getRestoredMessage(entry, listener.cacheWriteOnly)} | ||||||
|  |     Saved     Key : ${entry.savedKey ?? ''} | ||||||
|  |               Size: ${formatSize(entry.savedSize)} | ||||||
|  |               ${getSavedMessage(entry, listener.cacheReadOnly)} | ||||||
|  | ` | ||||||
|  |         ) | ||||||
|  |         .join('---\n') | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getRestoredMessage(entry: CacheEntryListener, cacheWriteOnly: boolean): string { | ||||||
|  |     if (entry.notRestored) { | ||||||
|  |         return `(Entry not restored: ${entry.notRestored})` | ||||||
|  |     } | ||||||
|  |     if (cacheWriteOnly) { | ||||||
|  |         return '(Entry not restored: cache is write-only)' | ||||||
|  |     } | ||||||
|  |     if (entry.requestedKey === undefined) { | ||||||
|  |         return '(Entry not restored: not requested)' | ||||||
|  |     } | ||||||
|  |     if (entry.restoredKey === undefined) { | ||||||
|  |         return '(Entry not restored: no match found)' | ||||||
|  |     } | ||||||
|  |     if (entry.restoredKey === entry.requestedKey) { | ||||||
|  |         return '(Entry restored: exact match found)' | ||||||
|  |     } | ||||||
|  |     return '(Entry restored: partial match found)' | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getSavedMessage(entry: CacheEntryListener, cacheReadOnly: boolean): string { | ||||||
|  |     if (entry.notSaved) { | ||||||
|  |         return `(Entry not saved: ${entry.notSaved})` | ||||||
|  |     } | ||||||
|  |     if (entry.savedKey === undefined) { | ||||||
|  |         if (cacheReadOnly) { | ||||||
|  |             return '(Entry not saved: cache is read-only)' | ||||||
|  |         } | ||||||
|  |         return '(Entry not saved: reason unknown)' | ||||||
|  |     } | ||||||
|  |     if (entry.savedSize === 0) { | ||||||
|  |         return '(Entry not saved: entry with key already exists)' | ||||||
|  |     } | ||||||
|  |     return '(Entry saved)' | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getCount( | ||||||
|  |     cacheEntries: CacheEntryListener[], | ||||||
|  |     predicate: (value: CacheEntryListener) => number | undefined | ||||||
|  | ): number { | ||||||
|  |     return cacheEntries.filter(e => predicate(e)).length | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getSize( | ||||||
|  |     cacheEntries: CacheEntryListener[], | ||||||
|  |     predicate: (value: CacheEntryListener) => number | undefined | ||||||
|  | ): number { | ||||||
|  |     const bytes = cacheEntries.map(e => predicate(e) ?? 0).reduce((p, v) => p + v, 0) | ||||||
|  |     return Math.round(bytes / (1024 * 1024)) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function formatSize(bytes: number | undefined): string { | ||||||
|  |     if (bytes === undefined || bytes === 0) { | ||||||
|  |         return '' | ||||||
|  |     } | ||||||
|  |     return `${Math.round(bytes / (1024 * 1024))} MB (${bytes} B)` | ||||||
|  | } | ||||||
							
								
								
									
										252
									
								
								src/cache-utils.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										252
									
								
								src/cache-utils.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,252 @@ | |||||||
|  | import * as core from '@actions/core' | ||||||
|  | import * as cache from '@actions/cache' | ||||||
|  | import * as github from '@actions/github' | ||||||
|  | import * as exec from '@actions/exec' | ||||||
|  |  | ||||||
|  | import * as crypto from 'crypto' | ||||||
|  | import * as path from 'path' | ||||||
|  | import * as fs from 'fs' | ||||||
|  |  | ||||||
|  | import {CacheEntryListener} from './cache-reporting' | ||||||
|  |  | ||||||
|  | const CACHE_PROTOCOL_VERSION = 'v6-' | ||||||
|  |  | ||||||
|  | const JOB_CONTEXT_PARAMETER = 'workflow-job-context' | ||||||
|  | const CACHE_DISABLED_PARAMETER = 'cache-disabled' | ||||||
|  | const CACHE_READONLY_PARAMETER = 'cache-read-only' | ||||||
|  | const CACHE_WRITEONLY_PARAMETER = 'cache-write-only' | ||||||
|  | const STRICT_CACHE_MATCH_PARAMETER = 'gradle-home-cache-strict-match' | ||||||
|  | const CACHE_CLEANUP_ENABLED_PARAMETER = 'gradle-home-cache-cleanup' | ||||||
|  | const CACHE_DEBUG_VAR = 'GRADLE_BUILD_ACTION_CACHE_DEBUG_ENABLED' | ||||||
|  |  | ||||||
|  | const CACHE_KEY_PREFIX_VAR = 'GRADLE_BUILD_ACTION_CACHE_KEY_PREFIX' | ||||||
|  | const CACHE_KEY_OS_VAR = 'GRADLE_BUILD_ACTION_CACHE_KEY_ENVIRONMENT' | ||||||
|  | const CACHE_KEY_JOB_VAR = 'GRADLE_BUILD_ACTION_CACHE_KEY_JOB' | ||||||
|  | const CACHE_KEY_JOB_INSTANCE_VAR = 'GRADLE_BUILD_ACTION_CACHE_KEY_JOB_INSTANCE' | ||||||
|  | const CACHE_KEY_JOB_EXECUTION_VAR = 'GRADLE_BUILD_ACTION_CACHE_KEY_JOB_EXECUTION' | ||||||
|  |  | ||||||
|  | const SEGMENT_DOWNLOAD_TIMEOUT_VAR = 'SEGMENT_DOWNLOAD_TIMEOUT_MINS' | ||||||
|  | const SEGMENT_DOWNLOAD_TIMEOUT_DEFAULT = 10 * 60 * 1000 // 10 minutes | ||||||
|  |  | ||||||
|  | export function isCacheDisabled(): boolean { | ||||||
|  |     if (!cache.isFeatureAvailable()) { | ||||||
|  |         return true | ||||||
|  |     } | ||||||
|  |     return core.getBooleanInput(CACHE_DISABLED_PARAMETER) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function isCacheReadOnly(): boolean { | ||||||
|  |     return !isCacheWriteOnly() && core.getBooleanInput(CACHE_READONLY_PARAMETER) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function isCacheWriteOnly(): boolean { | ||||||
|  |     return core.getBooleanInput(CACHE_WRITEONLY_PARAMETER) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function isCacheDebuggingEnabled(): boolean { | ||||||
|  |     return process.env[CACHE_DEBUG_VAR] ? true : false | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function isCacheCleanupEnabled(): boolean { | ||||||
|  |     return core.getBooleanInput(CACHE_CLEANUP_ENABLED_PARAMETER) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Represents a key used to restore a cache entry. | ||||||
|  |  * The Github Actions cache will first try for an exact match on the key. | ||||||
|  |  * If that fails, it will try for a prefix match on any of the restoreKeys. | ||||||
|  |  */ | ||||||
|  | export class CacheKey { | ||||||
|  |     key: string | ||||||
|  |     restoreKeys: string[] | ||||||
|  |  | ||||||
|  |     constructor(key: string, restoreKeys: string[]) { | ||||||
|  |         this.key = key | ||||||
|  |         this.restoreKeys = restoreKeys | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Generates a cache key specific to the current job execution. | ||||||
|  |  * The key is constructed from the following inputs (with some user overrides): | ||||||
|  |  * - The cache protocol version | ||||||
|  |  * - The name of the cache | ||||||
|  |  * - The runner operating system | ||||||
|  |  * - The name of the Job being executed | ||||||
|  |  * - The matrix values for the Job being executed (job context) | ||||||
|  |  * - The SHA of the commit being executed | ||||||
|  |  * | ||||||
|  |  * Caches are restored by trying to match the these key prefixes in order: | ||||||
|  |  * - The full key with SHA | ||||||
|  |  * - A previous key for this Job + matrix | ||||||
|  |  * - Any previous key for this Job (any matrix) | ||||||
|  |  * - Any previous key for this cache on the current OS | ||||||
|  |  */ | ||||||
|  | export function generateCacheKey(cacheName: string): CacheKey { | ||||||
|  |     const cacheKeyBase = `${getCacheKeyPrefix()}${CACHE_PROTOCOL_VERSION}${cacheName}` | ||||||
|  |  | ||||||
|  |     // At the most general level, share caches for all executions on the same OS | ||||||
|  |     const cacheKeyForEnvironment = `${cacheKeyBase}|${getCacheKeyEnvironment()}` | ||||||
|  |  | ||||||
|  |     // Prefer caches that run this job | ||||||
|  |     const cacheKeyForJob = `${cacheKeyForEnvironment}|${getCacheKeyJob()}` | ||||||
|  |  | ||||||
|  |     // Prefer (even more) jobs that run this job with the same context (matrix) | ||||||
|  |     const cacheKeyForJobContext = `${cacheKeyForJob}[${getCacheKeyJobInstance()}]` | ||||||
|  |  | ||||||
|  |     // Exact match on Git SHA | ||||||
|  |     const cacheKey = `${cacheKeyForJobContext}-${getCacheKeyJobExecution()}` | ||||||
|  |  | ||||||
|  |     if (core.getBooleanInput(STRICT_CACHE_MATCH_PARAMETER)) { | ||||||
|  |         return new CacheKey(cacheKey, [cacheKeyForJobContext]) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return new CacheKey(cacheKey, [cacheKeyForJobContext, cacheKeyForJob, cacheKeyForEnvironment]) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function getCacheKeyPrefix(): string { | ||||||
|  |     // Prefix can be used to force change all cache keys (defaults to cache protocol version) | ||||||
|  |     return process.env[CACHE_KEY_PREFIX_VAR] || '' | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getCacheKeyEnvironment(): string { | ||||||
|  |     const runnerOs = process.env['RUNNER_OS'] || '' | ||||||
|  |     return process.env[CACHE_KEY_OS_VAR] || runnerOs | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getCacheKeyJob(): string { | ||||||
|  |     // Prefix can be used to force change all cache keys (defaults to cache protocol version) | ||||||
|  |     return process.env[CACHE_KEY_JOB_VAR] || github.context.job | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getCacheKeyJobInstance(): string { | ||||||
|  |     const override = process.env[CACHE_KEY_JOB_INSTANCE_VAR] | ||||||
|  |     if (override) { | ||||||
|  |         return override | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // By default, we hash the full `matrix` data for the run, to uniquely identify this job invocation | ||||||
|  |     // The only way we can obtain the `matrix` data is via the `workflow-job-context` parameter in action.yml. | ||||||
|  |     const workflowJobContext = core.getInput(JOB_CONTEXT_PARAMETER) | ||||||
|  |     return hashStrings([workflowJobContext]) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getCacheKeyJobExecution(): string { | ||||||
|  |     // Used to associate a cache key with a particular execution (default is bound to the git commit sha) | ||||||
|  |     return process.env[CACHE_KEY_JOB_EXECUTION_VAR] || github.context.sha | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function hashFileNames(fileNames: string[]): string { | ||||||
|  |     return hashStrings(fileNames.map(x => x.replace(new RegExp(`\\${path.sep}`, 'g'), '/'))) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function hashStrings(values: string[]): string { | ||||||
|  |     const hash = crypto.createHash('md5') | ||||||
|  |     for (const value of values) { | ||||||
|  |         hash.update(value) | ||||||
|  |     } | ||||||
|  |     return hash.digest('hex') | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export async function restoreCache( | ||||||
|  |     cachePath: string[], | ||||||
|  |     cacheKey: string, | ||||||
|  |     cacheRestoreKeys: string[], | ||||||
|  |     listener: CacheEntryListener | ||||||
|  | ): Promise<cache.CacheEntry | undefined> { | ||||||
|  |     listener.markRequested(cacheKey, cacheRestoreKeys) | ||||||
|  |     try { | ||||||
|  |         // Only override the read timeout if the SEGMENT_DOWNLOAD_TIMEOUT_MINS env var has NOT been set | ||||||
|  |         const cacheRestoreOptions = process.env[SEGMENT_DOWNLOAD_TIMEOUT_VAR] | ||||||
|  |             ? {} | ||||||
|  |             : {segmentTimeoutInMs: SEGMENT_DOWNLOAD_TIMEOUT_DEFAULT} | ||||||
|  |         const restoredEntry = await cache.restoreCache(cachePath, cacheKey, cacheRestoreKeys, cacheRestoreOptions) | ||||||
|  |         if (restoredEntry !== undefined) { | ||||||
|  |             listener.markRestored(restoredEntry.key, restoredEntry.size) | ||||||
|  |         } | ||||||
|  |         return restoredEntry | ||||||
|  |     } catch (error) { | ||||||
|  |         listener.markNotRestored((error as Error).message) | ||||||
|  |         handleCacheFailure(error, `Failed to restore ${cacheKey}`) | ||||||
|  |         return undefined | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export async function saveCache(cachePath: string[], cacheKey: string, listener: CacheEntryListener): Promise<void> { | ||||||
|  |     try { | ||||||
|  |         const savedEntry = await cache.saveCache(cachePath, cacheKey) | ||||||
|  |         listener.markSaved(savedEntry.key, savedEntry.size) | ||||||
|  |     } catch (error) { | ||||||
|  |         if (error instanceof cache.ReserveCacheError) { | ||||||
|  |             listener.markAlreadyExists(cacheKey) | ||||||
|  |         } else { | ||||||
|  |             listener.markNotSaved((error as Error).message) | ||||||
|  |         } | ||||||
|  |         handleCacheFailure(error, `Failed to save cache entry with path '${cachePath}' and key: ${cacheKey}`) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function cacheDebug(message: string): void { | ||||||
|  |     if (isCacheDebuggingEnabled()) { | ||||||
|  |         core.info(message) | ||||||
|  |     } else { | ||||||
|  |         core.debug(message) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function handleCacheFailure(error: unknown, message: string): void { | ||||||
|  |     if (error instanceof cache.ValidationError) { | ||||||
|  |         // Fail on cache validation errors | ||||||
|  |         throw error | ||||||
|  |     } | ||||||
|  |     if (error instanceof cache.ReserveCacheError) { | ||||||
|  |         // Reserve cache errors are expected if the artifact has been previously cached | ||||||
|  |         core.info(`${message}: ${error}`) | ||||||
|  |     } else { | ||||||
|  |         // Warn on all other errors | ||||||
|  |         core.warning(`${message}: ${error}`) | ||||||
|  |         if (error instanceof Error && error.stack) { | ||||||
|  |             cacheDebug(error.stack) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Attempt to delete a file or directory, waiting to allow locks to be released | ||||||
|  |  */ | ||||||
|  | export async function tryDelete(file: string): Promise<void> { | ||||||
|  |     const maxAttempts = 5 | ||||||
|  |     for (let attempt = 1; attempt <= maxAttempts; attempt++) { | ||||||
|  |         if (!fs.existsSync(file)) { | ||||||
|  |             return | ||||||
|  |         } | ||||||
|  |         try { | ||||||
|  |             const stat = fs.lstatSync(file) | ||||||
|  |             if (stat.isDirectory()) { | ||||||
|  |                 fs.rmdirSync(file, {recursive: true}) | ||||||
|  |             } else { | ||||||
|  |                 fs.unlinkSync(file) | ||||||
|  |             } | ||||||
|  |             return | ||||||
|  |         } catch (error) { | ||||||
|  |             if (attempt === maxAttempts) { | ||||||
|  |                 core.warning(`Failed to delete ${file}, which will impact caching.  | ||||||
|  | It is likely locked by another process. Output of 'jps -ml': | ||||||
|  | ${await getJavaProcesses()}`) | ||||||
|  |                 throw error | ||||||
|  |             } else { | ||||||
|  |                 cacheDebug(`Attempt to delete ${file} failed. Will try again.`) | ||||||
|  |                 await delay(1000) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function delay(ms: number): Promise<void> { | ||||||
|  |     return new Promise(resolve => setTimeout(resolve, ms)) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function getJavaProcesses(): Promise<string> { | ||||||
|  |     const jpsOutput = await exec.getExecOutput('jps', ['-lm']) | ||||||
|  |     return jpsOutput.stdout | ||||||
|  | } | ||||||
							
								
								
									
										88
									
								
								src/caches.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								src/caches.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,88 @@ | |||||||
|  | import * as core from '@actions/core' | ||||||
|  | import {isCacheCleanupEnabled, isCacheDisabled, isCacheReadOnly, isCacheWriteOnly} from './cache-utils' | ||||||
|  | import {CacheListener} from './cache-reporting' | ||||||
|  | import {DaemonController} from './daemon-controller' | ||||||
|  | import {GradleStateCache} from './cache-base' | ||||||
|  | import {CacheCleaner} from './cache-cleaner' | ||||||
|  |  | ||||||
|  | const CACHE_RESTORED_VAR = 'GRADLE_BUILD_ACTION_CACHE_RESTORED' | ||||||
|  |  | ||||||
|  | export async function restore(gradleUserHome: string, cacheListener: CacheListener): Promise<void> { | ||||||
|  |     // Bypass restore cache on all but first action step in workflow. | ||||||
|  |     if (process.env[CACHE_RESTORED_VAR]) { | ||||||
|  |         core.info('Cache only restored on first action step.') | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |     core.exportVariable(CACHE_RESTORED_VAR, true) | ||||||
|  |  | ||||||
|  |     const gradleStateCache = new GradleStateCache(gradleUserHome) | ||||||
|  |  | ||||||
|  |     if (isCacheDisabled()) { | ||||||
|  |         core.info('Cache is disabled: will not restore state from previous builds.') | ||||||
|  |         // Initialize the Gradle User Home even when caching is disabled. | ||||||
|  |         gradleStateCache.init() | ||||||
|  |         cacheListener.cacheDisabled = true | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (gradleStateCache.cacheOutputExists()) { | ||||||
|  |         core.info('Gradle User Home already exists: will not restore from cache.') | ||||||
|  |         // Initialize pre-existing Gradle User Home. | ||||||
|  |         gradleStateCache.init() | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     gradleStateCache.init() | ||||||
|  |     // Mark the state as restored so that post-action will perform save. | ||||||
|  |     core.saveState(CACHE_RESTORED_VAR, true) | ||||||
|  |  | ||||||
|  |     if (isCacheWriteOnly()) { | ||||||
|  |         core.info('Cache is write-only: will not restore from cache.') | ||||||
|  |         cacheListener.cacheWriteOnly = true | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     await core.group('Restore Gradle state from cache', async () => { | ||||||
|  |         await gradleStateCache.restore(cacheListener) | ||||||
|  |     }) | ||||||
|  |  | ||||||
|  |     if (isCacheCleanupEnabled() && !isCacheReadOnly()) { | ||||||
|  |         core.info('Preparing cache for cleanup.') | ||||||
|  |         const cacheCleaner = new CacheCleaner(gradleUserHome, process.env['RUNNER_TEMP']!) | ||||||
|  |         await cacheCleaner.prepare() | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export async function save( | ||||||
|  |     gradleUserHome: string, | ||||||
|  |     cacheListener: CacheListener, | ||||||
|  |     daemonController: DaemonController | ||||||
|  | ): Promise<void> { | ||||||
|  |     if (isCacheDisabled()) { | ||||||
|  |         core.info('Cache is disabled: will not save state for later builds.') | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (!core.getState(CACHE_RESTORED_VAR)) { | ||||||
|  |         core.info('Cache will not be saved: not restored in main action step.') | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (isCacheReadOnly()) { | ||||||
|  |         core.info('Cache is read-only: will not save state for use in subsequent builds.') | ||||||
|  |         cacheListener.cacheReadOnly = true | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     await daemonController.stopAllDaemons() | ||||||
|  |  | ||||||
|  |     if (isCacheCleanupEnabled()) { | ||||||
|  |         core.info('Forcing cache cleanup.') | ||||||
|  |         const cacheCleaner = new CacheCleaner(gradleUserHome, process.env['RUNNER_TEMP']!) | ||||||
|  |         await cacheCleaner.forceCleanup() | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     await core.group('Caching Gradle state', async () => { | ||||||
|  |         return new GradleStateCache(gradleUserHome).save(cacheListener) | ||||||
|  |     }) | ||||||
|  | } | ||||||
							
								
								
									
										36
									
								
								src/daemon-controller.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								src/daemon-controller.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | |||||||
|  | import * as core from '@actions/core' | ||||||
|  | import * as exec from '@actions/exec' | ||||||
|  | import * as fs from 'fs' | ||||||
|  | import * as path from 'path' | ||||||
|  | import {BuildResult} from './build-results' | ||||||
|  |  | ||||||
|  | export class DaemonController { | ||||||
|  |     private readonly gradleHomes | ||||||
|  |  | ||||||
|  |     constructor(buildResults: BuildResult[]) { | ||||||
|  |         const allHomes = buildResults.map(buildResult => buildResult.gradleHomeDir) | ||||||
|  |         this.gradleHomes = Array.from(new Set(allHomes)) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     async stopAllDaemons(): Promise<void> { | ||||||
|  |         core.info('Stopping all Gradle daemons before saving Gradle User Home state') | ||||||
|  |  | ||||||
|  |         const executions: Promise<number>[] = [] | ||||||
|  |         const args = ['--stop'] | ||||||
|  |  | ||||||
|  |         for (const gradleHome of this.gradleHomes) { | ||||||
|  |             const executable = path.resolve(gradleHome, 'bin', 'gradle') | ||||||
|  |             if (!fs.existsSync(executable)) { | ||||||
|  |                 core.warning(`Gradle executable not found at ${executable}. Could not stop Gradle daemons.`) | ||||||
|  |                 continue | ||||||
|  |             } | ||||||
|  |             core.info(`Stopping Gradle daemons for ${gradleHome}`) | ||||||
|  |             executions.push( | ||||||
|  |                 exec.exec(executable, args, { | ||||||
|  |                     ignoreReturnCode: true | ||||||
|  |                 }) | ||||||
|  |             ) | ||||||
|  |         } | ||||||
|  |         await Promise.all(executions) | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -1,40 +1,26 @@ | |||||||
| import * as exec from "@actions/exec"; | import * as core from '@actions/core' | ||||||
|  | import * as exec from '@actions/exec' | ||||||
|  | import fs from 'fs' | ||||||
|  | import * as gradlew from './gradlew' | ||||||
|  |  | ||||||
|  | export async function executeGradleBuild(executable: string | undefined, root: string, args: string[]): Promise<void> { | ||||||
| export async function execute(executable: string, root: string, argv: string[]): Promise<BuildResult> { |     // Use the provided executable, or look for a Gradle wrapper script to run | ||||||
|  |     const toExecute = executable ?? gradlew.locateGradleWrapperScript(root) | ||||||
|     let publishing = false; |     verifyIsExecutableScript(toExecute) | ||||||
|     let buildScanLink: any = null; |     const status: number = await exec.exec(toExecute, args, { | ||||||
|  |  | ||||||
|     await exec.exec(executable, argv, { |  | ||||||
|         cwd: root, |         cwd: root, | ||||||
|         listeners: { |         ignoreReturnCode: true | ||||||
|             stdline: (line: string) => { |     }) | ||||||
|                 if (line.startsWith("Publishing build scan...")) { |  | ||||||
|                     publishing = true; |  | ||||||
|                 } |  | ||||||
|                 if (publishing && line.length == 0) { |  | ||||||
|                     publishing = false |  | ||||||
|                 } |  | ||||||
|                 if (publishing && line.startsWith("http")) { |  | ||||||
|                     buildScanLink = line.trim(); |  | ||||||
|                     publishing = false |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     if (buildScanLink != null) { |     if (status !== 0) { | ||||||
|         return new BuildResultImpl(buildScanLink.toString()); |         core.setFailed(`Gradle build failed: see console output for details`) | ||||||
|     } |     } | ||||||
|     return new BuildResultImpl(null as unknown as string); | } | ||||||
| } |  | ||||||
|  | function verifyIsExecutableScript(toExecute: string): void { | ||||||
| export interface BuildResult { |     try { | ||||||
|     buildScanUrl: string |         fs.accessSync(toExecute, fs.constants.X_OK) | ||||||
| } |     } catch (err) { | ||||||
|  |         throw new Error(`Gradle script '${toExecute}' is not executable.`) | ||||||
| class BuildResultImpl implements BuildResult { |  | ||||||
|     constructor(readonly buildScanUrl: string) { |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,9 +1,26 @@ | |||||||
| export function wrapperFilename() { | import * as path from 'path' | ||||||
|     const isWindows = process.platform === "win32"; | import fs from 'fs' | ||||||
|     return isWindows ? "gradlew.bat" : "gradlew"; |  | ||||||
|  | const IS_WINDOWS = process.platform === 'win32' | ||||||
|  |  | ||||||
|  | export function wrapperScriptFilename(): string { | ||||||
|  |     return IS_WINDOWS ? 'gradlew.bat' : 'gradlew' | ||||||
| } | } | ||||||
|  |  | ||||||
| export function installScriptFilename() { | export function installScriptFilename(): string { | ||||||
|     const isWindows = process.platform === "win32"; |     return IS_WINDOWS ? 'gradle.bat' : 'gradle' | ||||||
|     return isWindows ? "gradle.bat" : "gradle"; | } | ||||||
|  |  | ||||||
|  | export function locateGradleWrapperScript(buildRootDirectory: string): string { | ||||||
|  |     validateGradleWrapper(buildRootDirectory) | ||||||
|  |     return path.resolve(buildRootDirectory, wrapperScriptFilename()) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function validateGradleWrapper(buildRootDirectory: string): void { | ||||||
|  |     const wrapperProperties = path.resolve(buildRootDirectory, 'gradle/wrapper/gradle-wrapper.properties') | ||||||
|  |     if (!fs.existsSync(wrapperProperties)) { | ||||||
|  |         throw new Error( | ||||||
|  |             `Cannot locate a Gradle wrapper properties file at '${wrapperProperties}'. Specify 'gradle-version' or 'gradle-executable' for projects without Gradle wrapper configured.` | ||||||
|  |         ) | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user