-
Notifications
You must be signed in to change notification settings - Fork 12
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
[C4GT Community]: Raise NotImplementedError in InterfaceProtocolCheckMixin if either classes lack the declared method. #33
Comments
@codecakes can you please assign this to me i am interested in working on this issue |
@codecakes can you assign me this one |
@Blacksujit feel free to raise the PR. it will be automatically assigned to whoever has a PR in review. |
@MAVRICK-1 feel free to raise the PR. it will be automatically assigned to whoever has a PR in review. |
@codecakes was giving this a try but got stuck in pytests for this , any guide i could follow , i tested it on already implemented check for params not matching but it shows no error raised (i am on "main" branch ) |
@RISHIKESHk07 share instructions on what steps you took to reproduce your issue including command, code and screenshot. |
@codecakes wrote a new test file and tested it , on main branch |
@RISHIKESHk07 Good effort to begin with but you are proving the point that you have already declared the method. You are not doing anything wrong but contradicting the issue this ticket asks to implement. The issue clearly states to check if the method, in your case method_with_params, is absent in either classes, then it should raise. In your particular case, if you run this: class BaseClass:
def method_with_params(self, param1: int, param2: str):
pass
class IncorrectImplementation(BaseClass, InterfaceProtocolCheckMixin):
def method_with_params(self, param1: int):
pass
IncorrectImplementation() you will get a traceback like this because a.) you already have declared the method BUT b.) It has different signature. Traceback (most recent call last):
...
raise NotImplementedError(f"""Signature for {defined_method} not correct:
NotImplementedError: Signature for method_with_params not correct:
Expected: ['self', 'param1', 'param2']
Got: ['self', 'param1'] I suggest to read the description and goals again. Additionally, when sharing a bug with a screenshot that you want others to try which has a reproducible code, share the code separately when sharing an issue on any ticket. I suggest to look at the following to understand what details to share as a helpful guide: |
@codecakes Thanks for suggestions , i was not able get pytest working as shown in the terminal of photo ( figured it out after some trial and error ) . Will try to move forward in the issue |
@RISHIKESHk07 There is nothing wrong with your pytest setup. It is working and that is why it fails. See contributing to understand how to run tests generally. |
@RISHIKESHk07 Check updated Implementation details section for clarity |
@codecakes this is what i came up with , any suggestion i could make it better |
@RISHIKESHk07 I am unable to understand the context properly. From whatever I can gather from your screenshot, once you have implemented the code and written a unit test for it, raise a PR
|
Is this issue still open? |
hello, could u pls assign this issue to me i would like to work on it. |
@codecakes hello, I'd like to work on this issue too. |
@codecakes i have already sent an PR can you please check |
@ugly-custard @Mayank-tech69 @CraftyEngineer if you follow the necessary actions asked in this issue, you are free to raise a PR. It is a on a first-come first-serve basis. |
@ugly-custard good first attempt. I've left comments. |
Ticket Contents
Description
InterfaceProtocolCheckMixin checks for correct signature used by the implementation class. You can drop in the mixin wherever an implementation is subclassed with an interface definition.
For instance, a service interface is defined here
And It's implementation is here
InterfaceProtocolCheckMixin however doesn't exactly check if both the implementation and interface have the declared method.
Goals
Goals
Expected Outcome
During runtime:
Acceptance Criteria
Implementation Details
Check if both classes have the method declared here: https://github.com/Xcov19/project-healthcare/blob/964861545c969258caa5e86dfc63e413bf545fca/xcov19/utils/mixins.py#L18
UPDATE
If you have an Interface class
BaseClass
and an implementation classIncorrectImplementation
:Then, Running
IncorrectImplementation
should raiseNotImplementedError
because methodmethod_with_params
is missing fromIncorrectImplementation
andmethod2
is not defined in the InterfaceBaseClass
Mockups/Wireframes
No response
Product Name
project-healthcare
Organisation Name
XCoV19
Domain
Healthcare
Tech Skills Needed
Debugging, Python, Test, Testing Library
Mentor(s)
@codecakes
Complexity
Low
Category
Backend, Beginner Friendly, Testing
The text was updated successfully, but these errors were encountered: