Skip to content

Commit

Permalink
changes from review
Browse files Browse the repository at this point in the history
- Fix lints
- Add changelog
- Document unsafe binding with example
- Change some asserts to requires in tests
  • Loading branch information
aaronlisman committed Jul 18, 2023
1 parent 0de7841 commit d1c8036
Show file tree
Hide file tree
Showing 4 changed files with 63 additions and 3 deletions.
15 changes: 15 additions & 0 deletions .changelog/1330.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
```release-note:enhancement
workers: Add support for uploading scripts to a Workers for Platforms namespace.
```

```release-note:enhancement
workers: Add support for declaring arbitrary bindings with UnsafeBinding.
```

```release-note:enhancement
workers: Add support for uploading workers with Workers for Platforms namespace bindings.
```

```release-note:enhancement
workers: Add `pipeline_hash` field to Workers script response struct.
```
2 changes: 1 addition & 1 deletion workers_bindings.go
Original file line number Diff line number Diff line change
Expand Up @@ -407,7 +407,7 @@ func (b DispatchNamespaceBinding) serialize(bindingName string) (workerBindingMe
return meta, nil, nil
}

// UnsafeBinding is for experimental or deprecated bindings, and allows specifying any binding type or property
// UnsafeBinding is for experimental or deprecated bindings, and allows specifying any binding type or property.
type UnsafeBinding map[string]interface{}

// Type returns the type of the binding.
Expand Down
45 changes: 45 additions & 0 deletions workers_bindings_test.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
package cloudflare

import (
"bytes"
"context"
"encoding/json"
"fmt"
"io"
"net/http"
Expand Down Expand Up @@ -95,3 +97,46 @@ func TestListWorkerBindings(t *testing.T) {
})
assert.Equal(t, WorkerAnalyticsEngineBindingType, res.BindingList[7].Binding.Type())
}

func ExampleUnsafeBinding() {
pretty := func(meta workerBindingMeta) string {
buf := bytes.NewBufferString("")
encoder := json.NewEncoder(buf)
encoder.SetIndent("", " ")
if err := encoder.Encode(meta); err != nil {
fmt.Println("error:", err)
}
return buf.String()
}

binding_a := WorkerServiceBinding{
Service: "foo",
}
meta_a, _, _ := binding_a.serialize("my_binding")
meta_a_json := pretty(meta_a)
fmt.Println(meta_a_json)

binding_b := UnsafeBinding{
"type": "service",
"service": "foo",
}
meta_b, _, _ := binding_b.serialize("my_binding")
meta_b_json := pretty(meta_b)
fmt.Println(meta_b_json)

fmt.Println(meta_a_json == meta_b_json)
// Output:
// {
// "name": "my_binding",
// "service": "foo",
// "type": "service"
// }
//
// {
// "name": "my_binding",
// "service": "foo",
// "type": "service"
// }
//
// true
}
4 changes: 2 additions & 2 deletions workers_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1209,7 +1209,7 @@ func TestUploadWorker_ToDispatchNamespace(t *testing.T) {
assert.Equal(t, http.MethodPut, r.Method, "Expected method 'PUT', got %s", r.Method)

mpUpload, err := parseMultipartUpload(r)
assert.NoError(t, err)
require.NoError(t, err)

assert.Equal(t, workerScript, mpUpload.Script)

Expand Down Expand Up @@ -1242,7 +1242,7 @@ func TestUploadWorker_UnsafeBinding(t *testing.T) {
assert.Equal(t, http.MethodPut, r.Method, "Expected method 'PUT', got %s", r.Method)

mpUpload, err := parseMultipartUpload(r)
assert.NoError(t, err)
require.NoError(t, err)

assert.Equal(t, workerScript, mpUpload.Script)

Expand Down

0 comments on commit d1c8036

Please sign in to comment.