Skip to content

cieslarmichal/faker-cxx

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

C++ Faker, a powerful tool for generating realistic and randomized fake data in C++ programming, enhancing data testing and development workflows

Faker C++

clang++ apple clang++ g++ msvc bazel codecov Conan Center PRs Welcome Chat on Discord

Table of Contents

Introduction

Faker C++ is a C++ library inspired by the popular Faker.js, aimed at providing developers with a robust tool for generating fake (but realistic) data. Whether you're building test suites, populating databases, or creating demos, Faker C++ has got you covered.

Key Features

๐Ÿ“š Realistic Data Generation: Generate various types of data including names, addresses, emails, dates, and more.

๐Ÿ›  Modular Design: Choose from a wide range of modules like Internet, Location, String, Date, and more to generate specific types of data.

๐Ÿš€ Easy Integration: Seamlessly integrate with CMake, and it supports major compilers like MSVC, GCC, Clang, and Apple Clang.

๐Ÿ“– Usage and Documentation

To properly use Faker C++ you must first consume the Faker library (see Consuming Library with CMake). Once that is done, you need to include the proper header file depending on the module you wish to generate data from or use general include file faker-cxx/faker.h. All the docs can be found here.

Below is an example of how to use Faker C++ in your code.

#include <iostream>

#include "faker-cxx/faker.h" // or include specific module

int main()
{
    const auto id = faker::string::uuidV4();
    const auto email = faker::internet::email();
    const auto password = faker::internet::password();
    const auto city = faker::location::city();
    const auto streetAddress = faker::location::streetAddress();
    const auto bornDate = faker::date::birthdateByYear(1970, 2000);

    std::cout << id << std::endl; // 59990db5-3a5f-40bf-8af0-7834c29ee884
    std::cout << email << std::endl; // [email protected]
    std::cout << password << std::endl; // Mf+*[(_'lHfM.$v{
    std::cout << city << std::endl; // Rochester
    std::cout << streetAddress << std::endl; // 643 Ricardo Creek
    std::cout << bornDate << std::endl; // 1973-12-03T11:07:02Z

    return 0;
}

๐Ÿ’Ž Modules

  • ๐Ÿ›ฉ Airline - aircraft type, airline, airport, flight number
  • ๐Ÿผ Animal - animal type and species
  • ๐Ÿ“– Book - title, genre, author, publisher, format, series
  • ๐ŸŽจ Color - name, rgb, hex, hcl, lch, cmyk, lab, hsb, hsv, hwb, yuw
  • ๐Ÿ›’ Commerce - department, product name, SKU, EAN, ISBN, price, product description, categories
  • ๐Ÿข Company - name, type, industry, catchphrase, buzz phrase
  • ๐Ÿ–ฅ๏ธ Computer - type, manufacturer, model, CPU info, GPU info
  • ๐Ÿ” Crypto - SHA1, SHA256, MD5
  • ๐Ÿ’พ Database - column names, column types, database engines
  • โ„น๏ธ Datatype - booleans
  • ๐Ÿ“… Date - past, future, recent, soon date, birthdate, time, month, day of week
  • ๐Ÿ•น๏ธ E-sport - player, team, league, event, game
  • ๐Ÿฆ Finance - currency, IBAN, BIC, account name, account number, pin, credit card numbers
  • ๐Ÿ Food - food category, vegetables, fruits, meats, dishes
  • ๐Ÿ“ Git - branch name, commit messages, commit hash
  • ๐Ÿ‘จโ€๐Ÿ’ป Hacker - hacker words
  • โœ‹ Helper - random element, weighted random element
  • ๐Ÿ–ผ๏ธ Image - images url, avatar url, image dimensions, type, lorem image, flickr image
  • ๐ŸŒ Internet - email, username, password, emoji, protocol, IP, HTTP, url, domain, mac address, jwt
  • ๐ŸŒ Location - country, continent, city, zip code, state, street address, latitude, longitude, timezone
  • ๐Ÿ“š Lorem - words, sentences, paragraphs
  • ๐Ÿฅ Medicine - condition, medical test, specialty
  • ๐ŸŽฅ Movie - title, genre, actor, actress, director, tv show
  • ๐ŸŽถ Music - artist, song names, genre
  • ๐Ÿ”ข Number - integer, decimal, hex, octal, binary
  • ๐Ÿง‘ Person - first, last name, job title, nationality, language, passport, ssn, hobby, gender, sex, bio
  • ๐Ÿ“ž Phone - phone number, area code, IMEI, model, manufacturer
  • ๐Ÿชด Plant - plant type, tree, flower
  • ๐Ÿง‘โ€๐Ÿ”ฌ Science - chemical element, units
  • โšฝ Sport - sport name, soccer team, athletes, event
  • ๐Ÿ”ข String - UUID (V1, V3, V4, V5, V6, V7), ULID, nanoid, alpha, alphanumeric, numeric, sample
  • ๐Ÿ’ป System - file name, file type, file path, file extension, directory, semantic version, mime type
  • ๐Ÿš— Vehicle - type, model, fuel type, VIN, VRN, manufacturer, color
  • ๐ŸŽž๏ธ Video - format name, file extension, video codec, audio codec, resolution, aspect ratio, video url
  • ๐ŸŽฎ Video game - title, genre, platform, studio
  • ๐ŸŒค๏ธ Weather - weather description
  • ๐Ÿ’ฌ Word - sample, adjective, adverb, conjunction, interjection, noun, preposition, verb

