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

feat(manager): server allowance usage component #2311

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

Conversation

daniellacosse
Copy link
Contributor

Screenshot 2024-12-13 at 2 21 00 PM

@daniellacosse daniellacosse requested a review from a team as a code owner December 13, 2024 19:21
return html`
<p class="message">${this.message}</p>
<p class="allowance">
<span class="allowance-percentage">${this.formattedPercentage}</span>
Copy link
Contributor

Choose a reason for hiding this comment

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

Add some unit tests to validate the formatted values.

Copy link
Contributor Author

@daniellacosse daniellacosse Dec 16, 2024

Choose a reason for hiding this comment

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

So we don't really have UI unit tests set up yet - well, we have this approach, but yikes

Some options here -

  1. use the above approach, drilling down via querySelector and shadowRoot - not ideal imo. Klugy, cumbersome, fragile.
  2. set up something better - karma snapshots or storybook test runner. Ideal, but should probably be done in a separate PR.
  3. Break these out into separate functions and test them that way. Prefer to not let testability determine architecture but would be good enough and kicks the can down the road.

Copy link
Contributor

Choose a reason for hiding this comment

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

I'm fine with something like querySelector for now. That's how I tested the contact form logic in the absence of a better testing framework. I really just want something here to prevent regression of this formatting.

@property({type: String}) message: string;
@property({type: Number}) allowanceUsed: number;
@property({type: Number}) allowanceLimit: number;
@property({type: String}) allowanceUnit: 'gigabyte' | 'terabyte' = 'terabyte';
Copy link
Contributor

Choose a reason for hiding this comment

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

nit Shall we be "smart" to determine the unit automatically? For example, just let the caller pass a raw bytes: 1,234,567,000, then we automatically display it as 1.23 GB?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Sure, I can do that!

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

Successfully merging this pull request may close these issues.

3 participants