mirror of
				https://git.mirrors.martin98.com/https://github.com/actions/upload-artifact
				synced 2025-10-31 16:11:08 +08:00 
			
		
		
		
	Exclude hidden files by default backport
This commit is contained in:
		
							parent
							
								
									a8a3f3ad30
								
							
						
					
					
						commit
						afc7e4a27d
					
				| @ -61,6 +61,20 @@ const lonelyFilePath = path.join( | |||||||
|   'lonely-file.txt' |   'lonely-file.txt' | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | const hiddenFile = path.join(root, '.hidden-file.txt') | ||||||
|  | const fileInHiddenFolderPath = path.join( | ||||||
|  |   root, | ||||||
|  |   '.hidden-folder', | ||||||
|  |   'folder-in-hidden-folder', | ||||||
|  |   'file.txt' | ||||||
|  | ) | ||||||
|  | const fileInHiddenFolderInFolderA = path.join( | ||||||
|  |   root, | ||||||
|  |   'folder-a', | ||||||
|  |   '.hidden-folder-in-folder-a', | ||||||
|  |   'file.txt' | ||||||
|  | ) | ||||||
|  | 
 | ||||||
| describe('Search', () => { | describe('Search', () => { | ||||||
|   beforeAll(async () => { |   beforeAll(async () => { | ||||||
|     // mock all output so that there is less noise when running tests
 |     // mock all output so that there is less noise when running tests
 | ||||||
| @ -92,6 +106,13 @@ describe('Search', () => { | |||||||
|     await fs.mkdir(path.join(root, 'folder-h', 'folder-j', 'folder-k'), { |     await fs.mkdir(path.join(root, 'folder-h', 'folder-j', 'folder-k'), { | ||||||
|       recursive: true |       recursive: true | ||||||
|     }) |     }) | ||||||
|  |     await fs.mkdir( | ||||||
|  |       path.join(root, '.hidden-folder', 'folder-in-hidden-folder'), | ||||||
|  |       {recursive: true} | ||||||
|  |     ) | ||||||
|  |     await fs.mkdir(path.join(root, 'folder-a', '.hidden-folder-in-folder-a'), { | ||||||
|  |       recursive: true | ||||||
|  |     }) | ||||||
| 
 | 
 | ||||||
|     await fs.writeFile(searchItem1Path, 'search item1 file') |     await fs.writeFile(searchItem1Path, 'search item1 file') | ||||||
|     await fs.writeFile(searchItem2Path, 'search item2 file') |     await fs.writeFile(searchItem2Path, 'search item2 file') | ||||||
| @ -110,10 +131,19 @@ describe('Search', () => { | |||||||
|     await fs.writeFile(amazingFileInFolderHPath, 'amazing file') |     await fs.writeFile(amazingFileInFolderHPath, 'amazing file') | ||||||
| 
 | 
 | ||||||
|     await fs.writeFile(lonelyFilePath, 'all by itself') |     await fs.writeFile(lonelyFilePath, 'all by itself') | ||||||
|  | 
 | ||||||
|  |     await fs.writeFile(hiddenFile, 'hidden file') | ||||||
|  |     await fs.writeFile(fileInHiddenFolderPath, 'file in hidden directory') | ||||||
|  |     await fs.writeFile(fileInHiddenFolderInFolderA, 'file in hidden directory') | ||||||
|     /* |     /* | ||||||
|       Directory structure of files that get created: |       Directory structure of files that get created: | ||||||
|       root/ |       root/ | ||||||
|  |           .hidden-folder/ | ||||||
|  |             folder-in-hidden-folder/ | ||||||
|  |               file.txt | ||||||
|           folder-a/ |           folder-a/ | ||||||
|  |               .hidden-folder-in-folder-a/ | ||||||
|  |                 file.txt | ||||||
|               folder-b/ |               folder-b/ | ||||||
|                   folder-c/ |                   folder-c/ | ||||||
|                       search-item1.txt |                       search-item1.txt | ||||||
| @ -136,6 +166,7 @@ describe('Search', () => { | |||||||
|               folder-j/ |               folder-j/ | ||||||
|                   folder-k/ |                   folder-k/ | ||||||
|                       lonely-file.txt |                       lonely-file.txt | ||||||
|  |           .hidden-file.txt | ||||||
|           search-item5.txt |           search-item5.txt | ||||||
|     */ |     */ | ||||||
|   }) |   }) | ||||||
| @ -352,4 +383,24 @@ describe('Search', () => { | |||||||
|     ) |     ) | ||||||
|     expect(searchResult.filesToUpload.includes(lonelyFilePath)).toEqual(true) |     expect(searchResult.filesToUpload.includes(lonelyFilePath)).toEqual(true) | ||||||
|   }) |   }) | ||||||
|  | 
 | ||||||
|  |   it('Hidden files ignored by default', async () => { | ||||||
|  |     const searchPath = path.join(root, '**/*') | ||||||
|  |     const searchResult = await findFilesToUpload(searchPath) | ||||||
|  | 
 | ||||||
|  |     expect(searchResult.filesToUpload).not.toContain(hiddenFile) | ||||||
|  |     expect(searchResult.filesToUpload).not.toContain(fileInHiddenFolderPath) | ||||||
|  |     expect(searchResult.filesToUpload).not.toContain( | ||||||
|  |       fileInHiddenFolderInFolderA | ||||||
|  |     ) | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|  |   it('Hidden files included', async () => { | ||||||
|  |     const searchPath = path.join(root, '**/*') | ||||||
|  |     const searchResult = await findFilesToUpload(searchPath, true) | ||||||
|  | 
 | ||||||
|  |     expect(searchResult.filesToUpload).toContain(hiddenFile) | ||||||
|  |     expect(searchResult.filesToUpload).toContain(fileInHiddenFolderPath) | ||||||
|  |     expect(searchResult.filesToUpload).toContain(fileInHiddenFolderInFolderA) | ||||||
|  |   }) | ||||||
| }) | }) | ||||||
|  | |||||||
							
								
								
									
										155
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										155
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							| @ -3276,16 +3276,18 @@ exports.create = create; | |||||||
|  * Computes the sha256 hash of a glob |  * Computes the sha256 hash of a glob | ||||||
|  * |  * | ||||||
|  * @param patterns  Patterns separated by newlines |  * @param patterns  Patterns separated by newlines | ||||||
|  |  * @param currentWorkspace  Workspace used when matching files | ||||||
|  * @param options   Glob options |  * @param options   Glob options | ||||||
|  |  * @param verbose   Enables verbose logging | ||||||
|  */ |  */ | ||||||
| function hashFiles(patterns, options, verbose = false) { | function hashFiles(patterns, currentWorkspace = '', options, verbose = false) { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         let followSymbolicLinks = true; |         let followSymbolicLinks = true; | ||||||
|         if (options && typeof options.followSymbolicLinks === 'boolean') { |         if (options && typeof options.followSymbolicLinks === 'boolean') { | ||||||
|             followSymbolicLinks = options.followSymbolicLinks; |             followSymbolicLinks = options.followSymbolicLinks; | ||||||
|         } |         } | ||||||
|         const globber = yield create(patterns, { followSymbolicLinks }); |         const globber = yield create(patterns, { followSymbolicLinks }); | ||||||
|         return internal_hash_files_1.hashFiles(globber, verbose); |         return (0, internal_hash_files_1.hashFiles)(globber, currentWorkspace, verbose); | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
| exports.hashFiles = hashFiles; | exports.hashFiles = hashFiles; | ||||||
| @ -3300,7 +3302,11 @@ exports.hashFiles = hashFiles; | |||||||
| 
 | 
 | ||||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); |     var desc = Object.getOwnPropertyDescriptor(m, k); | ||||||
|  |     if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { | ||||||
|  |       desc = { enumerable: true, get: function() { return m[k]; } }; | ||||||
|  |     } | ||||||
|  |     Object.defineProperty(o, k2, desc); | ||||||
| }) : (function(o, m, k, k2) { | }) : (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     o[k2] = m[k]; |     o[k2] = m[k]; | ||||||
| @ -3313,7 +3319,7 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | |||||||
| var __importStar = (this && this.__importStar) || function (mod) { | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|     if (mod && mod.__esModule) return mod; |     if (mod && mod.__esModule) return mod; | ||||||
|     var result = {}; |     var result = {}; | ||||||
|     if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); |     if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||||
|     __setModuleDefault(result, mod); |     __setModuleDefault(result, mod); | ||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
| @ -3328,7 +3334,8 @@ function getOptions(copy) { | |||||||
|         followSymbolicLinks: true, |         followSymbolicLinks: true, | ||||||
|         implicitDescendants: true, |         implicitDescendants: true, | ||||||
|         matchDirectories: true, |         matchDirectories: true, | ||||||
|         omitBrokenSymbolicLinks: true |         omitBrokenSymbolicLinks: true, | ||||||
|  |         excludeHiddenFiles: false | ||||||
|     }; |     }; | ||||||
|     if (copy) { |     if (copy) { | ||||||
|         if (typeof copy.followSymbolicLinks === 'boolean') { |         if (typeof copy.followSymbolicLinks === 'boolean') { | ||||||
| @ -3347,6 +3354,10 @@ function getOptions(copy) { | |||||||
|             result.omitBrokenSymbolicLinks = copy.omitBrokenSymbolicLinks; |             result.omitBrokenSymbolicLinks = copy.omitBrokenSymbolicLinks; | ||||||
|             core.debug(`omitBrokenSymbolicLinks '${result.omitBrokenSymbolicLinks}'`); |             core.debug(`omitBrokenSymbolicLinks '${result.omitBrokenSymbolicLinks}'`); | ||||||
|         } |         } | ||||||
|  |         if (typeof copy.excludeHiddenFiles === 'boolean') { | ||||||
|  |             result.excludeHiddenFiles = copy.excludeHiddenFiles; | ||||||
|  |             core.debug(`excludeHiddenFiles '${result.excludeHiddenFiles}'`); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|     return result; |     return result; | ||||||
| } | } | ||||||
| @ -3362,7 +3373,11 @@ exports.getOptions = getOptions; | |||||||
| 
 | 
 | ||||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); |     var desc = Object.getOwnPropertyDescriptor(m, k); | ||||||
|  |     if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { | ||||||
|  |       desc = { enumerable: true, get: function() { return m[k]; } }; | ||||||
|  |     } | ||||||
|  |     Object.defineProperty(o, k2, desc); | ||||||
| }) : (function(o, m, k, k2) { | }) : (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     o[k2] = m[k]; |     o[k2] = m[k]; | ||||||
| @ -3375,7 +3390,7 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | |||||||
| var __importStar = (this && this.__importStar) || function (mod) { | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|     if (mod && mod.__esModule) return mod; |     if (mod && mod.__esModule) return mod; | ||||||
|     var result = {}; |     var result = {}; | ||||||
|     if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); |     if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||||
|     __setModuleDefault(result, mod); |     __setModuleDefault(result, mod); | ||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
| @ -3429,19 +3444,21 @@ class DefaultGlobber { | |||||||
|         return this.searchPaths.slice(); |         return this.searchPaths.slice(); | ||||||
|     } |     } | ||||||
|     glob() { |     glob() { | ||||||
|         var e_1, _a; |         var _a, e_1, _b, _c; | ||||||
|         return __awaiter(this, void 0, void 0, function* () { |         return __awaiter(this, void 0, void 0, function* () { | ||||||
|             const result = []; |             const result = []; | ||||||
|             try { |             try { | ||||||
|                 for (var _b = __asyncValues(this.globGenerator()), _c; _c = yield _b.next(), !_c.done;) { |                 for (var _d = true, _e = __asyncValues(this.globGenerator()), _f; _f = yield _e.next(), _a = _f.done, !_a; _d = true) { | ||||||
|                     const itemPath = _c.value; |                     _c = _f.value; | ||||||
|  |                     _d = false; | ||||||
|  |                     const itemPath = _c; | ||||||
|                     result.push(itemPath); |                     result.push(itemPath); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             catch (e_1_1) { e_1 = { error: e_1_1 }; } |             catch (e_1_1) { e_1 = { error: e_1_1 }; } | ||||||
|             finally { |             finally { | ||||||
|                 try { |                 try { | ||||||
|                     if (_c && !_c.done && (_a = _b.return)) yield _a.call(_b); |                     if (!_d && !_a && (_b = _e.return)) yield _b.call(_e); | ||||||
|                 } |                 } | ||||||
|                 finally { if (e_1) throw e_1.error; } |                 finally { if (e_1) throw e_1.error; } | ||||||
|             } |             } | ||||||
| @ -3499,6 +3516,10 @@ class DefaultGlobber { | |||||||
|                 if (!stats) { |                 if (!stats) { | ||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
|  |                 // Hidden file or directory?
 | ||||||
|  |                 if (options.excludeHiddenFiles && path.basename(item.path).match(/^\./)) { | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|                 // Directory
 |                 // Directory
 | ||||||
|                 if (stats.isDirectory()) { |                 if (stats.isDirectory()) { | ||||||
|                     // Matched
 |                     // Matched
 | ||||||
| @ -3604,7 +3625,11 @@ exports.DefaultGlobber = DefaultGlobber; | |||||||
| 
 | 
 | ||||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); |     var desc = Object.getOwnPropertyDescriptor(m, k); | ||||||
|  |     if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { | ||||||
|  |       desc = { enumerable: true, get: function() { return m[k]; } }; | ||||||
|  |     } | ||||||
|  |     Object.defineProperty(o, k2, desc); | ||||||
| }) : (function(o, m, k, k2) { | }) : (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     o[k2] = m[k]; |     o[k2] = m[k]; | ||||||
| @ -3617,7 +3642,7 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | |||||||
| var __importStar = (this && this.__importStar) || function (mod) { | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|     if (mod && mod.__esModule) return mod; |     if (mod && mod.__esModule) return mod; | ||||||
|     var result = {}; |     var result = {}; | ||||||
|     if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); |     if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||||
|     __setModuleDefault(result, mod); |     __setModuleDefault(result, mod); | ||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
| @ -3645,18 +3670,22 @@ const fs = __importStar(__nccwpck_require__(7147)); | |||||||
| const stream = __importStar(__nccwpck_require__(2781)); | const stream = __importStar(__nccwpck_require__(2781)); | ||||||
| const util = __importStar(__nccwpck_require__(3837)); | const util = __importStar(__nccwpck_require__(3837)); | ||||||
| const path = __importStar(__nccwpck_require__(1017)); | const path = __importStar(__nccwpck_require__(1017)); | ||||||
| function hashFiles(globber, verbose = false) { | function hashFiles(globber, currentWorkspace, verbose = false) { | ||||||
|     var e_1, _a; |     var _a, e_1, _b, _c; | ||||||
|     var _b; |     var _d; | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         const writeDelegate = verbose ? core.info : core.debug; |         const writeDelegate = verbose ? core.info : core.debug; | ||||||
|         let hasMatch = false; |         let hasMatch = false; | ||||||
|         const githubWorkspace = (_b = process.env['GITHUB_WORKSPACE']) !== null && _b !== void 0 ? _b : process.cwd(); |         const githubWorkspace = currentWorkspace | ||||||
|  |             ? currentWorkspace | ||||||
|  |             : (_d = process.env['GITHUB_WORKSPACE']) !== null && _d !== void 0 ? _d : process.cwd(); | ||||||
|         const result = crypto.createHash('sha256'); |         const result = crypto.createHash('sha256'); | ||||||
|         let count = 0; |         let count = 0; | ||||||
|         try { |         try { | ||||||
|             for (var _c = __asyncValues(globber.globGenerator()), _d; _d = yield _c.next(), !_d.done;) { |             for (var _e = true, _f = __asyncValues(globber.globGenerator()), _g; _g = yield _f.next(), _a = _g.done, !_a; _e = true) { | ||||||
|                 const file = _d.value; |                 _c = _g.value; | ||||||
|  |                 _e = false; | ||||||
|  |                 const file = _c; | ||||||
|                 writeDelegate(file); |                 writeDelegate(file); | ||||||
|                 if (!file.startsWith(`${githubWorkspace}${path.sep}`)) { |                 if (!file.startsWith(`${githubWorkspace}${path.sep}`)) { | ||||||
|                     writeDelegate(`Ignore '${file}' since it is not under GITHUB_WORKSPACE.`); |                     writeDelegate(`Ignore '${file}' since it is not under GITHUB_WORKSPACE.`); | ||||||
| @ -3679,7 +3708,7 @@ function hashFiles(globber, verbose = false) { | |||||||
|         catch (e_1_1) { e_1 = { error: e_1_1 }; } |         catch (e_1_1) { e_1 = { error: e_1_1 }; } | ||||||
|         finally { |         finally { | ||||||
|             try { |             try { | ||||||
|                 if (_d && !_d.done && (_a = _c.return)) yield _a.call(_c); |                 if (!_e && !_a && (_b = _f.return)) yield _b.call(_f); | ||||||
|             } |             } | ||||||
|             finally { if (e_1) throw e_1.error; } |             finally { if (e_1) throw e_1.error; } | ||||||
|         } |         } | ||||||
| @ -3719,7 +3748,7 @@ var MatchKind; | |||||||
|     MatchKind[MatchKind["File"] = 2] = "File"; |     MatchKind[MatchKind["File"] = 2] = "File"; | ||||||
|     /** Matched */ |     /** Matched */ | ||||||
|     MatchKind[MatchKind["All"] = 3] = "All"; |     MatchKind[MatchKind["All"] = 3] = "All"; | ||||||
| })(MatchKind = exports.MatchKind || (exports.MatchKind = {})); | })(MatchKind || (exports.MatchKind = MatchKind = {})); | ||||||
| //# sourceMappingURL=internal-match-kind.js.map
 | //# sourceMappingURL=internal-match-kind.js.map
 | ||||||
| 
 | 
 | ||||||
| /***/ }), | /***/ }), | ||||||
| @ -3731,7 +3760,11 @@ var MatchKind; | |||||||
| 
 | 
 | ||||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); |     var desc = Object.getOwnPropertyDescriptor(m, k); | ||||||
|  |     if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { | ||||||
|  |       desc = { enumerable: true, get: function() { return m[k]; } }; | ||||||
|  |     } | ||||||
|  |     Object.defineProperty(o, k2, desc); | ||||||
| }) : (function(o, m, k, k2) { | }) : (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     o[k2] = m[k]; |     o[k2] = m[k]; | ||||||
| @ -3744,7 +3777,7 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | |||||||
| var __importStar = (this && this.__importStar) || function (mod) { | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|     if (mod && mod.__esModule) return mod; |     if (mod && mod.__esModule) return mod; | ||||||
|     var result = {}; |     var result = {}; | ||||||
|     if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); |     if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||||
|     __setModuleDefault(result, mod); |     __setModuleDefault(result, mod); | ||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
| @ -3794,8 +3827,8 @@ exports.dirname = dirname; | |||||||
|  * or `C:` are expanded based on the current working directory. |  * or `C:` are expanded based on the current working directory. | ||||||
|  */ |  */ | ||||||
| function ensureAbsoluteRoot(root, itemPath) { | function ensureAbsoluteRoot(root, itemPath) { | ||||||
|     assert_1.default(root, `ensureAbsoluteRoot parameter 'root' must not be empty`); |     (0, assert_1.default)(root, `ensureAbsoluteRoot parameter 'root' must not be empty`); | ||||||
|     assert_1.default(itemPath, `ensureAbsoluteRoot parameter 'itemPath' must not be empty`); |     (0, assert_1.default)(itemPath, `ensureAbsoluteRoot parameter 'itemPath' must not be empty`); | ||||||
|     // Already rooted
 |     // Already rooted
 | ||||||
|     if (hasAbsoluteRoot(itemPath)) { |     if (hasAbsoluteRoot(itemPath)) { | ||||||
|         return itemPath; |         return itemPath; | ||||||
| @ -3805,7 +3838,7 @@ function ensureAbsoluteRoot(root, itemPath) { | |||||||
|         // Check for itemPath like C: or C:foo
 |         // Check for itemPath like C: or C:foo
 | ||||||
|         if (itemPath.match(/^[A-Z]:[^\\/]|^[A-Z]:$/i)) { |         if (itemPath.match(/^[A-Z]:[^\\/]|^[A-Z]:$/i)) { | ||||||
|             let cwd = process.cwd(); |             let cwd = process.cwd(); | ||||||
|             assert_1.default(cwd.match(/^[A-Z]:\\/i), `Expected current directory to start with an absolute drive root. Actual '${cwd}'`); |             (0, assert_1.default)(cwd.match(/^[A-Z]:\\/i), `Expected current directory to start with an absolute drive root. Actual '${cwd}'`); | ||||||
|             // Drive letter matches cwd? Expand to cwd
 |             // Drive letter matches cwd? Expand to cwd
 | ||||||
|             if (itemPath[0].toUpperCase() === cwd[0].toUpperCase()) { |             if (itemPath[0].toUpperCase() === cwd[0].toUpperCase()) { | ||||||
|                 // Drive only, e.g. C:
 |                 // Drive only, e.g. C:
 | ||||||
| @ -3830,11 +3863,11 @@ function ensureAbsoluteRoot(root, itemPath) { | |||||||
|         // Check for itemPath like \ or \foo
 |         // Check for itemPath like \ or \foo
 | ||||||
|         else if (normalizeSeparators(itemPath).match(/^\\$|^\\[^\\]/)) { |         else if (normalizeSeparators(itemPath).match(/^\\$|^\\[^\\]/)) { | ||||||
|             const cwd = process.cwd(); |             const cwd = process.cwd(); | ||||||
|             assert_1.default(cwd.match(/^[A-Z]:\\/i), `Expected current directory to start with an absolute drive root. Actual '${cwd}'`); |             (0, assert_1.default)(cwd.match(/^[A-Z]:\\/i), `Expected current directory to start with an absolute drive root. Actual '${cwd}'`); | ||||||
|             return `${cwd[0]}:\\${itemPath.substr(1)}`; |             return `${cwd[0]}:\\${itemPath.substr(1)}`; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     assert_1.default(hasAbsoluteRoot(root), `ensureAbsoluteRoot parameter 'root' must have an absolute root`); |     (0, assert_1.default)(hasAbsoluteRoot(root), `ensureAbsoluteRoot parameter 'root' must have an absolute root`); | ||||||
|     // Otherwise ensure root ends with a separator
 |     // Otherwise ensure root ends with a separator
 | ||||||
|     if (root.endsWith('/') || (IS_WINDOWS && root.endsWith('\\'))) { |     if (root.endsWith('/') || (IS_WINDOWS && root.endsWith('\\'))) { | ||||||
|         // Intentionally empty
 |         // Intentionally empty
 | ||||||
| @ -3851,7 +3884,7 @@ exports.ensureAbsoluteRoot = ensureAbsoluteRoot; | |||||||
|  * `\\hello\share` and `C:\hello` (and using alternate separator). |  * `\\hello\share` and `C:\hello` (and using alternate separator). | ||||||
|  */ |  */ | ||||||
| function hasAbsoluteRoot(itemPath) { | function hasAbsoluteRoot(itemPath) { | ||||||
|     assert_1.default(itemPath, `hasAbsoluteRoot parameter 'itemPath' must not be empty`); |     (0, assert_1.default)(itemPath, `hasAbsoluteRoot parameter 'itemPath' must not be empty`); | ||||||
|     // Normalize separators
 |     // Normalize separators
 | ||||||
|     itemPath = normalizeSeparators(itemPath); |     itemPath = normalizeSeparators(itemPath); | ||||||
|     // Windows
 |     // Windows
 | ||||||
| @ -3868,7 +3901,7 @@ exports.hasAbsoluteRoot = hasAbsoluteRoot; | |||||||
|  * `\`, `\hello`, `\\hello\share`, `C:`, and `C:\hello` (and using alternate separator).
 |  * `\`, `\hello`, `\\hello\share`, `C:`, and `C:\hello` (and using alternate separator).
 | ||||||
|  */ |  */ | ||||||
| function hasRoot(itemPath) { | function hasRoot(itemPath) { | ||||||
|     assert_1.default(itemPath, `isRooted parameter 'itemPath' must not be empty`); |     (0, assert_1.default)(itemPath, `isRooted parameter 'itemPath' must not be empty`); | ||||||
|     // Normalize separators
 |     // Normalize separators
 | ||||||
|     itemPath = normalizeSeparators(itemPath); |     itemPath = normalizeSeparators(itemPath); | ||||||
|     // Windows
 |     // Windows
 | ||||||
| @ -3936,7 +3969,11 @@ exports.safeTrimTrailingSeparator = safeTrimTrailingSeparator; | |||||||
| 
 | 
 | ||||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); |     var desc = Object.getOwnPropertyDescriptor(m, k); | ||||||
|  |     if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { | ||||||
|  |       desc = { enumerable: true, get: function() { return m[k]; } }; | ||||||
|  |     } | ||||||
|  |     Object.defineProperty(o, k2, desc); | ||||||
| }) : (function(o, m, k, k2) { | }) : (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     o[k2] = m[k]; |     o[k2] = m[k]; | ||||||
| @ -3949,7 +3986,7 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | |||||||
| var __importStar = (this && this.__importStar) || function (mod) { | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|     if (mod && mod.__esModule) return mod; |     if (mod && mod.__esModule) return mod; | ||||||
|     var result = {}; |     var result = {}; | ||||||
|     if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); |     if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||||
|     __setModuleDefault(result, mod); |     __setModuleDefault(result, mod); | ||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
| @ -3974,7 +4011,7 @@ class Path { | |||||||
|         this.segments = []; |         this.segments = []; | ||||||
|         // String
 |         // String
 | ||||||
|         if (typeof itemPath === 'string') { |         if (typeof itemPath === 'string') { | ||||||
|             assert_1.default(itemPath, `Parameter 'itemPath' must not be empty`); |             (0, assert_1.default)(itemPath, `Parameter 'itemPath' must not be empty`); | ||||||
|             // Normalize slashes and trim unnecessary trailing slash
 |             // Normalize slashes and trim unnecessary trailing slash
 | ||||||
|             itemPath = pathHelper.safeTrimTrailingSeparator(itemPath); |             itemPath = pathHelper.safeTrimTrailingSeparator(itemPath); | ||||||
|             // Not rooted
 |             // Not rooted
 | ||||||
| @ -4001,24 +4038,24 @@ class Path { | |||||||
|         // Array
 |         // Array
 | ||||||
|         else { |         else { | ||||||
|             // Must not be empty
 |             // Must not be empty
 | ||||||
|             assert_1.default(itemPath.length > 0, `Parameter 'itemPath' must not be an empty array`); |             (0, assert_1.default)(itemPath.length > 0, `Parameter 'itemPath' must not be an empty array`); | ||||||
|             // Each segment
 |             // Each segment
 | ||||||
|             for (let i = 0; i < itemPath.length; i++) { |             for (let i = 0; i < itemPath.length; i++) { | ||||||
|                 let segment = itemPath[i]; |                 let segment = itemPath[i]; | ||||||
|                 // Must not be empty
 |                 // Must not be empty
 | ||||||
|                 assert_1.default(segment, `Parameter 'itemPath' must not contain any empty segments`); |                 (0, assert_1.default)(segment, `Parameter 'itemPath' must not contain any empty segments`); | ||||||
|                 // Normalize slashes
 |                 // Normalize slashes
 | ||||||
|                 segment = pathHelper.normalizeSeparators(itemPath[i]); |                 segment = pathHelper.normalizeSeparators(itemPath[i]); | ||||||
|                 // Root segment
 |                 // Root segment
 | ||||||
|                 if (i === 0 && pathHelper.hasRoot(segment)) { |                 if (i === 0 && pathHelper.hasRoot(segment)) { | ||||||
|                     segment = pathHelper.safeTrimTrailingSeparator(segment); |                     segment = pathHelper.safeTrimTrailingSeparator(segment); | ||||||
|                     assert_1.default(segment === pathHelper.dirname(segment), `Parameter 'itemPath' root segment contains information for multiple segments`); |                     (0, assert_1.default)(segment === pathHelper.dirname(segment), `Parameter 'itemPath' root segment contains information for multiple segments`); | ||||||
|                     this.segments.push(segment); |                     this.segments.push(segment); | ||||||
|                 } |                 } | ||||||
|                 // All other segments
 |                 // All other segments
 | ||||||
|                 else { |                 else { | ||||||
|                     // Must not contain slash
 |                     // Must not contain slash
 | ||||||
|                     assert_1.default(!segment.includes(path.sep), `Parameter 'itemPath' contains unexpected path separators`); |                     (0, assert_1.default)(!segment.includes(path.sep), `Parameter 'itemPath' contains unexpected path separators`); | ||||||
|                     this.segments.push(segment); |                     this.segments.push(segment); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @ -4056,7 +4093,11 @@ exports.Path = Path; | |||||||
| 
 | 
 | ||||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); |     var desc = Object.getOwnPropertyDescriptor(m, k); | ||||||
|  |     if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { | ||||||
|  |       desc = { enumerable: true, get: function() { return m[k]; } }; | ||||||
|  |     } | ||||||
|  |     Object.defineProperty(o, k2, desc); | ||||||
| }) : (function(o, m, k, k2) { | }) : (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     o[k2] = m[k]; |     o[k2] = m[k]; | ||||||
| @ -4069,7 +4110,7 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | |||||||
| var __importStar = (this && this.__importStar) || function (mod) { | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|     if (mod && mod.__esModule) return mod; |     if (mod && mod.__esModule) return mod; | ||||||
|     var result = {}; |     var result = {}; | ||||||
|     if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); |     if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||||
|     __setModuleDefault(result, mod); |     __setModuleDefault(result, mod); | ||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
| @ -4157,7 +4198,11 @@ exports.partialMatch = partialMatch; | |||||||
| 
 | 
 | ||||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); |     var desc = Object.getOwnPropertyDescriptor(m, k); | ||||||
|  |     if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { | ||||||
|  |       desc = { enumerable: true, get: function() { return m[k]; } }; | ||||||
|  |     } | ||||||
|  |     Object.defineProperty(o, k2, desc); | ||||||
| }) : (function(o, m, k, k2) { | }) : (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     o[k2] = m[k]; |     o[k2] = m[k]; | ||||||
| @ -4170,7 +4215,7 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | |||||||
| var __importStar = (this && this.__importStar) || function (mod) { | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|     if (mod && mod.__esModule) return mod; |     if (mod && mod.__esModule) return mod; | ||||||
|     var result = {}; |     var result = {}; | ||||||
|     if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); |     if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||||
|     __setModuleDefault(result, mod); |     __setModuleDefault(result, mod); | ||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
| @ -4202,9 +4247,9 @@ class Pattern { | |||||||
|         else { |         else { | ||||||
|             // Convert to pattern
 |             // Convert to pattern
 | ||||||
|             segments = segments || []; |             segments = segments || []; | ||||||
|             assert_1.default(segments.length, `Parameter 'segments' must not empty`); |             (0, assert_1.default)(segments.length, `Parameter 'segments' must not empty`); | ||||||
|             const root = Pattern.getLiteral(segments[0]); |             const root = Pattern.getLiteral(segments[0]); | ||||||
|             assert_1.default(root && pathHelper.hasAbsoluteRoot(root), `Parameter 'segments' first element must be a root path`); |             (0, assert_1.default)(root && pathHelper.hasAbsoluteRoot(root), `Parameter 'segments' first element must be a root path`); | ||||||
|             pattern = new internal_path_1.Path(segments).toString().trim(); |             pattern = new internal_path_1.Path(segments).toString().trim(); | ||||||
|             if (patternOrNegate) { |             if (patternOrNegate) { | ||||||
|                 pattern = `!${pattern}`; |                 pattern = `!${pattern}`; | ||||||
| @ -4298,13 +4343,13 @@ class Pattern { | |||||||
|      */ |      */ | ||||||
|     static fixupPattern(pattern, homedir) { |     static fixupPattern(pattern, homedir) { | ||||||
|         // Empty
 |         // Empty
 | ||||||
|         assert_1.default(pattern, 'pattern cannot be empty'); |         (0, assert_1.default)(pattern, 'pattern cannot be empty'); | ||||||
|         // Must not contain `.` segment, unless first segment
 |         // Must not contain `.` segment, unless first segment
 | ||||||
|         // Must not contain `..` segment
 |         // Must not contain `..` segment
 | ||||||
|         const literalSegments = new internal_path_1.Path(pattern).segments.map(x => Pattern.getLiteral(x)); |         const literalSegments = new internal_path_1.Path(pattern).segments.map(x => Pattern.getLiteral(x)); | ||||||
|         assert_1.default(literalSegments.every((x, i) => (x !== '.' || i === 0) && x !== '..'), `Invalid pattern '${pattern}'. Relative pathing '.' and '..' is not allowed.`); |         (0, assert_1.default)(literalSegments.every((x, i) => (x !== '.' || i === 0) && x !== '..'), `Invalid pattern '${pattern}'. Relative pathing '.' and '..' is not allowed.`); | ||||||
|         // Must not contain globs in root, e.g. Windows UNC path \\foo\b*r
 |         // Must not contain globs in root, e.g. Windows UNC path \\foo\b*r
 | ||||||
|         assert_1.default(!pathHelper.hasRoot(pattern) || literalSegments[0], `Invalid pattern '${pattern}'. Root segment must not contain globs.`); |         (0, assert_1.default)(!pathHelper.hasRoot(pattern) || literalSegments[0], `Invalid pattern '${pattern}'. Root segment must not contain globs.`); | ||||||
|         // Normalize slashes
 |         // Normalize slashes
 | ||||||
|         pattern = pathHelper.normalizeSeparators(pattern); |         pattern = pathHelper.normalizeSeparators(pattern); | ||||||
|         // Replace leading `.` segment
 |         // Replace leading `.` segment
 | ||||||
| @ -4314,8 +4359,8 @@ class Pattern { | |||||||
|         // Replace leading `~` segment
 |         // Replace leading `~` segment
 | ||||||
|         else if (pattern === '~' || pattern.startsWith(`~${path.sep}`)) { |         else if (pattern === '~' || pattern.startsWith(`~${path.sep}`)) { | ||||||
|             homedir = homedir || os.homedir(); |             homedir = homedir || os.homedir(); | ||||||
|             assert_1.default(homedir, 'Unable to determine HOME directory'); |             (0, assert_1.default)(homedir, 'Unable to determine HOME directory'); | ||||||
|             assert_1.default(pathHelper.hasAbsoluteRoot(homedir), `Expected HOME directory to be a rooted path. Actual '${homedir}'`); |             (0, assert_1.default)(pathHelper.hasAbsoluteRoot(homedir), `Expected HOME directory to be a rooted path. Actual '${homedir}'`); | ||||||
|             pattern = Pattern.globEscape(homedir) + pattern.substr(1); |             pattern = Pattern.globEscape(homedir) + pattern.substr(1); | ||||||
|         } |         } | ||||||
|         // Replace relative drive root, e.g. pattern is C: or C:foo
 |         // Replace relative drive root, e.g. pattern is C: or C:foo
 | ||||||
| @ -10745,6 +10790,7 @@ var Inputs; | |||||||
|     Inputs["Path"] = "path"; |     Inputs["Path"] = "path"; | ||||||
|     Inputs["IfNoFilesFound"] = "if-no-files-found"; |     Inputs["IfNoFilesFound"] = "if-no-files-found"; | ||||||
|     Inputs["RetentionDays"] = "retention-days"; |     Inputs["RetentionDays"] = "retention-days"; | ||||||
|  |     Inputs["IncludeHiddenFiles"] = "include-hidden-files"; | ||||||
| })(Inputs = exports.Inputs || (exports.Inputs = {})); | })(Inputs = exports.Inputs || (exports.Inputs = {})); | ||||||
| var NoFileOptions; | var NoFileOptions; | ||||||
| (function (NoFileOptions) { | (function (NoFileOptions) { | ||||||
| @ -10805,13 +10851,15 @@ function getInputs() { | |||||||
|     const path = core.getInput(constants_1.Inputs.Path, { required: true }); |     const path = core.getInput(constants_1.Inputs.Path, { required: true }); | ||||||
|     const ifNoFilesFound = core.getInput(constants_1.Inputs.IfNoFilesFound); |     const ifNoFilesFound = core.getInput(constants_1.Inputs.IfNoFilesFound); | ||||||
|     const noFileBehavior = constants_1.NoFileOptions[ifNoFilesFound]; |     const noFileBehavior = constants_1.NoFileOptions[ifNoFilesFound]; | ||||||
|  |     const includeHiddenFiles = core.getBooleanInput(constants_1.Inputs.IncludeHiddenFiles); | ||||||
|     if (!noFileBehavior) { |     if (!noFileBehavior) { | ||||||
|         core.setFailed(`Unrecognized ${constants_1.Inputs.IfNoFilesFound} input. Provided: ${ifNoFilesFound}. Available options: ${Object.keys(constants_1.NoFileOptions)}`); |         core.setFailed(`Unrecognized ${constants_1.Inputs.IfNoFilesFound} input. Provided: ${ifNoFilesFound}. Available options: ${Object.keys(constants_1.NoFileOptions)}`); | ||||||
|     } |     } | ||||||
|     const inputs = { |     const inputs = { | ||||||
|         artifactName: name, |         artifactName: name, | ||||||
|         searchPath: path, |         searchPath: path, | ||||||
|         ifNoFilesFound: noFileBehavior |         ifNoFilesFound: noFileBehavior, | ||||||
|  |         includeHiddenFiles | ||||||
|     }; |     }; | ||||||
|     const retentionDaysStr = core.getInput(constants_1.Inputs.RetentionDays); |     const retentionDaysStr = core.getInput(constants_1.Inputs.RetentionDays); | ||||||
|     if (retentionDaysStr) { |     if (retentionDaysStr) { | ||||||
| @ -10873,11 +10921,12 @@ const fs_1 = __nccwpck_require__(7147); | |||||||
| const path_1 = __nccwpck_require__(1017); | const path_1 = __nccwpck_require__(1017); | ||||||
| const util_1 = __nccwpck_require__(3837); | const util_1 = __nccwpck_require__(3837); | ||||||
| const stats = (0, util_1.promisify)(fs_1.stat); | const stats = (0, util_1.promisify)(fs_1.stat); | ||||||
| function getDefaultGlobOptions() { | function getDefaultGlobOptions(includeHiddenFiles) { | ||||||
|     return { |     return { | ||||||
|         followSymbolicLinks: true, |         followSymbolicLinks: true, | ||||||
|         implicitDescendants: true, |         implicitDescendants: true, | ||||||
|         omitBrokenSymbolicLinks: true |         omitBrokenSymbolicLinks: true, | ||||||
|  |         excludeHiddenFiles: !includeHiddenFiles | ||||||
|     }; |     }; | ||||||
| } | } | ||||||
| /** | /** | ||||||
| @ -10931,10 +10980,10 @@ function getMultiPathLCA(searchPaths) { | |||||||
|     } |     } | ||||||
|     return path.join(...commonPaths); |     return path.join(...commonPaths); | ||||||
| } | } | ||||||
| function findFilesToUpload(searchPath, globOptions) { | function findFilesToUpload(searchPath, includeHiddenFiles) { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         const searchResults = []; |         const searchResults = []; | ||||||
|         const globber = yield glob.create(searchPath, globOptions || getDefaultGlobOptions()); |         const globber = yield glob.create(searchPath, getDefaultGlobOptions(includeHiddenFiles || false)); | ||||||
|         const rawSearchResults = yield globber.glob(); |         const rawSearchResults = yield globber.glob(); | ||||||
|         /* |         /* | ||||||
|           Files are saved with case insensitivity. Uploading both a.txt and A.txt will files to be overwritten |           Files are saved with case insensitivity. Uploading both a.txt and A.txt will files to be overwritten | ||||||
|  | |||||||
							
								
								
									
										18
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										18
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @ -11,7 +11,7 @@ | |||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@actions/artifact": "^1.1.2", |         "@actions/artifact": "^1.1.2", | ||||||
|         "@actions/core": "^1.10.0", |         "@actions/core": "^1.10.0", | ||||||
|         "@actions/glob": "^0.3.0", |         "@actions/glob": "^0.5.0", | ||||||
|         "@actions/io": "^1.1.2" |         "@actions/io": "^1.1.2" | ||||||
|       }, |       }, | ||||||
|       "devDependencies": { |       "devDependencies": { | ||||||
| @ -52,11 +52,11 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@actions/glob": { |     "node_modules/@actions/glob": { | ||||||
|       "version": "0.3.0", |       "version": "0.5.0", | ||||||
|       "resolved": "https://registry.npmjs.org/@actions/glob/-/glob-0.3.0.tgz", |       "resolved": "https://registry.npmjs.org/@actions/glob/-/glob-0.5.0.tgz", | ||||||
|       "integrity": "sha512-tJP1ZhF87fd6LBnaXWlahkyvdgvsLl7WnreW1EZaC8JWjpMXmzqWzQVe/IEYslrkT9ymibVrKyJN4UMD7uQM2w==", |       "integrity": "sha512-tST2rjPvJLRZLuT9NMUtyBjvj9Yo0MiJS3ow004slMvm8GFM+Zv9HvMJ7HWzfUyJnGrJvDsYkWBaaG3YKXRtCw==", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@actions/core": "^1.2.6", |         "@actions/core": "^1.9.1", | ||||||
|         "minimatch": "^3.0.4" |         "minimatch": "^3.0.4" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
| @ -6168,11 +6168,11 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "@actions/glob": { |     "@actions/glob": { | ||||||
|       "version": "0.3.0", |       "version": "0.5.0", | ||||||
|       "resolved": "https://registry.npmjs.org/@actions/glob/-/glob-0.3.0.tgz", |       "resolved": "https://registry.npmjs.org/@actions/glob/-/glob-0.5.0.tgz", | ||||||
|       "integrity": "sha512-tJP1ZhF87fd6LBnaXWlahkyvdgvsLl7WnreW1EZaC8JWjpMXmzqWzQVe/IEYslrkT9ymibVrKyJN4UMD7uQM2w==", |       "integrity": "sha512-tST2rjPvJLRZLuT9NMUtyBjvj9Yo0MiJS3ow004slMvm8GFM+Zv9HvMJ7HWzfUyJnGrJvDsYkWBaaG3YKXRtCw==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "@actions/core": "^1.2.6", |         "@actions/core": "^1.9.1", | ||||||
|         "minimatch": "^3.0.4" |         "minimatch": "^3.0.4" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  | |||||||
| @ -31,7 +31,7 @@ | |||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@actions/artifact": "^1.1.2", |     "@actions/artifact": "^1.1.2", | ||||||
|     "@actions/core": "^1.10.0", |     "@actions/core": "^1.10.0", | ||||||
|     "@actions/glob": "^0.3.0", |     "@actions/glob": "^0.5.0", | ||||||
|     "@actions/io": "^1.1.2" |     "@actions/io": "^1.1.2" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|  | |||||||
| @ -3,7 +3,8 @@ export enum Inputs { | |||||||
|   Name = 'name', |   Name = 'name', | ||||||
|   Path = 'path', |   Path = 'path', | ||||||
|   IfNoFilesFound = 'if-no-files-found', |   IfNoFilesFound = 'if-no-files-found', | ||||||
|   RetentionDays = 'retention-days' |   RetentionDays = 'retention-days', | ||||||
|  |   IncludeHiddenFiles = 'include-hidden-files' | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export enum NoFileOptions { | export enum NoFileOptions { | ||||||
|  | |||||||
| @ -11,6 +11,7 @@ export function getInputs(): UploadInputs { | |||||||
| 
 | 
 | ||||||
|   const ifNoFilesFound = core.getInput(Inputs.IfNoFilesFound) |   const ifNoFilesFound = core.getInput(Inputs.IfNoFilesFound) | ||||||
|   const noFileBehavior: NoFileOptions = NoFileOptions[ifNoFilesFound] |   const noFileBehavior: NoFileOptions = NoFileOptions[ifNoFilesFound] | ||||||
|  |   const includeHiddenFiles = core.getBooleanInput(Inputs.IncludeHiddenFiles) | ||||||
| 
 | 
 | ||||||
|   if (!noFileBehavior) { |   if (!noFileBehavior) { | ||||||
|     core.setFailed( |     core.setFailed( | ||||||
| @ -25,7 +26,8 @@ export function getInputs(): UploadInputs { | |||||||
|   const inputs = { |   const inputs = { | ||||||
|     artifactName: name, |     artifactName: name, | ||||||
|     searchPath: path, |     searchPath: path, | ||||||
|     ifNoFilesFound: noFileBehavior |     ifNoFilesFound: noFileBehavior, | ||||||
|  |     includeHiddenFiles | ||||||
|   } as UploadInputs |   } as UploadInputs | ||||||
| 
 | 
 | ||||||
|   const retentionDaysStr = core.getInput(Inputs.RetentionDays) |   const retentionDaysStr = core.getInput(Inputs.RetentionDays) | ||||||
|  | |||||||
| @ -11,11 +11,12 @@ export interface SearchResult { | |||||||
|   rootDirectory: string |   rootDirectory: string | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| function getDefaultGlobOptions(): glob.GlobOptions { | function getDefaultGlobOptions(includeHiddenFiles: boolean): glob.GlobOptions { | ||||||
|   return { |   return { | ||||||
|     followSymbolicLinks: true, |     followSymbolicLinks: true, | ||||||
|     implicitDescendants: true, |     implicitDescendants: true, | ||||||
|     omitBrokenSymbolicLinks: true |     omitBrokenSymbolicLinks: true, | ||||||
|  |     excludeHiddenFiles: !includeHiddenFiles | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -80,12 +81,12 @@ function getMultiPathLCA(searchPaths: string[]): string { | |||||||
| 
 | 
 | ||||||
| export async function findFilesToUpload( | export async function findFilesToUpload( | ||||||
|   searchPath: string, |   searchPath: string, | ||||||
|   globOptions?: glob.GlobOptions |   includeHiddenFiles?: boolean | ||||||
| ): Promise<SearchResult> { | ): Promise<SearchResult> { | ||||||
|   const searchResults: string[] = [] |   const searchResults: string[] = [] | ||||||
|   const globber = await glob.create( |   const globber = await glob.create( | ||||||
|     searchPath, |     searchPath, | ||||||
|     globOptions || getDefaultGlobOptions() |     getDefaultGlobOptions(includeHiddenFiles || false) | ||||||
|   ) |   ) | ||||||
|   const rawSearchResults: string[] = await globber.glob() |   const rawSearchResults: string[] = await globber.glob() | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -20,4 +20,9 @@ export interface UploadInputs { | |||||||
|    * Duration after which artifact will expire in days |    * Duration after which artifact will expire in days | ||||||
|    */ |    */ | ||||||
|   retentionDays: number |   retentionDays: number | ||||||
|  | 
 | ||||||
|  |   /** | ||||||
|  |    * Whether or not to include hidden files in the artifact | ||||||
|  |    */ | ||||||
|  |   includeHiddenFiles: boolean | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Ryan Troost
						Ryan Troost