use of com.vaticle.typedb.core.database.CoreTransaction in project grakn by graknlabs.
the class ResolutionTest method createRootAndAssertResponses.
private void createRootAndAssertResponses(CoreTransaction transaction, Conjunction conjunction, long answerCount, long explainableAnswers) throws InterruptedException {
ResolverRegistry registry = transaction.reasoner().resolverRegistry();
LinkedBlockingQueue<Match.Finished> responses = new LinkedBlockingQueue<>();
AtomicLong doneReceived = new AtomicLong(0L);
Set<Identifier.Variable.Retrievable> filter = new HashSet<>();
iterate(conjunction.variables()).map(Variable::id).filter(Identifier::isName).map(Identifier.Variable::asName).forEachRemaining(filter::add);
Actor.Driver<RootResolver.Conjunction> root;
try {
root = registry.root(conjunction, responses::add, iterDone -> doneReceived.incrementAndGet(), (throwable) -> fail());
} catch (TypeDBException e) {
fail();
return;
}
assertResponses(root, filter, responses, doneReceived, answerCount, explainableAnswers);
}
use of com.vaticle.typedb.core.database.CoreTransaction in project grakn by graknlabs.
the class UnifyIsaConcludableTest method setUp.
@BeforeClass
public static void setUp() throws IOException {
Util.resetDirectory(dataDir);
databaseMgr = CoreDatabaseManager.open(options);
databaseMgr.create(database);
session = databaseMgr.session(database, Arguments.Session.Type.SCHEMA);
try (CoreTransaction tx = session.transaction(Arguments.Transaction.Type.WRITE)) {
tx.query().define(TypeQL.parseQuery("define " + "person sub entity," + " owns first-name," + " owns last-name," + " owns age," + " plays employment:employee;" + "company sub entity," + " plays employment:employer;" + "employment sub relation," + " relates employee," + " relates employer;" + "name sub attribute, value string, abstract;" + "first-name sub name;" + "last-name sub name;" + "age sub attribute, value long;" + "").asDefine());
tx.commit();
}
}
use of com.vaticle.typedb.core.database.CoreTransaction in project grakn by graknlabs.
the class ExplanationTest method test_disjunction_explainable.
@Test
public void test_disjunction_explainable() {
try (CoreSession session = databaseMgr.session(database, Arguments.Session.Type.SCHEMA)) {
try (CoreTransaction txn = singleThreadElgTransaction(session, Arguments.Transaction.Type.WRITE)) {
ConceptManager conceptMgr = txn.concepts();
LogicManager logicMgr = txn.logic();
EntityType person = conceptMgr.putEntityType("person");
AttributeType name = conceptMgr.putAttributeType("name", AttributeType.ValueType.STRING);
person.setOwns(name);
RelationType friendship = conceptMgr.putRelationType("friendship");
friendship.setRelates("friend");
RelationType marriage = conceptMgr.putRelationType("marriage");
marriage.setRelates("husband");
marriage.setRelates("wife");
person.setPlays(friendship.getRelates("friend"));
person.setPlays(marriage.getRelates("husband"));
person.setPlays(marriage.getRelates("wife"));
logicMgr.putRule("marriage-is-friendship", TypeQL.parsePattern("{ $x isa person; $y isa person; (husband: $x, wife: $y) isa marriage; }").asConjunction(), TypeQL.parseVariable("(friend: $x, friend: $y) isa friendship").asThing());
txn.commit();
}
}
try (CoreSession session = databaseMgr.session(database, Arguments.Session.Type.DATA)) {
try (CoreTransaction txn = singleThreadElgTransaction(session, Arguments.Transaction.Type.WRITE)) {
txn.query().insert(TypeQL.parseQuery("insert $x isa person, has name 'Zack'; $y isa person, has name 'Yasmin'; (husband: $x, wife: $y) isa marriage;").asInsert());
txn.commit();
}
try (CoreTransaction txn = singleThreadElgTransaction(session, Arguments.Transaction.Type.READ, (new Options.Transaction().explain(true)))) {
List<ConceptMap> ans = txn.query().match(TypeQL.parseQuery("match $p1 isa person; { (friend: $p1, friend: $p2) isa friendship;} or { $p1 has name 'Zack'; }; ").asMatch()).toList();
assertEquals(3, ans.size());
ConceptMap withExplainable;
ConceptMap withoutExplainable;
if (ans.get(0).contains("p2")) {
withExplainable = ans.get(0);
if (!ans.get(1).contains("p2"))
withoutExplainable = ans.get(1);
else
withoutExplainable = ans.get(2);
} else if (ans.get(1).contains("p2")) {
withExplainable = ans.get(1);
if (!ans.get(0).contains("p2"))
withoutExplainable = ans.get(0);
else
withoutExplainable = ans.get(2);
} else {
withExplainable = ans.get(2);
if (!ans.get(0).contains("p2"))
withoutExplainable = ans.get(0);
else
withoutExplainable = ans.get(1);
}
assertEquals(3, withExplainable.concepts().size());
assertEquals(2, withoutExplainable.concepts().size());
assertFalse(withExplainable.explainables().isEmpty());
assertTrue(withoutExplainable.explainables().isEmpty());
assertSingleExplainableExplanations(withExplainable, 1, 1, 1, txn);
}
}
}
use of com.vaticle.typedb.core.database.CoreTransaction in project grakn by graknlabs.
the class ExplanationTest method test_has_variable_explainable_two_ways.
@Test
public void test_has_variable_explainable_two_ways() {
try (CoreSession session = databaseMgr.session(database, Arguments.Session.Type.SCHEMA)) {
try (CoreTransaction txn = singleThreadElgTransaction(session, Arguments.Transaction.Type.WRITE)) {
LogicManager logicMgr = txn.logic();
txn.query().define(TypeQL.parseQuery("define " + "user sub entity, " + " plays group-membership:member, " + " owns permission; " + "user-group sub entity," + " plays group-membership:user-group," + " owns permission," + " owns name; " + "group-membership sub relation," + " relates member," + " relates user-group; " + "permission sub attribute, value string;" + "name sub attribute, value string;").asDefine());
logicMgr.putRule("admin-group-gives-permissions", TypeQL.parsePattern("{ $x isa user; ($x, $g) isa group-membership; $g isa user-group, has name \"admin\", has permission $p; }").asConjunction(), TypeQL.parseVariable("$x has $p").asThing());
logicMgr.putRule("writer-group-gives-permissions", TypeQL.parsePattern("{ $x isa user; ($x, $g) isa group-membership; $g isa user-group, has name \"write\", has permission $p; }").asConjunction(), TypeQL.parseVariable("$x has $p").asThing());
txn.commit();
}
}
try (CoreSession session = databaseMgr.session(database, Arguments.Session.Type.DATA)) {
try (CoreTransaction txn = singleThreadElgTransaction(session, Arguments.Transaction.Type.WRITE)) {
txn.query().insert(TypeQL.parseQuery("insert " + "$x isa user; " + "$wg isa user-group, has name \"write\", has permission \"write\";" + "(member: $x, user-group: $wg) isa group-membership;" + "$admin isa user-group, has name \"admin\", has permission \"write\", has permission \"delete\";" + "(member: $x, user-group: $admin) isa group-membership;").asInsert());
txn.commit();
}
try (CoreTransaction txn = singleThreadElgTransaction(session, Arguments.Transaction.Type.READ, (new Options.Transaction().explain(true)))) {
List<ConceptMap> ans = txn.query().match(TypeQL.parseQuery("match $x isa user, has permission \"write\";").asMatch()).toList();
assertEquals(1, ans.size());
assertFalse(ans.get(0).explainables().isEmpty());
assertSingleExplainableExplanations(ans.get(0), 1, 1, 2, txn);
}
}
}
use of com.vaticle.typedb.core.database.CoreTransaction in project grakn by graknlabs.
the class ExplanationTest method test_relation_explainable.
@Test
public void test_relation_explainable() {
try (CoreSession session = databaseMgr.session(database, Arguments.Session.Type.SCHEMA)) {
try (CoreTransaction txn = singleThreadElgTransaction(session, Arguments.Transaction.Type.WRITE)) {
ConceptManager conceptMgr = txn.concepts();
LogicManager logicMgr = txn.logic();
EntityType person = conceptMgr.putEntityType("person");
AttributeType name = conceptMgr.putAttributeType("name", AttributeType.ValueType.STRING);
person.setOwns(name);
RelationType friendship = conceptMgr.putRelationType("friendship");
friendship.setRelates("friend");
RelationType marriage = conceptMgr.putRelationType("marriage");
marriage.setRelates("husband");
marriage.setRelates("wife");
person.setPlays(friendship.getRelates("friend"));
person.setPlays(marriage.getRelates("husband"));
person.setPlays(marriage.getRelates("wife"));
logicMgr.putRule("marriage-is-friendship", TypeQL.parsePattern("{ $x isa person; $y isa person; (husband: $x, wife: $y) isa marriage; }").asConjunction(), TypeQL.parseVariable("(friend: $x, friend: $y) isa friendship").asThing());
txn.commit();
}
}
try (CoreSession session = databaseMgr.session(database, Arguments.Session.Type.DATA)) {
try (CoreTransaction txn = singleThreadElgTransaction(session, Arguments.Transaction.Type.WRITE)) {
txn.query().insert(TypeQL.parseQuery("insert $x isa person, has name 'Zack'; $y isa person, has name 'Yasmin'; (husband: $x, wife: $y) isa marriage;").asInsert());
txn.commit();
}
try (CoreTransaction txn = singleThreadElgTransaction(session, Arguments.Transaction.Type.READ, (new Options.Transaction().explain(true)))) {
List<ConceptMap> ans = txn.query().match(TypeQL.parseQuery("match (friend: $p1, friend: $p2) isa friendship; $p1 has name $na;").asMatch()).toList();
assertEquals(2, ans.size());
assertFalse(ans.get(0).explainables().isEmpty());
assertFalse(ans.get(1).explainables().isEmpty());
assertSingleExplainableExplanations(ans.get(0), 1, 1, 1, txn);
assertSingleExplainableExplanations(ans.get(1), 1, 1, 1, txn);
}
}
}
Aggregations