mirror of
				https://github.com/shivammathur/setup-php.git
				synced 2025-10-26 05:05:09 +07:00 
			
		
		
		
	Compare commits
	
		
			365 Commits
		
	
	
		
			1.5.1
			...
			releases/v
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| bc71c880ee | |||
| 28c92ba4ee | |||
| ffd019edc6 | |||
| 0e506b34ac | |||
| aa0ecfbc6f | |||
| f29cd24dbf | |||
| 2a41b9d1ba | |||
| 2a0c477416 | |||
| 61aa0dc2f9 | |||
| f4e1b8d33e | |||
| e3a498a6a5 | |||
| fbdd58c5bc | |||
| 2c5cb7a75e | |||
| ab12e42197 | |||
| 5588437714 | |||
| d7eb9ade23 | |||
| 938988b211 | |||
| e030852d0e | |||
| 3aa870b0fe | |||
| 1229133602 | |||
| b1b8d8367c | |||
| 60ff55130a | |||
| e5690a9659 | |||
| 7958a5ccff | |||
| 113a31fceb | |||
| c9aea8708f | |||
| 7435bb8e4a | |||
| 5227e2cd5c | |||
| 906893d397 | |||
| f1b6b2bbe0 | |||
| e59c938e82 | |||
| 506357cdb9 | |||
| b57416e44d | |||
| 9d1fe69816 | |||
| fec64d1788 | |||
| 32c1436247 | |||
| baab28a534 | |||
| d58b967b58 | |||
| 17f3c38947 | |||
| 988f48930d | |||
| ea50e73b1f | |||
| bc906f7414 | |||
| 8bed24ebe1 | |||
| 698464efea | |||
| 45082e25a9 | |||
| f0338c8922 | |||
| 49311db00a | |||
| 7d9584bd3f | |||
| 45df3b1713 | |||
| 70cd53866f | |||
| 12d6e834b7 | |||
| 9fdc82bced | |||
| c485e8b283 | |||
| 7a90166ec2 | |||
| 8f96f50dcd | |||
| c470f034d0 | |||
| e2ad91ce1c | |||
| cb746892c2 | |||
| 8f542eae1a | |||
| 0769672a24 | |||
| c20693a6ca | |||
| 0c0ae39775 | |||
| d27996462b | |||
| 0a5e543af7 | |||
| 0cc14f65a2 | |||
| 1ecc5fdca3 | |||
| 5520fdb61a | |||
| d0f1a91dfd | |||
| 276480411d | |||
| 827b051fea | |||
| fdaf1f0003 | |||
| 030f4839d4 | |||
| 1bb08cc017 | |||
| 678ad243bf | |||
| 20b87bc786 | |||
| 288f9953ef | |||
| 77ac7d57f1 | |||
| 8983fb3ae2 | |||
| 87a933f720 | |||
| 847ea65468 | |||
| c52ce057af | |||
| 46b357b6c2 | |||
| 2fc508f43d | |||
| d8de30560b | |||
| 02db83ef5f | |||
| 6728eaf2ad | |||
| ca291eadaf | |||
| 8185c8186b | |||
| 44cf056ba8 | |||
| 9bfde13f48 | |||
| e38eccad04 | |||
| fa211a9d07 | |||
| 5865982519 | |||
| e201830bdd | |||
| 5c4074b01a | |||
| 48f537d6d0 | |||
| bc40a61480 | |||
| 3d5fae7917 | |||
| d0591e6d7c | |||
| b108a66489 | |||
| f0a05b4f6e | |||
| 5070ebd871 | |||
| bea4065e11 | |||
| c3875408ad | |||
| 1d1c0f2595 | |||
| 1ac189066e | |||
| 74cdfb97c1 | |||
| ee05ca54f6 | |||
| 12b1061a6b | |||
| 1c6058bc18 | |||
| 2f8045c593 | |||
| 6597a6a15b | |||
| 1cc85eb670 | |||
| 6cba0a914f | |||
| c43f842cf3 | |||
| 11e062bf23 | |||
| dee3cfee50 | |||
| 26b0fcc6cd | |||
| ab62fff526 | |||
| 446bccb14d | |||
| 29d99c6866 | |||
| 1444e002ab | |||
| 03b97e24e9 | |||
| f7fb800623 | |||
| 5593bd4bd3 | |||
| 3160874a27 | |||
| db0bbd209b | |||
| d920044a54 | |||
| 818ca89f55 | |||
| 8876ac788f | |||
| 0390a48770 | |||
| 274e348895 | |||
| 37d7b37f43 | |||
| d058d52012 | |||
| 17983e66e5 | |||
| 33a005dd90 | |||
| 1870ffc08c | |||
| 70fd71ab48 | |||
| 2f1900f7bc | |||
| 19497a0597 | |||
| 5b2e081bc0 | |||
| 66fa82fbca | |||
| 4aa42214b1 | |||
| 1e2c96a4b4 | |||
| 3e8d887b0d | |||
| a3d5500a6a | |||
| e763fddf01 | |||
| 3cd5c7fd3a | |||
| 988cef62da | |||
| be3ee05178 | |||
| a74c3369c5 | |||
| b9ef39c812 | |||
| 782615d572 | |||
| 31411b0d4d | |||
| 6b93e48d83 | |||
| fe504c5e23 | |||
| 61d755bd59 | |||
| 3455b4ca37 | |||
| 35c24a7d2f | |||
| da7361cc8f | |||
| 3f4c1842a0 | |||
| 062567eeb1 | |||
| 00b0d694d0 | |||
| 54afb29ef6 | |||
| 41329810ef | |||
| 90a6d88c24 | |||
| 8e6968c49e | |||
| 4ce413f558 | |||
| 533e0949a8 | |||
| 0ffe535b8e | |||
| 55fe8db60d | |||
| 5af5f992ec | |||
| e9e024e600 | |||
| a7ea0636d7 | |||
| c471c0a458 | |||
| 277239149a | |||
| 9385896f2a | |||
| 9cabd8564d | |||
| fdfa901941 | |||
| 527cd148c8 | |||
| 59b6e2b54a | |||
| 5ad0888329 | |||
| 3cfc409e14 | |||
| ebc671081f | |||
| efae663c0f | |||
| fa8a671e6f | |||
| 6a4159ba98 | |||
| 0da52b1327 | |||
| 3579c7ef28 | |||
| d9cf6f5ad6 | |||
| ea50c7c0a2 | |||
| 6ca549dcaa | |||
| d3760be2cc | |||
| 3454287b87 | |||
| 88c7757dc8 | |||
| 48cfea3f3e | |||
| 43cfa2b1a8 | |||
| 76cecacc5e | |||
| d6e173ffc6 | |||
| 26701f2ec8 | |||
| e934fe28b8 | |||
| d384d9fe7e | |||
| 4eeaf5f99e | |||
| fd2392db56 | |||
| 494dde7189 | |||
| 706dfca1e6 | |||
| d613c975f6 | |||
| fbe1419ce4 | |||
| c844c7b6e4 | |||
| 8e5cc09df9 | |||
| f4f8aec1f2 | |||
| b44b7344e0 | |||
| e01b2f0bf7 | |||
| f7f8ecb931 | |||
| 4f0d810cbc | |||
| 47335179aa | |||
| 63c4aea452 | |||
| 898b6fa1f9 | |||
| 747c8838bc | |||
| 9d6b61c5af | |||
| 5108c81610 | |||
| e58c704985 | |||
| e9c783eef0 | |||
| b44e5e009f | |||
| 8489dbf4de | |||
| f23ae2e6f7 | |||
| d2b233e45f | |||
| 320474a245 | |||
| 65ccfb36dc | |||
| 88fb99b592 | |||
| 9e7bc5c91f | |||
| ca2f547a35 | |||
| 9f21c80d24 | |||
| c4317135df | |||
| a2dd688679 | |||
| bd214a2dca | |||
| 2ee4653d1c | |||
| 0b3e0f451d | |||
| 0bfa897634 | |||
| 71db1e2cf1 | |||
| 16d1cd4766 | |||
| 1193cd100b | |||
| e839a77d8c | |||
| 552df3f2b0 | |||
| 3109c941eb | |||
| aa8706a5bf | |||
| 9afdee42e8 | |||
| aa0e9403d8 | |||
| 5b00f068f3 | |||
| 8f39d3eddd | |||
| 9d87d1fd14 | |||
| 07ae2343d0 | |||
| 7b8bf7af6a | |||
| 0ac6f76d36 | |||
| 6c6203b683 | |||
| 0c9f8a8e7e | |||
| 1705daea72 | |||
| 58fbc33c3a | |||
| 3f42b7d5fb | |||
| dd4f0db7bf | |||
| 7d026bfa6b | |||
| 6a70f864ec | |||
| 8e1cde2d0a | |||
| de32d8b95f | |||
| 273096b82f | |||
| 4c045616f4 | |||
| 935e74fb40 | |||
| a507be73b5 | |||
| 673dcaff6d | |||
| 2cbfd4fb41 | |||
| 0969980399 | |||
| 1fa2905bc6 | |||
| 790a48c30d | |||
| 4b69160eff | |||
| 7f805f22af | |||
| f2972dcf18 | |||
| 2d488f53fd | |||
| 421187c870 | |||
| 1798f4d615 | |||
| 8039546df3 | |||
| c6ad3d1a70 | |||
| 922f1e27b8 | |||
| 2d3750b36e | |||
| 51c7527bd8 | |||
| 2bf7ab0207 | |||
| b3a84fc51e | |||
| 1330950cd5 | |||
| afb57fca4e | |||
| 50344f4883 | |||
| 2b027bd9bc | |||
| 8f8207a1ca | |||
| 87e6c70743 | |||
| e3d18718a9 | |||
| cfa7bc51cd | |||
| ade633f0da | |||
| 2cabcf2941 | |||
| 9ce4bd6f1b | |||
| 190ae49ac1 | |||
| 032bc86056 | |||
| 704c5180a4 | |||
| e4fc767f9c | |||
| 1cf6a369bb | |||
| 14acb26bdc | |||
| 3ff7f9cedc | |||
| 98e937751c | |||
| 31b338b199 | |||
| 9e32964a24 | |||
| 4dcf2b117f | |||
| 6d8250310d | |||
| 3164116a42 | |||
| 747d45cb52 | |||
| 4b7ad1ca81 | |||
| 31ef16e586 | |||
| dd1def7620 | |||
| 693a73d8da | |||
| 965eb91efd | |||
| db9f610623 | |||
| 24fb306a50 | |||
| 919fe77b43 | |||
| 914c51cfb6 | |||
| 8d8c2bd524 | |||
| 7ef437ee9d | |||
| 0871fbb11b | |||
| 3039a720ed | |||
| 7f32ab318e | |||
| ddcacf4760 | |||
| 2f951ef5cd | |||
| 5a081357b4 | |||
| c4a64dff61 | |||
| aad33a8e35 | |||
| eae890b1b2 | |||
| 8fbd2ea6bb | |||
| 46161660dc | |||
| de68427afb | |||
| 4ba36c5432 | |||
| 99e2d8d309 | |||
| 929f9cd52d | |||
| 4dba50d3af | |||
| 1c258f399f | |||
| e05bc317ec | |||
| 44815f1f73 | |||
| 22f5ad47d2 | |||
| a29956826a | |||
| c11d023c03 | |||
| cade5f7157 | |||
| 7964656607 | |||
| 970e2d5ebb | |||
| 5b09e1195e | |||
| 6fdecd40be | |||
| 159a09794e | |||
| 0be846de83 | |||
| 981c662f5d | |||
| 71c631cffb | |||
| 47387dd6e9 | |||
| fec9df11d6 | |||
| 03f36220f4 | |||
| 1db0b0651d | |||
| 3f6c88dec7 | |||
| 2b938d931a | |||
| 71bd88f604 | |||
| 242082a22f | |||
| b9db11a072 | |||
| f381d2384c | |||
| 63d8fa1a9e | |||
| dd1c34be39 | 
							
								
								
									
										16
									
								
								.eslintrc.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								.eslintrc.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,16 @@ | ||||
| { | ||||
|   "env": { "node": true, "jest": true }, | ||||
|   "parser": "@typescript-eslint/parser", | ||||
|   "parserOptions": { "ecmaVersion": 2019, "sourceType": "module" }, | ||||
|   "extends": [ | ||||
|     "eslint:recommended", | ||||
|     "plugin:@typescript-eslint/eslint-recommended", | ||||
|     "plugin:@typescript-eslint/recommended", | ||||
|     "plugin:import/errors", | ||||
|     "plugin:import/warnings", | ||||
|     "plugin:import/typescript", | ||||
|     "plugin:prettier/recommended", | ||||
|     "prettier" | ||||
|   ], | ||||
|   "plugins": ["@typescript-eslint", "jest"] | ||||
| } | ||||
							
								
								
									
										27
									
								
								.github/CONTRIBUTING.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										27
									
								
								.github/CONTRIBUTING.md
									
									
									
									
										vendored
									
									
								
							| @ -17,12 +17,6 @@ Due to time constraints, you may not always get a quick response. Please do not | ||||
|  | ||||
| ## Coding Guidelines | ||||
|  | ||||
| This project comes with a `.prettierrc.json` configuration file. Please run the following command to format the code before committing it. | ||||
|  | ||||
| ```bash | ||||
| $ npm run format | ||||
| ``` | ||||
|  | ||||
| ## Using setup-php from a Git checkout | ||||
|  | ||||
| The following commands can be used to perform the initial checkout of setup-php: | ||||
| @ -39,6 +33,19 @@ Install setup-php dependencies using [npm](https://www.npmjs.com/): | ||||
| $ npm install | ||||
| ``` | ||||
|  | ||||
| If you are using `Windows` configure `git` to handle line endings. | ||||
|  | ||||
| ```cmd | ||||
| git config --local core.autocrlf true | ||||
| ``` | ||||
|  | ||||
| This project comes with `.prettierrc.json` and `eslintrc.json` configuration files. Please run the following commands to fix and verify the code quality. | ||||
|  | ||||
| ```bash | ||||
| $ npm run format | ||||
| $ npm run lint | ||||
| ``` | ||||
|  | ||||
| ## Running the test suite | ||||
|  | ||||
| After following the steps shown above, The `setup-php` tests in the `__tests__` directory can be run using this command: | ||||
| @ -47,6 +54,14 @@ After following the steps shown above, The `setup-php` tests in the `__tests__` | ||||
| $ npm test | ||||
| ``` | ||||
|  | ||||
| ## Creating a release | ||||
|  | ||||
| Create a release before you push your changes. | ||||
|  | ||||
| ```bash | ||||
| $ npm run release | ||||
| ``` | ||||
|  | ||||
| ## Reporting issues | ||||
|  | ||||
| Please submit the issue using the appropriate template provided for a bug report or a feature request: | ||||
|  | ||||
							
								
								
									
										7
									
								
								.github/FUNDING.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.github/FUNDING.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,8 +1,3 @@ | ||||
| # These are supported funding model platforms | ||||
|  | ||||
| github: shivammathur | ||||
| community_bridge: setup-php | ||||
| issuehunt: shivammathur | ||||
| patreon: shivammathur | ||||
| liberapay: shivammathur | ||||
| custom: https://www.paypal.me/shivammathur | ||||
| github:shivammathur | ||||
							
								
								
									
										2
									
								
								.github/ISSUE_TEMPLATE/feature_request.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/ISSUE_TEMPLATE/feature_request.md
									
									
									
									
										vendored
									
									
								
							| @ -8,7 +8,7 @@ assignees: '' | ||||
| --- | ||||
|  | ||||
| **Is your feature request related to a problem? Please describe.** | ||||
| A clear and concise description of what the problem is. Ex. I'm always frustrated when [...] | ||||
| A clear and concise description of what the problem is. Ex. I want to improve [...] | ||||
|  | ||||
| **Describe the solution you'd like** | ||||
| A clear and concise description of what you want to happen. | ||||
|  | ||||
							
								
								
									
										9
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							| @ -24,7 +24,14 @@ This PR [briefly explain what it does] | ||||
|  | ||||
| - [ ] I have written test cases for the changes in this pull request | ||||
| - [ ] I have run `npm run format` before the commit. | ||||
| - [ ] `npm test` returns with no unit test errors. | ||||
| - [ ] I have run `npm run lint` before the commit. | ||||
| - [ ] I have run `npm run release` before the commit. | ||||
| - [ ] `npm test` returns with no unit test errors and all code covered. | ||||
|  | ||||
| > In case this PR edits any scripts: | ||||
|  | ||||
| - [ ] I have checked the edited scripts for syntax. | ||||
| - [ ] I have tested the changes in an integration test (If yes, provide workflow YAML and link). | ||||
|  | ||||
| <!-- | ||||
| - Please target the develop branch when submitting the pull request. | ||||
|  | ||||
							
								
								
									
										31
									
								
								.github/PULL_REQUEST_TEMPLATE/FIX.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										31
									
								
								.github/PULL_REQUEST_TEMPLATE/FIX.md
									
									
									
									
										vendored
									
									
								
							| @ -1,31 +0,0 @@ | ||||
| --- | ||||
| name: 🐞 Bug Fix | ||||
| about: You have a fix for a bug? | ||||
| labels: bug | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## A Pull Request should be associated with an Issue. | ||||
|  | ||||
| > We wish to have discussions in Issues. A single issue may be targeted by multiple PRs. | ||||
| > If you're offering a new feature or fixing anything, we'd like to know beforehand in Issues, | ||||
| > and potentially we'll be able to point development in a particular direction. | ||||
|  | ||||
| Related issue:  | ||||
|  | ||||
| > Further notes in [Contribution Guidelines](.github/CONTRIBUTING.md) | ||||
| > Thank you! We are open to PRs, but please understand if for technical reasons we are unable to accept each and any PR | ||||
|  | ||||
| ### Description | ||||
|  | ||||
| This PR [briefly explain what it does] | ||||
|  | ||||
| > In case this PR introduced TypeScript/JavaScript code changes: | ||||
|  | ||||
| - [ ] I have written test cases for the changes in this pull request | ||||
| - [ ] I have run `npm run format` before the commit. | ||||
| - [ ] `npm test` returns with no unit test errors. | ||||
|  | ||||
| <!-- | ||||
| - Please target the develop branch when submitting the pull request. | ||||
| --> | ||||
							
								
								
									
										31
									
								
								.github/PULL_REQUEST_TEMPLATE/IMPROVEMENT.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										31
									
								
								.github/PULL_REQUEST_TEMPLATE/IMPROVEMENT.md
									
									
									
									
										vendored
									
									
								
							| @ -1,31 +0,0 @@ | ||||
| --- | ||||
| name: ⚙ Improvement | ||||
| about: You have some improvement to make setup-php better? | ||||
| labels: enhancement | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## A Pull Request should be associated with an Issue. | ||||
|  | ||||
| > We wish to have discussions in Issues. A single issue may be targeted by multiple PRs. | ||||
| > If you're offering a new feature or fixing anything, we'd like to know beforehand in Issues, | ||||
| > and potentially we'll be able to point development in a particular direction. | ||||
|  | ||||
| Related issue:  | ||||
|  | ||||
| > Further notes in [Contribution Guidelines](.github/CONTRIBUTING.md) | ||||
| > Thank you! We are open to PRs, but please understand if for technical reasons we are unable to accept each and any PR | ||||
|  | ||||
| ### Description | ||||
|  | ||||
| This PR [briefly explain what it does] | ||||
|  | ||||
| > In case this PR introduced TypeScript/JavaScript code changes: | ||||
|  | ||||
| - [ ] I have written test cases for the changes in this pull request | ||||
| - [ ] I have run `npm run format` before the commit. | ||||
| - [ ] `npm test` returns with no unit test errors. | ||||
|  | ||||
| <!-- | ||||
| - Please target the develop branch when submitting the pull request. | ||||
| --> | ||||
							
								
								
									
										31
									
								
								.github/PULL_REQUEST_TEMPLATE/NEW_FEATURE.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										31
									
								
								.github/PULL_REQUEST_TEMPLATE/NEW_FEATURE.md
									
									
									
									
										vendored
									
									
								
							| @ -1,31 +0,0 @@ | ||||
| --- | ||||
| name: 🎉 New Feature | ||||
| about: You have implemented some neat idea that you want to make part of setup-php? | ||||
| labels: enhancement | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## A Pull Request should be associated with an Issue. | ||||
|  | ||||
| > We wish to have discussions in Issues. A single issue may be targeted by multiple PRs. | ||||
| > If you're offering a new feature or fixing anything, we'd like to know beforehand in Issues, | ||||
| > and potentially we'll be able to point development in a particular direction. | ||||
|  | ||||
| Related issue:  | ||||
|  | ||||
| > Further notes in [Contribution Guidelines](.github/CONTRIBUTING.md) | ||||
| > Thank you! We are open to PRs, but please understand if for technical reasons we are unable to accept each and any PR | ||||
|  | ||||
| ### Description | ||||
|  | ||||
| This PR [briefly explain what it does] | ||||
|  | ||||
| > In case this PR introduced TypeScript/JavaScript code changes: | ||||
|  | ||||
| - [ ] I have written test cases for the changes in this pull request | ||||
| - [ ] I have run `npm run format` before the commit. | ||||
| - [ ] `npm test` returns with no unit test errors. | ||||
|  | ||||
| <!-- | ||||
| - Please target the develop branch when submitting the pull request. | ||||
| --> | ||||
							
								
								
									
										30
									
								
								.github/SECURITY.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								.github/SECURITY.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,30 @@ | ||||
| # Security Policy | ||||
|  | ||||
| ## Supported Versions | ||||
|  | ||||
| The following versions of this project are supported for security updates. | ||||
|  | ||||
| | Version | Supported          | | ||||
| | ------- | ------------------ | | ||||
| | 1.11.x  | :white_check_mark: | | ||||
| | 2.14.x  | :white_check_mark: | | ||||
|  | ||||
| ## Supported PHP Versions | ||||
|  | ||||
| This security policy only applies to the latest patches of the following PHP versions. | ||||
|  | ||||
| | Version | Supported          | | ||||
| | ------- | ------------------ | | ||||
| | 7.3     | :white_check_mark: | | ||||
| | 7.4     | :white_check_mark: | | ||||
| | 8.0     | :white_check_mark: | | ||||
| | 8.1     | :white_check_mark: | | ||||
|  | ||||
| ## Reporting a Vulnerability | ||||
|  | ||||
| If you have found any issues that might have security implications in the versions supported, please send a report privately to [contact@shivammathur.com](mailto:contact@shivammathur.com). | ||||
| Do not report security reports publicly. | ||||
|  | ||||
| ## Tidelift | ||||
|  | ||||
| If you use this GitHub Action through a Tidelift subscription, please refer to [https://tidelift.com/security](https://tidelift.com/security). | ||||
							
								
								
									
										4
									
								
								.github/codeql/codeql-configuration.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								.github/codeql/codeql-configuration.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,4 @@ | ||||
| name : CodeQL Configuration | ||||
|  | ||||
| paths: | ||||
|   - './src' | ||||
							
								
								
									
										25
									
								
								.github/workflows/codeql-workflow.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								.github/workflows/codeql-workflow.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,25 @@ | ||||
| name: CodeQL Workflow | ||||
| on: | ||||
|   workflow_dispatch: | ||||
|   schedule: | ||||
|     - cron: '0 15 * * 6' | ||||
| jobs: | ||||
|   codeql: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|         with: | ||||
|           fetch-depth: 2 | ||||
|  | ||||
|       - name: Initialize CodeQL | ||||
|         uses: github/codeql-action/init@v1 | ||||
|         with: | ||||
|           config-file: ./.github/codeql/codeql-configuration.yml | ||||
|           languages: javascript | ||||
|  | ||||
|       - name: Autobuild | ||||
|         uses: github/codeql-action/autobuild@v1 | ||||
|  | ||||
|       - name: Perform CodeQL Analysis | ||||
|         uses: github/codeql-action/analyze@v1 | ||||
							
								
								
									
										62
									
								
								.github/workflows/darwin.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										62
									
								
								.github/workflows/darwin.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,62 +0,0 @@ | ||||
| name: Darwin workflow | ||||
| on: [push, pull_request] | ||||
| jobs: | ||||
|   run: | ||||
|     name: Run | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 15 | ||||
|       matrix: | ||||
|         operating-system: [macOS-latest] | ||||
|         php-versions: ['5.6', '7.0', '7.1', '7.2', '7.3'] | ||||
|     steps: | ||||
|     - name: Checkout | ||||
|       uses: actions/checkout@master | ||||
|       with: | ||||
|         fetch-depth: 1 | ||||
|  | ||||
|     - name: Setup Node.js 12.x | ||||
|       uses: actions/setup-node@master | ||||
|       with: | ||||
|         node-version: 12.x | ||||
|  | ||||
|     - name: Cache node modules | ||||
|       uses: actions/cache@preview | ||||
|       id: cache | ||||
|       with: | ||||
|         path: node_modules | ||||
|         key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} | ||||
|         restore-keys: | | ||||
|           ${{ runner.os }}-node- | ||||
|  | ||||
|     - name: Installing NPM packages | ||||
|       if: steps.cache.outputs.cache-hit != 'true' | ||||
|       run: npm install   | ||||
|  | ||||
|     - name: Run tests | ||||
|       run: npm test | ||||
|  | ||||
|     - name: Send Coverage | ||||
|       continue-on-error: true | ||||
|       timeout-minutes: 2 | ||||
|       run: curl -s https://codecov.io/bash | bash -s -- -t ${{secrets.CODECOV_TOKEN}} -f coverage/clover.xml -n github-actions-codecov-${{ matrix.operating-system }}-php${{ matrix.php-versions }} | ||||
|  | ||||
|     - name: Setup PHP with extensions and custom config | ||||
|       run: node lib/install.js | ||||
|       env: | ||||
|         php-version: ${{ matrix.php-versions }} | ||||
|         extension-csv: mbstring, xdebug, pcov #optional | ||||
|         ini-values-csv: post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata #optional | ||||
|  | ||||
|     - name: Testing PHP version | ||||
|       run: php -v | ||||
|     - name: Testing Composer version | ||||
|       run: composer -V | ||||
|     - name: Testing Extensions | ||||
|       run: php -m | ||||
|     - name: Testing ini values | ||||
|       run: | | ||||
|         printf "post_max_size: %s\n" $(php -r "echo ini_get('post_max_size');") | ||||
|         printf "short_open_tag: %s\n" $(php -r "echo ini_get('short_open_tag');") | ||||
|         printf "date.timezone: %s\n" $(php -r "echo ini_get('date.timezone');") | ||||
							
								
								
									
										56
									
								
								.github/workflows/main-workflow.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								.github/workflows/main-workflow.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,56 @@ | ||||
| name: Main workflow | ||||
| on: | ||||
|   workflow_dispatch: | ||||
|   pull_request: | ||||
|     branches: | ||||
|       - releases/v1 | ||||
|     paths-ignore: | ||||
|       - '**.md' | ||||
|       - 'examples/**' | ||||
|   push: | ||||
|     branches: | ||||
|       - releases/v1 | ||||
|     paths-ignore: | ||||
|       - '**.md' | ||||
|       - 'examples/**' | ||||
| jobs: | ||||
|   run: | ||||
|     name: Run | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         operating-system: [ubuntu-20.04, ubuntu-18.04, windows-latest, macos-latest] | ||||
|         php-versions: ['5.6', '7.0', '7.1', '7.2', '7.3', '7.4', '8.0'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|  | ||||
|       - name: Setup PHP with extensions and custom config | ||||
|         run: node dist/index.js | ||||
|         env: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extensions: xml, opcache, xdebug, pcov #optional | ||||
|           ini-values: post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata #optional | ||||
|  | ||||
|       - name: Testing PHP version | ||||
|         run: | | ||||
|           php -v | ||||
|           php -r "if(strpos(phpversion(), '${{ matrix.php-versions }}') === false) {throw new Exception('Wrong PHP version Installed');}" | ||||
|  | ||||
|       - name: Testing Composer version | ||||
|         run: | | ||||
|           composer -V | ||||
|           php -r "if(strpos(@exec('composer -V'), 'Composer version') === false) {throw new Exception('Composer not found');}" | ||||
|       - name: Testing Extensions | ||||
|         run: | | ||||
|           php -m | ||||
|           php -r "if(! extension_loaded('xml')) {throw new Exception('xml not found');}" | ||||
|           php -r "if(! extension_loaded('Xdebug')) {throw new Exception('Xdebug not found');}" | ||||
|           php -r "if(phpversion()>=7.1 && ! extension_loaded('pcov')) {throw new Exception('PCOV not found');}" | ||||
|       - name: Testing ini values | ||||
|         run: | | ||||
|           php -r "if(ini_get('memory_limit')!='-1') {throw new Exception('memory_limit not disabled');}" | ||||
|           php -r "if(ini_get('post_max_size')!='256M') {throw new Exception('post_max_size not added');}" | ||||
|           php -r "if(ini_get('short_open_tag')!=1) {throw new Exception('short_open_tag not added');}" | ||||
|           php -r "if(ini_get('date.timezone')!='Asia/Kolkata') {throw new Exception('date.timezone not added');}" | ||||
							
								
								
									
										54
									
								
								.github/workflows/node-workflow.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								.github/workflows/node-workflow.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,54 @@ | ||||
| name: Node workflow | ||||
| on: | ||||
|   pull_request: | ||||
|     branches: | ||||
|       - releases/v1 | ||||
|     paths-ignore: | ||||
|       - '**.md' | ||||
|       - 'examples/**' | ||||
|   push: | ||||
|     branches: | ||||
|       - releases/v1 | ||||
|     paths-ignore: | ||||
|       - '**.md' | ||||
|       - 'examples/**' | ||||
| jobs: | ||||
|   run: | ||||
|     name: Run | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         operating-system: [ubuntu-latest, windows-latest, macos-latest] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|  | ||||
|       - name: Setup Node.js 16.x | ||||
|         uses: actions/setup-node@v1 | ||||
|         with: | ||||
|           node-version: 16.x | ||||
|  | ||||
|       - name: Install dependencies | ||||
|         run: npm install | ||||
|  | ||||
|       - name: Prettier Format Check | ||||
|         run: npm run format-check | ||||
|  | ||||
|       - name: ESLint Check | ||||
|         run: npm run lint | ||||
|  | ||||
|       - name: Run tests | ||||
|         run: npm test | ||||
|  | ||||
|       - name: Run npm audit | ||||
|         run: npm audit | ||||
|  | ||||
|       - name: Send Coverage | ||||
|         uses: codecov/codecov-action@v2 | ||||
|         with: | ||||
|           token: ${{ secrets.CODECOV_TOKEN }} | ||||
|           files: coverage/lcov.info | ||||
|           name: github-actions-codecov-${{ matrix.operating-system }} | ||||
|           fail_ci_if_error: false | ||||
|           verbose: true | ||||
							
								
								
									
										62
									
								
								.github/workflows/ubuntu.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										62
									
								
								.github/workflows/ubuntu.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,62 +0,0 @@ | ||||
| name: Ubuntu workflow | ||||
| on: [push, pull_request] | ||||
| jobs: | ||||
|   run: | ||||
|     name: Run | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 15 | ||||
|       matrix: | ||||
|         operating-system: [ubuntu-latest] | ||||
|         php-versions: ['5.6', '7.0', '7.1', '7.2', '7.3'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@master | ||||
|         with: | ||||
|           fetch-depth: 1 | ||||
|  | ||||
|       - name: Setup Node.js 12.x | ||||
|         uses: actions/setup-node@master | ||||
|         with: | ||||
|           node-version: 12.x | ||||
|  | ||||
|       - name: Cache node modules | ||||
|         uses: actions/cache@preview | ||||
|         id: cache | ||||
|         with: | ||||
|           path: node_modules | ||||
|           key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} | ||||
|           restore-keys: | | ||||
|             ${{ runner.os }}-node- | ||||
|  | ||||
|       - name: Installing NPM packages | ||||
|         if: steps.cache.outputs.cache-hit != 'true' | ||||
|         run: npm install | ||||
|  | ||||
|       - name: Run tests | ||||
|         run: npm test | ||||
|  | ||||
|       - name: Send Coverage | ||||
|         continue-on-error: true | ||||
|         timeout-minutes: 2 | ||||
|         run: curl -s https://codecov.io/bash | bash -s -- -t ${{secrets.CODECOV_TOKEN}} -f coverage/clover.xml -n github-actions-codecov-${{ matrix.operating-system }}-php${{ matrix.php-versions }} | ||||
|  | ||||
|       - name: Setup PHP with extensions and custom config | ||||
|         run: node lib/install.js | ||||
|         env: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, xdebug, pcov #optional | ||||
|           ini-values-csv: post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata #optional | ||||
|  | ||||
|       - name: Testing PHP version | ||||
|         run: php -v | ||||
|       - name: Testing Composer version | ||||
|         run: composer -V | ||||
|       - name: Testing Extensions | ||||
|         run: php -m | ||||
|       - name: Testing ini values | ||||
|         run: | | ||||
|           printf "post_max_size: %s\n" $(php -r "echo ini_get('post_max_size');") | ||||
|           printf "short_open_tag: %s\n" $(php -r "echo ini_get('short_open_tag');") | ||||
|           printf "date.timezone: %s\n" $(php -r "echo ini_get('date.timezone');") | ||||
							
								
								
									
										62
									
								
								.github/workflows/windows.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										62
									
								
								.github/workflows/windows.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,62 +0,0 @@ | ||||
| name: Windows workflow | ||||
| on: [push, pull_request] | ||||
| jobs: | ||||
|   run: | ||||
|     name: Run | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 15 | ||||
|       matrix: | ||||
|         operating-system: [windows-latest] | ||||
|         php-versions: ['5.6', '7.0', '7.1', '7.2', '7.3'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@master | ||||
|         with: | ||||
|           fetch-depth: 1 | ||||
|  | ||||
|       - name: Setup Node.js 12.x | ||||
|         uses: actions/setup-node@master | ||||
|         with: | ||||
|           node-version: 12.x | ||||
|  | ||||
|       - name: Cache node modules | ||||
|         uses: actions/cache@preview | ||||
|         id: cache | ||||
|         with: | ||||
|           path: node_modules | ||||
|           key: ${{ runner.os }}-node-${{ hashFiles('**\package-lock.json') }} | ||||
|           restore-keys: | | ||||
|             ${{ runner.os }}-node- | ||||
|  | ||||
|       - name: Installing NPM packages | ||||
|         if: steps.cache.outputs.cache-hit != 'true' | ||||
|         run: npm install | ||||
|  | ||||
|       - name: Run tests | ||||
|         run: npm test | ||||
|  | ||||
|       - name: Send Coverage | ||||
|         continue-on-error: true | ||||
|         timeout-minutes: 2 | ||||
|         run: curl -s https://codecov.io/bash | bash -s -- -t ${{secrets.CODECOV_TOKEN}} -f coverage/clover.xml -n github-actions-codecov-${{ matrix.operating-system }}-php${{ matrix.php-versions }} | ||||
|  | ||||
|       - name: Setup PHP with extensions and custom config | ||||
|         run: node lib/install.js | ||||
|         env: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, xdebug, pcov #optional | ||||
|           ini-values-csv: post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata #optional | ||||
|  | ||||
|       - name: Testing PHP version | ||||
|         run: php -v | ||||
|       - name: Testing Composer version | ||||
|         run: composer -V | ||||
|       - name: Testing Extensions | ||||
|         run: php -m | ||||
|       - name: Testing ini values | ||||
|         run: | | ||||
|           printf "post_max_size: %s\n" $(php -r "echo ini_get('post_max_size');") | ||||
|           printf "short_open_tag: %s\n" $(php -r "echo ini_get('short_open_tag');") | ||||
|           printf "date.timezone: %s\n" $(php -r "echo ini_get('date.timezone');") | ||||
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -1,6 +1,7 @@ | ||||
| # Explicitly not ignoring node_modules so that they are included in package downloaded by runner | ||||
| !node_modules/ | ||||
| node_modules/ | ||||
| __tests__/runner/* | ||||
| lib/ | ||||
|  | ||||
| # Rest of the file pulled from https://github.com/github/gitignore/blob/master/Node.gitignore | ||||
| # Logs | ||||
|  | ||||
| @ -1,11 +1,12 @@ | ||||
| { | ||||
|     "arrowParens": "avoid", | ||||
|     "bracketSpacing": false, | ||||
|     "endOfLine": "auto", | ||||
|     "parser": "typescript", | ||||
|     "printWidth": 80, | ||||
|     "tabWidth": 2, | ||||
|     "useTabs": false, | ||||
|     "semi": true, | ||||
|     "singleQuote": true, | ||||
|     "tabWidth": 2, | ||||
|     "trailingComma": "none", | ||||
|     "bracketSpacing": false, | ||||
|     "arrowParens": "avoid", | ||||
|     "parser": "typescript" | ||||
|   } | ||||
|     "useTabs": false | ||||
| } | ||||
							
								
								
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							| @ -1,7 +1,7 @@ | ||||
|  | ||||
| The MIT License (MIT) | ||||
|  | ||||
| Copyright (c) 2019 shivammathur and contributors | ||||
| Copyright (c) 2019-2020 shivammathur and contributors | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
|  | ||||
							
								
								
									
										414
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										414
									
								
								README.md
									
									
									
									
									
								
							| @ -8,107 +8,149 @@ | ||||
|  | ||||
| <p align="center"> | ||||
|   <a href="https://github.com/shivammathur/setup-php" title="GitHub action to setup PHP"><img alt="GitHub Actions status" src="https://github.com/shivammathur/setup-php/workflows/Main%20workflow/badge.svg"></a> | ||||
|   <a href="https://codecov.io/gh/shivammathur/setup-php" title="Code coverage"><img alt="Codecov Code Coverage" src="https://codecov.io/gh/shivammathur/setup-php/branch/master/graph/badge.svg"></a> | ||||
|   <a href="https://codecov.io/gh/shivammathur/setup-php" title="Code coverage"><img alt="Codecov Code Coverage" src="https://img.shields.io/codecov/c/github/shivammathur/setup-php?logo=codecov"></a> | ||||
|   <a href="https://github.com/shivammathur/setup-php/blob/master/LICENSE" title="license"><img alt="LICENSE" src="https://img.shields.io/badge/license-MIT-428f7e.svg"></a> | ||||
|   <a href="#tada-php-support" title="PHP Versions Supported"><img alt="PHP Versions Supported" src="https://img.shields.io/badge/php-%3E%3D%205.6-8892BF.svg"></a>  | ||||
|   <a href="https://www.patreon.com/shivammathur" title="Support Shivam Mathur on Patreon"><img alt="Support me on Patreon" src="https://shivammathur.com/badges/patreon.svg"></a>   <a href="https://www.paypal.me/shivammathur"><img alt="Support me on PayPal" src="https://shivammathur.com/badges/paypal.svg"></a> | ||||
|   <a href="https://www.codementor.io/shivammathur?utm_source=github&utm_medium=button&utm_term=shivammathur&utm_campaign=github" title="Contact Shivam Mathur on Codementor"><img alt="Contact me on Codementor" src="https://cdn.codementor.io/badges/contact_me_github.svg"></a>   | ||||
|   <a href="#tada-php-support" title="PHP Versions Supported"><img alt="PHP Versions Supported" src="https://img.shields.io/badge/php-%3E%3D%205.6-8892BF.svg"></a> | ||||
| </p> | ||||
|  | ||||
| Setup PHP with required extensions, php.ini configuration and composer in [GitHub Actions](https://github.com/features/actions "GitHub Actions"). This action can be added as a step in your action workflow and it will setup the PHP environment you need to test your application. Refer to [Usage](#memo-usage "How to use this") section and [examples](#examples "Examples of use") to see how to use this. | ||||
| Setup PHP with required extensions, php.ini configuration, code-coverage support and various tools like composer in [GitHub Actions](https://github.com/features/actions "GitHub Actions"). This action gives you a cross platform interface to setup the PHP environment you need to test your application. Refer to [Usage](#memo-usage "How to use this") section and [examples](#examples "Examples of use") to see how to use this. | ||||
|  | ||||
| ## Contents | ||||
|  | ||||
| - [PHP Support](#tada-php-support) | ||||
| - [OS/Platform Support](#cloud-osplatform-support) | ||||
| - [PHP Extension Support](#wrench-php-extension-support) | ||||
| - [Coverage support](#signal_strength-coverage-support) | ||||
| - [GitHub-Hosted Runner Support](#cloud-github-hosted-runner-support) | ||||
| - [PHP Extension Support](#heavy_plus_sign-php-extension-support) | ||||
| - [Tools Support](#wrench-tools-support) | ||||
| - [Coverage Support](#signal_strength-coverage-support) | ||||
|   - [Xdebug](#xdebug) | ||||
|   - [PCOV](#pcov) | ||||
|   - [Disable coverage](#disable-coverage) | ||||
| - [Usage](#memo-usage) | ||||
|   - [Basic Usage](#basic-usage) | ||||
|   - [Matrix Testing](#matrix-testing) | ||||
|   - [Cache dependencies](#cache-dependencies) | ||||
|   - [Basic Setup](#basic-setup) | ||||
|   - [Matrix Setup](#matrix-setup) | ||||
|   - [Thread Safe Setup](#thread-safe-setup)   | ||||
|   - [Cache Dependencies](#cache-dependencies) | ||||
|   - [Composer GitHub OAuth](#composer-github-oauth)   | ||||
|   - [Problem Matchers](#problem-matchers) | ||||
|   - [Examples](#examples) | ||||
| - [License](#scroll-license) | ||||
| - [Contributions](#1-contributions) | ||||
| - [Support this project](#sparkling_heart-support-this-project) | ||||
| - [This action uses the following works](#bookmark-this-action-uses-the-following-works) | ||||
| - [Support This project](#sparkling_heart-support-this-project) | ||||
| - [Dependencies](#bookmark-dependencies) | ||||
| - [Further Reading](#bookmark_tabs-further-reading) | ||||
|  | ||||
| ## :tada: PHP Support | ||||
|  | ||||
| |PHP Version|Stability|Release Support| | ||||
| |--- |--- |--- | | ||||
| |5.6|`Stable`|`End of life`| | ||||
| |7.0|`Stable`|`End of life`| | ||||
| |7.1|`Stable`|`Security fixes only`| | ||||
| |7.2|`Stable`|`Active`| | ||||
| |7.3|`Stable`|`Active`| | ||||
| |7.4|`RC4`/`RC5`|`Active`| | ||||
| | PHP Version | Stability | Release Support       | | ||||
| |-------------|-----------|-----------------------| | ||||
| | 5.6         | `Stable`  | `End of life`         | | ||||
| | 7.0         | `Stable`  | `End of life`         | | ||||
| | 7.1         | `Stable`  | `End of life`         | | ||||
| | 7.2         | `Stable`  | `End of life`         | | ||||
| | 7.3         | `Stable`  | `End of life`         | | ||||
| | 7.4         | `Stable`  | `Security fixes only` | | ||||
| | 8.0         | `Stable`  | `Active`              | | ||||
|  | ||||
| **Note:** PHP 7.4 is currently in development, do not use in production/release branches. | ||||
| ## :cloud: GitHub-Hosted Runner Support | ||||
|  | ||||
| ## :cloud: OS/Platform Support | ||||
| | Virtual environment  | YAML workflow label                | Pre-installed PHP      | | ||||
| |----------------------|------------------------------------|------------------------| | ||||
| | Ubuntu 20.04         | `ubuntu-latest` or `ubuntu-20.04`  | `PHP 7.4` to `PHP 8.1` | | ||||
| | Ubuntu 18.04         | `ubuntu-18.04`                     | `PHP 7.2` to `PHP 8.1` | | ||||
| | Windows Server 2022  | `windows-latest` or `windows-2022` | `PHP 8.1`              | | ||||
| | Windows Server 2019  | `windows-2019`                     | `PHP 8.1`              | | ||||
| | macOS Monterey 12.x  | `macos-12`                         | `PHP 8.1`              | | ||||
| | macOS Big Sur 11.x   | `macos-latest` or `macos-11`       | `PHP 8.1`              | | ||||
| | macOS Catalina 10.15 | `macos-10.15`                      | `PHP 8.1`              | | ||||
|  | ||||
| |Virtual environment|matrix.operating-system| | ||||
| |--- |--- | | ||||
| |Windows Server 2019|`windows-latest` or `windows-2019`| | ||||
| |Ubuntu 18.04|`ubuntu-latest` or `ubuntu-18.04`| | ||||
| |Ubuntu 16.04|`ubuntu-16.04`| | ||||
| |macOS X Catalina 10.15|`macOS-latest` or `macOS-10.15`| | ||||
|  | ||||
| ## :wrench: PHP Extension Support | ||||
| - On `ubuntu` extensions which have the package in `APT` are installed. If extension is not in `APT`, you can use `PECL` to install the extension as fallback by specifying `pecl: true`.  | ||||
| ## :heavy_plus_sign: PHP Extension Support | ||||
| - On `ubuntu` by default extensions which are available as a package can be installed. If the extension is not available as a package but it is on `PECL`, it can be installed by specifying `pecl` in the tools input. | ||||
| - On `windows` extensions which have `windows` binary on `PECL` can be installed. | ||||
| - On `macOS` extensions which are on `PECL` can be installed. | ||||
| - Extensions which are installed along with PHP if specified are enabled. | ||||
| - Extensions on `PECL` which do not have a latest stable version, their pre-release versions can be installed by suffixing the extension with its state i.e `alpha`, `beta`, `devel` or `snapshot` separated by a `-` like `msgpack-beta`. | ||||
| - Extensions which cannot be installed gracefully leave an error message in the logs, the action is not interrupted. | ||||
|  | ||||
| ## :signal_strength: Coverage support | ||||
| ## :wrench: Tools Support | ||||
|  | ||||
| These tools can be setup globally using the `tools` input. | ||||
|  | ||||
| `codeception`, `composer`, `composer-prefetcher`, `cs2pr`, `deployer`, `pecl`, `phinx`, `phive`, `phpcbf`, `phpcpd`, `php-config`, `php-cs-fixer`, `phpcs`, `phpize`, `phpmd`, `phpstan`, `phpunit`, `prestissimo`, `psalm`, `symfony` | ||||
|  | ||||
| ```yaml | ||||
| uses: shivammathur/setup-php@v1 | ||||
| with: | ||||
|   php-version: '7.4' | ||||
|   tools: php-cs-fixer, phpunit | ||||
| ``` | ||||
|  | ||||
| To set up a particular version of a tool, specify it in the form `tool:version`.  | ||||
|  | ||||
| The latest stable version of `composer` is set up by default. You can set up the required `composer` version by specifying `v1`, `v2`, `snapshot` or `preview` as versions or the exact version in semver format. | ||||
|  | ||||
| ```yaml | ||||
| uses: shivammathur/setup-php@v1 | ||||
| with: | ||||
|   php-version: '7.4' | ||||
|   tools: composer:v2 | ||||
| ``` | ||||
|  | ||||
| If you have specified composer plugins `prestissimo` or `composer-prefetcher` in tools, the latest stable version of `composer v1` will be setup. Unless some of your packages require `composer v1`, it is recommended to drop `prestissimo` and use `composer v2`. | ||||
|  | ||||
| Version for other tools should be in `semver` format and a valid release of the tool. | ||||
|  | ||||
| ```yaml | ||||
| uses: shivammathur/setup-php@v1 | ||||
| with: | ||||
|   php-version: '7.4' | ||||
|   tools: php-cs-fixer:2.16.2, phpunit:8.5.1 | ||||
| ``` | ||||
|  | ||||
| Tools which cannot be installed gracefully leave an error message in the logs, the action is not interrupted. | ||||
|  | ||||
| ## :signal_strength: Coverage Support | ||||
|  | ||||
| ### Xdebug | ||||
|  | ||||
| Specify `coverage: xdebug` to use `Xdebug`.   | ||||
| Runs on all [PHP versions supported](#tada-php-support "List of PHP versions supported on this GitHub Action")     | ||||
| Runs on all [PHP versions supported](#tada-php-support "List of PHP versions supported on this GitHub Action"). | ||||
|  | ||||
| ```yaml | ||||
| uses: shivammathur/setup-php@master | ||||
| uses: shivammathur/setup-php@v1 | ||||
| with: | ||||
|   php-version: '7.3'   | ||||
|   php-version: '7.4' | ||||
|   coverage: xdebug | ||||
| ``` | ||||
|  | ||||
| ### PCOV | ||||
|  | ||||
| Specify `coverage: pcov` to use `PCOV`.   | ||||
| Specify `coverage: pcov` to use `PCOV` and disable `Xdebug`.   | ||||
| It is much faster than `Xdebug`.   | ||||
| `PCOV` needs `PHP >= 7.1`.   | ||||
| If your source code directory is other than `src`, `lib` or, `app`, specify `pcov.directory` using the `ini-values-csv` input.   | ||||
| If your source code directory is other than `src`, `lib` or, `app`, specify `pcov.directory` using the `ini-values` input.   | ||||
|  | ||||
|  | ||||
| ```yaml | ||||
| uses: shivammathur/setup-php@master | ||||
| uses: shivammathur/setup-php@v1 | ||||
| with: | ||||
|   php-version: '7.3' | ||||
|   ini-values-csv: pcov.directory=api #optional, see above for usage. | ||||
|   php-version: '7.4' | ||||
|   ini-values: pcov.directory=api #optional, see above for usage. | ||||
|   coverage: pcov | ||||
| ``` | ||||
|  | ||||
| ### Disable coverage | ||||
| ### Disable Coverage | ||||
|  | ||||
| Specify `coverage: none` to disable both `Xdebug` and `PCOV`. | ||||
| Specify `coverage: none` to disable both `Xdebug` and `PCOV`.   | ||||
| Consider disabling the coverage using this PHP action for these reasons. | ||||
|  | ||||
| - You are not generating coverage reports while testing. | ||||
| - It will disable `Xdebug`, which will have a positive impact on PHP performance. | ||||
| - It will remove `Xdebug`, which will have a positive impact on PHP performance. | ||||
| - You are using `phpdbg` for running your tests. | ||||
|  | ||||
| ```yaml | ||||
| uses: shivammathur/setup-php@master | ||||
| uses: shivammathur/setup-php@v1 | ||||
| with: | ||||
|   php-version: '7.3' | ||||
|   php-version: '7.4' | ||||
|   coverage: none | ||||
| ``` | ||||
|  | ||||
| @ -117,69 +159,85 @@ with: | ||||
| Inputs supported by this GitHub Action. | ||||
|  | ||||
| - php-version `required` | ||||
| - extension-csv `optional` | ||||
| - ini-values-csv `optional` | ||||
| - extensions `optional` | ||||
| - ini-values `optional` | ||||
| - coverage `optional` | ||||
| - pecl `optional` | ||||
| - tools `optional` | ||||
|  | ||||
| See [action.yml](action.yml "Metadata for this GitHub Action") and usage below for more info. | ||||
|  | ||||
| ### Basic Usage | ||||
| ### Basic Setup | ||||
|  | ||||
| > Setup a particular PHP version. | ||||
|  | ||||
| ```yaml | ||||
| steps: | ||||
| - name: Checkout | ||||
|   uses: actions/checkout@master | ||||
|   uses: actions/checkout@v2 | ||||
|  | ||||
| - name: Setup PHP | ||||
|   uses: shivammathur/setup-php@master | ||||
|   uses: shivammathur/setup-php@v1 | ||||
|   with: | ||||
|     php-version: '7.3' | ||||
|     extension-csv: mbstring, xdebug #optional, setup extensions | ||||
|     ini-values-csv: post_max_size=256M, short_open_tag=On #optional, setup php.ini configuration | ||||
|     php-version: '7.4' | ||||
|     extensions: mbstring, intl #optional, setup extensions | ||||
|     ini-values: post_max_size=256M, short_open_tag=On #optional, setup php.ini configuration | ||||
|     coverage: xdebug #optional, setup coverage driver | ||||
|     pecl: true #optional, setup PECL | ||||
| - name: Check PHP Version | ||||
|   run: php -v | ||||
| - name: Check Composer Version | ||||
|   run: composer -V | ||||
| - name: Check PHP Extensions | ||||
|   run: php -m | ||||
|     tools: php-cs-fixer, phpunit #optional, setup tools globally | ||||
| ``` | ||||
|  | ||||
| ### Matrix Testing | ||||
| ### Matrix Setup | ||||
|  | ||||
| > Setup multiple PHP versions on multiple operating systems. | ||||
|  | ||||
| ```yaml | ||||
| jobs: | ||||
|   run:     | ||||
|   run: | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     strategy: | ||||
|       max-parallel: 15 | ||||
|       matrix: | ||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] | ||||
|         php-versions: ['5.6', '7.0', '7.1', '7.2', '7.3'] | ||||
|         operating-system: [ubuntu-latest, windows-latest, macos-latest] | ||||
|         php-versions: ['5.6', '7.0', '7.1', '7.2', '7.3', '7.4'] | ||||
|     name: PHP ${{ matrix.php-versions }} Test on ${{ matrix.operating-system }} | ||||
|     steps: | ||||
|     - name: Checkout | ||||
|       uses: actions/checkout@master | ||||
|       uses: actions/checkout@v2 | ||||
|  | ||||
|     - name: Setup PHP | ||||
|       uses: shivammathur/setup-php@master | ||||
|       uses: shivammathur/setup-php@v1 | ||||
|       with: | ||||
|         php-version: ${{ matrix.php-versions }} | ||||
|         extension-csv: mbstring, xdebug #optional, setup extensions | ||||
|         ini-values-csv: post_max_size=256M, short_open_tag=On #optional, setup php.ini configuration | ||||
|         extensions: mbstring, intl #optional, setup extensions | ||||
|         ini-values: post_max_size=256M, short_open_tag=On #optional, setup php.ini configuration | ||||
|         coverage: xdebug #optional, setup coverage driver | ||||
|         pecl: true #optional, setup PECL | ||||
|     - name: Check PHP Version | ||||
|       run: php -v | ||||
|     - name: Check Composer Version | ||||
|       run: composer -V | ||||
|     - name: Check PHP Extensions | ||||
|       run: php -m | ||||
|         tools: php-cs-fixer, phpunit #optional, setup tools globally | ||||
| ``` | ||||
|  | ||||
| ### Cache dependencies | ||||
| ### Thread Safe Setup | ||||
|  | ||||
| You can persist composer's internal cache directory using the [`action/cache`](https://github.com/actions/cache) GitHub Action. Dependencies cached are loaded directly instead of downloading them while installation. The files cached are available across check-runs and will reduce the workflow execution time. | ||||
| - `NTS` versions are setup by default. | ||||
| - On `ubuntu` and `macOS` only NTS versions are supported. | ||||
| - On `windows` both `TS` and `NTS` versions are supported. | ||||
|  | ||||
| ```yaml | ||||
| jobs: | ||||
|   run: | ||||
|     runs-on: windows-latest | ||||
|     name: Setup PHP TS on Windows | ||||
|     steps: | ||||
|     - name: Checkout | ||||
|       uses: actions/checkout@v2 | ||||
|  | ||||
|     - name: Setup PHP | ||||
|       uses: shivammathur/setup-php@v1 | ||||
|       with: | ||||
|         php-version: '7.4' | ||||
|       env: | ||||
|         phpts: ts # specify ts or nts | ||||
| ``` | ||||
|  | ||||
| ### Cache Dependencies | ||||
|  | ||||
| You can persist composer's internal cache directory using the [`action/cache`](https://github.com/actions/cache "GitHub Action to cache files") GitHub Action. Dependencies cached are loaded directly instead of downloading them while installation. The files cached are available across check-runs and will reduce the workflow execution time. | ||||
|  | ||||
| **Note:** Please do not cache `vendor` directory using `action/cache` as that will have side-effects. | ||||
|  | ||||
| @ -188,8 +246,8 @@ You can persist composer's internal cache directory using the [`action/cache`](h | ||||
|   id: composer-cache | ||||
|   run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|  | ||||
| - name: Cache dependencies   | ||||
|   uses: actions/cache@v1 | ||||
| - name: Cache dependencies | ||||
|   uses: actions/cache@v2 | ||||
|   with: | ||||
|     path: ${{ steps.composer-cache.outputs.dir }} | ||||
|     key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
| @ -199,54 +257,186 @@ You can persist composer's internal cache directory using the [`action/cache`](h | ||||
|   run: composer install --prefer-dist | ||||
| ``` | ||||
|  | ||||
| - If you do not commit `composer.lock`, you can use the hash of `composer.json` as the key for your cache. | ||||
| ```yaml | ||||
| key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
| ``` | ||||
|  | ||||
| - If you support a range of `composer` dependencies and use `prefer-lowest` and `prefer-stable` options, you can store them in your matrix add them to the keys. | ||||
| ```yaml | ||||
| key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}-${{ matrix.prefer }}- | ||||
| restore-keys: ${{ runner.os }}-composer-${{ matrix.prefer }}- | ||||
| ``` | ||||
|  | ||||
| ### Composer GitHub OAuth | ||||
|  | ||||
| If you have a number of workflows which setup multiple tools or have many composer dependencies, you might hit the GitHub's rate limit for composer. To avoid that you can add a `OAuth` token to the composer's config by setting `COMPOSER_TOKEN` environment variable. You can use [`GITHUB_TOKEN`](https://help.github.com/en/actions/configuring-and-managing-workflows/authenticating-with-the-github_token "GITHUB_TOKEN documentation") secret for this purpose. | ||||
|  | ||||
| ```yaml | ||||
| - name: Setup PHP | ||||
|   uses: shivammathur/setup-php@v2 | ||||
|   with: | ||||
|     php-version: '7.4' | ||||
|   env: | ||||
|     COMPOSER_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
| ``` | ||||
|  | ||||
| ### Problem Matchers | ||||
|  | ||||
| Problem matchers are `json` configurations which identify errors and warnings in your logs and surface that information prominently in the GitHub Actions UI by highlighting them and creating code annotations. | ||||
|  | ||||
| #### PHP | ||||
|  | ||||
| Setup problem matchers for your `PHP` output by adding this step after the `setup-php` step. | ||||
|  | ||||
| ```yaml | ||||
| - name: Setup problem matchers for PHP | ||||
|   run: echo "::add-matcher::${{ runner.tool_cache }}/php.json" | ||||
| ``` | ||||
|  | ||||
| #### PHPUnit | ||||
|  | ||||
| Setup problem matchers for your `PHPUnit` output by adding this step after the `setup-php` step. | ||||
|  | ||||
| ```yaml | ||||
| - name: Setup problem matchers for PHPUnit | ||||
|   run: echo "::add-matcher::${{ runner.tool_cache }}/phpunit.json" | ||||
| ``` | ||||
|  | ||||
| #### PHPStan | ||||
|  | ||||
| PHPStan supports error reporting in GitHub Actions, so no problem matchers are required. | ||||
|  | ||||
| ```yaml | ||||
| - name: Setup PHP | ||||
|   uses: shivammathur/setup-php@v2 | ||||
|   with: | ||||
|     php-version: '7.4' | ||||
|     tools: phpstan | ||||
|  | ||||
| - name: Run PHPStan | ||||
|   run: phpstan analyse src | ||||
| ``` | ||||
|  | ||||
| #### Psalm | ||||
|  | ||||
| Psalm supports error reporting in GitHub Actions with an output format `github`. | ||||
|  | ||||
| ```yaml | ||||
| - name: Setup PHP | ||||
|   uses: shivammathur/setup-php@v2 | ||||
|   with: | ||||
|     php-version: '7.4' | ||||
|     tools: psalm | ||||
|  | ||||
| - name: Run Psalm | ||||
|   run: psalm --output-format=github | ||||
| ``` | ||||
|  | ||||
| #### Tools with checkstyle support | ||||
|  | ||||
| For tools that support `checkstyle` reporting like `phpstan`, `psalm`, `php-cs-fixer` and `phpcs` you can use `cs2pr` to annotate your code.   | ||||
| For examples refer to [cs2pr documentation](https://github.com/staabm/annotate-pull-request-from-checkstyle).    | ||||
|  | ||||
| > Here is an example with `phpcs`. | ||||
|  | ||||
| ```yaml | ||||
| - name: Setup PHP | ||||
|   uses: shivammathur/setup-php@v2 | ||||
|   with: | ||||
|     php-version: '7.4' | ||||
|     tools: cs2pr, phpcs | ||||
|  | ||||
| - name: Run phpcs | ||||
|   run: phpcs -q --report=checkstyle src | cs2pr | ||||
| ``` | ||||
|  | ||||
| ### Examples | ||||
|  | ||||
| Examples for setting up this GitHub Action with different PHP Frameworks/Packages. | ||||
|  | ||||
| |Framework/Package|Runs on|Workflow| | ||||
| |--- |--- |--- | | ||||
| |CodeIgniter|`macOS`, `ubuntu` and `windows`|[codeigniter.yml](./examples/codeigniter.yml "GitHub Action for CodeIgniter")| | ||||
| |Laravel with `MySQL` and `Redis`|`ubuntu`|[laravel-mysql.yml](./examples/laravel-mysql.yml "GitHub Action for Laravel with MySQL and Redis")| | ||||
| |Laravel with `PostgreSQL` and `Redis`|`ubuntu`|[laravel-postgres.yml](./examples/laravel-postgres.yml "GitHub Action for Laravel with PostgreSQL and Redis")| | ||||
| |Laravel without services|`macOS`, `ubuntu` and `windows`|[laravel.yml](./examples/laravel.yml "GitHub Action for Laravel without services")| | ||||
| |Lumen with `MySQL` and `Redis`|`ubuntu`|[lumen-mysql.yml](./examples/lumen-mysql.yml "GitHub Action for Lumen with MySQL and Redis")| | ||||
| |Lumen with `PostgreSQL` and `Redis`|`ubuntu`|[lumen-postgres.yml](./examples/lumen-postgres.yml "GitHub Action for Lumen with PostgreSQL and Redis")| | ||||
| |Lumen without services|`macOS`, `ubuntu` and `windows`|[lumen.yml](./examples/lumen.yml "GitHub Action for Lumen without services")| | ||||
| |Phalcon with `MySQL`|`ubuntu`|[phalcon-mysql.yml](./examples/phalcon-mysql.yml "GitHub Action for Phalcon with MySQL")| | ||||
| |Phalcon with `PostgreSQL`|`ubuntu`|[phalcon-postgres.yml](./examples/phalcon-postgres.yml "GitHub Action for Phalcon with PostgreSQL")| | ||||
| |Slim Framework|`macOS`, `ubuntu` and `windows`|[slim-framework.yml](./examples/slim-framework.yml "GitHub Action for Slim Framework")| | ||||
| |Symfony with `MySQL`|`ubuntu`|[symfony-mysql.yml](./examples/symfony-mysql.yml "GitHub Action for Symfony with MySQL")| | ||||
| |Symfony with `PostgreSQL`|`ubuntu`|[symfony-postgres.yml](./examples/symfony-postgres.yml "GitHub Action for Symfony with PostgreSQL")| | ||||
| |Yii2 Starter Kit with `MySQL`|`ubuntu`|[yii2-mysql.yml](./examples/yii2-mysql.yml "GitHub Action for Yii2 Starter Kit with MySQL")| | ||||
| |Yii2 Starter Kit with `PostgreSQL`|`ubuntu`|[yii2-postgres.yml](./examples/yii2-postgres.yml "GitHub Action for Yii2 Starter Kit with PostgreSQL")| | ||||
| |Zend Framework|`macOS`, `ubuntu` and `windows`|[zend-framework.yml](./examples/zend-framework.yml "GitHub Action for Zend Framework")| | ||||
| | Framework/Package                     | Runs on                         | Workflow                                                                                                      | | ||||
| |---------------------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------| | ||||
| | CakePHP with `MySQL` and `Redis`      | `ubuntu`                        | [cakephp-mysql.yml](./examples/cakephp-mysql.yml "GitHub Action for CakePHP with MySQL and Redis")            | | ||||
| | CakePHP with `PostgreSQL` and `Redis` | `ubuntu`                        | [cakephp-postgres.yml](./examples/cakephp-postgres.yml "GitHub Action for CakePHP with Postgres and Redis")   | | ||||
| | CakePHP without services              | `macOS`, `ubuntu` and `windows` | [cakephp.yml](./examples/cakephp.yml "GitHub Action for CakePHP without services")                            | | ||||
| | CodeIgniter                           | `macOS`, `ubuntu` and `windows` | [codeigniter.yml](./examples/codeigniter.yml "GitHub Action for CodeIgniter")                                 | | ||||
| | Laravel with `MySQL` and `Redis`      | `ubuntu`                        | [laravel-mysql.yml](./examples/laravel-mysql.yml "GitHub Action for Laravel with MySQL and Redis")            | | ||||
| | Laravel with `PostgreSQL` and `Redis` | `ubuntu`                        | [laravel-postgres.yml](./examples/laravel-postgres.yml "GitHub Action for Laravel with PostgreSQL and Redis") | | ||||
| | Laravel without services              | `macOS`, `ubuntu` and `windows` | [laravel.yml](./examples/laravel.yml "GitHub Action for Laravel without services")                            | | ||||
| | Lumen with `MySQL` and `Redis`        | `ubuntu`                        | [lumen-mysql.yml](./examples/lumen-mysql.yml "GitHub Action for Lumen with MySQL and Redis")                  | | ||||
| | Lumen with `PostgreSQL` and `Redis`   | `ubuntu`                        | [lumen-postgres.yml](./examples/lumen-postgres.yml "GitHub Action for Lumen with PostgreSQL and Redis")       | | ||||
| | Lumen without services                | `macOS`, `ubuntu` and `windows` | [lumen.yml](./examples/lumen.yml "GitHub Action for Lumen without services")                                  | | ||||
| | Phalcon with `MySQL`                  | `ubuntu`                        | [phalcon-mysql.yml](./examples/phalcon-mysql.yml "GitHub Action for Phalcon with MySQL")                      | | ||||
| | Phalcon with `PostgreSQL`             | `ubuntu`                        | [phalcon-postgres.yml](./examples/phalcon-postgres.yml "GitHub Action for Phalcon with PostgreSQL")           | | ||||
| | Roots/bedrock                         | `ubuntu`                        | [bedrock.yml](./examples/bedrock.yml "GitHub Action for Wordpress Development using @roots/bedrock")          | | ||||
| | Roots/sage                            | `ubuntu`                        | [sage.yml](./examples/sage.yml "GitHub Action for Wordpress Development using @roots/sage")                   | | ||||
| | Slim Framework                        | `macOS`, `ubuntu` and `windows` | [slim-framework.yml](./examples/slim-framework.yml "GitHub Action for Slim Framework")                        | | ||||
| | Symfony with `MySQL`                  | `ubuntu`                        | [symfony-mysql.yml](./examples/symfony-mysql.yml "GitHub Action for Symfony with MySQL")                      | | ||||
| | Symfony with `PostgreSQL`             | `ubuntu`                        | [symfony-postgres.yml](./examples/symfony-postgres.yml "GitHub Action for Symfony with PostgreSQL")           | | ||||
| | Symfony without services              | `macOS`, `ubuntu` and `windows` | [symfony.yml](./examples/symfony.yml "GitHub Action for Symfony without services")                            | | ||||
| | Yii2 Starter Kit with `MySQL`         | `ubuntu`                        | [yii2-mysql.yml](./examples/yii2-mysql.yml "GitHub Action for Yii2 Starter Kit with MySQL")                   | | ||||
| | Yii2 Starter Kit with `PostgreSQL`    | `ubuntu`                        | [yii2-postgres.yml](./examples/yii2-postgres.yml "GitHub Action for Yii2 Starter Kit with PostgreSQL")        | | ||||
| | Zend Framework                        | `macOS`, `ubuntu` and `windows` | [zend-framework.yml](./examples/zend-framework.yml "GitHub Action for Zend Framework")                        | | ||||
|  | ||||
| ## :scroll: License | ||||
|  | ||||
| The scripts and documentation in this project are released under the [MIT License](LICENSE "License for shivammathur/setup-php"). This project has multiple [dependencies](https://github.com/shivammathur/setup-php/network/dependencies "Dependencies for this PHP Action") and their licenses can be found in their respective repositories. | ||||
| - The scripts and documentation in this project are released under the [MIT License](LICENSE "License for shivammathur/setup-php").  | ||||
| - This project has multiple [dependencies](#bookmark-dependencies "Dependencies for this PHP Action"). Their licenses can be found in their respective repositories. | ||||
| - The logo for `setup-php` is a derivative work of [php.net logo](https://www.php.net/download-logos.php) and is licensed under the [CC BY-SA 4.0 License](https://creativecommons.org/licenses/by-sa/4.0/ "Creative Commons License"). | ||||
|  | ||||
| ## :+1: Contributions | ||||
|  | ||||
| Contributions are welcome! See [Contributor's Guide](.github/CONTRIBUTING.md "shivammathur/setup-php contribution guide"). If you face any issues while using this or want to suggest a feature/improvement, create an issue [here](https://github.com/shivammathur/setup-php/issues "Issues reported"). | ||||
|  | ||||
| ## :sparkling_heart: Support this project | ||||
|  | ||||
| If this action helped you. | ||||
| ## :sparkling_heart: Support This Project | ||||
|  | ||||
| - Please star the project and share it, this helps reach more people. | ||||
| - If you blog, write about your experience using this. | ||||
| - Support on this project on <a href="https://www.patreon.com/shivammathur"><img alt="Patreon" src="https://shivammathur.com/badges/patreon.svg"></a> or using <a href="https://www.paypal.me/shivammathur"><img alt="Paypal" src="https://shivammathur.com/badges/paypal.svg"></a>. | ||||
| - Please star the project and share it. If you blog, please share your experience of using `setup-php`. | ||||
| - Please [reach out](mailto:contact@setup-php.com) if you have any questions about sponsoring setup-php. | ||||
|  | ||||
| ## :bookmark: This action uses the following works | ||||
| Many users and organisations support setup-php via [GitHub Sponsors](https://github.com/sponsors/shivammathur). | ||||
|  | ||||
| - [powershell-phpmanager](https://github.com/mlocati/powershell-phpmanager "Package to handle PHP on windows") | ||||
| - [Homebrew](https://brew.sh/ "MacOS package manager") | ||||
| - [ppa:ondrej/php](https://launchpad.net/~ondrej/+archive/ubuntu/php "Pre-compiled ubuntu packages") | ||||
| - [exolnet/homebrew-deprecated](https://github.com/eXolnet/homebrew-deprecated "Pre-compiled deprecated PHP for macOS") | ||||
| - [phpbrew](https://github.com/phpbrew/phpbrew "PHP packages manager") | ||||
| <a href="https://github.com/sponsors/shivammathur"><img src="https://setup-php.com/sponsors.svg?" alt="Sponsor shivammathur"></a> | ||||
|  | ||||
| These companies generously provide setup-php their products and services to aid in the development of this project. | ||||
|  | ||||
| <p> | ||||
|   <a href="https://www.jetbrains.com/?from=setup-php"> | ||||
|     <img src="https://setup-php.com/sponsors/jetbrains.svg" alt="JetBrains" width="106" height="60"> | ||||
|   </a> | ||||
|             | ||||
|   <a href="https://www.macstadium.com/opensource/members#gh-light-mode-only"> | ||||
|     <img src="https://setup-php.com/sponsors/macstadium.png" alt="Mac Stadium" width="148" height="60"> | ||||
|   </a> | ||||
|   <a href="https://www.macstadium.com/opensource/members#gh-dark-mode-only"> | ||||
|     <img src="https://setup-php.com/sponsors/macstadium-white.png" alt="Mac Stadium" width="148" height="60"> | ||||
|   </a> | ||||
|             | ||||
|   <a href="https://tidelift.com/subscription/pkg/npm-setup-php"> | ||||
|     <img src="https://setup-php.com/sponsors/tidelift.png" alt="Tidelift" width="70" height="60"> | ||||
|   </a> | ||||
|             | ||||
|   <a href="https://www.scaleway.com/en/about-us/open-source-program#gh-light-mode-only"> | ||||
|     <img src="https://setup-php.com/sponsors/scaleway.png" alt="Scaleway" width="174" height="60"> | ||||
|   </a> | ||||
|   <a href="https://www.scaleway.com/en/about-us/open-source-program#gh-dark-mode-only"> | ||||
|     <img src="https://setup-php.com/sponsors/scaleway-white.png" alt="Scaleway" width="174" height="60"> | ||||
|   </a> | ||||
| </p> | ||||
|  | ||||
| ## :bookmark: Dependencies | ||||
|  | ||||
| - [Node.js dependencies](https://github.com/shivammathur/setup-php/network/dependencies "Node.js dependencies") | ||||
| - [aaronparker/VcRedist](https://github.com/aaronparker/VcRedist "VcRedist PowerShell package") | ||||
| - [mlocati/powershell-phpmanager](https://github.com/mlocati/powershell-phpmanager "Package to handle PHP on windows") | ||||
| - [ppa:ondrej/php](https://launchpad.net/~ondrej/+archive/ubuntu/php "Packaging active PHP packages") | ||||
| - [shivammathur/homebrew-php](https://github.com/shivammathur/homebrew-php "Tap for PHP builds for MacOS") | ||||
| - [shivammathur/homebrew-extensions](https://github.com/shivammathur/homebrew-extensions "Tap for PHP extensions for MacOS") | ||||
| - [shivammathur/php-builder](https://github.com/shivammathur/php-builder "Nightly PHP package") | ||||
|  | ||||
| ## :bookmark_tabs: Further Reading | ||||
|  | ||||
| - [About GitHub Actions](https://github.com/features/actions "GitHub Actions") | ||||
| - [GitHub Actions Syntax](https://help.github.com/en/articles/workflow-syntax-for-github-actions "GitHub Actions Syntax") | ||||
| - [Other Awesome Actions](https://github.com/sdras/awesome-actions "List of Awesome GitHub Actions") | ||||
| - [Other Awesome Actions](https://github.com/sdras/awesome-actions "List of Awesome GitHub Actions") | ||||
| @ -12,9 +12,9 @@ describe('Config tests', () => { | ||||
|  | ||||
|     win32 = await config.addINIValues( | ||||
|       'post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata', | ||||
|       'fedora' | ||||
|       'openbsd' | ||||
|     ); | ||||
|     expect(win32).toContain('Platform fedora is not supported'); | ||||
|     expect(win32).toContain('Platform openbsd is not supported'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addINIValuesOnLinux', async () => { | ||||
| @ -29,9 +29,9 @@ describe('Config tests', () => { | ||||
|  | ||||
|     linux = await config.addINIValues( | ||||
|       'post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata', | ||||
|       'fedora' | ||||
|       'openbsd' | ||||
|     ); | ||||
|     expect(linux).toContain('Platform fedora is not supported'); | ||||
|     expect(linux).toContain('Platform openbsd is not supported'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addINIValuesOnDarwin', async () => { | ||||
| @ -45,8 +45,8 @@ describe('Config tests', () => { | ||||
|  | ||||
|     darwin = await config.addINIValues( | ||||
|       'post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata', | ||||
|       'fedora' | ||||
|       'openbsd' | ||||
|     ); | ||||
|     expect(darwin).toContain('Platform fedora is not supported'); | ||||
|     expect(darwin).toContain('Platform openbsd is not supported'); | ||||
|   }); | ||||
| }); | ||||
|  | ||||
| @ -1,20 +1,10 @@ | ||||
| import * as config from '../src/config'; | ||||
| import * as coverage from '../src/coverage'; | ||||
| import * as extensions from '../src/coverage'; | ||||
|  | ||||
| jest.mock('../src/extensions', () => ({ | ||||
|   addExtension: jest.fn().mockImplementation(extension => { | ||||
|     return 'addExtension ' + extension + '\n'; | ||||
|   }) | ||||
| })); | ||||
|  | ||||
| describe('Config tests', () => { | ||||
|   it('checking addCoverage with PCOV on windows', async () => { | ||||
|     let win32: string = await coverage.addCoverage('pcov', '7.4', 'win32'); | ||||
|     expect(win32).toContain('addExtension pcov'); | ||||
|     expect(win32).toContain( | ||||
|       'if(php -m | findstr -i xdebug) { Disable-PhpExtension xdebug C:\\tools\\php' | ||||
|     ); | ||||
|     let win32: string = await coverage.addCoverage('PCOV', '7.4', 'win32'); | ||||
|     expect(win32).toContain('Add-Extension pcov'); | ||||
|     expect(win32).toContain('Remove-Extension xdebug'); | ||||
|  | ||||
|     win32 = await coverage.addCoverage('pcov', '7.0', 'win32'); | ||||
|     expect(win32).toContain('PHP 7.1 or newer is required'); | ||||
| @ -24,50 +14,90 @@ describe('Config tests', () => { | ||||
|   }); | ||||
|  | ||||
|   it('checking addCoverage with PCOV on linux', async () => { | ||||
|     let linux: string = await coverage.addCoverage('pcov', '7.4', 'linux'); | ||||
|     expect(linux).toContain('addExtension pcov'); | ||||
|     expect(linux).toContain('sudo sed -i "/xdebug/d" $ini_file'); | ||||
|     expect(linux).toContain('sudo phpdismod -v 7.4 xdebug'); | ||||
|     const linux: string = await coverage.addCoverage('pcov', '7.4', 'linux'); | ||||
|     expect(linux).toContain('add_extension pcov'); | ||||
|     expect(linux).toContain('remove_extension xdebug'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addCoverage with PCOV on darwin', async () => { | ||||
|     let darwin: string = await coverage.addCoverage('pcov', '7.4', 'darwin'); | ||||
|     expect(darwin).toContain('addExtension pcov'); | ||||
|     const darwin: string = await coverage.addCoverage('pcov', '7.4', 'darwin'); | ||||
|     expect(darwin).toContain('add_brew_extension pcov'); | ||||
|     expect(darwin).toContain('remove_extension xdebug'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addCoverage with Xdebug on windows', async () => { | ||||
|     let win32: string = await coverage.addCoverage('xdebug', '7.3', 'win32'); | ||||
|     expect(win32).toContain('addExtension xdebug'); | ||||
|     const win32: string = await coverage.addCoverage('xdebug', '7.4', 'win32'); | ||||
|     expect(win32).toContain('Add-Extension xdebug'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addCoverage with Xdebug3 on windows', async () => { | ||||
|     const win32: string = await coverage.addCoverage('xdebug3', '7.4', 'win32'); | ||||
|     expect(win32).toContain('Add-Extension xdebug'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addCoverage with Xdebug2 on windows', async () => { | ||||
|     const win32: string = await coverage.addCoverage('xdebug2', '7.4', 'win32'); | ||||
|     expect(win32).toContain('Add-Extension xdebug stable 2.9.8'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addCoverage with Xdebug on linux', async () => { | ||||
|     let linux: string = await coverage.addCoverage('xdebug', '7.4', 'linux'); | ||||
|     expect(linux).toContain('addExtension xdebug'); | ||||
|     const linux: string = await coverage.addCoverage('xdebug', '8.0', 'linux'); | ||||
|     expect(linux).toContain('add_extension xdebug'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addCoverage with Xdebug3 on linux', async () => { | ||||
|     const linux: string = await coverage.addCoverage('xdebug3', '8.0', 'linux'); | ||||
|     expect(linux).toContain('add_extension xdebug'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addCoverage with Xdebug2 on linux', async () => { | ||||
|     const linux: string = await coverage.addCoverage('xdebug2', '7.4', 'linux'); | ||||
|     expect(linux).toContain('add_pecl_extension xdebug 2.9.8 zend_extension'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addCoverage with Xdebug on darwin', async () => { | ||||
|     let darwin: string = await coverage.addCoverage('xdebug', '7.4', 'darwin'); | ||||
|     expect(darwin).toContain('addExtension xdebug'); | ||||
|     const darwin: string = await coverage.addCoverage( | ||||
|       'xdebug', | ||||
|       '7.4', | ||||
|       'darwin' | ||||
|     ); | ||||
|     expect(darwin).toContain('add_brew_extension xdebug'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addCoverage with Xdebug3 on darwin', async () => { | ||||
|     const darwin: string = await coverage.addCoverage( | ||||
|       'xdebug3', | ||||
|       '7.4', | ||||
|       'darwin' | ||||
|     ); | ||||
|     expect(darwin).toContain('add_brew_extension xdebug'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addCoverage with Xdebug2 on darwin', async () => { | ||||
|     const darwin: string = await coverage.addCoverage( | ||||
|       'xdebug2', | ||||
|       '7.4', | ||||
|       'darwin' | ||||
|     ); | ||||
|     expect(darwin).toContain('add_brew_extension xdebug2'); | ||||
|   }); | ||||
|  | ||||
|   it('checking disableCoverage windows', async () => { | ||||
|     let win32 = await coverage.addCoverage('none', '7.4', 'win32'); | ||||
|     expect(win32).toContain('Disable-PhpExtension xdebug'); | ||||
|     expect(win32).toContain('Disable-PhpExtension pcov'); | ||||
|     const win32 = await coverage.addCoverage('none', '7.4', 'win32'); | ||||
|     expect(win32).toContain('Remove-Extension xdebug'); | ||||
|     expect(win32).toContain('Remove-Extension pcov'); | ||||
|   }); | ||||
|  | ||||
|   it('checking disableCoverage on linux', async () => { | ||||
|     let linux: string = await coverage.addCoverage('none', '7.4', 'linux'); | ||||
|     expect(linux).toContain('sudo phpdismod -v 7.4 xdebug'); | ||||
|     expect(linux).toContain('sudo phpdismod -v 7.4 pcov'); | ||||
|     expect(linux).toContain('sudo sed -i "/xdebug/d" $ini_file'); | ||||
|     expect(linux).toContain('sudo sed -i "/pcov/d" $ini_file'); | ||||
|     const linux: string = await coverage.addCoverage('none', '7.4', 'linux'); | ||||
|     expect(linux).toContain('remove_extension xdebug'); | ||||
|     expect(linux).toContain('remove_extension pcov'); | ||||
|   }); | ||||
|  | ||||
|   it('checking disableCoverage on darwin', async () => { | ||||
|     let darwin: string = await coverage.addCoverage('none', '7.4', 'darwin'); | ||||
|     expect(darwin).toContain('sudo sed -i \'\' "/xdebug/d" $ini_file'); | ||||
|     expect(darwin).toContain('sudo sed -i \'\' "/pcov/d" $ini_file'); | ||||
|     const darwin: string = await coverage.addCoverage('none', '7.4', 'darwin'); | ||||
|     expect(darwin).toContain('remove_extension xdebug'); | ||||
|     expect(darwin).toContain('remove_extension pcov'); | ||||
|   }); | ||||
|  | ||||
|   it('checking no or invalid coverage driver', async () => { | ||||
|  | ||||
| @ -3,83 +3,111 @@ import * as extensions from '../src/extensions'; | ||||
| describe('Extension tests', () => { | ||||
|   it('checking addExtensionOnWindows', async () => { | ||||
|     let win32: string = await extensions.addExtension( | ||||
|       'xdebug, pcov', | ||||
|       '7.2', | ||||
|       'Xdebug, pcov, sqlite, phalcon4, ast-beta', | ||||
|       '7.4', | ||||
|       'win32' | ||||
|     ); | ||||
|     expect(win32).toContain('Install-PhpExtension xdebug'); | ||||
|     expect(win32).toContain('Install-PhpExtension pcov'); | ||||
|     win32 = await extensions.addExtension('xdebug, pcov', '7.4', 'win32'); | ||||
|     const extension_url: string = | ||||
|       'https://xdebug.org/files/php_xdebug-2.8.0-7.4-vc15.dll'; | ||||
|     expect(win32).toContain( | ||||
|       'Invoke-WebRequest -Uri ' + | ||||
|         extension_url + | ||||
|         ' -OutFile C:\\tools\\php\\ext\\php_xdebug.dll' | ||||
|     ); | ||||
|     expect(win32).toContain('Install-PhpExtension pcov'); | ||||
|     expect(win32).toContain('Add-Extension xdebug'); | ||||
|     expect(win32).toContain('Add-Extension pcov'); | ||||
|     expect(win32).toContain('Add-Extension sqlite3'); | ||||
|     expect(win32).toContain('phalcon.ps1 phalcon4'); | ||||
|     expect(win32).toContain('Add-Extension ast beta'); | ||||
|  | ||||
|     win32 = await extensions.addExtension('xdebug2', '7.2', 'win32'); | ||||
|     expect(win32).toContain('Add-Extension xdebug stable 2.9.8'); | ||||
|  | ||||
|     win32 = await extensions.addExtension('mysql', '7.4', 'win32'); | ||||
|     expect(win32).toContain('Add-Extension mysqli'); | ||||
|     expect(win32).toContain('Add-Extension mysqlnd'); | ||||
|  | ||||
|     win32 = await extensions.addExtension('mysql', '8.0', 'win32'); | ||||
|     expect(win32).toContain('Add-Extension mysqli'); | ||||
|     expect(win32).toContain('Add-Extension mysqlnd'); | ||||
|  | ||||
|     win32 = await extensions.addExtension('mysql', '5.6', 'win32'); | ||||
|     expect(win32).toContain('Add-Extension mysql'); | ||||
|     expect(win32).toContain('Add-Extension mysqli'); | ||||
|     expect(win32).toContain('Add-Extension mysqlnd'); | ||||
|  | ||||
|     win32 = await extensions.addExtension( | ||||
|       'does_not_exist', | ||||
|       'phalcon3, does_not_exist', | ||||
|       '7.2', | ||||
|       'win32', | ||||
|       true | ||||
|     ); | ||||
|     expect(win32).toContain( | ||||
|       'Add-Extension does_not_exist "Install-PhpExtension does_not_exist" extension' | ||||
|     ); | ||||
|     expect(win32).toContain('phalcon.ps1 phalcon3'); | ||||
|     expect(win32).toContain('Add-Extension does_not_exist'); | ||||
|  | ||||
|     win32 = await extensions.addExtension('xdebug', '7.2', 'fedora'); | ||||
|     expect(win32).toContain('Platform fedora is not supported'); | ||||
|     win32 = await extensions.addExtension('xdebug', '7.2', 'openbsd'); | ||||
|     expect(win32).toContain('Platform openbsd is not supported'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addExtensionOnLinux', async () => { | ||||
|     let linux: string = await extensions.addExtension( | ||||
|       'xdebug, pcov', | ||||
|       '7.2', | ||||
|       'Xdebug, pcov, sqlite, ast-beta, xdebug-alpha', | ||||
|       '7.4', | ||||
|       'linux' | ||||
|     ); | ||||
|     expect(linux).toContain('sudo $debconf_fix apt-get install -y php7.4-pcov'); | ||||
|     expect(linux).toContain( | ||||
|       'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y php7.2-xdebug' | ||||
|       'sudo $debconf_fix apt-get install -y php7.4-sqlite3' | ||||
|     ); | ||||
|     expect(linux).toContain('pecl install xdebug'); | ||||
|     expect(linux).toContain('add_unstable_extension ast beta extension'); | ||||
|     expect(linux).toContain( | ||||
|       'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y php7.2-pcov' | ||||
|       'add_unstable_extension xdebug alpha zend_extension' | ||||
|     ); | ||||
|     expect(linux).toContain('pecl install pcov'); | ||||
|  | ||||
|     linux = await extensions.addExtension('phalcon3, phalcon4', '7.2', 'linux'); | ||||
|     expect(linux).toContain('phalcon.sh master 7.2'); | ||||
|     expect(linux).toContain('phalcon.sh 4.0.x 7.2'); | ||||
|     linux = await extensions.addExtension('gearman', '7.0', 'linux'); | ||||
|     expect(linux).toContain('gearman.sh'); | ||||
|  | ||||
|     linux = await extensions.addExtension('xdebug2', '7.2', 'linux'); | ||||
|     expect(linux).toContain('add_pecl_extension xdebug 2.9.8 zend_extension'); | ||||
|  | ||||
|     linux = await extensions.addExtension('xdebug', '7.2', 'openbsd'); | ||||
|     expect(linux).toContain('Platform openbsd is not supported'); | ||||
|  | ||||
|     linux = await extensions.addExtension('phalcon3, phalcon4', '7.3', 'linux'); | ||||
|     expect(linux).toContain('phalcon.sh master 7.3'); | ||||
|     expect(linux).toContain('phalcon.sh 4.0.x 7.3'); | ||||
|  | ||||
|     linux = await extensions.addExtension('xdebug', '7.2', 'fedora'); | ||||
|     expect(linux).toContain('Platform fedora is not supported'); | ||||
|     expect(linux).toContain('phalcon.sh phalcon3 7.3'); | ||||
|     expect(linux).toContain('phalcon.sh phalcon4 7.3'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addExtensionOnDarwin', async () => { | ||||
|     let darwin: string = await extensions.addExtension( | ||||
|       'xdebug, pcov', | ||||
|       'Xdebug, pcov, expect, grpc, igbinary, imagick, phalcon3, phalcon4, protobuf, psr, rdkafka, ssh2, swoole, vips, sqlite, ast-beta', | ||||
|       '7.2', | ||||
|       'darwin' | ||||
|     ); | ||||
|     expect(darwin).toContain('sudo pecl install xdebug'); | ||||
|     expect(darwin).toContain('sudo pecl install pcov'); | ||||
|     expect(darwin).toContain('add_brew_extension xdebug'); | ||||
|     expect(darwin).toContain('add_brew_extension pcov'); | ||||
|     expect(darwin).toContain('add_brew_extension expect'); | ||||
|     expect(darwin).toContain('add_brew_extension grpc'); | ||||
|     expect(darwin).toContain('add_brew_extension igbinary'); | ||||
|     expect(darwin).toContain('add_brew_extension imagick'); | ||||
|     expect(darwin).toContain('add_brew_extension phalcon3'); | ||||
|     expect(darwin).toContain('add_brew_extension phalcon4'); | ||||
|     expect(darwin).toContain('add_brew_extension protobuf'); | ||||
|     expect(darwin).toContain('add_brew_extension psr'); | ||||
|     expect(darwin).toContain('add_brew_extension rdkafka'); | ||||
|     expect(darwin).toContain('add_brew_extension ssh2'); | ||||
|     expect(darwin).toContain('add_brew_extension swoole'); | ||||
|     expect(darwin).toContain('add_brew_extension vips'); | ||||
|     expect(darwin).toContain('pecl_install sqlite3'); | ||||
|     expect(darwin).toContain('add_unstable_extension ast beta extension'); | ||||
|  | ||||
|     darwin = await extensions.addExtension('pcov', '5.6', 'darwin'); | ||||
|     expect(darwin).toContain('sudo pecl install pcov'); | ||||
|     expect(darwin).toContain('pecl_install pcov'); | ||||
|  | ||||
|     darwin = await extensions.addExtension('pcov', '7.2', 'darwin'); | ||||
|     expect(darwin).toContain('sudo pecl install pcov'); | ||||
|     expect(darwin).toContain('add_brew_extension pcov'); | ||||
|  | ||||
|     darwin = await extensions.addExtension('xdebug', '5.6', 'darwin'); | ||||
|     expect(darwin).toContain('sudo pecl install xdebug-2.5.5'); | ||||
|     expect(darwin).toContain('add_brew_extension xdebug'); | ||||
|  | ||||
|     darwin = await extensions.addExtension('xdebug', '7.2', 'darwin'); | ||||
|     expect(darwin).toContain('sudo pecl install xdebug'); | ||||
|     darwin = await extensions.addExtension('xdebug', '7.0', 'darwin'); | ||||
|     expect(darwin).toContain('add_brew_extension xdebug'); | ||||
|  | ||||
|     darwin = await extensions.addExtension('xdebug2', '7.2', 'darwin'); | ||||
|     expect(darwin).toContain('add_brew_extension xdebug2'); | ||||
|  | ||||
|     darwin = await extensions.addExtension( | ||||
|       'does_not_exist', | ||||
| @ -89,7 +117,7 @@ describe('Extension tests', () => { | ||||
|     ); | ||||
|     expect(darwin).toContain('add_extension does_not_exist'); | ||||
|  | ||||
|     darwin = await extensions.addExtension('xdebug', '7.2', 'fedora'); | ||||
|     expect(darwin).toContain('Platform fedora is not supported'); | ||||
|     darwin = await extensions.addExtension('xdebug', '7.2', 'openbsd'); | ||||
|     expect(darwin).toContain('Platform openbsd is not supported'); | ||||
|   }); | ||||
| }); | ||||
|  | ||||
| @ -4,57 +4,61 @@ import * as install from '../src/install'; | ||||
|  * Mock install.ts | ||||
|  */ | ||||
| jest.mock('../src/install', () => ({ | ||||
|   build: jest.fn().mockImplementation( | ||||
|     async ( | ||||
|       filename: string, | ||||
|       version: string, | ||||
|       os_version: string | ||||
|     ): Promise<string> => { | ||||
|       let extension_csv: string = process.env['extension-csv'] || ''; | ||||
|       let ini_values_csv: string = process.env['ini-values-csv'] || ''; | ||||
|       let coverage_driver: string = process.env['coverage'] || ''; | ||||
|   build: jest | ||||
|     .fn() | ||||
|     .mockImplementation( | ||||
|       async ( | ||||
|         filename: string, | ||||
|         version: string, | ||||
|         os_version: string | ||||
|       ): Promise<string> => { | ||||
|         const extension_csv: string = process.env['extensions'] || ''; | ||||
|         const ini_values_csv: string = process.env['ini-values'] || ''; | ||||
|         const coverage_driver: string = process.env['coverage'] || ''; | ||||
|         let tools_csv: string = process.env['tools'] || ''; | ||||
|         const pecl: string = process.env['pecl'] || ''; | ||||
|         if (pecl == 'true') { | ||||
|           tools_csv = 'pecl, ' + tools_csv; | ||||
|         } | ||||
|  | ||||
|       let script: string = 'initial script'; | ||||
|       if (extension_csv) { | ||||
|         script += 'install extensions'; | ||||
|       } | ||||
|       if (ini_values_csv) { | ||||
|         script += 'edit php.ini'; | ||||
|       } | ||||
|       if (coverage_driver) { | ||||
|         script += 'set coverage driver'; | ||||
|       } | ||||
|         let script = 'initial script ' + filename + version + os_version; | ||||
|         if (tools_csv) { | ||||
|           script += 'add_tool'; | ||||
|         } | ||||
|         if (extension_csv) { | ||||
|           script += 'install extensions'; | ||||
|         } | ||||
|         if (coverage_driver) { | ||||
|           script += 'set coverage driver'; | ||||
|         } | ||||
|         if (ini_values_csv) { | ||||
|           script += 'edit php.ini'; | ||||
|         } | ||||
|  | ||||
|       return script; | ||||
|         return script; | ||||
|       } | ||||
|     ), | ||||
|   run: jest.fn().mockImplementation(async (): Promise<string> => { | ||||
|     const os_version: string = process.env['RUNNER_OS'] || ''; | ||||
|     let version: string = process.env['php-version'] || ''; | ||||
|     version = version.length > 1 ? version.slice(0, 3) : version + '.0'; | ||||
|     let script = ''; | ||||
|     switch (os_version) { | ||||
|       case 'darwin': | ||||
|       case 'linux': | ||||
|         script = await install.build(os_version + '.sh', version, os_version); | ||||
|         script += 'bash script.sh ' + version + ' ' + __dirname; | ||||
|         break; | ||||
|       case 'win32': | ||||
|         script = await install.build(os_version + '.sh', version, os_version); | ||||
|         script += 'pwsh script.ps1 ' + version + ' ' + __dirname; | ||||
|         break; | ||||
|       default: | ||||
|         script += os_version + ' is not supported'; | ||||
|     } | ||||
|   ), | ||||
|   run: jest.fn().mockImplementation( | ||||
|     async (): Promise<string> => { | ||||
|       let os_version: string = process.env['RUNNER_OS'] || ''; | ||||
|       let version: string = process.env['php-version'] || ''; | ||||
|       let script: string = ''; | ||||
|       switch (os_version) { | ||||
|         case 'darwin': | ||||
|           script = await install.build(os_version + '.sh', version, os_version); | ||||
|           script += 'sh script.sh ' + version + ' ' + __dirname; | ||||
|           break; | ||||
|         case 'linux': | ||||
|           let pecl: string = process.env['pecl'] || ''; | ||||
|           script = await install.build(os_version + '.sh', version, os_version); | ||||
|           script += 'sh script.sh ' + version + ' ' + pecl + ' ' + __dirname; | ||||
|           break; | ||||
|         case 'win32': | ||||
|           script = await install.build(os_version + '.sh', version, os_version); | ||||
|           script += | ||||
|             'pwsh script.ps1 -version ' + version + ' -dir ' + __dirname; | ||||
|           break; | ||||
|         default: | ||||
|           script += os_version + ' is not supported'; | ||||
|       } | ||||
|  | ||||
|       return script; | ||||
|     } | ||||
|   ) | ||||
|     return script; | ||||
|   }) | ||||
| })); | ||||
|  | ||||
| /** | ||||
| @ -65,81 +69,113 @@ jest.mock('../src/install', () => ({ | ||||
|  * @param extension_csv | ||||
|  * @param ini_values_csv | ||||
|  * @param coverage_driver | ||||
|  * @param tools | ||||
|  * @param pecl | ||||
|  */ | ||||
| function setEnv( | ||||
|   version: string, | ||||
|   version: string | number, | ||||
|   os: string, | ||||
|   extension_csv: string, | ||||
|   ini_values_csv: string, | ||||
|   coverage_driver: string, | ||||
|   pecl: any | ||||
|   tools: string, | ||||
|   pecl: string | ||||
| ): void { | ||||
|   process.env['php-version'] = version; | ||||
|   process.env['php-version'] = version.toString(); | ||||
|   process.env['RUNNER_OS'] = os; | ||||
|   process.env['extension-csv'] = extension_csv; | ||||
|   process.env['ini-values-csv'] = ini_values_csv; | ||||
|   process.env['extensions'] = extension_csv; | ||||
|   process.env['ini-values'] = ini_values_csv; | ||||
|   process.env['coverage'] = coverage_driver; | ||||
|   process.env['tools'] = tools; | ||||
|   process.env['pecl'] = pecl; | ||||
| } | ||||
|  | ||||
| describe('Install', () => { | ||||
|   it('Test install on windows', async () => { | ||||
|     setEnv('7.3', 'win32', '', '', '', ''); | ||||
|     // @ts-ignore | ||||
|     let script: string = await install.run(); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('pwsh script.ps1 -version 7.3 -dir ' + __dirname); | ||||
|     setEnv('7.0', 'win32', '', '', '', '', ''); | ||||
|  | ||||
|     setEnv('7.3', 'win32', 'a, b', 'a=b', 'x', ''); | ||||
|     // @ts-ignore | ||||
|     script = await install.run(); | ||||
|     let script: string = '' + (await install.run()); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('pwsh script.ps1 7.0 ' + __dirname); | ||||
|  | ||||
|     setEnv('7.3', 'win32', '', '', '', '', ''); | ||||
|  | ||||
|     script = '' + (await install.run()); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('pwsh script.ps1 7.3 ' + __dirname); | ||||
|  | ||||
|     setEnv('7.3', 'win32', 'a, b', 'a=b', 'x', '', ''); | ||||
|  | ||||
|     script = '' + (await install.run()); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('install extensions'); | ||||
|     expect(script).toContain('edit php.ini'); | ||||
|     expect(script).toContain('set coverage driver'); | ||||
|     expect(script).toContain('pwsh script.ps1 -version 7.3 -dir ' + __dirname); | ||||
|     expect(script).toContain('pwsh script.ps1 7.3 ' + __dirname); | ||||
|   }); | ||||
|  | ||||
|   it('Test install on linux', async () => { | ||||
|     setEnv('7.3', 'linux', '', '', '', ''); | ||||
|     // @ts-ignore | ||||
|     let script: string = await install.run(); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('sh script.sh 7.3 '); | ||||
|     setEnv('7.3', 'linux', '', '', '', '', ''); | ||||
|  | ||||
|     setEnv('7.3', 'linux', 'a, b', 'a=b', 'x', 'true'); | ||||
|     // @ts-ignore | ||||
|     script = await install.run(); | ||||
|     let script: string = '' + (await install.run()); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('bash script.sh 7.3 '); | ||||
|  | ||||
|     setEnv('7.4', 'linux', 'a, b', 'a=b', 'x', 'phpunit', 'true'); | ||||
|  | ||||
|     script = '' + (await install.run()); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('install extensions'); | ||||
|     expect(script).toContain('edit php.ini'); | ||||
|     expect(script).toContain('set coverage driver'); | ||||
|     expect(script).toContain('sh script.sh 7.3 true'); | ||||
|     expect(script).toContain('bash script.sh 7.4'); | ||||
|     expect(script).toContain('add_tool'); | ||||
|  | ||||
|     setEnv('7.3', 'linux', 'a, b', 'a=b', 'x', true); | ||||
|     // @ts-ignore | ||||
|     script = await install.run(); | ||||
|     setEnv('7.3', 'linux', 'a, b', 'a=b', 'x', 'phpunit', ''); | ||||
|  | ||||
|     script = '' + (await install.run()); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('install extensions'); | ||||
|     expect(script).toContain('edit php.ini'); | ||||
|     expect(script).toContain('set coverage driver'); | ||||
|     expect(script).toContain('sh script.sh 7.3 true'); | ||||
|     expect(script).toContain('bash script.sh 7.3'); | ||||
|     expect(script).toContain('add_tool'); | ||||
|   }); | ||||
|  | ||||
|   it('Test install on darwin', async () => { | ||||
|     setEnv('7.3', 'darwin', '', '', '', ''); | ||||
|     // @ts-ignore | ||||
|     let script: string = await install.run(); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('sh script.sh 7.3 ' + __dirname); | ||||
|     setEnv('7.3', 'darwin', '', '', '', '', ''); | ||||
|  | ||||
|     setEnv('7.3', 'darwin', 'a, b', 'a=b', 'x', ''); | ||||
|     // @ts-ignore | ||||
|     script = await install.run(); | ||||
|     let script: string = '' + (await install.run()); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('bash script.sh 7.3 ' + __dirname); | ||||
|  | ||||
|     setEnv('7.3', 'darwin', 'a, b', 'a=b', 'x', '', ''); | ||||
|  | ||||
|     script = '' + (await install.run()); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('install extensions'); | ||||
|     expect(script).toContain('edit php.ini'); | ||||
|     expect(script).toContain('set coverage driver'); | ||||
|     expect(script).toContain('sh script.sh 7.3 ' + __dirname); | ||||
|     expect(script).toContain('bash script.sh 7.3 ' + __dirname); | ||||
|   }); | ||||
|  | ||||
|   it('Test malformed version inputs', async () => { | ||||
|     setEnv('7.4.1', 'darwin', '', '', '', '', ''); | ||||
|  | ||||
|     let script: string = '' + (await install.run()); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('bash script.sh 7.4 ' + __dirname); | ||||
|  | ||||
|     setEnv(8.0, 'darwin', '', '', '', '', ''); | ||||
|  | ||||
|     script = '' + (await install.run()); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('bash script.sh 8.0 ' + __dirname); | ||||
|  | ||||
|     setEnv(8, 'darwin', '', '', '', '', ''); | ||||
|  | ||||
|     script = '' + (await install.run()); | ||||
|     expect(script).toContain('initial script'); | ||||
|     expect(script).toContain('bash script.sh 8.0 ' + __dirname); | ||||
|   }); | ||||
| }); | ||||
|  | ||||
							
								
								
									
										481
									
								
								__tests__/tools.test.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										481
									
								
								__tests__/tools.test.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,481 @@ | ||||
| import * as tools from '../src/tools'; | ||||
|  | ||||
| describe('Tools tests', () => { | ||||
|   it('checking getCommand', async () => { | ||||
|     expect(await tools.getCommand('linux', 'tool')).toBe('add_tool '); | ||||
|     expect(await tools.getCommand('darwin', 'tool')).toBe('add_tool '); | ||||
|     expect(await tools.getCommand('win32', 'tool')).toBe('Add-Tool '); | ||||
|     expect(await tools.getCommand('openbsd', 'tool')).toContain( | ||||
|       'Platform openbsd is not supported' | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('checking getCommand', async () => { | ||||
|     expect(await tools.getCommand('linux', 'composertool')).toBe( | ||||
|       'add_composertool ' | ||||
|     ); | ||||
|     expect(await tools.getCommand('darwin', 'composertool')).toBe( | ||||
|       'add_composertool ' | ||||
|     ); | ||||
|     expect(await tools.getCommand('win32', 'composertool')).toBe( | ||||
|       'Add-Composertool ' | ||||
|     ); | ||||
|     expect(await tools.getCommand('openbsd', 'composertool')).toContain( | ||||
|       'Platform openbsd is not supported' | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('checking getCommand', async () => { | ||||
|     expect(await tools.getCommand('linux', 'pecl')).toBe('add_pecl '); | ||||
|     expect(await tools.getCommand('darwin', 'pecl')).toBe('add_pecl '); | ||||
|     expect(await tools.getCommand('win32', 'pecl')).toBe('Add-Pecl '); | ||||
|     expect(await tools.getCommand('openbsd', 'pecl')).toContain( | ||||
|       'Platform openbsd is not supported' | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('checking parseToolVersion', async () => { | ||||
|     expect(await tools.getToolVersion('latest')).toBe('latest'); | ||||
|     expect(await tools.getToolVersion('1.2.3')).toBe('1.2.3'); | ||||
|     expect(await tools.getToolVersion('^1.2.3')).toBe('1.2.3'); | ||||
|     expect(await tools.getToolVersion('>=1.2.3')).toBe('1.2.3'); | ||||
|     expect(await tools.getToolVersion('>1.2.3')).toBe('1.2.3'); | ||||
|     expect(await tools.getToolVersion('1.2.3-ALPHA')).toBe('1.2.3-ALPHA'); | ||||
|     expect(await tools.getToolVersion('1.2.3-alpha')).toBe('1.2.3-alpha'); | ||||
|     expect(await tools.getToolVersion('1.2.3-beta')).toBe('1.2.3-beta'); | ||||
|     expect(await tools.getToolVersion('1.2.3-rc')).toBe('1.2.3-rc'); | ||||
|     expect(await tools.getToolVersion('1.2.3-dev')).toBe('1.2.3-dev'); | ||||
|     expect(await tools.getToolVersion('1.2.3-alpha1')).toBe('1.2.3-alpha1'); | ||||
|     expect(await tools.getToolVersion('1.2.3-alpha.1')).toBe('1.2.3-alpha.1'); | ||||
|   }); | ||||
|  | ||||
|   it('checking parseToolVersion', async () => { | ||||
|     expect(await tools.parseTool('phpunit')).toStrictEqual({ | ||||
|       name: 'phpunit', | ||||
|       version: 'latest' | ||||
|     }); | ||||
|     expect(await tools.parseTool('phpunit:1.2.3')).toStrictEqual({ | ||||
|       name: 'phpunit', | ||||
|       version: '1.2.3' | ||||
|     }); | ||||
|     expect(await tools.parseTool('phpunit:^1.2.3')).toStrictEqual({ | ||||
|       name: 'phpunit', | ||||
|       version: '1.2.3' | ||||
|     }); | ||||
|     expect(await tools.parseTool('phpunit:>=1.2.3')).toStrictEqual({ | ||||
|       name: 'phpunit', | ||||
|       version: '1.2.3' | ||||
|     }); | ||||
|     expect(await tools.parseTool('phpunit:>1.2.3')).toStrictEqual({ | ||||
|       name: 'phpunit', | ||||
|       version: '1.2.3' | ||||
|     }); | ||||
|     expect(await tools.parseTool('phpunit:1.2.3-ALPHA')).toStrictEqual({ | ||||
|       name: 'phpunit', | ||||
|       version: '1.2.3-ALPHA' | ||||
|     }); | ||||
|     expect(await tools.parseTool('phpunit:1.2.3-alpha')).toStrictEqual({ | ||||
|       name: 'phpunit', | ||||
|       version: '1.2.3-alpha' | ||||
|     }); | ||||
|     expect(await tools.parseTool('phpunit:1.2.3-beta')).toStrictEqual({ | ||||
|       name: 'phpunit', | ||||
|       version: '1.2.3-beta' | ||||
|     }); | ||||
|     expect(await tools.parseTool('phpunit:1.2.3-rc')).toStrictEqual({ | ||||
|       name: 'phpunit', | ||||
|       version: '1.2.3-rc' | ||||
|     }); | ||||
|     expect(await tools.parseTool('phpunit:1.2.3-dev')).toStrictEqual({ | ||||
|       name: 'phpunit', | ||||
|       version: '1.2.3-dev' | ||||
|     }); | ||||
|     expect(await tools.parseTool('phpunit:1.2.3-alpha1')).toStrictEqual({ | ||||
|       name: 'phpunit', | ||||
|       version: '1.2.3-alpha1' | ||||
|     }); | ||||
|     expect(await tools.parseTool('phpunit:1.2.3-alpha.1')).toStrictEqual({ | ||||
|       name: 'phpunit', | ||||
|       version: '1.2.3-alpha.1' | ||||
|     }); | ||||
|   }); | ||||
|  | ||||
|   it('checking getUri', async () => { | ||||
|     expect( | ||||
|       await tools.getUri('tool', '.phar', 'latest', 'releases', '', 'download') | ||||
|     ).toBe('releases/latest/download/tool.phar'); | ||||
|     expect( | ||||
|       await tools.getUri('tool', '.phar', '1.2.3', 'releases', '', 'download') | ||||
|     ).toBe('releases/download/1.2.3/tool.phar'); | ||||
|     expect( | ||||
|       await tools.getUri('tool', '.phar', '1.2.3', 'releases', 'v', 'download') | ||||
|     ).toBe('releases/download/v1.2.3/tool.phar'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addPhive', async () => { | ||||
|     let script: string = await tools.addPhive('1.2.3', '7.4', 'linux'); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/phar-io/phive/releases/download/1.2.3/phive-1.2.3.phar phive' | ||||
|     ); | ||||
|  | ||||
|     script = await tools.addPhive('latest', '5.6', 'win32'); | ||||
|     expect(script).toContain( | ||||
|       'Add-Tool https://github.com/phar-io/phive/releases/download/0.12.1/phive-0.12.1.phar phive' | ||||
|     ); | ||||
|  | ||||
|     script = await tools.addPhive('latest', '7.1', 'win32'); | ||||
|     expect(script).toContain( | ||||
|       'Add-Tool https://github.com/phar-io/phive/releases/download/0.13.5/phive-0.13.5.phar phive' | ||||
|     ); | ||||
|  | ||||
|     script = await tools.addPhive('latest', '7.2', 'win32'); | ||||
|     expect(script).toContain( | ||||
|       'Add-Tool https://github.com/phar-io/phive/releases/download/0.14.5/phive-0.14.5.phar phive' | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('checking getPhpunitUri', async () => { | ||||
|     expect(await tools.getPharUrl('domain', 'tool', '', 'latest')).toBe( | ||||
|       'domain/tool.phar' | ||||
|     ); | ||||
|     expect(await tools.getPharUrl('domain', 'tool', 'v', '1.2.3')).toBe( | ||||
|       'domain/tool-v1.2.3.phar' | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('checking getDeployerUri', async () => { | ||||
|     expect(await tools.getDeployerUrl('latest')).toBe( | ||||
|       'https://deployer.org/deployer.phar' | ||||
|     ); | ||||
|     expect(await tools.getDeployerUrl('1.2.3')).toBe( | ||||
|       'https://deployer.org/releases/v1.2.3/deployer.phar' | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('checking addComposer', async () => { | ||||
|     expect(await tools.addComposer(['a', 'b'])).toStrictEqual([ | ||||
|       'composer', | ||||
|       'a', | ||||
|       'b' | ||||
|     ]); | ||||
|     expect(await tools.addComposer(['a', 'b', 'composer'])).toStrictEqual([ | ||||
|       'composer', | ||||
|       'a', | ||||
|       'b' | ||||
|     ]); | ||||
|     expect(await tools.addComposer(['a', 'b', 'composer:1.2'])).toStrictEqual([ | ||||
|       'composer', | ||||
|       'a', | ||||
|       'b' | ||||
|     ]); | ||||
|     expect(await tools.addComposer(['a', 'b', 'composer:1.2.3'])).toStrictEqual( | ||||
|       ['composer:1.2.3', 'a', 'b'] | ||||
|     ); | ||||
|     expect( | ||||
|       await tools.addComposer(['a', 'b', 'composer:v1.2.3']) | ||||
|     ).toStrictEqual(['composer:1.2.3', 'a', 'b']); | ||||
|     expect( | ||||
|       await tools.addComposer(['a', 'b', 'composer:snapshot']) | ||||
|     ).toStrictEqual(['composer:snapshot', 'a', 'b']); | ||||
|     expect( | ||||
|       await tools.addComposer(['a', 'b', 'composer:preview']) | ||||
|     ).toStrictEqual(['composer:preview', 'a', 'b']); | ||||
|     expect( | ||||
|       await tools.addComposer(['a', 'b', 'c', 'composer:1']) | ||||
|     ).toStrictEqual(['composer:1', 'a', 'b', 'c']); | ||||
|     expect( | ||||
|       await tools.addComposer(['a', 'b', 'c', 'composer:2']) | ||||
|     ).toStrictEqual(['composer:2', 'a', 'b', 'c']); | ||||
|     expect( | ||||
|       await tools.addComposer(['a', 'b', 'c', 'composer:v1']) | ||||
|     ).toStrictEqual(['composer:1', 'a', 'b', 'c']); | ||||
|     expect( | ||||
|       await tools.addComposer(['a', 'b', 'c', 'composer:v2']) | ||||
|     ).toStrictEqual(['composer:2', 'a', 'b', 'c']); | ||||
|     expect( | ||||
|       await tools.addComposer(['hirak', 'b', 'c', 'composer:v2']) | ||||
|     ).toStrictEqual(['composer:1', 'hirak', 'b', 'c']); | ||||
|   }); | ||||
|  | ||||
|   it('checking getComposerUrl', async () => { | ||||
|     expect(await tools.getComposerUrl('latest', '7.4')).toContain( | ||||
|       'https://getcomposer.org/composer-stable.phar' | ||||
|     ); | ||||
|     expect(await tools.getComposerUrl('stable', '7.4')).toContain( | ||||
|       'https://getcomposer.org/composer-stable.phar' | ||||
|     ); | ||||
|     expect(await tools.getComposerUrl('snapshot', '7.4')).toContain( | ||||
|       'https://getcomposer.org/composer.phar' | ||||
|     ); | ||||
|     expect(await tools.getComposerUrl('preview', '7.4')).toContain( | ||||
|       'https://getcomposer.org/composer-preview.phar' | ||||
|     ); | ||||
|     expect(await tools.getComposerUrl('1', '7.4')).toContain( | ||||
|       'https://getcomposer.org/composer-1.phar' | ||||
|     ); | ||||
|     expect(await tools.getComposerUrl('2', '7.4')).toContain( | ||||
|       'https://getcomposer.org/composer-2.phar' | ||||
|     ); | ||||
|     expect(await tools.getComposerUrl('1.7.2', '7.4')).toContain( | ||||
|       'https://github.com/composer/composer/releases/download/1.7.2/composer.phar' | ||||
|     ); | ||||
|     expect(await tools.getComposerUrl('1.7.2', '7.4')).toContain( | ||||
|       'https://getcomposer.org/composer-1.7.2.phar' | ||||
|     ); | ||||
|     expect(await tools.getComposerUrl('2.0.0-RC2', '7.4')).toContain( | ||||
|       'https://github.com/composer/composer/releases/download/2.0.0-RC2/composer.phar' | ||||
|     ); | ||||
|     expect(await tools.getComposerUrl('2.0.0-RC2', '7.4')).toContain( | ||||
|       'https://getcomposer.org/composer-2.0.0-RC2.phar' | ||||
|     ); | ||||
|     expect(await tools.getComposerUrl('wrong', '7.4')).toContain( | ||||
|       'https://getcomposer.org/composer-stable.phar' | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('checking getSymfonyUri', async () => { | ||||
|     expect(await tools.getSymfonyUri('latest', 'linux')).toContain( | ||||
|       'releases/latest/download/symfony_linux_amd64' | ||||
|     ); | ||||
|     expect(await tools.getSymfonyUri('1.2.3', 'linux')).toContain( | ||||
|       'releases/download/v1.2.3/symfony_linux_amd64' | ||||
|     ); | ||||
|     expect(await tools.getSymfonyUri('latest', 'darwin')).toContain( | ||||
|       'releases/latest/download/symfony_darwin_amd64' | ||||
|     ); | ||||
|     expect(await tools.getSymfonyUri('1.2.3', 'darwin')).toContain( | ||||
|       'releases/download/v1.2.3/symfony_darwin_amd64' | ||||
|     ); | ||||
|     expect(await tools.getSymfonyUri('latest', 'win32')).toContain( | ||||
|       'releases/latest/download/symfony_windows_amd64' | ||||
|     ); | ||||
|     expect(await tools.getSymfonyUri('1.2.3', 'win32')).toContain( | ||||
|       'releases/download/v1.2.3/symfony_windows_amd64' | ||||
|     ); | ||||
|     expect(await tools.getSymfonyUri('1.2.3', 'openbsd')).toContain( | ||||
|       'Platform openbsd is not supported' | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('checking getCleanedToolsList', async () => { | ||||
|     const tools_list: string[] = await tools.getCleanedToolsList( | ||||
|       'tool, composer:1.2.3, robmorgan/phinx' | ||||
|     ); | ||||
|     expect(tools_list).toStrictEqual(['composer:1.2.3', 'tool', 'phinx']); | ||||
|   }); | ||||
|  | ||||
|   it('checking addArchive', async () => { | ||||
|     let script: string = await tools.addArchive( | ||||
|       'tool', | ||||
|       'https://tool.com/tool.phar', | ||||
|       'linux' | ||||
|     ); | ||||
|     expect(script).toContain('add_tool https://tool.com/tool.phar tool'); | ||||
|     script = await tools.addArchive( | ||||
|       'tool', | ||||
|       'https://tool.com/tool.phar', | ||||
|       'darwin' | ||||
|     ); | ||||
|     expect(script).toContain('add_tool https://tool.com/tool.phar tool'); | ||||
|     script = await tools.addArchive( | ||||
|       'tool', | ||||
|       'https://tool.com/tool.phar', | ||||
|       'win32' | ||||
|     ); | ||||
|     expect(script).toContain('Add-Tool https://tool.com/tool.phar tool'); | ||||
|  | ||||
|     script = await tools.addArchive( | ||||
|       'tool', | ||||
|       'https://tool.com/tool.phar', | ||||
|       'openbsd' | ||||
|     ); | ||||
|     expect(script).toContain('Platform openbsd is not supported'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addDevTools', async () => { | ||||
|     let script: string = await tools.addDevTools('phpize', 'linux'); | ||||
|     expect(script).toContain('add_devtools'); | ||||
|     expect(script).toContain('add_log "$tick" "phpize" "Added"'); | ||||
|  | ||||
|     script = await tools.addDevTools('php-config', 'linux'); | ||||
|     expect(script).toContain('add_devtools'); | ||||
|     expect(script).toContain('add_log "$tick" "php-config" "Added"'); | ||||
|  | ||||
|     script = await tools.addDevTools('phpize', 'darwin'); | ||||
|     expect(script).toContain('add_log "$tick" "phpize" "Added"'); | ||||
|  | ||||
|     script = await tools.addDevTools('php-config', 'darwin'); | ||||
|     expect(script).toContain('add_log "$tick" "php-config" "Added"'); | ||||
|  | ||||
|     script = await tools.addDevTools('phpize', 'win32'); | ||||
|     expect(script).toContain( | ||||
|       'Add-Log "$cross" "phpize" "phpize is not a windows tool"' | ||||
|     ); | ||||
|  | ||||
|     script = await tools.addDevTools('php-config', 'win32'); | ||||
|     expect(script).toContain( | ||||
|       'Add-Log "$cross" "php-config" "php-config is not a windows tool"' | ||||
|     ); | ||||
|  | ||||
|     script = await tools.addDevTools('tool', 'openbsd'); | ||||
|     expect(script).toContain('Platform openbsd is not supported'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addPackage', async () => { | ||||
|     let script: string = await tools.addPackage( | ||||
|       'tool', | ||||
|       'tool:1.2.3', | ||||
|       'user/', | ||||
|       'linux' | ||||
|     ); | ||||
|     expect(script).toContain('add_composertool tool tool:1.2.3 user/'); | ||||
|  | ||||
|     script = await tools.addPackage('tool', 'tool:1.2.3', 'user/', 'darwin'); | ||||
|     expect(script).toContain('add_composertool tool tool:1.2.3 user/'); | ||||
|  | ||||
|     script = await tools.addPackage('tool', 'tool:1.2.3', 'user/', 'win32'); | ||||
|     expect(script).toContain('Add-Composertool tool tool:1.2.3 user/'); | ||||
|  | ||||
|     script = await tools.addPackage('tool', 'tool:1.2.3', 'user/', 'openbsd'); | ||||
|     expect(script).toContain('Platform openbsd is not supported'); | ||||
|   }); | ||||
|  | ||||
|   it('checking addTools on linux', async () => { | ||||
|     const script: string = await tools.addTools( | ||||
|       'cs2pr, php-cs-fixer, phpstan, phpunit, pecl, phinx, phinx:1.2.3, phive, php-config, phpize, symfony', | ||||
|       '7.4', | ||||
|       'linux' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/shivammathur/composer-cache/releases/latest/download/composer-7.4-stable.phar,https://getcomposer.org/composer-stable.phar composer' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/staabm/annotate-pull-request-from-checkstyle/releases/latest/download/cs2pr cs2pr' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/FriendsOfPHP/PHP-CS-Fixer/releases/latest/download/php-cs-fixer.phar php-cs-fixer' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/phpstan/phpstan/releases/latest/download/phpstan.phar phpstan' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://phar.io/releases/phive.phar phive' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://phar.phpunit.de/phpunit.phar phpunit' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/symfony/cli/releases/latest/download/symfony_linux_amd64 symfony' | ||||
|     ); | ||||
|     expect(script).toContain('add_pecl'); | ||||
|     expect(script).toContain('add_composertool phinx phinx robmorgan/'); | ||||
|     expect(script).toContain('add_composertool phinx phinx:1.2.3 robmorgan/'); | ||||
|     expect(script).toContain('add_devtools'); | ||||
|     expect(script).toContain('add_log "$tick" "php-config" "Added"'); | ||||
|     expect(script).toContain('add_log "$tick" "phpize" "Added"'); | ||||
|   }); | ||||
|   it('checking addTools on darwin', async () => { | ||||
|     const script: string = await tools.addTools( | ||||
|       'phpcs, phpcbf, phpcpd, phpmd, psalm, phinx, phive:1.2.3, cs2pr:1.2.3, phpize, php-config, symfony:1.2.3', | ||||
|       '7.4', | ||||
|       'darwin' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/shivammathur/composer-cache/releases/latest/download/composer-7.4-stable.phar,https://getcomposer.org/composer-stable.phar composer' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/staabm/annotate-pull-request-from-checkstyle/releases/download/1.2.3/cs2pr cs2pr' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/squizlabs/PHP_CodeSniffer/releases/latest/download/phpcs.phar phpcs' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/squizlabs/PHP_CodeSniffer/releases/latest/download/phpcbf.phar phpcbf' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://phar.phpunit.de/phpcpd.phar phpcpd' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/phpmd/phpmd/releases/latest/download/phpmd.phar phpmd' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'https://github.com/vimeo/psalm/releases/latest/download/psalm.phar psalm' | ||||
|     ); | ||||
|     expect(script).toContain('add_composertool phinx phinx robmorgan/'); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/phar-io/phive/releases/download/1.2.3/phive-1.2.3.phar phive' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/symfony/cli/releases/download/v1.2.3/symfony_darwin_amd64 symfony' | ||||
|     ); | ||||
|     expect(script).toContain('add_log "$tick" "phpize" "Added"'); | ||||
|     expect(script).toContain('add_log "$tick" "php-config" "Added"'); | ||||
|   }); | ||||
|   it('checking addTools on windows', async () => { | ||||
|     const script: string = await tools.addTools( | ||||
|       'cs2pr, deployer, phpmd, phinx, phive:0.13.2, php-config, phpize, symfony, does_not_exist, composer', | ||||
|       '7.4', | ||||
|       'win32' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'Add-Tool https://github.com/shivammathur/composer-cache/releases/latest/download/composer-7.4-stable.phar,https://getcomposer.org/composer-stable.phar composer' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'Add-Tool https://github.com/staabm/annotate-pull-request-from-checkstyle/releases/latest/download/cs2pr cs2pr' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'Add-Tool https://deployer.org/deployer.phar deployer' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'Add-Tool https://github.com/phpmd/phpmd/releases/latest/download/phpmd.phar phpmd' | ||||
|     ); | ||||
|     expect(script).toContain('Add-Composertool phinx phinx robmorgan/'); | ||||
|     expect(script).toContain( | ||||
|       'Add-Tool https://github.com/phar-io/phive/releases/download/0.13.2/phive-0.13.2.phar phive' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'Add-Tool https://github.com/symfony/cli/releases/latest/download/symfony_windows_amd64.exe symfony' | ||||
|     ); | ||||
|     expect(script).toContain('phpize is not a windows tool'); | ||||
|     expect(script).toContain('php-config is not a windows tool'); | ||||
|     expect(script).toContain('Tool does_not_exist is not supported'); | ||||
|   }); | ||||
|   it('checking addTools with composer tool using user/tool as input', async () => { | ||||
|     const script: string = await tools.addTools( | ||||
|       'codeception/codeception, hirak/prestissimo, narrowspark/automatic-composer-prefetcher, robmorgan/phinx', | ||||
|       '7.4', | ||||
|       'win32' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'Add-Tool https://github.com/shivammathur/composer-cache/releases/latest/download/composer-7.4-1.phar,https://getcomposer.org/composer-1.phar composer' | ||||
|     ); | ||||
|     expect(script).toContain('Add-Composertool prestissimo prestissimo hirak/'); | ||||
|     expect(script).toContain('Add-Composertool phinx phinx robmorgan/'); | ||||
|     expect(script).toContain( | ||||
|       'Add-Composertool composer-prefetcher composer-prefetcher narrowspark/automatic-' | ||||
|     ); | ||||
|   }); | ||||
|   it('checking composer setup', async () => { | ||||
|     let script: string = await tools.addTools( | ||||
|       'composer, composer:v1', | ||||
|       '7.4', | ||||
|       'linux' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/shivammathur/composer-cache/releases/latest/download/composer-7.4-1.phar,https://getcomposer.org/composer-1.phar composer' | ||||
|     ); | ||||
|  | ||||
|     script = await tools.addTools('composer:preview', '7.4', 'linux'); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/shivammathur/composer-cache/releases/latest/download/composer-7.4-preview.phar,https://getcomposer.org/composer-preview.phar composer' | ||||
|     ); | ||||
|     script = await tools.addTools( | ||||
|       'composer:v1, composer:preview, composer:snapshot', | ||||
|       '7.4', | ||||
|       'linux' | ||||
|     ); | ||||
|     expect(script).toContain( | ||||
|       'add_tool https://github.com/shivammathur/composer-cache/releases/latest/download/composer-7.4-snapshot.phar,https://getcomposer.org/composer.phar composer' | ||||
|     ); | ||||
|   }); | ||||
| }); | ||||
| @ -8,6 +8,10 @@ jest.mock('@actions/core', () => ({ | ||||
|   }) | ||||
| })); | ||||
|  | ||||
| jest.spyOn(utils, 'fetch').mockImplementation(async (url): Promise<string> => { | ||||
|   return `{ "latest": "8.0", "5.x": "5.6", "url": "${url}" }`; | ||||
| }); | ||||
|  | ||||
| async function cleanup(path: string): Promise<void> { | ||||
|   fs.unlink(path, error => { | ||||
|     if (error) { | ||||
| @ -17,58 +21,85 @@ async function cleanup(path: string): Promise<void> { | ||||
| } | ||||
|  | ||||
| describe('Utils tests', () => { | ||||
|   it('checking getInput', async () => { | ||||
|   it('checking readEnv', async () => { | ||||
|     process.env['test'] = 'setup-php'; | ||||
|     process.env['undefined'] = ''; | ||||
|     process.env['test-hyphen'] = 'setup-php'; | ||||
|     expect(await utils.readEnv('test')).toBe('setup-php'); | ||||
|     expect(await utils.readEnv('TEST')).toBe('setup-php'); | ||||
|     expect(await utils.readEnv('test_hyphen')).toBe('setup-php'); | ||||
|     expect(await utils.readEnv('TEST_HYPHEN')).toBe('setup-php'); | ||||
|     expect(await utils.readEnv('undefined')).toBe(''); | ||||
|   }); | ||||
|  | ||||
|   it('checking getInput', async () => { | ||||
|     expect(await utils.getInput('test', false)).toBe('setup-php'); | ||||
|     expect(await utils.getInput('undefined', false)).toBe(''); | ||||
|     expect(await utils.getInput('setup-php', false)).toBe('setup-php'); | ||||
|     expect(await utils.getInput('DoesNotExist', false)).toBe(''); | ||||
|     expect(async () => { | ||||
|       await utils.getInput('DoesNotExist', true); | ||||
|     }).rejects.toThrow('Input required and not supplied: DoesNotExist'); | ||||
|   }); | ||||
|  | ||||
|   it('checking fetch', async () => { | ||||
|     expect(await utils.fetch('test_url')).toBe( | ||||
|       '{ "latest": "8.0", "5.x": "5.6", "url": "test_url" }' | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('checking parseVersion', async () => { | ||||
|     expect(await utils.parseVersion('latest')).toBe('8.0'); | ||||
|     expect(await utils.parseVersion('7')).toBe('7.0'); | ||||
|     expect(await utils.parseVersion('7.4')).toBe('7.4'); | ||||
|     expect(await utils.parseVersion('5.x')).toBe('5.6'); | ||||
|     expect(await utils.parseVersion('4.x')).toBe(undefined); | ||||
|   }); | ||||
|  | ||||
|   it('checking asyncForEach', async () => { | ||||
|     let array: Array<number> = [1, 2, 3, 4]; | ||||
|     let sum: number = 0; | ||||
|     await utils.asyncForEach(array, function(num: number): void { | ||||
|       sum += num; | ||||
|     }); | ||||
|     expect(sum).toBe(10); | ||||
|     const array: Array<string> = ['a', 'b', 'c']; | ||||
|     let concat = ''; | ||||
|     await utils.asyncForEach( | ||||
|       array, | ||||
|       async function (str: string): Promise<void> { | ||||
|         concat += str; | ||||
|       } | ||||
|     ); | ||||
|     expect(concat).toBe('abc'); | ||||
|   }); | ||||
|  | ||||
|   it('checking asyncForEach', async () => { | ||||
|     expect(await utils.color('error')).toBe('31'); | ||||
|     expect(await utils.color('success')).toBe('32'); | ||||
|     expect(await utils.color('any')).toBe('32'); | ||||
|     expect(await utils.color('warning')).toBe('33'); | ||||
|   }); | ||||
|  | ||||
|   it('checking readScripts', async () => { | ||||
|     let rc: string = fs.readFileSync( | ||||
|       path.join(__dirname, '../src/scripts/7.4.sh'), | ||||
|       'utf8' | ||||
|     ); | ||||
|     let darwin: string = fs.readFileSync( | ||||
|     const darwin: string = fs.readFileSync( | ||||
|       path.join(__dirname, '../src/scripts/darwin.sh'), | ||||
|       'utf8' | ||||
|     ); | ||||
|     let linux: string = fs.readFileSync( | ||||
|     const linux: string = fs.readFileSync( | ||||
|       path.join(__dirname, '../src/scripts/linux.sh'), | ||||
|       'utf8' | ||||
|     ); | ||||
|     let win32: string = fs.readFileSync( | ||||
|     const win32: string = fs.readFileSync( | ||||
|       path.join(__dirname, '../src/scripts/win32.ps1'), | ||||
|       'utf8' | ||||
|     ); | ||||
|     expect(await utils.readScript('darwin.sh', '7.4', 'darwin')).toBe(rc); | ||||
|     expect(await utils.readScript('darwin.sh', '7.3', 'darwin')).toBe(darwin); | ||||
|     expect(await utils.readScript('linux.sh', '7.4', 'linux')).toBe(linux); | ||||
|     expect(await utils.readScript('linux.sh', '7.3', 'linux')).toBe(linux); | ||||
|     expect(await utils.readScript('win32.ps1', '7.4', 'win32')).toBe(win32); | ||||
|     expect(await utils.readScript('win32.ps1', '7.3', 'win32')).toBe(win32); | ||||
|     expect(await utils.readScript('fedora.sh', '7.3', 'fedora')).toContain( | ||||
|       'Platform fedora is not supported' | ||||
|     ); | ||||
|     expect(await utils.readScript('darwin.sh')).toBe(darwin); | ||||
|     expect(await utils.readScript('darwin.sh')).toBe(darwin); | ||||
|     expect(await utils.readScript('linux.sh')).toBe(linux); | ||||
|     expect(await utils.readScript('linux.sh')).toBe(linux); | ||||
|     expect(await utils.readScript('win32.ps1')).toBe(win32); | ||||
|     expect(await utils.readScript('win32.ps1')).toBe(win32); | ||||
|   }); | ||||
|  | ||||
|   it('checking writeScripts', async () => { | ||||
|     let testString: string = 'sudo apt-get install php'; | ||||
|     let runner_dir: string = process.env['RUNNER_TOOL_CACHE'] || ''; | ||||
|     let script_path: string = path.join(runner_dir, 'test.sh'); | ||||
|     const testString = 'sudo apt-get install php'; | ||||
|     const runner_dir: string = process.env['RUNNER_TOOL_CACHE'] || ''; | ||||
|     const script_path: string = path.join(runner_dir, 'test.sh'); | ||||
|     await utils.writeScript('test.sh', testString); | ||||
|     await fs.readFile(script_path, function(error: any, data: Buffer) { | ||||
|     fs.readFile(script_path, function (error: Error | null, data: Buffer) { | ||||
|       expect(testString).toBe(data.toString()); | ||||
|     }); | ||||
|     await cleanup(script_path); | ||||
| @ -87,17 +118,39 @@ describe('Utils tests', () => { | ||||
|   }); | ||||
|  | ||||
|   it('checking INIArray', async () => { | ||||
|     expect(await utils.INIArray('a=1, b=2, c=3')).toEqual([ | ||||
|     expect(await utils.CSVArray('a=1, b=2, c=3')).toEqual([ | ||||
|       'a=1', | ||||
|       'b=2', | ||||
|       'c=3' | ||||
|     ]); | ||||
|     expect(await utils.INIArray('')).toEqual([]); | ||||
|     expect(await utils.INIArray(' ')).toEqual([]); | ||||
|     expect(await utils.CSVArray('\'a=1,2\', "b=3, 4", c=5, d=~e~')).toEqual([ | ||||
|       'a=1,2', | ||||
|       'b=3, 4', | ||||
|       'c=5', | ||||
|       "d='~e~'" | ||||
|     ]); | ||||
|     expect(await utils.CSVArray('a=\'1,2\', b="3, 4", c=5')).toEqual([ | ||||
|       'a=1,2', | ||||
|       'b=3, 4', | ||||
|       'c=5' | ||||
|     ]); | ||||
|     expect(await utils.CSVArray('\'a=1,2\', "b=3, 4", c=5, d=~e~')).toEqual([ | ||||
|       'a=1,2', | ||||
|       'b=3, 4', | ||||
|       'c=5', | ||||
|       "d='~e~'" | ||||
|     ]); | ||||
|     expect(await utils.CSVArray('a=\'1,2\', b="3, 4", c=5')).toEqual([ | ||||
|       'a=1,2', | ||||
|       'b=3, 4', | ||||
|       'c=5' | ||||
|     ]); | ||||
|     expect(await utils.CSVArray('')).toEqual([]); | ||||
|     expect(await utils.CSVArray(' ')).toEqual([]); | ||||
|   }); | ||||
|  | ||||
|   it('checking log', async () => { | ||||
|     let message: string = 'Test message'; | ||||
|     const message = 'Test message'; | ||||
|  | ||||
|     let warning_log: string = await utils.log(message, 'win32', 'warning'); | ||||
|     expect(warning_log).toEqual('printf "\\033[33;1m' + message + ' \\033[0m"'); | ||||
| @ -126,8 +179,8 @@ describe('Utils tests', () => { | ||||
|     expect(step_log).toEqual('step_log "Test message"'); | ||||
|     step_log = await utils.stepLog(message, 'darwin'); | ||||
|     expect(step_log).toEqual('step_log "Test message"'); | ||||
|     step_log = await utils.stepLog(message, 'fedora'); | ||||
|     expect(step_log).toContain('Platform fedora is not supported'); | ||||
|     step_log = await utils.stepLog(message, 'openbsd'); | ||||
|     expect(step_log).toContain('Platform openbsd is not supported'); | ||||
|  | ||||
|     let add_log: string = await utils.addLog( | ||||
|       'tick', | ||||
| @ -140,8 +193,8 @@ describe('Utils tests', () => { | ||||
|     expect(add_log).toEqual('add_log "tick" "xdebug" "enabled"'); | ||||
|     add_log = await utils.addLog('tick', 'xdebug', 'enabled', 'darwin'); | ||||
|     expect(add_log).toEqual('add_log "tick" "xdebug" "enabled"'); | ||||
|     add_log = await utils.addLog('tick', 'xdebug', 'enabled', 'fedora'); | ||||
|     expect(add_log).toContain('Platform fedora is not supported'); | ||||
|     add_log = await utils.addLog('tick', 'xdebug', 'enabled', 'openbsd'); | ||||
|     expect(add_log).toContain('Platform openbsd is not supported'); | ||||
|   }); | ||||
|  | ||||
|   it('checking getExtensionPrefix', async () => { | ||||
| @ -154,11 +207,11 @@ describe('Utils tests', () => { | ||||
|   }); | ||||
|  | ||||
|   it('checking suppressOutput', async () => { | ||||
|     expect(await utils.suppressOutput('win32')).toEqual(' >$null 2>&1'); | ||||
|     expect(await utils.suppressOutput('linux')).toEqual(' >/dev/null 2>&1'); | ||||
|     expect(await utils.suppressOutput('darwin')).toEqual(' >/dev/null 2>&1'); | ||||
|     expect(await utils.suppressOutput('fedora')).toContain( | ||||
|       'Platform fedora is not supported' | ||||
|     expect(await utils.suppressOutput('win32')).toEqual(' '); | ||||
|     expect(await utils.suppressOutput('linux')).toEqual(' '); | ||||
|     expect(await utils.suppressOutput('darwin')).toEqual(' '); | ||||
|     expect(await utils.suppressOutput('openbsd')).toContain( | ||||
|       'Platform openbsd is not supported' | ||||
|     ); | ||||
|   }); | ||||
| }); | ||||
|  | ||||
							
								
								
									
										32
									
								
								action.yml
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								action.yml
									
									
									
									
									
								
							| @ -1,24 +1,38 @@ | ||||
| name: 'Setup PHP Action' | ||||
| author: shivammathur | ||||
| description: 'GitHub action to setup PHP with required extensions, php.ini configuration, code-coverage support and composer' | ||||
| description: 'GitHub Action for PHP' | ||||
| branding: | ||||
|   color: 'purple' | ||||
|   icon: 'play-circle' | ||||
| inputs: | ||||
|   php-version: | ||||
|     description: 'PHP version you want to install.' | ||||
|     description: 'Setup PHP version.' | ||||
|     default: '7.4' | ||||
|     required: true | ||||
|   extension-csv: | ||||
|     description: '(Optional) PHP extensions you want to install.' | ||||
|   extensions: | ||||
|     description: 'Setup PHP extensions.' | ||||
|     required: false | ||||
|   ini-values-csv:  | ||||
|     description: '(Optional) Custom values you want to set in php.ini.' | ||||
|   ini-values: | ||||
|     description: 'Add values to php.ini.' | ||||
|     required: false | ||||
|   coverage:  | ||||
|     description: '(Optional) Code coverage driver you want to install. (Accepts: xdebug, pcov and none)' | ||||
|     description: 'Setup code coverage driver.' | ||||
|     required: false | ||||
|   tools: | ||||
|     description: 'Setup popular tools globally.' | ||||
|     required: false | ||||
|   extension-csv: | ||||
|     description: 'Deprecated! Use extensions instead.' | ||||
|     deprecationMessage: 'The extension-csv property is deprecated. Use extensions instead.' | ||||
|     required: false | ||||
|   ini-values-csv: | ||||
|     description: 'Deprecated! Use ini-values instead.' | ||||
|     deprecationMessage: 'The ini-values-csv property is deprecated. Use ini-values instead.' | ||||
|     required: false | ||||
|   pecl: | ||||
|     description: '(Optional) Setup PECL on ubuntu' | ||||
|     description: 'Deprecated! Use tools instead to setup PECL.' | ||||
|     deprecationMessage: 'The pecl property is deprecated. Specify pecl in tools instead.' | ||||
|     required: false | ||||
| runs: | ||||
|   using: 'node12' | ||||
|   main: 'lib/install.js' | ||||
|   main: 'dist/index.js' | ||||
|  | ||||
							
								
								
									
										4010
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4010
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										32
									
								
								examples/bedrock.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								examples/bedrock.yml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,32 @@ | ||||
| # GitHub Action for roots/bedrock | ||||
| name: Testing Bedrock | ||||
| on: [push, pull_request] | ||||
| jobs: | ||||
|   bedrock: | ||||
|     name: Bedrock (PHP ${{ matrix.php-versions }}) | ||||
|     runs-on: ubuntu-latest | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         php-versions: ['7.1', '7.2', '7.3', '7.4'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: PHP test | ||||
|         run: composer test | ||||
							
								
								
									
										114
									
								
								examples/cakephp-mysql.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										114
									
								
								examples/cakephp-mysql.yml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,114 @@ | ||||
| # GitHub Action for CakePHP with MySQL and Redis | ||||
| # Tested with https://github.com/cakephp/app | ||||
| name: Testing CakePHP with MySQL | ||||
| on: [push, pull_request] | ||||
| jobs: | ||||
|   tests: | ||||
|     strategy: | ||||
|       matrix: | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     runs-on: ubuntu-latest | ||||
|     services: | ||||
|       mysql: | ||||
|         image: mysql:5.7 | ||||
|         env: | ||||
|           MYSQL_ALLOW_EMPTY_PASSWORD: false | ||||
|           MYSQL_ROOT_PASSWORD: password | ||||
|           MYSQL_DATABASE: cakephp | ||||
|         ports: | ||||
|           - 3306/tcp | ||||
|         options: --health-cmd="mysqladmin ping" --health-interval=10s --health-timeout=5s --health-retries=3 | ||||
|       redis: | ||||
|         image: redis | ||||
|         ports: | ||||
|           - 6379/tcp | ||||
|         options: --health-cmd="redis-cli ping" --health-interval=10s --health-timeout=5s --health-retries=3 | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP | ||||
|         uses: shivammathur/setup-php@v1 | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           # You can also use ext-apcu or ext-memcached instead of ext-redis | ||||
|           # Install memcached if using ext-memcached | ||||
|           extensions: mbstring, intl, redis, pdo_mysql | ||||
|           coverage: pcov | ||||
|       - name: Start mysql service | ||||
|         run: sudo /etc/init.d/mysql start | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install dependencies | ||||
|         run: | | ||||
|           composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|           composer run-script post-install-cmd --no-interaction | ||||
|       # Add a step to run migrations if required | ||||
|       - name: Test with phpunit | ||||
|         run: vendor/bin/phpunit --coverage-text | ||||
|         env: | ||||
|           REDIS_PORT: ${{ job.services.redis.ports['6379'] }} | ||||
|           DB_DSN: "mysql://root:password@127.0.0.1:${{ job.services.mysql.ports['3306'] }}/cakephp?init[]=SET sql_mode = \"STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION\"" | ||||
|  | ||||
|   coding-standard: | ||||
|     name: Coding Standard | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP | ||||
|         uses: shivammathur/setup-php@v1 | ||||
|         with: | ||||
|           php-version: '7.3' | ||||
|           extensions: mbstring, intl | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install dependencies | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: PHP CodeSniffer | ||||
|         run: composer cs-check | ||||
|  | ||||
|   static-analysis: | ||||
|     name: Static Analysis | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP | ||||
|         uses: shivammathur/setup-php@v1 | ||||
|         with: | ||||
|           php-version: '7.3' | ||||
|           extensions: mbstring, intl | ||||
|           tools: phpstan | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install dependencies | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Static Analysis using PHPStan | ||||
|         run: phpstan analyse --no-progress src/ | ||||
							
								
								
									
										112
									
								
								examples/cakephp-postgres.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										112
									
								
								examples/cakephp-postgres.yml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,112 @@ | ||||
| # GitHub Action for CakePHP with PostgreSQL and Redis | ||||
| # Tested with https://github.com/cakephp/app | ||||
| name: Testing CakePHP with PostgreSQL | ||||
| on: [push, pull_request] | ||||
| jobs: | ||||
|   tests: | ||||
|     strategy: | ||||
|       matrix: | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     runs-on: ubuntu-latest | ||||
|     services: | ||||
|       postgres: | ||||
|         image: postgres:10.8 | ||||
|         env: | ||||
|           POSTGRES_USER: postgres | ||||
|           POSTGRES_PASSWORD: postgres | ||||
|           POSTGRES_DB: postgres | ||||
|         ports: | ||||
|           - 5432/tcp | ||||
|         options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 3 | ||||
|       redis: | ||||
|         image: redis | ||||
|         ports: | ||||
|           - 6379/tcp | ||||
|         options: --health-cmd="redis-cli ping" --health-interval=10s --health-timeout=5s --health-retries=3 | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP | ||||
|         uses: shivammathur/setup-php@v1 | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           # You can also use ext-apcu or ext-memcached instead of ext-redis | ||||
|           # Install memcached if using ext-memcached | ||||
|           extensions: mbstring, intl, redis, pdo_pgsql | ||||
|           coverage: pcov | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install dependencies | ||||
|         run: | | ||||
|           composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|           composer run-script post-install-cmd --no-interaction | ||||
|       # Add a step to run migrations if required | ||||
|       - name: Test with phpunit | ||||
|         run: vendor/bin/phpunit --coverage-text | ||||
|         env: | ||||
|           REDIS_PORT: ${{ job.services.redis.ports['6379'] }} | ||||
|           DB_DSN: postgres://postgres@127.0.0.1:${{ job.services.postgres.ports['5432'] }}/postgres | ||||
|  | ||||
|   coding-standard: | ||||
|     name: Coding Standard | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP | ||||
|         uses: shivammathur/setup-php@v1 | ||||
|         with: | ||||
|           php-version: '7.3' | ||||
|           extensions: mbstring, intl | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install dependencies | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: PHP CodeSniffer | ||||
|         run: composer cs-check | ||||
|  | ||||
|   static-analysis: | ||||
|     name: Static Analysis | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP | ||||
|         uses: shivammathur/setup-php@v1 | ||||
|         with: | ||||
|           php-version: '7.3' | ||||
|           extensions: mbstring, intl | ||||
|           tools: phpstan | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install dependencies | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Static Analysis using PHPStan | ||||
|         run: phpstan analyse --no-progress src/ | ||||
							
								
								
									
										92
									
								
								examples/cakephp.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								examples/cakephp.yml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,92 @@ | ||||
| # GitHub Action for CakePHP | ||||
| # Tested with https://github.com/cakephp/app | ||||
| name: Testing CakePHP | ||||
| on: [push, pull_request] | ||||
| jobs: | ||||
|   tests: | ||||
|     strategy: | ||||
|       matrix: | ||||
|         operating-system: [ubuntu-latest, windows-latest, macos-latest] | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extensions: mbstring, intl, pdo_sqlite, pdo_mysql | ||||
|           coverage: pcov #optional | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install dependencies | ||||
|         run: | | ||||
|           composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|           composer run-script post-install-cmd --no-interaction | ||||
|       - name: Test with phpunit | ||||
|         run: vendor/bin/phpunit --coverage-text | ||||
|  | ||||
|   coding-standard: | ||||
|     name: Coding Standard | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP | ||||
|         uses: shivammathur/setup-php@v1 | ||||
|         with: | ||||
|           php-version: '7.3' | ||||
|           extensions: mbstring, intl | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install dependencies | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: PHP CodeSniffer | ||||
|         run: composer cs-check | ||||
|  | ||||
|   static-analysis: | ||||
|     name: Static Analysis | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP | ||||
|         uses: shivammathur/setup-php@v1 | ||||
|         with: | ||||
|           php-version: '7.3' | ||||
|           extensions: mbstring, intl | ||||
|           tools: phpstan | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install dependencies | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Static Analysis using PHPStan | ||||
|         run: phpstan analyse --no-progress src/ | ||||
| @ -4,21 +4,31 @@ on: [push, pull_request] | ||||
| jobs: | ||||
|   build: | ||||
|     strategy: | ||||
|       max-parallel: 6 | ||||
|       matrix: | ||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] | ||||
|         php-versions: ['7.2', '7.3'] | ||||
|         operating-system: [ubuntu-latest, windows-latest, macos-latest] | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@master | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, intl, curl, dom | ||||
|           extensions: mbstring, intl, curl, dom | ||||
|           coverage: xdebug #optional | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install dependencies | ||||
|         run: composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Test with phpunit | ||||
|         run: vendor/bin/phpunit --coverage-text | ||||
| @ -21,7 +21,7 @@ jobs: | ||||
|           MYSQL_ROOT_PASSWORD: password | ||||
|           MYSQL_DATABASE: laravel | ||||
|         ports: | ||||
|           - 3306 | ||||
|           - 3306/tcp | ||||
|         options: --health-cmd="mysqladmin ping" --health-interval=10s --health-timeout=5s --health-retries=3 | ||||
|       redis: | ||||
|         image: redis | ||||
| @ -30,20 +30,32 @@ jobs: | ||||
|         options: --health-cmd="redis-cli ping" --health-interval=10s --health-timeout=5s --health-retries=3 | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 3 | ||||
|       matrix: | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v1 | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, dom, fileinfo, mysql | ||||
|           extensions: mbstring, dom, fileinfo, mysql | ||||
|           coverage: xdebug #optional | ||||
|       - name: Start mysql service | ||||
|         run: sudo /etc/init.d/mysql start | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Prepare the application | ||||
|         run: | | ||||
|           php -r "file_exists('.env') || copy('.env.example', '.env');" | ||||
| @ -54,7 +66,9 @@ jobs: | ||||
|         run: php artisan migrate -v | ||||
|         env: | ||||
|           DB_PORT: ${{ job.services.mysql.ports['3306'] }} | ||||
|           REDIS_PORT: ${{ job.services.redis.ports['6379'] }} | ||||
|       - name: Test with phpunit | ||||
|         run: vendor/bin/phpunit --coverage-text | ||||
|         env: | ||||
|           DB_PORT: ${{ job.services.mysql.ports['3306'] }} | ||||
|           DB_PORT: ${{ job.services.mysql.ports['3306'] }} | ||||
|           REDIS_PORT: ${{ job.services.redis.ports['6379'] }} | ||||
| @ -32,20 +32,30 @@ jobs: | ||||
|         options: --health-cmd="redis-cli ping" --health-interval=10s --health-timeout=5s --health-retries=3 | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 3 | ||||
|       matrix: | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v1 | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, dom, fileinfo, pgsql | ||||
|           extensions: mbstring, dom, fileinfo, pgsql | ||||
|           coverage: xdebug #optional | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Prepare the application | ||||
|         run: | | ||||
|           php -r "file_exists('.env') || copy('.env.example', '.env');" | ||||
| @ -56,7 +66,9 @@ jobs: | ||||
|         run: php artisan migrate -v | ||||
|         env: | ||||
|           DB_PORT: ${{ job.services.postgres.ports[5432] }} | ||||
|           REDIS_PORT: ${{ job.services.redis.ports['6379'] }} | ||||
|       - name: Test with phpunit | ||||
|         run: vendor/bin/phpunit --coverage-text | ||||
|         env: | ||||
|           DB_PORT: ${{ job.services.postgres.ports[5432] }} | ||||
|           DB_PORT: ${{ job.services.postgres.ports[5432] }} | ||||
|           REDIS_PORT: ${{ job.services.redis.ports['6379'] }} | ||||
| @ -7,21 +7,31 @@ jobs: | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 6 | ||||
|       matrix: | ||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] | ||||
|         php-versions: ['7.2', '7.3'] | ||||
|         operating-system: [ubuntu-latest, windows-latest, macos-latest] | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v1 | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, dom, fileinfo | ||||
|           extensions: mbstring, dom, fileinfo | ||||
|           coverage: xdebug #optional | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Prepare the application | ||||
|         run: | | ||||
|           php -r "file_exists('.env') || copy('.env.example', '.env');" | ||||
|  | ||||
| @ -21,7 +21,7 @@ jobs: | ||||
|           MYSQL_ROOT_PASSWORD: password | ||||
|           MYSQL_DATABASE: lumen | ||||
|         ports: | ||||
|           - 3306 | ||||
|           - 3306/tcp | ||||
|         options: --health-cmd="mysqladmin ping" --health-interval=10s --health-timeout=5s --health-retries=3 | ||||
|       redis: | ||||
|         image: redis | ||||
| @ -30,21 +30,33 @@ jobs: | ||||
|         options: --health-cmd="redis-cli ping" --health-interval=10s --health-timeout=5s --health-retries=3 | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 3 | ||||
|       matrix: | ||||
|         php-versions: ['7.2', '7.3'] | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v1 | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, dom, fileinfo, mysql | ||||
|           extensions: mbstring, dom, fileinfo, mysql | ||||
|           coverage: xdebug #optional | ||||
|       - name: Start mysql service | ||||
|         run: sudo /etc/init.d/mysql start | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: | | ||||
|           composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|           composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|           composer require predis/predis illuminate/redis | ||||
|       - name: Prepare the application | ||||
|         run: php -r "file_exists('.env') || copy('.env.example', '.env');" | ||||
| @ -54,7 +66,9 @@ jobs: | ||||
|         run: php artisan migrate -v | ||||
|         env: | ||||
|           DB_PORT: ${{ job.services.mysql.ports['3306'] }} | ||||
|           REDIS_PORT: ${{ job.services.redis.ports['6379'] }} | ||||
|       - name: Test with phpunit | ||||
|         run: vendor/bin/phpunit --coverage-text | ||||
|         env: | ||||
|           DB_PORT: ${{ job.services.mysql.ports['3306'] }} | ||||
|           DB_PORT: ${{ job.services.mysql.ports['3306'] }} | ||||
|           REDIS_PORT: ${{ job.services.redis.ports['6379'] }} | ||||
| @ -32,21 +32,31 @@ jobs: | ||||
|         options: --health-cmd="redis-cli ping" --health-interval=10s --health-timeout=5s --health-retries=3 | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 3 | ||||
|       matrix: | ||||
|         php-versions: ['7.2', '7.3'] | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v1 | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, dom, fileinfo, pgsql | ||||
|           extensions: mbstring, dom, fileinfo, pgsql | ||||
|           coverage: xdebug #optional | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: | | ||||
|           composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|           composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|           composer require predis/predis illuminate/redis | ||||
|       - name: Prepare the application | ||||
|         run: php -r "file_exists('.env') || copy('.env.example', '.env');" | ||||
| @ -56,7 +66,9 @@ jobs: | ||||
|         run: php artisan migrate -v | ||||
|         env: | ||||
|           DB_PORT: ${{ job.services.postgres.ports[5432] }} | ||||
|           REDIS_PORT: ${{ job.services.redis.ports['6379'] }} | ||||
|       - name: Test with phpunit | ||||
|         run: vendor/bin/phpunit --coverage-text | ||||
|         env: | ||||
|           DB_PORT: ${{ job.services.postgres.ports[5432] }} | ||||
|           REDIS_PORT: ${{ job.services.redis.ports['6379'] }} | ||||
|  | ||||
| @ -7,21 +7,31 @@ jobs: | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 9 | ||||
|       matrix: | ||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] | ||||
|         php-versions: ['7.2', '7.3'] | ||||
|         operating-system: [ubuntu-latest, windows-latest, macos-latest] | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v1 | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, dom, fileinfo, mysql | ||||
|           extensions: mbstring, dom, fileinfo, mysql | ||||
|           coverage: xdebug #optional | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Prepare the application | ||||
|         run: php -r "file_exists('.env') || copy('.env.example', '.env');" | ||||
|       - name: Test with phpunit | ||||
|  | ||||
| @ -24,24 +24,38 @@ jobs: | ||||
|           MYSQL_ROOT_PASSWORD: password | ||||
|           MYSQL_DATABASE: phalcon | ||||
|         ports: | ||||
|           - 3306 | ||||
|           - 3306/tcp | ||||
|         options: --health-cmd="mysqladmin ping" --health-interval=10s --health-timeout=5s --health-retries=3 | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 3 | ||||
|       matrix: | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|       # For phalcon 3.x, use | ||||
|       # php-versions: ['7.0', '7.1', '7.2', '7.3'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v1 | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, dom, zip, phalcon4, mysql #use phalcon3 for the phalcon 3.x. | ||||
|           extensions: mbstring, dom, zip, phalcon4, mysql #use phalcon3 for the phalcon 3.x. | ||||
|           coverage: xdebug #optional | ||||
|       - name: Start mysql service | ||||
|         run: sudo /etc/init.d/mysql start | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Prepare the application | ||||
|         run: php -r "file_exists('.env') || copy('.env.example', '.env');" | ||||
|       - name: Run Migration | ||||
|  | ||||
| @ -29,20 +29,32 @@ jobs: | ||||
|         options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 3 | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 3 | ||||
|       matrix: | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|       # For phalcon 3.x, use | ||||
|       # php-versions: ['7.0', '7.1', '7.2', '7.3'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v1 | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, dom, zip, phalcon4, pgsql #use phalcon3 for the phalcon 3.x | ||||
|           extensions: mbstring, dom, zip, phalcon4, pgsql #use phalcon3 for the phalcon 3.x | ||||
|           coverage: xdebug #optional | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Prepare the application | ||||
|         run: php -r "file_exists('.env') || copy('.env.example', '.env');" | ||||
|       - name: Run Migration | ||||
|  | ||||
							
								
								
									
										57
									
								
								examples/sage.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								examples/sage.yml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,57 @@ | ||||
| # GitHub Action for roots/sage | ||||
| name: Testing Sage | ||||
| on: [push, pull_request] | ||||
| jobs: | ||||
|   sage: | ||||
|     name: Sage (PHP ${{ matrix.php-versions }} & Node ${{ matrix.node-versions }}) | ||||
|     runs-on: ubuntu-latest | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         php-versions: ['7.1', '7.2', '7.3', '7.4'] | ||||
|         node-versions: ['8', '10'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v1 | ||||
|         with: | ||||
|           node-version: ${{ matrix.node-versions }} | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extensions: mbstring | ||||
|       - name: Check node versions | ||||
|         run: node -v | ||||
|       - name: Get yarn cache | ||||
|         id: yarn-cache | ||||
|         run: echo "::set-output name=dir::$(yarn cache dir)" | ||||
|       - uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.yarn-cache.outputs.dir }} | ||||
|           key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-yarn- | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install yarn dependencies | ||||
|         run: yarn -V | ||||
|       - name: Install Composer dependencies | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Yarn test and build | ||||
|         run: | | ||||
|           yarn run test | ||||
|           yarn run build | ||||
|           yarn run rmdist | ||||
|           yarn run "build:production" | ||||
|       - name: PHP test | ||||
|         run: composer test | ||||
| @ -4,21 +4,31 @@ on: [push, pull_request] | ||||
| jobs: | ||||
|   build: | ||||
|     strategy: | ||||
|       max-parallel: 6 | ||||
|       matrix: | ||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] | ||||
|         php-versions: ['7.2', '7.3'] | ||||
|         operating-system: [ubuntu-latest, windows-latest, macos-latest] | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@master | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, simplexml, dom | ||||
|           extensions: mbstring, simplexml, dom | ||||
|           coverage: xdebug #optional | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install dependencies | ||||
|         run: composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Test with phpunit | ||||
|         run: vendor/bin/phpunit --coverage-text | ||||
| @ -13,33 +13,44 @@ jobs: | ||||
|           MYSQL_ROOT_PASSWORD: symfony | ||||
|           MYSQL_DATABASE: symfony | ||||
|         ports: | ||||
|           - 3306 | ||||
|           - 3306/tcp | ||||
|         options: --health-cmd="mysqladmin ping" --health-interval=10s --health-timeout=5s --health-retries=3 | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 3 | ||||
|       matrix: | ||||
|         php-versions: ['7.3'] | ||||
|         php-versions: ['7.3', '7.4'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v1 | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v2 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, xml, ctype, iconv, mysql | ||||
|           extensions: mbstring, xml, ctype, iconv, intl, pdo_sqlite, mysql | ||||
|           coverage: xdebug #optional | ||||
|       - name: Start mysql service | ||||
|         run: sudo /etc/init.d/mysql start | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: | | ||||
|           composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|           composer require --dev symfony/orm-pack symfony/phpunit-bridge | ||||
|           composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|           php bin/phpunit install | ||||
|       - name: Run Migration | ||||
|         run: | | ||||
|           composer require symfony/orm-pack | ||||
|           php bin/console doctrine:schema:update --force || echo "No migrations found or schema update failed" | ||||
|           php bin/console doctrine:migrations:migrate || echo "No migrations found or migration failed" | ||||
|         env: | ||||
|           DATABASE_URL: mysql://root:symfony@127.0.0.1:${{ job.services.mysql.ports['3306'] }}/symfony | ||||
|       - name: Run Tests | ||||
|         run: | | ||||
|           composer require phpunit | ||||
|           php bin/phpunit --coverage-text | ||||
|         run: php bin/phpunit --coverage-text | ||||
| @ -17,29 +17,38 @@ jobs: | ||||
|         options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 3 | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 3 | ||||
|       matrix: | ||||
|         php-versions: ['7.3'] | ||||
|         php-versions: ['7.3', '7.4'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v1 | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v2 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, xml, ctype, iconv, pgsql | ||||
|           extensions: mbstring, xml, ctype, iconv, intl, pdo_sqlite, pgsql | ||||
|           coverage: xdebug #optional | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: | | ||||
|           composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|           composer require --dev symfony/orm-pack symfony/phpunit-bridge | ||||
|           composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|           php bin/phpunit install | ||||
|       - name: Run Migration | ||||
|         run: | | ||||
|           composer require symfony/orm-pack | ||||
|           php bin/console doctrine:schema:update --force || echo "No migrations found or schema update failed" | ||||
|           php bin/console doctrine:migrations:migrate || echo "No migrations found or migration failed" | ||||
|         env: | ||||
|           DATABASE_URL: postgres://postgres:postgres@127.0.0.1:${{ job.services.postgres.ports[5432] }}/postgres?charset=UTF-8 | ||||
|       - name: Run Tests | ||||
|         run: | | ||||
|           composer require phpunit | ||||
|           php bin/phpunit --coverage-text | ||||
|         run: php bin/phpunit --coverage-text | ||||
| @ -7,24 +7,33 @@ jobs: | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 3 | ||||
|       matrix: | ||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] | ||||
|         php-versions: ['7.3'] | ||||
|         operating-system: [ubuntu-latest, windows-latest, macos-latest] | ||||
|         php-versions: ['7.3', '7.4'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v1 | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v2 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, xml, ctype, iconv | ||||
|           extensions: mbstring, xml, ctype, iconv, intl, pdo_sqlite | ||||
|           coverage: xdebug #optional | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: | | ||||
|           composer require symfony/orm-pack | ||||
|           composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|           composer require --dev symfony/phpunit-bridge | ||||
|           composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|           php bin/phpunit install | ||||
|       - name: Run Tests | ||||
|         run: | | ||||
|           composer require phpunit | ||||
|           php bin/phpunit --coverage-text | ||||
|         run: php bin/phpunit --coverage-text | ||||
| @ -19,28 +19,40 @@ jobs: | ||||
|           MYSQL_ROOT_PASSWORD: yii | ||||
|           MYSQL_DATABASE: yii | ||||
|         ports: | ||||
|           - 3306 | ||||
|           - 3306/tcp | ||||
|         options: --health-cmd="mysqladmin ping" --health-interval=10s --health-timeout=5s --health-retries=3 | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 3 | ||||
|       matrix: | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v1 | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Set Node.js 10.x | ||||
|         uses: actions/setup-node@master | ||||
|         uses: actions/setup-node@v1 | ||||
|         with: | ||||
|           node-version: 10.x | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, intl, gd, imagick, zip, dom, mysql | ||||
|           extensions: mbstring, intl, gd, imagick, zip, dom, mysql | ||||
|           coverage: xdebug #optional | ||||
|       - name: Start mysql service | ||||
|         run: sudo /etc/init.d/mysql start | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Prepare the application | ||||
|         run: | | ||||
|           php -r "file_exists('.env') || copy('.env.dist', '.env');" | ||||
|  | ||||
| @ -23,24 +23,34 @@ jobs: | ||||
|         options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 3 | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       max-parallel: 3 | ||||
|       matrix: | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v1 | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Set Node.js 10.x | ||||
|         uses: actions/setup-node@master | ||||
|         uses: actions/setup-node@v1 | ||||
|         with: | ||||
|           node-version: 10.x | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, intl, gd, imagick, zip, dom, pgsql | ||||
|           extensions: mbstring, intl, gd, imagick, zip, dom, pgsql | ||||
|           coverage: xdebug #optional | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install Composer dependencies | ||||
|         run: composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|         run: composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|       - name: Prepare the application | ||||
|         run: | | ||||
|           php -r "file_exists('.env') || copy('.env.dist', '.env');" | ||||
|  | ||||
| @ -4,23 +4,33 @@ on: [push, pull_request] | ||||
| jobs: | ||||
|   build: | ||||
|     strategy: | ||||
|       max-parallel: 6 | ||||
|       matrix: | ||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] | ||||
|         php-versions: ['7.2', '7.3'] | ||||
|         operating-system: [ubuntu-latest, windows-latest, macos-latest] | ||||
|         php-versions: ['7.2', '7.3', '7.4'] | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@master | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Setup PHP, with composer and extensions | ||||
|         uses: shivammathur/setup-php@master #https://github.com/shivammathur/setup-php | ||||
|         uses: shivammathur/setup-php@v1 #https://github.com/shivammathur/setup-php | ||||
|         with: | ||||
|           php-version: ${{ matrix.php-versions }} | ||||
|           extension-csv: mbstring, bcmath, curl, intl | ||||
|           extensions: mbstring, bcmath, curl, intl | ||||
|           coverage: xdebug #optional | ||||
|       - name: Get composer cache directory | ||||
|         id: composer-cache | ||||
|         run: echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
|       - name: Cache composer dependencies | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           path: ${{ steps.composer-cache.outputs.dir }} | ||||
|           # Use composer.json for key, if composer.lock is not committed. | ||||
|           # key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} | ||||
|           key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
|           restore-keys: ${{ runner.os }}-composer- | ||||
|       - name: Install dependencies | ||||
|         run: | | ||||
|           composer install --no-progress --no-suggest --prefer-dist --optimize-autoloader | ||||
|           composer install --no-progress --prefer-dist --optimize-autoloader | ||||
|           composer require --dev phpunit/phpunit squizlabs/php_codesniffer zendframework/zend-test | ||||
|       - name: Test with phpunit | ||||
|         run: vendor/bin/phpunit --coverage-text | ||||
| @ -9,4 +9,4 @@ module.exports = { | ||||
|   }, | ||||
|   verbose: true, | ||||
|   collectCoverage: true | ||||
| }; | ||||
| }; | ||||
|  | ||||
| @ -1,93 +0,0 @@ | ||||
| "use strict"; | ||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||
|     return new (P || (P = Promise))(function (resolve, reject) { | ||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||
|     }); | ||||
| }; | ||||
| var __importStar = (this && this.__importStar) || function (mod) { | ||||
|     if (mod && mod.__esModule) return mod; | ||||
|     var result = {}; | ||||
|     if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||||
|     result["default"] = mod; | ||||
|     return result; | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const utils = __importStar(require("./utils")); | ||||
| /** | ||||
|  * Function to add custom ini values | ||||
|  * | ||||
|  * @param ini_values_csv | ||||
|  * @param os_version | ||||
|  */ | ||||
| function addINIValues(ini_values_csv, os_version, no_step = false) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         let script = '\n'; | ||||
|         switch (no_step) { | ||||
|             case true: | ||||
|                 script += | ||||
|                     (yield utils.stepLog('Add php.ini values', os_version)) + | ||||
|                         (yield utils.suppressOutput(os_version)) + | ||||
|                         '\n'; | ||||
|                 break; | ||||
|             case false: | ||||
|             default: | ||||
|                 script += (yield utils.stepLog('Add php.ini values', os_version)) + '\n'; | ||||
|                 break; | ||||
|         } | ||||
|         switch (os_version) { | ||||
|             case 'win32': | ||||
|                 return script + (yield addINIValuesWindows(ini_values_csv)); | ||||
|             case 'darwin': | ||||
|             case 'linux': | ||||
|                 return script + (yield addINIValuesUnix(ini_values_csv)); | ||||
|             default: | ||||
|                 return yield utils.log('Platform ' + os_version + ' is not supported', os_version, 'error'); | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.addINIValues = addINIValues; | ||||
| /** | ||||
|  * Add script to set custom ini values for unix | ||||
|  * | ||||
|  * @param ini_values_csv | ||||
|  */ | ||||
| function addINIValuesUnix(ini_values_csv) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         let ini_values = yield utils.INIArray(ini_values_csv); | ||||
|         let script = '\n'; | ||||
|         yield utils.asyncForEach(ini_values, function (line) { | ||||
|             return __awaiter(this, void 0, void 0, function* () { | ||||
|                 script += | ||||
|                     (yield utils.addLog('$tick', line, 'Added to php.ini', 'linux')) + '\n'; | ||||
|             }); | ||||
|         }); | ||||
|         return 'echo "' + ini_values.join('\n') + '" >> $ini_file' + script; | ||||
|     }); | ||||
| } | ||||
| exports.addINIValuesUnix = addINIValuesUnix; | ||||
| /** | ||||
|  * Add script to set custom ini values for windows | ||||
|  * | ||||
|  * @param ini_values_csv | ||||
|  */ | ||||
| function addINIValuesWindows(ini_values_csv) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         let ini_values = yield utils.INIArray(ini_values_csv); | ||||
|         let script = '\n'; | ||||
|         yield utils.asyncForEach(ini_values, function (line) { | ||||
|             return __awaiter(this, void 0, void 0, function* () { | ||||
|                 script += | ||||
|                     (yield utils.addLog('$tick', line, 'Added to php.ini', 'win32')) + '\n'; | ||||
|             }); | ||||
|         }); | ||||
|         return ('Add-Content C:\\tools\\php\\php.ini "' + | ||||
|             ini_values.join('\n') + | ||||
|             '"' + | ||||
|             script); | ||||
|     }); | ||||
| } | ||||
| exports.addINIValuesWindows = addINIValuesWindows; | ||||
							
								
								
									
										151
									
								
								lib/coverage.js
									
									
									
									
									
								
							
							
						
						
									
										151
									
								
								lib/coverage.js
									
									
									
									
									
								
							| @ -1,151 +0,0 @@ | ||||
| "use strict"; | ||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||
|     return new (P || (P = Promise))(function (resolve, reject) { | ||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||
|     }); | ||||
| }; | ||||
| var __importStar = (this && this.__importStar) || function (mod) { | ||||
|     if (mod && mod.__esModule) return mod; | ||||
|     var result = {}; | ||||
|     if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||||
|     result["default"] = mod; | ||||
|     return result; | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const utils = __importStar(require("./utils")); | ||||
| const extensions = __importStar(require("./extensions")); | ||||
| const config = __importStar(require("./config")); | ||||
| /** | ||||
|  * Function to set coverage driver | ||||
|  * | ||||
|  * @param coverage_driver | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  */ | ||||
| function addCoverage(coverage_driver, version, os_version) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         coverage_driver.toLowerCase(); | ||||
|         let script = '\n' + (yield utils.stepLog('Setup Coverage', os_version)); | ||||
|         switch (coverage_driver) { | ||||
|             case 'pcov': | ||||
|                 return script + (yield addCoveragePCOV(version, os_version)); | ||||
|             case 'xdebug': | ||||
|                 return script + (yield addCoverageXdebug(version, os_version)); | ||||
|             case 'none': | ||||
|                 return script + (yield disableCoverage(version, os_version)); | ||||
|             default: | ||||
|                 return ''; | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.addCoverage = addCoverage; | ||||
| /** | ||||
|  * Function to setup Xdebug | ||||
|  * | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  */ | ||||
| function addCoverageXdebug(version, os_version) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         return ((yield extensions.addExtension('xdebug', version, os_version, true)) + | ||||
|             (yield utils.suppressOutput(os_version)) + | ||||
|             '\n' + | ||||
|             (yield utils.addLog('$tick', 'xdebug', 'Xdebug enabled as coverage driver', os_version))); | ||||
|     }); | ||||
| } | ||||
| exports.addCoverageXdebug = addCoverageXdebug; | ||||
| /** | ||||
|  * Function to setup PCOV | ||||
|  * | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  */ | ||||
| function addCoveragePCOV(version, os_version) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         let script = '\n'; | ||||
|         switch (version) { | ||||
|             default: | ||||
|                 script += | ||||
|                     (yield extensions.addExtension('pcov', version, os_version, true)) + | ||||
|                         (yield utils.suppressOutput(os_version)) + | ||||
|                         '\n'; | ||||
|                 script += | ||||
|                     (yield config.addINIValues('pcov.enabled=1', os_version, true)) + '\n'; | ||||
|                 // add command to disable xdebug and enable pcov | ||||
|                 switch (os_version) { | ||||
|                     case 'linux': | ||||
|                         script += | ||||
|                             'if [ -e /etc/php/' + | ||||
|                                 version + | ||||
|                                 '/mods-available/xdebug.ini ]; then sudo phpdismod -v ' + | ||||
|                                 version + | ||||
|                                 ' xdebug; fi\n'; | ||||
|                         script += 'sudo sed -i "/xdebug/d" $ini_file\n'; | ||||
|                         break; | ||||
|                     case 'darwin': | ||||
|                         script += 'sudo sed -i \'\' "/xdebug/d" $ini_file\n'; | ||||
|                         break; | ||||
|                     case 'win32': | ||||
|                         script += | ||||
|                             'if(php -m | findstr -i xdebug) { Disable-PhpExtension xdebug C:\\tools\\php }\n'; | ||||
|                         break; | ||||
|                 } | ||||
|                 // success | ||||
|                 script += yield utils.addLog('$tick', 'coverage: pcov', 'PCOV enabled as coverage driver', os_version); | ||||
|                 // version is not supported | ||||
|                 break; | ||||
|             case '5.6': | ||||
|             case '7.0': | ||||
|                 script += yield utils.addLog('$cross', 'pcov', 'PHP 7.1 or newer is required', os_version); | ||||
|                 break; | ||||
|         } | ||||
|         return script; | ||||
|     }); | ||||
| } | ||||
| exports.addCoveragePCOV = addCoveragePCOV; | ||||
| /** | ||||
|  * Function to disable Xdebug and PCOV | ||||
|  * | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  */ | ||||
| function disableCoverage(version, os_version) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         let script = '\n'; | ||||
|         switch (os_version) { | ||||
|             case 'linux': | ||||
|                 script += | ||||
|                     'if [ -e /etc/php/' + | ||||
|                         version + | ||||
|                         '/mods-available/xdebug.ini ]; then sudo phpdismod -v ' + | ||||
|                         version + | ||||
|                         ' xdebug; fi\n'; | ||||
|                 script += | ||||
|                     'if [ -e /etc/php/' + | ||||
|                         version + | ||||
|                         '/mods-available/pcov.ini ]; then sudo phpdismod -v ' + | ||||
|                         version + | ||||
|                         ' pcov; fi\n'; | ||||
|                 script += 'sudo sed -i "/xdebug/d" $ini_file\n'; | ||||
|                 script += 'sudo sed -i "/pcov/d" $ini_file\n'; | ||||
|                 break; | ||||
|             case 'darwin': | ||||
|                 script += 'sudo sed -i \'\' "/xdebug/d" $ini_file\n'; | ||||
|                 script += 'sudo sed -i \'\' "/pcov/d" $ini_file\n'; | ||||
|                 break; | ||||
|             case 'win32': | ||||
|                 script += | ||||
|                     'if(php -m | findstr -i xdebug) { Disable-PhpExtension xdebug C:\\tools\\php }\n'; | ||||
|                 script += | ||||
|                     'if(php -m | findstr -i pcov) { Disable-PhpExtension pcov C:\\tools\\php }\n'; | ||||
|                 break; | ||||
|         } | ||||
|         script += yield utils.addLog('$tick', 'none', 'Disabled Xdebug and PCOV', os_version); | ||||
|         return script; | ||||
|     }); | ||||
| } | ||||
| exports.disableCoverage = disableCoverage; | ||||
| @ -1,192 +0,0 @@ | ||||
| "use strict"; | ||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||
|     return new (P || (P = Promise))(function (resolve, reject) { | ||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||
|     }); | ||||
| }; | ||||
| var __importStar = (this && this.__importStar) || function (mod) { | ||||
|     if (mod && mod.__esModule) return mod; | ||||
|     var result = {}; | ||||
|     if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||||
|     result["default"] = mod; | ||||
|     return result; | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const path = __importStar(require("path")); | ||||
| const utils = __importStar(require("./utils")); | ||||
| /** | ||||
|  * Install and enable extensions | ||||
|  * | ||||
|  * @param extension_csv | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  * @param log_prefix | ||||
|  */ | ||||
| function addExtension(extension_csv, version, os_version, no_step = false) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         let script = '\n'; | ||||
|         switch (no_step) { | ||||
|             case true: | ||||
|                 script += | ||||
|                     (yield utils.stepLog('Setup Extensions', os_version)) + | ||||
|                         (yield utils.suppressOutput(os_version)); | ||||
|                 break; | ||||
|             case false: | ||||
|             default: | ||||
|                 script += yield utils.stepLog('Setup Extensions', os_version); | ||||
|                 break; | ||||
|         } | ||||
|         switch (os_version) { | ||||
|             case 'win32': | ||||
|                 return script + (yield addExtensionWindows(extension_csv, version)); | ||||
|             case 'darwin': | ||||
|                 return script + (yield addExtensionDarwin(extension_csv, version)); | ||||
|             case 'linux': | ||||
|                 return script + (yield addExtensionLinux(extension_csv, version)); | ||||
|             default: | ||||
|                 return yield utils.log('Platform ' + os_version + ' is not supported', os_version, 'error'); | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.addExtension = addExtension; | ||||
| /** | ||||
|  * Install and enable extensions for darwin | ||||
|  * | ||||
|  * @param extension_csv | ||||
|  * @param version | ||||
|  */ | ||||
| function addExtensionDarwin(extension_csv, version) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         let extensions = yield utils.extensionArray(extension_csv); | ||||
|         let script = '\n'; | ||||
|         yield utils.asyncForEach(extensions, function (extension) { | ||||
|             return __awaiter(this, void 0, void 0, function* () { | ||||
|                 extension = extension.toLowerCase(); | ||||
|                 // add script to enable extension is already installed along with php | ||||
|                 let install_command = ''; | ||||
|                 switch (version + extension) { | ||||
|                     case '5.6xdebug': | ||||
|                         install_command = 'sudo pecl install xdebug-2.5.5 >/dev/null 2>&1'; | ||||
|                         break; | ||||
|                     default: | ||||
|                         install_command = 'sudo pecl install ' + extension + ' >/dev/null 2>&1'; | ||||
|                         break; | ||||
|                 } | ||||
|                 script += | ||||
|                     '\nadd_extension ' + | ||||
|                         extension + | ||||
|                         ' "' + | ||||
|                         install_command + | ||||
|                         '" ' + | ||||
|                         (yield utils.getExtensionPrefix(extension)); | ||||
|             }); | ||||
|         }); | ||||
|         return script; | ||||
|     }); | ||||
| } | ||||
| exports.addExtensionDarwin = addExtensionDarwin; | ||||
| /** | ||||
|  * Install and enable extensions for windows | ||||
|  * | ||||
|  * @param extension_csv | ||||
|  * @param version | ||||
|  */ | ||||
| function addExtensionWindows(extension_csv, version) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         let extensions = yield utils.extensionArray(extension_csv); | ||||
|         let script = '\n'; | ||||
|         yield utils.asyncForEach(extensions, function (extension) { | ||||
|             return __awaiter(this, void 0, void 0, function* () { | ||||
|                 extension = extension.toLowerCase(); | ||||
|                 // add script to enable extension is already installed along with php | ||||
|                 let install_command = ''; | ||||
|                 switch (version + extension) { | ||||
|                     case '7.4xdebug': | ||||
|                         const extension_url = 'https://xdebug.org/files/php_xdebug-2.8.0-7.4-vc15.dll'; | ||||
|                         install_command = | ||||
|                             'Invoke-WebRequest -Uri ' + | ||||
|                                 extension_url + | ||||
|                                 ' -OutFile C:\\tools\\php\\ext\\php_xdebug.dll\n'; | ||||
|                         install_command += 'Enable-PhpExtension xdebug'; | ||||
|                         break; | ||||
|                     case '7.2xdebug': | ||||
|                     default: | ||||
|                         install_command = 'Install-PhpExtension ' + extension; | ||||
|                         break; | ||||
|                 } | ||||
|                 script += | ||||
|                     '\nAdd-Extension ' + | ||||
|                         extension + | ||||
|                         ' "' + | ||||
|                         install_command + | ||||
|                         '" ' + | ||||
|                         (yield utils.getExtensionPrefix(extension)); | ||||
|             }); | ||||
|         }); | ||||
|         return script; | ||||
|     }); | ||||
| } | ||||
| exports.addExtensionWindows = addExtensionWindows; | ||||
| /** | ||||
|  * Install and enable extensions for linux | ||||
|  * | ||||
|  * @param extension_csv | ||||
|  * @param version | ||||
|  */ | ||||
| function addExtensionLinux(extension_csv, version) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         let extensions = yield utils.extensionArray(extension_csv); | ||||
|         let script = '\n'; | ||||
|         yield utils.asyncForEach(extensions, function (extension) { | ||||
|             return __awaiter(this, void 0, void 0, function* () { | ||||
|                 extension = extension.toLowerCase(); | ||||
|                 // add script to enable extension is already installed along with php | ||||
|                 let install_command = ''; | ||||
|                 switch (version + extension) { | ||||
|                     case '7.2phalcon3': | ||||
|                     case '7.3phalcon3': | ||||
|                         install_command = | ||||
|                             'sh ' + | ||||
|                                 path.join(__dirname, '../src/scripts/phalcon.sh') + | ||||
|                                 ' master ' + | ||||
|                                 version + | ||||
|                                 ' >/dev/null 2>&1'; | ||||
|                         break; | ||||
|                     case '7.2phalcon4': | ||||
|                     case '7.3phalcon4': | ||||
|                     case '7.4phalcon4': | ||||
|                         install_command = | ||||
|                             'sh ' + | ||||
|                                 path.join(__dirname, '../src/scripts/phalcon.sh') + | ||||
|                                 ' 4.0.x ' + | ||||
|                                 version + | ||||
|                                 ' >/dev/null 2>&1'; | ||||
|                         break; | ||||
|                     default: | ||||
|                         install_command = | ||||
|                             'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y php' + | ||||
|                                 version + | ||||
|                                 '-' + | ||||
|                                 extension.replace('pdo_', '').replace('pdo-', '') + | ||||
|                                 ' >/dev/null 2>&1 || sudo pecl install ' + | ||||
|                                 extension + | ||||
|                                 ' >/dev/null 2>&1'; | ||||
|                         break; | ||||
|                 } | ||||
|                 script += | ||||
|                     '\nadd_extension ' + | ||||
|                         extension + | ||||
|                         ' "' + | ||||
|                         install_command + | ||||
|                         '" ' + | ||||
|                         (yield utils.getExtensionPrefix(extension)); | ||||
|             }); | ||||
|         }); | ||||
|         return script; | ||||
|     }); | ||||
| } | ||||
| exports.addExtensionLinux = addExtensionLinux; | ||||
| @ -1,85 +0,0 @@ | ||||
| "use strict"; | ||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||
|     return new (P || (P = Promise))(function (resolve, reject) { | ||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||
|     }); | ||||
| }; | ||||
| var __importStar = (this && this.__importStar) || function (mod) { | ||||
|     if (mod && mod.__esModule) return mod; | ||||
|     var result = {}; | ||||
|     if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||||
|     result["default"] = mod; | ||||
|     return result; | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const exec_1 = require("@actions/exec/lib/exec"); | ||||
| const core = __importStar(require("@actions/core")); | ||||
| const config = __importStar(require("./config")); | ||||
| const coverage = __importStar(require("./coverage")); | ||||
| const extensions = __importStar(require("./extensions")); | ||||
| const utils = __importStar(require("./utils")); | ||||
| /** | ||||
|  * Build the script | ||||
|  * | ||||
|  * @param filename | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  */ | ||||
| function build(filename, version, os_version) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         // taking inputs | ||||
|         let extension_csv = yield utils.getInput('extension-csv', false); | ||||
|         let ini_values_csv = yield utils.getInput('ini-values-csv', false); | ||||
|         let coverage_driver = yield utils.getInput('coverage', false); | ||||
|         let script = yield utils.readScript(filename, version, os_version); | ||||
|         if (extension_csv) { | ||||
|             script += yield extensions.addExtension(extension_csv, version, os_version); | ||||
|         } | ||||
|         if (ini_values_csv) { | ||||
|             script += yield config.addINIValues(ini_values_csv, os_version); | ||||
|         } | ||||
|         if (coverage_driver) { | ||||
|             script += yield coverage.addCoverage(coverage_driver, version, os_version); | ||||
|         } | ||||
|         return yield utils.writeScript(filename, script); | ||||
|     }); | ||||
| } | ||||
| exports.build = build; | ||||
| /** | ||||
|  * Run the script | ||||
|  */ | ||||
| function run() { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         try { | ||||
|             let os_version = process.platform; | ||||
|             let version = yield utils.getInput('php-version', true); | ||||
|             // check the os version and run the respective script | ||||
|             let script_path = ''; | ||||
|             switch (os_version) { | ||||
|                 case 'darwin': | ||||
|                     script_path = yield build(os_version + '.sh', version, os_version); | ||||
|                     yield exec_1.exec('sh ' + script_path + ' ' + version + ' ' + __dirname); | ||||
|                     break; | ||||
|                 case 'linux': | ||||
|                     let pecl = yield utils.getInput('pecl', false); | ||||
|                     script_path = yield build(os_version + '.sh', version, os_version); | ||||
|                     yield exec_1.exec('sh ' + script_path + ' ' + version + ' ' + pecl); | ||||
|                     break; | ||||
|                 case 'win32': | ||||
|                     script_path = yield build('win32.ps1', version, os_version); | ||||
|                     yield exec_1.exec('pwsh ' + script_path + ' -version ' + version + ' -dir ' + __dirname); | ||||
|                     break; | ||||
|             } | ||||
|         } | ||||
|         catch (error) { | ||||
|             core.setFailed(error.message); | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.run = run; | ||||
| // call the run function | ||||
| run(); | ||||
							
								
								
									
										35
									
								
								lib/pecl.js
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								lib/pecl.js
									
									
									
									
									
								
							| @ -1,35 +0,0 @@ | ||||
| "use strict"; | ||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||
|     return new (P || (P = Promise))(function (resolve, reject) { | ||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||
|     }); | ||||
| }; | ||||
| var __importStar = (this && this.__importStar) || function (mod) { | ||||
|     if (mod && mod.__esModule) return mod; | ||||
|     var result = {}; | ||||
|     if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||||
|     result["default"] = mod; | ||||
|     return result; | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const hc = __importStar(require("typed-rest-client/HttpClient")); | ||||
| /** | ||||
|  * Function to check if PECL extension exists | ||||
|  * | ||||
|  * @param extension | ||||
|  */ | ||||
| function checkPECLExtension(extension) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         const http = new hc.HttpClient('shivammathur/php-setup', [], { | ||||
|             allowRetries: true, | ||||
|             maxRetries: 2 | ||||
|         }); | ||||
|         const response = yield http.get('https://pecl.php.net/json.php?package=' + extension); | ||||
|         return response.message.statusCode === 200; | ||||
|     }); | ||||
| } | ||||
| exports.checkPECLExtension = checkPECLExtension; | ||||
							
								
								
									
										242
									
								
								lib/utils.js
									
									
									
									
									
								
							
							
						
						
									
										242
									
								
								lib/utils.js
									
									
									
									
									
								
							| @ -1,242 +0,0 @@ | ||||
| "use strict"; | ||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||
|     return new (P || (P = Promise))(function (resolve, reject) { | ||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||
|     }); | ||||
| }; | ||||
| var __importStar = (this && this.__importStar) || function (mod) { | ||||
|     if (mod && mod.__esModule) return mod; | ||||
|     var result = {}; | ||||
|     if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||||
|     result["default"] = mod; | ||||
|     return result; | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const fs = __importStar(require("fs")); | ||||
| const path = __importStar(require("path")); | ||||
| const core = __importStar(require("@actions/core")); | ||||
| /** | ||||
|  * Function to get inputs from both with and env annotations. | ||||
|  * | ||||
|  * @param name | ||||
|  * @param mandatory | ||||
|  */ | ||||
| function getInput(name, mandatory) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         let input = process.env[name]; | ||||
|         switch (input) { | ||||
|             case '': | ||||
|             case undefined: | ||||
|                 return core.getInput(name, { required: mandatory }); | ||||
|             default: | ||||
|                 return input; | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.getInput = getInput; | ||||
| /** | ||||
|  * Async foreach loop | ||||
|  * | ||||
|  * @author https://github.com/Atinux | ||||
|  * @param array | ||||
|  * @param callback | ||||
|  */ | ||||
| function asyncForEach(array, callback) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         for (let index = 0; index < array.length; index++) { | ||||
|             yield callback(array[index], index, array); | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.asyncForEach = asyncForEach; | ||||
| /** | ||||
|  * Read the scripts | ||||
|  * | ||||
|  * @param filename | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  */ | ||||
| function readScript(filename, version, os_version) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         switch (os_version) { | ||||
|             case 'darwin': | ||||
|                 switch (version) { | ||||
|                     case '7.4': | ||||
|                         return fs.readFileSync(path.join(__dirname, '../src/scripts/7.4.sh'), 'utf8'); | ||||
|                 } | ||||
|                 return fs.readFileSync(path.join(__dirname, '../src/scripts/' + filename), 'utf8'); | ||||
|             case 'linux': | ||||
|             case 'win32': | ||||
|                 return fs.readFileSync(path.join(__dirname, '../src/scripts/' + filename), 'utf8'); | ||||
|             default: | ||||
|                 return yield log('Platform ' + os_version + ' is not supported', os_version, 'error'); | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.readScript = readScript; | ||||
| /** | ||||
|  * Write final script which runs | ||||
|  * | ||||
|  * @param filename | ||||
|  * @param version | ||||
|  * @param script | ||||
|  */ | ||||
| function writeScript(filename, script) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         let runner_dir = yield getInput('RUNNER_TOOL_CACHE', false); | ||||
|         let script_path = path.join(runner_dir, filename); | ||||
|         fs.writeFileSync(script_path, script, { mode: 0o755 }); | ||||
|         return script_path; | ||||
|     }); | ||||
| } | ||||
| exports.writeScript = writeScript; | ||||
| /** | ||||
|  * Function to break extension csv into an array | ||||
|  * | ||||
|  * @param extension_csv | ||||
|  */ | ||||
| function extensionArray(extension_csv) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         switch (extension_csv) { | ||||
|             case '': | ||||
|             case ' ': | ||||
|                 return []; | ||||
|             default: | ||||
|                 return extension_csv.split(',').map(function (extension) { | ||||
|                     return extension | ||||
|                         .trim() | ||||
|                         .replace('php-', '') | ||||
|                         .replace('php_', ''); | ||||
|                 }); | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.extensionArray = extensionArray; | ||||
| /** | ||||
|  * Function to break ini values csv into an array | ||||
|  * | ||||
|  * @param ini_values_csv | ||||
|  * @constructor | ||||
|  */ | ||||
| function INIArray(ini_values_csv) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         switch (ini_values_csv) { | ||||
|             case '': | ||||
|             case ' ': | ||||
|                 return []; | ||||
|             default: | ||||
|                 return ini_values_csv.split(',').map(function (ini_value) { | ||||
|                     return ini_value.trim(); | ||||
|                 }); | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.INIArray = INIArray; | ||||
| /** | ||||
|  * Function to log a step | ||||
|  * | ||||
|  * @param message | ||||
|  * @param os_version | ||||
|  */ | ||||
| function stepLog(message, os_version) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         switch (os_version) { | ||||
|             case 'win32': | ||||
|                 return 'Step-Log "' + message + '"'; | ||||
|             case 'linux': | ||||
|             case 'darwin': | ||||
|                 return 'step_log "' + message + '"'; | ||||
|             default: | ||||
|                 return yield log('Platform ' + os_version + ' is not supported', os_version, 'error'); | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.stepLog = stepLog; | ||||
| /** | ||||
|  * Function to log a result | ||||
|  * @param mark | ||||
|  * @param subject | ||||
|  * @param message | ||||
|  */ | ||||
| function addLog(mark, subject, message, os_version) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         switch (os_version) { | ||||
|             case 'win32': | ||||
|                 return 'Add-Log "' + mark + '" "' + subject + '" "' + message + '"'; | ||||
|             case 'linux': | ||||
|             case 'darwin': | ||||
|                 return 'add_log "' + mark + '" "' + subject + '" "' + message + '"'; | ||||
|             default: | ||||
|                 return yield log('Platform ' + os_version + ' is not supported', os_version, 'error'); | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.addLog = addLog; | ||||
| /** | ||||
|  * Log to console | ||||
|  * | ||||
|  * @param message | ||||
|  * @param os_version | ||||
|  * @param log_type | ||||
|  * @param prefix | ||||
|  */ | ||||
| function log(message, os_version, log_type) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         const color = { | ||||
|             error: '31', | ||||
|             success: '32', | ||||
|             warning: '33' | ||||
|         }; | ||||
|         switch (os_version) { | ||||
|             case 'win32': | ||||
|                 return ('printf "\\033[' + color[log_type] + ';1m' + message + ' \\033[0m"'); | ||||
|             case 'linux': | ||||
|             case 'darwin': | ||||
|             default: | ||||
|                 return 'echo "\\033[' + color[log_type] + ';1m' + message + '\\033[0m"'; | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.log = log; | ||||
| /** | ||||
|  * Function to get prefix required to load an extension. | ||||
|  * | ||||
|  * @param extension | ||||
|  */ | ||||
| function getExtensionPrefix(extension) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         let zend = ['xdebug', 'opcache', 'ioncube', 'eaccelerator']; | ||||
|         switch (zend.indexOf(extension)) { | ||||
|             case 0: | ||||
|             case 1: | ||||
|                 return 'zend_extension'; | ||||
|             case -1: | ||||
|             default: | ||||
|                 return 'extension'; | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.getExtensionPrefix = getExtensionPrefix; | ||||
| /** | ||||
|  * Function to get the suffix to suppress console output | ||||
|  * | ||||
|  * @param os_version | ||||
|  */ | ||||
| function suppressOutput(os_version) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         switch (os_version) { | ||||
|             case 'win32': | ||||
|                 return ' >$null 2>&1'; | ||||
|             case 'linux': | ||||
|             case 'darwin': | ||||
|                 return ' >/dev/null 2>&1'; | ||||
|             default: | ||||
|                 return yield log('Platform ' + os_version + ' is not supported', os_version, 'error'); | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.suppressOutput = suppressOutput; | ||||
							
								
								
									
										140
									
								
								node_modules/@actions/core/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										140
									
								
								node_modules/@actions/core/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,140 +0,0 @@ | ||||
| # `@actions/core` | ||||
|  | ||||
| > Core functions for setting results, logging, registering secrets and exporting variables across actions | ||||
|  | ||||
| ## Usage | ||||
|  | ||||
| ### Import the package | ||||
|  | ||||
| ```js | ||||
| // javascript | ||||
| const core = require('@actions/core'); | ||||
|  | ||||
| // typescript | ||||
| import * as core from '@actions/core'; | ||||
| ``` | ||||
|  | ||||
| #### Inputs/Outputs | ||||
|  | ||||
| Action inputs can be read with `getInput`.  Outputs can be set with `setOutput` which makes them available to be mapped into inputs of other actions to ensure they are decoupled. | ||||
|  | ||||
| ```js | ||||
| const myInput = core.getInput('inputName', { required: true }); | ||||
|  | ||||
| core.setOutput('outputKey', 'outputVal'); | ||||
| ``` | ||||
|  | ||||
| #### Exporting variables | ||||
|  | ||||
| Since each step runs in a separate process, you can use `exportVariable` to add it to this step and future steps environment blocks. | ||||
|  | ||||
| ```js | ||||
| core.exportVariable('envVar', 'Val'); | ||||
| ``` | ||||
|  | ||||
| #### Setting a secret | ||||
|  | ||||
| Setting a secret registers the secret with the runner to ensure it is masked in logs. | ||||
|  | ||||
| ```js | ||||
| core.setSecret('myPassword'); | ||||
| ``` | ||||
|  | ||||
| #### PATH Manipulation | ||||
|  | ||||
| To make a tool's path available in the path for the remainder of the job (without altering the machine or containers state), use `addPath`.  The runner will prepend the path given to the jobs PATH. | ||||
|  | ||||
| ```js | ||||
| core.addPath('/path/to/mytool'); | ||||
| ``` | ||||
|  | ||||
| #### Exit codes | ||||
|  | ||||
| You should use this library to set the failing exit code for your action.  If status is not set and the script runs to completion, that will lead to a success. | ||||
|  | ||||
| ```js | ||||
| const core = require('@actions/core'); | ||||
|  | ||||
| try { | ||||
|   // Do stuff | ||||
| } | ||||
| catch (err) { | ||||
|   // setFailed logs the message and sets a failing exit code | ||||
|   core.setFailed(`Action failed with error ${err}`); | ||||
| } | ||||
|  | ||||
| Note that `setNeutral` is not yet implemented in actions V2 but equivalent functionality is being planned. | ||||
|  | ||||
| ``` | ||||
|  | ||||
| #### Logging | ||||
|  | ||||
| Finally, this library provides some utilities for logging. Note that debug logging is hidden from the logs by default. This behavior can be toggled by enabling the [Step Debug Logs](../../docs/action-debugging.md#step-debug-logs). | ||||
|  | ||||
| ```js | ||||
| const core = require('@actions/core'); | ||||
|  | ||||
| const myInput = core.getInput('input'); | ||||
| try { | ||||
|   core.debug('Inside try block'); | ||||
|    | ||||
|   if (!myInput) { | ||||
|     core.warning('myInput was not set'); | ||||
|   } | ||||
|    | ||||
|   // Do stuff | ||||
| } | ||||
| catch (err) { | ||||
|   core.error(`Error ${err}, action may still succeed though`); | ||||
| } | ||||
| ``` | ||||
|  | ||||
| This library can also wrap chunks of output in foldable groups. | ||||
|  | ||||
| ```js | ||||
| const core = require('@actions/core') | ||||
|  | ||||
| // Manually wrap output | ||||
| core.startGroup('Do some function') | ||||
| doSomeFunction() | ||||
| core.endGroup() | ||||
|  | ||||
| // Wrap an asynchronous function call | ||||
| const result = await core.group('Do something async', async () => { | ||||
|   const response = await doSomeHTTPRequest() | ||||
|   return response | ||||
| }) | ||||
| ``` | ||||
|  | ||||
| #### Action state | ||||
|  | ||||
| You can use this library to save state and get state for sharing information between a given wrapper action:  | ||||
|  | ||||
| **action.yml** | ||||
| ```yaml | ||||
| name: 'Wrapper action sample' | ||||
| inputs: | ||||
|   name: | ||||
|     default: 'GitHub' | ||||
| runs: | ||||
|   using: 'node12' | ||||
|   main: 'main.js' | ||||
|   post: 'cleanup.js' | ||||
| ``` | ||||
|  | ||||
| In action's `main.js`: | ||||
|  | ||||
| ```js | ||||
| const core = require('@actions/core'); | ||||
|  | ||||
| core.saveState("pidToKill", 12345); | ||||
| ``` | ||||
|  | ||||
| In action's `cleanup.js`: | ||||
| ```js | ||||
| const core = require('@actions/core'); | ||||
|  | ||||
| var pid = core.getState("pidToKill"); | ||||
|  | ||||
| process.kill(pid); | ||||
| ``` | ||||
							
								
								
									
										16
									
								
								node_modules/@actions/core/lib/command.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								node_modules/@actions/core/lib/command.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,16 +0,0 @@ | ||||
| interface CommandProperties { | ||||
|     [key: string]: string; | ||||
| } | ||||
| /** | ||||
|  * Commands | ||||
|  * | ||||
|  * Command Format: | ||||
|  *   ##[name key=value;key=value]message | ||||
|  * | ||||
|  * Examples: | ||||
|  *   ##[warning]This is the user warning message | ||||
|  *   ##[set-secret name=mypassword]definitelyNotAPassword! | ||||
|  */ | ||||
| export declare function issueCommand(command: string, properties: CommandProperties, message: string): void; | ||||
| export declare function issue(name: string, message?: string): void; | ||||
| export {}; | ||||
							
								
								
									
										66
									
								
								node_modules/@actions/core/lib/command.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										66
									
								
								node_modules/@actions/core/lib/command.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,66 +0,0 @@ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const os = require("os"); | ||||
| /** | ||||
|  * Commands | ||||
|  * | ||||
|  * Command Format: | ||||
|  *   ##[name key=value;key=value]message | ||||
|  * | ||||
|  * Examples: | ||||
|  *   ##[warning]This is the user warning message | ||||
|  *   ##[set-secret name=mypassword]definitelyNotAPassword! | ||||
|  */ | ||||
| function issueCommand(command, properties, message) { | ||||
|     const cmd = new Command(command, properties, message); | ||||
|     process.stdout.write(cmd.toString() + os.EOL); | ||||
| } | ||||
| exports.issueCommand = issueCommand; | ||||
| function issue(name, message = '') { | ||||
|     issueCommand(name, {}, message); | ||||
| } | ||||
| exports.issue = issue; | ||||
| const CMD_STRING = '::'; | ||||
| class Command { | ||||
|     constructor(command, properties, message) { | ||||
|         if (!command) { | ||||
|             command = 'missing.command'; | ||||
|         } | ||||
|         this.command = command; | ||||
|         this.properties = properties; | ||||
|         this.message = message; | ||||
|     } | ||||
|     toString() { | ||||
|         let cmdStr = CMD_STRING + this.command; | ||||
|         if (this.properties && Object.keys(this.properties).length > 0) { | ||||
|             cmdStr += ' '; | ||||
|             for (const key in this.properties) { | ||||
|                 if (this.properties.hasOwnProperty(key)) { | ||||
|                     const val = this.properties[key]; | ||||
|                     if (val) { | ||||
|                         // safely append the val - avoid blowing up when attempting to | ||||
|                         // call .replace() if message is not a string for some reason | ||||
|                         cmdStr += `${key}=${escape(`${val || ''}`)},`; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         cmdStr += CMD_STRING; | ||||
|         // safely append the message - avoid blowing up when attempting to | ||||
|         // call .replace() if message is not a string for some reason | ||||
|         const message = `${this.message || ''}`; | ||||
|         cmdStr += escapeData(message); | ||||
|         return cmdStr; | ||||
|     } | ||||
| } | ||||
| function escapeData(s) { | ||||
|     return s.replace(/\r/g, '%0D').replace(/\n/g, '%0A'); | ||||
| } | ||||
| function escape(s) { | ||||
|     return s | ||||
|         .replace(/\r/g, '%0D') | ||||
|         .replace(/\n/g, '%0A') | ||||
|         .replace(/]/g, '%5D') | ||||
|         .replace(/;/g, '%3B'); | ||||
| } | ||||
| //# sourceMappingURL=command.js.map | ||||
							
								
								
									
										1
									
								
								node_modules/@actions/core/lib/command.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/core/lib/command.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1 +0,0 @@ | ||||
| {"version":3,"file":"command.js","sourceRoot":"","sources":["../src/command.ts"],"names":[],"mappings":";;AAAA,yBAAwB;AAQxB;;;;;;;;;GASG;AACH,SAAgB,YAAY,CAC1B,OAAe,EACf,UAA6B,EAC7B,OAAe;IAEf,MAAM,GAAG,GAAG,IAAI,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,OAAO,CAAC,CAAA;IACrD,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,CAAA;AAC/C,CAAC;AAPD,oCAOC;AAED,SAAgB,KAAK,CAAC,IAAY,EAAE,UAAkB,EAAE;IACtD,YAAY,CAAC,IAAI,EAAE,EAAE,EAAE,OAAO,CAAC,CAAA;AACjC,CAAC;AAFD,sBAEC;AAED,MAAM,UAAU,GAAG,IAAI,CAAA;AAEvB,MAAM,OAAO;IAKX,YAAY,OAAe,EAAE,UAA6B,EAAE,OAAe;QACzE,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO,GAAG,iBAAiB,CAAA;SAC5B;QAED,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;QACtB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;QAC5B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IACxB,CAAC;IAED,QAAQ;QACN,IAAI,MAAM,GAAG,UAAU,GAAG,IAAI,CAAC,OAAO,CAAA;QAEtC,IAAI,IAAI,CAAC,UAAU,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YAC9D,MAAM,IAAI,GAAG,CAAA;YACb,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,UAAU,EAAE;gBACjC,IAAI,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;oBACvC,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;oBAChC,IAAI,GAAG,EAAE;wBACP,8DAA8D;wBAC9D,6DAA6D;wBAC7D,MAAM,IAAI,GAAG,GAAG,IAAI,MAAM,CAAC,GAAG,GAAG,IAAI,EAAE,EAAE,CAAC,GAAG,CAAA;qBAC9C;iBACF;aACF;SACF;QAED,MAAM,IAAI,UAAU,CAAA;QAEpB,kEAAkE;QAClE,6DAA6D;QAC7D,MAAM,OAAO,GAAG,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,EAAE,CAAA;QACvC,MAAM,IAAI,UAAU,CAAC,OAAO,CAAC,CAAA;QAE7B,OAAO,MAAM,CAAA;IACf,CAAC;CACF;AAED,SAAS,UAAU,CAAC,CAAS;IAC3B,OAAO,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAA;AACtD,CAAC;AAED,SAAS,MAAM,CAAC,CAAS;IACvB,OAAO,CAAC;SACL,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC;SACrB,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC;SACrB,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC;SACpB,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;AACzB,CAAC"} | ||||
							
								
								
									
										112
									
								
								node_modules/@actions/core/lib/core.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										112
									
								
								node_modules/@actions/core/lib/core.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,112 +0,0 @@ | ||||
| /** | ||||
|  * Interface for getInput options | ||||
|  */ | ||||
| export interface InputOptions { | ||||
|     /** Optional. Whether the input is required. If required and not present, will throw. Defaults to false */ | ||||
|     required?: boolean; | ||||
| } | ||||
| /** | ||||
|  * The code to exit an action | ||||
|  */ | ||||
| export declare enum ExitCode { | ||||
|     /** | ||||
|      * A code indicating that the action was successful | ||||
|      */ | ||||
|     Success = 0, | ||||
|     /** | ||||
|      * A code indicating that the action was a failure | ||||
|      */ | ||||
|     Failure = 1 | ||||
| } | ||||
| /** | ||||
|  * Sets env variable for this action and future actions in the job | ||||
|  * @param name the name of the variable to set | ||||
|  * @param val the value of the variable | ||||
|  */ | ||||
| export declare function exportVariable(name: string, val: string): void; | ||||
| /** | ||||
|  * Registers a secret which will get masked from logs | ||||
|  * @param secret value of the secret | ||||
|  */ | ||||
| export declare function setSecret(secret: string): void; | ||||
| /** | ||||
|  * Prepends inputPath to the PATH (for this action and future actions) | ||||
|  * @param inputPath | ||||
|  */ | ||||
| export declare function addPath(inputPath: string): void; | ||||
| /** | ||||
|  * Gets the value of an input.  The value is also trimmed. | ||||
|  * | ||||
|  * @param     name     name of the input to get | ||||
|  * @param     options  optional. See InputOptions. | ||||
|  * @returns   string | ||||
|  */ | ||||
| export declare function getInput(name: string, options?: InputOptions): string; | ||||
| /** | ||||
|  * Sets the value of an output. | ||||
|  * | ||||
|  * @param     name     name of the output to set | ||||
|  * @param     value    value to store | ||||
|  */ | ||||
| export declare function setOutput(name: string, value: string): void; | ||||
| /** | ||||
|  * Sets the action status to failed. | ||||
|  * When the action exits it will be with an exit code of 1 | ||||
|  * @param message add error issue message | ||||
|  */ | ||||
| export declare function setFailed(message: string): void; | ||||
| /** | ||||
|  * Writes debug message to user log | ||||
|  * @param message debug message | ||||
|  */ | ||||
| export declare function debug(message: string): void; | ||||
| /** | ||||
|  * Adds an error issue | ||||
|  * @param message error issue message | ||||
|  */ | ||||
| export declare function error(message: string): void; | ||||
| /** | ||||
|  * Adds an warning issue | ||||
|  * @param message warning issue message | ||||
|  */ | ||||
| export declare function warning(message: string): void; | ||||
| /** | ||||
|  * Writes info to log with console.log. | ||||
|  * @param message info message | ||||
|  */ | ||||
| export declare function info(message: string): void; | ||||
| /** | ||||
|  * Begin an output group. | ||||
|  * | ||||
|  * Output until the next `groupEnd` will be foldable in this group | ||||
|  * | ||||
|  * @param name The name of the output group | ||||
|  */ | ||||
| export declare function startGroup(name: string): void; | ||||
| /** | ||||
|  * End an output group. | ||||
|  */ | ||||
| export declare function endGroup(): void; | ||||
| /** | ||||
|  * Wrap an asynchronous function call in a group. | ||||
|  * | ||||
|  * Returns the same type as the function itself. | ||||
|  * | ||||
|  * @param name The name of the group | ||||
|  * @param fn The function to wrap in the group | ||||
|  */ | ||||
| export declare function group<T>(name: string, fn: () => Promise<T>): Promise<T>; | ||||
| /** | ||||
|  * Saves state for current action, the state can only be retrieved by this action's post job execution. | ||||
|  * | ||||
|  * @param     name     name of the state to store | ||||
|  * @param     value    value to store | ||||
|  */ | ||||
| export declare function saveState(name: string, value: string): void; | ||||
| /** | ||||
|  * Gets the value of an state set by this action's main execution. | ||||
|  * | ||||
|  * @param     name     name of the state to get | ||||
|  * @returns   string | ||||
|  */ | ||||
| export declare function getState(name: string): string; | ||||
							
								
								
									
										195
									
								
								node_modules/@actions/core/lib/core.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										195
									
								
								node_modules/@actions/core/lib/core.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,195 +0,0 @@ | ||||
| "use strict"; | ||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||
|     return new (P || (P = Promise))(function (resolve, reject) { | ||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||
|     }); | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const command_1 = require("./command"); | ||||
| const os = require("os"); | ||||
| const path = require("path"); | ||||
| /** | ||||
|  * The code to exit an action | ||||
|  */ | ||||
| var ExitCode; | ||||
| (function (ExitCode) { | ||||
|     /** | ||||
|      * A code indicating that the action was successful | ||||
|      */ | ||||
|     ExitCode[ExitCode["Success"] = 0] = "Success"; | ||||
|     /** | ||||
|      * A code indicating that the action was a failure | ||||
|      */ | ||||
|     ExitCode[ExitCode["Failure"] = 1] = "Failure"; | ||||
| })(ExitCode = exports.ExitCode || (exports.ExitCode = {})); | ||||
| //----------------------------------------------------------------------- | ||||
| // Variables | ||||
| //----------------------------------------------------------------------- | ||||
| /** | ||||
|  * Sets env variable for this action and future actions in the job | ||||
|  * @param name the name of the variable to set | ||||
|  * @param val the value of the variable | ||||
|  */ | ||||
| function exportVariable(name, val) { | ||||
|     process.env[name] = val; | ||||
|     command_1.issueCommand('set-env', { name }, val); | ||||
| } | ||||
| exports.exportVariable = exportVariable; | ||||
| /** | ||||
|  * Registers a secret which will get masked from logs | ||||
|  * @param secret value of the secret | ||||
|  */ | ||||
| function setSecret(secret) { | ||||
|     command_1.issueCommand('add-mask', {}, secret); | ||||
| } | ||||
| exports.setSecret = setSecret; | ||||
| /** | ||||
|  * Prepends inputPath to the PATH (for this action and future actions) | ||||
|  * @param inputPath | ||||
|  */ | ||||
| function addPath(inputPath) { | ||||
|     command_1.issueCommand('add-path', {}, inputPath); | ||||
|     process.env['PATH'] = `${inputPath}${path.delimiter}${process.env['PATH']}`; | ||||
| } | ||||
| exports.addPath = addPath; | ||||
| /** | ||||
|  * Gets the value of an input.  The value is also trimmed. | ||||
|  * | ||||
|  * @param     name     name of the input to get | ||||
|  * @param     options  optional. See InputOptions. | ||||
|  * @returns   string | ||||
|  */ | ||||
| function getInput(name, options) { | ||||
|     const val = process.env[`INPUT_${name.replace(/ /g, '_').toUpperCase()}`] || ''; | ||||
|     if (options && options.required && !val) { | ||||
|         throw new Error(`Input required and not supplied: ${name}`); | ||||
|     } | ||||
|     return val.trim(); | ||||
| } | ||||
| exports.getInput = getInput; | ||||
| /** | ||||
|  * Sets the value of an output. | ||||
|  * | ||||
|  * @param     name     name of the output to set | ||||
|  * @param     value    value to store | ||||
|  */ | ||||
| function setOutput(name, value) { | ||||
|     command_1.issueCommand('set-output', { name }, value); | ||||
| } | ||||
| exports.setOutput = setOutput; | ||||
| //----------------------------------------------------------------------- | ||||
| // Results | ||||
| //----------------------------------------------------------------------- | ||||
| /** | ||||
|  * Sets the action status to failed. | ||||
|  * When the action exits it will be with an exit code of 1 | ||||
|  * @param message add error issue message | ||||
|  */ | ||||
| function setFailed(message) { | ||||
|     process.exitCode = ExitCode.Failure; | ||||
|     error(message); | ||||
| } | ||||
| exports.setFailed = setFailed; | ||||
| //----------------------------------------------------------------------- | ||||
| // Logging Commands | ||||
| //----------------------------------------------------------------------- | ||||
| /** | ||||
|  * Writes debug message to user log | ||||
|  * @param message debug message | ||||
|  */ | ||||
| function debug(message) { | ||||
|     command_1.issueCommand('debug', {}, message); | ||||
| } | ||||
| exports.debug = debug; | ||||
| /** | ||||
|  * Adds an error issue | ||||
|  * @param message error issue message | ||||
|  */ | ||||
| function error(message) { | ||||
|     command_1.issue('error', message); | ||||
| } | ||||
| exports.error = error; | ||||
| /** | ||||
|  * Adds an warning issue | ||||
|  * @param message warning issue message | ||||
|  */ | ||||
| function warning(message) { | ||||
|     command_1.issue('warning', message); | ||||
| } | ||||
| exports.warning = warning; | ||||
| /** | ||||
|  * Writes info to log with console.log. | ||||
|  * @param message info message | ||||
|  */ | ||||
| function info(message) { | ||||
|     process.stdout.write(message + os.EOL); | ||||
| } | ||||
| exports.info = info; | ||||
| /** | ||||
|  * Begin an output group. | ||||
|  * | ||||
|  * Output until the next `groupEnd` will be foldable in this group | ||||
|  * | ||||
|  * @param name The name of the output group | ||||
|  */ | ||||
| function startGroup(name) { | ||||
|     command_1.issue('group', name); | ||||
| } | ||||
| exports.startGroup = startGroup; | ||||
| /** | ||||
|  * End an output group. | ||||
|  */ | ||||
| function endGroup() { | ||||
|     command_1.issue('endgroup'); | ||||
| } | ||||
| exports.endGroup = endGroup; | ||||
| /** | ||||
|  * Wrap an asynchronous function call in a group. | ||||
|  * | ||||
|  * Returns the same type as the function itself. | ||||
|  * | ||||
|  * @param name The name of the group | ||||
|  * @param fn The function to wrap in the group | ||||
|  */ | ||||
| function group(name, fn) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         startGroup(name); | ||||
|         let result; | ||||
|         try { | ||||
|             result = yield fn(); | ||||
|         } | ||||
|         finally { | ||||
|             endGroup(); | ||||
|         } | ||||
|         return result; | ||||
|     }); | ||||
| } | ||||
| exports.group = group; | ||||
| //----------------------------------------------------------------------- | ||||
| // Wrapper action state | ||||
| //----------------------------------------------------------------------- | ||||
| /** | ||||
|  * Saves state for current action, the state can only be retrieved by this action's post job execution. | ||||
|  * | ||||
|  * @param     name     name of the state to store | ||||
|  * @param     value    value to store | ||||
|  */ | ||||
| function saveState(name, value) { | ||||
|     command_1.issueCommand('save-state', { name }, value); | ||||
| } | ||||
| exports.saveState = saveState; | ||||
| /** | ||||
|  * Gets the value of an state set by this action's main execution. | ||||
|  * | ||||
|  * @param     name     name of the state to get | ||||
|  * @returns   string | ||||
|  */ | ||||
| function getState(name) { | ||||
|     return process.env[`STATE_${name}`] || ''; | ||||
| } | ||||
| exports.getState = getState; | ||||
| //# sourceMappingURL=core.js.map | ||||
							
								
								
									
										1
									
								
								node_modules/@actions/core/lib/core.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/core/lib/core.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1 +0,0 @@ | ||||
| {"version":3,"file":"core.js","sourceRoot":"","sources":["../src/core.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,uCAA6C;AAE7C,yBAAwB;AACxB,6BAA4B;AAU5B;;GAEG;AACH,IAAY,QAUX;AAVD,WAAY,QAAQ;IAClB;;OAEG;IACH,6CAAW,CAAA;IAEX;;OAEG;IACH,6CAAW,CAAA;AACb,CAAC,EAVW,QAAQ,GAAR,gBAAQ,KAAR,gBAAQ,QAUnB;AAED,yEAAyE;AACzE,YAAY;AACZ,yEAAyE;AAEzE;;;;GAIG;AACH,SAAgB,cAAc,CAAC,IAAY,EAAE,GAAW;IACtD,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,GAAG,CAAA;IACvB,sBAAY,CAAC,SAAS,EAAE,EAAC,IAAI,EAAC,EAAE,GAAG,CAAC,CAAA;AACtC,CAAC;AAHD,wCAGC;AAED;;;GAGG;AACH,SAAgB,SAAS,CAAC,MAAc;IACtC,sBAAY,CAAC,UAAU,EAAE,EAAE,EAAE,MAAM,CAAC,CAAA;AACtC,CAAC;AAFD,8BAEC;AAED;;;GAGG;AACH,SAAgB,OAAO,CAAC,SAAiB;IACvC,sBAAY,CAAC,UAAU,EAAE,EAAE,EAAE,SAAS,CAAC,CAAA;IACvC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,GAAG,SAAS,GAAG,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAA;AAC7E,CAAC;AAHD,0BAGC;AAED;;;;;;GAMG;AACH,SAAgB,QAAQ,CAAC,IAAY,EAAE,OAAsB;IAC3D,MAAM,GAAG,GACP,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,IAAI,EAAE,CAAA;IACrE,IAAI,OAAO,IAAI,OAAO,CAAC,QAAQ,IAAI,CAAC,GAAG,EAAE;QACvC,MAAM,IAAI,KAAK,CAAC,oCAAoC,IAAI,EAAE,CAAC,CAAA;KAC5D;IAED,OAAO,GAAG,CAAC,IAAI,EAAE,CAAA;AACnB,CAAC;AARD,4BAQC;AAED;;;;;GAKG;AACH,SAAgB,SAAS,CAAC,IAAY,EAAE,KAAa;IACnD,sBAAY,CAAC,YAAY,EAAE,EAAC,IAAI,EAAC,EAAE,KAAK,CAAC,CAAA;AAC3C,CAAC;AAFD,8BAEC;AAED,yEAAyE;AACzE,UAAU;AACV,yEAAyE;AAEzE;;;;GAIG;AACH,SAAgB,SAAS,CAAC,OAAe;IACvC,OAAO,CAAC,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAA;IACnC,KAAK,CAAC,OAAO,CAAC,CAAA;AAChB,CAAC;AAHD,8BAGC;AAED,yEAAyE;AACzE,mBAAmB;AACnB,yEAAyE;AAEzE;;;GAGG;AACH,SAAgB,KAAK,CAAC,OAAe;IACnC,sBAAY,CAAC,OAAO,EAAE,EAAE,EAAE,OAAO,CAAC,CAAA;AACpC,CAAC;AAFD,sBAEC;AAED;;;GAGG;AACH,SAAgB,KAAK,CAAC,OAAe;IACnC,eAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;AACzB,CAAC;AAFD,sBAEC;AAED;;;GAGG;AACH,SAAgB,OAAO,CAAC,OAAe;IACrC,eAAK,CAAC,SAAS,EAAE,OAAO,CAAC,CAAA;AAC3B,CAAC;AAFD,0BAEC;AAED;;;GAGG;AACH,SAAgB,IAAI,CAAC,OAAe;IAClC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,GAAG,EAAE,CAAC,GAAG,CAAC,CAAA;AACxC,CAAC;AAFD,oBAEC;AAED;;;;;;GAMG;AACH,SAAgB,UAAU,CAAC,IAAY;IACrC,eAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAA;AACtB,CAAC;AAFD,gCAEC;AAED;;GAEG;AACH,SAAgB,QAAQ;IACtB,eAAK,CAAC,UAAU,CAAC,CAAA;AACnB,CAAC;AAFD,4BAEC;AAED;;;;;;;GAOG;AACH,SAAsB,KAAK,CAAI,IAAY,EAAE,EAAoB;;QAC/D,UAAU,CAAC,IAAI,CAAC,CAAA;QAEhB,IAAI,MAAS,CAAA;QAEb,IAAI;YACF,MAAM,GAAG,MAAM,EAAE,EAAE,CAAA;SACpB;gBAAS;YACR,QAAQ,EAAE,CAAA;SACX;QAED,OAAO,MAAM,CAAA;IACf,CAAC;CAAA;AAZD,sBAYC;AAED,yEAAyE;AACzE,uBAAuB;AACvB,yEAAyE;AAEzE;;;;;GAKG;AACH,SAAgB,SAAS,CAAC,IAAY,EAAE,KAAa;IACnD,sBAAY,CAAC,YAAY,EAAE,EAAC,IAAI,EAAC,EAAE,KAAK,CAAC,CAAA;AAC3C,CAAC;AAFD,8BAEC;AAED;;;;;GAKG;AACH,SAAgB,QAAQ,CAAC,IAAY;IACnC,OAAO,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,EAAE,CAAC,IAAI,EAAE,CAAA;AAC3C,CAAC;AAFD,4BAEC"} | ||||
							
								
								
									
										67
									
								
								node_modules/@actions/core/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										67
									
								
								node_modules/@actions/core/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,67 +0,0 @@ | ||||
| { | ||||
|   "_args": [ | ||||
|     [ | ||||
|       "@actions/core@1.2.0", | ||||
|       "E:\\python\\setup-php" | ||||
|     ] | ||||
|   ], | ||||
|   "_from": "@actions/core@1.2.0", | ||||
|   "_id": "@actions/core@1.2.0", | ||||
|   "_inBundle": false, | ||||
|   "_integrity": "sha512-ZKdyhlSlyz38S6YFfPnyNgCDZuAF2T0Qv5eHflNWytPS8Qjvz39bZFMry9Bb/dpSnqWcNeav5yM2CTYpJeY+Dw==", | ||||
|   "_location": "/@actions/core", | ||||
|   "_phantomChildren": {}, | ||||
|   "_requested": { | ||||
|     "type": "version", | ||||
|     "registry": true, | ||||
|     "raw": "@actions/core@1.2.0", | ||||
|     "name": "@actions/core", | ||||
|     "escapedName": "@actions%2fcore", | ||||
|     "scope": "@actions", | ||||
|     "rawSpec": "1.2.0", | ||||
|     "saveSpec": null, | ||||
|     "fetchSpec": "1.2.0" | ||||
|   }, | ||||
|   "_requiredBy": [ | ||||
|     "/" | ||||
|   ], | ||||
|   "_resolved": "https://registry.npmjs.org/@actions/core/-/core-1.2.0.tgz", | ||||
|   "_spec": "1.2.0", | ||||
|   "_where": "E:\\python\\setup-php", | ||||
|   "bugs": { | ||||
|     "url": "https://github.com/actions/toolkit/issues" | ||||
|   }, | ||||
|   "description": "Actions core lib", | ||||
|   "devDependencies": { | ||||
|     "@types/node": "^12.0.2" | ||||
|   }, | ||||
|   "directories": { | ||||
|     "lib": "lib", | ||||
|     "test": "__tests__" | ||||
|   }, | ||||
|   "files": [ | ||||
|     "lib" | ||||
|   ], | ||||
|   "homepage": "https://github.com/actions/toolkit/tree/master/packages/core", | ||||
|   "keywords": [ | ||||
|     "github", | ||||
|     "actions", | ||||
|     "core" | ||||
|   ], | ||||
|   "license": "MIT", | ||||
|   "main": "lib/core.js", | ||||
|   "name": "@actions/core", | ||||
|   "publishConfig": { | ||||
|     "access": "public" | ||||
|   }, | ||||
|   "repository": { | ||||
|     "type": "git", | ||||
|     "url": "git+https://github.com/actions/toolkit.git", | ||||
|     "directory": "packages/core" | ||||
|   }, | ||||
|   "scripts": { | ||||
|     "test": "echo \"Error: run tests from root\" && exit 1", | ||||
|     "tsc": "tsc" | ||||
|   }, | ||||
|   "version": "1.2.0" | ||||
| } | ||||
							
								
								
									
										7
									
								
								node_modules/@actions/exec/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								node_modules/@actions/exec/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,7 +0,0 @@ | ||||
| Copyright 2019 GitHub | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
							
								
								
									
										60
									
								
								node_modules/@actions/exec/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										60
									
								
								node_modules/@actions/exec/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,60 +0,0 @@ | ||||
| # `@actions/exec` | ||||
|  | ||||
| ## Usage | ||||
|  | ||||
| #### Basic | ||||
|  | ||||
| You can use this package to execute your tools on the command line in a cross platform way: | ||||
|  | ||||
| ```js | ||||
| const exec = require('@actions/exec'); | ||||
|  | ||||
| await exec.exec('node index.js'); | ||||
| ``` | ||||
|  | ||||
| #### Args | ||||
|  | ||||
| You can also pass in arg arrays: | ||||
|  | ||||
| ```js | ||||
| const exec = require('@actions/exec'); | ||||
|  | ||||
| await exec.exec('node', ['index.js', 'foo=bar']); | ||||
| ``` | ||||
|  | ||||
| #### Output/options | ||||
|  | ||||
| Capture output or specify [other options](https://github.com/actions/toolkit/blob/d9347d4ab99fd507c0b9104b2cf79fb44fcc827d/packages/exec/src/interfaces.ts#L5): | ||||
|  | ||||
| ```js | ||||
| const exec = require('@actions/exec'); | ||||
|  | ||||
| let myOutput = ''; | ||||
| let myError = ''; | ||||
|  | ||||
| const options = {}; | ||||
| options.listeners = { | ||||
|   stdout: (data: Buffer) => { | ||||
|     myOutput += data.toString(); | ||||
|   }, | ||||
|   stderr: (data: Buffer) => { | ||||
|     myError += data.toString(); | ||||
|   } | ||||
| }; | ||||
| options.cwd = './lib'; | ||||
|  | ||||
| await exec.exec('node', ['index.js', 'foo=bar'], options); | ||||
| ``` | ||||
|  | ||||
| #### Exec tools not in the PATH | ||||
|  | ||||
| You can use it in conjunction with the `which` function from `@actions/io` to execute tools that are not in the PATH: | ||||
|  | ||||
| ```js | ||||
| const exec = require('@actions/exec'); | ||||
| const io = require('@actions/io'); | ||||
|  | ||||
| const pythonPath: string = await io.which('python', true) | ||||
|  | ||||
| await exec.exec(`"${pythonPath}"`, ['main.py']); | ||||
| ``` | ||||
							
								
								
									
										12
									
								
								node_modules/@actions/exec/lib/exec.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								node_modules/@actions/exec/lib/exec.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,12 +0,0 @@ | ||||
| import * as im from './interfaces'; | ||||
| /** | ||||
|  * Exec a command. | ||||
|  * Output will be streamed to the live console. | ||||
|  * Returns promise with return code | ||||
|  * | ||||
|  * @param     commandLine        command to execute (can include additional args). Must be correctly escaped. | ||||
|  * @param     args               optional arguments for tool. Escaping is handled by the lib. | ||||
|  * @param     options            optional exec options.  See ExecOptions | ||||
|  * @returns   Promise<number>    exit code | ||||
|  */ | ||||
| export declare function exec(commandLine: string, args?: string[], options?: im.ExecOptions): Promise<number>; | ||||
							
								
								
									
										37
									
								
								node_modules/@actions/exec/lib/exec.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										37
									
								
								node_modules/@actions/exec/lib/exec.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,37 +0,0 @@ | ||||
| "use strict"; | ||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||
|     return new (P || (P = Promise))(function (resolve, reject) { | ||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||
|     }); | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const tr = require("./toolrunner"); | ||||
| /** | ||||
|  * Exec a command. | ||||
|  * Output will be streamed to the live console. | ||||
|  * Returns promise with return code | ||||
|  * | ||||
|  * @param     commandLine        command to execute (can include additional args). Must be correctly escaped. | ||||
|  * @param     args               optional arguments for tool. Escaping is handled by the lib. | ||||
|  * @param     options            optional exec options.  See ExecOptions | ||||
|  * @returns   Promise<number>    exit code | ||||
|  */ | ||||
| function exec(commandLine, args, options) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         const commandArgs = tr.argStringToArray(commandLine); | ||||
|         if (commandArgs.length === 0) { | ||||
|             throw new Error(`Parameter 'commandLine' cannot be null or empty.`); | ||||
|         } | ||||
|         // Path to tool to execute should be first arg | ||||
|         const toolPath = commandArgs[0]; | ||||
|         args = commandArgs.slice(1).concat(args || []); | ||||
|         const runner = new tr.ToolRunner(toolPath, args, options); | ||||
|         return runner.exec(); | ||||
|     }); | ||||
| } | ||||
| exports.exec = exec; | ||||
| //# sourceMappingURL=exec.js.map | ||||
							
								
								
									
										1
									
								
								node_modules/@actions/exec/lib/exec.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/exec/lib/exec.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1 +0,0 @@ | ||||
| {"version":3,"file":"exec.js","sourceRoot":"","sources":["../src/exec.ts"],"names":[],"mappings":";;;;;;;;;;;AACA,mCAAkC;AAElC;;;;;;;;;GASG;AACH,SAAsB,IAAI,CACxB,WAAmB,EACnB,IAAe,EACf,OAAwB;;QAExB,MAAM,WAAW,GAAG,EAAE,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAA;QACpD,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;YAC5B,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAA;SACpE;QACD,8CAA8C;QAC9C,MAAM,QAAQ,GAAG,WAAW,CAAC,CAAC,CAAC,CAAA;QAC/B,IAAI,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC,CAAA;QAC9C,MAAM,MAAM,GAAkB,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,EAAE,OAAO,CAAC,CAAA;QACxE,OAAO,MAAM,CAAC,IAAI,EAAE,CAAA;IACtB,CAAC;CAAA;AAdD,oBAcC"} | ||||
							
								
								
									
										35
									
								
								node_modules/@actions/exec/lib/interfaces.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										35
									
								
								node_modules/@actions/exec/lib/interfaces.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,35 +0,0 @@ | ||||
| /// <reference types="node" /> | ||||
| import * as stream from 'stream'; | ||||
| /** | ||||
|  * Interface for exec options | ||||
|  */ | ||||
| export interface ExecOptions { | ||||
|     /** optional working directory.  defaults to current */ | ||||
|     cwd?: string; | ||||
|     /** optional envvar dictionary.  defaults to current process's env */ | ||||
|     env?: { | ||||
|         [key: string]: string; | ||||
|     }; | ||||
|     /** optional.  defaults to false */ | ||||
|     silent?: boolean; | ||||
|     /** optional out stream to use. Defaults to process.stdout */ | ||||
|     outStream?: stream.Writable; | ||||
|     /** optional err stream to use. Defaults to process.stderr */ | ||||
|     errStream?: stream.Writable; | ||||
|     /** optional. whether to skip quoting/escaping arguments if needed.  defaults to false. */ | ||||
|     windowsVerbatimArguments?: boolean; | ||||
|     /** optional.  whether to fail if output to stderr.  defaults to false */ | ||||
|     failOnStdErr?: boolean; | ||||
|     /** optional.  defaults to failing on non zero.  ignore will not fail leaving it up to the caller */ | ||||
|     ignoreReturnCode?: boolean; | ||||
|     /** optional. How long in ms to wait for STDIO streams to close after the exit event of the process before terminating. defaults to 10000 */ | ||||
|     delay?: number; | ||||
|     /** optional. Listeners for output. Callback functions that will be called on these events */ | ||||
|     listeners?: { | ||||
|         stdout?: (data: Buffer) => void; | ||||
|         stderr?: (data: Buffer) => void; | ||||
|         stdline?: (data: string) => void; | ||||
|         errline?: (data: string) => void; | ||||
|         debug?: (data: string) => void; | ||||
|     }; | ||||
| } | ||||
							
								
								
									
										3
									
								
								node_modules/@actions/exec/lib/interfaces.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								node_modules/@actions/exec/lib/interfaces.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,3 +0,0 @@ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| //# sourceMappingURL=interfaces.js.map | ||||
							
								
								
									
										1
									
								
								node_modules/@actions/exec/lib/interfaces.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/exec/lib/interfaces.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1 +0,0 @@ | ||||
| {"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../src/interfaces.ts"],"names":[],"mappings":""} | ||||
							
								
								
									
										37
									
								
								node_modules/@actions/exec/lib/toolrunner.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										37
									
								
								node_modules/@actions/exec/lib/toolrunner.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,37 +0,0 @@ | ||||
| /// <reference types="node" /> | ||||
| import * as events from 'events'; | ||||
| import * as im from './interfaces'; | ||||
| export declare class ToolRunner extends events.EventEmitter { | ||||
|     constructor(toolPath: string, args?: string[], options?: im.ExecOptions); | ||||
|     private toolPath; | ||||
|     private args; | ||||
|     private options; | ||||
|     private _debug; | ||||
|     private _getCommandString; | ||||
|     private _processLineBuffer; | ||||
|     private _getSpawnFileName; | ||||
|     private _getSpawnArgs; | ||||
|     private _endsWith; | ||||
|     private _isCmdFile; | ||||
|     private _windowsQuoteCmdArg; | ||||
|     private _uvQuoteCmdArg; | ||||
|     private _cloneExecOptions; | ||||
|     private _getSpawnOptions; | ||||
|     /** | ||||
|      * Exec a tool. | ||||
|      * Output will be streamed to the live console. | ||||
|      * Returns promise with return code | ||||
|      * | ||||
|      * @param     tool     path to tool to exec | ||||
|      * @param     options  optional exec options.  See ExecOptions | ||||
|      * @returns   number | ||||
|      */ | ||||
|     exec(): Promise<number>; | ||||
| } | ||||
| /** | ||||
|  * Convert an arg string to an array of args. Handles escaping | ||||
|  * | ||||
|  * @param    argString   string of arguments | ||||
|  * @returns  string[]    array of arguments | ||||
|  */ | ||||
| export declare function argStringToArray(argString: string): string[]; | ||||
							
								
								
									
										574
									
								
								node_modules/@actions/exec/lib/toolrunner.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										574
									
								
								node_modules/@actions/exec/lib/toolrunner.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,574 +0,0 @@ | ||||
| "use strict"; | ||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||
|     return new (P || (P = Promise))(function (resolve, reject) { | ||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||
|     }); | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const os = require("os"); | ||||
| const events = require("events"); | ||||
| const child = require("child_process"); | ||||
| /* eslint-disable @typescript-eslint/unbound-method */ | ||||
| const IS_WINDOWS = process.platform === 'win32'; | ||||
| /* | ||||
|  * Class for running command line tools. Handles quoting and arg parsing in a platform agnostic way. | ||||
|  */ | ||||
| class ToolRunner extends events.EventEmitter { | ||||
|     constructor(toolPath, args, options) { | ||||
|         super(); | ||||
|         if (!toolPath) { | ||||
|             throw new Error("Parameter 'toolPath' cannot be null or empty."); | ||||
|         } | ||||
|         this.toolPath = toolPath; | ||||
|         this.args = args || []; | ||||
|         this.options = options || {}; | ||||
|     } | ||||
|     _debug(message) { | ||||
|         if (this.options.listeners && this.options.listeners.debug) { | ||||
|             this.options.listeners.debug(message); | ||||
|         } | ||||
|     } | ||||
|     _getCommandString(options, noPrefix) { | ||||
|         const toolPath = this._getSpawnFileName(); | ||||
|         const args = this._getSpawnArgs(options); | ||||
|         let cmd = noPrefix ? '' : '[command]'; // omit prefix when piped to a second tool | ||||
|         if (IS_WINDOWS) { | ||||
|             // Windows + cmd file | ||||
|             if (this._isCmdFile()) { | ||||
|                 cmd += toolPath; | ||||
|                 for (const a of args) { | ||||
|                     cmd += ` ${a}`; | ||||
|                 } | ||||
|             } | ||||
|             // Windows + verbatim | ||||
|             else if (options.windowsVerbatimArguments) { | ||||
|                 cmd += `"${toolPath}"`; | ||||
|                 for (const a of args) { | ||||
|                     cmd += ` ${a}`; | ||||
|                 } | ||||
|             } | ||||
|             // Windows (regular) | ||||
|             else { | ||||
|                 cmd += this._windowsQuoteCmdArg(toolPath); | ||||
|                 for (const a of args) { | ||||
|                     cmd += ` ${this._windowsQuoteCmdArg(a)}`; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         else { | ||||
|             // OSX/Linux - this can likely be improved with some form of quoting. | ||||
|             // creating processes on Unix is fundamentally different than Windows. | ||||
|             // on Unix, execvp() takes an arg array. | ||||
|             cmd += toolPath; | ||||
|             for (const a of args) { | ||||
|                 cmd += ` ${a}`; | ||||
|             } | ||||
|         } | ||||
|         return cmd; | ||||
|     } | ||||
|     _processLineBuffer(data, strBuffer, onLine) { | ||||
|         try { | ||||
|             let s = strBuffer + data.toString(); | ||||
|             let n = s.indexOf(os.EOL); | ||||
|             while (n > -1) { | ||||
|                 const line = s.substring(0, n); | ||||
|                 onLine(line); | ||||
|                 // the rest of the string ... | ||||
|                 s = s.substring(n + os.EOL.length); | ||||
|                 n = s.indexOf(os.EOL); | ||||
|             } | ||||
|             strBuffer = s; | ||||
|         } | ||||
|         catch (err) { | ||||
|             // streaming lines to console is best effort.  Don't fail a build. | ||||
|             this._debug(`error processing line. Failed with error ${err}`); | ||||
|         } | ||||
|     } | ||||
|     _getSpawnFileName() { | ||||
|         if (IS_WINDOWS) { | ||||
|             if (this._isCmdFile()) { | ||||
|                 return process.env['COMSPEC'] || 'cmd.exe'; | ||||
|             } | ||||
|         } | ||||
|         return this.toolPath; | ||||
|     } | ||||
|     _getSpawnArgs(options) { | ||||
|         if (IS_WINDOWS) { | ||||
|             if (this._isCmdFile()) { | ||||
|                 let argline = `/D /S /C "${this._windowsQuoteCmdArg(this.toolPath)}`; | ||||
|                 for (const a of this.args) { | ||||
|                     argline += ' '; | ||||
|                     argline += options.windowsVerbatimArguments | ||||
|                         ? a | ||||
|                         : this._windowsQuoteCmdArg(a); | ||||
|                 } | ||||
|                 argline += '"'; | ||||
|                 return [argline]; | ||||
|             } | ||||
|         } | ||||
|         return this.args; | ||||
|     } | ||||
|     _endsWith(str, end) { | ||||
|         return str.endsWith(end); | ||||
|     } | ||||
|     _isCmdFile() { | ||||
|         const upperToolPath = this.toolPath.toUpperCase(); | ||||
|         return (this._endsWith(upperToolPath, '.CMD') || | ||||
|             this._endsWith(upperToolPath, '.BAT')); | ||||
|     } | ||||
|     _windowsQuoteCmdArg(arg) { | ||||
|         // for .exe, apply the normal quoting rules that libuv applies | ||||
|         if (!this._isCmdFile()) { | ||||
|             return this._uvQuoteCmdArg(arg); | ||||
|         } | ||||
|         // otherwise apply quoting rules specific to the cmd.exe command line parser. | ||||
|         // the libuv rules are generic and are not designed specifically for cmd.exe | ||||
|         // command line parser. | ||||
|         // | ||||
|         // for a detailed description of the cmd.exe command line parser, refer to | ||||
|         // http://stackoverflow.com/questions/4094699/how-does-the-windows-command-interpreter-cmd-exe-parse-scripts/7970912#7970912 | ||||
|         // need quotes for empty arg | ||||
|         if (!arg) { | ||||
|             return '""'; | ||||
|         } | ||||
|         // determine whether the arg needs to be quoted | ||||
|         const cmdSpecialChars = [ | ||||
|             ' ', | ||||
|             '\t', | ||||
|             '&', | ||||
|             '(', | ||||
|             ')', | ||||
|             '[', | ||||
|             ']', | ||||
|             '{', | ||||
|             '}', | ||||
|             '^', | ||||
|             '=', | ||||
|             ';', | ||||
|             '!', | ||||
|             "'", | ||||
|             '+', | ||||
|             ',', | ||||
|             '`', | ||||
|             '~', | ||||
|             '|', | ||||
|             '<', | ||||
|             '>', | ||||
|             '"' | ||||
|         ]; | ||||
|         let needsQuotes = false; | ||||
|         for (const char of arg) { | ||||
|             if (cmdSpecialChars.some(x => x === char)) { | ||||
|                 needsQuotes = true; | ||||
|                 break; | ||||
|             } | ||||
|         } | ||||
|         // short-circuit if quotes not needed | ||||
|         if (!needsQuotes) { | ||||
|             return arg; | ||||
|         } | ||||
|         // the following quoting rules are very similar to the rules that by libuv applies. | ||||
|         // | ||||
|         // 1) wrap the string in quotes | ||||
|         // | ||||
|         // 2) double-up quotes - i.e. " => "" | ||||
|         // | ||||
|         //    this is different from the libuv quoting rules. libuv replaces " with \", which unfortunately | ||||
|         //    doesn't work well with a cmd.exe command line. | ||||
|         // | ||||
|         //    note, replacing " with "" also works well if the arg is passed to a downstream .NET console app. | ||||
|         //    for example, the command line: | ||||
|         //          foo.exe "myarg:""my val""" | ||||
|         //    is parsed by a .NET console app into an arg array: | ||||
|         //          [ "myarg:\"my val\"" ] | ||||
|         //    which is the same end result when applying libuv quoting rules. although the actual | ||||
|         //    command line from libuv quoting rules would look like: | ||||
|         //          foo.exe "myarg:\"my val\"" | ||||
|         // | ||||
|         // 3) double-up slashes that precede a quote, | ||||
|         //    e.g.  hello \world    => "hello \world" | ||||
|         //          hello\"world    => "hello\\""world" | ||||
|         //          hello\\"world   => "hello\\\\""world" | ||||
|         //          hello world\    => "hello world\\" | ||||
|         // | ||||
|         //    technically this is not required for a cmd.exe command line, or the batch argument parser. | ||||
|         //    the reasons for including this as a .cmd quoting rule are: | ||||
|         // | ||||
|         //    a) this is optimized for the scenario where the argument is passed from the .cmd file to an | ||||
|         //       external program. many programs (e.g. .NET console apps) rely on the slash-doubling rule. | ||||
|         // | ||||
|         //    b) it's what we've been doing previously (by deferring to node default behavior) and we | ||||
|         //       haven't heard any complaints about that aspect. | ||||
|         // | ||||
|         // note, a weakness of the quoting rules chosen here, is that % is not escaped. in fact, % cannot be | ||||
|         // escaped when used on the command line directly - even though within a .cmd file % can be escaped | ||||
|         // by using %%. | ||||
|         // | ||||
|         // the saving grace is, on the command line, %var% is left as-is if var is not defined. this contrasts | ||||
|         // the line parsing rules within a .cmd file, where if var is not defined it is replaced with nothing. | ||||
|         // | ||||
|         // one option that was explored was replacing % with ^% - i.e. %var% => ^%var^%. this hack would | ||||
|         // often work, since it is unlikely that var^ would exist, and the ^ character is removed when the | ||||
|         // variable is used. the problem, however, is that ^ is not removed when %* is used to pass the args | ||||
|         // to an external program. | ||||
|         // | ||||
|         // an unexplored potential solution for the % escaping problem, is to create a wrapper .cmd file. | ||||
|         // % can be escaped within a .cmd file. | ||||
|         let reverse = '"'; | ||||
|         let quoteHit = true; | ||||
|         for (let i = arg.length; i > 0; i--) { | ||||
|             // walk the string in reverse | ||||
|             reverse += arg[i - 1]; | ||||
|             if (quoteHit && arg[i - 1] === '\\') { | ||||
|                 reverse += '\\'; // double the slash | ||||
|             } | ||||
|             else if (arg[i - 1] === '"') { | ||||
|                 quoteHit = true; | ||||
|                 reverse += '"'; // double the quote | ||||
|             } | ||||
|             else { | ||||
|                 quoteHit = false; | ||||
|             } | ||||
|         } | ||||
|         reverse += '"'; | ||||
|         return reverse | ||||
|             .split('') | ||||
|             .reverse() | ||||
|             .join(''); | ||||
|     } | ||||
|     _uvQuoteCmdArg(arg) { | ||||
|         // Tool runner wraps child_process.spawn() and needs to apply the same quoting as | ||||
|         // Node in certain cases where the undocumented spawn option windowsVerbatimArguments | ||||
|         // is used. | ||||
|         // | ||||
|         // Since this function is a port of quote_cmd_arg from Node 4.x (technically, lib UV, | ||||
|         // see https://github.com/nodejs/node/blob/v4.x/deps/uv/src/win/process.c for details), | ||||
|         // pasting copyright notice from Node within this function: | ||||
|         // | ||||
|         //      Copyright Joyent, Inc. and other Node contributors. All rights reserved. | ||||
|         // | ||||
|         //      Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|         //      of this software and associated documentation files (the "Software"), to | ||||
|         //      deal in the Software without restriction, including without limitation the | ||||
|         //      rights to use, copy, modify, merge, publish, distribute, sublicense, and/or | ||||
|         //      sell copies of the Software, and to permit persons to whom the Software is | ||||
|         //      furnished to do so, subject to the following conditions: | ||||
|         // | ||||
|         //      The above copyright notice and this permission notice shall be included in | ||||
|         //      all copies or substantial portions of the Software. | ||||
|         // | ||||
|         //      THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|         //      IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|         //      FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|         //      AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|         //      LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | ||||
|         //      FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS | ||||
|         //      IN THE SOFTWARE. | ||||
|         if (!arg) { | ||||
|             // Need double quotation for empty argument | ||||
|             return '""'; | ||||
|         } | ||||
|         if (!arg.includes(' ') && !arg.includes('\t') && !arg.includes('"')) { | ||||
|             // No quotation needed | ||||
|             return arg; | ||||
|         } | ||||
|         if (!arg.includes('"') && !arg.includes('\\')) { | ||||
|             // No embedded double quotes or backslashes, so I can just wrap | ||||
|             // quote marks around the whole thing. | ||||
|             return `"${arg}"`; | ||||
|         } | ||||
|         // Expected input/output: | ||||
|         //   input : hello"world | ||||
|         //   output: "hello\"world" | ||||
|         //   input : hello""world | ||||
|         //   output: "hello\"\"world" | ||||
|         //   input : hello\world | ||||
|         //   output: hello\world | ||||
|         //   input : hello\\world | ||||
|         //   output: hello\\world | ||||
|         //   input : hello\"world | ||||
|         //   output: "hello\\\"world" | ||||
|         //   input : hello\\"world | ||||
|         //   output: "hello\\\\\"world" | ||||
|         //   input : hello world\ | ||||
|         //   output: "hello world\\" - note the comment in libuv actually reads "hello world\" | ||||
|         //                             but it appears the comment is wrong, it should be "hello world\\" | ||||
|         let reverse = '"'; | ||||
|         let quoteHit = true; | ||||
|         for (let i = arg.length; i > 0; i--) { | ||||
|             // walk the string in reverse | ||||
|             reverse += arg[i - 1]; | ||||
|             if (quoteHit && arg[i - 1] === '\\') { | ||||
|                 reverse += '\\'; | ||||
|             } | ||||
|             else if (arg[i - 1] === '"') { | ||||
|                 quoteHit = true; | ||||
|                 reverse += '\\'; | ||||
|             } | ||||
|             else { | ||||
|                 quoteHit = false; | ||||
|             } | ||||
|         } | ||||
|         reverse += '"'; | ||||
|         return reverse | ||||
|             .split('') | ||||
|             .reverse() | ||||
|             .join(''); | ||||
|     } | ||||
|     _cloneExecOptions(options) { | ||||
|         options = options || {}; | ||||
|         const result = { | ||||
|             cwd: options.cwd || process.cwd(), | ||||
|             env: options.env || process.env, | ||||
|             silent: options.silent || false, | ||||
|             windowsVerbatimArguments: options.windowsVerbatimArguments || false, | ||||
|             failOnStdErr: options.failOnStdErr || false, | ||||
|             ignoreReturnCode: options.ignoreReturnCode || false, | ||||
|             delay: options.delay || 10000 | ||||
|         }; | ||||
|         result.outStream = options.outStream || process.stdout; | ||||
|         result.errStream = options.errStream || process.stderr; | ||||
|         return result; | ||||
|     } | ||||
|     _getSpawnOptions(options, toolPath) { | ||||
|         options = options || {}; | ||||
|         const result = {}; | ||||
|         result.cwd = options.cwd; | ||||
|         result.env = options.env; | ||||
|         result['windowsVerbatimArguments'] = | ||||
|             options.windowsVerbatimArguments || this._isCmdFile(); | ||||
|         if (options.windowsVerbatimArguments) { | ||||
|             result.argv0 = `"${toolPath}"`; | ||||
|         } | ||||
|         return result; | ||||
|     } | ||||
|     /** | ||||
|      * Exec a tool. | ||||
|      * Output will be streamed to the live console. | ||||
|      * Returns promise with return code | ||||
|      * | ||||
|      * @param     tool     path to tool to exec | ||||
|      * @param     options  optional exec options.  See ExecOptions | ||||
|      * @returns   number | ||||
|      */ | ||||
|     exec() { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             return new Promise((resolve, reject) => { | ||||
|                 this._debug(`exec tool: ${this.toolPath}`); | ||||
|                 this._debug('arguments:'); | ||||
|                 for (const arg of this.args) { | ||||
|                     this._debug(`   ${arg}`); | ||||
|                 } | ||||
|                 const optionsNonNull = this._cloneExecOptions(this.options); | ||||
|                 if (!optionsNonNull.silent && optionsNonNull.outStream) { | ||||
|                     optionsNonNull.outStream.write(this._getCommandString(optionsNonNull) + os.EOL); | ||||
|                 } | ||||
|                 const state = new ExecState(optionsNonNull, this.toolPath); | ||||
|                 state.on('debug', (message) => { | ||||
|                     this._debug(message); | ||||
|                 }); | ||||
|                 const fileName = this._getSpawnFileName(); | ||||
|                 const cp = child.spawn(fileName, this._getSpawnArgs(optionsNonNull), this._getSpawnOptions(this.options, fileName)); | ||||
|                 const stdbuffer = ''; | ||||
|                 if (cp.stdout) { | ||||
|                     cp.stdout.on('data', (data) => { | ||||
|                         if (this.options.listeners && this.options.listeners.stdout) { | ||||
|                             this.options.listeners.stdout(data); | ||||
|                         } | ||||
|                         if (!optionsNonNull.silent && optionsNonNull.outStream) { | ||||
|                             optionsNonNull.outStream.write(data); | ||||
|                         } | ||||
|                         this._processLineBuffer(data, stdbuffer, (line) => { | ||||
|                             if (this.options.listeners && this.options.listeners.stdline) { | ||||
|                                 this.options.listeners.stdline(line); | ||||
|                             } | ||||
|                         }); | ||||
|                     }); | ||||
|                 } | ||||
|                 const errbuffer = ''; | ||||
|                 if (cp.stderr) { | ||||
|                     cp.stderr.on('data', (data) => { | ||||
|                         state.processStderr = true; | ||||
|                         if (this.options.listeners && this.options.listeners.stderr) { | ||||
|                             this.options.listeners.stderr(data); | ||||
|                         } | ||||
|                         if (!optionsNonNull.silent && | ||||
|                             optionsNonNull.errStream && | ||||
|                             optionsNonNull.outStream) { | ||||
|                             const s = optionsNonNull.failOnStdErr | ||||
|                                 ? optionsNonNull.errStream | ||||
|                                 : optionsNonNull.outStream; | ||||
|                             s.write(data); | ||||
|                         } | ||||
|                         this._processLineBuffer(data, errbuffer, (line) => { | ||||
|                             if (this.options.listeners && this.options.listeners.errline) { | ||||
|                                 this.options.listeners.errline(line); | ||||
|                             } | ||||
|                         }); | ||||
|                     }); | ||||
|                 } | ||||
|                 cp.on('error', (err) => { | ||||
|                     state.processError = err.message; | ||||
|                     state.processExited = true; | ||||
|                     state.processClosed = true; | ||||
|                     state.CheckComplete(); | ||||
|                 }); | ||||
|                 cp.on('exit', (code) => { | ||||
|                     state.processExitCode = code; | ||||
|                     state.processExited = true; | ||||
|                     this._debug(`Exit code ${code} received from tool '${this.toolPath}'`); | ||||
|                     state.CheckComplete(); | ||||
|                 }); | ||||
|                 cp.on('close', (code) => { | ||||
|                     state.processExitCode = code; | ||||
|                     state.processExited = true; | ||||
|                     state.processClosed = true; | ||||
|                     this._debug(`STDIO streams have closed for tool '${this.toolPath}'`); | ||||
|                     state.CheckComplete(); | ||||
|                 }); | ||||
|                 state.on('done', (error, exitCode) => { | ||||
|                     if (stdbuffer.length > 0) { | ||||
|                         this.emit('stdline', stdbuffer); | ||||
|                     } | ||||
|                     if (errbuffer.length > 0) { | ||||
|                         this.emit('errline', errbuffer); | ||||
|                     } | ||||
|                     cp.removeAllListeners(); | ||||
|                     if (error) { | ||||
|                         reject(error); | ||||
|                     } | ||||
|                     else { | ||||
|                         resolve(exitCode); | ||||
|                     } | ||||
|                 }); | ||||
|             }); | ||||
|         }); | ||||
|     } | ||||
| } | ||||
| exports.ToolRunner = ToolRunner; | ||||
| /** | ||||
|  * Convert an arg string to an array of args. Handles escaping | ||||
|  * | ||||
|  * @param    argString   string of arguments | ||||
|  * @returns  string[]    array of arguments | ||||
|  */ | ||||
| function argStringToArray(argString) { | ||||
|     const args = []; | ||||
|     let inQuotes = false; | ||||
|     let escaped = false; | ||||
|     let arg = ''; | ||||
|     function append(c) { | ||||
|         // we only escape double quotes. | ||||
|         if (escaped && c !== '"') { | ||||
|             arg += '\\'; | ||||
|         } | ||||
|         arg += c; | ||||
|         escaped = false; | ||||
|     } | ||||
|     for (let i = 0; i < argString.length; i++) { | ||||
|         const c = argString.charAt(i); | ||||
|         if (c === '"') { | ||||
|             if (!escaped) { | ||||
|                 inQuotes = !inQuotes; | ||||
|             } | ||||
|             else { | ||||
|                 append(c); | ||||
|             } | ||||
|             continue; | ||||
|         } | ||||
|         if (c === '\\' && escaped) { | ||||
|             append(c); | ||||
|             continue; | ||||
|         } | ||||
|         if (c === '\\' && inQuotes) { | ||||
|             escaped = true; | ||||
|             continue; | ||||
|         } | ||||
|         if (c === ' ' && !inQuotes) { | ||||
|             if (arg.length > 0) { | ||||
|                 args.push(arg); | ||||
|                 arg = ''; | ||||
|             } | ||||
|             continue; | ||||
|         } | ||||
|         append(c); | ||||
|     } | ||||
|     if (arg.length > 0) { | ||||
|         args.push(arg.trim()); | ||||
|     } | ||||
|     return args; | ||||
| } | ||||
| exports.argStringToArray = argStringToArray; | ||||
| class ExecState extends events.EventEmitter { | ||||
|     constructor(options, toolPath) { | ||||
|         super(); | ||||
|         this.processClosed = false; // tracks whether the process has exited and stdio is closed | ||||
|         this.processError = ''; | ||||
|         this.processExitCode = 0; | ||||
|         this.processExited = false; // tracks whether the process has exited | ||||
|         this.processStderr = false; // tracks whether stderr was written to | ||||
|         this.delay = 10000; // 10 seconds | ||||
|         this.done = false; | ||||
|         this.timeout = null; | ||||
|         if (!toolPath) { | ||||
|             throw new Error('toolPath must not be empty'); | ||||
|         } | ||||
|         this.options = options; | ||||
|         this.toolPath = toolPath; | ||||
|         if (options.delay) { | ||||
|             this.delay = options.delay; | ||||
|         } | ||||
|     } | ||||
|     CheckComplete() { | ||||
|         if (this.done) { | ||||
|             return; | ||||
|         } | ||||
|         if (this.processClosed) { | ||||
|             this._setResult(); | ||||
|         } | ||||
|         else if (this.processExited) { | ||||
|             this.timeout = setTimeout(ExecState.HandleTimeout, this.delay, this); | ||||
|         } | ||||
|     } | ||||
|     _debug(message) { | ||||
|         this.emit('debug', message); | ||||
|     } | ||||
|     _setResult() { | ||||
|         // determine whether there is an error | ||||
|         let error; | ||||
|         if (this.processExited) { | ||||
|             if (this.processError) { | ||||
|                 error = new Error(`There was an error when attempting to execute the process '${this.toolPath}'. This may indicate the process failed to start. Error: ${this.processError}`); | ||||
|             } | ||||
|             else if (this.processExitCode !== 0 && !this.options.ignoreReturnCode) { | ||||
|                 error = new Error(`The process '${this.toolPath}' failed with exit code ${this.processExitCode}`); | ||||
|             } | ||||
|             else if (this.processStderr && this.options.failOnStdErr) { | ||||
|                 error = new Error(`The process '${this.toolPath}' failed because one or more lines were written to the STDERR stream`); | ||||
|             } | ||||
|         } | ||||
|         // clear the timeout | ||||
|         if (this.timeout) { | ||||
|             clearTimeout(this.timeout); | ||||
|             this.timeout = null; | ||||
|         } | ||||
|         this.done = true; | ||||
|         this.emit('done', error, this.processExitCode); | ||||
|     } | ||||
|     static HandleTimeout(state) { | ||||
|         if (state.done) { | ||||
|             return; | ||||
|         } | ||||
|         if (!state.processClosed && state.processExited) { | ||||
|             const message = `The STDIO streams did not close within ${state.delay / | ||||
|                 1000} seconds of the exit event from process '${state.toolPath}'. This may indicate a child process inherited the STDIO streams and has not yet exited.`; | ||||
|             state._debug(message); | ||||
|         } | ||||
|         state._setResult(); | ||||
|     } | ||||
| } | ||||
| //# sourceMappingURL=toolrunner.js.map | ||||
							
								
								
									
										1
									
								
								node_modules/@actions/exec/lib/toolrunner.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/exec/lib/toolrunner.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										67
									
								
								node_modules/@actions/exec/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										67
									
								
								node_modules/@actions/exec/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,67 +0,0 @@ | ||||
| { | ||||
|   "_args": [ | ||||
|     [ | ||||
|       "@actions/exec@1.0.1", | ||||
|       "E:\\python\\setup-php" | ||||
|     ] | ||||
|   ], | ||||
|   "_from": "@actions/exec@1.0.1", | ||||
|   "_id": "@actions/exec@1.0.1", | ||||
|   "_inBundle": false, | ||||
|   "_integrity": "sha512-nvFkxwiicvpzNiCBF4wFBDfnBvi7xp/as7LE1hBxBxKG2L29+gkIPBiLKMVORL+Hg3JNf07AKRfl0V5djoypjQ==", | ||||
|   "_location": "/@actions/exec", | ||||
|   "_phantomChildren": {}, | ||||
|   "_requested": { | ||||
|     "type": "version", | ||||
|     "registry": true, | ||||
|     "raw": "@actions/exec@1.0.1", | ||||
|     "name": "@actions/exec", | ||||
|     "escapedName": "@actions%2fexec", | ||||
|     "scope": "@actions", | ||||
|     "rawSpec": "1.0.1", | ||||
|     "saveSpec": null, | ||||
|     "fetchSpec": "1.0.1" | ||||
|   }, | ||||
|   "_requiredBy": [ | ||||
|     "/" | ||||
|   ], | ||||
|   "_resolved": "https://registry.npmjs.org/@actions/exec/-/exec-1.0.1.tgz", | ||||
|   "_spec": "1.0.1", | ||||
|   "_where": "E:\\python\\setup-php", | ||||
|   "bugs": { | ||||
|     "url": "https://github.com/actions/toolkit/issues" | ||||
|   }, | ||||
|   "description": "Actions exec lib", | ||||
|   "devDependencies": { | ||||
|     "@actions/io": "^1.0.1" | ||||
|   }, | ||||
|   "directories": { | ||||
|     "lib": "lib", | ||||
|     "test": "__tests__" | ||||
|   }, | ||||
|   "files": [ | ||||
|     "lib" | ||||
|   ], | ||||
|   "gitHead": "a2ab4bcf78e4f7080f0d45856e6eeba16f0bbc52", | ||||
|   "homepage": "https://github.com/actions/toolkit/tree/master/packages/exec", | ||||
|   "keywords": [ | ||||
|     "github", | ||||
|     "actions", | ||||
|     "exec" | ||||
|   ], | ||||
|   "license": "MIT", | ||||
|   "main": "lib/exec.js", | ||||
|   "name": "@actions/exec", | ||||
|   "publishConfig": { | ||||
|     "access": "public" | ||||
|   }, | ||||
|   "repository": { | ||||
|     "type": "git", | ||||
|     "url": "git+https://github.com/actions/toolkit.git" | ||||
|   }, | ||||
|   "scripts": { | ||||
|     "test": "echo \"Error: run tests from root\" && exit 1", | ||||
|     "tsc": "tsc" | ||||
|   }, | ||||
|   "version": "1.0.1" | ||||
| } | ||||
							
								
								
									
										9
									
								
								node_modules/fs/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								node_modules/fs/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,9 +0,0 @@ | ||||
| # Security holding package | ||||
|  | ||||
| This package name is not currently in use, but was formerly occupied | ||||
| by another package. To avoid malicious use, npm is hanging on to the | ||||
| package name, but loosely, and we'll probably give it to you if you | ||||
| want it. | ||||
|  | ||||
| You may adopt this package by contacting support@npmjs.com and | ||||
| requesting the name. | ||||
							
								
								
									
										48
									
								
								node_modules/fs/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										48
									
								
								node_modules/fs/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,48 +0,0 @@ | ||||
| { | ||||
|   "_args": [ | ||||
|     [ | ||||
|       "fs@0.0.1-security", | ||||
|       "E:\\python\\setup-php" | ||||
|     ] | ||||
|   ], | ||||
|   "_from": "fs@0.0.1-security", | ||||
|   "_id": "fs@0.0.1-security", | ||||
|   "_inBundle": false, | ||||
|   "_integrity": "sha1-invTcYa23d84E/I4WLV+yq9eQdQ=", | ||||
|   "_location": "/fs", | ||||
|   "_phantomChildren": {}, | ||||
|   "_requested": { | ||||
|     "type": "version", | ||||
|     "registry": true, | ||||
|     "raw": "fs@0.0.1-security", | ||||
|     "name": "fs", | ||||
|     "escapedName": "fs", | ||||
|     "rawSpec": "0.0.1-security", | ||||
|     "saveSpec": null, | ||||
|     "fetchSpec": "0.0.1-security" | ||||
|   }, | ||||
|   "_requiredBy": [ | ||||
|     "/" | ||||
|   ], | ||||
|   "_resolved": "https://registry.npmjs.org/fs/-/fs-0.0.1-security.tgz", | ||||
|   "_spec": "0.0.1-security", | ||||
|   "_where": "E:\\python\\setup-php", | ||||
|   "author": "", | ||||
|   "bugs": { | ||||
|     "url": "https://github.com/npm/security-holder/issues" | ||||
|   }, | ||||
|   "description": "This package name is not currently in use, but was formerly occupied by another package. To avoid malicious use, npm is hanging on to the package name, but loosely, and we'll probably give it to you if you want it.", | ||||
|   "homepage": "https://github.com/npm/security-holder#readme", | ||||
|   "keywords": [], | ||||
|   "license": "ISC", | ||||
|   "main": "index.js", | ||||
|   "name": "fs", | ||||
|   "repository": { | ||||
|     "type": "git", | ||||
|     "url": "git+https://github.com/npm/security-holder.git" | ||||
|   }, | ||||
|   "scripts": { | ||||
|     "test": "echo \"Error: no test specified\" && exit 1" | ||||
|   }, | ||||
|   "version": "0.0.1-security" | ||||
| } | ||||
							
								
								
									
										12791
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										12791
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										59
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										59
									
								
								package.json
									
									
									
									
									
								
							| @ -1,13 +1,25 @@ | ||||
| { | ||||
|   "name": "setup-php", | ||||
|   "version": "1.5.1", | ||||
|   "version": "1.11.7", | ||||
|   "private": false, | ||||
|   "description": "Setup PHP for use with GitHub Actions", | ||||
|   "main": "lib/setup-php.js", | ||||
|   "main": "lib/install.js", | ||||
|   "types": "lib/install.d.ts", | ||||
|   "directories": { | ||||
|     "lib": "lib", | ||||
|     "test": "__tests__", | ||||
|     "src": "src" | ||||
|   }, | ||||
|   "files": [ | ||||
|     "lib", | ||||
|     "src" | ||||
|   ], | ||||
|   "scripts": { | ||||
|     "build": "tsc", | ||||
|     "format": "prettier --write **/*.ts", | ||||
|     "format-check": "prettier --check **/*.ts", | ||||
|     "lint": "eslint **/src/*.ts --cache --fix", | ||||
|     "format": "prettier --write **/src/*.ts && git add .", | ||||
|     "format-check": "prettier --check **/src/*.ts", | ||||
|     "release": "ncc build -o dist && git add -f dist/", | ||||
|     "test": "jest" | ||||
|   }, | ||||
|   "repository": { | ||||
| @ -22,24 +34,33 @@ | ||||
|   "author": "shivammathur", | ||||
|   "license": "MIT", | ||||
|   "dependencies": { | ||||
|     "@actions/core": "^1.2.0", | ||||
|     "@actions/exec": "^1.0.1", | ||||
|     "@actions/core": "^1.6.0", | ||||
|     "@actions/exec": "^1.1.1", | ||||
|     "@actions/io": "^1.1.2", | ||||
|     "fs": "0.0.1-security" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "@types/jest": "^24.0.21", | ||||
|     "@types/node": "^12.12.0", | ||||
|     "husky": "^3.0.9", | ||||
|     "jest": "^24.9.0", | ||||
|     "jest-circus": "^24.9.0", | ||||
|     "prettier": "^1.17.1", | ||||
|     "ts-jest": "^24.1.0", | ||||
|     "typescript": "^3.6.4" | ||||
|     "@types/jest": "^27.4.1", | ||||
|     "@types/node": "^17.0.23", | ||||
|     "@typescript-eslint/eslint-plugin": "^5.18.0", | ||||
|     "@typescript-eslint/parser": "^5.18.0", | ||||
|     "@vercel/ncc": "^0.33.3", | ||||
|     "eslint": "^8.13.0", | ||||
|     "eslint-config-prettier": "^8.5.0", | ||||
|     "eslint-plugin-import": "^2.26.0", | ||||
|     "eslint-plugin-jest": "^26.1.4", | ||||
|     "eslint-plugin-prettier": "^4.0.0", | ||||
|     "jest": "^27.5.1", | ||||
|     "jest-circus": "^27.5.1", | ||||
|     "prettier": "^2.6.2", | ||||
|     "simple-git-hooks": "^2.7.0", | ||||
|     "ts-jest": "^27.1.4", | ||||
|     "typescript": "^4.6.3" | ||||
|   }, | ||||
|   "husky": { | ||||
|     "skipCI": true, | ||||
|     "hooks": { | ||||
|       "pre-commit": "npm run build && npm run format" | ||||
|     } | ||||
|   "bugs": { | ||||
|     "url": "https://github.com/shivammathur/setup-php/issues" | ||||
|   }, | ||||
|   "simple-git-hooks": { | ||||
|     "pre-commit": "npm run format && npm run lint && npm run test && npm run build && npm run release" | ||||
|   } | ||||
| } | ||||
|  | ||||
| @ -1,17 +1,59 @@ | ||||
| import * as utils from './utils'; | ||||
|  | ||||
| /** | ||||
|  * Add script to set custom ini values for unix | ||||
|  * | ||||
|  * @param ini_values_csv | ||||
|  */ | ||||
| export async function addINIValuesUnix( | ||||
|   ini_values_csv: string | ||||
| ): Promise<string> { | ||||
|   const ini_values: Array<string> = await utils.CSVArray(ini_values_csv); | ||||
|   let script = '\n'; | ||||
|   await utils.asyncForEach(ini_values, async function (line: string) { | ||||
|     script += | ||||
|       (await utils.addLog('$tick', line, 'Added to php.ini', 'linux')) + '\n'; | ||||
|   }); | ||||
|   return ( | ||||
|     'echo "' + ini_values.join('\n') + '" >> ${pecl_file:-$ini_file}' + script | ||||
|   ); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Add script to set custom ini values for windows | ||||
|  * | ||||
|  * @param ini_values_csv | ||||
|  */ | ||||
| export async function addINIValuesWindows( | ||||
|   ini_values_csv: string | ||||
| ): Promise<string> { | ||||
|   const ini_values: Array<string> = await utils.CSVArray(ini_values_csv); | ||||
|   let script = '\n'; | ||||
|   await utils.asyncForEach(ini_values, async function (line: string) { | ||||
|     script += | ||||
|       (await utils.addLog('$tick', line, 'Added to php.ini', 'win32')) + '\n'; | ||||
|   }); | ||||
|   return ( | ||||
|     'Add-Content C:\\tools\\php\\php.ini "' + | ||||
|     ini_values.join('\n') + | ||||
|     '"' + | ||||
|     script | ||||
|   ); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Function to add custom ini values | ||||
|  * | ||||
|  * @param ini_values_csv | ||||
|  * @param os_version | ||||
|  * @param no_step | ||||
|  */ | ||||
| export async function addINIValues( | ||||
|   ini_values_csv: string, | ||||
|   os_version: string, | ||||
|   no_step = false | ||||
| ): Promise<string> { | ||||
|   let script: string = '\n'; | ||||
|   let script = '\n'; | ||||
|   switch (no_step) { | ||||
|     case true: | ||||
|       script += | ||||
| @ -38,42 +80,3 @@ export async function addINIValues( | ||||
|       ); | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Add script to set custom ini values for unix | ||||
|  * | ||||
|  * @param ini_values_csv | ||||
|  */ | ||||
| export async function addINIValuesUnix( | ||||
|   ini_values_csv: string | ||||
| ): Promise<string> { | ||||
|   let ini_values: Array<string> = await utils.INIArray(ini_values_csv); | ||||
|   let script: string = '\n'; | ||||
|   await utils.asyncForEach(ini_values, async function(line: string) { | ||||
|     script += | ||||
|       (await utils.addLog('$tick', line, 'Added to php.ini', 'linux')) + '\n'; | ||||
|   }); | ||||
|   return 'echo "' + ini_values.join('\n') + '" >> $ini_file' + script; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Add script to set custom ini values for windows | ||||
|  * | ||||
|  * @param ini_values_csv | ||||
|  */ | ||||
| export async function addINIValuesWindows( | ||||
|   ini_values_csv: string | ||||
| ): Promise<string> { | ||||
|   let ini_values: Array<string> = await utils.INIArray(ini_values_csv); | ||||
|   let script: string = '\n'; | ||||
|   await utils.asyncForEach(ini_values, async function(line: string) { | ||||
|     script += | ||||
|       (await utils.addLog('$tick', line, 'Added to php.ini', 'win32')) + '\n'; | ||||
|   }); | ||||
|   return ( | ||||
|     'Add-Content C:\\tools\\php\\php.ini "' + | ||||
|     ini_values.join('\n') + | ||||
|     '"' + | ||||
|     script | ||||
|   ); | ||||
| } | ||||
|  | ||||
							
								
								
									
										28
									
								
								src/configs/brew_extensions
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								src/configs/brew_extensions
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,28 @@ | ||||
| amqp=amqp | ||||
| apcu=apcu | ||||
| expect=expect | ||||
| grpc=grpc | ||||
| igbinary=igbinary | ||||
| imagick=imagick | ||||
| imap=imap | ||||
| memcache=memcache | ||||
| memcached=memcached | ||||
| mongodb=mongodb | ||||
| msgpack=msgpack | ||||
| pcov=pcov | ||||
| pecl_http=http | ||||
| phalcon3=phalcon | ||||
| phalcon4=phalcon | ||||
| propro=propro | ||||
| protobuf=protobuf | ||||
| psr=psr | ||||
| raphf=raphf | ||||
| rdkafka=rdkafka | ||||
| redis=redis | ||||
| ssh2=ssh2 | ||||
| swoole=swoole | ||||
| vips=vips | ||||
| xdebug=xdebug | ||||
| xdebug2=xdebug | ||||
| yaml=yaml | ||||
| zmq=zmq | ||||
| @ -1,58 +0,0 @@ | ||||
| variants: | ||||
|   dev: | ||||
|     bcmath: | ||||
|     calendar: | ||||
|     cli: | ||||
|     ctype: | ||||
|     dom: | ||||
|     fileinfo: | ||||
|     filter: | ||||
|     ipc: | ||||
|     iconv: | ||||
|     json: | ||||
|     mbregex: | ||||
|     mbstring: | ||||
|     mhash: | ||||
|     mcrypt: | ||||
|     pcntl: | ||||
|     pcre: | ||||
|     pdo: | ||||
|     phar: | ||||
|     posix: | ||||
|     sockets: | ||||
|     tokenizer: | ||||
|     xml: | ||||
|     curl: | ||||
|     openssl: | ||||
|     zip: | ||||
|     gd: | ||||
|       - --with-freetype | ||||
|       - --with-pdo-mysql=mysqlnd | ||||
|       - --with-mysqli=mysqlnd | ||||
|       - --with-pgsql | ||||
|       - --with-pdo-pgsql | ||||
|       - --with-gmp=/usr/local/opt/gmp | ||||
|       - --with-openssl | ||||
|       - --with-pear | ||||
|       - --with-zip | ||||
|       - --with-libxml | ||||
|       - --with-kerberos | ||||
|       - --with-gd | ||||
|       - --with-ffi | ||||
|       - --with-curl | ||||
|       - --with-mhash | ||||
|       - --with-readline=/usr/local/opt/readline | ||||
|       - --with-iconv=/usr/local/opt/libiconv | ||||
|       - --with-icu-dir=/usr/local/opt/icu4c | ||||
|       - --with-config-file-path=/etc | ||||
|       - --enable-intl | ||||
|       - --enable-xml | ||||
|       - --enable-sysvsem | ||||
|       - --enable-sysvshm | ||||
|       - --enable-sysvmsg | ||||
|       - --enable-phpdbg | ||||
|       - --enable-exif | ||||
|       - --enable-gd | ||||
|       - --enable-soap | ||||
|       - --enable-xmlreader | ||||
|       - --enable-zend-test=shared | ||||
							
								
								
									
										6
									
								
								src/configs/php-versions.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								src/configs/php-versions.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,6 @@ | ||||
| { | ||||
|   "latest": "8.0", | ||||
|   "5.x": "5.6", | ||||
|   "7.x": "7.4", | ||||
|   "8.x": "8.0" | ||||
| } | ||||
							
								
								
									
										24
									
								
								src/configs/phpunit.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								src/configs/phpunit.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,24 @@ | ||||
| { | ||||
|   "problemMatcher": [ | ||||
|     { | ||||
|       "owner": "phpunit", | ||||
|       "pattern": [ | ||||
|         { | ||||
|           "regexp": "^\\d+\\)\\s.*$" | ||||
|         }, | ||||
|         { | ||||
|           "regexp": "^(.*Failed\\sasserting\\sthat.*)$", | ||||
|           "message": 1 | ||||
|         }, | ||||
|         { | ||||
|           "regexp": "^\\s*$" | ||||
|         }, | ||||
|         { | ||||
|           "regexp": "^(.*):(\\d+)$", | ||||
|           "file": 1, | ||||
|           "line": 2 | ||||
|         } | ||||
|       ] | ||||
|     } | ||||
|   ] | ||||
| } | ||||
							
								
								
									
										148
									
								
								src/coverage.ts
									
									
									
									
									
								
							
							
						
						
									
										148
									
								
								src/coverage.ts
									
									
									
									
									
								
							| @ -2,51 +2,22 @@ import * as utils from './utils'; | ||||
| import * as extensions from './extensions'; | ||||
| import * as config from './config'; | ||||
|  | ||||
| /** | ||||
|  * Function to set coverage driver | ||||
|  * | ||||
|  * @param coverage_driver | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  */ | ||||
| export async function addCoverage( | ||||
|   coverage_driver: string, | ||||
| export async function addCoverageXdebug( | ||||
|   extension: string, | ||||
|   version: string, | ||||
|   os_version: string | ||||
|   os_version: string, | ||||
|   pipe: string | ||||
| ): Promise<string> { | ||||
|   coverage_driver.toLowerCase(); | ||||
|   let script: string = | ||||
|     '\n' + (await utils.stepLog('Setup Coverage', os_version)); | ||||
|   switch (coverage_driver) { | ||||
|     case 'pcov': | ||||
|       return script + (await addCoveragePCOV(version, os_version)); | ||||
|     case 'xdebug': | ||||
|       return script + (await addCoverageXdebug(version, os_version)); | ||||
|     case 'none': | ||||
|       return script + (await disableCoverage(version, os_version)); | ||||
|     default: | ||||
|       return ''; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Function to setup Xdebug | ||||
|  * | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  */ | ||||
| export async function addCoverageXdebug(version: string, os_version: string) { | ||||
|   return ( | ||||
|     (await extensions.addExtension('xdebug', version, os_version, true)) + | ||||
|     (await utils.suppressOutput(os_version)) + | ||||
|     '\n' + | ||||
|     (await utils.addLog( | ||||
|       '$tick', | ||||
|       'xdebug', | ||||
|       'Xdebug enabled as coverage driver', | ||||
|       os_version | ||||
|     )) | ||||
|   const xdebug = | ||||
|     (await extensions.addExtension(extension, version, os_version, true)) + | ||||
|     pipe; | ||||
|   const log = await utils.addLog( | ||||
|     '$tick', | ||||
|     extension, | ||||
|     'Xdebug enabled as coverage driver', | ||||
|     os_version | ||||
|   ); | ||||
|   return xdebug + '\n' + log; | ||||
| } | ||||
|  | ||||
| /** | ||||
| @ -54,14 +25,19 @@ export async function addCoverageXdebug(version: string, os_version: string) { | ||||
|  * | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  * @param pipe | ||||
|  */ | ||||
| export async function addCoveragePCOV(version: string, os_version: string) { | ||||
|   let script: string = '\n'; | ||||
| export async function addCoveragePCOV( | ||||
|   version: string, | ||||
|   os_version: string, | ||||
|   pipe: string | ||||
| ): Promise<string> { | ||||
|   let script = '\n'; | ||||
|   switch (version) { | ||||
|     default: | ||||
|       script += | ||||
|         (await extensions.addExtension('pcov', version, os_version, true)) + | ||||
|         (await utils.suppressOutput(os_version)) + | ||||
|         pipe + | ||||
|         '\n'; | ||||
|       script += | ||||
|         (await config.addINIValues('pcov.enabled=1', os_version, true)) + '\n'; | ||||
| @ -69,20 +45,11 @@ export async function addCoveragePCOV(version: string, os_version: string) { | ||||
|       // add command to disable xdebug and enable pcov | ||||
|       switch (os_version) { | ||||
|         case 'linux': | ||||
|           script += | ||||
|             'if [ -e /etc/php/' + | ||||
|             version + | ||||
|             '/mods-available/xdebug.ini ]; then sudo phpdismod -v ' + | ||||
|             version + | ||||
|             ' xdebug; fi\n'; | ||||
|           script += 'sudo sed -i "/xdebug/d" $ini_file\n'; | ||||
|           break; | ||||
|         case 'darwin': | ||||
|           script += 'sudo sed -i \'\' "/xdebug/d" $ini_file\n'; | ||||
|           script += 'remove_extension xdebug' + pipe + '\n'; | ||||
|           break; | ||||
|         case 'win32': | ||||
|           script += | ||||
|             'if(php -m | findstr -i xdebug) { Disable-PhpExtension xdebug C:\\tools\\php }\n'; | ||||
|           script += 'Remove-Extension xdebug' + pipe + '\n'; | ||||
|           break; | ||||
|       } | ||||
|  | ||||
| @ -114,35 +81,23 @@ export async function addCoveragePCOV(version: string, os_version: string) { | ||||
|  * | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  * @param pipe | ||||
|  */ | ||||
| export async function disableCoverage(version: string, os_version: string) { | ||||
|   let script: string = '\n'; | ||||
| export async function disableCoverage( | ||||
|   version: string, | ||||
|   os_version: string, | ||||
|   pipe: string | ||||
| ): Promise<string> { | ||||
|   let script = '\n'; | ||||
|   switch (os_version) { | ||||
|     case 'linux': | ||||
|       script += | ||||
|         'if [ -e /etc/php/' + | ||||
|         version + | ||||
|         '/mods-available/xdebug.ini ]; then sudo phpdismod -v ' + | ||||
|         version + | ||||
|         ' xdebug; fi\n'; | ||||
|       script += | ||||
|         'if [ -e /etc/php/' + | ||||
|         version + | ||||
|         '/mods-available/pcov.ini ]; then sudo phpdismod -v ' + | ||||
|         version + | ||||
|         ' pcov; fi\n'; | ||||
|       script += 'sudo sed -i "/xdebug/d" $ini_file\n'; | ||||
|       script += 'sudo sed -i "/pcov/d" $ini_file\n'; | ||||
|       break; | ||||
|     case 'darwin': | ||||
|       script += 'sudo sed -i \'\' "/xdebug/d" $ini_file\n'; | ||||
|       script += 'sudo sed -i \'\' "/pcov/d" $ini_file\n'; | ||||
|       script += 'remove_extension xdebug' + pipe + '\n'; | ||||
|       script += 'remove_extension pcov' + pipe + '\n'; | ||||
|       break; | ||||
|     case 'win32': | ||||
|       script += | ||||
|         'if(php -m | findstr -i xdebug) { Disable-PhpExtension xdebug C:\\tools\\php }\n'; | ||||
|       script += | ||||
|         'if(php -m | findstr -i pcov) { Disable-PhpExtension pcov C:\\tools\\php }\n'; | ||||
|       script += 'Remove-Extension xdebug' + pipe + '\n'; | ||||
|       script += 'Remove-Extension pcov' + pipe + '\n'; | ||||
|       break; | ||||
|   } | ||||
|   script += await utils.addLog( | ||||
| @ -154,3 +109,38 @@ export async function disableCoverage(version: string, os_version: string) { | ||||
|  | ||||
|   return script; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Function to set coverage driver | ||||
|  * | ||||
|  * @param coverage_driver | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  */ | ||||
| export async function addCoverage( | ||||
|   coverage_driver: string, | ||||
|   version: string, | ||||
|   os_version: string | ||||
| ): Promise<string> { | ||||
|   coverage_driver = coverage_driver.toLowerCase(); | ||||
|   const script: string = | ||||
|     '\n' + (await utils.stepLog('Setup Coverage', os_version)); | ||||
|   const pipe: string = await utils.suppressOutput(os_version); | ||||
|   switch (coverage_driver) { | ||||
|     case 'pcov': | ||||
|       return script + (await addCoveragePCOV(version, os_version, pipe)); | ||||
|     case 'xdebug': | ||||
|     case 'xdebug3': | ||||
|       return ( | ||||
|         script + (await addCoverageXdebug('xdebug', version, os_version, pipe)) | ||||
|       ); | ||||
|     case 'xdebug2': | ||||
|       return ( | ||||
|         script + (await addCoverageXdebug('xdebug2', version, os_version, pipe)) | ||||
|       ); | ||||
|     case 'none': | ||||
|       return script + (await disableCoverage(version, os_version, pipe)); | ||||
|     default: | ||||
|       return ''; | ||||
|   } | ||||
| } | ||||
|  | ||||
										
											Binary file not shown.
										
									
								
							| @ -1,49 +1,6 @@ | ||||
| import * as path from 'path'; | ||||
| import * as utils from './utils'; | ||||
|  | ||||
| /** | ||||
|  * Install and enable extensions | ||||
|  * | ||||
|  * @param extension_csv | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  * @param log_prefix | ||||
|  */ | ||||
| export async function addExtension( | ||||
|   extension_csv: string, | ||||
|   version: string, | ||||
|   os_version: string, | ||||
|   no_step = false | ||||
| ): Promise<string> { | ||||
|   let script: string = '\n'; | ||||
|   switch (no_step) { | ||||
|     case true: | ||||
|       script += | ||||
|         (await utils.stepLog('Setup Extensions', os_version)) + | ||||
|         (await utils.suppressOutput(os_version)); | ||||
|       break; | ||||
|     case false: | ||||
|     default: | ||||
|       script += await utils.stepLog('Setup Extensions', os_version); | ||||
|       break; | ||||
|   } | ||||
|  | ||||
|   switch (os_version) { | ||||
|     case 'win32': | ||||
|       return script + (await addExtensionWindows(extension_csv, version)); | ||||
|     case 'darwin': | ||||
|       return script + (await addExtensionDarwin(extension_csv, version)); | ||||
|     case 'linux': | ||||
|       return script + (await addExtensionLinux(extension_csv, version)); | ||||
|     default: | ||||
|       return await utils.log( | ||||
|         'Platform ' + os_version + ' is not supported', | ||||
|         os_version, | ||||
|         'error' | ||||
|       ); | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Install and enable extensions for darwin | ||||
|  * | ||||
| @ -54,25 +11,52 @@ export async function addExtensionDarwin( | ||||
|   extension_csv: string, | ||||
|   version: string | ||||
| ): Promise<string> { | ||||
|   let extensions: Array<string> = await utils.extensionArray(extension_csv); | ||||
|   let script: string = '\n'; | ||||
|   await utils.asyncForEach(extensions, async function(extension: string) { | ||||
|     extension = extension.toLowerCase(); | ||||
|     // add script to enable extension is already installed along with php | ||||
|     let install_command: string = ''; | ||||
|     switch (version + extension) { | ||||
|       case '5.6xdebug': | ||||
|         install_command = 'sudo pecl install xdebug-2.5.5 >/dev/null 2>&1'; | ||||
|   const extensions: Array<string> = await utils.extensionArray(extension_csv); | ||||
|   let script = '\n'; | ||||
|   await utils.asyncForEach(extensions, async function (extension: string) { | ||||
|     const version_extension: string = version + extension; | ||||
|     const [extension_name, stability]: string[] = extension.split('-'); | ||||
|     const ext_prefix = await utils.getExtensionPrefix(extension_name); | ||||
|     const command_prefix = 'pecl_install '; | ||||
|     let command = ''; | ||||
|     switch (true) { | ||||
|       // match pre-release versions | ||||
|       case /.+-(beta|alpha|devel|snapshot)/.test(extension): | ||||
|         script += | ||||
|           '\nadd_unstable_extension ' + | ||||
|           extension_name + | ||||
|           ' ' + | ||||
|           stability + | ||||
|           ' ' + | ||||
|           ext_prefix; | ||||
|         return; | ||||
|       // match 5.6 to 8.0 amqp, expect, grpc, igbinary, imagick, imap, mongodb, msgpack, pecl_http, propro, protobuf, raphf, rdkafka, redis, ssh2, swoole, xdebug, xdebug2, yaml, zmq | ||||
|       // match 7.1pcov to 8.0pcov | ||||
|       // match 7.0vips to 8.0vips | ||||
|       case /(5\.6|7\.[0-4]|8.0)(amqp|expect|grpc|igbinary|imagick|imap|mcrypt|mongodb|msgpack|^(pecl_)?http$|propro|protobuf|psr|raphf|rdkafka|redis|ssh2|swoole|xdebug|xdebug2|yaml|zmq)/.test( | ||||
|         version_extension | ||||
|       ): | ||||
|       case /(7\.[1-4]|8\.0])pcov/.test(version_extension): | ||||
|       case /^(5\.6|7\.[0-3])phalcon3$|^7\.[2-4]phalcon4$/.test( | ||||
|         version_extension | ||||
|       ): | ||||
|       case /(7\.[0-4]|8\.0])vips/.test(version_extension): | ||||
|         command = 'add_brew_extension ' + extension_name.replace('pecl_', ''); | ||||
|         break; | ||||
|       // match sqlite | ||||
|       case /^sqlite$/.test(extension): | ||||
|         extension = 'sqlite3'; | ||||
|         command = command_prefix + extension; | ||||
|         break; | ||||
|       default: | ||||
|         install_command = 'sudo pecl install ' + extension + ' >/dev/null 2>&1'; | ||||
|         command = command_prefix + extension; | ||||
|         break; | ||||
|     } | ||||
|     script += | ||||
|       '\nadd_extension ' + | ||||
|       extension + | ||||
|       ' "' + | ||||
|       install_command + | ||||
|       command + | ||||
|       '" ' + | ||||
|       (await utils.getExtensionPrefix(extension)); | ||||
|   }); | ||||
| @ -89,35 +73,51 @@ export async function addExtensionWindows( | ||||
|   extension_csv: string, | ||||
|   version: string | ||||
| ): Promise<string> { | ||||
|   let extensions: Array<string> = await utils.extensionArray(extension_csv); | ||||
|   let script: string = '\n'; | ||||
|   await utils.asyncForEach(extensions, async function(extension: string) { | ||||
|     extension = extension.toLowerCase(); | ||||
|     // add script to enable extension is already installed along with php | ||||
|  | ||||
|     let install_command: string = ''; | ||||
|     switch (version + extension) { | ||||
|       case '7.4xdebug': | ||||
|         const extension_url: string = | ||||
|           'https://xdebug.org/files/php_xdebug-2.8.0-7.4-vc15.dll'; | ||||
|         install_command = | ||||
|           'Invoke-WebRequest -Uri ' + | ||||
|           extension_url + | ||||
|           ' -OutFile C:\\tools\\php\\ext\\php_xdebug.dll\n'; | ||||
|         install_command += 'Enable-PhpExtension xdebug'; | ||||
|   const extensions: Array<string> = await utils.extensionArray(extension_csv); | ||||
|   let script = '\n'; | ||||
|   await utils.asyncForEach(extensions, async function (extension: string) { | ||||
|     const [extension_name, stability]: string[] = extension.split('-'); | ||||
|     const version_extension: string = version + extension; | ||||
|     switch (true) { | ||||
|       // match pre-release versions | ||||
|       case /.+-(beta|alpha|devel|snapshot)/.test(extension): | ||||
|         script += '\nAdd-Extension ' + extension_name + ' ' + stability; | ||||
|         break; | ||||
|       // match 5.6mysql, 5.6mysqli, 5.6mysqlnd | ||||
|       case /^5\.6(mysql|mysqli|mysqlnd)$/.test(version_extension): | ||||
|         script += | ||||
|           '\nAdd-Extension mysql\nAdd-Extension mysqli\nAdd-Extension mysqlnd'; | ||||
|         break; | ||||
|       // match 7.2xdebug2 to 7.4xdebug2 | ||||
|       case /7\.[2-4]xdebug2/.test(version_extension): | ||||
|         script += '\nAdd-Extension xdebug stable 2.9.8'; | ||||
|         break; | ||||
|       // match 7.0mysql..8.0mysql | ||||
|       // match 7.0mysqli..8.0mysqli | ||||
|       // match 7.0mysqlnd..8.0mysqlnd | ||||
|       case /[7-8]\.\d(mysql|mysqli|mysqlnd)$/.test(version_extension): | ||||
|         script += '\nAdd-Extension mysqli\nAdd-Extension mysqlnd'; | ||||
|         break; | ||||
|       // match sqlite | ||||
|       case /^sqlite$/.test(extension): | ||||
|         extension = 'sqlite3'; | ||||
|         script += '\nAdd-Extension ' + extension; | ||||
|         break; | ||||
|       // match 7.0phalcon3...7.3phalcon3 and 7.2phalcon4...7.4phalcon4 | ||||
|       case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension): | ||||
|         script += | ||||
|           '\n& ' + | ||||
|           path.join(__dirname, '../src/scripts/ext/phalcon.ps1') + | ||||
|           ' ' + | ||||
|           extension + | ||||
|           ' ' + | ||||
|           version + | ||||
|           '\n'; | ||||
|         break; | ||||
|       case '7.2xdebug': | ||||
|       default: | ||||
|         install_command = 'Install-PhpExtension ' + extension; | ||||
|         script += '\nAdd-Extension ' + extension; | ||||
|         break; | ||||
|     } | ||||
|     script += | ||||
|       '\nAdd-Extension ' + | ||||
|       extension + | ||||
|       ' "' + | ||||
|       install_command + | ||||
|       '" ' + | ||||
|       (await utils.getExtensionPrefix(extension)); | ||||
|   }); | ||||
|   return script; | ||||
| } | ||||
| @ -127,56 +127,109 @@ export async function addExtensionWindows( | ||||
|  * | ||||
|  * @param extension_csv | ||||
|  * @param version | ||||
|  * @param pipe | ||||
|  */ | ||||
| export async function addExtensionLinux( | ||||
|   extension_csv: string, | ||||
|   version: string | ||||
|   version: string, | ||||
|   pipe: string | ||||
| ): Promise<string> { | ||||
|   let extensions: Array<string> = await utils.extensionArray(extension_csv); | ||||
|   let script: string = '\n'; | ||||
|   await utils.asyncForEach(extensions, async function(extension: string) { | ||||
|     extension = extension.toLowerCase(); | ||||
|     // add script to enable extension is already installed along with php | ||||
|  | ||||
|     let install_command: string = ''; | ||||
|     switch (version + extension) { | ||||
|       case '7.2phalcon3': | ||||
|       case '7.3phalcon3': | ||||
|         install_command = | ||||
|           'sh ' + | ||||
|           path.join(__dirname, '../src/scripts/phalcon.sh') + | ||||
|           ' master ' + | ||||
|           version + | ||||
|           ' >/dev/null 2>&1'; | ||||
|         break; | ||||
|       case '7.2phalcon4': | ||||
|       case '7.3phalcon4': | ||||
|       case '7.4phalcon4': | ||||
|         install_command = | ||||
|           'sh ' + | ||||
|           path.join(__dirname, '../src/scripts/phalcon.sh') + | ||||
|           ' 4.0.x ' + | ||||
|           version + | ||||
|           ' >/dev/null 2>&1'; | ||||
|   const extensions: Array<string> = await utils.extensionArray(extension_csv); | ||||
|   let script = '\n'; | ||||
|   await utils.asyncForEach(extensions, async function (extension: string) { | ||||
|     const version_extension: string = version + extension; | ||||
|     const [extension_name, stability]: string[] = extension.split('-'); | ||||
|     const ext_prefix = await utils.getExtensionPrefix(extension_name); | ||||
|     const command_prefix = 'sudo $debconf_fix apt-get install -y php'; | ||||
|     let command = ''; | ||||
|     switch (true) { | ||||
|       // match pre-release versions | ||||
|       case /.+-(beta|alpha|devel|snapshot)/.test(extension): | ||||
|         script += | ||||
|           '\nadd_unstable_extension ' + | ||||
|           extension_name + | ||||
|           ' ' + | ||||
|           stability + | ||||
|           ' ' + | ||||
|           ext_prefix; | ||||
|         return; | ||||
|       // match 5.6gearman..7.4gearman | ||||
|       case /^((5\.6)|(7\.[0-4]))gearman$/.test(version_extension): | ||||
|         script += | ||||
|           '\n. ' + path.join(__dirname, '../src/scripts/ext/gearman.sh'); | ||||
|         return; | ||||
|       // match 7.0phalcon3...7.3phalcon3 or 7.2phalcon4...7.4phalcon4 | ||||
|       case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension): | ||||
|         script += | ||||
|           '\nbash ' + | ||||
|           path.join(__dirname, '../src/scripts/ext/phalcon.sh') + | ||||
|           ' ' + | ||||
|           extension + | ||||
|           ' ' + | ||||
|           version; | ||||
|         return; | ||||
|       // match 7.2xdebug2 to 7.4xdebug2 | ||||
|       case /^7\.[2-4]xdebug2$/.test(version_extension): | ||||
|         script += '\nadd_pecl_extension xdebug 2.9.8 ' + ext_prefix; | ||||
|         return; | ||||
|       // match sqlite | ||||
|       case /^sqlite$/.test(extension): | ||||
|         extension = 'sqlite3'; | ||||
|         command = command_prefix + version + '-' + extension + pipe; | ||||
|         break; | ||||
|       default: | ||||
|         install_command = | ||||
|           'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y php' + | ||||
|         command = | ||||
|           command_prefix + | ||||
|           version + | ||||
|           '-' + | ||||
|           extension.replace('pdo_', '').replace('pdo-', '') + | ||||
|           ' >/dev/null 2>&1 || sudo pecl install ' + | ||||
|           extension + | ||||
|           ' >/dev/null 2>&1'; | ||||
|           pipe; | ||||
|         break; | ||||
|     } | ||||
|     script += | ||||
|       '\nadd_extension ' + | ||||
|       extension + | ||||
|       ' "' + | ||||
|       install_command + | ||||
|       '" ' + | ||||
|       (await utils.getExtensionPrefix(extension)); | ||||
|       '\nadd_extension ' + extension + ' "' + command + '" ' + ext_prefix; | ||||
|   }); | ||||
|   return script; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Install and enable extensions | ||||
|  * | ||||
|  * @param extension_csv | ||||
|  * @param version | ||||
|  * @param os_version | ||||
|  * @param no_step | ||||
|  */ | ||||
| export async function addExtension( | ||||
|   extension_csv: string, | ||||
|   version: string, | ||||
|   os_version: string, | ||||
|   no_step = false | ||||
| ): Promise<string> { | ||||
|   const pipe: string = await utils.suppressOutput(os_version); | ||||
|   let script = '\n'; | ||||
|   switch (no_step) { | ||||
|     case true: | ||||
|       script += (await utils.stepLog('Setup Extensions', os_version)) + pipe; | ||||
|       break; | ||||
|     case false: | ||||
|     default: | ||||
|       script += await utils.stepLog('Setup Extensions', os_version); | ||||
|       break; | ||||
|   } | ||||
|  | ||||
|   switch (os_version) { | ||||
|     case 'win32': | ||||
|       return script + (await addExtensionWindows(extension_csv, version)); | ||||
|     case 'darwin': | ||||
|       return script + (await addExtensionDarwin(extension_csv, version)); | ||||
|     case 'linux': | ||||
|       return script + (await addExtensionLinux(extension_csv, version, pipe)); | ||||
|     default: | ||||
|       return await utils.log( | ||||
|         'Platform ' + os_version + ' is not supported', | ||||
|         os_version, | ||||
|         'error' | ||||
|       ); | ||||
|   } | ||||
| } | ||||
|  | ||||
| @ -1,8 +1,9 @@ | ||||
| import {exec} from '@actions/exec/lib/exec'; | ||||
| import {exec} from '@actions/exec'; | ||||
| import * as core from '@actions/core'; | ||||
| import * as config from './config'; | ||||
| import * as coverage from './coverage'; | ||||
| import * as extensions from './extensions'; | ||||
| import * as tools from './tools'; | ||||
| import * as utils from './utils'; | ||||
|  | ||||
| /** | ||||
| @ -18,20 +19,33 @@ export async function build( | ||||
|   os_version: string | ||||
| ): Promise<string> { | ||||
|   // taking inputs | ||||
|   let extension_csv: string = await utils.getInput('extension-csv', false); | ||||
|   let ini_values_csv: string = await utils.getInput('ini-values-csv', false); | ||||
|   let coverage_driver: string = await utils.getInput('coverage', false); | ||||
|   const name = 'setup-php'; | ||||
|   const url = 'https://setup-php.com/support'; | ||||
|   const extension_csv: string = | ||||
|     (await utils.getInput('extensions', false)) || | ||||
|     (await utils.getInput('extension', false)) || | ||||
|     (await utils.getInput('extension-csv', false)); | ||||
|   const ini_values_csv: string = | ||||
|     (await utils.getInput('ini-values', false)) || | ||||
|     (await utils.getInput('ini-values-csv', false)); | ||||
|   const coverage_driver: string = await utils.getInput('coverage', false); | ||||
|   const tools_csv: string = await utils.getInput('tools', false); | ||||
|  | ||||
|   let script: string = await utils.readScript(filename); | ||||
|   script += await tools.addTools(tools_csv, version, os_version); | ||||
|  | ||||
|   let script: string = await utils.readScript(filename, version, os_version); | ||||
|   if (extension_csv) { | ||||
|     script += await extensions.addExtension(extension_csv, version, os_version); | ||||
|   } | ||||
|   if (ini_values_csv) { | ||||
|     script += await config.addINIValues(ini_values_csv, os_version); | ||||
|   } | ||||
|   if (coverage_driver) { | ||||
|     script += await coverage.addCoverage(coverage_driver, version, os_version); | ||||
|   } | ||||
|   if (ini_values_csv) { | ||||
|     script += await config.addINIValues(ini_values_csv, os_version); | ||||
|   } | ||||
|  | ||||
|   script += '\n' + (await utils.stepLog('Support this project', os_version)); | ||||
|   script += '\n' + (await utils.addLog('$tick', name, url, os_version)); | ||||
|  | ||||
|   return await utils.writeScript(filename, script); | ||||
| } | ||||
| @ -39,33 +53,52 @@ export async function build( | ||||
| /** | ||||
|  * Run the script | ||||
|  */ | ||||
| export async function run() { | ||||
| export async function run(): Promise<void> { | ||||
|   try { | ||||
|     let os_version: string = process.platform; | ||||
|     let version: string = await utils.getInput('php-version', true); | ||||
|     // check the os version and run the respective script | ||||
|     let script_path: string = ''; | ||||
|     switch (os_version) { | ||||
|       case 'darwin': | ||||
|         script_path = await build(os_version + '.sh', version, os_version); | ||||
|         await exec('sh ' + script_path + ' ' + version + ' ' + __dirname); | ||||
|         break; | ||||
|       case 'linux': | ||||
|         let pecl: string = await utils.getInput('pecl', false); | ||||
|         script_path = await build(os_version + '.sh', version, os_version); | ||||
|         await exec('sh ' + script_path + ' ' + version + ' ' + pecl); | ||||
|         break; | ||||
|       case 'win32': | ||||
|         script_path = await build('win32.ps1', version, os_version); | ||||
|         await exec( | ||||
|           'pwsh ' + script_path + ' -version ' + version + ' -dir ' + __dirname | ||||
|         ); | ||||
|         break; | ||||
|     if ((await utils.readEnv('ImageOS')) == 'ubuntu16') { | ||||
|       core.setFailed( | ||||
|         'setup-php is not supported on Ubuntu 16.04. Please upgrade to Ubuntu 18.04 or Ubuntu 20.04 - https://setup-php.com/i/452' | ||||
|       ); | ||||
|       return; | ||||
|     } | ||||
|     core.warning( | ||||
|       'setup-php v1 is deprecated.\nPlease upgrade to v2 - https://setup-php.com/w/Switch-to-v2' | ||||
|     ); | ||||
|     const version: string = await utils.parseVersion( | ||||
|       await utils.getInput('php-version', true) | ||||
|     ); | ||||
|     if (parseFloat(version) < 5.6 || parseFloat(version) > 8.0) { | ||||
|       core.setFailed( | ||||
|         `setup-php v1 supports only PHP 5.6 to 8.0.\nPlease upgrade to v2 - https://setup-php.com/w/Switch-to-v2` | ||||
|       ); | ||||
|       return; | ||||
|     } | ||||
|     if (version) { | ||||
|       const os_version: string = process.platform; | ||||
|       // check the os version and run the respective script | ||||
|       let script_path = ''; | ||||
|       switch (os_version) { | ||||
|         case 'darwin': | ||||
|         case 'linux': | ||||
|           script_path = await build(os_version + '.sh', version, os_version); | ||||
|           await exec('bash ' + script_path + ' ' + version + ' ' + __dirname); | ||||
|           break; | ||||
|         case 'win32': | ||||
|           script_path = await build('win32.ps1', version, os_version); | ||||
|           await exec('pwsh ' + script_path + ' ' + version + ' ' + __dirname); | ||||
|           break; | ||||
|       } | ||||
|     } else { | ||||
|       core.setFailed('Unable to get the PHP version'); | ||||
|     } | ||||
|   } catch (error) { | ||||
|     core.setFailed(error.message); | ||||
|     core.setFailed(error as Error); | ||||
|   } | ||||
| } | ||||
|  | ||||
| // call the run function | ||||
| run(); | ||||
| (async () => { | ||||
|   await run(); | ||||
| })().catch(error => { | ||||
|   core.setFailed(error.message); | ||||
| }); | ||||
|  | ||||
| @ -1,115 +0,0 @@ | ||||
| tick="✓" | ||||
| cross="✗" | ||||
|  | ||||
| step_log() { | ||||
|   message=$1 | ||||
|   printf "\n\033[90;1m==> \033[0m\033[37;1m%s\033[0m\n" "$message" | ||||
| } | ||||
|  | ||||
| add_log() { | ||||
|   mark=$1 | ||||
|   subject=$2 | ||||
|   message=$3 | ||||
|   if [ "$mark" = "$tick" ]; then | ||||
|     printf "\033[32;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s\033[0m\n" "$mark" "$subject" "$message" | ||||
|   else | ||||
|     printf "\033[31;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s\033[0m\n" "$mark" "$subject" "$message" | ||||
|   fi | ||||
| } | ||||
| version='7.4.0RC5' | ||||
| step_log "Setup dependencies" | ||||
| for package in pkg-config autoconf bison re2c openssl@1.1 krb5 enchant libffi freetype intltool icu4c libiconv t1lib gd libzip gmp tidyp libxml2 libxslt postgresql curl; | ||||
| do | ||||
|   brew install "$package" >/dev/null 2>&1 | ||||
|   add_log "$tick" "$package" "Installed" | ||||
| done | ||||
| brew link icu4c gettext --force >/dev/null 2>&1 | ||||
|  | ||||
| for package in gettext gmp krb5 icu4c bison openssl@1.1 libxml2 libffi libxslt libiconv pkgconfig enchant krb5 readline libedit freetype; | ||||
| do | ||||
|   caps_package=$(echo "$package" | tr '[:lower:]' '[:upper:]') | ||||
|   { | ||||
|   echo 'export PATH="/usr/local/opt/'"$package"'/bin:$PATH"' | ||||
|   echo 'export PKG_CONFIG_PATH="/usr/local/opt/'$package'/lib/pkgconfig:$PKG_CONFIG_PATH"' | ||||
|   echo 'export '"$caps_package"'_LIBS="-L/usr/local/opt/'$package'/lib"' | ||||
|   echo 'export '"$caps_package"'_CFLAGS="-I/usr/local/opt/'$package'/include"' | ||||
|   } >> ~/.bash_profile; | ||||
| done | ||||
| { | ||||
| echo 'export ICONV_LIBS="-L/usr/local/opt/libiconv/lib"' | ||||
| echo 'export ICONV_CFLAGS="-I/usr/local/opt/libiconv/include"' | ||||
| echo 'export LIBXML_LIBS="-L/usr/local/opt/libxml2/lib"' | ||||
| echo 'export LIBXML_CFLAGS="-I/usr/local/opt/libxml2/include"' | ||||
| echo 'export ICU_LIBS="-L/usr/local/opt/icu4c/lib"' | ||||
| echo 'export ICU_CFLAGS="-I/usr/local/opt/icu4c/include"' | ||||
| echo 'export OPENSSL_LIBS="-L/usr/local/opt/openssl@1.1/lib -lcrypto"' | ||||
| echo 'export OPENSSL_CFLAGS="-I/usr/local/opt/openssl@1.1/include"' | ||||
| echo 'export OPENSSL_ROOT_DIR="/usr/local/opt/openssl@1.1/"' | ||||
| echo 'export OPENSSL_LIB_DIR="/usr/local/opt/openssl@1.1/lib"' | ||||
| echo 'export OPENSSL_INCLUDE_DIR="/usr/local/opt/openssl@1.1/include"' | ||||
| echo 'export PKG_CONFIG="/usr/local/opt/pkgconfig/bin/pkg-config"' | ||||
| echo 'export EXTRA_LIBS="/usr/local/opt/readline/lib/libhistory.dylib | ||||
| /usr/local/opt/readline/lib/libreadline.dylib | ||||
| /usr/local/opt/openssl@1.1/lib/libssl.dylib | ||||
| /usr/local/opt/openssl@1.1/lib/libcrypto.dylib | ||||
| /usr/local/opt/icu4c/lib/libicudata.dylib | ||||
| /usr/local/opt/icu4c/lib/libicui18n.dylib | ||||
| /usr/local/opt/icu4c/lib/libicuio.dylib | ||||
| /usr/local/opt/icu4c/lib/libicutu.dylib | ||||
| /usr/local/opt/icu4c/lib/libicuuc.dylib"' | ||||
| } >> ~/.bash_profile | ||||
| config_file=$2/../src/configs/config.yaml | ||||
|  | ||||
| step_log "Setup PHPBrew" | ||||
| curl -L -O https://github.com/phpbrew/phpbrew/raw/master/phpbrew >/dev/null 2>&1 | ||||
| chmod +x ./phpbrew | ||||
| sudo mv phpbrew /usr/local/bin/phpbrew | ||||
| sudo mkdir -p /opt/phpbrew | ||||
| sudo mkdir -p /usr/local/lib | ||||
| sudo mkdir -p /usr/local/bin | ||||
| sudo phpbrew init --root=/opt/phpbrew --config="$config_file" >/dev/null 2>&1 | ||||
| sudo chmod -R 777 /opt/phpbrew | ||||
| export PHPBREW_ROOT=/opt/phpbrew | ||||
| export PHPBREW_HOME=/opt/phpbrew | ||||
| echo "[[ -e ~/.phpbrew/bashrc ]] && source ~/.phpbrew/bashrc" >> ~/.bashrc | ||||
| add_log "$tick" "PHPBrew" "Installed" | ||||
|  | ||||
| source ~/.bash_profile >/dev/null 2>&1 | ||||
| source ~/.bashrc >/dev/null 2>&1 | ||||
|  | ||||
| step_log "Setup PHP and Composer" | ||||
| phpbrew install -j 6 $version +dev >/dev/null 2>&1 | ||||
| phpbrew switch $version | ||||
| sudo ln -sf /opt/phpbrew/php/php-$version/bin/* /usr/local/bin/ | ||||
| sudo ln -sf /opt/phpbrew/php/php-$version/etc/php.ini /etc/php.ini | ||||
| ini_file=$(php --ini | grep "Loaded Configuration" | sed -e "s|.*:s*||" | sed "s/ //g") | ||||
| ext_dir=$(php -i | grep "extension_dir => /opt" | sed -e "s|.*=> s*||") | ||||
| pecl config-set php_ini "$ini_file" >/dev/null 2>&1 | ||||
| sudo chmod 777 "$ini_file" | ||||
| brew install composer >/dev/null 2>&1 | ||||
|  | ||||
| add_log "$tick" "PHP" "Installed PHP$version" | ||||
| add_log "$tick" "Composer" "Installed" | ||||
|  | ||||
| add_extension() { | ||||
|   extension=$1 | ||||
|   install_command=$2 | ||||
|   prefix=$3 | ||||
|   if ! php -m | grep -i -q "$extension" && [ -e "$ext_dir/$extension.so" ]; then | ||||
|     echo "$prefix=$extension" >>"$ini_file" && add_log "$tick" "$extension" "Enabled" | ||||
|   elif php -m | grep -i -q "$extension"; then | ||||
|     add_log "$tick" "$extension" "Enabled" | ||||
|   elif ! php -m | grep -i -q "$extension"; then | ||||
|     exists=$(curl -sL https://pecl.php.net/json.php?package="$extension" -w "%{http_code}" -o /dev/null) | ||||
|     if [ "$exists" = "200" ]; then | ||||
|       ( | ||||
|         eval "$install_command" && \ | ||||
|         add_log "$tick" "$extension" "Installed and enabled" | ||||
|       ) || add_log "$cross" "$extension" "Could not install $extension on PHP$version" | ||||
|     else | ||||
|       if ! php -m | grep -i -q "$extension"; then | ||||
|         add_log "$cross" "$extension" "Could not find $extension for PHP$version on PECL" | ||||
|       fi | ||||
|     fi | ||||
|   fi | ||||
| } | ||||
| @ -1,11 +1,10 @@ | ||||
| tick="✓" | ||||
| cross="✗" | ||||
|  | ||||
| # Function to log start of a operation | ||||
| step_log() { | ||||
|   message=$1 | ||||
|   printf "\n\033[90;1m==> \033[0m\033[37;1m%s\033[0m\n" "$message" | ||||
| } | ||||
|  | ||||
| # Function to log result of a operation | ||||
| add_log() { | ||||
|   mark=$1 | ||||
|   subject=$2 | ||||
| @ -17,42 +16,334 @@ add_log() { | ||||
|   fi | ||||
| } | ||||
|  | ||||
| version=$1 | ||||
| export HOMEBREW_NO_INSTALL_CLEANUP=TRUE | ||||
| if [ "$1" = "5.6" ] || [ "$1" = "7.0" ]; then | ||||
|   brew tap exolnet/homebrew-deprecated >/dev/null 2>&1 | ||||
| fi | ||||
| step_log "Setup PHP and Composer" | ||||
| brew install php@"$1" composer >/dev/null 2>&1 | ||||
| brew link --force --overwrite php@"$1" >/dev/null 2>&1 | ||||
| ini_file=$(php -d "date.timezone=UTC" --ini | grep "Loaded Configuration" | sed -e "s|.*:s*||" | sed "s/ //g") | ||||
| echo "date.timezone=UTC" >> "$ini_file" | ||||
| ext_dir=$(php -i | grep "extension_dir => /usr" | sed -e "s|.*=> s*||") | ||||
| sudo chmod 777 "$ini_file" | ||||
| mkdir -p "$(pecl config-get ext_dir)" | ||||
| composer global require hirak/prestissimo >/dev/null 2>&1 | ||||
| add_log "$tick" "PHP" "Installed PHP$version" | ||||
| add_log "$tick" "Composer" "Installed" | ||||
| # Function to remove extensions | ||||
| remove_extension() { | ||||
|   local extension=$1 | ||||
|   sudo sed -Ei '' "/=(.*\/)?\"?$extension/d" "$ini_file" | ||||
|   sudo rm -rf "$scan_dir"/*"$extension"*  | ||||
|   sudo rm -rf "$ext_dir"/"$extension".so  | ||||
| } | ||||
|  | ||||
| add_extension() { | ||||
|   extension=$1 | ||||
|   install_command=$2 | ||||
| # Function to test if extension is loaded | ||||
| check_extension() { | ||||
|   local extension=$1 | ||||
|   if [ "$extension" != "mysql" ]; then | ||||
|     php -m | grep -i -q -w "$extension" | ||||
|   else | ||||
|     php -m | grep -i -q "$extension" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to install PECL extensions and accept default options | ||||
| pecl_install() { | ||||
|   local extension=$1 | ||||
|   yes '' | sudo pecl install -f "$extension"  | ||||
| } | ||||
|  | ||||
| # Function to get the PECL version | ||||
| get_pecl_version() { | ||||
|   local extension=$1 | ||||
|   stability="$(echo "$2" | grep -m 1 -Eio "(alpha|beta|rc|snapshot|preview)")" | ||||
|   pecl_rest='https://pecl.php.net/rest/r/' | ||||
|   response=$(curl "${curl_opts[@]}" "$pecl_rest$extension"/allreleases.xml) | ||||
|   pecl_version=$(echo "$response" | grep -m 1 -Eio "([0-9]+\.[0-9]+\.[0-9]+${stability}[0-9]+)") | ||||
|   if [ ! "$pecl_version" ]; then | ||||
|     pecl_version=$(echo "$response" | grep -m 1 -Eo "([0-9]+\.[0-9]+\.[0-9]+)") | ||||
|   fi | ||||
|   echo "$pecl_version" | ||||
| } | ||||
|  | ||||
| # Function to install a PECL version | ||||
| add_pecl_extension() { | ||||
|   local extension=$1 | ||||
|   pecl_version=$2 | ||||
|   prefix=$3 | ||||
|   if ! php -m | grep -i -q "$extension" && [ -e "$ext_dir/$extension.so" ]; then | ||||
|     echo "$prefix=$extension" >>"$ini_file" && add_log $tick "$extension" "Enabled" | ||||
|   elif php -m | grep -i -q "$extension"; then | ||||
|   if [[ $pecl_version =~ .*(alpha|beta|rc|snapshot|preview).* ]]; then | ||||
|     pecl_version=$(get_pecl_version "$extension" "$pecl_version") | ||||
|   fi | ||||
|   if ! check_extension "$extension" && [ -e "$ext_dir/$extension.so" ]; then | ||||
|     echo "$prefix=$ext_dir/$extension.so" >>"$ini_file" | ||||
|   fi | ||||
|   ext_version=$(php -r "echo phpversion('$extension');") | ||||
|   if [ "$ext_version" = "$pecl_version" ]; then | ||||
|     add_log "$tick" "$extension" "Enabled" | ||||
|   elif ! php -m | grep -i -q "$extension"; then | ||||
|     exists=$(curl -sL https://pecl.php.net/json.php?package="$extension" -w "%{http_code}" -o /dev/null) | ||||
|     if [ "$exists" = "200" ]; then | ||||
|       ( | ||||
|         eval "$install_command" && \ | ||||
|         add_log "$tick" "$extension" "Installed and enabled" | ||||
|       ) || add_log "$cross" "$extension" "Could not install $extension on PHP$version" | ||||
|     else | ||||
|       if ! php -m | grep -i -q "$extension"; then | ||||
|         add_log "$cross" "$extension" "Could not find $extension for PHP$version on PECL" | ||||
|       fi | ||||
|   else | ||||
|     remove_extension "$extension" | ||||
|     ( | ||||
|       pecl_install "$extension-$pecl_version"  && | ||||
|       check_extension "$extension" && | ||||
|       add_log "$tick" "$extension" "Installed and enabled" | ||||
|     ) || add_log "$cross" "$extension" "Could not install $extension-$pecl_version on PHP $semver" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to fetch a brew tap | ||||
| fetch_brew_tap() { | ||||
|   tap=$1 | ||||
|   tap_user=$(dirname "$tap") | ||||
|   tap_name=$(basename "$tap") | ||||
|   mkdir -p "$tap_dir/$tap_user" | ||||
|   sudo curl "${curl_opts[@]}" "https://github.com/$tap/archive/master.tar.gz" | sudo tar -xzf - -C "$tap_dir/$tap_user" | ||||
|   if [ -d "$tap_dir/$tap_user/$tap_name-master" ]; then | ||||
|     sudo mv "$tap_dir/$tap_user/$tap_name-master" "$tap_dir/$tap_user/$tap_name" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to add a brew tap. | ||||
| add_brew_tap() { | ||||
|   tap=$1 | ||||
|   if ! [ -d "$tap_dir/$tap" ]; then | ||||
|     fetch_brew_tap "$tap"  | ||||
|     if ! [ -d "$tap_dir/$tap" ]; then | ||||
|       brew tap "$tap"  | ||||
|     fi | ||||
|   fi | ||||
| } | ||||
| } | ||||
|  | ||||
| # Function to install a php extension from shivammathur/extensions tap. | ||||
| add_brew_extension() { | ||||
|   formula=$1 | ||||
|   extension=$(grep "$formula=" "$dist"/../src/configs/brew_extensions | cut -d '=' -f 2) | ||||
|   [[ -z "$extension" ]] && extension="$(echo "$formula" | sed -E "s/pecl_|[0-9]//g")" | ||||
|   add_brew_tap shivammathur/homebrew-php | ||||
|   add_brew_tap shivammathur/homebrew-extensions | ||||
|   sudo mv "$tap_dir"/shivammathur/homebrew-extensions/.github/deps/"$formula"/* "$tap_dir/homebrew/homebrew-core/Formula/" 2>/dev/null || true | ||||
|   brew install "$formula@$version" | ||||
|   sudo cp "$brew_prefix/opt/$formula@$version/$extension.so" "$ext_dir" | ||||
| } | ||||
|  | ||||
| # Function to setup extensions | ||||
| add_extension() { | ||||
|   local extension=$1 | ||||
|   install_command=$2 | ||||
|   prefix=$3 | ||||
|   if ! check_extension "$extension" && [ -e "$ext_dir/$extension.so" ]; then | ||||
|     echo "$prefix=$ext_dir/$extension.so" >>"$ini_file" && add_log "$tick" "$extension" "Enabled" | ||||
|   elif check_extension "$extension"; then | ||||
|     add_log "$tick" "$extension" "Enabled" | ||||
|   elif ! check_extension "$extension"; then | ||||
|     ( | ||||
|       eval "$install_command"  && | ||||
|       check_extension "$extension" && | ||||
|       add_log "$tick" "$extension" "Installed and enabled" | ||||
|     ) || add_log "$cross" "$extension" "Could not install $extension on PHP $semver" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to pre-release extensions using PECL | ||||
| add_unstable_extension() { | ||||
|   local extension=$1 | ||||
|   stability=$2 | ||||
|   prefix=$3 | ||||
|   pecl_version=$(get_pecl_version "$extension" "$stability") | ||||
|   add_pecl_extension "$extension" "$pecl_version" "$prefix" | ||||
| } | ||||
|  | ||||
| # Function to configure composer | ||||
| configure_composer() { | ||||
|   tool_path=$1 | ||||
|   sudo ln -sf "$tool_path" "$tool_path.phar" | ||||
|   php -r "try {\$p=new Phar('$tool_path.phar', 0);exit(0);} catch(Exception \$e) {exit(1);}" | ||||
|   if [ $? -eq 1 ]; then | ||||
|     add_log "$cross" "composer" "Could not download composer" | ||||
|     exit 1; | ||||
|   fi | ||||
|   if ! [ -d "$composer_home" ]; then | ||||
|     sudo -u "$(id -un)" -g "$(id -gn)" mkdir -p -m=00755 "$composer_home" | ||||
|   else | ||||
|     sudo chown -R "$(id -un)":"$(id -gn)" "$composer_home" | ||||
|   fi | ||||
|   if ! [ -e "$composer_json" ]; then | ||||
|     echo '{}' | tee "$composer_json" >/dev/null | ||||
|     chmod 644 "$composer_json" | ||||
|   fi | ||||
|   composer -q config -g process-timeout 0 | ||||
|   echo "$composer_bin" >> "$GITHUB_PATH" | ||||
|   if [ -n "$COMPOSER_TOKEN" ]; then | ||||
|     composer -q config -g github-oauth.github.com "$COMPOSER_TOKEN" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to setup a remote tool. | ||||
| add_tool() { | ||||
|   url=$1 | ||||
|   tool=$2 | ||||
|   tool_path="$tool_path_dir/$tool" | ||||
|   if [ ! -e "$tool_path" ]; then | ||||
|     rm -rf "$tool_path" | ||||
|   fi | ||||
|   if [ "$tool" = "composer" ]; then | ||||
|     IFS="," read -r -a urls <<< "$url" | ||||
|     status_code=$(sudo curl -f -w "%{http_code}" -o "$tool_path" "${curl_opts[@]}" "${urls[0]}") || | ||||
|     status_code=$(sudo curl -w "%{http_code}" -o "$tool_path" "${curl_opts[@]}" "${urls[1]}") | ||||
|   else | ||||
|     status_code=$(sudo curl -w "%{http_code}" -o "$tool_path" "${curl_opts[@]}" "$url") | ||||
|   fi | ||||
|   if [ "$status_code" != "200" ] && [[ "$url" =~ .*github.com.*releases.*latest.* ]]; then | ||||
|     url="${url//releases\/latest\/download/releases/download/$(curl "${curl_opts[@]}" "$(echo "$url" | cut -d '/' -f '1-5')/releases" | grep -Eo -m 1 "([0-9]+\.[0-9]+\.[0-9]+)/$(echo "$url" | sed -e "s/.*\///")" | cut -d '/' -f 1)}" | ||||
|     status_code=$(sudo curl -w "%{http_code}" -o "$tool_path" "${curl_opts[@]}" "$url") | ||||
|   fi | ||||
|   if [ "$status_code" = "200" ]; then | ||||
|     sudo chmod a+x "$tool_path" | ||||
|     if [ "$tool" = "composer" ]; then | ||||
|       configure_composer "$tool_path" | ||||
|     elif [ "$tool" = "phan" ]; then | ||||
|       add_extension fileinfo "pecl_install fileinfo" extension  | ||||
|       add_extension ast "pecl_install ast" extension  | ||||
|     elif [ "$tool" = "phive" ]; then | ||||
|       add_extension curl "pecl_install curl" extension  | ||||
|       add_extension mbstring "pecl_install mbstring" extension  | ||||
|       add_extension xml "pecl_install xml" extension  | ||||
|     elif [ "$tool" = "cs2pr" ]; then | ||||
|       sudo sed -i '' 's/exit(9)/exit(0)/' "$tool_path" | ||||
|       tr -d '\r' < "$tool_path" | sudo tee "$tool_path.tmp"  && sudo mv "$tool_path.tmp" "$tool_path" | ||||
|       sudo chmod a+x "$tool_path" | ||||
|     fi | ||||
|     add_log "$tick" "$tool" "Added" | ||||
|   else | ||||
|     add_log "$cross" "$tool" "Could not setup $tool" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to add a tool using composer | ||||
| add_composertool() { | ||||
|   tool=$1 | ||||
|   release=$2 | ||||
|   prefix=$3 | ||||
|   ( | ||||
|     sudo rm -f "$composer_lock"  || true | ||||
|     composer global require "$prefix$release"  && | ||||
|     add_log "$tick" "$tool" "Added" | ||||
|   ) || add_log "$cross" "$tool" "Could not setup $tool" | ||||
|   if [ -e "$composer_bin/composer" ]; then | ||||
|     sudo cp -p "$tool_path_dir/composer" "$composer_bin" | ||||
|   fi | ||||
|   if [ "$tool" = "codeception" ]; then | ||||
|     sudo ln -s "$composer_bin"/codecept "$composer_bin"/codeception | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to configure PECL | ||||
| configure_pecl() { | ||||
|   for tool in pear pecl; do | ||||
|     sudo "$tool" config-set php_ini "$ini_file"  | ||||
|     sudo "$tool" channel-update "$tool".php.net  | ||||
|   done | ||||
| } | ||||
|  | ||||
| # Function to log PECL, it is installed along with PHP | ||||
| add_pecl() { | ||||
|   add_log "$tick" "PECL" "Added" | ||||
| } | ||||
|  | ||||
| # Function to backup all libraries of a formula | ||||
| link_libraries() { | ||||
|   formula=$1 | ||||
|   formula_prefix="$(brew --prefix "$formula")" | ||||
|   sudo mkdir -p "$formula_prefix"/lib | ||||
|   for lib in "$formula_prefix"/lib/*.dylib; do | ||||
|     lib_name=$(basename "$lib") | ||||
|     sudo cp -a "$lib" "$brew_prefix/lib/$lib_name" 2>/dev/null || true | ||||
|   done | ||||
| } | ||||
|  | ||||
| patch_brew() { | ||||
|   formula_installer="$brew_repo"/Library/Homebrew/formula_installer.rb | ||||
|   code=" keg.link\(verbose: verbose\?" | ||||
|   sudo sed -Ei '' "s/$code.*/$code, overwrite: true\)/" "$formula_installer" | ||||
|   # shellcheck disable=SC2064 | ||||
|   trap "sudo sed -Ei '' 's/$code.*/$code, overwrite: overwrite?\)/' $formula_installer" exit | ||||
| } | ||||
|  | ||||
| # Helper function to update the dependencies. | ||||
| update_dependencies_helper() { | ||||
|   dependency=$1 | ||||
|   curl -o "$tap_dir/homebrew/homebrew-core/Formula/$formula.rb" "${curl_opts[@]}" "https://raw.githubusercontent.com/Homebrew/homebrew-core/master/Formula/$formula.rb" | ||||
|   link_libraries "$dependency" | ||||
| } | ||||
|  | ||||
| # Function to update dependencies | ||||
| update_dependencies() { | ||||
|   if ! [ -e /tmp/update_dependencies ]; then | ||||
|     if [ "${ImageOS:-}" != "" ] && [ "${ImageVersion:-}" != "" ]; then | ||||
|       patch_brew | ||||
|       while read -r dependency; do | ||||
|         update_dependencies_helper "$dependency" & | ||||
|         to_wait+=($!) | ||||
|       done <"$tap_dir/shivammathur/homebrew-php/.github/deps/${ImageOS:?}_${ImageVersion:?}" | ||||
|       wait "${to_wait[@]}" | ||||
|     fi | ||||
|     echo '' | sudo tee /tmp/update_dependencies  | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to get PHP version if it is already installed using Homebrew. | ||||
| get_brewed_php() { | ||||
|   php_cellar="$brew_prefix"/Cellar/php | ||||
|   if [ -d "$php_cellar" ] && ! [[ "$(find "$php_cellar" -maxdepth 1 -name "$version*" | wc -l 2>/dev/null)" -eq 0 ]]; then | ||||
|     php-config --version 2>/dev/null | cut -c 1-3 | ||||
|   else | ||||
|     echo 'false'; | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to setup PHP and composer | ||||
| setup_php() { | ||||
|   add_brew_tap shivammathur/homebrew-php | ||||
|   update_dependencies | ||||
|   brew upgrade shivammathur/php/php@"$version" 2>/dev/null || brew install shivammathur/php/php@"$version" | ||||
|   brew link --force --overwrite php@"$version" | ||||
| } | ||||
|  | ||||
| # Function to configure PHP | ||||
| configure_php() { | ||||
|   ( | ||||
|     echo -e "date.timezone=UTC\nmemory_limit=-1" | ||||
|     [[ "$version" =~ 8.0 ]] && echo -e "opcache.enable=1\nopcache.jit_buffer_size=256M\nopcache.jit=1235" | ||||
|     [[ "$version" =~ 7.[2-4]|8.0 ]] && echo -e "xdebug.mode=coverage" | ||||
|   ) | sudo tee -a "$ini_file" >/dev/null | ||||
| } | ||||
|  | ||||
| # Variables | ||||
| tick="✓" | ||||
| cross="✗" | ||||
| version=$1 | ||||
| dist=$2 | ||||
| tool_path_dir="/usr/local/bin" | ||||
| curl_opts=(-sL) | ||||
| composer_home="$HOME/.composer" | ||||
| composer_bin="$composer_home/vendor/bin" | ||||
| composer_json="$composer_home/composer.json" | ||||
| composer_lock="$composer_home/composer.lock" | ||||
| brew_prefix="$(brew --prefix)" | ||||
| brew_repo="$(brew --repository)" | ||||
| tap_dir="$brew_repo"/Library/Taps | ||||
| existing_version=$(get_brewed_php) | ||||
| export HOMEBREW_CHANGE_ARCH_TO_ARM=1 | ||||
| export HOMEBREW_DEVELOPER=1 | ||||
| export HOMEBREW_NO_INSTALL_CLEANUP=1 | ||||
| export HOMEBREW_NO_AUTO_UPDATE=1 | ||||
| export HOMEBREW_NO_INSTALLED_DEPENDENTS_CHECK=1 | ||||
|  | ||||
| # Setup PHP | ||||
| step_log "Setup PHP" | ||||
| if [ "$existing_version" != "$version" ]; then | ||||
|   setup_php  | ||||
|   status="Installed" | ||||
| else | ||||
|   status="Found" | ||||
| fi | ||||
| ini_file=$(php -d "date.timezone=UTC" --ini | grep "Loaded Configuration" | sed -e "s|.*:s*||" | sed "s/ //g") | ||||
| sudo chmod 777 "$ini_file" "$tool_path_dir" | ||||
| configure_php | ||||
| ext_dir=$(php -i | grep -Ei "extension_dir => /" | sed -e "s|.*=> s*||") | ||||
| scan_dir=$(php --ini | grep additional | sed -e "s|.*: s*||") | ||||
| sudo mkdir -m 777 -p "$ext_dir" "$HOME/.composer" | ||||
| semver=$(php -v | head -n 1 | cut -f 2 -d ' ') | ||||
| if [ "${semver%.*}" != "$version" ]; then | ||||
|   add_log "$cross" "PHP" "Could not setup PHP $version" | ||||
|   exit 1 | ||||
| fi | ||||
| configure_pecl | ||||
| sudo cp "$dist"/../src/configs/*.json "$RUNNER_TOOL_CACHE/" | ||||
| add_log "$tick" "PHP" "$status PHP $semver" | ||||
|  | ||||
							
								
								
									
										22
									
								
								src/scripts/ext/gearman.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								src/scripts/ext/gearman.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| # Helper function to add gearman extension. | ||||
| add_gearman_helper() { | ||||
|   add_ppa ondrej/pkg-gearman | ||||
|   sudo DEBIAN_FRONTEND=noninteractive apt-fast install -y libgearman-dev | ||||
|   enable_extension gearman extension | ||||
|   if ! check_extension gearman; then | ||||
|     status="Installed and enabled" | ||||
|     sudo DEBIAN_FRONTEND=noninteractive apt-fast install -y php"${version:?}"-gearman || pecl_install gearman | ||||
|     enable_extension gearman extension | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to add gearman extension. | ||||
| add_gearman() { | ||||
|   status="Enabled" | ||||
|   add_gearman_helper  | ||||
|   if check_extension gearman; then | ||||
|     add_log "${tick:?}" "gearman" "$status" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| add_gearman | ||||
							
								
								
									
										56
									
								
								src/scripts/ext/phalcon.ps1
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								src/scripts/ext/phalcon.ps1
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,56 @@ | ||||
| Param ( | ||||
|     [Parameter(Position = 0, Mandatory = $true)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidateSet('phalcon3', 'phalcon4')] | ||||
|     [string] | ||||
|     $extension, | ||||
|     [Parameter(Position = 1, Mandatory = $true)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidateLength(1, [int]::MaxValue)] | ||||
|     [string] | ||||
|     $version | ||||
| ) | ||||
|  | ||||
| # Function to install phalcon | ||||
| Function Install-Phalcon() { | ||||
|     if ($extension_version -eq '4') { | ||||
|         Install-Phpextension phalcon -MinimumStability stable -Path $php_dir | ||||
|     } else { | ||||
|         $installed = Get-Php -Path $php_dir | ||||
|         $nts = if (!$installed.ThreadSafe) { "_nts" } else { "" } | ||||
|         $match = Invoke-WebRequest -UseBasicParsing -Uri "$domain/phalcon/cphalcon/releases/v3.4.5" | Select-String -Pattern "href=`"(.*phalcon_x64_.*_php${version}_${extension_version}.*[0-9]${nts}.zip)`"" | ||||
|         $zip_file = $match.Matches[0].Groups[1].Value | ||||
|         Invoke-WebRequest -UseBasicParsing -Uri $domain/$zip_file -OutFile $ENV:RUNNER_TOOL_CACHE\phalcon.zip > $null 2>&1 | ||||
|         Expand-Archive -Path $ENV:RUNNER_TOOL_CACHE\phalcon.zip -DestinationPath $ENV:RUNNER_TOOL_CACHE\phalcon -Force > $null 2>&1 | ||||
|         Copy-Item -Path "$ENV:RUNNER_TOOL_CACHE\phalcon\php_phalcon.dll" -Destination "$ext_dir\php_phalcon.dll" | ||||
|         Enable-PhpExtension -Extension phalcon -Path $php_dir | ||||
|     } | ||||
|     printf "\033[%s;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" "32" $tick $extension "Installed and enabled" | ||||
| } | ||||
|  | ||||
| $tick = ([char]8730) | ||||
| $domain = 'https://github.com' | ||||
| $php_dir = 'C:\tools\php' | ||||
| $ext_dir = $php_dir + '\ext' | ||||
| $extension_version = $extension.substring($extension.Length - 1) | ||||
|  | ||||
| if($extension_version -eq '4') { | ||||
|     if (Test-Path $ext_dir\php_psr.dll) { | ||||
|         Enable-PhpExtension -Extension psr -Path $php_dir | ||||
|     } else { | ||||
|         Install-Phpextension psr -MinimumStability stable -Path $php_dir | ||||
|     } | ||||
| } | ||||
|  | ||||
| if(Test-Path $ext_dir\php_phalcon.dll) { | ||||
|     $phalcon = Get-PhpExtension $ext_dir\php_phalcon.dll | ||||
|     if($phalcon.Version[0] -eq $extension_version) { | ||||
|         Enable-PhpExtension -Extension phalcon -Path $php_dir | ||||
|         printf "\033[%s;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" "32" $tick $extension "Enabled" | ||||
|     } else { | ||||
|         Remove-Item $ext_dir\php_phalcon.dll | ||||
|         Install-Phalcon | ||||
|     } | ||||
| } else { | ||||
|     Install-Phalcon | ||||
| } | ||||
							
								
								
									
										71
									
								
								src/scripts/ext/phalcon.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								src/scripts/ext/phalcon.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,71 @@ | ||||
| # Function to log result of a operation | ||||
| add_log() { | ||||
|   mark=$1 | ||||
|   subject=$2 | ||||
|   message=$3 | ||||
|   if [ "$mark" = "$tick" ]; then | ||||
|     printf "\033[32;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s\033[0m\n" "$mark" "$subject" "$message" | ||||
|   else | ||||
|     printf "\033[31;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s\033[0m\n" "$mark" "$subject" "$message" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to update php ppa | ||||
| update_ppa() { | ||||
|   if [ "$ppa_updated" = "false" ]; then | ||||
|     find /etc/apt/sources.list.d -type f -name 'ondrej-ubuntu-php*.list' -exec sudo DEBIAN_FRONTEND=noninteractive apt-get update -o Dir::Etc::sourcelist="{}" ';'  | ||||
|     ppa_updated="true" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to install phalcon | ||||
| install_phalcon() { | ||||
|   local extension=$1 | ||||
|   version=$2 | ||||
|   (update_ppa && sudo DEBIAN_FRONTEND=noninteractive apt-get install -y "php$version-psr" "php$version-$extension"  && add_log "$tick" "$extension" "Installed and enabled") || | ||||
|   add_log "$cross" "$extension" "Could not install $extension on PHP $semver" | ||||
| } | ||||
|  | ||||
| ini_file="/etc/php/$2/cli/conf.d/50-phalcon.ini" | ||||
| ext_dir=$(php -i | grep "extension_dir => /usr" | sed -e "s|.*=> s*||") | ||||
| semver=$(php -v | head -n 1 | cut -f 2 -d ' ' | cut -f 1 -d '-') | ||||
| extension_major_version=$(echo "$1" | grep -i -Po '\d') | ||||
| ppa_updated="false" | ||||
| tick="✓" | ||||
| cross="✗" | ||||
|  | ||||
| if [ "$extension_major_version" = "4" ]; then | ||||
|   if [ -e "$ext_dir/psr.so" ] && ! php -m | grep -i -q -w psr; then | ||||
|     echo "extension=psr.so" | sudo tee -a "$ini_file"  | ||||
|   fi | ||||
|  | ||||
|   if [ -e "$ext_dir/phalcon.so" ]; then | ||||
|     if php -m | grep -i -q -w psr; then | ||||
|       phalcon_version=$(php -d="extension=phalcon" -r "echo phpversion('phalcon');" | cut -d'.' -f 1) | ||||
|       if [ "$phalcon_version" != "$extension_major_version" ]; then | ||||
|         install_phalcon "$1" "$2" | ||||
|       else | ||||
|         echo "extension=phalcon.so" | sudo tee -a "$ini_file"  | ||||
|         add_log "$tick" "$1" "Enabled" | ||||
|       fi | ||||
|     else | ||||
|       install_phalcon "$1" "$2" | ||||
|     fi | ||||
|   else | ||||
|     install_phalcon "$1" "$2" | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| if [ "$extension_major_version" = "3" ]; then | ||||
|   if [ -e "$ext_dir/phalcon.so" ]; then | ||||
|     phalcon_version=$(php -d="extension=phalcon.so" -r "echo phpversion('phalcon');" | cut -d'.' -f 1) | ||||
|     if [ "$phalcon_version" != "$extension_major_version" ]; then | ||||
|       install_phalcon "$1" "$2" | ||||
|     else | ||||
|       echo "extension=phalcon.so" | sudo tee -a "$ini_file"  | ||||
|       add_log "$tick" "$1" "Enabled" | ||||
|     fi | ||||
|   else | ||||
|     install_phalcon "$1" "$2" | ||||
|   fi | ||||
| fi | ||||
| @ -1,11 +1,10 @@ | ||||
| tick="✓" | ||||
| cross="✗" | ||||
|  | ||||
| # Function to log start of a operation | ||||
| step_log() { | ||||
|   message=$1 | ||||
|   printf "\n\033[90;1m==> \033[0m\033[37;1m%s\033[0m\n" "$message" | ||||
| } | ||||
|  | ||||
| # Function to log result of a operation | ||||
| add_log() { | ||||
|   mark=$1 | ||||
|   subject=$2 | ||||
| @ -16,71 +15,347 @@ add_log() { | ||||
|     printf "\033[31;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s\033[0m\n" "$mark" "$subject" "$message" | ||||
|   fi | ||||
| } | ||||
| existing_version=$(php-config --version | cut -c 1-3) | ||||
| version=$1 | ||||
| status="Switched to PHP$version" | ||||
| step_log "Setup PHP and Composer" | ||||
| find /etc/apt/sources.list.d -type f -name 'ondrej-ubuntu-php*.list' -exec sudo DEBIAN_FRONTEND=noninteractive apt-fast update -o Dir::Etc::sourcelist="{}" ';' >/dev/null 2>&1 | ||||
| if [ "$existing_version" != "$1" ]; then | ||||
| 	if [ ! -e "/usr/bin/php$1" ]; then | ||||
| 		if [ "$1" != "7.4" ]; then | ||||
| 		  sudo DEBIAN_FRONTEND=noninteractive apt-fast install -y php"$1" curl php"$1"-curl >/dev/null 2>&1 | ||||
| 		else | ||||
| 		  sudo DEBIAN_FRONTEND=noninteractive apt-fast install -y php"$1" php"$1"-dev php"$1"-xml curl php"$1"-curl >/dev/null 2>&1 | ||||
| 		fi | ||||
| 		status="Installed PHP$version" | ||||
| 	fi | ||||
|  | ||||
| 	for tool in php phar phar.phar php-cgi php-config phpize; do | ||||
| 		if [ -e "/usr/bin/$tool$1" ]; then | ||||
| 			sudo update-alternatives --set $tool /usr/bin/"$tool$1" >/dev/null 2>&1 | ||||
| 		fi | ||||
| 	done | ||||
| fi | ||||
|  | ||||
| ini_file=$(php --ini | grep "Loaded Configuration" | sed -e "s|.*:s*||" | sed "s/ //g") | ||||
| ext_dir=$(php -i | grep "extension_dir => /usr" | sed -e "s|.*=> s*||") | ||||
| sudo chmod 777 "$ini_file" | ||||
| sudo mkdir -p /run/php | ||||
| add_log "$tick" "PHP" "$status" | ||||
| if [ "$2" = "true" ]; then | ||||
|   if [ "$1" != "7.4" ]; then | ||||
|     sudo DEBIAN_FRONTEND=noninteractive apt-fast install -y php"$1"-dev php"$1"-xml >/dev/null 2>&1 | ||||
| # Function to backup and cleanup package lists. | ||||
| cleanup_lists() { | ||||
|   ppa_prefix=${1-ondrej} | ||||
|   if [ ! -e /etc/apt/sources.list.d.save ]; then | ||||
|     sudo mv /etc/apt/sources.list.d /etc/apt/sources.list.d.save | ||||
|     sudo mkdir /etc/apt/sources.list.d | ||||
|     sudo mv /etc/apt/sources.list.d.save/*"${ppa_prefix}"*.list /etc/apt/sources.list.d/ | ||||
|     trap "sudo mv /etc/apt/sources.list.d.save/*.list /etc/apt/sources.list.d/ 2>/dev/null" exit | ||||
|   fi | ||||
|   sudo update-alternatives --set php-config /usr/bin/php-config"$1" >/dev/null 2>&1 | ||||
|   sudo update-alternatives --set phpize /usr/bin/phpize"$1" >/dev/null 2>&1 | ||||
|   wget https://github.com/pear/pearweb_phars/raw/master/install-pear-nozlib.phar >/dev/null 2>&1 | ||||
|   sudo php install-pear-nozlib.phar >/dev/null 2>&1 | ||||
|   sudo pear config-set php_ini "$ini_file" >/dev/null 2>&1 | ||||
|   add_log "$tick" "PECL" "Installed" | ||||
| fi | ||||
| } | ||||
|  | ||||
| if [ ! -e "/usr/bin/composer" ]; then | ||||
| 	curl -s -L https://getcomposer.org/installer > composer-setup.php | ||||
| 	if [ "$(curl -s https://composer.github.io/installer.sig)" != "$(php -r "echo hash_file('sha384', 'composer-setup.php');")" ]; then | ||||
| 		>&2 echo 'ERROR: Invalid installer signature'		 | ||||
| 	else | ||||
| 		export COMPOSER_ALLOW_SUPERUSER=1 | ||||
| 		sudo php composer-setup.php --install-dir=/usr/local/bin --filename=composer | ||||
| 	fi | ||||
| 	rm composer-setup.php	 | ||||
| fi | ||||
| composer global require hirak/prestissimo >/dev/null 2>&1 | ||||
| add_log "$tick" "Composer" "Installed" | ||||
| # Function to add ppa:ondrej/php. | ||||
| add_ppa() { | ||||
|   ppa=${1:-ondrej/php} | ||||
|   if ! apt-cache policy | grep -q "$ppa"; then | ||||
|     cleanup_lists "$(dirname "$ppa")" | ||||
|     LC_ALL=C.UTF-8 sudo apt-add-repository ppa:"$ppa" -y | ||||
|   fi | ||||
| } | ||||
|  | ||||
| add_extension() | ||||
| { | ||||
|   extension=$1 | ||||
| # Function to update the package lists. | ||||
| update_lists() { | ||||
|   if [ ! -e /tmp/setup_php ]; then | ||||
|     add_ppa ondrej/php  | ||||
|     cleanup_lists | ||||
|     sudo "$debconf_fix" apt-get update  | ||||
|     echo '' | sudo tee /tmp/setup_php  | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to configure PECL | ||||
| configure_pecl() { | ||||
|   if ! [ -e /tmp/pecl_config ]; then | ||||
|     if ! command -v pecl >/dev/null || ! command -v pear >/dev/null; then | ||||
|       add_pecl  | ||||
|     fi | ||||
|     for script in pear pecl; do | ||||
|       sudo "$script" config-set php_ini "${pecl_file:-$ini_file}"  | ||||
|       sudo "$script" channel-update "$script".php.net  | ||||
|     done | ||||
|     echo '' | sudo tee /tmp/pecl_config  | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to get the PECL version | ||||
| get_pecl_version() { | ||||
|   local extension=$1 | ||||
|   stability="$(echo "$2" | grep -m 1 -Eio "(alpha|beta|rc|snapshot|preview)")" | ||||
|   pecl_rest='https://pecl.php.net/rest/r/' | ||||
|   response=$(curl "${curl_opts[@]}" "$pecl_rest$extension"/allreleases.xml) | ||||
|   pecl_version=$(echo "$response" | grep -m 1 -Eio "([0-9]+\.[0-9]+\.[0-9]+${stability}[0-9]+)") | ||||
|   if [ ! "$pecl_version" ]; then | ||||
|     pecl_version=$(echo "$response" | grep -m 1 -Eo "([0-9]+\.[0-9]+\.[0-9]+)") | ||||
|   fi | ||||
|   echo "$pecl_version" | ||||
| } | ||||
|  | ||||
| # Function to install PECL extensions and accept default options | ||||
| pecl_install() { | ||||
|   local extension=$1 | ||||
|   yes '' | sudo pecl install -f "$extension"  | ||||
| } | ||||
|  | ||||
| # Function to enable existing extensions. | ||||
| enable_extension() { | ||||
|   sudo find /var/lib/php/modules/"$version" -path "*disabled*$1" -delete | ||||
|   if ! check_extension "$1" && [ -e "$ext_dir/$1.so" ]; then | ||||
|     echo "$2=$ext_dir/$1.so" | sudo tee -a "$pecl_file" >/dev/null | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to test if extension is loaded | ||||
| check_extension() { | ||||
|   local extension=$1 | ||||
|   if [ "$extension" != "mysql" ]; then | ||||
|     php -m | grep -i -q -w "$extension" | ||||
|   else | ||||
|     php -m | grep -i -q "$extension" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to delete extensions | ||||
| delete_extension() { | ||||
|   local extension=$1 | ||||
|   sudo sed -Ei "/=(.*\/)?\"?$extension/d" "$ini_file" | ||||
|   sudo sed -Ei "/=(.*\/)?\"?$extension/d" "$pecl_file" | ||||
|   sudo rm -rf "$scan_dir"/*"$extension"*  | ||||
|   sudo rm -rf "$ext_dir"/"$extension".so  | ||||
|   sudo sed -i "/Package: php$version-$extension/,/^$/d" /var/lib/dpkg/status | ||||
| } | ||||
|  | ||||
| # Function to disable and delete extensions | ||||
| remove_extension() { | ||||
|   local extension=$1 | ||||
|   if [ -e /etc/php/"$version"/mods-available/"$extension".ini ]; then | ||||
|     sudo phpdismod -v "$version" "$extension" | ||||
|   fi | ||||
|   delete_extension "$extension" | ||||
| } | ||||
|  | ||||
| # Function to setup extensions | ||||
| add_extension() { | ||||
|   local extension=$1 | ||||
|   install_command=$2 | ||||
|   prefix=$3 | ||||
|   if ! php -m | grep -i -q "$extension" && [ -e "$ext_dir/$extension.so" ]; then | ||||
|     echo "$prefix=$extension" >> "$ini_file" && add_log "$tick" "$extension" "Enabled" | ||||
|   elif php -m | grep -i -q "$extension"; then | ||||
|   enable_extension "$extension" "$prefix" | ||||
|   if check_extension "$extension"; then | ||||
|     add_log "$tick" "$extension" "Enabled" | ||||
|   elif ! php -m | grep -i -q "$extension"; then | ||||
|       ( | ||||
|         eval "$install_command" && \ | ||||
|         add_log "$tick" "$extension" "Installed and enabled" | ||||
|       ) || add_log "$cross" "$extension" "Could not install $extension on php$version" | ||||
|   elif ! check_extension "$extension"; then | ||||
|     eval "$install_command"  || | ||||
|     (update_lists && eval "$install_command" ) || pecl_install "$extension" | ||||
|     (check_extension "$extension" && add_log "$tick" "$extension" "Installed and enabled") || | ||||
|     add_log "$cross" "$extension" "Could not install $extension on PHP $semver" | ||||
|   fi | ||||
| } | ||||
|   sudo chmod 777 "$ini_file" | ||||
| } | ||||
|  | ||||
| # Function to install a PECL version | ||||
| add_pecl_extension() { | ||||
|   local extension=$1 | ||||
|   pecl_version=$2 | ||||
|   prefix=$3 | ||||
|   configure_pecl | ||||
|   if [[ $pecl_version =~ .*(alpha|beta|rc|snapshot|preview).* ]]; then | ||||
|     pecl_version=$(get_pecl_version "$extension" "$pecl_version") | ||||
|   fi | ||||
|   enable_extension "$extension" "$prefix" | ||||
|   ext_version=$(php -r "echo phpversion('$extension');") | ||||
|   if [ "$ext_version" = "$pecl_version" ]; then | ||||
|     add_log "$tick" "$extension" "Enabled" | ||||
|   else | ||||
|     delete_extension "$extension" | ||||
|     ( | ||||
|       sudo pecl install -f "$extension-$pecl_version"  && | ||||
|       check_extension "$extension" && | ||||
|       add_log "$tick" "$extension" "Installed and enabled" | ||||
|     ) || add_log "$cross" "$extension" "Could not install $extension-$pecl_version on PHP $semver" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to pre-release extensions using PECL | ||||
| add_unstable_extension() { | ||||
|   local extension=$1 | ||||
|   stability=$2 | ||||
|   prefix=$3 | ||||
|   pecl_version=$(get_pecl_version "$extension" "$stability") | ||||
|   add_pecl_extension "$extension" "$pecl_version" "$prefix" | ||||
| } | ||||
|  | ||||
| # Function to configure composer | ||||
| configure_composer() { | ||||
|   tool_path=$1 | ||||
|   sudo ln -sf "$tool_path" "$tool_path.phar" | ||||
|   php -r "try {\$p=new Phar('$tool_path.phar', 0);exit(0);} catch(Exception \$e) {exit(1);}" | ||||
|   if [ $? -eq 1 ]; then | ||||
|     add_log "$cross" "composer" "Could not download composer" | ||||
|     exit 1; | ||||
|   fi | ||||
|   if ! [ -d "$composer_home" ]; then | ||||
|     sudo -u "$(id -un)" -g "$(id -gn)" mkdir -p -m=00755 "$composer_home" | ||||
|   else | ||||
|     sudo chown -R "$(id -un)":"$(id -gn)" "$composer_home" | ||||
|   fi | ||||
|   if ! [ -e "$composer_json" ]; then | ||||
|     echo '{}' | tee "$composer_json" >/dev/null | ||||
|     chmod 644 "$composer_json" | ||||
|   fi | ||||
|   composer -q config -g process-timeout 0 | ||||
|   echo "$composer_bin" >> "$GITHUB_PATH" | ||||
|   if [ -n "$COMPOSER_TOKEN" ]; then | ||||
|     composer -q config -g github-oauth.github.com "$COMPOSER_TOKEN" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to setup a remote tool. | ||||
| add_tool() { | ||||
|   url=$1 | ||||
|   tool=$2 | ||||
|   tool_path="$tool_path_dir/$tool" | ||||
|   if [ ! -e "$tool_path" ]; then | ||||
|     rm -rf "$tool_path" | ||||
|   fi | ||||
|   if [ "$tool" = "composer" ]; then | ||||
|     IFS="," read -r -a urls <<< "$url" | ||||
|     status_code=$(sudo curl -f -w "%{http_code}" -o "$tool_path" "${curl_opts[@]}" "${urls[0]}") || | ||||
|     status_code=$(sudo curl -w "%{http_code}" -o "$tool_path" "${curl_opts[@]}" "${urls[1]}") | ||||
|   else | ||||
|     status_code=$(sudo curl -w "%{http_code}" -o "$tool_path" "${curl_opts[@]}" "$url") | ||||
|   fi | ||||
|   if [ "$status_code" != "200" ] && [[ "$url" =~ .*github.com.*releases.*latest.* ]]; then | ||||
|     url="${url//releases\/latest\/download/releases/download/$(curl "${curl_opts[@]}" "$(echo "$url" | cut -d '/' -f '1-5')/releases" | grep -Eo -m 1 "([0-9]+\.[0-9]+\.[0-9]+)/$(echo "$url" | sed -e "s/.*\///")" | cut -d '/' -f 1)}" | ||||
|     status_code=$(sudo curl -w "%{http_code}" -o "$tool_path" "${curl_opts[@]}" "$url") | ||||
|   fi | ||||
|   if [ "$status_code" = "200" ]; then | ||||
|     sudo chmod a+x "$tool_path" | ||||
|     if [ "$tool" = "composer" ]; then | ||||
|       configure_composer "$tool_path" | ||||
|     elif [ "$tool" = "cs2pr" ]; then | ||||
|       sudo sed -i 's/\r$//; s/exit(9)/exit(0)/' "$tool_path" | ||||
|     elif [ "$tool" = "phive" ]; then | ||||
|       add_extension curl "$apt_install php$version-curl" extension  | ||||
|       add_extension mbstring "$apt_install php$version-mbstring" extension  | ||||
|       add_extension xml "$apt_install php$version-xml" extension  | ||||
|     fi | ||||
|     add_log "$tick" "$tool" "Added" | ||||
|   else | ||||
|     add_log "$cross" "$tool" "Could not setup $tool" | ||||
|     [ "$tool" = "composer" ] && exit 1 | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to setup a tool using composer | ||||
| add_composertool() { | ||||
|   tool=$1 | ||||
|   release=$2 | ||||
|   prefix=$3 | ||||
|   ( | ||||
|     sudo rm -f "$composer_lock"  || true | ||||
|     composer global require "$prefix$release"  && | ||||
|     add_log "$tick" "$tool" "Added" | ||||
|   ) || add_log "$cross" "$tool" "Could not setup $tool" | ||||
|   if [ -e "$composer_bin/composer" ]; then | ||||
|     sudo cp -p "$tool_path_dir/composer" "$composer_bin" | ||||
|   fi | ||||
|   if [ "$tool" = "codeception" ]; then | ||||
|     sudo ln -s "$composer_bin"/codecept "$composer_bin"/codeception | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to setup phpize and php-config | ||||
| add_devtools() { | ||||
|   if ! [ -e "/usr/bin/phpize$version" ] || ! [ -e "/usr/bin/php-config$version" ]; then | ||||
|     update_lists && $apt_install php"$version"-dev php"$version"-xml  | ||||
|   fi | ||||
|   sudo update-alternatives --set php-config /usr/bin/php-config"$version"  | ||||
|   sudo update-alternatives --set phpize /usr/bin/phpize"$version"  | ||||
|   configure_pecl | ||||
| } | ||||
|  | ||||
| # Function to setup the nightly build from master branch | ||||
| setup_master() { | ||||
|   curl "${curl_opts[@]}" https://github.com/shivammathur/php-builder/releases/latest/download/install.sh | bash -s "github" | ||||
| } | ||||
|  | ||||
| add_packaged_php() { | ||||
|   if [ "${use_package_cache:-true}" = "false" ]; then | ||||
|     update_lists | ||||
|     IFS=' ' read -r -a packages <<<"$(echo "cli curl mbstring xml intl" | sed "s/[^ ]*/php$version-&/g")" | ||||
|     $apt_install "${packages[@]}" | ||||
|   else | ||||
|     curl "${curl_opts[@]}" https://github.com/shivammathur/php-ubuntu/releases/latest/download/install.sh | bash -s "$version" | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to setup PECL | ||||
| add_pecl() { | ||||
|   add_devtools | ||||
|   if [ ! -e /usr/bin/pecl ]; then | ||||
|     $apt_install php-pear  | ||||
|   fi | ||||
|   configure_pecl | ||||
|   add_log "$tick" "PECL" "Added" | ||||
| } | ||||
|  | ||||
| # Function to switch versions of PHP binaries | ||||
| switch_version() { | ||||
|   for tool in pear pecl php phar phar.phar php-cgi php-config phpize phpdbg; do | ||||
|     if [ -e "/usr/bin/$tool$version" ]; then | ||||
|       sudo update-alternatives --set $tool /usr/bin/"$tool$version" | ||||
|     fi | ||||
|   done | ||||
| } | ||||
|  | ||||
| # Function to get PHP version in semver format | ||||
| php_semver() { | ||||
|   if [ ! "$version" = "8.0" ]; then | ||||
|     php"$version" -v | head -n 1 | cut -f 2 -d ' ' | cut -f 1 -d '-' | ||||
|   else | ||||
|     php -v | head -n 1 | cut -f 2 -d ' ' | ||||
|   fi | ||||
| } | ||||
|  | ||||
| # Function to configure PHP | ||||
| configure_php() { | ||||
|   ( | ||||
|     echo -e "date.timezone=UTC\nmemory_limit=-1" | ||||
|     [[ "$version" =~ 8.0 ]] && echo -e "opcache.enable=1\nopcache.jit_buffer_size=256M\nopcache.jit=1235" | ||||
|     [[ "$version" =~ 7.[2-4]|8.0 ]] && echo -e "xdebug.mode=coverage" | ||||
|   ) | sudo tee -a "$pecl_file" >/dev/null | ||||
| } | ||||
|  | ||||
| # Variables | ||||
| tick="✓" | ||||
| cross="✗" | ||||
| version=$1 | ||||
| dist=$2 | ||||
| debconf_fix="DEBIAN_FRONTEND=noninteractive" | ||||
| apt_install="sudo $debconf_fix apt-fast install -y --no-install-recommends" | ||||
| tool_path_dir="/usr/local/bin" | ||||
| curl_opts=(-sL) | ||||
| composer_home="$HOME/.composer" | ||||
| composer_bin="$composer_home/vendor/bin" | ||||
| composer_json="$composer_home/composer.json" | ||||
| composer_lock="$composer_home/composer.lock" | ||||
| existing_version=$(php-config --version 2>/dev/null | cut -c 1-3) | ||||
|  | ||||
| # Setup PHP | ||||
| step_log "Setup PHP" | ||||
| sudo mkdir -m 777 -p "$HOME/.composer" /var/run /run/php | ||||
| . /etc/lsb-release | ||||
|  | ||||
| if [ "$existing_version" != "$version" ]; then | ||||
|   if [ ! -e "/usr/bin/php$version" ]; then | ||||
|     if [ "$version" = "8.0" ]; then | ||||
|       setup_master  | ||||
|     else | ||||
|       add_packaged_php  | ||||
|     fi | ||||
|     status="Installed" | ||||
|   else | ||||
|     status="Switched to" | ||||
|   fi | ||||
|  | ||||
|   switch_version  | ||||
| else | ||||
|   status="Found" | ||||
| fi | ||||
|  | ||||
| if ! command -v php"$version" >/dev/null; then | ||||
|   add_log "$cross" "PHP" "Could not setup PHP $version" | ||||
|   exit 1 | ||||
| fi | ||||
| semver=$(php_semver) | ||||
| scan_dir=$(php --ini | grep additional | sed -e "s|.*: s*||") | ||||
| ini_file=$(php --ini | grep "Loaded Configuration" | sed -e "s|.*:s*||" | sed "s/ //g") | ||||
| ext_dir=$(php -i | grep "extension_dir => /" | sed -e "s|.*=> s*||") | ||||
| pecl_file="$scan_dir"/99-pecl.ini | ||||
| echo '' | sudo tee "$pecl_file"  | ||||
| configure_php | ||||
| sudo rm -rf /usr/local/bin/phpunit  | ||||
| sudo chmod 777 "$ini_file" "$pecl_file" "$tool_path_dir" | ||||
| sudo cp "$dist"/../src/configs/*.json "$RUNNER_TOOL_CACHE/" | ||||
| add_log "$tick" "PHP" "$status PHP $semver" | ||||
|  | ||||
| @ -1,5 +0,0 @@ | ||||
| cd ~ && git clone --depth=1 https://github.com/krakjoe/pcov.git | ||||
| cd pcov && phpize | ||||
| ./configure --enable-pcov | ||||
| make | ||||
| sudo make install | ||||
| @ -1,26 +0,0 @@ | ||||
| ini_file=$(php --ini | grep "Loaded Configuration" | sed -e "s|.*:s*||" | sed "s/ //g") | ||||
| if [ ! "$(apt-cache search php"$2"-psr)" ]; then | ||||
|   sudo DEBIAN_FRONTEND=noninteractive add-apt-repository ppa:ondrej/php -y >/dev/null 2>&1 | ||||
| fi | ||||
| sudo DEBIAN_FRONTEND=noninteractive apt-fast install -y php"$2"-dev php"$2"-psr | ||||
| for tool in php-config phpize; do | ||||
|   if [ -e "/usr/bin/$tool$2" ]; then | ||||
|     sudo update-alternatives --set $tool /usr/bin/"$tool$2" | ||||
|   fi | ||||
| done | ||||
|  | ||||
| if [ ! "$(apt-cache search php"$2"-psr)" ]; then | ||||
|   cd ~ && git clone --depth=1 https://github.com/jbboehr/php-psr.git | ||||
|   cd php-psr && sudo /usr/bin/phpize"$2" | ||||
|   ./configure --with-php-config=/usr/bin/php-config"$2" | ||||
|   make -j2 && sudo make -j2 install | ||||
|   echo "extension=psr.so" >> "$ini_file" | ||||
| fi | ||||
|  | ||||
| if [ "$1" = "master" ]; then | ||||
|   sudo DEBIAN_FRONTEND=noninteractive apt-fast install -y php"$2"-phalcon | ||||
| else | ||||
|   cd ~ && git clone --depth=1 -v https://github.com/phalcon/cphalcon.git -b "$1" | ||||
|   cd cphalcon/build && sudo ./install --phpize /usr/bin/phpize"$2" --php-config /usr/bin/php-config"$2" | ||||
|   echo "extension=phalcon.so" >> "$ini_file" | ||||
| fi | ||||
| @ -1,87 +1,326 @@ | ||||
| param ( | ||||
|     [Parameter(Mandatory=$true)][string]$version = "7.3", | ||||
|     [Parameter(Mandatory=$true)][string]$dir | ||||
|   [Parameter(Position = 0, Mandatory = $true)] | ||||
|   [ValidateNotNull()] | ||||
|   [ValidateLength(1, [int]::MaxValue)] | ||||
|   [string] | ||||
|   $version = '7.4', | ||||
|   [Parameter(Position = 1, Mandatory = $true)] | ||||
|   [ValidateNotNull()] | ||||
|   [ValidateLength(1, [int]::MaxValue)] | ||||
|   [string] | ||||
|   $dist | ||||
| ) | ||||
|  | ||||
| $tick = ([char]8730) | ||||
| $cross = ([char]10007) | ||||
|  | ||||
| Function Step-Log($message) { | ||||
|   printf "\n\033[90;1m==> \033[0m\033[37;1m%s \033[0m\n" $message | ||||
| } | ||||
|  | ||||
| Function Add-Log($mark, $subject, $message) { | ||||
|   $code = if($mark -eq $cross) {"31"} else {"32"} | ||||
|   $code = if ($mark -eq $cross) { "31" } else { "32" } | ||||
|   printf "\033[%s;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" $code $mark $subject $message | ||||
| } | ||||
|  | ||||
| if($version -eq '7.4') { | ||||
| 	$version = '7.4RC' | ||||
| Function Add-ToProfile { | ||||
|   param( | ||||
|     [Parameter(Position = 0, Mandatory = $true)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidateLength(1, [int]::MaxValue)] | ||||
|     [string] | ||||
|     $input_profile, | ||||
|     [Parameter(Position = 1, Mandatory = $true)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidateLength(1, [int]::MaxValue)] | ||||
|     [string] | ||||
|     $search, | ||||
|     [Parameter(Position = 2, Mandatory = $true)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidateLength(1, [int]::MaxValue)] | ||||
|     [string] | ||||
|     $value | ||||
|   ) | ||||
|   if($null -eq (Get-Content $input_profile | findstr $search)) { | ||||
|     Add-Content -Path $input_profile -Value $value | ||||
|   } | ||||
| } | ||||
|  | ||||
| Step-Log "Setup PhpManager" | ||||
| Install-Module -Name PhpManager -Force -Scope CurrentUser | ||||
| Add-Log $tick "PhpManager" "Installed" | ||||
|  | ||||
| $installed = $($(php -v)[0] -join '')[4..6] -join '' | ||||
| Step-Log "Setup PHP and Composer" | ||||
| $status = "Switched to PHP$version" | ||||
| if($installed -ne $version) { | ||||
|   if($version -lt '7.0') { | ||||
|     Install-Module -Name VcRedist -Force | ||||
|   } | ||||
|   Install-Php -Version $version -Architecture x86 -ThreadSafe $true -InstallVC -Path C:\tools\php -TimeZone UTC -InitialPhpIni Production -Force >$null 2>&1 | ||||
|   $status = "Installed PHP$version" | ||||
| } | ||||
|  | ||||
| $ext_dir = "C:\tools\php\ext" | ||||
| Add-Content C:\tools\php\php.ini "date.timezone = 'UTC'" | ||||
| Set-PhpIniKey extension_dir $ext_dir | ||||
| if($version -lt '7.4') { | ||||
|   Enable-PhpExtension openssl | ||||
|   Enable-PhpExtension curl | ||||
| } else { | ||||
|   Add-Content C:\tools\php\php.ini "extension=php_openssl.dll`nextension=php_curl.dll" | ||||
|   Copy-Item $dir"\..\src\ext\php_pcov.dll" -Destination $ext_dir"\php_pcov.dll" | ||||
| } | ||||
| Add-Log $tick "PHP" $status | ||||
|  | ||||
| Install-Composer -Scope System -Path C:\tools\php | ||||
| Add-Log $tick "Composer" "Installed" | ||||
|  | ||||
| Function Add-Extension($extension, $install_command, $prefix) | ||||
| { | ||||
|   try { | ||||
|     $exist = Test-Path -Path C:\tools\php\ext\php_$extension.dll | ||||
|     if(!(php -m | findstr -i ${extension}) -and $exist) { | ||||
|       Add-Content C:\tools\php\php.ini "$prefix=php_$extension.dll" | ||||
|       Add-Log $tick $extension "Enabled" | ||||
|     } elseif(php -m | findstr -i $extension) { | ||||
|       Add-Log $tick $extension "Enabled" | ||||
|     } | ||||
|   } catch [Exception] { | ||||
|     Add-Log $cross $extension "Could not enable" | ||||
|   } | ||||
|  | ||||
|   $status = 404 | ||||
|   try  { | ||||
|     $status = (Invoke-WebRequest -Uri "https://pecl.php.net/json.php?package=$extension" -UseBasicParsing -DisableKeepAlive).StatusCode | ||||
|   } catch [Exception] { | ||||
|     $status = 500 | ||||
|   } | ||||
|  | ||||
|   if($status -eq 200) { | ||||
|     if(!(php -m | findstr -i $extension)) { | ||||
|       try { | ||||
|         Invoke-Expression $install_command | ||||
|         Add-Log $tick $extension "Installed and enabled" | ||||
|       } catch [Exception] { | ||||
|         Add-Log $cross $extension "Could not install on PHP$version" | ||||
|       } | ||||
| Function Add-Printf { | ||||
|   if (-not(Test-Path "C:\Program Files\Git\usr\bin\printf.exe")) { | ||||
|     if(Test-Path "C:\msys64\usr\bin\printf.exe") { | ||||
|       New-Item -Path $php_dir\printf.exe -ItemType SymbolicLink -Value C:\msys64\usr\bin\printf.exe -Force > $null 2>&1 | ||||
|     } else { | ||||
|       Invoke-WebRequest -UseBasicParsing -Uri "$github/shivammathur/printf/releases/latest/download/printf-x64.zip" -OutFile "$php_dir\printf.zip" | ||||
|       Expand-Archive -Path $php_dir\printf.zip -DestinationPath $php_dir -Force | ||||
|     } | ||||
|   } else { | ||||
|     if(!(php -m | findstr -i $extension)) { | ||||
|       Add-Log $cross $extension "Could not find $extension for PHP$version on PECL" | ||||
|     New-Item -Path $php_dir\printf.exe -ItemType SymbolicLink -Value "C:\Program Files\Git\usr\bin\printf.exe" -Force > $null 2>&1 | ||||
|   } | ||||
| } | ||||
|  | ||||
| Function Install-PSPackage() { | ||||
|   param( | ||||
|     [Parameter(Position = 0, Mandatory = $true)] | ||||
|     $package, | ||||
|     [Parameter(Position = 1, Mandatory = $true)] | ||||
|     $psm1_path, | ||||
|     [Parameter(Position = 2, Mandatory = $true)] | ||||
|     $url, | ||||
|     [Parameter(Position = 3, Mandatory = $true)] | ||||
|     $cmdlet | ||||
|   ) | ||||
|   $module_path = "$php_dir\$psm1_path.psm1" | ||||
|   if(-not (Test-Path $module_path -PathType Leaf)) { | ||||
|     $zip_file = "$php_dir\$package.zip" | ||||
|     Invoke-WebRequest -UseBasicParsing -Uri $url -OutFile $zip_file | ||||
|     Expand-Archive -Path $zip_file -DestinationPath $php_dir -Force | ||||
|   } | ||||
|   Import-Module $module_path | ||||
|   Add-ToProfile $current_profile "$package-search" "Import-Module $module_path" | ||||
|  | ||||
|   if($null -eq (Get-Command $cmdlet -ErrorAction SilentlyContinue)) { | ||||
|     Install-Module -Name $package -Force | ||||
|   } | ||||
| } | ||||
|  | ||||
| Function Add-Extension { | ||||
|   Param ( | ||||
|     [Parameter(Position = 0, Mandatory = $true)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidateLength(1, [int]::MaxValue)] | ||||
|     [string] | ||||
|     $extension, | ||||
|     [Parameter(Position = 1, Mandatory = $false)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidateSet('stable', 'beta', 'alpha', 'devel', 'snapshot')] | ||||
|     [string] | ||||
|     $stability = 'stable', | ||||
|     [Parameter(Position = 2, Mandatory = $false)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidatePattern('^\d+(\.\d+){0,2}$')] | ||||
|     [string] | ||||
|     $extension_version = '' | ||||
|   ) | ||||
|   try { | ||||
|     $extension_info = Get-PhpExtension -Path $php_dir | Where-Object { $_.Name -eq $extension -or $_.Handle -eq $extension } | ||||
|     if ($null -ne $extension_info) { | ||||
|       switch ($extension_info.State) { | ||||
|         'Builtin' { | ||||
|           Add-Log $tick $extension "Enabled" | ||||
|         } | ||||
|         'Enabled' { | ||||
|           Add-Log $tick $extension "Enabled" | ||||
|         } | ||||
|         default { | ||||
|           Enable-PhpExtension -Extension $extension_info.Handle -Path $php_dir | ||||
|           Add-Log $tick $extension "Enabled" | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     else { | ||||
|       if($extension_version -ne '') { | ||||
|         Install-PhpExtension -Extension $extension -Version $extension_version -MinimumStability $stability -MaximumStability $stability -Path $php_dir | ||||
|       } else { | ||||
|         Install-PhpExtension -Extension $extension -MinimumStability $stability -MaximumStability $stability -Path $php_dir | ||||
|       } | ||||
|  | ||||
|       Add-Log $tick $extension "Installed and enabled" | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   catch { | ||||
|     Add-Log $cross $extension "Could not install $extension on PHP $($installed.FullVersion)" | ||||
|   } | ||||
| } | ||||
|  | ||||
| Function Remove-Extension() { | ||||
|   Param ( | ||||
|     [Parameter(Position = 0, Mandatory = $true)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidateLength(1, [int]::MaxValue)] | ||||
|     [string] | ||||
|     $extension | ||||
|   ) | ||||
|   if(php -m | findstr -i $extension) { | ||||
|     Disable-PhpExtension $extension $php_dir | ||||
|   } | ||||
|   if (Test-Path $ext_dir\php_$extension.dll) { | ||||
|     Remove-Item $ext_dir\php_$extension.dll | ||||
|   } | ||||
| } | ||||
|  | ||||
|  | ||||
| Function Edit-ComposerConfig() { | ||||
|   Param( | ||||
|     [Parameter(Position = 0, Mandatory = $true)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidateLength(1, [int]::MaxValue)] | ||||
|     [string] | ||||
|     $tool_path | ||||
|   ) | ||||
|   Copy-Item $tool_path -Destination "$tool_path.phar" | ||||
|   php -r "try {`$p=new Phar('$tool_path.phar', 0);exit(0);} catch(Exception `$e) {exit(1);}" | ||||
|   if ($? -eq $False) { | ||||
|     Add-Log "$cross" "composer" "Could not download composer" | ||||
|     exit 1; | ||||
|   } | ||||
|   if (-not(Test-Path $composer_json)) { | ||||
|     Set-Content -Path $composer_json -Value "{}" | ||||
|   } | ||||
|   composer -q config -g process-timeout 0 | ||||
|   Write-Output $composer_bin | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8 | ||||
|   if (Test-Path env:COMPOSER_TOKEN) { | ||||
|     composer -q config -g github-oauth.github.com $env:COMPOSER_TOKEN | ||||
|   } | ||||
| } | ||||
|  | ||||
| Function Add-Tool() { | ||||
|   Param ( | ||||
|     [Parameter(Position = 0, Mandatory = $true)] | ||||
|     [ValidateNotNull()] | ||||
|     $url, | ||||
|     [Parameter(Position = 1, Mandatory = $true)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidateLength(1, [int]::MaxValue)] | ||||
|     [string] | ||||
|     $tool | ||||
|   ) | ||||
|   if (Test-Path $php_dir\$tool) { | ||||
|     Remove-Item $php_dir\$tool | ||||
|   } | ||||
|   if($url.Count -gt 1) { $url = $url[0] } | ||||
|   if ($tool -eq "symfony") { | ||||
|     Invoke-WebRequest -UseBasicParsing -Uri $url -OutFile $php_dir\$tool.exe | ||||
|     Add-ToProfile $current_profile $tool "New-Alias $tool $php_dir\$tool.exe"  | ||||
|   } else { | ||||
|     try { | ||||
|       Invoke-WebRequest -UseBasicParsing -Uri $url -OutFile $php_dir\$tool | ||||
|     } catch { | ||||
|       if($url -match '.*github.com.*releases.*latest.*') { | ||||
|         try { | ||||
|           $url = $url.replace("releases/latest/download", "releases/download/" + ([regex]::match((Invoke-WebRequest -UseBasicParsing -Uri ($url.split('/release')[0] + "/releases")).Content, "([0-9]+\.[0-9]+\.[0-9]+)/" + ($url.Substring($url.LastIndexOf("/") + 1))).Groups[0].Value).split('/')[0]) | ||||
|           Invoke-WebRequest -UseBasicParsing -Uri $url -OutFile $php_dir\$tool | ||||
|         } catch { } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   if (((Get-ChildItem -Path $php_dir/* | Where-Object Name -Match "^$tool(.exe|.phar)*$").Count -gt 0)) { | ||||
|     $bat_content = @() | ||||
|     $bat_content += "@ECHO off" | ||||
|     $bat_content += "setlocal DISABLEDELAYEDEXPANSION" | ||||
|     $bat_content += "SET BIN_TARGET=%~dp0/" + $tool | ||||
|     $bat_content += "php %BIN_TARGET% %*" | ||||
|     Set-Content -Path $php_dir\$tool.bat -Value $bat_content | ||||
|     Add-ToProfile $current_profile $tool "New-Alias $tool $php_dir\$tool.bat"  | ||||
|     if($tool -eq "composer") { | ||||
|       Edit-ComposerConfig $php_dir\$tool | ||||
|     } elseif($tool -eq "cs2pr") { | ||||
|       (Get-Content $php_dir/cs2pr).replace('exit(9)', 'exit(0)') | Set-Content $php_dir/cs2pr | ||||
|     } elseif($tool -eq "phan") { | ||||
|       Add-Extension fileinfo  | ||||
|       Add-Extension ast  | ||||
|     } elseif($tool -eq "phive") { | ||||
|       Add-Extension xml  | ||||
|     } elseif($tool -eq "wp-cli") { | ||||
|       Copy-Item $php_dir\wp-cli.bat -Destination $php_dir\wp.bat | ||||
|     } | ||||
|     Add-Log $tick $tool "Added" | ||||
|   } else { | ||||
|     Add-Log $cross $tool "Could not add $tool" | ||||
|   } | ||||
| } | ||||
|  | ||||
| Function Add-Composertool() { | ||||
|   Param ( | ||||
|     [Parameter(Position = 0, Mandatory = $true)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidateLength(1, [int]::MaxValue)] | ||||
|     [string] | ||||
|     $tool, | ||||
|     [Parameter(Position = 1, Mandatory = $true)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidateLength(1, [int]::MaxValue)] | ||||
|     [string] | ||||
|     $release, | ||||
|     [Parameter(Position = 2, Mandatory = $true)] | ||||
|     [ValidateNotNull()] | ||||
|     [ValidateLength(1, [int]::MaxValue)] | ||||
|     [string] | ||||
|     $prefix | ||||
|   ) | ||||
|   if(Test-Path $composer_lock) { | ||||
|     Remove-Item -Path $composer_lock -Force | ||||
|   } | ||||
|   composer -q global require $prefix$release 2>&1 | out-null | ||||
|   if($tool -eq "codeception") { | ||||
|     Copy-Item $composer_bin\codecept.bat -Destination $composer_bin\codeception.bat | ||||
|   } | ||||
|   if($?) { | ||||
|     Add-Log $tick $tool "Added" | ||||
|   } else { | ||||
|     Add-Log $cross $tool "Could not setup $tool" | ||||
|   } | ||||
|   if(Test-Path $composer_bin\composer) { | ||||
|     Copy-Item -Path "$php_dir\composer" -Destination "$composer_bin\composer" -Force | ||||
|   } | ||||
| } | ||||
|  | ||||
| Function Add-Pecl() { | ||||
|   Add-Log $tick "PECL" "Use extensions input to setup PECL extensions on windows" | ||||
| } | ||||
|  | ||||
| # Variables | ||||
| $tick = ([char]8730) | ||||
| $cross = ([char]10007) | ||||
| $php_dir = 'C:\tools\php' | ||||
| $ext_dir = "$php_dir\ext" | ||||
| $current_profile = "$PSHOME\Profile.ps1" | ||||
| $ProgressPreference = 'SilentlyContinue' | ||||
| $github = 'https://github.com' | ||||
| $composer_bin = "$env:APPDATA\Composer\vendor\bin" | ||||
| $composer_json = "$env:APPDATA\Composer\composer.json" | ||||
| $composer_lock = "$env:APPDATA\Composer\composer.lock" | ||||
| $arch = 'x64' | ||||
| if(-not([Environment]::Is64BitOperatingSystem) -or $version -lt '7.0') { | ||||
|   $arch = 'x86' | ||||
| } | ||||
| $ts = $env:PHPTS -eq 'ts' | ||||
| if($env:PHPTS -ne 'ts') { | ||||
|   $env:PHPTS = 'nts' | ||||
| } | ||||
| if(-not(Test-Path -LiteralPath $current_profile)) { | ||||
|   New-Item -Path $current_profile -ItemType "file" -Force  | ||||
| } | ||||
|  | ||||
| Add-Printf  | ||||
| Step-Log "Setup PhpManager" | ||||
| Install-PSPackage PhpManager PhpManager\PhpManager "$github/mlocati/powershell-phpmanager/releases/latest/download/PhpManager.zip" Get-Php  | ||||
| Add-Log $tick "PhpManager" "Installed" | ||||
|  | ||||
| Step-Log "Setup PHP" | ||||
| $installed = $null | ||||
| if (Test-Path -LiteralPath $php_dir -PathType Container) { | ||||
|   try { | ||||
|     $installed = Get-Php -Path $php_dir | ||||
|   } catch { } | ||||
| } | ||||
| $status = "Installed" | ||||
| if ($null -eq $installed -or -not("$($installed.Version).".StartsWith(($version -replace '^(\d+(\.\d+)*).*', '$1.'))) -or $ts -ne $installed.ThreadSafe) { | ||||
|   if ($version -lt '7.0' -and ($null -eq (Get-Module -ListAvailable -Name VcRedist))) { | ||||
|     Install-PSPackage VcRedist VcRedist-main\VcRedist\VcRedist "$github/aaronparker/VcRedist/archive/main.zip" Get-VcList  | ||||
|   } | ||||
|   try { | ||||
|     Install-Php -Version $version -Architecture $arch -ThreadSafe $ts -InstallVC -Path $php_dir -TimeZone UTC -InitialPhpIni Production -Force > $null 2>&1 | ||||
|   } catch { } | ||||
| } else { | ||||
|   $status = "Found" | ||||
| } | ||||
|  | ||||
| $installed = Get-Php -Path $php_dir | ||||
| if($installed.MajorMinorVersion -ne $version) { | ||||
|   Add-Log $cross "PHP" "Could not setup PHP $version" | ||||
|   exit 1 | ||||
| } | ||||
| ('date.timezone=UTC', 'memory_limit=-1', 'xdebug.mode=coverage') | ForEach-Object { $p=$_.split('='); Set-PhpIniKey -Key $p[0] -Value $p[1] -Path $php_dir } | ||||
| Enable-PhpExtension -Extension openssl, curl, opcache, mbstring -Path $php_dir | ||||
| Update-PhpCAInfo -Path $php_dir -Source CurrentUser | ||||
| Copy-Item -Path $dist\..\src\configs\*.json -Destination $env:RUNNER_TOOL_CACHE | ||||
| New-Item -ItemType Directory -Path $composer_bin -Force > $null 2>&1 | ||||
| Add-Log $tick "PHP" "$status PHP $($installed.FullVersion)" | ||||
|  | ||||
| @ -1,3 +0,0 @@ | ||||
| cd ~ && git clone --depth=1 https://github.com/xdebug/xdebug.git | ||||
| cd xdebug || echo "Failed to clone Xdebug" | ||||
| sudo ./rebuild.sh | ||||
| @ -1,6 +0,0 @@ | ||||
| cd ~ && git clone --depth=1 https://github.com/xdebug/xdebug.git | ||||
| cd xdebug || echo "Failed to clone Xdebug" | ||||
| sudo phpize | ||||
| sudo ./configure | ||||
| sudo make | ||||
| sudo cp modules/xdebug.so "$(php -i | grep "extension_dir => /opt" | sed -e "s|.*=> s*||")" | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user
	