Skip to content

Latest commit

 

History

History
100 lines (73 loc) · 2.92 KB

README.md

File metadata and controls

100 lines (73 loc) · 2.92 KB

Data Generator

Overview

The Data Generator project provides a flexible and customizable way to generate random data for various use cases, such as testing, development, and simulation. The project leverages the DataFaker library to create realistic and diverse datasets. The current implementation includes generators for payment, aviation, StarGate, and StarWars data.

Features

  • Generate realistic data for various domains
  • Easily extendable with new data templates
  • Uses DataFaker for rich and varied data generation
  • Outputs data in JSON format for easy integration

Local Build

  1. Clone the repository:
    git clone https://github.com/skodjob/data-generator.git
  2. Navigate to the project directory:
    cd data-generator
  3. Build the project using Maven:
    mvn clean install

Usage

Include dependency to your maven test project

<dependency>
    <groupId>io.skodjob</groupId>
    <artifactId>data-generator</artifactId>
</dependency>

Generate Payment Data

To generate payment data, use the payment_data template:

import io.skodjob.datagenerator.DataGenerator;
import io.skodjob.datagenerator.enums.ETemplateType;

public class Main {
    public static void main(String[] args) {
        DataGenerator dataGenerator = new DataGenerator(ETemplateType.PAYMENT_FIAT);
        String paymentDataString = dataGenerator.generateData();
        JsonNode paymentDataJson = dataGenerator.generateJsonData();
        System.out.println(paymentDataString);
    }
}

Generate Flight Data

To generate flight data, use the flights template:

import io.skodjob.datagenerator.DataGenerator;
import io.skodjob.datagenerator.enums.ETemplateType;

public class Main {
    public static void main(String[] args) {
        DataGenerator dataGenerator = new DataGenerator(ETemplateType.FLIGHTS);
        String paymentDataString = dataGenerator.generateData();
        JsonNode paymentDataJson = dataGenerator.generateJsonData();
        System.out.println(paymentDataString);
    }
}

To use different templates just change the input parameter for DataGenerator and use it in the same way.

Templates

The project currently includes the following templates:

  • payment_data
  • flights
  • stargate
  • starwars
  • iot_device
  • payroll

Each template corresponds to a specific data domain and generates JSON data that can be used for various testing and development purposes.

Contributing

Contributions are welcome! Please fork the repository and create a pull request with your changes. Ensure that your code follows the existing style and includes tests for new functionality.

License

This project is licensed under the Apache License 2.0. See the LICENSE file for details.

Contact

For any inquiries or issues, please open an issue on the GitHub repository.