HHH-11290 - Migrate all documentation snippets that derive the source code from extras instead of actual Unit Tests

Fixed in the Locking chapter
This commit is contained in:
Vlad Mihalcea 2017-06-28 15:28:53 +03:00
parent 1d0a44ab92
commit 64b16fdf5e
7 changed files with 219 additions and 67 deletions

View File

@ -53,17 +53,17 @@ According to JPA, the valid types for these attributes are limited to:
==== ====
[source,java] [source,java]
---- ----
include::{extrasdir}/entity/Version.java[] include::{sourcedir}/OptimisticLockingTest.java[tags=locking-optimistic-entity-mapping-example,indent=0]
---- ----
[source,java] [source,java]
---- ----
include::{extrasdir}/entity/Timestamp.java[] include::{sourcedir}/OptimisticLockingTimestampTest.java[tags=locking-optimistic-entity-mapping-example,indent=0]
---- ----
[source,java] [source,java]
---- ----
include::{extrasdir}/entity/Instant.java[] include::{sourcedir}/OptimisticLockingInstantTest.java[tags=locking-optimistic-entity-mapping-example,indent=0]
---- ----
==== ====
@ -77,7 +77,7 @@ The version number mechanism for optimistic locking is provided through a `@Vers
==== ====
[source, JAVA,indent=0] [source, JAVA,indent=0]
---- ----
include::{sourcedir}/OptimisticLockingTest.java[tags=locking-optimistic-version-number-example] include::{sourcedir}/OptimisticLockingTest.java[tags=locking-optimistic-version-number-example,indent=0]
---- ----
==== ====
@ -106,7 +106,7 @@ Timestamping is automatically used if you the `@Version` annotation on a `Date`
==== ====
[source, JAVA,indent=0] [source, JAVA,indent=0]
---- ----
include::{sourcedir}/OptimisticLockingTest.java[tags=locking-optimistic-version-timestamp-example] include::{sourcedir}/OptimisticLockingTest.java[tags=locking-optimistic-version-timestamp-example,indent=0]
---- ----
==== ====
@ -122,7 +122,7 @@ if you use the `@org.hibernate.annotations.Generated(GenerationTime.ALWAYS)` or
==== ====
[source, JAVA,indent=0] [source, JAVA,indent=0]
---- ----
include::{sourcedir}/VersionSourceTest.java[tags=locking-optimistic-version-timestamp-source-mapping-example] include::{sourcedir}/VersionSourceTest.java[tags=locking-optimistic-version-timestamp-source-mapping-example,indent=0]
---- ----
==== ====
@ -133,7 +133,7 @@ Now, when persisting a `Person` entity, Hibernate calls the database-specific cu
==== ====
[source, JAVA,indent=0] [source, JAVA,indent=0]
---- ----
include::{sourcedir}/VersionSourceTest.java[tags=locking-optimistic-version-timestamp-source-persist-example] include::{sourcedir}/VersionSourceTest.java[tags=locking-optimistic-version-timestamp-source-persist-example,indent=0]
---- ----
[source, SQL,indent=0] [source, SQL,indent=0]
@ -155,7 +155,7 @@ as illustrated in the following example.
==== ====
[source, JAVA,indent=0] [source, JAVA,indent=0]
---- ----
include::{sourcedir}/OptimisticLockTest.java[tags=locking-optimistic-exclude-attribute-mapping-example] include::{sourcedir}/OptimisticLockTest.java[tags=locking-optimistic-exclude-attribute-mapping-example,indent=0]
---- ----
==== ====
@ -167,7 +167,7 @@ the two concurrent transactions are not going to conflict as illustrated by the
==== ====
[source, JAVA,indent=0] [source, JAVA,indent=0]
---- ----
include::{sourcedir}/OptimisticLockTest.java[tags=locking-optimistic-exclude-attribute-example] include::{sourcedir}/OptimisticLockTest.java[tags=locking-optimistic-exclude-attribute-example,indent=0]
---- ----
[source, SQL,indent=0] [source, SQL,indent=0]
@ -357,7 +357,7 @@ The scope can either be `NORMAL` (default value) or `EXTENDED`. The `EXTENDED` s
==== ====
[source, JAVA,indent=0] [source, JAVA,indent=0]
---- ----
include::{sourcedir}/ExplicitLockingTest.java[tags=locking-jpa-query-hints-timeout-example] include::{sourcedir}/ExplicitLockingTest.java[tags=locking-jpa-query-hints-timeout-example,indent=0]
---- ----
[source, SQL,indent=0] [source, SQL,indent=0]
@ -390,7 +390,7 @@ The following example shows how to obtain shared database lock without waiting f
==== ====
[source, JAVA,indent=0] [source, JAVA,indent=0]
---- ----
include::{sourcedir}/ExplicitLockingTest.java[tags=locking-buildLockRequest-example] include::{sourcedir}/ExplicitLockingTest.java[tags=locking-buildLockRequest-example,indent=0]
---- ----
[source, SQL,indent=0] [source, SQL,indent=0]
@ -416,7 +416,7 @@ For this reason, Hibernate uses secondary selects to lock the previously fetched
==== ====
[source, JAVA,indent=0] [source, JAVA,indent=0]
---- ----
include::{sourcedir}/ExplicitLockingTest.java[tags=locking-follow-on-example] include::{sourcedir}/ExplicitLockingTest.java[tags=locking-follow-on-example,indent=0]
---- ----
[source, SQL,indent=0] [source, SQL,indent=0]
@ -435,7 +435,7 @@ To avoid the N+1 query problem, a separate query can be used to apply the lock u
==== ====
[source, JAVA,indent=0] [source, JAVA,indent=0]
---- ----
include::{sourcedir}/ExplicitLockingTest.java[tags=locking-follow-on-secondary-query-example] include::{sourcedir}/ExplicitLockingTest.java[tags=locking-follow-on-secondary-query-example,indent=0]
---- ----
[source, SQL,indent=0] [source, SQL,indent=0]
@ -456,7 +456,7 @@ Even more important is that you can overrule the default follow-on-locking detec
==== ====
[source, JAVA,indent=0] [source, JAVA,indent=0]
---- ----
include::{sourcedir}/ExplicitLockingTest.java[tags=locking-follow-on-explicit-example] include::{sourcedir}/ExplicitLockingTest.java[tags=locking-follow-on-explicit-example,indent=0]
---- ----
[source, SQL,indent=0] [source, SQL,indent=0]

View File

@ -1,10 +0,0 @@
@Entity
public class Thing2 {
@Id
private Integer id;
@Version
private Instant ts;
...
}

View File

@ -1,11 +0,0 @@
@Entity
public class Thing {
@Id
private Integer id;
@Version
private Timestamp ts;
...
}

View File

@ -1,10 +0,0 @@
@Entity
public class Course {
@Id
private Integer id;
@Version
private Integer version;
...
}

View File

@ -0,0 +1,91 @@
/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
* See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
*/
package org.hibernate.userguide.locking;
import java.sql.Timestamp;
import java.time.Instant;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Version;
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
import org.junit.Test;
import static org.hibernate.testing.transaction.TransactionUtil.doInJPA;
/**
* @author Vlad Mihalcea
*/
public class OptimisticLockingInstantTest extends BaseEntityManagerFunctionalTestCase {
@Override
protected Class<?>[] getAnnotatedClasses() {
return new Class<?>[] {
Person.class
};
}
@Test
public void test() {
Person _person = doInJPA( this::entityManagerFactory, entityManager -> {
Person person = new Person( );
person.setName( "John Doe" );
entityManager.persist( person );
return person;
} );
doInJPA( this::entityManagerFactory, entityManager -> {
Person person = entityManager.find( Person.class, _person.getId() );
person.setName( person.getName().toUpperCase() );
} );
}
//tag::locking-optimistic-entity-mapping-example[]
@Entity(name = "Person")
public static class Person {
@Id
@GeneratedValue
private Long id;
@Column(name = "`name`")
private String name;
//tag::locking-optimistic-version-number-example[]
@Version
private Instant version;
//end::locking-optimistic-version-number-example[]
//Getters and setters are omitted for brevity
//end::locking-optimistic-entity-mapping-example[]
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Instant getVersion() {
return version;
}
//tag::locking-optimistic-entity-mapping-example[]
}
//end::locking-optimistic-entity-mapping-example[]
}

View File

@ -60,6 +60,7 @@ public class OptimisticLockingTest extends BaseEntityManagerFunctionalTestCase {
} ); } );
} }
//tag::locking-optimistic-entity-mapping-example[]
@Entity(name = "Person") @Entity(name = "Person")
public static class Person { public static class Person {
@ -75,6 +76,9 @@ public class OptimisticLockingTest extends BaseEntityManagerFunctionalTestCase {
private long version; private long version;
//end::locking-optimistic-version-number-example[] //end::locking-optimistic-version-number-example[]
//Getters and setters are omitted for brevity
//end::locking-optimistic-entity-mapping-example[]
public Long getId() { public Long getId() {
return id; return id;
} }
@ -98,7 +102,9 @@ public class OptimisticLockingTest extends BaseEntityManagerFunctionalTestCase {
public void setVersion(long version) { public void setVersion(long version) {
this.version = version; this.version = version;
} }
//tag::locking-optimistic-entity-mapping-example[]
} }
//end::locking-optimistic-entity-mapping-example[]
@Entity(name = "Phone") @Entity(name = "Phone")
public static class Phone { public static class Phone {
@ -145,9 +151,5 @@ public class OptimisticLockingTest extends BaseEntityManagerFunctionalTestCase {
public Date getVersion() { public Date getVersion() {
return version; return version;
} }
public void setVersion(Date version) {
this.version = version;
}
} }
} }

View File

@ -0,0 +1,90 @@
/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
* See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
*/
package org.hibernate.userguide.locking;
import java.sql.Timestamp;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Version;
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
import org.junit.Test;
import static org.hibernate.testing.transaction.TransactionUtil.doInJPA;
/**
* @author Vlad Mihalcea
*/
public class OptimisticLockingTimestampTest extends BaseEntityManagerFunctionalTestCase {
@Override
protected Class<?>[] getAnnotatedClasses() {
return new Class<?>[] {
Person.class
};
}
@Test
public void test() {
Person _person = doInJPA( this::entityManagerFactory, entityManager -> {
Person person = new Person( );
person.setName( "John Doe" );
entityManager.persist( person );
return person;
} );
doInJPA( this::entityManagerFactory, entityManager -> {
Person person = entityManager.find( Person.class, _person.getId() );
person.setName( person.getName().toUpperCase() );
} );
}
//tag::locking-optimistic-entity-mapping-example[]
@Entity(name = "Person")
public static class Person {
@Id
@GeneratedValue
private Long id;
@Column(name = "`name`")
private String name;
//tag::locking-optimistic-version-number-example[]
@Version
private Timestamp version;
//end::locking-optimistic-version-number-example[]
//Getters and setters are omitted for brevity
//end::locking-optimistic-entity-mapping-example[]
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Timestamp getVersion() {
return version;
}
//tag::locking-optimistic-entity-mapping-example[]
}
//end::locking-optimistic-entity-mapping-example[]
}