Consuming the library with CMake

With Git submodules and add_library

  1. Add faker to git submodules (execute in project root):

    mkdir externals && cd externals
    git submodule add https://github.com/cieslarmichal/faker-cxx.git
    git submodule update --init --recursive
    
  2. Link with library:

    set(BUILD_TESTING OFF)
    
    add_subdirectory(externals/faker-cxx)
    
    add_executable(main Main.cpp)
    
    target_link_libraries(main faker-cxx)

With FetchContent

set(BUILD_TESTING OFF)

FetchContent_Declare(faker
    GIT_REPOSITORY https://github.com/cieslarmichal/faker-cxx.git
    GIT_TAG main
)

FetchContent_MakeAvailable(faker)

add_executable(main Main.cpp)

target_link_libraries(main faker-cxx)

โš’๏ธ Compiler support

Dependencies

  • GTest (set BUILD_TESTING=OFF CMake flag to disable this dependency)

In order to use external dependencies installed in your system, you can set the USE_SYSTEM_DEPENDENCIES CMake flag to ON.

๐Ÿ“ฆ Building the library with Conan

The library can be built using Conan package manager to solve external dependencies. To build the library with Conan, follow the steps below:

  1. Install required dependencies:

    conan install conanfile.txt --build=missing
  2. Build the library:

    cmake --preset=conan-release -DUSE_SYSTEM_DEPENDENCIES:BOOL=ON
    cmake --build --preset=conan-release

Installing the library with Conan

You can install pre-built binaries for faker-cxx or build it from source using Conan. Use the following command:

conan install --requires="faker-cxx/[*]" --build=missing

The faker-cxx Conan recipe is kept up to date by Conan maintainers and community contributors. If the version is out of date, please create an issue or pull request on the ConanCenterIndex repository.

Building the library with Bazel

As alternative, this project can be built using Bazel. The dependencies are managed directly by Bazel modules, downloading and building all external dependencies. Follow the steps below to build the project:

  1. Navigate to the project directory:

    cd /path/to/faker-cxx
  2. Build the project:

    bazel build //:faker-cxx

โœจ Contributing

We would love it if you contributed to Faker C++! ๐Ÿš€

Check our guides on how to build the project locally:

Please make sure to read the Contributing Guide before making a pull request.

Additionally, we encourage you to join our Discord Channel for contributors.

๐Ÿ“˜ Credits

Thanks to all the people who already contributed to Faker!

๐Ÿ“ Changelog

Detailed changes for each release are documented in the release notes.

๐Ÿ”‘ License

This project is under MIT license.