-
Notifications
You must be signed in to change notification settings - Fork 89
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
Should every IoT Agent align to use eslint #830
Comments
I'd like to swap out JSHint for EsLint on the long runner: #753 as well [sigh] since it should make the maintenance of the ongoing merge conflicts easier. If this proposal is accepted I may combine prettier and eslint into a single PR (and remove all jshint work arounds. |
Thank you very much for creating the issue and the explanations above. We are still discussing the issue internally and I hope we can provide feedback on it soon. Sorry for the delay. On the meanwhile, looking to the proposed PRs, I have a couple of doubts, pls:
|
To quote Wikipedia: eslint is a static code analysis tool for identifying problematic patterns found in JavaScript code. Rules in ESLint are configurable, and customized rules can be defined and loaded Tâmia provides a set of such rules
This is very similar to the commonly used airbnb code rules, with one important addition/omission/change. - Tâmia does not provide any code style rules, hence it is very easy to complement this base set of linter rules with another for code styling. As you know, I've been pushing Prettier - and they also supply a eslint config eslint-plugin-prettier - using this enforces the prettier formatting, and removes the need for any overrides where jshint formatting rules were conflicting with prettier. The |
Please find some feedback:
|
I have created my own branch of #800 - expression-lib-alternative and merged my eslint branch into it:
Total time to fix - 8 minutes - I don't think this is much of a blocker. Replacing jshint with eslint is a simple mechanical process which could be easily added into IOTA Manager - the only problem is waiting and merging in other PRs whilst still at the back of the queue takes time. If I could see movement elsewhere I could easily apply the same process to another repo. I fully agree removing callbacks and using promises is an aspiration and not intended to be part of this PR and should be separated from this discussion. |
This is the state of the lull across the IoT Agents
Which of these PRs are still active? |
As far as I remember we use plain spaces to indent in our code, not tabs. Can configuration be adjusted to align with our current indentation style? In fact, maybe already works that way... I see in the proposed PRs configuration like:
What does exactly mean? (I have tried to find indent_style and indent_size in the link you provide https://eslint.org/docs/user-guide/configuring but I didn't find them...) |
My mistake - that should be the editorconfig - an attempt to maintain consistent coding styles across various IDEs. The JavaScript
|
Given that #800 has now been merged, I thought it would be an opportune moment to ask whether these PRs could be processed. I have updated the PRs again to ensure no conflicts. This is the state of the lull across the IoT Agents
For these repos I see no conflicting commits in the last 6 months and no progress on the outstanding PRs - are they active? How is the queue being dealt with?
These two are more problematic, and I can see you will want to process #849 before accepting #831. Question should #753 be withdrawn? The eslint PR supersedes it. On the UL IoT Agent all the outstanding PRs telefonicaid/iotagent-ul#411 and telefonicaid/iotagent-ul#412 appear to be waiting for some equivalent works - is this scheduled? The other two are approved or equivalents to approved work elsewhere - telefonicaid/iotagent-ul#429 telefonicaid/iotagent-ul#430 Basically just asking if it is worth continuing maintaining these PRs. |
I'm still thinking the work is valuable. Let's start the merge by the "simplest" repositories which I think are Sigfox and L2M2M. The PR in LWM2M has been just merged. The PR in Sigfox has been commented with a couple of things I have spotted in a last review on it. |
Current status: eslint PRs on IOTA-Sigfox, IOTA-LWM2M and IOTAManager (and STH, as bonus track ;) has been already merged. Next ones are IOTA-UL and IOTA-JSON. There is an outstanding ongoing work on leading slashes mqtt topics authored by @jmezzera. The piece of work corresponding to IOTA-JSON is pending, but given that the "parallel" work in IOTA-UL is finished (PR telefonicaid/iotagent-ul#429) I understand it would be provided soon. @jmezzera could you provide some update on this, please? Thanks! |
I was just working on this aspect this morning, planning to have it done by the end of the day. |
@jmezzera work on MQTT improvements has been just merged in IOTA-UL and IOTA-JSON (thanks!). Thus, I think once the eslint PRs on these repos gets updates with master and conflict solved, they would be ready for final review and merge. |
Conflicts have been resolved. PRs have been updated.
|
As far as I understand, all the PRs related with eslint have been already merged in every repository so we are almost done :) However, there is still one pending, in this repository itself, for the iotagent-node-lib: PR #831. The summary of "parallel" PRs that may conflict are the following ones:
Notes:
|
#831 is a blind mechanical change - it will ES6-ify the existing Much easier to merge the In contrast none of the other PRs are large enough to cause too many problems ( 9, 3, 1 and 10 files respectively) |
Thanks for the feedback! I have edited the table above accordingly. |
I have fixed the merge conflicts for the NGSI-LD PR: This makes the merge of ngsi-ld + eslint a simple matter of accept mine as an experiment have created a new branch for this see here: https://github.com/jason-fox/iotagent-node-lib/tree/feature/eslint_and_ngsi-ld I would still prefer that the NGSI-LD is actioned first as I don't want to be maintaining three branches ( |
PR #831 finally merged. After merging, let's see tonight if the newly generated IOTAs containers with the new version of the library work in the CI e2s tests. If no problem is found (we don't expect any), the issue will be closed. |
CI e2e went fine last night. So I think nothing is pending and this issue can be closed. |
LoRaWAN and OPC-UA already use ES6 and are linted using ESLint. The telefonica IoT Agents code base is older and continues to use jshint
I see several advantages of swapping out the older linter and replacing it with the ES6 compliant one:
const
andlet
is supposedly more performant - well they would say that wouldn't theyThe existing minimum node engine is Node 8. Node 8 is reaching EoF and is already compliant with
const
andlet
anyway . I can't see why there would there be any problem is upgrading the IoT Agents to use the newer syntax? It's just a start - ideally someone can delete the existing async library callbacks and replace them with proper native ES2015+ Promises and useasync await
- it would make the code a lot easier to follow. I'm not sure if the iot-node-lib eventually needs to offer promise endpoints itself or just useutils.promisify()
but that is an issue for another day. This would just be a start.As a broad mechanical automated change, it would make sense to try push this through whilst there is a lull to avoid merge conflicts with other ongoing PRs.
The text was updated successfully, but these errors were encountered: