/** * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.apache.jena.sparql.modify; import java.util.concurrent.atomic.AtomicLong ; import org.apache.jena.atlas.iterator.Iter ; import org.apache.jena.atlas.junit.BaseTest ; import org.apache.jena.graph.Node ; import org.apache.jena.graph.NodeFactory ; import org.apache.jena.rdf.model.Model ; import org.apache.jena.rdf.model.ModelFactory ; import org.apache.jena.rdf.model.RDFNode ; import org.apache.jena.rdf.model.Resource ; import org.apache.jena.sparql.core.DatasetGraph ; import org.apache.jena.sparql.core.DatasetGraphFactory ; import org.apache.jena.sparql.core.DatasetGraphWrapper ; import org.apache.jena.sparql.core.Quad ; import org.apache.jena.sparql.sse.SSE ; import org.apache.jena.update.* ; import org.apache.jena.vocabulary.OWL ; import org.apache.jena.vocabulary.RDF ; import org.junit.Test ; // Most of the testing of SPARQL Update is scripts and uses the SPARQL-WG test suite. // Here are a few additional tests public class TestUpdateOperations extends BaseTest { private static final String DIR = "testing/Update" ; private DatasetGraph graphStore() { return DatasetGraphFactory.create() ; } private Node gName = SSE.parseNode("<http://example/g>") ; @Test public void load1() { DatasetGraph gs = graphStore() ; UpdateRequest req = UpdateFactory.create("LOAD <"+DIR+"/D.nt>") ; UpdateAction.execute(req, gs) ; assertEquals(1, gs.getDefaultGraph().size()) ; assertFalse( gs.listGraphNodes().hasNext()) ; } @Test public void load2() { DatasetGraph gs = graphStore() ; UpdateRequest req = UpdateFactory.create("LOAD <"+DIR+"/D.nt> INTO GRAPH <"+gName.getURI()+">") ; UpdateAction.execute(req, gs) ; } // Quad loading @Test public void load3() { DatasetGraph gs = graphStore() ; UpdateRequest req = UpdateFactory.create("LOAD <"+DIR+"/D.nq>") ; UpdateAction.execute(req, gs) ; assertEquals(0, gs.getDefaultGraph().size()) ; gs.containsGraph(NodeFactory.createURI("http://example/")) ; assertEquals(1, gs.getGraph(gName).size()) ; } // Bad: loading quads into a named graph @Test(expected=UpdateException.class) public void load4() { DatasetGraph gs = graphStore() ; UpdateRequest req = UpdateFactory.create("LOAD <"+DIR+"/D.nq> INTO GRAPH <"+gName.getURI()+">") ; UpdateAction.execute(req, gs) ; } @Test public void load5() { DatasetGraph gs = graphStore() ; UpdateRequest req = UpdateFactory.create("LOAD SILENT <"+DIR+"/D.nq> INTO GRAPH <"+gName.getURI()+">") ; UpdateAction.execute(req, gs) ; assertEquals(0, Iter.count(gs.find())) ; } @Test public void insert_where_01() { Model m = ModelFactory.createDefaultModel(); Resource anon = m.createResource(); anon.addProperty(RDF.type, OWL.Thing); assertEquals(1, m.size()); UpdateRequest req = UpdateFactory.create("INSERT { ?s ?p ?o } WHERE { ?o ?p ?s }"); UpdateAction.execute(req, m); assertEquals(2, m.size()); assertEquals(1, m.listStatements(anon, null, (RDFNode)null).toList().size()); assertEquals(1, m.listStatements(null, null, anon).toList().size()); } // Check constant and template quads @Test public void delete_insert_where_01() { DatasetGraph dsg0 = DatasetGraphFactory.create() ; UpdateRequest req = UpdateFactory.create("INSERT DATA { <x> <p> 2 . <z> <q> 2 . <z> <q> 3 . }") ; UpdateAction.execute(req, dsg0); assertEquals(3, dsg0.getDefaultGraph().size()) ; AtomicLong counterIns = new AtomicLong(0) ; AtomicLong counterDel = new AtomicLong(0) ; DatasetGraph dsg = new DatasetGraphWrapper(dsg0) { @Override public void add(Quad quad) { counterIns.incrementAndGet() ; super.add(quad) ; } @Override public void delete(Quad quad) { counterDel.incrementAndGet() ; super.delete(quad) ; } } ; // WHERE clause doubles the effect. String s = "DELETE { ?x <p> 2 . <z> <q> 2 } INSERT { ?x <p> 1 . <x> <q> 1 } WHERE { ?x <p> ?o {} UNION {} }" ; req = UpdateFactory.create(s) ; UpdateAction.execute(req, dsg); assertEquals(3, counterIns.get()) ; // 3 : 1 constant, 2 from template. assertEquals(3, counterIns.get()) ; assertEquals(3, dsg.getDefaultGraph().size()) ; } }