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

Introduce Error Prone #712

Merged
merged 56 commits into from
May 31, 2018
Merged
Show file tree
Hide file tree
Changes from 24 commits
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
ca3791b
Add Error Prone compiler
alexander-yevsyukov May 22, 2018
a31f735
Change `Nullable`, address some ret. vals
alexander-yevsyukov May 22, 2018
cdd6f28
Handle ignored return values
alexander-yevsyukov May 22, 2018
6a287f4
Handle checking return values
alexander-yevsyukov May 23, 2018
3c8ba11
Handle checking return values
alexander-yevsyukov May 23, 2018
9243298
Extract variable
alexander-yevsyukov May 23, 2018
a963623
Use `Nullable` from the Checker framework
alexander-yevsyukov May 24, 2018
d519c98
Fix using generic param as qualifier
alexander-yevsyukov May 24, 2018
a3c5013
Handle return values
alexander-yevsyukov May 24, 2018
9b3849c
Handle ignored return values
alexander-yevsyukov May 26, 2018
1692180
Handle ignored return values
alexander-yevsyukov May 26, 2018
0980153
Handle ignored return values
alexander-yevsyukov May 27, 2018
86c9ae0
Handle ignored return values
alexander-yevsyukov May 27, 2018
95e2f77
Handle ignored return values
alexander-yevsyukov May 27, 2018
4721160
Fix tests
alexander-yevsyukov May 27, 2018
6b27e92
Fix test
alexander-yevsyukov May 27, 2018
9eb65ce
Fix test
alexander-yevsyukov May 28, 2018
735dd14
Fix tests
alexander-yevsyukov May 28, 2018
e50ddd3
Fix tests
alexander-yevsyukov May 28, 2018
1805508
Merge remote-tracking branch 'remotes/origin/master' into error-prone
alexander-yevsyukov May 28, 2018
f50ab3f
Merge remote-tracking branch 'remotes/origin/master' into error-prone
alexander-yevsyukov May 28, 2018
474130f
Improve code layout
alexander-yevsyukov May 28, 2018
8fdda34
Optimize imports
alexander-yevsyukov May 28, 2018
116d7df
Optimize imports
alexander-yevsyukov May 28, 2018
ea04d7a
Improve code layout
alexander-yevsyukov May 30, 2018
dc646e0
Fix EOF
alexander-yevsyukov May 30, 2018
8a9ec74
Extract aggregate reading operation as a method object
alexander-yevsyukov May 30, 2018
2d153ea
Improve code layout
alexander-yevsyukov May 30, 2018
352edf0
Remove redundant `inheritDoc`
alexander-yevsyukov May 30, 2018
203a3ad
Remove unused methods
alexander-yevsyukov May 30, 2018
505821b
Fix Javadoc layout
alexander-yevsyukov May 30, 2018
ec2cab9
Improve code layout
alexander-yevsyukov May 30, 2018
425fae2
Fix code layout
alexander-yevsyukov May 30, 2018
8917a70
Allow several types of nullable annotations
alexander-yevsyukov May 30, 2018
dc9e982
Simplify work with streams
alexander-yevsyukov May 30, 2018
a243fa3
Simplify var type
alexander-yevsyukov May 30, 2018
860c0c2
Fix code layout
alexander-yevsyukov May 30, 2018
08d16b4
Improve code layout
alexander-yevsyukov May 30, 2018
621c4eb
Improve code layout
alexander-yevsyukov May 30, 2018
8b881d8
Improve code layout
alexander-yevsyukov May 30, 2018
dbb62a9
Align generic params
alexander-yevsyukov May 30, 2018
d4039d8
Improve code layout
alexander-yevsyukov May 30, 2018
5ba1a15
Add static import
alexander-yevsyukov May 30, 2018
b9f1c0f
Use streams
alexander-yevsyukov May 30, 2018
febd39e
Fix code layout
alexander-yevsyukov May 30, 2018
1bd2d02
Merge remote-tracking branch 'remotes/origin/master' into error-prone
alexander-yevsyukov May 31, 2018
1c4823d
Resolve Error Prone errors
alexander-yevsyukov May 31, 2018
6b59984
Remove some `final`s for local vars
alexander-yevsyukov May 31, 2018
6064a57
Simplify a stream op.
alexander-yevsyukov May 31, 2018
1dbaead
Extract method
alexander-yevsyukov May 31, 2018
70072bf
Remove redundant formatting calls
alexander-yevsyukov May 31, 2018
ed402e3
Use statically imported methods for streams
alexander-yevsyukov May 31, 2018
2bf51b3
Extract variables
alexander-yevsyukov May 31, 2018
c260016
Merge remote-tracking branch 'remotes/origin/master' into error-prone
alexander-yevsyukov May 31, 2018
ae3b3bf
Remove `final` var qualifier
alexander-yevsyukov May 31, 2018
e812167
Improve code layout
alexander-yevsyukov May 31, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .idea/codeStyles/Project.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 7 additions & 0 deletions .idea/inspectionProfiles/Project_Default.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

