Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

test: Add unit test for lifecycle/pkg/utils/yaml/yaml.go #5473

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

gru-agent[bot]
Copy link

@gru-agent gru-agent bot commented Mar 14, 2025

Trigger Info

Trigger Type Triggered By Source File Assignment
Auto Trigger TestGru lifecycle/pkg/utils/strings/strings.go Detail

Summary

This PR introduces comprehensive unit tests for the yaml utility package, ensuring robust validation and functionality across various scenarios. The tests cover the following methods:

  • unmarshalStrict: Validates strict unmarshalling of YAML data into structs, including edge cases like empty input and invalid object types.

  • UnmarshalToMap: Tests conversion of YAML data into a map, handling valid, invalid, and empty inputs.

  • ToJSON: Ensures YAML data is correctly converted into JSON, including support for multiple documents and invalid inputs.

  • Marshal: Verifies YAML serialization of objects, including handling of nil inputs.

  • MarshalFile: Tests writing serialized YAML data to files, ensuring file content matches the input object.

  • Unmarshal: Validates unmarshalling of YAML data into objects, including error handling for invalid inputs.

  • IsNil: Checks if YAML data represents an empty map or structure, with error handling for invalid YAML.

  • UnmarshalFile: Ensures YAML data is correctly read from files and unmarshalled into objects.

  • MarshalConfigs: Tests serialization of multiple YAML configurations, ensuring correct handling of multiple documents.

These tests utilize testify/assert for assertions and cover edge cases to ensure reliability and correctness of the YAML utility functions.

Coverage

The change in coverage value, such as: 0% -> 50%, indicates that the coverage was 0% before writing the tests and 50% after writing them.

https://web.dev/articles/ta-code-coverage

Type Change
lines 0% -> 0%
statements 0% -> 0%
functions 0% -> 0%
branches 0% -> 0%

Test Statuses

Status Change
$schema http://json-schema.org/draft-07/schema#
passed 0 -> 20 🔺
failed 0 -> 0
skipped 0 -> 0
error 1 -> 0 🔻
source ai

Tip

You can @gru-agent and leave your feedback. TestGru will make adjustments based on your input

Tip

You can @gru-agent rebase to rebase the PR.

Tip

You can @gru-agent redo to reset or rebase before redoing the PR.

Tip

To modify the test code yourself, click here Edit Test Code

@sealos-ci-robot
Copy link
Member

🤖 Generated by lychee action

Summary

Status Count
🔍 Total 2070
✅ Successful 451
⏳ Timeouts 0
🔀 Redirected 0
👻 Excluded 1617
❓ Unknown 0
🚫 Errors 0

Full action output

Full Github Actions output

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant