Skip to content

Commit

Permalink
fix tests
Browse files Browse the repository at this point in the history
  • Loading branch information
Marchand-Nicolas committed Dec 27, 2024
1 parent d517013 commit 24016e3
Show file tree
Hide file tree
Showing 5 changed files with 59 additions and 46 deletions.
58 changes: 33 additions & 25 deletions app/analytics/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,12 +17,12 @@ export default function Page() {
const { address } = useAccount();
const [loading, setLoading] = useState<boolean>(true);

const [quests, setQuests] = useState<QuestList> ({} as QuestList);
const [quests, setQuests] = useState<QuestList>({} as QuestList);

const fetchQuests = useCallback(async () => {
try {
setLoading(true);
const res = await getQuests() || {};
const res = (await getQuests()) || {};
setQuests(res);
setLoading(false);
} catch (error) {
Expand All @@ -39,34 +39,42 @@ export default function Page() {
<div className={styles.backButton}>
<BackButton onClick={() => router.back()} />
</div>
<Typography type={TEXT_TYPE.H1} color="transparent" className={styles.title}>Quest Analytics</Typography>
<Typography
type={TEXT_TYPE.H1}
color="transparent"
className={styles.title}
>
Quest Analytics
</Typography>
<div className={styles.card_container}>
{loading ? (
<FeaturedQuestSkeleton />
) : (
(Object.keys(quests) as (keyof typeof quests)[]).map((categoryName: keyof typeof quests) => {
const categoryValue = quests[categoryName];
if (Array.isArray(categoryValue)) {
return categoryValue.map((quest: QuestDocument) => {
return (
<Quest
key={quest.id}
title={quest.title_card}
onClick={() => router.push(`/analytics/${quest.id}`)}
imgSrc={quest.img_card}
issuer={{
name: quest.issuer,
logoFavicon: quest.logo,
}}
reward={quest.rewards_title}
id={quest.id}
expired={false}
/>
);
});
(Object.keys(quests) as (keyof typeof quests)[]).map(
(categoryName: keyof typeof quests) => {
const categoryValue = quests[categoryName];
if (Array.isArray(categoryValue)) {
return categoryValue.map((quest: QuestDocument) => {
return (
<Quest
key={quest.id}
title={quest.title_card}
onClick={() => router.push(`/analytics/${quest.id}`)}
imgSrc={quest.img_card}
issuer={{
name: quest.issuer,
logoFavicon: quest.logo,
}}
reward={quest.rewards_title}
id={quest.id}
expired={false}
/>
);
});
}
return null;
}
return null;
})
)
)}
</div>
</div>
Expand Down
1 change: 0 additions & 1 deletion context/QuestsProvider.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -138,7 +138,6 @@ export const QuestsContextProvider = ({
!quest.expired
)
: undefined;

setFeaturedQuest(
lastBoostedQuest ||
notExpired[Math.floor(Math.random() * notExpired.length)]
Expand Down
5 changes: 3 additions & 2 deletions jest.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
module.exports = {
testEnvironment: "node",
transform: {
"\\.[jt]sx?$": "ts-jest",
"^.+\\.(js|jsx|ts|tsx)$": ["babel-jest", { presets: ["next/babel"] }],
},
setupFilesAfterEnv: ["./jest.setup.js"],
moduleNameMapper: {
Expand All @@ -21,4 +21,5 @@ module.exports = {
statements: -10,
},
},
};
transformIgnorePatterns: ["node_modules/(?!(@starknet-react|@starknetkit)/)"],
};
27 changes: 16 additions & 11 deletions tests/utils/domainService.test.js
Original file line number Diff line number Diff line change
@@ -1,23 +1,26 @@
import { getDomainFromAddress } from '@utils/domainService';
import { getDomainFromAddress } from "@utils/domainService";

const API_URL = process.env.NEXT_PUBLIC_STARKNET_ID_API_LINK;

describe("getDomainFromAddress function", () => {
it("should return a valid domain for a valid address", async () => {
const validAddress = "0x061b6c0a78f9edf13cea17b50719f3344533fadd470b8cb29c2b4318014f52d3";
it("should return a valid domain for a valid address", async () => {
const validAddress =
"0x061b6c0a78f9edf13cea17b50719f3344533fadd470b8cb29c2b4318014f52d3";
const expectedDomain = "fricoben.stark";

// Mocking the fetch function to return a predefined response
const mockResponse = { domain: expectedDomain };
const fetchMock = jest.fn().mockResolvedValue({
json: jest.fn().mockResolvedValue(mockResponse),
json: jest.fn().mockResolvedValue(mockResponse),
});
(fetch as jest.Mock) = fetchMock;
fetch = fetchMock;

const domain = await getDomainFromAddress(validAddress);

expect(domain).toBe(expectedDomain);
expect(fetchMock).toHaveBeenCalledWith(`${API_URL}/addr_to_domain?addr=${validAddress}`);
expect(fetchMock).toHaveBeenCalledWith(
`${API_URL}/addr_to_domain?addr=${validAddress}`
);
});

it("should return an empty string for an invalid address", async () => {
Expand All @@ -27,13 +30,15 @@ it("should return a valid domain for a valid address", async () => {
// Mocking the fetch function to simulate an error
const mockResponse = { domain: expectedDomain };
const fetchMock = jest.fn().mockResolvedValue({
json: jest.fn().mockResolvedValue(mockResponse),
});
(fetch as jest.Mock) = fetchMock;
json: jest.fn().mockResolvedValue(mockResponse),
});
fetch = fetchMock;

const domain = await getDomainFromAddress(invalidAddress);

expect(domain).toBe("");
expect(fetchMock).toHaveBeenCalledWith(`${API_URL}/addr_to_domain?addr=${invalidAddress}`);
expect(fetchMock).toHaveBeenCalledWith(
`${API_URL}/addr_to_domain?addr=${invalidAddress}`
);
});
});
});
14 changes: 7 additions & 7 deletions tests/utils/walletConfig.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import {
getConnectorIcon,
getConnectorName,
getConnectorDiscovery,
} from "../../utils/walletConfig";
} from "@utils/walletConfig";
class MockConnector {
constructor(id, name, isAvailable) {
this.id = id;
Expand Down Expand Up @@ -65,10 +65,10 @@ describe("sortConnectors function", () => {
describe("getConnectorIcon function", () => {
it("should return the icon for a wallet when the ID matches", () => {
expect(getConnectorIcon("argentX")).toBe(
"",
""
);
expect(getConnectorIcon("braavos")).toBe(
"",
""
);
});

Expand Down Expand Up @@ -123,26 +123,26 @@ describe("getConnectorDiscovery function", () => {

it("should return the wallet's website URL when no downloads are available", () => {
expect(getConnectorDiscovery("argentWebWallet")).toBe(
"https://www.argent.xyz/argent-x/",
"https://www.argent.xyz/argent-x/"
);
});

it("should return the correct download link for the user's browser if available", () => {
expect(getConnectorDiscovery("braavos")).toBe(
"https://chrome.google.com/webstore/detail/braavos-wallet/jnlgamecbpmbajjfhmmmlhejkemejdma",
"https://chrome.google.com/webstore/detail/braavos-wallet/jnlgamecbpmbajjfhmmmlhejkemejdma"
);
});

it("should return the ecosystem website if no wallet data is found", () => {
expect(getConnectorDiscovery("wallet")).toBe(
"https://www.starknet-ecosystem.com",
"https://www.starknet-ecosystem.com"
);
});

it("should return the wallet's website when navigator is undefined", () => {
Object.defineProperty(global, "navigator", { value: undefined });
expect(getConnectorDiscovery("argentX")).toBe(
"https://www.argent.xyz/argent-x/",
"https://www.argent.xyz/argent-x/"
);
});
});

0 comments on commit 24016e3

Please sign in to comment.