47 changes: 24 additions & 23 deletions client/src/main/java/io/spine/client/CommandFactory.java
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,6 @@
import io.spine.protobuf.AnyPacker;
import io.spine.time.ZoneOffset;
import io.spine.validate.ValidationException;

import org.checkerframework.checker.nullness.qual.Nullable;

import static com.google.common.base.Preconditions.checkNotNull;
Expand Down Expand Up @@ -72,8 +71,8 @@ public Command create(Message message) throws ValidationException {
checkNotNull(message);
checkValid(message);

final CommandContext context = createContext();
final Command result = createCommand(message, context);
CommandContext context = createContext();
Command result = createCommand(message, context);
return result;
}

Expand All @@ -94,8 +93,8 @@ public Command create(Message message, int targetVersion) throws ValidationExcep
checkNotNull(message);
checkValid(message);

final CommandContext context = createContext(targetVersion);
final Command result = createCommand(message, context);
CommandContext context = createContext(targetVersion);
Command result = createCommand(message, context);
return result;
}

Expand All @@ -115,7 +114,7 @@ public Command createWithContext(Message message, CommandContext context)
checkNotNull(context);
checkValid(message);

final Command result = createCommand(message, context);
Command result = createCommand(message, context);
return result;
}

Expand All @@ -138,9 +137,9 @@ public Command createBasedOnContext(Message message, CommandContext context)
checkNotNull(context);
checkValid(message);

final CommandContext newContext = contextBasedOn(context);
CommandContext newContext = contextBasedOn(context);

final Command result = createCommand(message, newContext);
Command result = createCommand(message, newContext);
return result;
}

Expand All @@ -157,11 +156,12 @@ public Command createBasedOnContext(Message message, CommandContext context)
* @return a new command
*/
private static Command createCommand(Message message, CommandContext context) {
final Any packed = AnyPacker.pack(message);
final Command.Builder result = Command.newBuilder()
.setId(Commands.generateId())
.setMessage(packed)
.setContext(context);
Any packed = AnyPacker.pack(message);
Command.Builder result = Command
.newBuilder()
.setId(Commands.generateId())
.setMessage(packed)
.setContext(context);
return result.build();
}

