-
Notifications
You must be signed in to change notification settings - Fork 19
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* feat: support count tokens * fix: lint * test: add count tokens test
- Loading branch information
1 parent
c96c8c6
commit 7326edf
Showing
5 changed files
with
160 additions
and
6 deletions.
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
package anthropic | ||
|
||
import ( | ||
"context" | ||
"net/http" | ||
) | ||
|
||
type CountTokensResponse struct { | ||
httpHeader | ||
|
||
InputTokens int `json:"input_tokens"` | ||
} | ||
|
||
func (c *Client) CountTokens( | ||
ctx context.Context, | ||
request MessagesRequest, | ||
) (response CountTokensResponse, err error) { | ||
var setters []requestSetter | ||
if len(c.config.BetaVersion) > 0 { | ||
setters = append(setters, withBetaVersion(c.config.BetaVersion...)) | ||
} | ||
|
||
urlSuffix := "/messages/count_tokens" | ||
req, err := c.newRequest(ctx, http.MethodPost, urlSuffix, request, setters...) | ||
if err != nil { | ||
return | ||
} | ||
|
||
err = c.sendRequest(req, &response) | ||
return | ||
} |
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,88 @@ | ||
package anthropic_test | ||
|
||
import ( | ||
"context" | ||
"encoding/json" | ||
"net/http" | ||
"strings" | ||
"testing" | ||
|
||
"github.com/liushuangls/go-anthropic/v2" | ||
"github.com/liushuangls/go-anthropic/v2/internal/test" | ||
) | ||
|
||
func TestCountTokens(t *testing.T) { | ||
server := test.NewTestServer() | ||
server.RegisterHandler("/v1/messages/count_tokens", handleCountTokens) | ||
|
||
ts := server.AnthropicTestServer() | ||
ts.Start() | ||
defer ts.Close() | ||
|
||
baseUrl := ts.URL + "/v1" | ||
client := anthropic.NewClient( | ||
test.GetTestToken(), | ||
anthropic.WithBaseURL(baseUrl), | ||
anthropic.WithBetaVersion(anthropic.BetaTokenCounting20241101), | ||
) | ||
|
||
request := anthropic.MessagesRequest{ | ||
Model: anthropic.ModelClaude3Dot5HaikuLatest, | ||
MultiSystem: anthropic.NewMultiSystemMessages("you are an assistant", "you are snarky"), | ||
Messages: []anthropic.Message{ | ||
anthropic.NewUserTextMessage("What is your name?"), | ||
anthropic.NewAssistantTextMessage("My name is Claude."), | ||
anthropic.NewUserTextMessage("What is your favorite color?"), | ||
}, | ||
} | ||
|
||
t.Run("count tokens success", func(t *testing.T) { | ||
resp, err := client.CountTokens(context.Background(), request) | ||
if err != nil { | ||
t.Fatalf("CountTokens error: %v", err) | ||
} | ||
|
||
t.Logf("CountTokens resp: %+v", resp) | ||
}) | ||
|
||
t.Run("count tokens failure", func(t *testing.T) { | ||
request.MaxTokens = 10 | ||
_, err := client.CountTokens(context.Background(), request) | ||
if err == nil { | ||
t.Fatalf("CountTokens expected error, got nil") | ||
} | ||
|
||
t.Logf("CountTokens error: %v", err) | ||
}) | ||
} | ||
|
||
func handleCountTokens(w http.ResponseWriter, r *http.Request) { | ||
var err error | ||
var resBytes []byte | ||
|
||
if r.Method != "POST" { | ||
http.Error(w, "Method not allowed", http.StatusMethodNotAllowed) | ||
} | ||
|
||
var req anthropic.MessagesRequest | ||
if req, err = getRequest[anthropic.MessagesRequest](r); err != nil { | ||
http.Error(w, "could not read request", http.StatusInternalServerError) | ||
return | ||
} | ||
if req.MaxTokens > 0 { | ||
http.Error(w, "max_tokens: Extra inputs are not permitted", http.StatusBadRequest) | ||
return | ||
} | ||
|
||
betaHeaders := r.Header.Get("Anthropic-Beta") | ||
if !strings.Contains(betaHeaders, string(anthropic.BetaTokenCounting20241101)) { | ||
http.Error(w, "missing beta version header", http.StatusBadRequest) | ||
return | ||
} | ||
|
||
res := anthropic.CountTokensResponse{ | ||
InputTokens: 100, | ||
} | ||
resBytes, _ = json.Marshal(res) | ||
_, _ = w.Write(resBytes) | ||
} |
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,35 @@ | ||
package integrationtest | ||
|
||
import ( | ||
"context" | ||
"testing" | ||
|
||
"github.com/liushuangls/go-anthropic/v2" | ||
) | ||
|
||
func TestCountTokens(t *testing.T) { | ||
testAPIKey(t) | ||
client := anthropic.NewClient( | ||
APIKey, | ||
anthropic.WithBetaVersion(anthropic.BetaTokenCounting20241101), | ||
) | ||
ctx := context.Background() | ||
|
||
request := anthropic.MessagesRequest{ | ||
Model: anthropic.ModelClaude3Dot5HaikuLatest, | ||
MultiSystem: anthropic.NewMultiSystemMessages("you are an assistant", "you are snarky"), | ||
Messages: []anthropic.Message{ | ||
anthropic.NewUserTextMessage("What is your name?"), | ||
anthropic.NewAssistantTextMessage("My name is Claude."), | ||
anthropic.NewUserTextMessage("What is your favorite color?"), | ||
}, | ||
} | ||
|
||
t.Run("CountTokens on real API", func(t *testing.T) { | ||
resp, err := client.CountTokens(ctx, request) | ||
if err != nil { | ||
t.Fatalf("CountTokens error: %s", err) | ||
} | ||
t.Logf("CountTokens resp: %+v", resp) | ||
}) | ||
} |
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