Skip to content

Commit

Permalink
fix: validate publish dir in buildbot (#71)
Browse files Browse the repository at this point in the history
* fix: validate publish dir in buildbot

* refactor: use IS_LOCAL
  • Loading branch information
Skn0tt committed Nov 9, 2023
1 parent 3b58f20 commit df8f8cf
Show file tree
Hide file tree
Showing 3 changed files with 47 additions and 11 deletions.
25 changes: 25 additions & 0 deletions src/helpers/fixOutputDir.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
const { join } = require('path')

const getAngularJson = require('./getAngularJson')
const { getProject } = require('./setUpEdgeFunction')

const fixOutputDir = async function ({ failBuild, siteRoot, PUBLISH_DIR, IS_LOCAL, netlifyConfig }) {
const angularJson = getAngularJson({ failBuild, siteRoot })
const project = getProject(angularJson)

const { outputPath } = project.architect.build.options

const correctPublishDir = join(outputPath, 'browser')
if (correctPublishDir === PUBLISH_DIR) {
return
}

if (IS_LOCAL) {
console.warn(`Publish directory is configured incorrectly. Updating to "${correctPublishDir}".`)
netlifyConfig.build.publish = correctPublishDir
} else {
failBuild(`Publish directory is configured incorrectly. Please set it to "${correctPublishDir}".`)
}
}

module.exports = fixOutputDir
17 changes: 11 additions & 6 deletions src/helpers/setUpEdgeFunction.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,15 @@ const getAllFilesIn = (dir) =>

const toPosix = (path) => path.split(sep).join(posix.sep)

const setUpEdgeFunction = async ({ angularJson, projectName, netlifyConfig, constants, failBuild }) => {
const project = angularJson.projects[projectName]
const getProject = (angularJson) => {
const projectName = angularJson.defaultProject ?? Object.keys(angularJson.projects)[0]
return angularJson.projects[projectName]
}

module.exports.getProject = getProject

const setUpEdgeFunction = async ({ angularJson, constants, failBuild }) => {
const project = getProject(angularJson)
const {
architect: { build },
} = project
Expand All @@ -30,15 +37,13 @@ const setUpEdgeFunction = async ({ angularJson, projectName, netlifyConfig, cons
return failBuild('Could not find build output directory')
}

netlifyConfig.build.publish = join(outputDir, 'browser')

const serverDistRoot = join(outputDir, 'server')
if (!existsSync(serverDistRoot)) {
console.log('No server output generated, skipping SSR setup.')
return
}

console.log(`Writing Angular SSR Edge Function for project "${projectName}" ...`)
console.log(`Writing Angular SSR Edge Function ...`)

const edgeFunctionDir = join(constants.INTERNAL_EDGE_FUNCTIONS_SRC, 'angular-ssr')
await mkdir(edgeFunctionDir, { recursive: true })
Expand Down Expand Up @@ -101,4 +106,4 @@ const setUpEdgeFunction = async ({ angularJson, projectName, netlifyConfig, cons
await writeFile(join(edgeFunctionDir, 'angular-ssr.mjs'), ssrFunction)
}

module.exports = setUpEdgeFunction
module.exports.setUpEdgeFunction = setUpEdgeFunction
16 changes: 11 additions & 5 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,10 @@ const { rm } = require('fs/promises')
const { join } = require('path')

const ensureNoCompetingPlugin = require('./helpers/ensureNoCompetingPlugin')
const fixOutputDir = require('./helpers/fixOutputDir')
const getAngularJson = require('./helpers/getAngularJson')
const getAngularRoot = require('./helpers/getAngularRoot')
const setUpEdgeFunction = require('./helpers/setUpEdgeFunction')
const { setUpEdgeFunction } = require('./helpers/setUpEdgeFunction')
const validateAngularVersion = require('./helpers/validateAngularVersion')

let isValidAngularProject = true
Expand All @@ -17,7 +18,7 @@ module.exports = {
const edgeFunctionDir = join(constants.INTERNAL_EDGE_FUNCTIONS_SRC, 'angular-ssr')
await rm(edgeFunctionDir, { recursive: true })
},
async onPreBuild({ netlifyConfig, utils }) {
async onPreBuild({ netlifyConfig, utils, constants }) {
const siteRoot = getAngularRoot({ netlifyConfig })
isValidAngularProject = await validateAngularVersion(siteRoot)
if (!isValidAngularProject) {
Expand All @@ -28,6 +29,14 @@ module.exports = {
ensureNoCompetingPlugin(siteRoot, utils.build.failBuild)

netlifyConfig.build.command ??= 'npm run build'

await fixOutputDir({
siteRoot,
failBuild: utils.build.failBuild,
PUBLISH_DIR: constants.PUBLISH_DIR,
IS_LOCAL: constants.IS_LOCAL,
netlifyConfig,
})
},
async onBuild({ utils, netlifyConfig, constants }) {
if (!isValidAngularProject) {
Expand All @@ -39,11 +48,8 @@ module.exports = {
const siteRoot = getAngularRoot({ netlifyConfig })
const angularJson = getAngularJson({ failBuild, siteRoot })

const projectName = angularJson.defaultProject ?? Object.keys(angularJson.projects)[0]

await setUpEdgeFunction({
angularJson,
projectName,
constants,
netlifyConfig,
failBuild,
Expand Down

0 comments on commit df8f8cf

Please sign in to comment.