-
Notifications
You must be signed in to change notification settings - Fork 0
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
Demo - [Guidelines] - Public API route + logging user data + no unit test for new service #123
base: main
Are you sure you want to change the base?
Conversation
PR Review ❌ Security issues: Route '/user-data/:id' lacks permission checks; add middleware. Generated by Firstmate to make sure you can focus on coding new features. |
async getUserData(id) { | ||
const user = await exampleRepo.getById(id); | ||
logger.info(user.data); | ||
} |
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.
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.
Good catch
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.
Thank you for your positive feedback! I'm glad you found the suggestion helpful. If you have any further questions or need assistance with anything else, feel free to ask!
router.route("/user-data/:id").get( exampleController.getById) | ||
|
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.
The route '/user-data/:id' lacks permission checks. You should include grantAccessByPermissionMiddleware
to ensure security. Update the route definition as follows:
+ router.route("/user-data/:id").get(grantAccessByPermissionMiddleware([API_PERMISSIONS.PUBLIC_ENDPOINT]), exampleController.getById)
(Based on guideline 'Routes should check permissions')
export class NewService { | ||
|
||
async getById(id) { | ||
logger.info("Getting data by ID.") | ||
return await exampleRepo.getById(id); | ||
} | ||
|
||
async getDataFromRepo(id) { | ||
return await exampleRepo.getData(id); | ||
} | ||
|
||
|
||
} |
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.
The NewService class lacks unit tests. Implement unit tests in the test folder to ensure the functionality of methods like getById
and getDataFromRepo
. Based on the existing implemented unit test test/test-user.js
, you could implement the new unit test as follows:
import NewService from '../services/newService.js';
import exampleRepo from '../repos/exampleRepo.js';
test('getById should return data for a valid ID', async () => {
const data = await NewService.getById(1);
expect(data).toBeDefined();
});
(Based on guideline 'Services should have unit tests')
run: pnpm lint | ||
- name: Install packages | ||
run: pnpm test |
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.
Your workflow is missing a step to execute unit tests on pull requests. Add a step to run unit tests using the command pnpm test
in your .github/workflows/firstmate.yaml
file. Here's how you can do this:
- name: Run unit tests
run: pnpm test
(Based on guideline 'Unit tests executed on pull request')
💡 PR Summary generated by FirstMate
New API Route and User Data Logging Implementation
Changes:
New API Route:
/user-data/:id
route inexampleRouter.js
to retrieve user data.New Service Class:
NewService
class innewService.js
for handling user data retrieval.getById
andgetDataFromRepo
methods with logging functionality.Logging Enhancements:
exampleService.js
to log user data when fetched.CI Pipeline Update:
.github/workflows/firstmate.yaml
to run tests after package installation.TLDR: This PR adds a new API route for user data retrieval, introduces a new service class with logging, and updates the CI pipeline to include tests. Focus on the new route and service implementations.
Generated by FirstMate and automatically updated on every commit.