-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
chore(allsrv): add the service layer to consolidate all domain logic
This might seem like a "moving the cheese" change. However, upon closer look we see that the `server_v2` implementation is purely a translation between the HTTP RESTful API and the domain. All traffic speaks to the service, which holds all the logic for the Foo domain. We've effectively decoupled the domain from the transport layer (HTTP). Any additional transport we want to support (gRPC/Thrift/etc) is merely creating the transport implementation. We won't duplicate our logic in each transport layer. Often, when we have consolidated all the business logic, it's very simple to just generate the RPC layer and inject the SVC to transact with the different API integrations.
- Loading branch information
Showing
10 changed files
with
417 additions
and
126 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
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 |
---|---|---|
|
@@ -29,7 +29,7 @@ func TestServer(t *testing.T) { | |
) | ||
svr = allsrv.ObserveHandler("allsrv", met)(svr) | ||
|
||
req := httptest.NewRequest("POST", "/foo", newJSONBody(t, allsrv.Foo{ | ||
req := httptest.NewRequest("POST", "/foo", newJSONBody(t, allsrv.FooV0{ | ||
Name: "first-foo", | ||
Note: "some note", | ||
})) | ||
|
@@ -39,8 +39,8 @@ func TestServer(t *testing.T) { | |
svr.ServeHTTP(rec, req) | ||
|
||
assert.Equal(t, http.StatusCreated, rec.Code) | ||
expectJSONBody(t, rec.Body, func(t *testing.T, got allsrv.Foo) { | ||
want := allsrv.Foo{ | ||
expectJSONBody(t, rec.Body, func(t *testing.T, got allsrv.FooV0) { | ||
want := allsrv.FooV0{ | ||
ID: "id1", | ||
Name: "first-foo", | ||
Note: "some note", | ||
|
@@ -52,7 +52,7 @@ func TestServer(t *testing.T) { | |
t.Run("when provided invalid basic auth should fail", func(t *testing.T) { | ||
svr := allsrv.NewServer(new(allsrv.InmemDB), allsrv.WithBasicAuth("[email protected]", "PaSsWoRd")) | ||
|
||
req := httptest.NewRequest("POST", "/foo", newJSONBody(t, allsrv.Foo{ | ||
req := httptest.NewRequest("POST", "/foo", newJSONBody(t, allsrv.FooV0{ | ||
Name: "first-foo", | ||
Note: "some note", | ||
})) | ||
|
@@ -86,8 +86,8 @@ func TestServer(t *testing.T) { | |
svr.ServeHTTP(rec, req) | ||
|
||
assert.Equal(t, http.StatusOK, rec.Code) | ||
expectJSONBody(t, rec.Body, func(t *testing.T, got allsrv.Foo) { | ||
want := allsrv.Foo{ | ||
expectJSONBody(t, rec.Body, func(t *testing.T, got allsrv.FooV0) { | ||
want := allsrv.FooV0{ | ||
ID: "reader1", | ||
Name: "read", | ||
Note: "another note", | ||
|
@@ -123,7 +123,7 @@ func TestServer(t *testing.T) { | |
var svr http.Handler = allsrv.NewServer(db, allsrv.WithBasicAuth("[email protected]", "PaSsWoRd")) | ||
svr = allsrv.ObserveHandler("allsrv", met)(svr) | ||
|
||
req := httptest.NewRequest("PUT", "/foo", newJSONBody(t, allsrv.Foo{ | ||
req := httptest.NewRequest("PUT", "/foo", newJSONBody(t, allsrv.FooV0{ | ||
ID: "id1", | ||
Name: "second_name", | ||
Note: "second note", | ||
|
@@ -148,7 +148,7 @@ func TestServer(t *testing.T) { | |
|
||
svr := allsrv.NewServer(db, allsrv.WithBasicAuth("[email protected]", "PaSsWoRd")) | ||
|
||
req := httptest.NewRequest("PUT", "/foo", newJSONBody(t, allsrv.Foo{ | ||
req := httptest.NewRequest("PUT", "/foo", newJSONBody(t, allsrv.FooV0{ | ||
ID: "id1", | ||
Name: "second_name", | ||
Note: "second note", | ||
|
Oops, something went wrong.