fix: API v2 recurring spelling #21069
Triggered via pull request
April 16, 2024 21:32
keithwillcode
opened
#14620
Status
Success
Total duration
21m 33s
Artifacts
13
pr.yml
on: pull_request_target
Detect changes
19s
Type check
/
check-types
2m 5s
Unit tests
/
test
1m 41s
Production build
/
Build API V1
2m 23s
Production build (without database)
/
Build
10m 4s
Matrix: E2E App Store tests / e2e-app-store
Matrix: E2E React embeds tests / e2e-embed
Matrix: E2E embeds tests / e2e-embed
Matrix: E2E tests / e2e
Analyze Build
/
analyze
1m 34s
required
3s
Annotations
14 errors, 21 warnings, and 10 notices
[@calcom/app-store] › packages/app-store/routing-forms/playwright/tests/basic.e2e.ts:337:9 › Routing Forms › Seeded Routing Form › Test preview should return correct route:
packages/app-store/routing-forms/playwright/tests/basic.e2e.ts#L1
1) [@***com/app-store] › packages/app-store/routing-forms/playwright/tests/basic.e2e.ts:337:9 › Routing Forms › Seeded Routing Form › Test preview should return correct route
Test timeout of 60000ms exceeded.
|
[@calcom/app-store] › packages/app-store/routing-forms/playwright/tests/basic.e2e.ts:337:9 › Routing Forms › Seeded Routing Form › Test preview should return correct route:
packages/app-store/routing-forms/playwright/tests/basic.e2e.ts#L345
1) [@***com/app-store] › packages/app-store/routing-forms/playwright/tests/basic.e2e.ts:337:9 › Routing Forms › Seeded Routing Form › Test preview should return correct route
page.fill: Target closed
=========================== logs ===========================
waiting for locator('[data-testid="form-field-Test field"]')
============================================================
343 |
344 | // //event redirect
> 345 | await page.fill('[data-testid="form-field-Test field"]', "event-routing");
| ^
346 | await page.click('[data-testid="test-routing"]');
347 | let routingType = await page.locator('[data-testid="test-routing-result-type"]').innerText();
348 | let route = await page.locator('[data-testid="test-routing-result"]').innerText();
at /home/runner/actions-runner/_work/***.com/***.com/packages/app-store/routing-forms/playwright/tests/basic.e2e.ts:345:18
|
[@calcom/app-store] › packages/app-store/routing-forms/playwright/tests/basic.e2e.ts:337:9 › Routing Forms › Seeded Routing Form › Test preview should return correct route:
packages/app-store/routing-forms/playwright/tests/basic.e2e.ts#L1
1) [@***com/app-store] › packages/app-store/routing-forms/playwright/tests/basic.e2e.ts:337:9 › Routing Forms › Seeded Routing Form › Test preview should return correct route
Pending operations:
- page.fill at packages/app-store/routing-forms/playwright/tests/basic.e2e.ts:345:18
|
[@calcom/web] › apps/web/playwright/teams.e2e.ts:122:7 › Teams - NonOrg -- future › Can create a booking for Round Robin EventType:
apps/web/playwright/teams.e2e.ts#L156
1) [@***com/web] › apps/web/playwright/teams.e2e.ts:122:7 › Teams - NonOrg -- future › Can create a booking for Round Robin EventType
Error: expect(received).toBe(expected) // Object.is equality
Expected: true
Received: false
154 | return BookingTitle === bookingTitle;
155 | })
> 156 | ).toBe(true);
| ^
157 |
158 | // Since all the users have the same leastRecentlyBooked value
159 | // Anyone of the teammates could be the Host of the booking.
at /home/runner/actions-runner/_work/***.com/***.com/apps/web/playwright/teams.e2e.ts:156:7
|
[@calcom/web] › apps/web/playwright/profile.e2e.ts:20:7 › Teams › Profile page is loaded for users in Organization:
apps/web/playwright/fixtures/users.ts#L868
1) [@***com/web] › apps/web/playwright/profile.e2e.ts:20:7 › Teams › Profile page is loaded for users in Organization
apiRequestContext.post: read ECONNRESET
=========================== logs ===========================
→ POST http://***:3000/api/auth/***lback/credentials
user-agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.5563.19 Safari/537.36
accept: */*
accept-encoding: gzip,deflate,br
content-type: application/json
content-length: 228
cookie: next-auth.csrf-token=bde8829acdfd9578f24cc0cda39842b8f2691d7d029459c2b41f6d19356f3f87%7C4461d42b16be5d0d155cfce68e529036949a321d23bf1e1f0b280dc257851c30; next-auth.***lback-url=http%3A%2F%2F***%3A3000
← 408 Request Timeout
connection: close
============================================================
at apps/web/playwright/fixtures/users.ts:868
866 | csrfToken,
867 | };
> 868 | return page.context().request.post("/api/auth/***lback/credentials", {
| ^
869 | data,
870 | });
871 | }
at apiLogin (/home/runner/actions-runner/_work/***.com/***.com/apps/web/playwright/fixtures/users.ts:868:33)
at /home/runner/actions-runner/_work/***.com/***.com/apps/web/playwright/profile.e2e.ts:28:5
|
[@calcom/web] › apps/web/playwright/profile.e2e.ts:102:7 › Update Profile › Can update a users email (verification enabled):
apps/web/playwright/profile.e2e.ts#L148
2) [@***com/web] › apps/web/playwright/profile.e2e.ts:102:7 › Update Profile › Can update a users email (verification enabled)
page.waitForURL: Timeout 30000ms exceeded.
=========================== logs ===========================
waiting for navigation to "/event-types" until "load"
navigated to "http://***:3000/auth/login"
============================================================
146 |
147 | // After email verification is successfull. user is sent to /event-types
> 148 | await page.waitForURL("/event-types");
| ^
149 |
150 | await page.goto("/settings/my-account/profile");
151 | const emailInputUpdated = await page.getByTestId("profile-form-email-0");
at /home/runner/actions-runner/_work/***.com/***.com/apps/web/playwright/profile.e2e.ts:148:16
|
[@calcom/web] › apps/web/playwright/profile.e2e.ts:102:7 › Update Profile › Can update a users email (verification enabled):
apps/web/playwright/profile.e2e.ts#L148
2) [@***com/web] › apps/web/playwright/profile.e2e.ts:102:7 › Update Profile › Can update a users email (verification enabled)
Retry #1 ───────────────────────────────────────────────────────────────────────────────────────
page.waitForURL: Timeout 30000ms exceeded.
=========================== logs ===========================
waiting for navigation to "/event-types" until "load"
navigated to "http://***:3000/auth/login"
============================================================
146 |
147 | // After email verification is successfull. user is sent to /event-types
> 148 | await page.waitForURL("/event-types");
| ^
149 |
150 | await page.goto("/settings/my-account/profile");
151 | const emailInputUpdated = await page.getByTestId("profile-form-email-0");
at /home/runner/actions-runner/_work/***.com/***.com/apps/web/playwright/profile.e2e.ts:148:16
|
[@calcom/web] › apps/web/playwright/eventType/limit-tab.e2e.ts:12:7 › Limits Tab - Event Type › Check the functionalities of the Limits Tab:
apps/web/playwright/fixtures/regularBookings.ts#L172
1) [@***com/web] › apps/web/playwright/eventType/limit-tab.e2e.ts:12:7 › Limits Tab - Event Type › Check the functionalities of the Limits Tab
locator.click: Error: strict mode violation: getByRole('button', { name: 'Add Limit' }) resolved to 2 elements:
1) <button type="button" class="whitespace-nowrap inline-fl…>…</button> aka getByRole('list').filter({ hasText: 'Per dayPer weekAdd Limit' }).getByRole('button', { name: 'Add Limit' })
2) <button type="button" class="whitespace-nowrap inline-fl…>…</button> aka getByRole('list').filter({ hasText: 'MinutesPer dayAdd Limit' }).getByRole('button', { name: 'Add Limit' })
=========================== logs ===========================
waiting for getByRole('button', { name: 'Add Limit' })
============================================================
at apps/web/playwright/fixtures/regularBookings.ts:172
170 |
171 | await limitDurationSwitch.click();
> 172 | await page.getByRole("button", { name: addlimit }).click();
| ^
173 | await expect(page.getByTestId("add-limit")).toHaveCount(2);
174 | await limitDurationSwitch.click();
175 | },
at Object.checkLimitBookingDuration (/home/runner/actions-runner/_work/***.com/***.com/apps/web/playwright/fixtures/regularBookings.ts:172:58)
at /home/runner/actions-runner/_work/***.com/***.com/apps/web/playwright/eventType/limit-tab.e2e.ts:14:5
|
[@calcom/web] › apps/web/playwright/availability.e2e.ts:114:7 › Availablity › Can manage single schedule:
apps/web/playwright/availability.e2e.ts#L1
1) [@***com/web] › apps/web/playwright/availability.e2e.ts:114:7 › Availablity › Can manage single schedule
Test timeout of 60000ms exceeded.
|
[@calcom/web] › apps/web/playwright/availability.e2e.ts:114:7 › Availablity › Can manage single schedule:
apps/web/playwright/availability.e2e.ts#L167
1) [@***com/web] › apps/web/playwright/availability.e2e.ts:114:7 › Availablity › Can manage single schedule
locator.click: Target closed
=========================== logs ===========================
waiting for getByTestId('dialog-rejection')
locator resolved to <button type="button" data-testid="dialog-rejection" cla…>Close</button>
attempting click action
waiting for element to be visible, enabled and stable
element is visible, enabled and stable
scrolling into view if needed
done scrolling
<p class="text-left" data-testid="toast-success">Working Hours test schedule updated successfully</p> from <div id="__next" aria-hidden="true" data-aria-hidden=…>…</div> subtree intercepts pointer events
retrying click action, attempt #1
waiting for element to be visible, enabled and stable
element is visible, enabled and stable
scrolling into view if needed
done scrolling
<button class="data-testid-toast-success bg-brand-defaul…>…</button> from <div id="__next" aria-hidden="true" data-aria-hidden=…>…</div> subtree intercepts pointer events
retrying click action, attempt #2
waiting 20ms
waiting for element to be visible, enabled and stable
element is visible, enabled and stable
scrolling into view if needed
done scrolling
<button class="data-testid-toast-success bg-brand-defaul…>…</button> from <div id="__next" aria-hidden="true" data-aria-hidden=…>…</div> subtree intercepts pointer events
retrying click action, attempt #3
waiting 100ms
waiting for element to be visible, enabled and stable
element is visible, enabled and stable
scrolling into view if needed
done scrolling
<button class="data-testid-toast-success bg-brand-defaul…>…</button> from <div id="__next" aria-hidden="true" data-aria-hidden=…>…</div> subtree intercepts pointer events
retrying click action, attempt #4
waiting 100ms
waiting for element to be visible, enabled and stable
element is visible, enabled and stable
scrolling into view if needed
done scrolling
<button class="data-testid-toast-success bg-brand-defaul…>…</button> from <div id="__next" aria-hidden="true" data-aria-hidden=…>…</div> subtree intercepts pointer events
retrying click action, attempt #5
waiting 500ms
waiting for element to be visible, enabled and stable
element is visible, enabled and stable
scrolling into view if needed
done scrolling
<button class="data-testid-toast-success bg-brand-defaul…>…</button> from <div id="__next" aria-hidden="true" data-aria-hidden=…>…</div> subtree intercepts pointer events
retrying click action, attempt #6
waiting 500ms
waiting for element to be visible, enabled and stable
element is visible, enabled and stable
scrolling into view if needed
done scrolling
<button class="data-testid-toast-success bg-brand-defaul…>…</button> from <div id="__next" aria-hidden="true" data-aria-hidden=…>…</div> subtree intercepts pointer events
retrying click action, attempt #7
waiting 500ms
waiting for element to be visible, enabled and stable
element is visible, enabled and stable
scrolling into view if needed
done scrolling
<button class="data-testid-toast-success bg-brand-defaul…>…</button> from <div id="__next" aria-hidden="true" data-aria-hidden=…>…</div> subtree intercepts pointer events
retrying click action, attempt #8
waiting 500ms
waiting for element to be visible, enabled and stable
element is visible, enabled and stable
scrolling into view if needed
done scrolling
<button class="data-testid-toast-success bg-brand-defaul…>…</button> from <div id="__next" aria-hidden="true" data-aria-hidden=…>…</div> subtree intercepts pointer events
retrying click action, attempt #9
waiting 500ms
waiting for element to be visible, enabled and stable
element is visible, enabled and stable
scrolling into v
|
[@calcom/web] › apps/web/playwright/availability.e2e.ts:114:7 › Availablity › Can manage single schedule:
apps/web/playwright/availability.e2e.ts#L1
1) [@***com/web] › apps/web/playwright/availability.e2e.ts:114:7 › Availablity › Can manage single schedule
Pending operations:
- locator.click at apps/web/playwright/availability.e2e.ts:167:48
|
[@calcom/web] › apps/web/playwright/integrations-stripe.e2e.ts:130:7 › Stripe integration › Can book a paid booking:
apps/web/playwright/integrations-stripe.e2e.ts#L1
1) [@***com/web] › apps/web/playwright/integrations-stripe.e2e.ts:130:7 › Stripe integration › Can book a paid booking
Test timeout of 60000ms exceeded.
|
[@calcom/web] › apps/web/playwright/integrations-stripe.e2e.ts:130:7 › Stripe integration › Can book a paid booking:
apps/web/playwright/fixtures/users.ts#L892
1) [@***com/web] › apps/web/playwright/integrations-stripe.e2e.ts:130:7 › Stripe integration › Can book a paid booking
page.waitForURL: Navigation failed because page was closed!
=========================== logs ===========================
waiting for navigation to "/payment/*" until "load"
navigated to "http://***:3000/booking/8VBuvTVwSnEZqPR7MrNcxY?isSuccessBookingPage=true&email=test%40example.com&eventTypeSlug=paid"
============================================================
at apps/web/playwright/fixtures/users.ts:892
890 | await page.fill('[name="email"]', "test@example.com");
891 |
> 892 | await Promise.all([page.waitForURL("/payment/*"), page.press('[name="email"]', "Enter")]);
| ^
893 |
894 | await makePaymentUsingStripe(page);
895 | }
at bookAndPayEvent (/home/runner/actions-runner/_work/***.com/***.com/apps/web/playwright/fixtures/users.ts:892:27)
at /home/runner/actions-runner/_work/***.com/***.com/apps/web/playwright/integrations-stripe.e2e.ts:138:5
|
[@calcom/web] › apps/web/playwright/integrations-stripe.e2e.ts:130:7 › Stripe integration › Can book a paid booking:
apps/web/playwright/fixtures/users.ts#L892
1) [@***com/web] › apps/web/playwright/integrations-stripe.e2e.ts:130:7 › Stripe integration › Can book a paid booking
Retry #1 ───────────────────────────────────────────────────────────────────────────────────────
page.waitForURL: Timeout 30000ms exceeded.
=========================== logs ===========================
waiting for navigation to "/payment/*" until "load"
navigated to "http://***:3000/booking/rinhp7ZgLXgJV4sScJpfQ8?isSuccessBookingPage=true&email=test%40example.com&eventTypeSlug=paid"
============================================================
at apps/web/playwright/fixtures/users.ts:892
890 | await page.fill('[name="email"]', "test@example.com");
891 |
> 892 | await Promise.all([page.waitForURL("/payment/*"), page.press('[name="email"]', "Enter")]);
| ^
893 |
894 | await makePaymentUsingStripe(page);
895 | }
at bookAndPayEvent (/home/runner/actions-runner/_work/***.com/***.com/apps/web/playwright/fixtures/users.ts:892:27)
at /home/runner/actions-runner/_work/***.com/***.com/apps/web/playwright/integrations-stripe.e2e.ts:138:5
|
🎭 Playwright Run Summary
2 passed (13.1s)
|
🎭 Playwright Run Summary
2 skipped
2 passed (6.6s)
|
🎭 Playwright Run Summary
1 passed (3.7s)
|
🎭 Playwright Run Summary
1 flaky
[@***com/app-store] › packages/app-store/routing-forms/playwright/tests/basic.e2e.ts:337:9 › Routing Forms › Seeded Routing Form › Test preview should return correct route
5 skipped
7 passed (1.4m)
|
🎭 Playwright Run Summary
1 skipped
13 passed (48.5s)
|
🎭 Playwright Run Summary
1 flaky
[@***com/web] › apps/web/playwright/teams.e2e.ts:122:7 › Teams - NonOrg -- future › Can create a booking for Round Robin EventType
12 skipped
45 passed (1.5m)
|
🎭 Playwright Run Summary
2 flaky
[@***com/web] › apps/web/playwright/profile.e2e.ts:20:7 › Teams › Profile page is loaded for users in Organization
[@***com/web] › apps/web/playwright/profile.e2e.ts:102:7 › Update Profile › Can update a users email (verification enabled)
8 skipped
45 passed (2.2m)
|
🎭 Playwright Run Summary
1 flaky
[@***com/web] › apps/web/playwright/eventType/limit-tab.e2e.ts:12:7 › Limits Tab - Event Type › Check the functionalities of the Limits Tab
2 skipped
54 passed (2.8m)
|
🎭 Playwright Run Summary
1 flaky
[@***com/web] › apps/web/playwright/availability.e2e.ts:114:7 › Availablity › Can manage single schedule
4 skipped
79 passed (3.1m)
|
🎭 Playwright Run Summary
1 flaky
[@***com/web] › apps/web/playwright/integrations-stripe.e2e.ts:130:7 › Stripe integration › Can book a paid booking
3 skipped
47 passed (3.3m)
|
Detect changes
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, dorny/paths-filter@v2. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
Unit tests / test
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
Type check / check-types
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
Production build / Build API V1
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
Linters / lint
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3, ataylorme/eslint-annotate-action@v2. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
Production build (without database) / Build
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
Production build / Build
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
Analyze Build / analyze
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3, dawidd6/action-download-artifact@v2, peter-evans/find-comment@v2, peter-evans/create-or-update-comment@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
Analyze Build / analyze
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|
E2E App Store tests / E2E App Store (2/2)
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
E2E embeds tests / E2E Embed Core (2/2)
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
E2E React embeds tests / E2E Embed React (1/2)
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
E2E React embeds tests / E2E Embed React (2/2)
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
E2E App Store tests / E2E App Store (1/2)
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
E2E embeds tests / E2E Embed Core (1/2)
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
E2E tests / E2E tests (5/5)
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
E2E tests / E2E tests (4/5)
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
E2E tests / E2E tests (2/5)
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
E2E tests / E2E tests (1/5)
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
E2E tests / E2E tests (3/5)
Failed to restore: aborted
|
E2E tests / E2E tests (3/5)
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v3, buildjet/setup-node@v3, buildjet/cache@v3. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
|
Artifacts
Produced during runtime
Name | Size | |
---|---|---|
app-store-results-1_2
Expired
|
3.91 MB |
|
app-store-results-2_2
Expired
|
177 KB |
|
bundle
Expired
|
2.21 KB |
|
embed-core-results-1_2
Expired
|
186 KB |
|
embed-core-results-2_2
Expired
|
178 KB |
|
embed-react-results-1_2
Expired
|
175 KB |
|
embed-react-results-2_2
Expired
|
173 KB |
|
lint-results
Expired
|
212 KB |
|
test-results-1_5
Expired
|
19.8 MB |
|
test-results-2_5
Expired
|
8.18 MB |
|
test-results-3_5
Expired
|
32.5 MB |
|
test-results-4_5
Expired
|
9.88 MB |
|
test-results-5_5
Expired
|
2.89 MB |
|