From 7ca63b189b5b00b12653c9ca423825d6c3f0d056 Mon Sep 17 00:00:00 2001 From: Phillip Webb Date: Wed, 20 Mar 2024 23:17:38 -0700 Subject: [PATCH] Fix Windows related issues Fixes gh-2 --- .../lib/index.js | 27 +++++---- .../zip-contents-collector-extension-test.js | 59 ++++++++++--------- 2 files changed, 47 insertions(+), 39 deletions(-) diff --git a/packages/antora-zip-contents-collector-extension/lib/index.js b/packages/antora-zip-contents-collector-extension/lib/index.js index 3624bb6..9c2a535 100644 --- a/packages/antora-zip-contents-collector-extension/lib/index.js +++ b/packages/antora-zip-contents-collector-extension/lib/index.js @@ -98,7 +98,7 @@ function register ({ config, downloadLog }) { async function uiLoaded ({ uiCatalog }) { const layouts = uiCatalog.findByType('layout') - if (layouts.filter((file) => file.path === 'layouts/bare.hbs').length === 0) { + if (layouts.filter((file) => posixify(file.path) === 'layouts/bare.hbs').length === 0) { logger.trace("Adding 'bare' layout to UI catalog") const file = new Vinyl({ path: 'layouts/bare.hbs', @@ -363,8 +363,8 @@ function register ({ config, downloadLog }) { destination = include.path && (destination ? ospath.join(destination, include.path) : include.path) file = asAntoraFile(include, zipFile, file, destination) logger.trace(`Adding ${file.path} to content aggregate`) - const existing = componentVersionBucket.files.find(({ path: candidate }) => candidate === file.path) - if (file.path === 'antora.yml' || file.path === 'modules/antora.yml') { + const existing = componentVersionBucket.files.find((candidate) => candidate.src.path === file.src.path) + if (file.src.path === 'antora.yml' || file.src.path === 'modules/antora.yml') { const generated = yaml.load(file.contents) Object.assign(componentVersionBucket, generated) if (!('prerelease' in generated)) delete componentVersionBucket.prerelease @@ -383,7 +383,6 @@ function register ({ config, downloadLog }) { module: moduleName, family: 'page', }) - file.src.relative = file.relative const pageAttributes = { 'page-layout': 'bare', 'page-component-name': component.name, @@ -392,7 +391,7 @@ function register ({ config, downloadLog }) { 'page-component-display-version': version.displayVersion, 'page-component-title': component.title, 'page-module': moduleName, - 'page-relative': file.src.relative, + 'page-relative': file.src.path, 'page-origin-type': file.src.origin.type, 'page-origin-url': file.src.origin.url, } @@ -407,11 +406,19 @@ function register ({ config, downloadLog }) { const extname = ospath.extname(path) const stem = basename.slice(0, basename.length - extname.length) const mediaType = mimeTypes.lookup(extname) || fallbackMediaType - const result = Object.assign(file.clone(), { - src: { origin: include.origin, path, basename, stem, extname, abspath: path, mediaType, zipFile, ...src }, - }) - result.path = path - return result + src = { + origin: include.origin, + path, + basename, + stem, + extname, + abspath: path, + relative: path, + mediaType, + zipFile, + ...src, + } + return { path, contents: file.contents, stat: file.stat, src } } async function cleanupCollectorCacheDir (collectorCacheDir) { diff --git a/packages/antora-zip-contents-collector-extension/test/zip-contents-collector-extension-test.js b/packages/antora-zip-contents-collector-extension/test/zip-contents-collector-extension-test.js index 2d45086..e1cf652 100644 --- a/packages/antora-zip-contents-collector-extension/test/zip-contents-collector-extension-test.js +++ b/packages/antora-zip-contents-collector-extension/test/zip-contents-collector-extension-test.js @@ -25,6 +25,8 @@ const os = require('os') const ospath = require('path') const Vinyl = require('vinyl') +const posixify = ospath.sep === '\\' ? (p) => p.replace(/\\/g, '/') : (p) => p + const FIXTURES_DIR = ospath.join(__dirname, 'fixtures') const FIXTURES_REPOS_DIR = ospath.join(FIXTURES_DIR, 'repos') const FIXTURES_ZIPS_DIR = ospath.join(FIXTURES_DIR, 'zips') @@ -94,7 +96,7 @@ describe('zip contents collector extension', () => { }, after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(1) - expect(contentAggregate[0].files[0].path).to.equal('modules/ROOT/pages/index.adoc') + expect(contentAggregate[0].files[0].src.path).to.equal('modules/ROOT/pages/index.adoc') }, }) }) @@ -116,7 +118,7 @@ describe('zip contents collector extension', () => { }, after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(1) - expect(contentAggregate[0].files[0].path).to.equal('modules/ROOT/pages/index.adoc') + expect(contentAggregate[0].files[0].src.path).to.equal('modules/ROOT/pages/index.adoc') }, }) }) @@ -142,7 +144,7 @@ describe('zip contents collector extension', () => { }, after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(1) - expect(contentAggregate[0].files[0].path).to.equal('modules/ROOT/pages/index.adoc') + expect(contentAggregate[0].files[0].src.path).to.equal('modules/ROOT/pages/index.adoc') }, }) }) @@ -165,8 +167,8 @@ describe('zip contents collector extension', () => { httpPath: '/', after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(2) - expect(contentAggregate[0].files[0].path).to.equal('modules/ROOT/pages/c1.adoc') - expect(contentAggregate[0].files[1].path).to.equal('modules/ROOT/pages/c2.adoc') + expect(contentAggregate[0].files[0].src.path).to.equal('modules/ROOT/pages/c1.adoc') + expect(contentAggregate[0].files[1].src.path).to.equal('modules/ROOT/pages/c2.adoc') }, }) }) @@ -188,7 +190,7 @@ describe('zip contents collector extension', () => { }, after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(1) - expect(contentAggregate[0].files[0].path).to.equal('modules/ROOT/pages/index.adoc') + expect(contentAggregate[0].files[0].src.path).to.equal('modules/ROOT/pages/index.adoc') }, }) }) @@ -264,7 +266,7 @@ describe('zip contents collector extension', () => { httpPath: '/v1.2.3', after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(2) - const page = contentAggregate[0].files.find((it) => it.relative === 'modules/ROOT/pages/index.adoc') + const page = contentAggregate[0].files.find((it) => it.src.path === 'modules/ROOT/pages/index.adoc') expect(page).to.be.exist() }, }) @@ -284,7 +286,7 @@ describe('zip contents collector extension', () => { httpPath: '/v1.2.3', after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(2) - const page = contentAggregate[0].files.find((it) => it.relative === 'modules/ROOT/pages/index.adoc') + const page = contentAggregate[0].files.find((it) => it.src.path === 'modules/ROOT/pages/index.adoc') expect(page).to.be.exist() }, }) @@ -304,7 +306,7 @@ describe('zip contents collector extension', () => { httpPath: '/v1.2.3', after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(2) - const page = contentAggregate[0].files.find((it) => it.relative === 'modules/ROOT/pages/index.adoc') + const page = contentAggregate[0].files.find((it) => it.src.path === 'modules/ROOT/pages/index.adoc') expect(page).to.be.exist() }, }) @@ -325,7 +327,7 @@ describe('zip contents collector extension', () => { httpPath: '/v1.2.3', after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(2) - const page = contentAggregate[0].files.find((it) => it.relative === 'modules/ROOT/pages/index.adoc') + const page = contentAggregate[0].files.find((it) => it.src.path === 'modules/ROOT/pages/index.adoc') expect(page).to.be.exist() }, }) @@ -356,7 +358,7 @@ describe('zip contents collector extension', () => { downloadLog, after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(2) - const page = contentAggregate[0].files.find((it) => it.relative === 'modules/ROOT/pages/index.adoc') + const page = contentAggregate[0].files.find((it) => it.src.path === 'modules/ROOT/pages/index.adoc') expect(page).to.be.exist() expect(downloadLog.length).to.equal(1) expect(downloadLog[0].url).to.equal(`http://localhost:${httpServerPort}/release/v1.2.3/start-page.zip`) @@ -386,6 +388,7 @@ describe('zip contents collector extension', () => { expect(files[0]).to.have.property('stat') expect(files[0].src).to.eql({ path: 'modules/ROOT/pages/index.adoc', + relative: 'modules/ROOT/pages/index.adoc', abspath: 'modules/ROOT/pages/index.adoc', basename: 'index.adoc', stem: 'index', @@ -418,7 +421,7 @@ describe('zip contents collector extension', () => { }, after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(1) - expect(contentAggregate[0].files[0].path).to.equal('modules/ROOT/pages/index.adoc') + expect(contentAggregate[0].files[0].src.path).to.equal('modules/ROOT/pages/index.adoc') }, }) }) @@ -447,7 +450,7 @@ describe('zip contents collector extension', () => { }, after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(1) - expect(contentAggregate[0].files[0].path).to.equal('modules/ROOT/pages/index.adoc') + expect(contentAggregate[0].files[0].src.path).to.equal('modules/ROOT/pages/index.adoc') }, }) }) @@ -552,7 +555,7 @@ describe('zip contents collector extension', () => { times: 2, after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(1) - expect(contentAggregate[0].files[0].path).to.equal('modules/ROOT/pages/index.adoc') + expect(contentAggregate[0].files[0].src.path).to.equal('modules/ROOT/pages/index.adoc') expect(downloadLog.length).to.equal(2) expect(downloadLog[0].statusCode).to.equal(200) expect(downloadLog[1].statusCode).to.equal(304) @@ -579,7 +582,7 @@ describe('zip contents collector extension', () => { times: 2, after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(1) - expect(contentAggregate[0].files[0].path).to.equal('modules/ROOT/pages/index.adoc') + expect(contentAggregate[0].files[0].src.path).to.equal('modules/ROOT/pages/index.adoc') expect(downloadLog.length).to.equal(4) expect(downloadLog[0].statusCode).to.equal(404) expect(downloadLog[1].statusCode).to.equal(200) @@ -610,7 +613,7 @@ describe('zip contents collector extension', () => { }, after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(1) - expect(contentAggregate[0].files[0].path).to.equal('modules/ROOT/pages/index.adoc') + expect(contentAggregate[0].files[0].src.path).to.equal('modules/ROOT/pages/index.adoc') }, }) }) @@ -632,7 +635,7 @@ describe('zip contents collector extension', () => { }, after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(1) - expect(contentAggregate[0].files[0].path).to.equal('modules/ROOT/pages/index.adoc') + expect(contentAggregate[0].files[0].src.path).to.equal('modules/ROOT/pages/index.adoc') }, }) }) @@ -662,7 +665,7 @@ describe('zip contents collector extension', () => { This is the real deal. ` - expect(contentAggregate[0].files[0].contents.toString()).to.equal(expectedContents + '\n') + expect(contentAggregate[0].files[0].contents.toString().replace(/\r/g, '')).to.equal(expectedContents + '\n') expect(contentAggregate[0].files[0].stat).to.not.equal(originalStat) expect(contentAggregate[0].files[0].stat.size).to.not.equal(originalStat.size) expect(contentAggregate[0].files[0].src).to.not.have.property('scanned') @@ -690,13 +693,12 @@ describe('zip contents collector extension', () => { expect(contentAggregate[0].files).to.have.lengthOf(0) const files = contentCatalog.getFiles() const src = files[0].src - expect(files.filter((file) => file.path === 'api/java/README')).to.have.lengthOf(1) - expect(files.filter((file) => file.path === 'api/java/javadoc.css')).to.have.lengthOf(1) - expect(files.filter((file) => file.path === 'api/java/javadoc.html')).to.have.lengthOf(1) + expect(files.filter((file) => file.src.path === 'api/java/README')).to.have.lengthOf(1) + expect(files.filter((file) => file.src.path === 'api/java/javadoc.css')).to.have.lengthOf(1) + expect(files.filter((file) => file.src.path === 'api/java/javadoc.html')).to.have.lengthOf(1) expect(src.module).to.be.equal('ROOT') expect(src.family).to.be.equal('page') expect(src.component).to.be.equal('test') - expect(src.relative).to.be.equal('api/java/README') }, }) }) @@ -719,13 +721,12 @@ describe('zip contents collector extension', () => { expect(contentAggregate[0].files).to.have.lengthOf(0) const files = contentCatalog.getFiles() const src = files[0].src - expect(files.filter((file) => file.path === 'api/java/README')).to.have.lengthOf(1) - expect(files.filter((file) => file.path === 'api/java/javadoc.css')).to.have.lengthOf(1) - expect(files.filter((file) => file.path === 'api/java/javadoc.html')).to.have.lengthOf(1) + expect(files.filter((file) => file.src.path === 'api/java/README')).to.have.lengthOf(1) + expect(files.filter((file) => file.src.path === 'api/java/javadoc.css')).to.have.lengthOf(1) + expect(files.filter((file) => file.src.path === 'api/java/javadoc.html')).to.have.lengthOf(1) expect(src.module).to.be.equal('mymodule') expect(src.family).to.be.equal('page') expect(src.component).to.be.equal('test') - expect(src.relative).to.be.equal('api/java/README') }, }) }) @@ -794,7 +795,7 @@ describe('zip contents collector extension', () => { after: ({ uiCatalog }) => { const layouts = uiCatalog.findByType('layout') expect(layouts).to.have.lengthOf(1) - expect(layouts[0].path).to.be.equal('layouts/bare.hbs') + expect(posixify(layouts[0].path)).to.be.equal('layouts/bare.hbs') }, }) }) @@ -821,7 +822,7 @@ describe('zip contents collector extension', () => { after: ({ uiCatalog }) => { const layouts = uiCatalog.findByType('layout') expect(layouts).to.have.lengthOf(1) - expect(layouts[0].path).to.be.equal('layouts/bare.hbs') + expect(posixify(layouts[0].path)).to.be.equal('layouts/bare.hbs') expect(layouts[0].contents.toString()).to.be.equal('test') }, }) @@ -845,7 +846,7 @@ describe('zip contents collector extension', () => { }, after: ({ contentAggregate }) => { expect(contentAggregate[0].files).to.have.lengthOf(1) - expect(contentAggregate[0].files[0].path).to.equal('modules/ROOT/pages/index.adoc') + expect(contentAggregate[0].files[0].src.path).to.equal('modules/ROOT/pages/index.adoc') }, }) })