Commit Graph

45 Commits

Author SHA1 Message Date
dependabot[bot] d66a438bda Bump jackson-databind from 2.9.9 to 2.9.10.1 in /sdk (#155)
Bumps [jackson-databind](https://github.com/FasterXML/jackson) from 2.9.9 to 2.9.10.1.
- [Release notes](https://github.com/FasterXML/jackson/releases)
- [Commits](https://github.com/FasterXML/jackson/commits)

Signed-off-by: dependabot[bot] <support@github.com>
2020-01-24 14:14:08 -08:00
Artur Souza cf68f24289
Java SDK with all features implemented for milestone 0.4 (#154)
* Basic Dapr HTTP Client for Actors.

* ActorTypeInformation with parsing logic + some stubs.

* Fixing license.

* Adding MethodContext + StateSerializer.

* Add ActorRuntime (#44)

* Add ActorRuntime

* split DaprAsyncClient hierarchy into 2 hierarchies for the different directions of communication

* Rename DaprClientBase to AbstractDaprClient

* Add ActorId

* Encapsulating async call in AbstractDaprClient as a single method. (#46)

* Add ActorMethodInfoMap (#47)

* Add ActorMethodInfoMap

* Add ConverterUtils class (#49)

* Add ConverterUtils + unit test

* Improved async call to okhttp. Former solution just wrapped a blocking call, now we using asynch call and collect the results via callbacks. Mono's are created based on the result. This make more efficient use of the resources since nothing is blocking now. Reformatted according new checkstyle (#48)

* More reformatting to 2 spaces indentation. (#50)

* Add ActorTimer and related (#51)

* Add ActorTimer and related

* cr

* ActorService + DaprStateProvider + some more. (#53)

* Faster JSON building + separate auto-gen jar + tests. (#55)

* closed the response objects and returning a string (#56)

* Add ReminderInfo (#54)

* Add ReminderInfo

* remove extra var

* More Actors Stuff (#57)

* ActorManager

* More work done.

* Adding example for actor runtime service.

* Implements ActorStateManager + fixes + javadocs.

* ActorProxy + some refactoring (#62)

* ActorManager

* More work done.

* Adding example for actor runtime service.

* Implements ActorStateManager + fixes + javadocs.

* Fix OrderManager example in order to process http 201
Change the implement the calls to DAPR using the class AbstractDaprClient because before the change the class always return Mono.Empty
Implementation of the ActorAsyncProxy
Change the name of the Actor Dapr Http Async Client

* Update code with the changes proposed by Artur in the code review

* Changes to support ActorProxy + Fixes.

Co-authored-by: Juan Jose Herrera <35985447+JuanJose-Herrera@users.noreply.github.com>

* Adding new methods for Http Client (#60)

* Adding new methods for Http Client

* Finishing implementation for HttpClient

* Adding JavaDoc and Changing return Type to new Methods

* Using ObjectSerializer and changing Constants values

* Adding gRPC client adapter, to encapsulate gRPC logic from the user (#61)

* Adding a common adapter to be exposed to users, for calling either the gRPC or the HTTP Clients.
Implementing gRPC adapter based on interface.
Moving ActorStateSerializer and renamed to be used as a generic utility for Serializing objects

* Creating a builder for the GrpcClient
Abstracting generic serialize and deserialize methods into a generic base class while leaving Actor specific stuff into the ActorStateSerializer class
Adding Javadocs

* Unit tests for ActorManager + fixes for Timer and Reminder. (#63)

* Add UnitTest to ActorProxyImpl and JaCoCo (coverage tool) implementation (#67)

* Change from unwrapMethodResponse to deserialize, because the response from an actor method is not wrapped in "Data" object
Add Unit test for the ActorProxy class

* #24 Implement more testing to the ActorProxyImpl and refactor how we manage the errors with Mono
#20 Add the coverage tool JaCoCo, the rules are commented at this moment in order to allow to execute the examples at this moment, if we enable the rules, the compilation fails.

* Enable rules for unit test coverage with a minimum of 0 in order to allow the developers to success compile, the minimum should be set to .8 before the projects ends

* Use the unwrapMethodResponse of the serilizer in order to deserilize actor responses.

* Reverting ActorProxyImpl.java

There is not need to change ActorProxyImpl since the previous change to not wrap it with the "data" structure was incorrect.

Co-authored-by: Artur Souza <artursouza.ms@outlook.com>

* Starting package to handle SpringBoot integration. (#69)

* Request body must be null on get for okhttp, empty body does not work… (#70)

* Request body must be null on get for okhttp, empty body does not work.  Also, expose the ActorStateManager methods that ought to be exposed to user.

* Make ctor package private and use equals for string compare

* Refactoring HTTP Client and creating Client HTTP Adapter (#68)

* Refactoring HTTP Client to follow same pattern as the GRPC Client.
Creating DaprClientHttpAdapter to be exposed to the users.
Refactor all uses of the http Client to use the adapter instead following composition rather than inheritance.
Dealing with conflicts

* Renaming AppToDaprHttpAsync to AppToDaprHttpAsyncClient changed previously by mistake

* Refactor Adapters to centralize all generic and actor specific functionality in the same place, having a single entry point for all communications to DAPR.
Leaving GRPC Adapter implemented, but without the possibility to create an instance of it.
Fixing Test cases

* Addressing PR comments

* PubSub + related fixes. (#71)

* Fixing issue regarding GET and DELETE method (#76)

* Unit tests for PubSub + JavaDocs. (#75)

* Invoke service + unit tests. (#78)

* Java sdk wip (#77)

* Fixing issue regarding GET and DELETE method

* Adding unit test for DaprHttp.java

* Adding test scope

* Renaming a property and fixing conflict to merge.

Co-authored-by: Artur Souza <artursouza.ms@outlook.com>

* pubsub sample needs update for listener interface (#80)

* Fix bindings + add samples (#81)

* Fix binding and add samples

* Fix sample command line

* update comment for name change

* lowercase d matches runtime, though it looks like it is case insensitive

* Spliting Actor client and runtime into a separate jar. (#83)

* Unit testing + bug fixing in GRPC Adapter (#79)

* Adding mockito plugin to be able to mock final classes
Increasing test coverage for ObjectSerializer
Fixing bug in GRPC Adapter while creating the envelopes, found during unit testing.

* First step into returning Http Headers as part of the response for the DaprClientHttpAdapter
Updating State object to match the API.
Fixing Broken Unit Tests and increasing coverage for DaprClientGrpcAdapter

* Adding documentation, fixing typos and renaming support method to be more descriptive.

* Addressing PR comments
Increasing test coverage
Fixing Merge conflicts

* Addressing PR comments

* Addressing comments regarding where to build the query parameters forthe HTTP Client calls. (#84)

* Addressing comments regarding where to build the query parameters for the HTTP Client calls.

* Making map immutable while also preventing a NPE

* Fixing DaprHttp and its tests. (#93)

* Increasing test coverage for DaprClientGrpcAdapter (#94)

* Upload jacoco test coverage report to artifact storage (#95)

* set jacoco report output dir

* upload test report

* add dapr version info

* #26 Integretion Testing Initial Example (#74)

* #26 Add Hello World Integration Testing working on Windows, need work to work on MAC and Linux

* #26 Add new Integration Test to test DAPR state functionality

* #26 Add Hello World Integration Testing working on Windows, need work to work on MAC and Linux

* Update Integration Testing getting free ports automatically

* #26 Refractor to use a base class for all the integration tests

* #26 Make StateOptions as optional in order to not throw a null pointer exception

* #26 Remove empty lines and correct the ident

* Adding license to DaprIntegrationTestingRunner

Co-authored-by: Young Bu Park <youngp@microsoft.com>
Co-authored-by: Artur Souza <artursouza.ms@outlook.com>

* Fixing and finishing unit tests (#97)

* Fixing and finishing unit tests

* Fixing styling Issues and adding new test

* Unit tests for stateful actors + fixes. (#104)

* Receiving the StateOptions on save as part of the State, to comply with the DAPR API (#105)

* Receiving the StateOptions on save as part of the State, to comply with the DAPR API

* #26 Add integration test for Concurrency funtionality in the states module

Co-authored-by: Juan Jose Herrera <35985447+JuanJose-Herrera@users.noreply.github.com>
Co-authored-by: Artur Souza <artursouza.ms@outlook.com>

* Deploy Jar packages to Nexus via CI (#106)

* Add SNAPSHOT suffix to version

* set deployment setup

* add ossrh  repostiory

* OSSRH setting

* add deployment steps

* exclude examples jar

* remove condition

* exclude spring boot pkg

Co-authored-by: Artur Souza <artursouza.ms@outlook.com>

* deactivate should not call save (#108)

Co-authored-by: Artur Souza <artursouza.ms@outlook.com>

* Fixing bug, where call should be deferred instead of async (#102)

* Fixing bug, where call should be deferred instead of async

* Removing unused pool property
Returning null as response body if empty response is found.
Adding Test case for validating callback is executed when expected.

* Fixing assertion based on previous changes

* Adding test case to verify that the call to grpc only happens when the requestor block the thread, instead of in parallel immediately after calling the methods in the adapter.
Documenting complex test case

* Fixing merge conflicts

* Documenting complex test case

* Disable GPG sign by default (#111)

* [CD] Fix gpg private key import (#113)

* fix gpg key import process

* add GPG_TTY env setting

* revert

* rename dapr-sdk to dapr-actors

* fix

* Fix GPG plugin

* [CD] Conditional SNAPSHOT and final release (#115)

* Release pkg based on tag and branch

* Update build.yml

* Update build.yml

* Creating unit tests for HttpAdapter + Adding junit 5 dependency + Reformating code (#112)

Co-authored-by: Artur Souza <artursouza.ms@outlook.com>

* Removing springboot jar and adding some unit tests for ActorRuntime. (#114)

* Release SNAPSHOT pkg for every build (#118)

* Release SNAPSHOT build every build

* fix

* Fix sample (#119)

Co-authored-by: Artur Souza <artursouza.ms@outlook.com>

* Unit tests for actors, no state. (#117)

* actor unit tests, no state

clean up a bit

* Rename class

* Fix merge

Co-authored-by: Artur Souza <artursouza.ms@outlook.com>

* Moving io.dapr.runtime to test + fixing examples accordingly. (#121)

* mvn integration-test doesn't work w/o this plugin (#122)

* Resolving conflict for PR #110 (#130)

* Renaming State domain object.
Removing duplicate use of State Options.
Adding custom serialize and deserialize classes for StateOptions objects.

* #26 Refractor StateOptions to clean unused code

* Fixing merge issues.

* Fixing unit test for DaprClientHttpAdapterTest after refactoring.

Co-authored-by: Juan Jose Herrera <35985447+JuanJose-Herrera@users.noreply.github.com>

* Refactor StateOptions and add IT consistency testing (#110)

* Renaming State domain object.
Removing duplicate use of State Options.
Adding custom serialize and deserialize classes for StateOptions objects.

* #26 Refractor StateOptions to clean unused code

* Fixing merge issues.

* #26 Add integration test for states using Retry policies

Co-authored-by: Artur Souza <artursouza.ms@outlook.com>

* Fix IT issues, to run the integration test rember to add the parameter skipITs=false (#131)

* Addresses multiple items from design review (#124)

* Use byte[] for customer data and serialized data.
Fixes for actor demo.

* Simplifying ObjectSerializer + handling CloudEvent properly.

* Split DaprClient into 3 parts to hide actor APIs.

* Remove Actor "dummy" interface.

* Supports custom serializer.

* Change seriaizer to receive Object directly.

* Handling custom serialization in State APIs + enhancements to the state APIs.

* Addressing small comment on Mono chain in ActorManager.

* Make serializer mandatory, throwing exception when null.

* Fix arg parsing problem -Dexec.args= seems to not allow hyphens inside (#136)

* Fix bug in Actor due to timer serialization. (#139)

* Missing block (#140)

* Install local test kafka before running build and tests (#142)

* local test kafka docker-compose yaml

* add kafka install step

* Separate serializer for state. (#135)

* Add gRPC State Integration Test (#138)

* Add GRP State Integration Test

* Explain ignored test cases for GRPC

* Explain ignored test cases for GRPC

* Update DaprClientTestBuilder.java

Co-authored-by: Artur Souza <artursouza.ms@outlook.com>

* Actor Activation / Deactivation Integartion Test (#144)

* Adding common setup for starting dapr applications in Integration Tests.
Adding integration test for Actor Activation and Reactivation.

* Changing the way parameters are sent to the application running under Dapr in ITs to fix issue found in Ubuntu about wrong parsing.
Moving logic of the ActivationClient into the IT class

* Fixing compilation issues in test due to rebase from upstream.

* Addressing PR comments

* Adding more unit test to reach 80% Coverage (#149)

* Adding checkstyle + fix style in sdk-actos. (#146)

* Update debug instructions since LB is not needed. (#150)

* Add E2E testing for bindings (#148)

* Add GRP State Integration Test

* Explain ignored test cases for GRPC

* Explain ignored test cases for GRPC

* Update DaprClientTestBuilder.java

* Add binding E2E testing.

* Add fix binding E2E testing after merge with new changes

* Remove example comments

Co-authored-by: Artur Souza <artursouza.ms@outlook.com>

* Adding documentation for examples (#153)

Co-authored-by: Leon Mai <lemai@microsoft.com>
Co-authored-by: ji11er <57505038+ji11er@users.noreply.github.com>
Co-authored-by: Juan Jose Herrera <35985447+JuanJose-Herrera@users.noreply.github.com>
Co-authored-by: mestizoLopez <ing.javierlg@gmail.com>
Co-authored-by: Andres Robles <15348598+AndresRoblesMX@users.noreply.github.com>
Co-authored-by: Young Bu Park <youngp@microsoft.com>
Co-authored-by: Marcos Reyes <59033058+marcosreyes05@users.noreply.github.com>
2020-01-24 12:49:56 -08:00
Young Bu Park b63fa48954
Initial commit of GitHub Actions CI (#91)
* Initial commit of gh actions yaml

* Add dapr runtime install

* show dapr install version

* add java_sdk_wip branch for pr build
2020-01-13 16:22:12 -08:00
Artur Souza 43bf1fde7c
Merge pull request #40 from artursouza/doc_debug
Documentation on how to debug Java apps or SDK.
2019-12-13 17:12:31 -08:00
Artur Souza 13b00439eb
Get pen for Win and MacOS + alt for VSCode 2019-12-11 15:50:21 -08:00
Artur Souza 4712988a44
Note on alternate order of commands to debug 2019-12-11 12:48:13 -08:00
Yaron Schneider 7512824d28
Merge branch 'master' into doc_debug 2019-12-11 11:19:20 -08:00
Artur Souza 05eb058492 Documentation on how to debug Java apps or SDK. 2019-12-11 00:05:51 -08:00
Artur Souza ab5dcca641
Merge pull request #38 from dapr/readme1
link maven install webpage and clarify version
2019-12-10 11:05:04 -08:00
LM 1cdd49c92c link maven and clarify version 2019-12-10 09:14:39 -08:00
Artur Souza 900eacc5ce
Merge pull request #27 from artursouza/grpc_examples
New example for Dapr's Grpc invoke using Java.
2019-12-09 10:23:41 -08:00
Artur Souza e09debc228 New example for Dapr's Grpc invoke using Java.
Adds documentation for the other samples too.
2019-12-08 00:55:09 -08:00
Artur Souza 48556cbefd
Merge pull request #18 from artursouza/kick-off
Repackaging + fixing samples
2019-12-06 11:50:37 -08:00
Artur Souza 46cd8d997a
Fixing instructions in README.md 2019-12-06 11:48:34 -08:00
Artur Souza c3b7c41dfd
Remove . in description for pom.xml 2019-12-06 11:17:59 -08:00
Artur Souza f89a53e241
Fixing port on Example.java 2019-12-06 11:17:03 -08:00
Artur Souza b10a6fd039 Renames project to . Fixes examples. Adds proto files from release-0.3. 2019-12-05 18:30:13 -08:00
Bruno Borges 06116e223d fix readme 2019-11-30 02:12:12 -08:00
Bruno Borges 37fa7d9542 fix formatting javadoc 2019-11-30 02:04:58 -08:00
Bruno Borges 3d41d54c73 new example 2019-11-30 02:01:10 -08:00
Bruno Borges 77919c8663 Make the project modular 2019-11-30 00:07:02 -08:00
Bruno Borges 409936a30b Add dapr repo as a submodule to generate protobuffers classes 2019-11-29 23:29:10 -08:00
Shalabh Mohan Shrivastava a4645db031
Merge pull request #7 from dapr/pkg
Adding Central Repo requirements in pom file for the artifacts upload
2019-10-17 14:10:20 -07:00
Shalabh Mohan Shrivastava acdb27596a To ensure a level of quality of the components available in the Nexus Central
Repository , adding requirements in pom file for the artifacts

 - Noted that Signing artifacts will be offline manual process
2019-10-17 14:00:49 -07:00
Shalabh Mohan Shrivastava ad544136f0
Merge pull request #6 from dapr/pkg
Add java-sdk package instructions for nexus repo manager
2019-10-16 09:30:46 -07:00
Shalabh Mohan Shrivastava 0135c949d7 revert back the usage section
revert back the usage section
2019-10-16 01:46:50 -07:00
Shalabh Mohan Shrivastava 39b6566782 Add java-sdk package instructions for nexus repo manager
Add java-sdk package instructions for nexus repo manager
2019-10-16 01:24:36 -07:00
Aman Bhardwaj 763a20aab1
Merge pull request #5 from dapr/contrib
Adding Contribution guidance in java sdk repo
2019-10-15 18:07:01 -07:00
Shalabh Mohan Shrivastava cc64035ef1 Adding Contribution guidance in java sdk repo
Adding Contribution guidance in java sdk repo
2019-10-15 17:53:20 -07:00
Yaron Schneider 714cf4297b
Update README.md 2019-10-14 16:43:02 -07:00
Yaron Schneider f3cf99ee89
Merge pull request #4 from dapr/yaron2-patch-1
Update README.md
2019-10-11 11:26:52 -07:00
Yaron Schneider 18b5b19fde
Update README.md
Add `--protocol` flag for grpc
2019-10-11 11:26:34 -07:00
Yaron Schneider 387c778397
Update README.md
Add `--protocol` flag for grpc
2019-10-11 11:26:23 -07:00
Yaron Schneider 12b2d12f95
Merge pull request #3 from yaron2/templates
Add issue and PR templates
2019-10-11 10:36:32 -07:00
Yaron Schneider b98a78ebd8
Update question.md 2019-10-11 10:34:56 -07:00
Yaron Schneider 1b6e78b0a0
Update discussion.md 2019-10-11 10:34:47 -07:00
Yaron Schneider 63f9f2cb5c
Update proposal.md 2019-10-11 10:34:35 -07:00
Yaron Schneider e0a22ac615
Update feature_request.md 2019-10-11 10:34:26 -07:00
Yaron Schneider 8b41b34486
Update bug_report.md 2019-10-11 10:34:16 -07:00
yaron2 317d0cec58 templates 2019-10-11 10:06:11 -07:00
Aman Bhardwaj 5912ca903d
Merge pull request #2 from brendandburns/master
Initial add of a README.
2019-10-09 21:30:16 -07:00
Brendan Burns 03ed8c1ebf Initial add of a README. 2019-10-09 21:23:03 -07:00
Yaron Schneider b42372ed81
Merge pull request #1 from brendandburns/master
Initial add.
2019-10-09 12:32:45 -07:00
Brendan Burns 340ab1a17e Initial add. 2019-10-09 10:30:54 -07:00
Brendan Burns 3a5b944dbd
Initial commit 2019-10-09 10:30:20 -07:00