X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=tests%2Forg.simantics.db.tests%2Fsrc%2Forg%2Fsimantics%2Fdb%2Ftests%2Fapi%2Fwrite%2Fclaim%2FWriteWithMultipleInverses.java;fp=tests%2Forg.simantics.db.tests%2Fsrc%2Forg%2Fsimantics%2Fdb%2Ftests%2Fapi%2Fwrite%2Fclaim%2FWriteWithMultipleInverses.java;h=6d4d9b1071dcdb9755a62cb276073d75a2f01db0;hb=67fd62f9c742337ec80eef658192db198a0efaac;hp=0000000000000000000000000000000000000000;hpb=cde82ba81327d5515fdca362f7f4c70f5103ae80;p=simantics%2Fplatform.git diff --git a/tests/org.simantics.db.tests/src/org/simantics/db/tests/api/write/claim/WriteWithMultipleInverses.java b/tests/org.simantics.db.tests/src/org/simantics/db/tests/api/write/claim/WriteWithMultipleInverses.java new file mode 100644 index 000000000..6d4d9b107 --- /dev/null +++ b/tests/org.simantics.db.tests/src/org/simantics/db/tests/api/write/claim/WriteWithMultipleInverses.java @@ -0,0 +1,63 @@ +package org.simantics.db.tests.api.write.claim; + +import java.util.ArrayList; +import java.util.Collection; + +import org.junit.Test; +import org.simantics.db.Resource; +import org.simantics.db.WriteGraph; +import org.simantics.db.common.request.WriteResultRequest; +import org.simantics.db.exception.DatabaseException; +import org.simantics.db.testing.annotation.Fails; +import org.simantics.db.testing.base.ExistingDatabaseTest; +import org.simantics.db.testing.common.WriteQuery; +import org.simantics.layer0.Layer0; + +public class WriteWithMultipleInverses extends ExistingDatabaseTest { + + @Test + @Fails + public void test() throws Exception{ + + final Collection predicates = getSession().syncRequest(new WriteResultRequest>() { + @Override + public Collection perform(WriteGraph g) throws DatabaseException { + Layer0 L0 = Layer0.getInstance(g); + Collection result = new ArrayList(); + for(int i=0;i<1;i++) { + Resource predicate = g.newResource(); + g.claim(predicate, L0.SubrelationOf, null, L0.IsRelatedTo); + g.claim(predicate, L0.InverseOf, null, L0.IsRelatedTo); + g.claim(predicate, L0.InverseOf, null, L0.IsWeaklyRelatedTo); + g.claim(predicate, L0.InverseOf, null, L0.IsComposedOf); + g.claim(predicate, L0.InverseOf, null, L0.IsDependencyOf); + result.add(predicate); + } + return result; + } + }); + + checkException(); + + try { + getSession().syncRequest(new WriteQuery(this) { + + @Override + public void run(WriteGraph g) throws Throwable { + + for(Resource predicate : predicates) + g.claim(predicate, predicate, predicate); + + } + + }); + + } catch (DatabaseException e) { + return; + } + + fail("Write should throw."); + + } + +}