Files
python/exercises/practice/etl/etl_test.py
BethanyG e7a6b0dc7d [JinJa2] Corrected the macro used for comments on the test file. (#3373)
* Corrected the macro for comments on the test file.
* Added current_date (utcnow()) variable available for template macros.
* Removed unnecessary datetime import from macros file.
* Regenerated all practice exercise test files to add timestamp.
* Changed `datetime.now(tz=timezone.utc)` to `datetime.now(tz=timezone.utc).date()`
* Second regeneration to remove `timestamp` and just keep `date` for test files.
[no important files changed]
2023-07-14 15:52:15 -07:00

67 lines
1.8 KiB
Python

import unittest
from etl import (
transform,
)
# These tests are auto-generated with test data from:
# https://github.com/exercism/problem-specifications/tree/main/exercises/etl/canonical-data.json
# File last updated on 2023-07-14
class EtlTest(unittest.TestCase):
def test_single_letter(self):
legacy_data = {1: ["A"]}
data = {"a": 1}
self.assertEqual(transform(legacy_data), data)
def test_single_score_with_multiple_letters(self):
legacy_data = {1: ["A", "E", "I", "O", "U"]}
data = {"a": 1, "e": 1, "i": 1, "o": 1, "u": 1}
self.assertEqual(transform(legacy_data), data)
def test_multiple_scores_with_multiple_letters(self):
legacy_data = {1: ["A", "E"], 2: ["D", "G"]}
data = {"a": 1, "d": 2, "e": 1, "g": 2}
self.assertEqual(transform(legacy_data), data)
def test_multiple_scores_with_differing_numbers_of_letters(self):
legacy_data = {
1: ["A", "E", "I", "O", "U", "L", "N", "R", "S", "T"],
2: ["D", "G"],
3: ["B", "C", "M", "P"],
4: ["F", "H", "V", "W", "Y"],
5: ["K"],
8: ["J", "X"],
10: ["Q", "Z"],
}
data = {
"a": 1,
"b": 3,
"c": 3,
"d": 2,
"e": 1,
"f": 4,
"g": 2,
"h": 4,
"i": 1,
"j": 8,
"k": 5,
"l": 1,
"m": 3,
"n": 1,
"o": 1,
"p": 3,
"q": 10,
"r": 1,
"s": 1,
"t": 1,
"u": 1,
"v": 4,
"w": 4,
"x": 8,
"y": 4,
"z": 10,
}
self.assertEqual(transform(legacy_data), data)