-
Notifications
You must be signed in to change notification settings - Fork 789
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
Record logs into step artifacts #1339
Merged
Merged
Changes from 6 commits
Commits
Show all changes
46 commits
Select commit
Hold shift + click to select a range
79e5763
Record log entries into context
satansdeer c3cbf4b
Add log field to context
satansdeer f3debf5
Add SKYVERN_LOG artifact type
satansdeer c1e7ff6
Add skyvern log tab on the frontend
satansdeer b1f14c6
Add SkyvernLogEncoder to handle non-serializable objects
satansdeer b2cb9c4
Record logs to an artifact
satansdeer eb6fc3d
Record only logs corresponding to a step
satansdeer 57cd772
Recover empty line
satansdeer 419e12b
Add text log encoder
satansdeer ddbc340
re-enable upload block (#1324)
wintonzheng f313326
remove no latest screenshot error log (#1325)
LawyZheng 9b35651
Put a guard in workflow save error detail (#1326)
wintonzheng 2d90fed
urlencode download suffix (#1327)
LawyZheng be0e817
wait for downloads to be done (#1328)
LawyZheng 5ee8c3b
Skyvern Forms UI (#1330)
wintonzheng f8a6b58
Fix a navigation bug with saved tasks (#1331)
wintonzheng 8bf863c
workflow run block (#1332)
wintonzheng 5d32d53
forloop metadata variables (#1334)
LawyZheng 3c37a4a
auto prepend scheme to url (#1335)
LawyZheng 1aa1146
rename GEMINI_FLUSH->GEMINI_FLASH (#1333)
nmfisher f3bb2fe
bump navigation max retry to 5 (#1336)
LawyZheng 6606fba
add workflow_run_id column to artifacts + ObserverCruise and Observer…
wintonzheng aabc0fc
add observer cruise id to artifacts table (#1337)
wintonzheng b83c648
ObserverThought reproduce migration script (#1338)
wintonzheng 40e9dd3
Import structlog
satansdeer 5c8488d
Define build_log_uri method
satansdeer 127b8a6
Merge main
satansdeer 4742fc4
Extract save logs functions
satansdeer 974b37e
Pass step_id to log artifact methods
satansdeer d48f792
Define get_artifact_by_entity_id
satansdeer f57c7b6
Reuse log artifacts when saving
satansdeer c8274c3
Introduce get artifacts by entity id handler
satansdeer 3ff49cb
Get step artifacts using entity id handler
satansdeer c3ce7d3
Remove logs
satansdeer 72b3f15
Record workflow run logs
satansdeer aac781f
Save task logs
satansdeer ff86b52
Merge branch 'main' into maksimi/record-logs
satansdeer a86d81d
Remove print
satansdeer 0f0633f
Merge main
satansdeer 727dd7e
Revert change to InvalidUrl type
satansdeer 2312281
Add complete_action.action_order back
satansdeer d66e67b
Add with_skyvern_context decorator
satansdeer 2cf5f69
Merge branch 'main' into shu/maksimi/record-logs-new
wintonzheng 63829fa
address typing
wintonzheng 9eda7ca
Add ENABLE_LOG_ARTIFACTS env variable; Disable log artifacts by default
satansdeer 631f898
Pre-commit check
satansdeer File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
import json | ||
from typing import Any | ||
|
||
class SkyvernLogEncoder(json.JSONEncoder): | ||
"""Custom JSON encoder for Skyvern logs that handles non-serializable objects""" | ||
def default(self, obj: Any) -> Any: | ||
if hasattr(obj, 'model_dump'): | ||
return obj.model_dump() | ||
|
||
if hasattr(obj, '__dataclass_fields__'): | ||
return {k: getattr(obj, k) for k in obj.__dataclass_fields__} | ||
|
||
if hasattr(obj, '__dict__'): | ||
return { | ||
'type': obj.__class__.__name__, | ||
'attributes': {k: v for k, v in obj.__dict__.items() if not k.startswith('_')} | ||
} | ||
# Handle other non-serializable objects | ||
try: | ||
return str(obj) | ||
except Exception: | ||
return f"<non-serializable-{obj.__class__.__name__}>" |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there a way we can also capture task and workflow level logs? Even if we don't render them in the UI today
We historically associate logs like that w/ the first step, although @wintonzheng is currently overhauling it
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yeah we just added new columns to the artifacts db: https://github.com/Skyvern-AI/skyvern/blob/main/skyvern/forge/sdk/db/models.py#L169-L174
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
https://github.com/Skyvern-AI/skyvern/pull/1345/files
here's the example of supporting artifact upload for observer thought.
going forward we can add support for task level and workflow run level artifacts