mirror of
				https://gitea.com/actions/setup-java.git
				synced 2025-10-26 07:16:35 +00:00 
			
		
		
		
	Merge "v2-preview" branch into "main" (#150)
* actions/setup-java@v2 - Support different distributions (#132) * Implement support for custom vendors in setup-java * minor improvements * minor refactoring * Add unit tests and e2e tests * Update documentation for setup-java@v2 release * minor improvements * regenerate dist * fix comments * resolve comments * resolve comments * fix tests * Update README.md Co-authored-by: George Adams <george.adams@microsoft.com> * Apply suggestions from code review Co-authored-by: Konrad Pabjan <konradpabjan@github.com> * fix minor nitpicks * handle 4th digit * pull latest main * Update README.md * rename adoptium to adopt * rename adoptium to adopt * rename adoptium to adopt * Update README.md * make java-version and distribution required for action * update readme * fix tests * fix e2e tests Co-authored-by: George Adams <george.adams@microsoft.com> Co-authored-by: Konrad Pabjan <konradpabjan@github.com> * Add "overwrite-settings" input parameter (#136) * add overwrite-settings parameter * fix e2e tests * print debug * fix e2e tests * add comment * remove comment * Add "Contents/Home" postfix on macOS if provider creates it (#139) * Update e2e-versions.yml * Update e2e-versions.yml * implement fix * Update e2e-versions.yml * Update installer.ts * fix filter logic * Update e2e-versions.yml * remove extra logic * Update e2e-versions.yml * Add check-latest flag (#141) * add changes for check-latest * run prerelease script * resolving comments * fixing tests * fix spelling * improve core.info messages * run format * run prerelease * change version to fix test * resolve comment for check-latest * Update README.md * added hosted tool cache section * Apply suggestions from code review Co-authored-by: Maxim Lobanov <v-malob@microsoft.com> Co-authored-by: Konrad Pabjan <konradpabjan@github.com> * Avoid "+" sign in Java path in v2-preview (#145) * try to handle _ versions * more logs * more debug * test 1 * more fixes * fix typo * Update e2e-versions.yml * add unit-tests * remove debug info from tests * debug pre-cached versions * change e2e tests to ubuntu-latest * update npm licenses Co-authored-by: George Adams <george.adams@microsoft.com> Co-authored-by: Konrad Pabjan <konradpabjan@github.com> Co-authored-by: Dmitry Shibanov <dmitry-shibanov@github.com>
This commit is contained in:
		| @@ -1,14 +1,7 @@ | ||||
| import io = require('@actions/io'); | ||||
| import fs = require('fs'); | ||||
| import os = require('os'); | ||||
| import path = require('path'); | ||||
|  | ||||
| // make the os.homedir() call be local to the tests | ||||
| jest.doMock('os', () => { | ||||
|   return { | ||||
|     homedir: jest.fn(() => __dirname) | ||||
|   }; | ||||
| }); | ||||
| import os from 'os'; | ||||
|  | ||||
| import * as auth from '../src/auth'; | ||||
|  | ||||
| @@ -16,8 +9,12 @@ const m2Dir = path.join(__dirname, auth.M2_DIR); | ||||
| const settingsFile = path.join(m2Dir, auth.SETTINGS_FILE); | ||||
|  | ||||
| describe('auth tests', () => { | ||||
|   let spyOSHomedir: jest.SpyInstance; | ||||
|  | ||||
|   beforeEach(async () => { | ||||
|     await io.rmRF(m2Dir); | ||||
|     spyOSHomedir = jest.spyOn(os, 'homedir'); | ||||
|     spyOSHomedir.mockReturnValue(__dirname); | ||||
|   }, 300000); | ||||
|  | ||||
|   afterAll(async () => { | ||||
| @@ -26,6 +23,9 @@ describe('auth tests', () => { | ||||
|     } catch { | ||||
|       console.log('Failed to remove test directories'); | ||||
|     } | ||||
|     jest.resetAllMocks(); | ||||
|     jest.clearAllMocks(); | ||||
|     jest.restoreAllMocks(); | ||||
|   }, 100000); | ||||
|  | ||||
|   it('creates settings.xml in alternate locations', async () => { | ||||
| @@ -35,10 +35,9 @@ describe('auth tests', () => { | ||||
|  | ||||
|     const altHome = path.join(__dirname, 'runner', 'settings'); | ||||
|     const altSettingsFile = path.join(altHome, auth.SETTINGS_FILE); | ||||
|     process.env[`INPUT_SETTINGS-PATH`] = altHome; | ||||
|     await io.rmRF(altHome); // ensure it doesn't already exist | ||||
|  | ||||
|     await auth.configAuthentication(id, username, password); | ||||
|     await auth.createAuthenticationSettings(id, username, password, altHome, true); | ||||
|  | ||||
|     expect(fs.existsSync(m2Dir)).toBe(false); | ||||
|     expect(fs.existsSync(settingsFile)).toBe(false); | ||||
| @@ -49,7 +48,6 @@ describe('auth tests', () => { | ||||
|       auth.generate(id, username, password) | ||||
|     ); | ||||
|  | ||||
|     delete process.env[`INPUT_SETTINGS-PATH`]; | ||||
|     await io.rmRF(altHome); | ||||
|   }, 100000); | ||||
|  | ||||
| @@ -58,13 +56,11 @@ describe('auth tests', () => { | ||||
|     const username = 'UNAME'; | ||||
|     const password = 'TOKEN'; | ||||
|  | ||||
|     await auth.configAuthentication(id, username, password); | ||||
|     await auth.createAuthenticationSettings(id, username, password, m2Dir, true); | ||||
|  | ||||
|     expect(fs.existsSync(m2Dir)).toBe(true); | ||||
|     expect(fs.existsSync(settingsFile)).toBe(true); | ||||
|     expect(fs.readFileSync(settingsFile, 'utf-8')).toEqual( | ||||
|       auth.generate(id, username, password) | ||||
|     ); | ||||
|     expect(fs.readFileSync(settingsFile, 'utf-8')).toEqual(auth.generate(id, username, password)); | ||||
|   }, 100000); | ||||
|  | ||||
|   it('creates settings.xml with additional configuration', async () => { | ||||
| @@ -73,7 +69,7 @@ describe('auth tests', () => { | ||||
|     const password = 'TOKEN'; | ||||
|     const gpgPassphrase = 'GPG'; | ||||
|  | ||||
|     await auth.configAuthentication(id, username, password, gpgPassphrase); | ||||
|     await auth.createAuthenticationSettings(id, username, password, m2Dir, true, gpgPassphrase); | ||||
|  | ||||
|     expect(fs.existsSync(m2Dir)).toBe(true); | ||||
|     expect(fs.existsSync(settingsFile)).toBe(true); | ||||
| @@ -87,18 +83,33 @@ describe('auth tests', () => { | ||||
|     const username = 'USERNAME'; | ||||
|     const password = 'PASSWORD'; | ||||
|  | ||||
|     fs.mkdirSync(m2Dir, {recursive: true}); | ||||
|     fs.mkdirSync(m2Dir, { recursive: true }); | ||||
|     fs.writeFileSync(settingsFile, 'FAKE FILE'); | ||||
|     expect(fs.existsSync(m2Dir)).toBe(true); | ||||
|     expect(fs.existsSync(settingsFile)).toBe(true); | ||||
|  | ||||
|     await auth.configAuthentication(id, username, password); | ||||
|     await auth.createAuthenticationSettings(id, username, password, m2Dir, true); | ||||
|  | ||||
|     expect(fs.existsSync(m2Dir)).toBe(true); | ||||
|     expect(fs.existsSync(settingsFile)).toBe(true); | ||||
|     expect(fs.readFileSync(settingsFile, 'utf-8')).toEqual( | ||||
|       auth.generate(id, username, password) | ||||
|     ); | ||||
|     expect(fs.readFileSync(settingsFile, 'utf-8')).toEqual(auth.generate(id, username, password)); | ||||
|   }, 100000); | ||||
|  | ||||
|   it('does not overwrite existing settings.xml files', async () => { | ||||
|     const id = 'packages'; | ||||
|     const username = 'USERNAME'; | ||||
|     const password = 'PASSWORD'; | ||||
|  | ||||
|     fs.mkdirSync(m2Dir, { recursive: true }); | ||||
|     fs.writeFileSync(settingsFile, 'FAKE FILE'); | ||||
|     expect(fs.existsSync(m2Dir)).toBe(true); | ||||
|     expect(fs.existsSync(settingsFile)).toBe(true); | ||||
|  | ||||
|     await auth.createAuthenticationSettings(id, username, password, m2Dir, false); | ||||
|  | ||||
|     expect(fs.existsSync(m2Dir)).toBe(true); | ||||
|     expect(fs.existsSync(settingsFile)).toBe(true); | ||||
|     expect(fs.readFileSync(settingsFile, 'utf-8')).toEqual('FAKE FILE'); | ||||
|   }, 100000); | ||||
|  | ||||
|   it('generates valid settings.xml with minimal configuration', () => { | ||||
| @@ -143,8 +154,6 @@ describe('auth tests', () => { | ||||
|   </servers> | ||||
| </settings>`; | ||||
|  | ||||
|     expect(auth.generate(id, username, password, gpgPassphrase)).toEqual( | ||||
|       expectedSettings | ||||
|     ); | ||||
|     expect(auth.generate(id, username, password, gpgPassphrase)).toEqual(expectedSettings); | ||||
|   }); | ||||
| }); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Maxim Lobanov
					Maxim Lobanov