mirror of
https://github.com/rendercv/rendercv.git
synced 2026-02-05 19:11:47 -05:00
* Rename `data` folder with schema * Start refactoring data models * Work on entry models * Keep working on entries * Keep working on data models * Push old data files * Keep working on data models * First draft of schema.cv * Keep working on schema * Keep working on schema * Improve schema.models * Keep working on rendercv.schema * Work on schema.design * Keep working on rendercv.schema * Complete variant_class_generator * Keep working rendercv.schema * Keep working on rendercv.schema * Final touches to rendercv.schema * Improve json schema descriptions in rendercv.schema * Start working on rendercv.schema tests * Keep implementing rendercv.schema tests * Add more tests for rendercv.schema * Improve rendercv.schema * Improve docstrings and comments in rendercv.schema * Implement better pydantic error handling in `rendercv.schema` * Improve variant class system * Fix rendercv.schema tests * Start working on rendercv.templater * Update template names * Switching to new rendercv typst template soon * Work on new templater * Rename renderer with renderer_old * Don't use utils in rendercv.schema * Complete connections * Update renderer folder structure * Work on new renderer * Work on new renderer * Date processing on new renderer * Improve date processing, support multiple emails, phones, and websites * Improve markdown to Typst * Complete entry template processing * Time span computation in new renderer * Better entry templates * Setup new templates * Improve rendercv.schema * Start adding tests for rendercv.renderer * New markdown parser! * Improve markdown to typst conversion * Finalize markdown parser * Add new test files for rendercv.renderer * Fix cv and connections * Add connections test * Improve connection tests * Improve entry templates * Add model processor tests * Improve templater * Rename old folders * Improve schema * Add file generation logic to renderer * Fix naming issues * Fix schema tests * Add path type tests * Add font family and typst dimension type tests * Rename old tests * Fix design tests * Start integration testing of renderer * Improve entry tempates * Handle nested highlights properly * Finalize Typst preamble template * Start working on new CLI * Remove old test files * Implement override dictionary in new schema * Start working on new CLI * Better prints on render command * New structure * New render printer * Add all the commands to new CLI * Work on new command in new cli * Improve new command * Add error handler to new cli * Work on create theme command * Complete create theme command * Remove old source files * Improve exceptions * Create new docs * Add writing tests guide * Fix cli printer and write tests * Test copy templates * Add app tests * Bring back accidentally removed files * Imporve cli and tests * Fix path issues * Improve * Improve * Add reference file comparison tests * Fix path resolver * Start working on test_pdf_png * Implement comparison of multiple files (png) * Start testing typst * Fix templating issues * Fix header and entry templates issues * Implement short second rows * Fix date issues * Fix nested bullets and add summary * Update testdata * Implement footer * Update testdata * Reimagined design and locale schema, first iteration * Reimagined design and locale second iteration * Update design and locale schemas * Adapt templater to the new design and locale * Fix tests * Update lib.typ and testdata for the new locale and design * Implement proper tests with all combinations of entries * Remove some docstrings * fix connections logic * Improve * Start working on examples * Update testdata * Fix long second row issue * fix templating issues * Fix lib.typ issues * Update testdata * Fix clean_trailing_parts * Update test cv * update test cv * Update theme defaults * update schema and fix moderncv * Fix moderncv issues * Update testdata * Update testdata and examples * Fix issues about photo * Fix typst photo path issues * improve entry templates from yaml * add new locale * Rename writing tests doc * Update writing tests * Improve tests * Add more cli tests * Increase test coverage * Rename variant pydantic model generator * Improve tests * Update testdata and improve tests * Format, fix pre-commit errors * Fix scripts and update entry figures * Improve tests * Write docstrings of schema * Write schema docstrings * Setup api reference * Start working on new docs * Work on docs * Improve progress panel of render command * Finalize new docs index * Complete CLI docs * Work on YAML input structure page * Finalize user guide * Start working on developer guide * Improve api reference * Improve developer guide * Improve developer guide * Improve developer gide * Improve developer guide * Improve developer guide * Update developer guide * Improve developer guide * Improve developer guide * Improve developer guide * Developer guide first draft * update developer guide * Update examples * Update testdata * Handle wrong installation (rendercv instead of rendercv[full]) * Remove unnecessary files * Write set up vs code page * Update README.md * Change docs description * Compress design options gif * minor updates * Polish all the json schema descriptions * Update testdata and examples * Remove some emdashed from docs * Add whatsapp support * Add TestEscapeTypstCharacters to tests * Implement custom connections * Add page break before sections feature * Revert page break before sections feature * Rebase to main * Fix social network tests, update schema
106 lines
3.7 KiB
Python
106 lines
3.7 KiB
Python
import pydantic
|
|
import pytest
|
|
|
|
# They are called dynamically in the test with `eval(f"{entry_type}(**entry)")`.
|
|
from rendercv.schema.models.cv.entries.bullet import BulletEntry # NOQA: F401
|
|
from rendercv.schema.models.cv.entries.education import EducationEntry # NOQA: F401
|
|
from rendercv.schema.models.cv.entries.experience import ExperienceEntry # NOQA: F401
|
|
from rendercv.schema.models.cv.entries.normal import NormalEntry # NOQA: F401
|
|
from rendercv.schema.models.cv.entries.one_line import OneLineEntry # NOQA: F401
|
|
from rendercv.schema.models.cv.entries.publication import PublicationEntry # NOQA: F401
|
|
from rendercv.schema.models.cv.section import (
|
|
Section,
|
|
available_entry_models,
|
|
dictionary_key_to_proper_section_title,
|
|
get_entry_type_name_and_section_model,
|
|
)
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
("entry", "expected_entry_type", "expected_section_type"),
|
|
[
|
|
(
|
|
"publication_entry",
|
|
"PublicationEntry",
|
|
"SectionWithPublicationEntries",
|
|
),
|
|
(
|
|
"experience_entry",
|
|
"ExperienceEntry",
|
|
"SectionWithExperienceEntries",
|
|
),
|
|
(
|
|
"education_entry",
|
|
"EducationEntry",
|
|
"SectionWithEducationEntries",
|
|
),
|
|
(
|
|
"normal_entry",
|
|
"NormalEntry",
|
|
"SectionWithNormalEntries",
|
|
),
|
|
("one_line_entry", "OneLineEntry", "SectionWithOneLineEntries"),
|
|
("text_entry", "TextEntry", "SectionWithTextEntries"),
|
|
("bullet_entry", "BulletEntry", "SectionWithBulletEntries"),
|
|
],
|
|
)
|
|
def test_get_entry_type_name_and_section_model(
|
|
entry, expected_entry_type, expected_section_type, request: pytest.FixtureRequest
|
|
):
|
|
entry = request.getfixturevalue(entry)
|
|
entry_type, SectionModel = get_entry_type_name_and_section_model(entry)
|
|
assert entry_type == expected_entry_type
|
|
assert SectionModel.__name__ == expected_section_type
|
|
|
|
# Initialize the entry with the entry type to test with model instances too
|
|
if entry_type != "TextEntry":
|
|
entry = eval(f"{entry_type}(**entry)")
|
|
entry_type, SectionModel = get_entry_type_name_and_section_model(entry)
|
|
assert entry_type == expected_entry_type
|
|
assert SectionModel.__name__ == expected_section_type
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"EntryType",
|
|
available_entry_models,
|
|
)
|
|
def test_entries_with_extra_attributes(EntryType, request: pytest.FixtureRequest):
|
|
# Get the name of the class:
|
|
entry_type_name: str = EntryType.__name__
|
|
|
|
# Convert from camel case to snake case
|
|
entry_type_name = "".join(
|
|
["_" + c.lower() if c.isupper() else c for c in entry_type_name]
|
|
).lstrip("_")
|
|
|
|
# Get entry contents from fixture:
|
|
entry_contents = request.getfixturevalue(entry_type_name)
|
|
|
|
entry_contents["extra_attribute"] = "extra value"
|
|
|
|
entry = EntryType(**entry_contents)
|
|
|
|
assert entry.extra_attribute == "extra value"
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
("key", "expected_section_title"),
|
|
[
|
|
("this_is_a_test", "This Is a Test"),
|
|
("welcome_to_rendercv!", "Welcome to Rendercv!"),
|
|
("Welcome to RenderCV!", "Welcome to RenderCV!"),
|
|
("\\faGraduationCap_education", "\\faGraduationCap_education"),
|
|
("\\faGraduationCap Education", "\\faGraduationCap Education"),
|
|
("Hello_World", "Hello_World"),
|
|
("Hello World", "Hello World"),
|
|
],
|
|
)
|
|
def test_dictionary_key_to_proper_section_title(key, expected_section_title):
|
|
assert dictionary_key_to_proper_section_title(key) == expected_section_title
|
|
|
|
|
|
def test_section_rejects_none_entries():
|
|
section_adapter = pydantic.TypeAdapter(Section)
|
|
with pytest.raises(pydantic.ValidationError):
|
|
section_adapter.validate_python([None])
|