Bird
Raised Fist0
Postmantesting~8 mins

Why pre-request scripts prepare data in Postman - Framework Benefits

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Framework Mode - Why pre-request scripts prepare data
Folder Structure of a Postman Test Project
PostmanProject/
├── collections/
│   └── MyAPI.postman_collection.json
├── environments/
│   ├── dev.postman_environment.json
│   ├── staging.postman_environment.json
│   └── prod.postman_environment.json
├── scripts/
│   ├── pre-request/
│   │   └── prepareData.js
│   └── tests/
│       └── validateResponse.js
├── globals.json
└── README.md
Test Framework Layers in Postman
  • Collections: Group of API requests organized by feature or endpoint.
  • Environments: Variables for different deployment stages (dev, staging, prod).
  • Pre-request Scripts: JavaScript code that runs before each request to prepare or modify data.
  • Test Scripts: JavaScript code that runs after a request to validate the response.
  • Globals: Variables accessible across collections and environments.
  • Utilities: Shared scripts or helper functions used in pre-request or test scripts.
Configuration Patterns for Pre-request Scripts
  • Environment Variables: Store URLs, tokens, or credentials per environment to switch easily.
  • Global Variables: Use for data shared across collections or requests.
  • Pre-request Script Usage: Prepare dynamic data like timestamps, tokens, or random values before sending requests.
  • Secure Credentials: Store sensitive data in environment variables, not hard-coded in scripts.
  • Data-driven Testing: Use CSV or JSON files imported into Postman to feed data into pre-request scripts.
Test Reporting and CI/CD Integration
  • Newman CLI: Run Postman collections from command line for automation.
  • CI/CD Pipelines: Integrate Newman runs in Jenkins, GitHub Actions, or GitLab pipelines.
  • Report Formats: Generate HTML, JSON, or JUnit reports from Newman for test results.
  • Pre-request Script Role: Ensures data is ready so tests run reliably in automated environments.
Best Practices for Pre-request Scripts in Postman Frameworks
  • Keep Scripts Simple: Only prepare or modify data needed for the request.
  • Use Environment Variables: Avoid hard-coding values; use variables for flexibility.
  • Modularize Code: Put reusable functions in separate scripts or utilities.
  • Secure Sensitive Data: Never expose secrets in scripts; use environment variables with restricted access.
  • Test Script Independence: Pre-request scripts should not depend on previous test results to avoid flaky tests.
Self Check Question

Where would you add a new pre-request script that generates a fresh authentication token before each API call in this Postman framework structure?

Key Result
Pre-request scripts prepare dynamic data before API requests to ensure tests run reliably and flexibly.

Practice

(1/5)
1. Why do pre-request scripts run before sending a request in Postman?
easy
A. To display the test results
B. To check the response status code
C. To prepare or update data needed for the request
D. To log the response time

Solution

  1. Step 1: Understand the role of pre-request scripts

    Pre-request scripts run before the request is sent to prepare or update any data needed for the request.
  2. Step 2: Differentiate from other script types

    Scripts that check response status or display results run after the request, not before.
  3. Final Answer:

    To prepare or update data needed for the request -> Option C
  4. Quick Check:

    Pre-request scripts prepare data = C [OK]
Hint: Pre-request scripts run before requests to set data [OK]
Common Mistakes:
  • Confusing pre-request scripts with test scripts
  • Thinking pre-request scripts check responses
  • Assuming pre-request scripts run after requests
2. Which of the following is the correct way to set a variable named token in a pre-request script?
easy
A. pm.variables.set('token', 'abc123');
B. pm.environment.get('token', 'abc123');
C. pm.variables.get('token', 'abc123');
D. pm.environment.delete('token', 'abc123');

Solution

  1. Step 1: Identify the correct method to set a variable

    In Postman scripts, pm.variables.set or pm.environment.set is used to set variables. Here, pm.variables.set('token', 'abc123'); correctly sets the variable.
  2. Step 2: Understand other methods

    pm.environment.get and pm.variables.get retrieve variables, not set them. pm.environment.delete removes variables.
  3. Final Answer:

    pm.variables.set('token', 'abc123'); -> Option A
  4. Quick Check:

    Set variable uses .set() method = B [OK]
Hint: Use .set() to assign variables in pre-request scripts [OK]
Common Mistakes:
  • Using .get() instead of .set() to assign variables
  • Confusing environment and variables methods
  • Trying to delete variables when setting them
3. What will be the value of the variable timestamp after running this pre-request script?
const now = new Date().getTime();
pm.variables.set('timestamp', now);
medium
A. A number representing milliseconds since Jan 1, 1970
B. An error because pm.variables.set is incorrect
C. Undefined because now is not set
D. A string representing the current date

Solution

  1. Step 1: Understand new Date().getTime()

    This returns the current time in milliseconds since January 1, 1970 (Unix epoch) as a number.
  2. Step 2: Check variable assignment

    The script sets the variable timestamp to this number using pm.variables.set, which is correct syntax.
  3. Final Answer:

    A number representing milliseconds since Jan 1, 1970 -> Option A
  4. Quick Check:

    getTime() returns milliseconds number = D [OK]
Hint: getTime() returns milliseconds number, not string [OK]
Common Mistakes:
  • Thinking getTime() returns a date string
  • Assuming variable is undefined
  • Confusing set() method usage
4. Identify the error in this pre-request script:
pm.environment.set('authToken', getToken());
function getToken() {
  return getToken();
}
medium
A. The function getToken is missing parentheses
B. pm.environment.set is not a valid method
C. Variables cannot be set in pre-request scripts
D. The function getToken causes infinite recursion

Solution

  1. Step 1: Analyze the function call

    The script calls getToken() inside pm.environment.set('authToken', getToken()). The function getToken() returns getToken(), which calls itself again.
  2. Step 2: Identify recursion problem

    This causes infinite recursion because getToken() calls itself directly, leading to a stack overflow.
  3. Final Answer:

    The function getToken causes infinite recursion -> Option D
  4. Quick Check:

    Function calls itself recursively = infinite recursion [OK]
Hint: Avoid recursive functions in pre-request scripts [OK]
Common Mistakes:
  • Thinking pm.environment.set is invalid
  • Missing that getToken calls itself recursively
  • Assuming variables can't be set in pre-request scripts
5. You want to generate a random user ID before each request and store it in an environment variable userId. Which pre-request script correctly achieves this?
hard
A. const id = Math.random() * 1000; pm.environment.get('userId', id);
B. const id = Math.floor(Math.random() * 1000); pm.environment.set('userId', id);
C. pm.environment.set('userId', Math.random());
D. const id = Math.floor(Math.random() * 1000); pm.environment.delete('userId');

Solution

  1. Step 1: Generate a random integer ID

    Math.floor(Math.random() * 1000) generates a random whole number between 0 and 999, suitable for a user ID.
  2. Step 2: Correctly set the environment variable

    pm.environment.set('userId', id); correctly stores the generated ID in the environment variable userId.
  3. Final Answer:

    const id = Math.floor(Math.random() * 1000); pm.environment.set('userId', id); -> Option B
  4. Quick Check:

    Use Math.floor and .set() to store random ID = A [OK]
Hint: Use Math.floor and pm.environment.set to save random IDs [OK]
Common Mistakes:
  • Using .get() instead of .set() to store variables
  • Not rounding random numbers to integers
  • Deleting variables instead of setting them