-
Notifications
You must be signed in to change notification settings - Fork 16k
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
core: update load chat prompt template multi mesages #27584
core: update load chat prompt template multi mesages #27584
Conversation
The latest updates on your projects. Learn more about Vercel for Git ↗︎ 1 Skipped Deployment
|
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.
could we add a unit test for the change
…hat_prompt_template' into snova-jorgep/load_chat_prompt_template
@baskaryan tests and examples for loading added |
@baskaryan please take a look when you have the time |
Closing as I believe this functionality exists: from langchain_core.prompts import ChatPromptTemplate
from langchain_core.load import dumpd
from langchain_core.load.load import load
import json
prompt = ChatPromptTemplate(
[
("system", "system message is {system_message}"),
("user", "user message is {user_message}"),
]
)
with open("foo.json", "w") as f:
json.dump(dumpd(prompt), f)
with open("foo.json", "r") as f:
reloaded = load(json.load(f)) See guide here: https://python.langchain.com/docs/how_to/serialization/ Let me know if this does not cover your use case. Thank you! |
@ccurme I think this not covers loading a full conversation (multiple turns with roles in a template), The current implementation loads only one message into the chat template |
I may not be understanding the issue. In the example above, This appears to replicate and pass the test you added: from langchain_core.prompts import ChatPromptTemplate
from langchain_core.load import dumpd
from langchain_core.load.load import load
import json
prompt = ChatPromptTemplate(
[
("system", "You are a comedian"),
("user", "Tell me a {adjective} joke about {content}."),
]
).partial(content="dogs")
with open("foo.json", "w") as f:
json.dump(dumpd(prompt), f)
with open("foo.json", "r") as f:
reloaded = load(json.load(f))
expected_prompt = ChatPromptTemplate(
input_variables=["adjective"],
partial_variables={"content": "dogs"},
messages=[
("system", "You are a comedian"),
("human", "Tell me a {adjective} joke about {content}."),
],
)
assert reloaded == expected_prompt Would you mind sharing a failing test that uses the |
Hi @ccurme this is the case in which you load the prompt template using the load_prompt method from langchain_core.prompts.loading in cases where the user has not necessarily initially created ChatPromptTemplate object, but only defined it in the default structure as here libs/core/tests/unit_tests/examples/simple_chat_prompt.json extending this https://github.com/jhpiedrahitao/langchain/blob/76040e51336e3e83af446019fa36bea7dba65b5e/libs/core/tests/unit_tests/prompts/test_loading.py#L12 |
with multiple messages (loles) when using file loading (load from config)