Skip to content

Latest commit

 

History

History
106 lines (89 loc) · 4.59 KB

README.md

File metadata and controls

106 lines (89 loc) · 4.59 KB

Roblox Test Files

The testfiles repository contains a database of files for testing implementations of various Roblox file formats.

Philosophy

  • Specification: How a thing is supposed to behave.
  • Implementation: How the thing actually behaves.
  • Ideally, the implementation matches the specification.
  • In reality, this never quite happens.
  • It is hard to have a correct implementation without a specification.
  • It is harder to have a correct implementation if it is the specification!
  • Comparing an implementation to a specification is often difficult, if not impossible.

Enter: golden files

Key points:

  • A program uses an implementation to write a golden file, which serves as a snapshot representing the specification.
  • The golden file should be extremely readable, as it will be reviewed manually to determine its correctness.
  • When the implementation is modified, it is compared against the current golden file to check for regressions.
  • If the specification needs to change, the golden file can be rewritten by the program with the current implementation.
  • Diffing can be used to inspect the correctness of the golden file after it has been updated.

In general, the content of a golden file should be line-based to interact better with the diffing of version control systems. One unit of information per line. Other than that, the content is fairly free-form; it should focus on being parsable by human eyeballs.

JSON is used as the format for golden files. The specification provides a detailed explanation.

Structure

Spec directory

Descriptions for known file formats are contained within the spec directory. Also contained are descriptions of golden file formats.

Data directory

All test files are contained within the data directory. Files within this directory are structured according the following rules:

  • A directory is used only for organization, and is meant to be visited recursively.
  • A hidden file is any file that starts with a .. These are ignored.
  • A golden file is any file with the .golden extension.
  • A config file is any file with the .golden-config extension.
  • An input file is any other file.

Sibling files form a group when their names match. The part of the name used to match depends on the type:

  • An input file uses its full name.
  • A golden file uses its name without the .golden extension.
  • A config file uses its name without the .golden-config extension.

For example, the following files would be grouped together:

  • Baseplate.rbxl
  • Baseplate.rbxl.golden
  • Baseplate.rbxl.golden-config

Source directory

The src directory contains the sources for commands that produce golden files for various implementations of supported formats.

Tools directory

The tools directory contains tools that aid in the production of test files.

Testing

To test an implementation against the database, a program must be written. The program should satisfy the following properties:

  • The program should receive a directory, and iterate through the files within it:
    • Directories are iterated recursively.
    • Files starting with . are ignored.
    • Files with the .golden extension are golden files.
    • Files with the .golden-config extension are config files.
    • All other files are input files.
  • The program groups files according to the rules described above.
  • An input file with an unknown extension can be ignored.
  • If the group has a config file, it configures how the input is parsed. Otherwise, sensible defaults can be used.
  • For each valid input file, the program must produce a JSON structure that is semantically equal to the content of the corresponding golden file, in order for the implementation to be considered correct.
  • If there is no corresponding golden file, then the content must be considered empty.
  • If the JSON structure does not match, the program should output a human-readable difference between the produced structure and the content.
  • If some sort of "update" flag is explicitly provided to the program, then the produced structure should be written to the golden file. The program should output the difference.
  • If producing a difference is infeasible, then the program may simply write the golden file with the expectation that diffing will be handled by a version control system.

Licensing

Files within the testfiles repository, including input files, golden files, and documents, unless noted otherwise, are licensed to the testfiles contributors under the CC-BY-SA-4.0 license.