-
Notifications
You must be signed in to change notification settings - Fork 6
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Allow relative paths in scoped packages #12
Conversation
The resolver module implements a path resolving algorithm that leverages node's own require. This has a couple benefits: * more likely to continue working as expected when features are introduced to npm/node * reduction of code duplication (npm/node already implements the module resolution we are interested in for this project) * allow the use of NODE_PATH variable to control module directory Additionally, `resolver` leverages `Package` and `Import` constructors which implement some of the same logic previously found on the `find` function in `lib/importer.js`. The benefit of creating these constructors will obvious when unit tests are introduced for this project. `Package`: implements logic related to retrieving package data, such as getting the package.json, and getting the sass 'main' file for a given package. `Import`: implements logic to make sense of a sass import.
This allows the tests to work consistently
2e928e4
to
1c4ce24
Compare
e9e7f34
to
17e3c65
Compare
Also improved style in tests
862267c
to
3dace1a
Compare
Actually, may need to reconsider this change of implementation after considering issues with dependencies of dependencies... |
I have some thoughts in mind for a solution for the problem stated above. Will add tests for nested dependencies in the process since those are missing. |
@@ -5,7 +5,8 @@ | |||
"main": "index.js", | |||
"bin": "./bin/npm-sass", | |||
"scripts": { | |||
"test": "mocha test/index.js" | |||
"test": "NODE_PATH=$NODE_PATH:\"$(git rev-parse --show-toplevel)/test/fixtures/node_modules\" mocha test/index.js", | |||
"unit-test": "mocha test/units/*.js" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Would you mind refactoring this a little to rename what is now the test
task, and then have test
run both of the existing test tasks?
That way we can get better coverage in CI.
Thank you so much for your work on this, it's really appreciated. I'm not actually using this module in any of my own projects at the moment (it was written to solve some problems at a former workplace), so it might take a while for me to establish whether it's working as intended. Do you need a fix for the issue quickly? I'm happy to publish a pre-release version so you can use it straight away. Meanwhile I'll try to review as best I can. My first quick review is very positive. I like the changes you've made to the general readability of the code. It's certainly a lot easier to follow than my efforts. Will try to look more in depth soon. |
Hey @lennym Thanks for the response. I'm not in a rush to get this code. Currently, this is something I'm experimenting with, with the hopes that I can pitch it to my organization as a standard tool. We are currently undergoing a re-architecture of the way we manage front-end assets and so far, the idea of using npm-sass seems really appealing, though I'm not 100% sure as of right now whether we will be using it at a large scale soon. Don't feel rushed to publish any of it. I will fix the issue I stated above and work on a couple of experiments that do not require this PR to be merged. If the experiments work out and my team members buy into the idea of using npm-sass regularly, I'd gladly take this project off your hands, especially if you feel burdened by maintaining something you do not use currently. Even if it for a temporary period. How would you feel about that? |
Because string expansion is not compatible with all shells
525dbba
to
0375885
Compare
This helps some of the async code easier to read
@lennym I believe I am done making code changes to this branch. I updated the test scripts per your advice. Please let me know if there is anything else you would like for me to address. The major changes since you last saw this PR are:
There are some items that would make sense to address eventually but not as part of this PR.
|
@lennym I just hit this as well - going to test my issue with @GeorgeTaveras1231 's fork and see if it works. As a side note, @GeorgeTaveras1231, great work - my first time looking at this in a while and it's really clear coding. Love it. |
@GeorgeTaveras1231 @lennym This does appear to work, but I was expecting the relative import to be relative to the // assuming "style": "dist/scss/library.scss"
// relative to the "style" file
@import '@scope/library/variables/colors';
// relative to the package directory
@import '@scope/library/dist/scss/variables/colors'; My preference would be the former, but it's not a terrible change. That said, I would definitely request documentation for this. |
Thanks so much for your ongoing work on this @GeorgeTaveras1231 and @tshelburne. In reference to the options provided above by @tshelburne, I'd actually have a very strong preference for the second one as it works in the same way as I should have some time next week to set aside to reviewing this properly, with a view to merging and releasing. |
"test": "mocha test/index.js" | ||
"test": "mocha $npm_package_config_unit_test_files $npm_package_config_integration_test_files", | ||
"unit-test": "mocha $npm_package_config_unit_test_files", | ||
"integration-test": "mocha $npm_package_config_integration_test_files" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
TIL. Thanks @GeorgeTaveras1231!
Thank you so much for your work on this @GeorgeTaveras1231, I really appreciate it. I will take some time to address some of your further points above today. |
I've published your changes with a major version bump to v2.0.0 Thanks again for contributing. |
Currently, a path such as
"@lennym/npm-sass-test-sass/child-file"
errors out. This makes it work(referring to the first commit in this PR), but I have concerns about the growing complexity of thefind
function.I'm thinking about abstracting some of the package details such as
isScoped
,name
, and
entrypointLocation
(currently known as thelocation
var) into aPackage
constructor in order to test each of these details in isolation while also simplifying the implementation offind
.What do you think @lennym?
As I mentioned above, I gave a shot at refactoring the code to make it easier to test. I've yet to write unit tests for the logic but while digging into the code I found that a custom file resolution algorithm was being used. After some research, I found that node's own
require
function could be used to implement this. I like this because this is likely to stay compatible with node/npm future implementations. I tried to describe the changes in this PR 230e069Finally, I wrote unit tests for all of the new code. It is all runnable via
npm run unit-test
.I'm very glad to see that this tool exists, which makes me happy to contribute to it 😄 . @lennym let me know what you think, looking forward to hearing back.