Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/creditdatamw/zefaker
zefaker is a command-line tool for generating CSV, Excel, JSON and SQL files from a Groovy DSL
https://github.com/creditdatamw/zefaker
csv dsl excel generate-data groovy json testing
Last synced: 3 months ago
JSON representation
zefaker is a command-line tool for generating CSV, Excel, JSON and SQL files from a Groovy DSL
- Host: GitHub
- URL: https://github.com/creditdatamw/zefaker
- Owner: creditdatamw
- License: apache-2.0
- Created: 2020-02-28T20:19:26.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2023-05-25T19:35:42.000Z (over 1 year ago)
- Last Synced: 2023-05-25T22:00:36.526Z (over 1 year ago)
- Topics: csv, dsl, excel, generate-data, groovy, json, testing
- Language: JavaScript
- Homepage:
- Size: 547 KB
- Stars: 28
- Watchers: 3
- Forks: 1
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Zé Faker
========`zefaker` is a command-line tool that helps developers generate and export data into CSV, Excel and SQL files for testing their applications.
## Features
* Random data generation via [java-faker](https://github.com/DiUS/java-faker) with Locale support
* Export to CSV
* Export to Excel Sheet
* Export to SQL INSERTS
* Export to SQL COPY (for PostgreSQL)
* Export to JSON
* Export to JSON Lines## Why would I use this?
Short answer **to generate (test) data**.
If you ever need to have a CSV, Excel file with (random*) data or need to
populate a database with development/dummy data you can use `zefaker` to
generate the data, leveraging the power of [Groovy](https://www.groovy-lang.org)We created it because we deal with a lot of Excel files (with lots of columns!) and SQL data and often have to generate files to test the code that processes those files or data.
_* the generated data does not have to be random_
## Example Usage
> NOTE: Checkout the [examples](./examples/) for even more examples, and "advanced" usage
Let's go straight to an example:
Create a file named `person.groovy` and place the following content:
```groovy
// person.groovylocale("en-GB") // tells Java Faker to use the given tag for the Locale.
// You can also use a custom faker
// import net.datafaker.Faker
// useFaker(new Faker(Locale.getLanguageTag("en-GB")))generateData([
"FirstName": { faker -> faker.name().firstName() },
"LastName": { faker -> faker.name().lastName() },
"Age": { faker -> faker.number().numberBetween(18, 70) },
"AccountStatus": { faker -> faker.options().option("Open", "Closed") },
"Plan": { faker -> "FREE" } // doesn't necessarily have to be a faker value
])
```Once you have this, you can pass it to the `zefaker` command to generate a file:
### Exporting as a CSV File
```sh
$ zefaker -f person.groovy -rows 1000 -output people.csv -csv
```The example command, above, generates a file named **people.csv** with **1000 rows**
populated with data generated using the Faker functions specified in the Groovy script.### Exporting as an Excel file
```sh
$ zefaker -f person.groovy -rows 1000 -output people.xlsx -sheet People
```The example command, above, generates a file named **people.xlsx** with **1000 records**.
> _Bonus / Shameless plug_: If you're using Java, you can process the generated files _quickly_ and
_efficiently_ using [zerocell](https://github.com/creditdatamw/zerocell).### Exporting as an SQL file
```sh
$ zefaker -f person.groovy -rows 1000 -output people.sql -sql -table people
```The example command, above, generates a file named **people.sql** with
**1000 INSERT statements** which have random data in the _VALUES_ clause.### Exporting as a JSON file
```sh
$ zefaker -f person.groovy -rows 1000 -output people.json -json
```The example command, above, generates a file named **people.json** with **1000 JSON objects**.
## Installation
Download a copy of `zefaker` from the [Releases](https://github.com/creditdatamw/zefaker/releases) page.
> NOTE: Requires at least Java 8 to be installed
## Usage
The build archive contains start scripts, `zefaker` and `zefaker.bat` for UN*X and Windows environments, respectively.
### Command Line
```sh
Usage: zefaker [options]
-f=FILE Groovy file with column definitions
-rows=ROWS Number of rows to generate
-output=FILE File to write to, e.g. generated.xlsx
-sheet=NAME Sheet name in the generated Excel file
-table=NAME The name of the table to use in SQL INSERT mode
-sql Use SQL INSERT export mode
-vvv Show verbose output
-x Overwrite existing file
```### Web based UI
You can run the following `java -jar zefaker.jar -web` to start a webserver at port `4567`:
![[]](zefakerweb.png)
### In the Groovy Script
Within your Groovy script you are required to use the *generateFrom()*
function to generate the Excel file.#### Methods
The following are the only methods that are required in the groovy script for
Zefaker to run.**ColumnDef column(int index, String name)**
This method defines a new Column that has a name and an index (position)
**void generateFrom(ColumnDef[] columns)**
This method actually initiates the generation of the Excel file. If you don't
call this method you won't actually get any result.Example: `generateFrom([ (firstName) : { faker -> faker.name().firstName() } ])`
#### Properties
Inside the Groovy script you can set some variables or properties that affect the
output of zefaker. These variables, consequently, take precedence over arguments
specified on the command-line.The following special variables are available, and are therefore *reserved names*:
* **sheetName** - Change the name of the target Sheet in Excel. Overrides `-sheet`
* **tableName** - Change the name of the target table in SQL INSERTS. Overrides `-table`
* **outputFile** - The name/path of the file to write output to. Overrides `-f`
* **verbose** - Show verbose output. Overrides `-vvv`
* **maxRows** - Sets the maximum number of rows to generate in the file. Overrides `-rows`
* **overwriteExisting** - Whether to overrite an existing file with the new Workbook. Overrides `-x`## Building
We are using `Gradle` for this, so follow the instructions below to build it.
```sh
$ git clone https://github.com/creditdatamw/zefaker.git
$ cd zefaker
$ gradlew clean build
```After this, the build file will be in `build/libs/zefaker-all.jar` - it is an executable Jar file.
## Using Docker
You will have to build the image locally at the moment, :). Then run:
```sh
$ docker run --volume "$(pwd):/tmp:rw" zefaker -f /tmp/example.groovy -output /tmp/first.sql -sql
```## CONTRIBUTING
Help out by resolving an issue in the [issue tracker](https://github.com/creditdatamw/zefaker/issues).
Pull Requests are welcome. If you run into a problem, create an issue and we will try to resolve it.---
Copyright (c) 2022, Credit Data CRB Ltd