/*
* 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.lang;
import org.apache.jena.atlas.junit.BaseTest ;
import org.apache.jena.query.Query ;
import org.apache.jena.query.QueryException ;
import org.apache.jena.query.QueryFactory ;
import org.junit.Test ;
public class TestVarScope extends BaseTest
{
private static void scope(String queryStr)
{
Query query = QueryFactory.create(queryStr) ;
}
@Test public void scope_01() { scope("SELECT ?x { ?s ?p ?o }") ; }
@Test public void scope_02() { scope("SELECT ?s { ?s ?p ?o }") ; }
@Test public void scope_03() { scope("SELECT (?o+1 AS ?x) { ?s ?p ?o }") ; }
@Test(expected=QueryException.class)
public void scope_04() { scope("SELECT (?o+1 AS ?o) { ?s ?p ?o }") ; }
@Test(expected=QueryException.class)
public void scope_05() { scope("SELECT (?o+1 AS ?x) (?o+1 AS ?x) { ?s ?p ?o }") ; }
@Test public void scope_06() { scope("SELECT (?z+1 AS ?x) { ?s ?p ?o } GROUP BY (?o+5 AS ?z)") ; }
@Test(expected=QueryException.class)
public void scope_07() { scope("SELECT (?o+1 AS ?x) { ?s ?p ?o } GROUP BY (?o+5 AS ?x)") ; }
@Test public void scope_08() { scope("SELECT (count(*) AS ?X) (?X+1 AS ?Z) { ?s ?p ?o }") ; }
@Test public void scope_09() { scope("SELECT (count(*) AS ?X) (?X+?o AS ?Z) { ?s ?p ?o } GROUP BY ?o") ; }
@Test public void scope_10() { scope("SELECT (?o+1 AS ?x) { ?s ?p ?o MINUS { ?s ?p ?x} } ") ; }
@Test(expected=QueryException.class)
public void scope_15() { scope("SELECT (?o+1 AS ?x) { { SELECT (123 AS ?x) {?s ?p ?o } } } ") ; }
@Test(expected=QueryException.class)
public void scope_16() { scope("SELECT (?o+1 AS ?o) { { SELECT (123 AS ?x) {?s ?p ?o } } } ") ; }
@Test(expected=QueryException.class)
public void scope_17() { scope("SELECT (?o+1 AS ?o) { { SELECT (123 AS ?x) {?s ?p ?o FILTER(?x > 57)} } } ") ; }
@Test public void scope_20() { scope("SELECT ?x { ?x ?p ?o } GROUP BY ?x") ; }
@Test (expected=QueryException.class)
public void scope_21() { scope("SELECT ?o { ?x ?p ?o } GROUP BY ?x") ; }
@Test(expected=QueryException.class)
public void scope_22() { scope("SELECT * { ?s ?p ?o BIND(5 AS ?o) }") ; }
@Test public void scope_23() { scope("SELECT * { ?s ?p ?o { BIND(5 AS ?o) } }") ; }
@Test(expected=QueryException.class)
public void scope_24() { scope("SELECT * { { ?s ?p ?o } BIND(5 AS ?o) }") ; }
@Test public void scope_25() { scope("SELECT * { { ?s ?p ?o } { BIND(5 AS ?o) } }") ; }
@Test public void scope_26() { scope("SELECT * { ?s ?p ?o OPTIONAL{?s ?p2 ?o2} BIND(?o2+5 AS ?z) }") ; }
@Test(expected=QueryException.class)
public void scope_27() { scope("SELECT * { ?s ?p ?o OPTIONAL{?s ?p2 ?o2} BIND(5 AS ?o2) }") ; }
@Test(expected=QueryException.class)
public void scope_28() { scope("SELECT * { { ?s ?p ?o OPTIONAL{?s ?p2 ?o2} } BIND(?o+5 AS ?o2) }") ; }
@Test(expected=QueryException.class)
public void scope_29() { scope("SELECT * { ?s ?p ?o OPTIONAL{?s ?p2 ?o2} BIND(5 AS ?o) }") ; }
@Test(expected=QueryException.class)
public void scope_30() { scope("SELECT * { { ?s ?p ?o } OPTIONAL{?s ?p2 ?o2} BIND(5 AS ?o) }") ; }
@Test(expected=QueryException.class)
public void scope_34() { scope("SELECT * { { ?s ?p ?o } UNION {?s ?p2 ?o2} BIND(5 AS ?o) }") ; }
@Test
public void scope_35() { scope("SELECT * { ?s1 ?p1 ?z { ?s ?p ?z } UNION { BIND(5 AS ?z) } }") ; }
// Subqueries
@Test(expected=QueryException.class)
public void scope_50() { scope("SELECT * { SELECT (?o+1 AS ?o) { ?s ?p ?o }}") ; }
@Test
public void scope_51()
{
scope("SELECT ?y { " +
"{ { SELECT (?x AS ?y) { ?s ?p ?x } } } UNION { { SELECT (?x AS ?y) { ?s ?p ?x } } }" +
"}") ;
}
@Test(expected=QueryException.class)
public void scope_52()
{
scope("SELECT ?y { " +
"{ { SELECT (?o+1 AS ?x) (?o+1 AS ?x) { ?s ?p ?o } } UNION { ?s ?p ?x } }" +
"}") ;
}
@Test(expected=QueryException.class)
public void scope_63()
{
// Check nested things get checked.
scope("SELECT * { { ?s ?p ?o } UNION { ?s ?p ?o1 BIND(5 AS ?o1) } }") ;
}
@Test(expected=QueryException.class)
public void scope_64()
{
// Check nested things get checked.
scope("SELECT * { { { ?s ?p ?o1 BIND(5 AS ?o1) } } }") ;
}
@Test(expected=QueryException.class)
public void scope_65()
{
scope("SELECT ( (?x+1) AS ?x ) {}") ;
}
@Test(expected=QueryException.class)
public void scope_66()
{
scope("SELECT ( (?x+1) AS ?y) (2 AS ?x) {}") ;
}
}