From fd8a462ed8a4f9127f08cd5217fa7eedaaec1205 Mon Sep 17 00:00:00 2001 From: Alissa Crane Date: Thu, 8 Aug 2024 13:26:46 -0700 Subject: [PATCH] feat: added test workflow (#10) Co-authored-by: Alissa Crane --- .github/workflows/test.yml | 26 ++++++++++++++ src/components/TransactionWrapper.test.tsx | 42 ++++++++++++++++++++++ src/components/TransactionWrapper.tsx | 6 ++-- src/components/WalletWrapper.test.tsx | 38 ++++++++++++++++++-- tsconfig.json | 2 +- 5 files changed, 107 insertions(+), 7 deletions(-) create mode 100644 .github/workflows/test.yml create mode 100644 src/components/TransactionWrapper.test.tsx diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml new file mode 100644 index 0000000..7a4bddc --- /dev/null +++ b/.github/workflows/test.yml @@ -0,0 +1,26 @@ +name: Kit Test +on: + push: + branches: ['main'] + pull_request: + branches: ['main'] +jobs: + build: + runs-on: ubuntu-latest + strategy: + matrix: + node-version: [18.x] + # See supported Node.js release schedule at https://nodejs.org/en/about/releases/ + steps: + - name: Checkout + uses: actions/checkout@v4 + + - name: Setup Bun + uses: oven-sh/setup-bun@v2 + + - name: Template Install dependencies + run: bun install + + - name: Kit Test + # When fails, please check your tests + run: bun run test:coverage diff --git a/src/components/TransactionWrapper.test.tsx b/src/components/TransactionWrapper.test.tsx new file mode 100644 index 0000000..18e1399 --- /dev/null +++ b/src/components/TransactionWrapper.test.tsx @@ -0,0 +1,42 @@ +import { QueryClient, QueryClientProvider } from '@tanstack/react-query'; +import { render, screen } from '@testing-library/react'; +import { describe, expect, it } from 'vitest'; +import { http, WagmiProvider, createConfig } from 'wagmi'; +import { base } from 'wagmi/chains'; +import { mock } from 'wagmi/connectors'; +import TransactionWrapper from './TransactionWrapper'; + +const config = createConfig({ + chains: [base], + connectors: [ + mock({ + accounts: [ + '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266', + '0x70997970c51812dc3a010c7d01b50e0d17dc79c8', + '0x3C44CdDdB6a900fa2b585dd299e03d12FA4293BC', + ], + }), + ], + transports: { + [base.id]: http(), + }, +}); +const queryClient = new QueryClient(); + +const renderWithProviders = (component: JSX.Element) => { + return render( + + + {component} + + , + ); +}; + +describe('TransactionWrapper', () => { + it('should renders', () => { + renderWithProviders(); + const transaction = screen.getByText('Collect'); + expect(transaction).toBeInTheDocument(); + }); +}); diff --git a/src/components/TransactionWrapper.tsx b/src/components/TransactionWrapper.tsx index 61e0d4b..a83e848 100644 --- a/src/components/TransactionWrapper.tsx +++ b/src/components/TransactionWrapper.tsx @@ -10,6 +10,8 @@ import type { TransactionError, TransactionResponse, } from '@coinbase/onchainkit/transaction'; +import type { Address, ContractFunctionParameters } from 'viem'; +import { parseEther } from 'viem'; import { BASE_SEPOLIA_CHAIN_ID, collectionAddress, @@ -19,9 +21,7 @@ import { mintReferral, quantity, tokenId, -} from 'src/constants'; -import type { Address, ContractFunctionParameters } from 'viem'; -import { parseEther } from 'viem'; +} from '../constants'; type TransactionWrapperParams = { address: Address; diff --git a/src/components/WalletWrapper.test.tsx b/src/components/WalletWrapper.test.tsx index 3644aba..2f51658 100644 --- a/src/components/WalletWrapper.test.tsx +++ b/src/components/WalletWrapper.test.tsx @@ -1,10 +1,42 @@ -import { render } from '@testing-library/react'; +import { QueryClient, QueryClientProvider } from '@tanstack/react-query'; +import { render, screen } from '@testing-library/react'; import { describe, expect, it } from 'vitest'; +import { http, WagmiProvider, createConfig } from 'wagmi'; +import { base } from 'wagmi/chains'; +import { mock } from 'wagmi/connectors'; import WalletWrapper from './WalletWrapper'; +const config = createConfig({ + chains: [base], + connectors: [ + mock({ + accounts: [ + '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266', + '0x70997970c51812dc3a010c7d01b50e0d17dc79c8', + '0x3C44CdDdB6a900fa2b585dd299e03d12FA4293BC', + ], + }), + ], + transports: { + [base.id]: http(), + }, +}); +const queryClient = new QueryClient(); + +const renderWithProviders = (Component: React.ComponentType) => { + return render( + + + + + , + ); +}; + describe('WalletWrapper', () => { it('should renders', () => { - render(); - expect(true).toBeTruthy(); + renderWithProviders(WalletWrapper); + const wallet = screen.getByTestId('ockConnectWallet_Container'); + expect(wallet).toBeInTheDocument(); }); }); diff --git a/tsconfig.json b/tsconfig.json index 672fd3a..697ba86 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -11,7 +11,7 @@ "moduleResolution": "bundler", "resolveJsonModule": true, "isolatedModules": true, - "jsx": "preserve", + "jsx": "react-jsx", "incremental": true, "plugins": [ {