MultithreadedLmdbStoreRDFSIT.java
/*******************************************************************************
* Copyright (c) 2023 Eclipse RDF4J contributors.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Distribution License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: BSD-3-Clause
*******************************************************************************/
package org.eclipse.rdf4j.sail.shacl;
import java.io.File;
import java.io.IOException;
import org.apache.commons.io.FileUtils;
import org.assertj.core.util.Files;
import org.eclipse.rdf4j.common.transaction.IsolationLevels;
import org.eclipse.rdf4j.sail.NotifyingSail;
import org.eclipse.rdf4j.sail.NotifyingSailConnection;
import org.eclipse.rdf4j.sail.inferencer.fc.SchemaCachingRDFSInferencer;
import org.eclipse.rdf4j.sail.lmdb.LmdbStore;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Tag;
@Tag("slow")
public class MultithreadedLmdbStoreRDFSIT extends MultithreadedTest {
File file;
@AfterEach
public void after() {
try {
FileUtils.deleteDirectory(file);
} catch (IOException e) {
throw new RuntimeException(e);
}
}
@BeforeEach
public void before() {
file = Files.newTemporaryFolder();
}
@Override
NotifyingSail getBaseSail() {
NotifyingSail notifyingSail = new LmdbStore(file);
notifyingSail = new SchemaCachingRDFSInferencer(notifyingSail);
try (NotifyingSailConnection connection = notifyingSail.getConnection()) {
connection.begin(IsolationLevels.NONE);
connection.clear();
connection.commit();
}
return notifyingSail;
}
}