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

'HarmCategory' object has no attribute 'lower' error when used with google-cloud-aiplatform #3379

Open
michael-erasmus opened this issue Jan 10, 2025 · 1 comment

Comments

@michael-erasmus
Copy link

I'm using google-cloud-aiplatform with weave and running into the error 'HarmCategory' object has no attribute 'lower when specifying safety_settings

Here's a minimal reproducible example:

Install dependencies

$ pip install weave google-cloud-aiplatform

Then create a run.py file like this:

import vertexai
from vertexai.generative_models import GenerativeModel, HarmBlockThreshold, HarmCategory

import weave

@weave.op
def run():
    vertexai.init(project='<PROJECT_NAME>', location='<LOCATION>')
    model = GenerativeModel('gemini-1.5-pro-002')

    generation_config = {
            "temperature": 0.7,
            "max_output_tokens": 100,
    }

    safety_config = {
        HarmCategory.HARM_CATEGORY_UNSPECIFIED: HarmBlockThreshold.BLOCK_NONE,
        HarmCategory.HARM_CATEGORY_DANGEROUS_CONTENT: HarmBlockThreshold.BLOCK_NONE,
        HarmCategory.HARM_CATEGORY_HARASSMENT: HarmBlockThreshold.BLOCK_NONE,
        HarmCategory.HARM_CATEGORY_HATE_SPEECH: HarmBlockThreshold.BLOCK_NONE,
        HarmCategory.HARM_CATEGORY_SEXUALLY_EXPLICIT: HarmBlockThreshold.BLOCK_NONE,
    }

    response = model.generate_content(
        "Hello Gemini!", generation_config=generation_config, safety_settings=safety_config
    )

    print(response.candidates[0].content.parts[0].text)


if __name__ == "__main__":
    weave.init('repro-error')
    run()

Then run

$ python run.py

This results in the error:

Logged in as Weights & Biases user: michael-erasmus.
View Weave data at https://wandb.ai/chesscom/repro-error/weave
Error creating call:
Traceback (most recent call last):
  File "/Users/michaelerasmus/.pyenv/versions/3.10.13/envs/venv-chess.com-weave-repro/lib/python3.10/site-packages/weave/trace/op.py", line 444, in _do_call
    call = _create_call(op, *args, __weave=__weave, **kwargs)
  File "/Users/michaelerasmus/.pyenv/versions/3.10.13/envs/venv-chess.com-weave-repro/lib/python3.10/site-packages/weave/trace/op.py", line 259, in _create_call
    return client.create_call(
  File "/Users/michaelerasmus/.pyenv/versions/3.10.13/envs/venv-chess.com-weave-repro/lib/python3.10/site-packages/weave/trace/trace_sentry.py", line 204, in wrapper
    return func(*args, **kwargs)
  File "/Users/michaelerasmus/.pyenv/versions/3.10.13/envs/venv-chess.com-weave-repro/lib/python3.10/site-packages/weave/trace/weave_client.py", line 766, in create_call
    inputs_redacted = redact_sensitive_keys(inputs)
  File "/Users/michaelerasmus/.pyenv/versions/3.10.13/envs/venv-chess.com-weave-repro/lib/python3.10/site-packages/weave/trace/weave_client.py", line 1654, in redact_sensitive_keys
    dict_res[k] = redact_sensitive_keys(v)
  File "/Users/michaelerasmus/.pyenv/versions/3.10.13/envs/venv-chess.com-weave-repro/lib/python3.10/site-packages/weave/trace/weave_client.py", line 1651, in redact_sensitive_keys
    if should_redact(k):
  File "/Users/michaelerasmus/.pyenv/versions/3.10.13/envs/venv-chess.com-weave-repro/lib/python3.10/site-packages/weave/trace/sanitize.py", line 11, in should_redact
    return key.lower() in REDACT_KEYS
AttributeError: 'HarmCategory' object has no attribute 'lower'
 (subsequent messages of this type will be suppressed)
Hello! How can I help you today?

🍩 https://wandb.ai/chesscom/repro-error/r/call/0194526d-983e-7691-bc38-2850e3d2fc94

It seems like the code assumes that the keys will be strings when they're not.

@jamie-rasmussen
Copy link
Collaborator

Thank you for the detailed report! This is not specific to google-cloud-aiplatform but is actually a problem with any non-string keys in a dictionary as you noted. The essential problem can be reproduced with this:

from weave.trace.weave_client import redact_sensitive_keys
d = {1: 2}
redact_sensitive_keys(d)

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

No branches or pull requests

2 participants