Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Make yarn-run-dev not move queries.json to build folder #162

Open
wants to merge 14 commits into
base: master
Choose a base branch
from

Conversation

simonvbrae
Copy link

@simonvbrae simonvbrae commented Sep 19, 2024

This is a draft PR, I am still making changes.

Calling yarn run dev would result in the queries.json file being moved to build/ after generation resulting in missing data sources and queries in the development server.
This PR changes lets that move happen outside of webpack so it doesn't happen when running yarn run dev, only when running yarn run build.

package.json Outdated
@@ -51,7 +51,7 @@
],
"scripts": {
"lint": "eslint src/*.js",
"dev-prod": "comunica-compile-config config/config-default.json > .tmp-comunica-engine.js && ./bin/queries-to-json.js && webpack serve --config webpack.config.js --mode production",
"dev-prod": "comunica-compile-config config/config-default.json > .tmp-comunica-engine.js && ./bin/queries-to-json.js && webpack serve --config webpack.config.dev.js --mode production",
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are you sure this is correct. AFAICS, webpack.config.dev.js does not exist?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Forgot to commit my change, fixed now!

Copy link
Member

@rubensworks rubensworks left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks @simonvbrae, looks good!

Can you confirm build and serving works correctly in these cases? (because the CI currently only checks one of these)

  • yarn run dev (yarn run dev-prod should be the same)
  • yarn run build
  • node bin/generate.js

If yes, I'll merge this right away!

rubensworks added a commit that referenced this pull request Oct 15, 2024
This reverts commit 165f3fb.

Reverted because the package deployed to npm was broken because of this.
A proper fix will land in #162.
@simonvbrae
Copy link
Author

Thanks @simonvbrae, looks good!

Can you confirm build and serving works correctly in these cases? (because the CI currently only checks one of these)

  • yarn run dev (yarn run dev-prod should be the same)
  • yarn run build
  • node bin/generate.js

If yes, I'll merge this right away!

I have tested all of the options, it's ready for merge!

@@ -41,7 +41,7 @@ module.exports = [
path.join(__dirname, './images/sparql.png'),
path.join(__dirname, './favicon.ico'),
path.join(__dirname, './solid-client-id.jsonld'),
path.join(process.cwd(), './queries.json'),
path.join(__dirname, './queries.json'),
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure this is correct, as this may break overriding queries.json when using bin/generate.js.
Can you double-check this? (as we don't have unit tests for this)

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It seems to still work; using the option -q results in custom queries being made available.

image

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should I add a unit test for this? And would it be a good start to check if the custom query correctly ends up in queries.json in the build folder?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A test would be great indeed! But let's keep this for a separate PR. I'll merge this one already. Thanks for checking!

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm sorry for raising this point again, but the lacking unit test is making me a bit paranoid right now 😅
Could you try invoking bin/generate.js with a custom queries config from a completely different directory to check everything works correctly?

Because the usage of __dirname here would cause the queries.json file to be loaded from the repo directory, and not from a different directory.
But I could be missing something.

Copy link
Author

@simonvbrae simonvbrae Dec 6, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Better safe than sorry!

Calling ./bin/generate -q /home/custom_queries worked correctly.
The reason it works is that queries.json seems to be generated in the directory denoted by __dirname and copied from there to build/.

I thought, what if queries.json gets generated in cwd(), which could be incompatible with using __dirname in some cases. I tested this in two ways:
I ran bin/generate -q /home/custom_queries outside of the repo, this failed because it could not resolve babel-loader, I assume this is normal behaviour?
I also ran .bin/generate from a subdirectory of the repo. This worked correctly.

Do these tests cover everything?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I ran bin/generate -q /home/custom_queries outside of the repo, this failed because it could not resolve babel-loader, I assume this is normal behaviour?

That should also work, but probably doesn't in this case because it can't find the node_modules.
Can you try globally installing this package (your dev version), and running the bin like that? (yarn link should also be able to do that (at least yarn classic, not sure about the newer ones))
You should then be able to run comunica-web-client-generator from anywhere.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This also seemed to work: comunica-web-client-generator -q /home/custom_queries works in any directory and I used a print to make sure it's using my local version correctly.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I just re-read your previous comment.
The fact that queries.json is generated in __dirname is a bit strange.
This means that even when running the command elsewhere, queries.json will get generated within the directory of the source code.
I would the source code to remain immutable, and only the cwd to get modified.
Do you think it's feasible to restore the old behaviour of this file getting generated in process.cwd()? This would also simplify debugging on this file.

Copy link
Author

@simonvbrae simonvbrae Dec 13, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have restored it and tested, everything seems to work correctly, including custom queries folder via -q.

@rubensworks
Copy link
Member

@simonvbrae It looks like the CI doesn't pass. Can you check why?

@simonvbrae
Copy link
Author

simonvbrae commented Nov 22, 2024

@simonvbrae It looks like the CI doesn't pass. Can you check why?

The error is
Error: ENOENT: no such file or directory, rename '/home/runner/work/jQuery-Widget.js/jQuery-Widget.js/queries.json' -> '/home/runner/work/jQuery-Widget.js/jQuery-Widget.js/build/queries.json'

This could be caused by this line we discussed above, the failing CI runs may be expecting queries.json to be present in CWD.
I've changed it back, which should fix the CI.

@rubensworks
Copy link
Member

Still seems to be failing after your change :/

@simonvbrae
Copy link
Author

The issue seems to be caused by an absent build folder, my current commit creates the folder, which fixes the CI.

But the absent build folder raises a few questions:

  • Where is the build output if the build folder doesn't exist?
    This is especially strange considering that all the webpack entries have this exact build folder (that doesn't exist) as their output path.
  • So why is the call to webpack() successful when all of it's entries have an output.path that doesn't exist?

I didn't find anything in the documentation suggesting that webpack creates this directory and, in practise, it doesn't seem to create it because the error of build folder not existing happens after the call to webpack().

I'm not sure as to whether everything is correct within the CI but I am committing what makes the CI pass for now.

@rubensworks
Copy link
Member

@simonvbrae Is this one ready for review?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants