/** * Licensed to The Apereo Foundation under one or more contributor license * agreements. See the NOTICE file distributed with this work for additional * information regarding copyright ownership. * * * The Apereo Foundation licenses this file to you under the Educational * Community 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://opensource.org/licenses/ecl2.txt * * 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.opencastproject.assetmanager.api; import org.opencastproject.assetmanager.api.query.AQueryBuilder; import org.opencastproject.assetmanager.api.query.PropertyField; import org.opencastproject.assetmanager.api.query.PropertySchema; import org.junit.Test; import java.util.Date; public class AssetManagerTest { /** * Does not run. Only to test compilation. */ @Test(expected = java.lang.NullPointerException.class) public void testAssetManagerApiCompilation() { AssetManager am = null; AQueryBuilder q = am.createQuery(); // // Selection // // Select all versions of media package "mp-id". // Fetch media packages and associated metadata like version, creation date etc. // Do not fetch any properties since the query does not contain a property target. q.select(q.snapshot()).where(q.mediaPackageId("mp-id")).run(); // Select the latest version of "mp-id". // Fetch the media package and associated metadata like version, creation date etc. // Do not fetch any properties since the query does not contain a property target. q.select(q.snapshot()).where(q.mediaPackageId("mp-id").and(q.version().isLatest())).run(); // Select the latest version of "mp-id". // Fetch the media package and associated metadata like version, creation date etc. // Also fetch _all_ properties of the media package. q.select(q.snapshot(), q.properties()).where(q.mediaPackageId("some-mp-id").and(q.version().isLatest())).run(); // Select the latest version of "mp-id" only if it has properties of namespace "org.opencastproject.service" attached. // Fetch only the media package and associated metadata like version, creation date etc. q.select(q.snapshot()).where(q.mediaPackageId("mp-id").and(q.version().isLatest()).and(q.hasPropertiesOf("org.opencastproject.service"))).run(); // Select all versions of media package "mp-id" that are archived before now. Do not fetch associated properties. final Date date = null; // <- assume some real date here q.select(q.snapshot()).where(q.mediaPackageId("mp-id").and(q.archived().lt(date))).run(); // does not compile because of a type error //AssetResult r = q.select(q.mediaPackage("some-mp-id").and(q.archived().lt(q.val(Value.mk("bla"))))).fetchProperties(false).run(); // Select all versions of all media packages of series "series". // Also fetch all of their properties. q.select(q.snapshot()).where(q.seriesId().eq("series")).run(); // Select the latest version of each media package of series "series". // Also fetch all of their properties. q.select(q.snapshot()).where(q.seriesId().eq("series").and(q.version().isLatest())).run(); // Select all media packages and all of their versions that have boolean property "org.opencastproject.myservice:approved" set to true. // Fetch media packages and associated metadata like version, creation date etc. // Fetch all properties of namespace "org.opencastproject.myservice" q.select(q.snapshot(), q.propertiesOf("org.opencastproject.myservice")) .where(q.property(Value.BOOLEAN, "org.opencastproject.myservice", "approved").eq(true)).run(); // The above works but it's better to define and use a property schema! final Props p = new Props(q); // Select all versions of media packages that have boolean property "org.opencastproject.myservice:approved" set to true. q.select(q.snapshot()).where(p.approved().eq(true)).run(); // Select all versions of media packages and properties of namespace "org.opencastproject.myservice" having a "count" property of less than 10. q.select(q.snapshot(), q.propertiesOf(p.namespace())).where(p.count().lt(10L)).run(); final Version v = null; // <- assume some version here // Select all versions of all media packages having a younger version than "v". // Order the result set after their archival date. q.select(q.snapshot()).where(q.version().lt(v)).orderBy(q.archived().asc()).run(); // Select properties of namespace "org.opencastproject.myservice" of media package "mp-id". q.select(p.allProperties()).where(q.mediaPackageId("mp-id")).run(); // Select property "org.opencastproject.myservice:count" of media package "mp-id". q.select(p.count().target()).where(q.mediaPackageId("mp-id")).run(); // Select all media packages and their start property which start in the future. q.select(q.snapshot(), p.start().target()).where(p.start().gt(new Date())).run(); // // Deletion // // Delete all properties of all media packages. q.delete("owner", q.properties()).run(); // Delete all properties of namespace "org.opencastproject.myservice" of all media packages. q.delete("owner", q.propertiesOf("org.opencastproject.myservice")).run(); // Delete all properties of namespace "org.opencastproject.myservice" from media package "mp-id". q.delete("owner", q.propertiesOf("org.opencastproject.myservice")).where(q.mediaPackageId("mp-id")).run(); // Delete property "org.opencastproject.myservice:prop" from media package "mp-id". q.delete("owner", q.properties(PropertyName.mk("org.opencastproject.myservice", "prop"))).where(q.mediaPackageId("mp-id")).run(); // Delete properties "org.opencastproject.myservice:prop" and "org.opencastproject.myservice:prop2" from media package "mp-id". q.delete("owner", q.properties(PropertyName.mk("org.opencastproject.myservice", "prop"), PropertyName.mk("org.opencastproject.myservice", "prop2"))).where(q.mediaPackageId("mp-id")).run(); // Delete all "org.opencastproject.myservice:approved" properties from all media package having a "org.opencastproject.myservice:count" greater 10. q.delete("owner", p.approved().target()).where(p.count().gt(10L)); // // Properties // // Set property "org.opencastproject.myservice:count" of media package "mp-id" to 10. am.setProperty(Property.mk(PropertyId.mk("mp-id", "org.opencastproject.myservice", "count"), Value.mk(10L))); // Set property "org.opencastproject.myservice:count" of media package "mp-id" to 10 using the schema definition. am.setProperty(p.count().mk("mp-id", 10L)); } /** A service's sample property schema. */ static class Props extends PropertySchema { Props(AQueryBuilder q) { super(q, "org.opencastproject.myservice"); } // define your properties here below public PropertyField<Long> count() { return longProp("count"); } public PropertyField<Boolean> approved() { return booleanProp("approved"); } public PropertyField<Date> start() { return dateProp("start"); } } }