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

fix(datetime): handle am / pm variants #5406

Merged
merged 18 commits into from
Aug 9, 2024

Conversation

timreichen
Copy link
Contributor

@timreichen timreichen requested a review from kt3k as a code owner July 10, 2024 21:54
Copy link

codecov bot commented Jul 10, 2024

Codecov Report

Attention: Patch coverage is 77.41935% with 7 lines in your changes missing coverage. Please review.

Project coverage is 96.24%. Comparing base (860f578) to head (9c93c1c).

Files Patch % Lines
datetime/_date_time_formatter.ts 77.41% 7 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #5406      +/-   ##
==========================================
- Coverage   96.26%   96.24%   -0.02%     
==========================================
  Files         473      473              
  Lines       38390    38419      +29     
  Branches     5571     5584      +13     
==========================================
+ Hits        36955    36978      +23     
- Misses       1393     1399       +6     
  Partials       42       42              

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

Copy link
Contributor

@iuioiua iuioiua left a comment

Choose a reason for hiding this comment

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

To my surprise, these tests all pass even without the implementation change. Why? I think we should add more thorough testing for dayPeriod before working on this addition. Also, we should update the format and parse documentation to reflect this change.

@babiabeo
Copy link
Contributor

babiabeo commented Jul 18, 2024

I think the problem is in partsToDate method:

case "hour": {
let value = Number(part.value);
const dayPeriod = parts.find(
(part: DateTimeFormatPart) => part.type === "dayPeriod",
);
if (dayPeriod?.value === "PM") value += 12;
utc ? date.setUTCHours(value) : date.setHours(value);
break;

It only checks if dayPeriod.value is ”PM”. Otherwise, it ignores other values. That's why these tests all pass even without the implementation change.

@iuioiua
Copy link
Contributor

iuioiua commented Jul 24, 2024

@babiabeo, would you be interested in creating some tests to compliment this PR?

@iuioiua
Copy link
Contributor

iuioiua commented Jul 31, 2024

@timreichen, reminder that we can't merge this PR until the tests that it touches has been improved. Please see the above comments.

@timreichen
Copy link
Contributor Author

Please hold with this PR until #5622.

@timreichen timreichen requested a review from iuioiua August 8, 2024 14:19
@iuioiua
Copy link
Contributor

iuioiua commented Aug 8, 2024

@timreichen, have the tests been improved as requested above?

@github-actions github-actions bot added the io label Aug 8, 2024
@github-actions github-actions bot removed the io label Aug 8, 2024
@timreichen
Copy link
Contributor Author

@timreichen, have the tests been improved as requested above?

Yes, I added tests for all valid cases and a test that throws on invalid data.

datetime/_date_time_formatter_test.ts Show resolved Hide resolved
datetime/_date_time_formatter_test.ts Outdated Show resolved Hide resolved
datetime/_date_time_formatter_test.ts Outdated Show resolved Hide resolved
datetime/_date_time_formatter_test.ts Outdated Show resolved Hide resolved
datetime/_date_time_formatter_test.ts Outdated Show resolved Hide resolved
Copy link
Contributor

@iuioiua iuioiua left a comment

Choose a reason for hiding this comment

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

Nice! LGTM.

@iuioiua iuioiua changed the title fix(datetime): am / pm variants fix(datetime): handle am / pm variants Aug 9, 2024
@iuioiua iuioiua merged commit 7edeba4 into denoland:main Aug 9, 2024
14 checks passed
@timreichen timreichen deleted the datetime-fix-am/pm-variants branch August 17, 2024 23:38
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