Expand Down Expand Up @@ -196,7 +196,7 @@ private CommandContext createContext(int targetVersion) {
private static CommandContext createContext(@Nullable TenantId tenantId,
UserId userId,
ZoneOffset zoneOffset) {
final CommandContext.Builder result = newContextBuilder(tenantId, userId, zoneOffset);
CommandContext.Builder result = newContextBuilder(tenantId, userId, zoneOffset);
return result.build();
}

Expand All @@ -216,8 +216,8 @@ static CommandContext createContext(@Nullable TenantId tenantId,
UserId userId,
ZoneOffset zoneOffset,
int targetVersion) {
final CommandContext.Builder builder = newContextBuilder(tenantId, userId, zoneOffset);
final CommandContext result = builder.setTargetVersion(targetVersion)
CommandContext.Builder builder = newContextBuilder(tenantId, userId, zoneOffset);
CommandContext result = builder.setTargetVersion(targetVersion)
.build();
return result;
}
Expand All @@ -226,17 +226,18 @@ static CommandContext createContext(@Nullable TenantId tenantId,
private static CommandContext.Builder newContextBuilder(@Nullable TenantId tenantId,
UserId userId,
ZoneOffset zoneOffset) {
ActorContext.Builder actorContext =
ActorContext.newBuilder()
.setActor(userId)
.setTimestamp(getCurrentTime())
.setZoneOffset(zoneOffset);
ActorContext.Builder actorContext = ActorContext
.newBuilder()
.setActor(userId)
.setTimestamp(getCurrentTime())
.setZoneOffset(zoneOffset);
if (tenantId != null) {
actorContext.setTenantId(tenantId);
}

final CommandContext.Builder result = CommandContext.newBuilder()
.setActorContext(actorContext);
CommandContext.Builder result = CommandContext
.newBuilder()
.setActorContext(actorContext);
return result;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,26 +28,31 @@
import io.spine.test.client.TestEntity;
import io.spine.time.ZoneOffset;
import io.spine.time.ZoneOffsets;
import org.junit.Test;
import org.junit.jupiter.api.DisplayName;
import org.junit.jupiter.api.Nested;
import org.junit.jupiter.api.Test;

import java.util.Set;

import static com.google.common.collect.Sets.newHashSet;
import static io.spine.base.Identifier.newUuid;
import static io.spine.core.given.GivenUserId.of;
import static io.spine.test.DisplayNames.NOT_ACCEPT_NULLS;
import static io.spine.time.Timestamps2.isLaterThan;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNull;
import static org.junit.Assert.assertTrue;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull;
import static org.junit.jupiter.api.Assertions.assertNull;
import static org.junit.jupiter.api.Assertions.assertThrows;
import static org.junit.jupiter.api.Assertions.assertTrue;

/**
* Base tests for the {@linkplain ActorRequestFactory} descendants.
*
* @author Alex Tymchenko
*/
public abstract class ActorRequestFactoryShould {
@DisplayName("Actor request factory should")
abstract class ActorRequestFactoryTest {

private final UserId actor = of(newUuid());
private final ZoneOffset zoneOffset = ZoneOffsets.UTC;
Expand All @@ -74,57 +79,11 @@ ActorContext actorContext() {
return factory().actorContext();
}

@Test(expected = NullPointerException.class)
public void require_actor_in_Builder() {
builder().setZoneOffset(zoneOffset)
.build();
}

@Test
public void return_set_values_in_Builder() {
final ActorRequestFactory.Builder builder = builder()
.setActor(actor)
.setZoneOffset(zoneOffset);
assertNotNull(builder.getActor());
assertNotNull(builder.getZoneOffset());
assertNull(builder.getTenantId());
}

@Test
public void create_instance_by_user() {
final int currentOffset = ZoneOffsets.getDefault()
.getAmountSeconds();
final ActorRequestFactory aFactory = builder()
.setActor(actor)
.build();

assertEquals(actor, aFactory.getActor());
assertEquals(currentOffset, aFactory.getZoneOffset()
.getAmountSeconds());
}

@Test
public void create_instance_by_user_and_timezone() {
assertEquals(actor, factory().getActor());
assertEquals(zoneOffset, factory().getZoneOffset());
}

@Test
public void be_single_tenant_by_default() {
assertNull(factory().getTenantId());
}

@Test
public void support_moving_between_timezones() {
final ActorRequestFactory factoryInAnotherTimezone =
factory().switchTimezone(ZoneOffsets.ofHours(-8));
assertNotEquals(factory().getZoneOffset(), factoryInAnotherTimezone.getZoneOffset());
}

@SuppressWarnings({"SerializableNonStaticInnerClassWithoutSerialVersionUID",
"SerializableInnerClassWithNonSerializableOuterClass"})
"SerializableInnerClassWithNonSerializableOuterClass"})
@Test
public void not_accept_nulls_as_public_method_arguments() {
@DisplayName(NOT_ACCEPT_NULLS)
void passNullToleranceCheck() {
new NullPointerTester()
.setDefault(Message.class, TestEntity.getDefaultInstance())
.setDefault((new TypeToken<Class<? extends Message>>() {
Expand All @@ -136,6 +95,69 @@ public void not_accept_nulls_as_public_method_arguments() {
.testInstanceMethods(factory(), NullPointerTester.Visibility.PUBLIC);
}

@Nested
@DisplayName("in Builder")
class BuilderTest {

@Test
@DisplayName("require actor")
void requireActor() {
assertThrows(NullPointerException.class, () -> builder().setZoneOffset(zoneOffset)
.build());
}

@Test
@DisplayName("return set values")
void returnSetValues() {
final ActorRequestFactory.Builder builder = builder()
.setActor(actor)
.setZoneOffset(zoneOffset);
assertNotNull(builder.getActor());
assertNotNull(builder.getZoneOffset());
assertNull(builder.getTenantId());
}
}

@Nested
@DisplayName("when created")
class WhenCreatedTest {

@Test
@DisplayName("be single tenant")
void beSingleTenant() {
assertNull(factory().getTenantId());
}

@Test
@DisplayName("store given user")
void storeUser() {
final int currentOffset = ZoneOffsets.getDefault()
.getAmountSeconds();
final ActorRequestFactory aFactory = builder()
.setActor(actor)
.build();

assertEquals(actor, aFactory.getActor());
assertEquals(currentOffset, aFactory.getZoneOffset()
.getAmountSeconds());
}

@Test
@DisplayName("store given user and timezone")
void storeUserAndTimezone() {
assertEquals(actor, factory().getActor());
assertEquals(zoneOffset, factory().getZoneOffset());
}
}

@Test
@DisplayName("support moving between timezones")
void moveBetweenTimezones() {
final ActorRequestFactory factoryInAnotherTimezone =
factory().switchTimezone(ZoneOffsets.ofHours(-8));
assertNotEquals(factory().getZoneOffset(), factoryInAnotherTimezone.getZoneOffset());
}

void verifyContext(ActorContext actualContext) {
final ActorContext expectedContext = actorContext();

Expand Down
Loading