**Helloooooooo!** Hope you're doing great! This is SMY! 👋 Let's Jump right in 🚀 Part 1: [https://smy.hashnode.dev/typescript-sdk-development-a-5-year-old-could-follow-this-step-by-step-part-1-our-first-mvp](https://smy.hashnode.dev/typescript-sdk-development-a-5-year-old-could-follow-this-step-by-step-part-1-our-first-mvp) Part 2: [https://smy.hashnode.dev/typescript-sdk-development-a-5-year-old-could-follow-this-step-by-step-part-2-folder-structure-integrating-api](https://smy.hashnode.dev/typescript-sdk-development-a-5-year-old-could-follow-this-step-by-step-part-2-folder-structure-integrating-api) Part 4: [https://smy.hashnode.dev/typescript-sdk-development-a-5-year-old-could-follow-this-step-by-step-part-4-publishing-to-npm](https://smy.hashnode.dev/typescript-sdk-development-a-5-year-old-could-follow-this-step-by-step-part-4-publishing-to-npm) Part 5: [https://smy.hashnode.dev/typescript-sdk-development-a-5-year-old-could-follow-this-step-by-step-part-5-cdn-for-browsers](https://smy.hashnode.dev/typescript-sdk-development-a-5-year-old-could-follow-this-step-by-step-part-5-cdn-for-browsers) This is Part 3 of our SDK development series where we will dive into creating test apps for react, browser, node, and legacy node. ## Contents: * ⚡ `Setting up tsup for different execution environments` * ⚡ `Creating our apps` ### Step 1: Setting up `tsup` for different environments At the root of the project create `tsup.config.ts` file, and paste the following content: ```javascript import { defineConfig } from "tsup"; export default defineConfig({ clean: true, dts: true, entry: ["src/index.ts"], format: ["cjs", "esm", "iife"], minify: true, }); ``` `clean` - Clean the output directory before each build `dts` - type definitions for TypeScript `entry` - specifying the entry point `format` - `cjs` for legacy, `esm` for newer node projects and `iife` for browsers `minify` - minifies our code and reduces bundle size No extra configuration is needed, as `tsup` will automatically look for this file and handle everything for us :) Now exit and re-rerun `build` command ```bash npm run build ``` You will see the following output in our `dist` folder data:image/s3,"s3://crabby-images/08581/0858147bb7d42a189ed50e173934de349cbc5c07" alt="" `index.cjs` - for CJS output `index.js` - for ESM `index.global.js` - for browsers ### Step 2: Create a Node App In `example-apps/Node` create a `index.js` file and paste the following content: ```javascript import sdk from "../../dist/index.js"; console.log(await sdk.fetchUsers()); ``` Now run the file with a node in a separate terminal and head over to the folder: ```bash node index.js ``` You will see the output in the terminal. ### Step 3: Create a Legacy Node App In `example-apps/Legacy-Node` create a `index.cjs` file and paste the following content: ```javascript const sdk = require("../../dist/index.cjs"); sdk.default.fetchUsers().then((users) => console.log(users)); ``` Now run the file with a node in a separate terminal and head over to the folder: ```bash node index.cjs ``` You will see the output in the terminal. ### Step 4: Create a Browser App In `example-apps/Browser` create a `index.html` file and paste the following content: ```xml
Edit src/App.tsx
and save to test HMR
Click on the Vite and React logos to learn more
> ); } export default App; ``` Run the react App, and head over to the console, it should look like the following: data:image/s3,"s3://crabby-images/4f7df/4f7dfcd6739497f483b5f7ff610a21f534bae498" alt="" ## Wrapping Up: We Just completed the steps to build and run our SDK in different environments. Head over to Part 4 to publish our SDK. ..... Now you're equipped with knowledge to build your own SDK. Happy coding! 🚀 That's it, folks! hope it was a good read for you. Thank you! ✨ 👉 Follow me [GitHub](https://github.com/smyaseen) [LinkedIn](https://www.linkedin.com/in/sm-y)