Commit the new iPOJO version (0.7.6).

git-svn-id: https://svn.apache.org/repos/asf/felix/trunk@642265 13f79535-47bb-0310-9956-ffa450edef68
diff --git a/ipojo/tests/tests.composite/pom.xml b/ipojo/tests/tests.composite/pom.xml
new file mode 100644
index 0000000..e016d37
--- /dev/null
+++ b/ipojo/tests/tests.composite/pom.xml
@@ -0,0 +1,112 @@
+<!--

+	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.

+-->

+<project>

+	<parent>

+		<groupId>ipojo.tests</groupId>

+		<artifactId>ipojo.tests</artifactId>

+		<version>0.7.6-SNAPSHOT</version>

+		<relativePath>../pom.xml</relativePath>

+	</parent>

+

+	<modelVersion>4.0.0</modelVersion>

+	<packaging>bundle</packaging>

+	<name>iPOJO Composite Test Suite</name>

+	<artifactId>tests.composite</artifactId>

+	<dependencies>

+		<dependency>

+			<groupId>org.apache.felix</groupId>

+			<artifactId>org.apache.felix.ipojo</artifactId>

+			<version>0.7.6-SNAPSHOT</version>

+		</dependency>

+		<dependency>

+			<groupId>org.apache.felix</groupId>

+			<artifactId>org.apache.felix.ipojo.composite</artifactId>

+			<version>0.7.6-SNAPSHOT</version>

+		</dependency>

+		<dependency>

+			<groupId>org.apache.felix</groupId>

+			<artifactId>org.apache.felix.ipojo.metadata</artifactId>

+			<version>0.7.6-SNAPSHOT</version>

+		</dependency>

+		<dependency>

+			<groupId>org.apache.felix</groupId>

+			<artifactId>org.osgi.core</artifactId>

+			<version>1.0.0</version>

+		</dependency>

+		<dependency>

+			<groupId>junit</groupId>

+			<artifactId>junit</artifactId>

+			<version>3.8.1</version>

+		</dependency>

+		<dependency>

+			<groupId>ipojo.examples</groupId>

+			<artifactId>org.apache.felix.ipojo.junit4osgi</artifactId>

+			<version>0.7.6-SNAPSHOT</version>

+		</dependency>

+		<dependency>

+			<groupId>ipojo.tests</groupId>

+			<artifactId>tests.core</artifactId>

+			<version>0.7.6-SNAPSHOT</version>

+		</dependency>

+	</dependencies>

+	<build>

+		<plugins>

+			<plugin>

+				<groupId>org.apache.felix</groupId>

+				<artifactId>maven-bundle-plugin</artifactId>

+				<version>1.4.0</version>

+				<extensions>true</extensions>

+				<configuration>

+					<instructions>

+						<Export-Package>

+							org.apache.felix.ipojo.test.composite.service

+						</Export-Package>

+						<Bundle-SymbolicName>

+							${pom.artifactId}

+						</Bundle-SymbolicName>

+						<Private-Package>

+							org.apache.felix.ipojo.test.composite.*

+						</Private-Package>

+						<Test-Suite>

+							org.apache.felix.ipojo.test.composite.CompositeTestSuite

+						</Test-Suite>

+						<Import-Package>

+							org.apache.felix.ipojo.test.scenarios.service,*

+						</Import-Package>

+					</instructions>

+				</configuration>

+			</plugin>

+			<plugin>

+				<groupId>org.apache.felix</groupId>

+				<artifactId>maven-ipojo-plugin</artifactId>

+				<version>0.7.6-SNAPSHOT</version>

+				<executions>

+					<execution>

+						<goals>

+							<goal>ipojo-bundle</goal>

+						</goals>

+						<configuration>

+							<ignoreAnnotations>true</ignoreAnnotations>

+						</configuration>

+					</execution>

+				</executions>

+			</plugin>

+		</plugins>

+	</build>

+</project>

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/CompositeTestSuite.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/CompositeTestSuite.java
new file mode 100644
index 0000000..efa9de3
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/CompositeTestSuite.java
@@ -0,0 +1,48 @@
+/* 

+ * 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.felix.ipojo.test.composite;

+

+import junit.framework.Test;

+

+import org.apache.felix.ipojo.junit4osgi.OSGiTestSuite;

+import org.apache.felix.ipojo.test.composite.exporter.ExportTestSuite;

+import org.apache.felix.ipojo.test.composite.importer.ImportTestSuite;

+import org.apache.felix.ipojo.test.composite.infrastructure.InfrastructureTestSuite;

+import org.apache.felix.ipojo.test.composite.instance.SimpleInstance;

+import org.apache.felix.ipojo.test.composite.instantiator.InstantiatorTestSuite;

+import org.apache.felix.ipojo.test.composite.provides.ProvidesTestSuite;

+import org.apache.felix.ipojo.test.composite.test.CompositeTest;

+import org.osgi.framework.BundleContext;

+

+public class CompositeTestSuite {

+    

+    public static Test suite(BundleContext bc) {

+        OSGiTestSuite ots = new OSGiTestSuite("iPOJO Composites Test Suite", bc);    

+        ots.addTest(InfrastructureTestSuite.suite(bc));

+        ots.addTest(InstantiatorTestSuite.suite(bc));

+        ots.addTest(ImportTestSuite.suite(bc));

+        ots.addTest(ExportTestSuite.suite(bc));

+        ots.addTestSuite(CompositeTest.class);

+        ots.addTestSuite(SimpleInstance.class);

+        ots.addTest(ProvidesTestSuite.suite(bc));

+

+        return ots;

+    }

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/Baz2CheckProvider.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/Baz2CheckProvider.java
new file mode 100644
index 0000000..662c8e2
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/Baz2CheckProvider.java
@@ -0,0 +1,81 @@
+/* 

+ * 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.felix.ipojo.test.composite.component;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.test.scenarios.service.BazService;

+import org.apache.felix.ipojo.test.scenarios.service.CheckService;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class Baz2CheckProvider implements CheckService {

+	

+	BazService fs;

+	

+	int simpleB = 0;

+	int objectB = 0;

+	int refB = 0;

+	int simpleU = 0;

+	int objectU = 0;

+	int refU = 0;

+

+	public boolean check() {

+		return fs.foo();

+	}

+

+	public Properties getProps() {

+		Properties props = new Properties();

+		props.put("result", new Boolean(fs.foo()));

+		props.put("voidB", new Integer(simpleB));

+		props.put("objectB", new Integer(objectB));

+		props.put("refB", new Integer(refB));

+		props.put("voidU", new Integer(simpleU));

+		props.put("objectU", new Integer(objectU));

+		props.put("refU", new Integer(refU));

+		props.put("boolean", new Boolean(fs.getBoolean()));

+		props.put("int", new Integer(fs.getInt()));

+		props.put("long", new Long(fs.getLong()));

+		props.put("double", new Double(fs.getDouble()));

+		if(fs.getObject() != null) { props.put("object", fs.getObject()); }

+		

+		return props;

+	}

+	

+	private void voidBind() {

+		simpleB++;

+	}

+	private void voidUnbind() {

+		simpleU++;

+	}

+	

+	protected void objectBind(Object o) {

+		if(o != null && o instanceof FooService) { objectB++; }

+	}

+	protected void objectUnbind(Object o) {

+		if(o != null && o instanceof FooService) { objectU++; }

+	}

+	

+	public void refBind(ServiceReference sr) {

+		if(sr != null) { refB++; }

+	}

+	public void refUnbind(ServiceReference sr) {

+		if(sr != null) { refU++; }

+	}

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/BazProviderType1.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/BazProviderType1.java
new file mode 100644
index 0000000..6917d39
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/BazProviderType1.java
@@ -0,0 +1,51 @@
+/* 

+ * 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.felix.ipojo.test.composite.component;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.test.scenarios.service.BazService;

+

+public class BazProviderType1 implements BazService {

+	

+	private int m_bar;

+	private String m_foo;

+

+	public boolean foo() {

+		return true;

+	}

+

+	public Properties fooProps() {

+		Properties p = new Properties();

+		p.put("bar", new Integer(m_bar));

+		p.put("foo", m_foo);

+		return p;

+	}

+	

+	public boolean getBoolean() { return true; }

+

+	public double getDouble() { return 1.0; }

+

+	public int getInt() { return 1; }

+

+	public long getLong() { return 1; }

+

+	public Boolean getObject() { return new Boolean(true); }

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/TataProvider.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/TataProvider.java
new file mode 100644
index 0000000..2607b55
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/TataProvider.java
@@ -0,0 +1,222 @@
+/* 

+ * 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.felix.ipojo.test.composite.component;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.test.composite.service.Tata;

+

+

+public class TataProvider implements Tata {

+    

+    int tata = 0;

+    int tataStr = 0;

+    int tataStrs = 0;

+    int tata_2 = 0;

+    int tata_3 = 0;

+    int tata1 = 0;

+    int tata1_1 = 0;

+    int tata5 = 0;

+    int tata5_1 = 0;

+    int tata5_2 = 0;

+    int tataBoolean = 0;

+    int tataBooleans = 0;

+    int tataByte = 0;

+    int tataBytes = 0;

+    private int add;

+    private int tataShorts;

+    private int tataShort;

+    private int tataLongs;

+    private int tataLong;

+    private int tataInts;

+    private int tataInt;

+    private int tataFloat;

+    private int tataFloats;

+    private int tataDoubles;

+    private int tataDouble;

+    private int tataChars;

+    private int tataChar;

+    

+    public Properties getPropsTata() {

+        Properties props = new Properties();

+        props.put("tata", new Integer(tata));

+        props.put("tataStr", new Integer(tataStr));

+        props.put("tataStrs", new Integer(tataStrs));

+        props.put("tata_2", new Integer(tata_2));

+        props.put("tata_3", new Integer(tata_3));

+        props.put("tata1", new Integer(tata1));

+        props.put("tata1_1", new Integer(tata1_1));

+        props.put("tata5", new Integer(tata5));

+        props.put("tata5_1", new Integer(tata5_1));

+        props.put("tata5_2", new Integer(tata5_2));

+        props.put("add", new Integer(add));

+        props.put("tataBoolean", new Integer(tataBoolean));

+        props.put("tataBoolean", new Integer(tataBoolean));

+        props.put("tataByte", new Integer(tataByte));

+        props.put("tataBytes", new Integer(tataBytes));

+        props.put("tataShort", new Integer(tataShort));

+        props.put("tataShorts", new Integer(tataShorts));

+        props.put("tataLongs", new Integer(tataLongs));

+        props.put("tataLong", new Integer(tataLong));

+        props.put("tataInt", new Integer(tataInt));

+        props.put("tataInts", new Integer(tataInts));

+        props.put("tataFloat", new Integer(tataFloat));

+        props.put("tataFloats", new Integer(tataFloats));

+        props.put("tataDouble", new Integer(tataDouble));

+        props.put("tataDoubles", new Integer(tataDoubles));

+        props.put("tataChar", new Integer(tataChar));

+        props.put("tataChars", new Integer(tataChars));

+        return props;

+    }

+

+    public void tata() {

+        tata++;

+    }

+

+    public String tataStr() {

+        tataStr++;

+        return "Tata";

+    }

+

+    public String[] tataStrs() {

+        tataStrs++;

+        return new String[] {"T", "A", "T", "A"};

+    }

+

+    public void tata(int i, int j) {

+        tata_2++;        

+    }

+

+    public void tata(String s) {

+        tata_3++;

+    }

+

+    public String tata1(String a) {

+        tata1++;

+       return a;

+    }

+

+    public String tata1(char[] a) {

+        tata1_1++;

+        String s = new String(a);

+        return s;

+    }

+

+    public String tata5(String a, int i) {

+       tata5++;

+       return a+i;

+    }

+

+    public String tata5(String[] a, int i) {

+       tata5_1++;

+       return ""+a.length + i;

+    }

+

+    public String tata5(String a, int[] i) {

+        tata5_2++;

+        return a + i.length;

+    }

+

+    public boolean tataBoolean(boolean b) {

+        tataBoolean++;

+        return b;

+    }

+

+    public boolean[] tataBooleans(boolean[] b) {

+        tataBooleans++;

+       return b;

+    }

+

+    public byte tataByte(byte b) {

+        tataByte++;

+        return b;

+    }

+

+    public byte[] tataBytes(byte[] b) {

+        tataBytes++;

+        return b;

+    }

+

+    public char tataChar(char c) {

+       tataChar++;

+       return c;

+    }

+

+    public char[] tataChars(char[] c) {

+        tataChars++;

+        return c;

+    }

+

+    public double tataDouble(double d) {

+        tataDouble++;

+        return d;

+    }

+

+    public double[] tataDoubles(double[] d) {

+        tataDoubles++;

+        return d;

+    }

+

+    public float tataFloat(float f) {

+        tataFloat++;

+        return f;

+    }

+

+    public float[] tataFloats(float[] f) {

+        tataFloats++;

+        return f;

+    }

+

+    public int tataInt(int i) {

+        tataInt++;

+        return i;

+    }

+

+    public int[] tataInts(int[] its) {

+        tataInts++;

+        return its;

+    }

+

+    public long tataLong(long l) {

+        tataLong++;

+        return l;

+    }

+

+    public long[] tataLongs(long[] l) {

+        tataLongs++;

+        return l;

+    }

+

+    public short tataShort(short s) {

+        tataShort++;

+        return s;

+    }

+

+    public short[] tataShorts(short[] s) {

+        tataShorts++;

+        return s;

+    }

+

+    public long add(int i, int j, int k) {

+        add++;

+        return i + j + k;

+    }

+

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/TotoProvider.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/TotoProvider.java
new file mode 100644
index 0000000..fb79bc4
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/TotoProvider.java
@@ -0,0 +1,73 @@
+/* 

+ * 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.felix.ipojo.test.composite.component;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.test.composite.service.Toto;

+

+

+public class TotoProvider implements Toto {

+    

+    private int i = 0;

+    public static int toto = 0;

+    public static int toto_2 = 0;

+    public static int toto_3 = 0;

+    public static int toto_4 = 0;

+    public static int toto1 = 0;

+    

+    public int count() {

+        return i;

+    }

+    

+    public void toto() {

+        toto++;        

+    }

+

+    public void toto(int i, int j) {

+        toto_2++;

+    }

+

+    public String toto(String a) {

+        toto_3++;

+        return a;

+    }

+

+    public String toto(String[] a) {

+        toto_4++;

+        return "toto";

+    }

+

+    public void toto1(String j) {

+        i++;

+        toto1++;        

+    }

+

+    public Properties getProps() {

+        Properties props = new Properties();

+        props.put("i", new Integer(i));

+        props.put("toto", new Integer(toto));

+        props.put("toto_2", new Integer(toto_2));

+        props.put("toto_3", new Integer(toto_3));

+        props.put("toto_4", new Integer(toto_4));

+        props.put("toto1", new Integer(toto1));

+        return props;

+    }

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/TotoProviderGlue.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/TotoProviderGlue.java
new file mode 100644
index 0000000..3ea3a88
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/component/TotoProviderGlue.java
@@ -0,0 +1,81 @@
+/* 

+ * 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.felix.ipojo.test.composite.component;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.test.composite.service.Toto;

+

+

+public class TotoProviderGlue implements Toto {

+    

+    Toto m_toto;

+    

+    private int i = 0;

+    public static int toto = 0;

+    public static int toto_2 = 0;

+    public static int toto_3 = 0;

+    public static int toto_4 = 0;

+    public static int toto1 = 0;

+    

+    public int count() {

+        return i;

+    }

+    

+    public void toto() {

+        toto++;

+        m_toto.toto();

+    }

+

+    public void toto(int i, int j) {

+        toto_2++;

+        m_toto.toto(i, j);

+    }

+

+    public String toto(String a) {

+        toto_3++;

+        return a;

+    }

+

+    public String toto(String[] a) {

+        toto_4++;

+        return "toto";

+    }

+

+    public void toto1(String j) {

+        i++;

+        toto1++;

+        m_toto.toto1(j);

+    }

+

+    public Properties getProps() {

+        Properties props = new Properties();

+        props.put("i", new Integer(i));

+        props.put("gtoto", new Integer(toto));

+        props.put("gtoto_2", new Integer(toto_2));

+        props.put("gtoto_3", new Integer(toto_3));

+        props.put("gtoto_4", new Integer(toto_4));

+        props.put("gtoto1", new Integer(toto1));

+        props.put("glue", "glue");

+        Properties p2 = m_toto.getProps();

+        props.putAll(p2);

+        return props;

+    }

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/ExportTestSuite.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/ExportTestSuite.java
new file mode 100644
index 0000000..d9b84f1
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/ExportTestSuite.java
@@ -0,0 +1,40 @@
+/* 

+ * 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.felix.ipojo.test.composite.exporter;

+

+import junit.framework.Test;

+import junit.framework.TestSuite;

+

+import org.apache.felix.ipojo.junit4osgi.OSGiTestSuite;

+import org.osgi.framework.BundleContext;

+

+public class ExportTestSuite extends TestSuite {

+

+	public static Test suite(BundleContext bc) {

+		OSGiTestSuite ots = new OSGiTestSuite("Composite Service Exporters Test Suite", bc);

+		ots.addTestSuite(SimpleExport.class);

+		ots.addTestSuite(OptionalExport.class);

+		ots.addTestSuite(MultipleExport.class);

+		ots.addTestSuite(OptionalMultipleExport.class);

+		ots.addTestSuite(FilteredExport.class);

+		ots.setBundleContext(bc);

+		return ots;

+	}

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/FilteredExport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/FilteredExport.java
new file mode 100644
index 0000000..938bb94
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/FilteredExport.java
@@ -0,0 +1,230 @@
+/* 

+ * 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.felix.ipojo.test.composite.exporter;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.BazService;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class FilteredExport extends OSGiTestCase {

+	

+	ComponentInstance export1;

+	Factory fooProvider;

+	ComponentInstance foo1 = null, foo2 = null;

+	

+	public void setUp() {

+		fooProvider = Utils.getFactoryByName(context, "BazProviderType");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p1 = new Properties();

+		p1.put("name", "foo1");

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		

+		try {

+			foo1 = fooProvider.createComponentInstance(p1);

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Fail to create foos : " + e.getMessage());

+		}

+		

+		foo1.stop();

+		foo2.stop();

+		

+		Factory factory = Utils.getFactoryByName(context, "composite.export.5");

+		Properties props = new Properties();

+		props.put("name", "export");

+		try {

+			export1 = factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Fail to instantiate exporter " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		foo1.dispose();

+		foo2.dispose();

+		export1.dispose();

+		foo1 = null;

+		foo2 = null;

+		export1 = null;

+	}

+	

+	public void test1() {

+		export1.start();

+		

+		// Check that no foo service are available

+		assertEquals("Check no foo service", Utils.getServiceReferences(context, FooService.class.getName(), null).length, 0);

+		

+		// Test invalidity

+		assertTrue("Check invalidity - 0", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 0", isFooServiceProvided());

+		assertEquals("Check number of provides - 0", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 1", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo2.start();

+		assertTrue("Check validity - 2", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke());

+		

+		foo1.stop();

+		assertTrue("Check invalidity - 3", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 0);

+		

+		foo2.stop();

+		assertTrue("Check invalidity - 4", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 0);

+		

+		foo2.start();

+		assertTrue("Check invalidity - 5", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 5", isFooServiceProvided());

+		assertEquals("Check number of provides - 5", countFooServiceProvided(), 0);

+	}

+	

+	public void test2() {

+		export1.start();

+		

+		// Test invalidity

+		assertTrue("Check invalidity - 0", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 0", isFooServiceProvided());

+		assertEquals("Check number of provides - 0", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 1", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo2.start();

+		assertTrue("Check validity - 2", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke());

+		

+		foo2.stop();

+		assertTrue("Check validity - 3", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 3", invoke());

+		

+		foo1.stop();

+		assertTrue("Check invalidity - 4", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 5", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 5", isFooServiceProvided());

+		assertEquals("Check number of provides - 5", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 5", invoke());

+	}

+	

+	public void test3() {

+		foo1.start();

+		foo2.start();

+		

+		export1.start();

+		assertTrue("Check validity - 1", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo1.stop();

+		assertTrue("Check invalidity - 2", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 0);

+		

+		foo2.stop();

+		assertTrue("Check invalidity - 3", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 4", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 4", invoke());

+	}

+	

+	public void test4() {

+		foo1.start();

+		foo2.start();

+		

+		export1.start();

+		assertTrue("Check validity - 1", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo2.stop();

+		assertTrue("Check validity - 2", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke());

+		

+		foo1.stop();

+		assertTrue("Check invalidity - 3", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 0);

+		

+		foo2.start();

+		assertTrue("Check invalidity - 4", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 0);

+	}

+	

+	

+	

+	private boolean isFooServiceProvided() {

+		ServiceReference ref = Utils.getServiceReferenceByName(context, BazService.class.getName(), export1.getInstanceName());

+		return ref != null;

+	}

+	

+	private int countFooServiceProvided() {

+		ServiceReference[] refs = Utils.getServiceReferences(context, BazService.class.getName(), "(instance.name="+export1.getInstanceName()+")");

+		return refs.length;

+	}

+	

+	private boolean invoke() {

+		ServiceReference ref = Utils.getServiceReferenceByName(context, BazService.class.getName(), export1.getInstanceName());

+		if(ref == null) { return false; }

+		BazService fs = (BazService) context.getService(ref);

+		return fs.foo();

+	}

+	

+	

+	

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/MultipleExport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/MultipleExport.java
new file mode 100644
index 0000000..10a0a4e
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/MultipleExport.java
@@ -0,0 +1,247 @@
+/* 

+ * 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.felix.ipojo.test.composite.exporter;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.BazService;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class MultipleExport extends OSGiTestCase {

+	

+	ComponentInstance export3;

+	Factory fooProvider;

+	ComponentInstance foo1 = null, foo2 = null;

+

+	public void setUp() {

+		fooProvider = Utils.getFactoryByName(context, "BazProviderType");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p1 = new Properties();

+		p1.put("name", "foo1");

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		

+		try {

+			foo1 = fooProvider.createComponentInstance(p1);

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Fail to create foos : " + e.getMessage());

+		}

+		

+		foo1.stop();

+		foo2.stop();

+		

+		Factory factory = Utils.getFactoryByName(context, "composite.export.3");

+		Properties props = new Properties();

+		props.put("name", "export");

+		try {

+			export3 = factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Fail to instantiate exporter " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		foo1.dispose();

+		foo2.dispose();

+		export3.dispose();

+		foo1 = null;

+		foo2 = null;

+		export3 = null;

+	}

+	

+	public void test1() {

+		export3.start();

+		

+		// Check that no foo service are available

+		assertEquals("Check no foo service", Utils.getServiceReferences(context, FooService.class.getName(), null).length, 0);

+		

+		// Test invalidity

+		assertTrue("Check invalidity - 0", export3.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 0", isFooServiceProvided());

+		assertEquals("Check number of provides - 0", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 1", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke(1));

+		

+		foo2.start();

+		assertTrue("Check validity - 2", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 2);

+		assertTrue("Check invocation - 2", invoke(2));

+		

+		foo1.stop();

+		assertTrue("Check validity - 3", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3 ("+countFooServiceProvided()+")", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 3", invoke(1));

+		

+		foo2.stop();

+		assertTrue("Check invalidity - 4", export3.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 0);

+		

+		foo2.start();

+		assertTrue("Check validity - 5", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 5", isFooServiceProvided());

+		assertEquals("Check number of provides - 5", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 5", invoke(1));

+	}

+	

+	public void test2() {

+		export3.start();

+		

+		// Test invalidity

+		assertTrue("Check invalidity - 0", export3.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 0", isFooServiceProvided());

+		assertEquals("Check number of provides - 0", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 1", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo2.start();

+		assertTrue("Check validity - 2", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 2);

+		assertTrue("Check invocation - 2", invoke(2));

+		

+		foo2.stop();

+		assertTrue("Check validity - 3", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 3", invoke(1));

+		

+		foo1.stop();

+		assertTrue("Check invalidity - 4", export3.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 5", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 5", isFooServiceProvided());

+		assertEquals("Check number of provides - 5", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 5", invoke(1));

+	}

+	

+	public void test3() {

+		foo1.start();

+		foo2.start();

+		

+		export3.start();

+		assertTrue("Check validity - 1", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 2);

+		assertTrue("Check invocation - 1", invoke(2));

+		

+		foo1.stop();

+		assertTrue("Check validity - 2", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke(1));

+		

+		foo2.stop();

+		assertTrue("Check invalidity - 3", export3.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 4", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 4", invoke(1));

+	}

+	

+	public void test4() {

+		foo1.start();

+		foo2.start();

+		

+		export3.start();

+		assertTrue("Check validity - 1", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 2);

+		assertTrue("Check invocation - 1", invoke(2));

+		

+		foo2.stop();

+		assertTrue("Check validity - 2", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke(1));

+		

+		foo1.stop();

+		assertTrue("Check invalidity - 3", export3.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 0);

+		

+		foo2.start();

+		assertTrue("Check validity - 4", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 4", invoke(1));

+	}

+	

+	

+	

+	private boolean isFooServiceProvided() {

+		ServiceReference ref = Utils.getServiceReferenceByName(context, BazService.class.getName(), export3.getInstanceName());

+		return ref != null;

+	}

+	

+	private int countFooServiceProvided() {

+		ServiceReference[] refs = Utils.getServiceReferences(context, BazService.class.getName(), "(instance.name="+export3.getInstanceName()+")");

+		return refs.length;

+	}

+	

+	private boolean invoke() {

+		ServiceReference ref = Utils.getServiceReferenceByName(context, BazService.class.getName(), export3.getInstanceName());

+		if(ref == null) { return false; }

+		BazService fs = (BazService) context.getService(ref);

+		context.ungetService(ref);

+		return fs.foo();

+	}

+	

+	private boolean invoke(int nb) {

+		ServiceReference[] refs = Utils.getServiceReferences(context, BazService.class.getName(), "(instance.name="+export3.getInstanceName()+")");

+		if(refs == null) { return false; }

+		if (nb > refs.length) { return false; }

+		for(int i = 0; i < nb; i++) {

+			BazService fs = (BazService) context.getService(refs[i]);

+			context.ungetService(refs[i]);

+			if(!fs.foo()) { return false; }

+		}

+		return true;

+	}

+	

+	

+	

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/OptionalExport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/OptionalExport.java
new file mode 100644
index 0000000..5c30d24
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/OptionalExport.java
@@ -0,0 +1,234 @@
+/* 

+ * 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.felix.ipojo.test.composite.exporter;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.BazService;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class OptionalExport extends OSGiTestCase {

+	

+	ComponentInstance export2;

+	Factory fooProvider;

+	ComponentInstance foo1 = null, foo2 = null;

+

+	public void setUp() {

+		fooProvider = Utils.getFactoryByName(context, "BazProviderType");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p1 = new Properties();

+		p1.put("name", "foo1");

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		

+		try {

+			foo1 = fooProvider.createComponentInstance(p1);

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Fail to create foos : " + e.getMessage());

+		}

+		

+		foo1.stop();

+		foo2.stop();

+		

+		Factory factory = Utils.getFactoryByName(context, "composite.export.2");

+		Properties props = new Properties();

+		props.put("name", "export");

+		try {

+			export2 = factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Fail to instantiate exporter " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		foo1.dispose();

+		foo2.dispose();

+		export2.dispose();

+		foo1 = null;

+		foo2 = null;

+		export2 = null;

+	}

+	

+	public void test1() {

+		export2.start();

+		

+		// Check that no foo service are available

+		assertEquals("Check no foo service", Utils.getServiceReferences(context, FooService.class.getName(), null).length, 0);

+		

+		// Test validity

+		assertTrue("Check validity - 0", export2.getState() == ComponentInstance.VALID);

+		assertFalse("Check providing - 0", isFooServiceProvided());

+		assertEquals("Check number of provides - 0", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 1", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo2.start();

+		assertTrue("Check validity - 2", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke());

+		

+		foo1.stop();

+		assertTrue("Check validity - 3", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3 ("+countFooServiceProvided()+")", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 3", invoke());

+		

+		foo2.stop();

+		assertTrue("Check validity - 4", export2.getState() == ComponentInstance.VALID);

+		assertFalse("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 0);

+		

+		foo2.start();

+		assertTrue("Check validity - 5", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 5", isFooServiceProvided());

+		assertEquals("Check number of provides - 5", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 5", invoke());

+	}

+	

+	public void test2() {

+		export2.start();

+		

+		// Test invalidity

+		assertTrue("Check validity - 0", export2.getState() == ComponentInstance.VALID);

+		assertFalse("Check providing - 0", isFooServiceProvided());

+		assertEquals("Check number of provides - 0", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 1", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo2.start();

+		assertTrue("Check validity - 2", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke());

+		

+		foo2.stop();

+		assertTrue("Check validity - 3", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 3", invoke());

+		

+		foo1.stop();

+		assertTrue("Check validity - 4", export2.getState() == ComponentInstance.VALID);

+		assertFalse("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 5", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 5", isFooServiceProvided());

+		assertEquals("Check number of provides - 5", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 5", invoke());

+	}

+	

+	public void test3() {

+		foo1.start();

+		foo2.start();

+		

+		export2.start();

+		assertTrue("Check validity - 1", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo1.stop();

+		assertTrue("Check validity - 2", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke());

+		

+		foo2.stop();

+		assertTrue("Check validity - 3", export2.getState() == ComponentInstance.VALID);

+		assertFalse("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 4", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 4", invoke());

+	}

+	

+	public void test4() {

+		foo1.start();

+		foo2.start();

+		

+		export2.start();

+		assertTrue("Check validity - 1", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo2.stop();

+		assertTrue("Check validity - 2", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke());

+		

+		foo1.stop();

+		assertTrue("Check validity - 3", export2.getState() == ComponentInstance.VALID);

+		assertFalse("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 0);

+		

+		foo2.start();

+		assertTrue("Check validity - 4", export2.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 4", invoke());

+	}

+	

+	

+	

+	private boolean isFooServiceProvided() {

+		ServiceReference ref = Utils.getServiceReferenceByName(context, BazService.class.getName(), export2.getInstanceName());

+		return ref != null;

+	}

+	

+	private int countFooServiceProvided() {

+		ServiceReference[] refs = Utils.getServiceReferences(context, BazService.class.getName(), "(instance.name="+export2.getInstanceName()+")");

+		return refs.length;

+	}

+	

+	private boolean invoke() {

+		ServiceReference ref = Utils.getServiceReferenceByName(context, BazService.class.getName(), export2.getInstanceName());

+		if(ref == null) { return false; }

+		BazService fs = (BazService) context.getService(ref);

+		return fs.foo();

+	}

+	

+	

+	

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/OptionalMultipleExport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/OptionalMultipleExport.java
new file mode 100644
index 0000000..997be4e
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/OptionalMultipleExport.java
@@ -0,0 +1,247 @@
+/* 

+ * 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.felix.ipojo.test.composite.exporter;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.BazService;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class OptionalMultipleExport extends OSGiTestCase {

+	

+	ComponentInstance export3;

+	Factory fooProvider;

+	ComponentInstance foo1 = null, foo2 = null;

+

+	public void setUp() {

+		fooProvider = Utils.getFactoryByName(context, "BazProviderType");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p1 = new Properties();

+		p1.put("name", "foo1");

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		

+		try {

+			foo1 = fooProvider.createComponentInstance(p1);

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Fail to create foos : " + e.getMessage());

+		}

+		

+		foo1.stop();

+		foo2.stop();

+		

+		Factory factory = Utils.getFactoryByName(context, "composite.export.4");

+		Properties props = new Properties();

+		props.put("name", "export");

+		try {

+			export3 = factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Fail to instantiate exporter " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		foo1.dispose();

+		foo2.dispose();

+		export3.dispose();

+		foo1 = null;

+		foo2 = null;

+		export3 = null;

+	}

+	

+	public void test1() {

+		export3.start();

+		

+		// Check that no foo service are available

+		assertEquals("Check no foo service", Utils.getServiceReferences(context, FooService.class.getName(), null).length, 0);

+		

+		// Test invalidity

+		assertTrue("Check validity - 0", export3.getState() == ComponentInstance.VALID);

+		assertFalse("Check providing - 0", isFooServiceProvided());

+		assertEquals("Check number of provides - 0", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 1", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke(1));

+		

+		foo2.start();

+		assertTrue("Check validity - 2", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 2);

+		assertTrue("Check invocation - 2", invoke(2));

+		

+		foo1.stop();

+		assertTrue("Check validity - 3", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3 ("+countFooServiceProvided()+")", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 3", invoke(1));

+		

+		foo2.stop();

+		assertTrue("Check validity - 4", export3.getState() == ComponentInstance.VALID);

+		assertFalse("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 0);

+		

+		foo2.start();

+		assertTrue("Check validity - 5", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 5", isFooServiceProvided());

+		assertEquals("Check number of provides - 5", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 5", invoke(1));

+	}

+	

+	public void test2() {

+		export3.start();

+		

+		// Test invalidity

+		assertTrue("Check validity - 0", export3.getState() == ComponentInstance.VALID);

+		assertFalse("Check providing - 0", isFooServiceProvided());

+		assertEquals("Check number of provides - 0", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 1", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo2.start();

+		assertTrue("Check validity - 2", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 2);

+		assertTrue("Check invocation - 2", invoke(2));

+		

+		foo2.stop();

+		assertTrue("Check validity - 3", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 3", invoke(1));

+		

+		foo1.stop();

+		assertTrue("Check validity - 4", export3.getState() == ComponentInstance.VALID);

+		assertFalse("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 5", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 5", isFooServiceProvided());

+		assertEquals("Check number of provides - 5", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 5", invoke(1));

+	}

+	

+	public void test3() {

+		foo1.start();

+		foo2.start();

+		

+		export3.start();

+		assertTrue("Check validity - 1", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 2);

+		assertTrue("Check invocation - 1", invoke(2));

+		

+		foo1.stop();

+		assertTrue("Check validity - 2", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke(1));

+		

+		foo2.stop();

+		assertTrue("Check validity - 3", export3.getState() == ComponentInstance.VALID);

+		assertFalse("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 4", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 4", invoke(1));

+	}

+	

+	public void test4() {

+		foo1.start();

+		foo2.start();

+		

+		export3.start();

+		assertTrue("Check validity - 1", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 2);

+		assertTrue("Check invocation - 1", invoke(2));

+		

+		foo2.stop();

+		assertTrue("Check validity - 2", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke(1));

+		

+		foo1.stop();

+		assertTrue("Check validity - 3", export3.getState() == ComponentInstance.VALID);

+		assertFalse("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 0);

+		

+		foo2.start();

+		assertTrue("Check validity - 4", export3.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 4", invoke(1));

+	}

+	

+	

+	

+	private boolean isFooServiceProvided() {

+		ServiceReference ref = Utils.getServiceReferenceByName(context, BazService.class.getName(), export3.getInstanceName());

+		return ref != null;

+	}

+	

+	private int countFooServiceProvided() {

+		ServiceReference[] refs = Utils.getServiceReferences(context, BazService.class.getName(), "(instance.name="+export3.getInstanceName()+")");

+		return refs.length;

+	}

+	

+	private boolean invoke() {

+		ServiceReference ref = Utils.getServiceReferenceByName(context, BazService.class.getName(), export3.getInstanceName());

+		if(ref == null) { return false; }

+		BazService fs = (BazService) context.getService(ref);

+		context.ungetService(ref);

+		return fs.foo();

+	}

+	

+	private boolean invoke(int nb) {

+		ServiceReference[] refs = Utils.getServiceReferences(context, BazService.class.getName(), "(instance.name="+export3.getInstanceName()+")");

+		if(refs == null) { return false; }

+		if (nb > refs.length) { return false; }

+		for(int i = 0; i < nb; i++) {

+			BazService fs = (BazService) context.getService(refs[i]);

+			context.ungetService(refs[i]);

+			if(!fs.foo()) { return false; }

+		}

+		return true;

+	}

+	

+	

+	

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/SimpleExport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/SimpleExport.java
new file mode 100644
index 0000000..5ee7cd7
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/exporter/SimpleExport.java
@@ -0,0 +1,234 @@
+/* 

+ * 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.felix.ipojo.test.composite.exporter;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.BazService;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class SimpleExport extends OSGiTestCase {

+	

+	ComponentInstance export1;

+	Factory fooProvider;

+	ComponentInstance foo1 = null, foo2 = null;

+

+	public void setUp() {

+		fooProvider = Utils.getFactoryByName(context, "BazProviderType");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p1 = new Properties();

+		p1.put("name", "foo1");

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		

+		try {

+			foo1 = fooProvider.createComponentInstance(p1);

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Fail to create foos : " + e.getMessage());

+		}

+		

+		foo1.stop();

+		foo2.stop();

+		

+		Factory factory = Utils.getFactoryByName(context, "composite.export.1");

+		Properties props = new Properties();

+		props.put("name", "export");

+		try {

+			export1 = factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Fail to instantiate exporter " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		foo1.dispose();

+		foo2.dispose();

+		export1.dispose();

+		foo1 = null;

+		foo2 = null;

+		export1 = null;

+	}

+	

+	public void test1() {

+		export1.start();

+		

+		// Check that no foo service are available

+		assertEquals("Check no foo service", Utils.getServiceReferences(context, FooService.class.getName(), null).length, 0);

+		

+		// Test invalidity

+		assertTrue("Check invalidity - 0", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 0", isFooServiceProvided());

+		assertEquals("Check number of provides - 0", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 1", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo2.start();

+		assertTrue("Check validity - 2", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke());

+		

+		foo1.stop();

+		assertTrue("Check validity - 3", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3 ("+countFooServiceProvided()+")", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 3", invoke());

+		

+		foo2.stop();

+		assertTrue("Check invalidity - 4", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 0);

+		

+		foo2.start();

+		assertTrue("Check validity - 5", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 5", isFooServiceProvided());

+		assertEquals("Check number of provides - 5", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 5", invoke());

+	}

+	

+	public void test2() {

+		export1.start();

+		

+		// Test invalidity

+		assertTrue("Check invalidity - 0", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 0", isFooServiceProvided());

+		assertEquals("Check number of provides - 0", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 1", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo2.start();

+		assertTrue("Check validity - 2", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke());

+		

+		foo2.stop();

+		assertTrue("Check validity - 3", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 3", invoke());

+		

+		foo1.stop();

+		assertTrue("Check invalidity - 4", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 5", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 5", isFooServiceProvided());

+		assertEquals("Check number of provides - 5", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 5", invoke());

+	}

+	

+	public void test3() {

+		foo1.start();

+		foo2.start();

+		

+		export1.start();

+		assertTrue("Check validity - 1", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo1.stop();

+		assertTrue("Check validity - 2", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke());

+		

+		foo2.stop();

+		assertTrue("Check invalidity - 3", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 0);

+		

+		foo1.start();

+		assertTrue("Check validity - 4", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 4", invoke());

+	}

+	

+	public void test4() {

+		foo1.start();

+		foo2.start();

+		

+		export1.start();

+		assertTrue("Check validity - 1", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 1", isFooServiceProvided());

+		assertEquals("Check number of provides - 1", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 1", invoke());

+		

+		foo2.stop();

+		assertTrue("Check validity - 2", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 2", isFooServiceProvided());

+		assertEquals("Check number of provides - 2", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 2", invoke());

+		

+		foo1.stop();

+		assertTrue("Check invalidity - 3", export1.getState() == ComponentInstance.INVALID);

+		assertFalse("Check providing - 3", isFooServiceProvided());

+		assertEquals("Check number of provides - 3", countFooServiceProvided(), 0);

+		

+		foo2.start();

+		assertTrue("Check validity - 4", export1.getState() == ComponentInstance.VALID);

+		assertTrue("Check providing - 4", isFooServiceProvided());

+		assertEquals("Check number of provides - 4", countFooServiceProvided(), 1);

+		assertTrue("Check invocation - 4", invoke());

+	}

+	

+	

+	

+	private boolean isFooServiceProvided() {

+		ServiceReference ref = Utils.getServiceReferenceByName(context, BazService.class.getName(), export1.getInstanceName());

+		return ref != null;

+	}

+	

+	private int countFooServiceProvided() {

+		ServiceReference[] refs = Utils.getServiceReferences(context, BazService.class.getName(), "(instance.name="+export1.getInstanceName()+")");

+		return refs.length;

+	}

+	

+	private boolean invoke() {

+		ServiceReference ref = Utils.getServiceReferenceByName(context, BazService.class.getName(), export1.getInstanceName());

+		if(ref == null) { return false; }

+		BazService fs = (BazService) context.getService(ref);

+		return fs.foo();

+	}

+	

+	

+	

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedFilteredImport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedFilteredImport.java
new file mode 100644
index 0000000..659705f
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedFilteredImport.java
@@ -0,0 +1,150 @@
+/* 

+ * 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.felix.ipojo.test.composite.importer;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class DelayedFilteredImport extends OSGiTestCase {

+	

+	ComponentInstance import1;

+	Factory fooProvider;

+	ComponentInstance foo1, foo2;

+

+	public void setUp() {

+		

+		Properties p = new Properties();

+		p.put("name", "importer");

+		Factory compFact = Utils.getFactoryByName(context, "composite.requires.1");

+		try {

+			import1 = compFact.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Cannot instantiate the component : " + e.getMessage());

+		}

+		

+		import1.stop();

+		

+		fooProvider = Utils.getFactoryByName(context, "FooProviderType-1");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p1 = new Properties();

+		p1.put("name", "foo1");

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo1 = fooProvider.createComponentInstance(p1);

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Cannot instantiate foo providers : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		foo1.dispose();

+		foo2.dispose();

+		import1.dispose();

+		foo1 = null;

+		foo2 = null;

+		import1 = null;

+	}

+	

+	public void testSimple() {

+		import1.start(); 

+		//Two providers

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import1);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo1.stop();

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo2.stop();		

+		assertTrue("Test component invalidity - 2", import1.getState() == ComponentInstance.INVALID);

+		

+		foo2.start();

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+	}

+	

+	public void testSimple2() {

+		import1.start(); 

+		//Two providers

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import1);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo2.stop();

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo1.stop();		

+		assertTrue("Test component invalidity - 2", import1.getState() == ComponentInstance.INVALID);

+		

+		foo1.start();

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+	}

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedMultipleImport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedMultipleImport.java
new file mode 100644
index 0000000..99b359c
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedMultipleImport.java
@@ -0,0 +1,156 @@
+/* 

+ * 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.felix.ipojo.test.composite.importer;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class DelayedMultipleImport extends OSGiTestCase {

+	

+	ComponentInstance import2;

+	Factory fooProvider;

+	ComponentInstance foo1, foo2;

+

+	public void setUp() {

+		

+		Properties p = new Properties();

+		p.put("name", "importer");

+		Factory compFact = Utils.getFactoryByName(context, "composite.requires.2");

+		try {

+			import2 = compFact.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Cannot instantiate the component : " + e.getMessage());

+		}

+		

+		import2.stop();

+		

+		fooProvider = Utils.getFactoryByName(context, "FooProviderType-1");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p1 = new Properties();

+		p1.put("name", "foo1");

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo1 = fooProvider.createComponentInstance(p1);

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Cannot instantiate foo providers : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		foo1.dispose();

+		foo2.dispose();

+		import2.dispose();

+		foo1 = null;

+		foo2 = null;

+		import2 = null;

+	}

+	

+	public void testSimple() {

+		import2.start(); 

+		//Two providers

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import2);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 2);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		fs = (FooService) sc.getService(refs[1]);

+		assertTrue("Test foo invocation (2)", fs.foo());

+		sc.ungetService(refs[1]);

+		

+		foo1.stop();

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo2.stop();		

+		assertTrue("Test component invalidity - 2", import2.getState() == ComponentInstance.INVALID);

+		

+		foo2.start();

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+	}

+	

+	public void testSimple2() {

+		import2.start(); 

+		//Two providers

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import2);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 2);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		fs = (FooService) sc.getService(refs[1]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[1]);

+		

+		foo2.stop();

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo1.stop();		

+		assertTrue("Test component invalidity - 2", import2.getState() == ComponentInstance.INVALID);

+		

+		foo1.start();

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+	}

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedOptionalImport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedOptionalImport.java
new file mode 100644
index 0000000..41ffb28
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedOptionalImport.java
@@ -0,0 +1,156 @@
+/* 

+ * 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.felix.ipojo.test.composite.importer;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class DelayedOptionalImport extends OSGiTestCase {

+	

+	ComponentInstance import3;

+	Factory fooProvider;

+	ComponentInstance foo1, foo2;

+

+	public void setUp() {

+		

+		Properties p = new Properties();

+		p.put("name", "importer");

+		Factory compFact = Utils.getFactoryByName(context, "composite.requires.3");

+		try {

+			import3 = compFact.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Cannot instantiate the component : " + e.getMessage());

+		}

+		

+		import3.stop();

+		

+		fooProvider = Utils.getFactoryByName(context, "FooProviderType-1");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p1 = new Properties();

+		p1.put("name", "foo1");

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo1 = fooProvider.createComponentInstance(p1);

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Cannot instantiate foo providers : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		foo1.dispose();

+		foo2.dispose();

+		import3.dispose();

+		foo1 = null;

+		foo2 = null;

+		import3 = null;

+	}

+	

+	public void testSimple() {

+		import3.start(); 

+		//Two providers

+		assertTrue("Test component validity", import3.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import3);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo1.stop();

+		assertTrue("Test component validity", import3.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import3);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo2.stop();		

+		assertTrue("Test component validity - 2", import3.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import3);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertEquals("Test foo non-availability inside the composite - 3.1", refs.length, 0);

+		

+		foo2.start();

+		assertTrue("Test component validity", import3.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import3);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+	}

+	

+	public void testSimple2() {

+		import3.start(); 

+		//Two providers

+		assertTrue("Test component validity", import3.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import3);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo2.stop();

+		assertTrue("Test component validity", import3.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import3);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo1.stop();		

+		assertTrue("Test component validity - 2", import3.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import3);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 0);

+		

+		foo1.start();

+		assertTrue("Test component validity", import3.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import3);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+	}

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedOptionalMultipleImport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedOptionalMultipleImport.java
new file mode 100644
index 0000000..de9d875
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedOptionalMultipleImport.java
@@ -0,0 +1,162 @@
+/* 

+ * 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.felix.ipojo.test.composite.importer;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class DelayedOptionalMultipleImport extends OSGiTestCase {

+	

+	ComponentInstance import4;

+	Factory fooProvider;

+	ComponentInstance foo1, foo2;

+

+	public void setUp() {

+		

+		Properties p = new Properties();

+		p.put("name", "importer");

+		Factory compFact = Utils.getFactoryByName(context, "composite.requires.4");

+		try {

+			import4 = compFact.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Cannot instantiate the component : " + e.getMessage());

+		}

+		

+		import4.stop();

+		

+		fooProvider = Utils.getFactoryByName(context, "FooProviderType-1");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p1 = new Properties();

+		p1.put("name", "foo1");

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo1 = fooProvider.createComponentInstance(p1);

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Cannot instantiate foo providers : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		foo1.dispose();

+		foo2.dispose();

+		import4.dispose();

+		foo1 = null;

+		foo2 = null;

+		import4 = null;

+	}

+	

+	public void testSimple() {

+		import4.start(); 

+		//Two providers

+		assertTrue("Test component validity", import4.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import4);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 2);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		fs = (FooService) sc.getService(refs[1]);

+		assertTrue("Test foo invocation (2)", fs.foo());

+		sc.ungetService(refs[1]);

+		

+		foo1.stop();

+		assertTrue("Test component validity", import4.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import4);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo2.stop();		

+		assertTrue("Test component validity - 2", import4.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import4);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertEquals("Test foo availability inside the composite - 1", refs.length, 0);

+		

+		foo2.start();

+		assertTrue("Test component validity", import4.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import4);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+	}

+	

+	public void testSimple2() {

+		import4.start(); 

+		//Two providers

+		assertTrue("Test component validity", import4.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import4);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 2);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		fs = (FooService) sc.getService(refs[1]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[1]);

+		

+		foo2.stop();

+		assertTrue("Test component validity", import4.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import4);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo1.stop();		

+		assertTrue("Test component validity - 2", import4.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import4);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertEquals("Test foo availability inside the composite - 1", refs.length, 0);

+		

+		foo1.start();

+		assertTrue("Test component validity", import4.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import4);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+	}

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedSimpleImport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedSimpleImport.java
new file mode 100644
index 0000000..e29055d
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/DelayedSimpleImport.java
@@ -0,0 +1,151 @@
+/* 

+ * 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.felix.ipojo.test.composite.importer;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class DelayedSimpleImport extends OSGiTestCase {

+	

+	ComponentInstance import1;

+	Factory fooProvider;

+	ComponentInstance foo1, foo2;

+

+	public void setUp() {

+		

+		Properties p = new Properties();

+		p.put("name", "importer");

+		Factory compFact = Utils.getFactoryByName(context, "composite.requires.1");

+		try {

+			import1 = compFact.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Cannot instantiate the component : " + e.getMessage());

+		}

+		

+		import1.stop();

+		

+		fooProvider = Utils.getFactoryByName(context, "FooProviderType-1");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p1 = new Properties();

+		p1.put("name", "foo1");

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo1 = fooProvider.createComponentInstance(p1);

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Cannot instantiate foo providers : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		foo1.dispose();

+		foo2.dispose();

+		import1.dispose();

+		foo1 = null;

+		foo2 = null;

+		import1 = null;

+	}

+	

+	public void testSimple() {

+        import1.start();

+

+		//Two providers

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import1);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo1.stop();

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 2", refs);

+		assertEquals("Test foo availability inside the composite - 2.2", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo2.stop();		

+		assertTrue("Test component invalidity - 2", import1.getState() == ComponentInstance.INVALID);

+		

+		foo2.start();

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+	}

+	

+	public void testSimple2() {

+		import1.start(); 

+		//Two providers

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import1);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo2.stop();

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo1.stop();		

+		assertTrue("Test component invalidity - 2", import1.getState() == ComponentInstance.INVALID);

+		

+		foo1.start();

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+	}

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/FilteredImport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/FilteredImport.java
new file mode 100644
index 0000000..69b3a37
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/FilteredImport.java
@@ -0,0 +1,147 @@
+/* 

+ * 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.felix.ipojo.test.composite.importer;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class FilteredImport extends OSGiTestCase {

+	

+	ComponentInstance import1;

+	Factory fooProvider;

+	Factory fooProvider2;

+	

+	ComponentInstance foo1, foo2;

+

+	public void setUp() {

+		Properties p = new Properties();

+		p.put("name", "importer");

+		Factory compFact = Utils.getFactoryByName(context, "composite.requires.5");

+		try {

+			import1 = compFact.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Cannot instantiate the component : " + e.getMessage());

+		}

+		import1.stop();

+		

+		fooProvider = Utils.getFactoryByName(context, "FooProviderType-1");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		fooProvider2 = Utils.getFactoryByName(context, "FooProviderType-2");

+		assertNotNull("Check fooProvider availability", fooProvider2);

+		

+		Properties p1 = new Properties();

+		p1.put("name", "foo1");

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo1 = fooProvider.createComponentInstance(p1);

+			foo2 = fooProvider2.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Cannot instantiate foo providers : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		foo1.dispose();

+		foo2.dispose();

+		import1.dispose();

+		foo1 = null;

+		foo2 = null;

+		import1 = null;

+	}

+	

+	public void testSimple() {

+		import1.start(); 

+		//Two providers

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import1);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo1.stop();

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo2.stop();		

+		assertTrue("Test component invalidity - 2", import1.getState() == ComponentInstance.INVALID);

+		

+		foo2.start();

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+	}

+	

+	public void testSimple2() {

+		import1.start(); 

+		//Two providers

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import1);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo2.stop();

+		assertTrue("Test component invalidity - 1", import1.getState() == ComponentInstance.INVALID);

+		

+		// Stop the second provider

+		foo1.stop();		

+		assertTrue("Test component invalidity - 2", import1.getState() == ComponentInstance.INVALID);

+		

+		foo1.start();

+		assertTrue("Test component invalidity - 3", import1.getState() == ComponentInstance.INVALID);

+		

+		foo2.start();

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+	}	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/ImportTestSuite.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/ImportTestSuite.java
new file mode 100644
index 0000000..2f25b2c
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/ImportTestSuite.java
@@ -0,0 +1,43 @@
+/* 

+ * 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.felix.ipojo.test.composite.importer;

+

+import junit.framework.Test;

+

+import org.apache.felix.ipojo.junit4osgi.OSGiTestSuite;

+import org.osgi.framework.BundleContext;

+

+public class ImportTestSuite {

+

+	public static Test suite(BundleContext bc) {

+	    OSGiTestSuite ots = new OSGiTestSuite("Composite Import Test Suite", bc);

+	    ots.addTestSuite(SimpleImport.class);

+	    ots.addTestSuite(DelayedSimpleImport.class);

+	    ots.addTestSuite(OptionalImport.class);

+	    ots.addTestSuite(DelayedOptionalImport.class);

+	    ots.addTestSuite(MultipleImport.class);

+	    ots.addTestSuite(DelayedMultipleImport.class);

+	    ots.addTestSuite(OptionalMultipleImport.class);

+	    ots.addTestSuite(DelayedOptionalMultipleImport.class);

+	    ots.addTestSuite(FilteredImport.class);

+	    ots.addTestSuite(DelayedFilteredImport.class);

+		return ots;

+	}

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/MultipleImport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/MultipleImport.java
new file mode 100644
index 0000000..4d5df53
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/MultipleImport.java
@@ -0,0 +1,190 @@
+/* 

+ * 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.felix.ipojo.test.composite.importer;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class MultipleImport extends OSGiTestCase {

+	

+	ComponentInstance import2;

+	Factory fooProvider;

+

+	public void setUp() {

+		fooProvider = Utils.getFactoryByName(context, "FooProviderType-1");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p = new Properties();

+		p.put("name", "importer");

+		Factory compFact = Utils.getFactoryByName(context, "composite.requires.2");

+		try {

+			import2 = compFact.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Cannot instantiate the component : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		import2.dispose();

+		import2 = null;

+	}

+	

+	public void testSimple() {

+		// No provider -> Invalid

+		assertTrue("Test component invalidity", import2.getState() == ComponentInstance.INVALID);

+		

+		ComponentInstance foo = null;

+		Properties p = new Properties();

+		p.put("name", "foo");

+		try {

+			foo = fooProvider.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo component " + e.getMessage());

+		}

+		

+		ComponentInstance foo2 = null;

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo2 component " + e.getMessage());

+		}

+		

+		// The foo service is available => import1 must be valid

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import2);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2 ("+refs.length+")", refs.length, 2);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		FooService fs2 = (FooService) sc.getService(refs[1]);

+		assertTrue("Test foo invocation", fs2.foo());

+		sc.ungetService(refs[0]);

+		sc.ungetService(refs[1]);

+		

+		// Stop the second provider

+		foo2.dispose();

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 2", refs);

+		assertEquals("Test foo availability inside the composite - 2.1 ("+refs.length+")", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// stop the foo provider

+		foo.stop();

+		

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 2", import2.getState() == ComponentInstance.INVALID);

+		

+		foo.start();

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo.dispose(); 

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 3", import2.getState() == ComponentInstance.INVALID);

+	}

+	

+	public void testSimple2() {

+		// No provider -> Invalid

+		assertTrue("Test component invalidity", import2.getState() == ComponentInstance.INVALID);

+		

+		ComponentInstance foo1 = null;

+		Properties p = new Properties();

+		p.put("name", "foo");

+		try {

+			foo1 = fooProvider.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo component " + e.getMessage());

+		}

+		

+		ComponentInstance foo2 = null;

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo2 component " + e.getMessage());

+		}

+		

+		// The foo service is available => import1 must be valid

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import2);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2 ("+refs.length+")", refs.length, 2);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		FooService fs2 = (FooService) sc.getService(refs[1]);

+		assertTrue("Test foo invocation", fs2.foo());

+		sc.ungetService(refs[0]);

+		sc.ungetService(refs[1]);

+		

+		// Stop the first provider

+		foo1.stop();

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 2", refs);

+		assertEquals("Test foo availability inside the composite - 2.1 ("+refs.length+")", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// stop the second foo provider

+		foo2.dispose();

+		

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 2", import2.getState() == ComponentInstance.INVALID);

+		

+		foo1.start();

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo1.dispose(); 

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 3", import2.getState() == ComponentInstance.INVALID);

+	}

+

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/OptionalImport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/OptionalImport.java
new file mode 100644
index 0000000..69cd1bb
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/OptionalImport.java
@@ -0,0 +1,184 @@
+/* 

+ * 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.felix.ipojo.test.composite.importer;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class OptionalImport extends OSGiTestCase {

+	

+	ComponentInstance import3;

+	Factory fooProvider;

+

+	public void setUp() {

+		fooProvider = Utils.getFactoryByName(context, "FooProviderType-1");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p = new Properties();

+		p.put("name", "importer");

+		Factory compFact = Utils.getFactoryByName(context, "composite.requires.3");

+		try {

+			import3 = compFact.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Cannot instantiate the component : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		import3.dispose();

+		import3 = null;

+	}

+	

+	public void testSimple() {

+		// No provider -> valid

+		assertTrue("Test component invalidity", import3.getState() == ComponentInstance.VALID);

+		

+		ComponentInstance foo = null;

+		Properties p = new Properties();

+		p.put("name", "foo");

+		try {

+			foo = fooProvider.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo component " + e.getMessage());

+		}

+		

+		ComponentInstance foo2 = null;

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo2 component " + e.getMessage());

+		}

+		

+		// The foo service is available => import1 must be valid

+		assertTrue("Test component validity", import3.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import3);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo2.dispose();

+		assertTrue("Test component validity", import3.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import3);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 2", refs);

+		assertEquals("Test foo availability inside the composite - 2.1 ("+refs.length+")", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// stop the foo provider

+		foo.stop();

+		

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 2", import3.getState() == ComponentInstance.VALID);

+		

+		foo.start();

+		assertTrue("Test component validity", import3.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import3);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo.dispose(); 

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 3", import3.getState() == ComponentInstance.VALID);

+	}

+	

+	public void testSimple2() {

+		// No provider -> valid

+		assertTrue("Test component invalidity", import3.getState() == ComponentInstance.VALID);

+		

+		ComponentInstance foo1 = null;

+		Properties p = new Properties();

+		p.put("name", "foo");

+		try {

+			foo1 = fooProvider.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo component " + e.getMessage());

+		}

+		

+		ComponentInstance foo2 = null;

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo2 component " + e.getMessage());

+		}

+		

+		// The foo service is available => import1 must be valid

+		assertTrue("Test component validity", import3.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import3);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo1.stop();

+		assertTrue("Test component validity", import3.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import3);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 2", refs);

+		assertEquals("Test foo availability inside the composite - 2.1 ("+refs.length+")", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// stop the foo provider

+		foo2.dispose();

+		

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 2", import3.getState() == ComponentInstance.VALID);

+		

+		foo1.start();

+		assertTrue("Test component validity", import3.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import3);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo1.dispose(); 

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 3", import3.getState() == ComponentInstance.VALID);

+	}

+

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/OptionalMultipleImport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/OptionalMultipleImport.java
new file mode 100644
index 0000000..811301d
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/OptionalMultipleImport.java
@@ -0,0 +1,201 @@
+/* 

+ * 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.felix.ipojo.test.composite.importer;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class OptionalMultipleImport extends OSGiTestCase {

+	

+	ComponentInstance import2;

+	Factory fooProvider;

+

+	public void setUp() {

+		fooProvider = Utils.getFactoryByName(context, "FooProviderType-1");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p = new Properties();

+		p.put("name", "importer");

+		Factory compFact = Utils.getFactoryByName(context, "composite.requires.4");

+		try {

+			import2 = compFact.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Cannot instantiate the component : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		import2.dispose();

+		import2 = null;

+	}

+	

+	public void testSimple() {

+		// No provider -> valid

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		

+		ComponentInstance foo = null;

+		Properties p = new Properties();

+		p.put("name", "foo");

+		try {

+			foo = fooProvider.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo component " + e.getMessage());

+		}

+		

+		ComponentInstance foo2 = null;

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo2 component " + e.getMessage());

+		}

+		

+		// The foo service is available => import1 must be valid

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import2);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2 ("+refs.length+")", refs.length, 2);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		FooService fs2 = (FooService) sc.getService(refs[1]);

+		assertTrue("Test foo invocation", fs2.foo());

+		sc.ungetService(refs[0]);

+		sc.ungetService(refs[1]);

+		

+		// Stop the second provider

+		foo2.dispose();

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 2", refs);

+		assertEquals("Test foo availability inside the composite - 2.1 ("+refs.length+")", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// stop the foo provider

+		foo.stop();

+		

+		// No provider -> valid

+		assertTrue("Test component validity - 2", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertEquals("Test foo non-availability inside the composite - 1", refs.length, 0);

+		

+		foo.start();

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo.dispose(); 

+		// No provider -> Invalid

+		assertTrue("Test component validity - 3", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertEquals("Test foo non-availability inside the composite - 2", refs.length, 0);

+	}

+	

+	public void testSimple2() {

+		// No provider -> Invalid

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		

+		ComponentInstance foo1 = null;

+		Properties p = new Properties();

+		p.put("name", "foo");

+		try {

+			foo1 = fooProvider.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo component " + e.getMessage());

+		}

+		

+		ComponentInstance foo2 = null;

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo2 component " + e.getMessage());

+		}

+		

+		// The foo service is available => import1 must be valid

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import2);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2 ("+refs.length+")", refs.length, 2);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		FooService fs2 = (FooService) sc.getService(refs[1]);

+		assertTrue("Test foo invocation", fs2.foo());

+		sc.ungetService(refs[0]);

+		sc.ungetService(refs[1]);

+		

+		// Stop the first provider

+		foo1.stop();

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 2", refs);

+		assertEquals("Test foo availability inside the composite - 2.1 ("+refs.length+")", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// stop the second foo provider

+		foo2.dispose();

+		

+		// No provider -> Invalid

+		assertTrue("Test component validity - 2", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertEquals("Test foo non-availability inside the composite - 1", refs.length, 0);

+		

+		foo1.start();

+		assertTrue("Test component validity", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo1.dispose(); 

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 3", import2.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import2);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertEquals("Test foo non-availability inside the composite - 2", refs.length, 0);

+	}

+

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/SimpleImport.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/SimpleImport.java
new file mode 100644
index 0000000..9bcdc87
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/importer/SimpleImport.java
@@ -0,0 +1,184 @@
+/* 

+ * 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.felix.ipojo.test.composite.importer;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class SimpleImport extends OSGiTestCase {

+	

+	ComponentInstance import1;

+	Factory fooProvider;

+

+	public void setUp() {

+		fooProvider = Utils.getFactoryByName(context, "FooProviderType-1");

+		assertNotNull("Check fooProvider availability", fooProvider);

+		

+		Properties p = new Properties();

+		p.put("name", "importer");

+		Factory compFact = Utils.getFactoryByName(context, "composite.requires.1");

+		try {

+			import1 = compFact.createComponentInstance(p);

+		} catch(Exception e) {

+		    e.printStackTrace();

+			fail("Cannot instantiate the component : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		import1.dispose();

+		import1 = null;

+	}

+	

+	public void testSimple() {

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 0 ("+import1.getState()+")", import1.getState() == ComponentInstance.INVALID);

+		

+		ComponentInstance foo = null;

+		Properties p = new Properties();

+		p.put("name", "foo");

+		try {

+			foo = fooProvider.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo component " + e.getMessage());

+		}

+		

+		ComponentInstance foo2 = null;

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo2 component " + e.getMessage());

+		}

+		

+		// The foo service is available => import1 must be valid

+		assertTrue("Test component validity - 1", import1.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import1);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the second provider

+		foo2.dispose();

+		assertTrue("Test component validity - 2", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 2", refs);

+		assertEquals("Test foo availability inside the composite - 2.1 ("+refs.length+")", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// stop the foo provider

+		foo.stop();

+		

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 2", import1.getState() == ComponentInstance.INVALID);

+		

+		foo.start();

+		assertTrue("Test component validity - 3", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo.dispose(); 

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 3", import1.getState() == ComponentInstance.INVALID);

+	}

+	

+	public void testSimple2() {

+		// No provider -> Invalid

+		assertTrue("Test component invalidity", import1.getState() == ComponentInstance.INVALID);

+		

+		ComponentInstance foo1 = null;

+		Properties p = new Properties();

+		p.put("name", "foo");

+		try {

+			foo1 = fooProvider.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo component " + e.getMessage());

+		}

+		

+		ComponentInstance foo2 = null;

+		Properties p2 = new Properties();

+		p2.put("name", "foo2");

+		try {

+			foo2 = fooProvider.createComponentInstance(p2);

+		} catch(Exception e) {

+			fail("Fail to instantiate the foo2 component " + e.getMessage());

+		}

+		

+		// The foo service is available => import1 must be valid

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(import1);

+		ServiceReference[] refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 1", refs);

+		assertEquals("Test foo availability inside the composite - 1.2", refs.length, 1);

+		FooService fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// Stop the first provider

+		foo1.stop();

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 2", refs);

+		assertEquals("Test foo availability inside the composite - 2.1 ("+refs.length+")", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		// stop the second foo provider

+		foo2.dispose();

+		

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 2", import1.getState() == ComponentInstance.INVALID);

+		

+		foo1.start();

+		assertTrue("Test component validity", import1.getState() == ComponentInstance.VALID);

+		sc = Utils.getServiceContext(import1);

+		refs = Utils.getServiceReferences(sc, FooService.class.getName(), null);

+		assertNotNull("Test foo availability inside the composite - 3", refs);

+		assertEquals("Test foo availability inside the composite - 3.1", refs.length, 1);

+		fs = (FooService) sc.getService(refs[0]);

+		assertTrue("Test foo invocation", fs.foo());

+		sc.ungetService(refs[0]);

+		

+		foo1.dispose(); 

+		// No provider -> Invalid

+		assertTrue("Test component invalidity - 3", import1.getState() == ComponentInstance.INVALID);

+	}	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/EmptyCompositeTest.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/EmptyCompositeTest.java
new file mode 100644
index 0000000..a729b33
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/EmptyCompositeTest.java
@@ -0,0 +1,222 @@
+/* 

+ * 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.felix.ipojo.test.composite.infrastructure;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.architecture.ComponentTypeDescription;

+import org.apache.felix.ipojo.architecture.InstanceDescription;

+import org.apache.felix.ipojo.composite.CompositeManager;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.osgi.framework.InvalidSyntaxException;

+

+public class EmptyCompositeTest extends OSGiTestCase {

+	

+	public void testEmptyCompositeCreation() {

+		Factory factory = Utils.getFactoryByName(context, "composite.empty");

+		Properties props = new Properties();

+		props.put("name", "empty");

+		

+		ComponentInstance ci = null;

+		try {

+			ci = factory.createComponentInstance(props);

+		} catch (Exception e) {

+		    e.printStackTrace();

+			fail("Unacceptable configuration : " + e.getMessage());

+		}

+		

+		ComponentTypeDescription cd = ci.getFactory().getComponentDescription();

+		assertEquals("Check component type name", cd.getName(), "composite.empty");

+//		assertEquals("Check class name (" + cd.getClassName() + ")", cd.getClassName(), "composite");

+		assertEquals("Check offered service", cd.getprovidedServiceSpecification().length, 0);

+		assertEquals("Check configurable properties", cd.getProperties().length, 0);

+		

+		InstanceDescription id = ci.getInstanceDescription();

+		assertEquals("Check composite instance name", id.getName(), "empty");

+		assertEquals("Check composite instance state (" + id.getState() + ")", id.getState(), ComponentInstance.VALID);

+		

+		assertEquals("Check contained instance", id.getContainedInstances().length, 0);

+		

+		assertTrue("Check composite manager", ci instanceof CompositeManager);

+		CompositeManager cm = (CompositeManager) ci;

+		ServiceContext sc = cm.getServiceContext();

+		try {

+			assertEquals("Check number of factories imported", sc.getServiceReferences(Factory.class.getName(), null).length, context.getServiceReferences(Factory.class.getName(), null).length);

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e.getMessage());

+		}

+		ci.dispose();

+	}

+	

+	public void testInstanceCreation1() {

+		Factory factory = Utils.getFactoryByName(context, "composite.empty");

+		Properties props = new Properties();

+		props.put("name", "empty");

+		

+		ComponentInstance ci = null;

+		try {

+			ci = factory.createComponentInstance(props);

+		} catch(Exception e) {

+		    e.printStackTrace();

+			fail("Unacceptable configuration : " + e.getMessage());

+		}

+		

+		assertTrue("Check composite manager", ci instanceof CompositeManager);

+		CompositeManager cm = (CompositeManager) ci;

+		ServiceContext sc = cm.getServiceContext();

+		try {

+			assertEquals("Check number of factories imported", sc.getServiceReferences(Factory.class.getName(), null).length, context.getServiceReferences(Factory.class.getName(), null).length);

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e.getMessage());

+		}

+		

+		Properties props2 = new Properties();

+		props2.put("name", "empty2");

+		ComponentInstance ci2 = null;

+		try {

+			ci2 = factory.createComponentInstance(props2, sc);

+		} catch(Exception e) {

+		    e.printStackTrace();

+			fail("Unacceptable configuration : " + e.getMessage());

+		}

+		

+		InstanceDescription id = ci.getInstanceDescription();

+		assertEquals("Check composite instance name", id.getName(), "empty");

+		assertEquals("Check composite instance state", id.getState(), ComponentInstance.VALID);

+		assertEquals("Check contained instance", id.getContainedInstances().length, 1);

+		InstanceDescription id2 = id.getContainedInstances()[0];

+		assertEquals("Check composite instance name", id2.getName(), "empty2");

+		assertEquals("Check composite instance state", id2.getState(), ComponentInstance.VALID);

+		assertEquals("Check contained instance", id2.getContainedInstances().length, 0);

+		

+		ci2.dispose();

+		id = ci.getInstanceDescription();

+		assertEquals("Check composite instance name", id.getName(), "empty");

+		assertEquals("Check composite instance state", id.getState(), ComponentInstance.VALID);

+		assertEquals("Check contained instance", id.getContainedInstances().length, 0);

+		

+		ci.dispose();

+	}

+	

+	public void testInstanceCreation2() {

+		Factory factory = Utils.getFactoryByName(context, "composite.empty");

+		Properties props = new Properties();

+		props.put("name", "empty");

+		

+		ComponentInstance ci = null;

+		try {

+			ci = factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Unacceptable configuration : " + e.getMessage());

+		}

+		

+		assertTrue("Check composite manager", ci instanceof CompositeManager);

+		CompositeManager cm = (CompositeManager) ci;

+		ServiceContext sc = cm.getServiceContext();

+		try {

+			assertEquals("Check number of factories imported", sc.getServiceReferences(Factory.class.getName(), null).length, context.getServiceReferences(Factory.class.getName(), null).length);

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e.getMessage());

+		}

+		

+		Factory factory2 = Utils.getFactoryByName(sc, "composite.empty");

+		assertNotNull("Check factory2 not null", factory2);

+		Properties props2 = new Properties();

+		props2.put("name", "empty2");

+		ComponentInstance ci2 = null;

+		try {

+			ci2 = factory2.createComponentInstance(props2);

+		} catch(Exception e) {

+			fail("Unacceptable configuration : " + e.getMessage());

+		}

+		

+		InstanceDescription id = ci.getInstanceDescription();

+		assertEquals("Check composite instance name", id.getName(), "empty");

+		assertEquals("Check composite instance state", id.getState(), ComponentInstance.VALID);

+		assertEquals("Check contained instance", id.getContainedInstances().length, 1);

+		InstanceDescription id2 = id.getContainedInstances()[0];

+		assertEquals("Check composite instance name", id2.getName(), "empty2");

+		assertEquals("Check composite instance state", id2.getState(), ComponentInstance.VALID);

+		assertEquals("Check contained instance", id2.getContainedInstances().length, 0);

+		

+		ci2.dispose();

+		id = ci.getInstanceDescription();

+		assertEquals("Check composite instance name", id.getName(), "empty");

+		assertEquals("Check composite instance state", id.getState(), ComponentInstance.VALID);

+		assertEquals("Check contained instance", id.getContainedInstances().length, 0);

+		

+		ci.dispose();

+	}

+	

+	public void testInstanceCreation3() {

+		Factory factory = Utils.getFactoryByName(context, "composite.empty");

+		Properties props = new Properties();

+		props.put("name", "empty");

+		

+		ComponentInstance ci = null;

+		try {

+			ci = factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Unacceptable configuration : " + e.getMessage());

+		}

+		

+		assertTrue("Check composite manager", ci instanceof CompositeManager);

+		CompositeManager cm = (CompositeManager) ci;

+		ServiceContext sc = cm.getServiceContext();

+		try {

+			assertEquals("Check number of factories imported", sc.getServiceReferences(Factory.class.getName(), null).length, context.getServiceReferences(Factory.class.getName(), null).length);

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e.getMessage());

+		}

+		

+		Factory factory2 = Utils.getFactoryByName(sc, "composite.empty");

+		assertNotNull("Check factory2 not null", factory2);

+		Properties props2 = new Properties();

+		props2.put("name", "empty2");

+		ComponentInstance ci2 = null;

+		try {

+			ci2 = factory2.createComponentInstance(props2, sc);

+		} catch(Exception e) {

+			fail("Unacceptable configuration : " + e.getMessage());

+		}

+		

+		InstanceDescription id = ci.getInstanceDescription();

+		assertEquals("Check composite instance name", id.getName(), "empty");

+		assertEquals("Check composite instance state", id.getState(), ComponentInstance.VALID);

+		assertEquals("Check contained instance", id.getContainedInstances().length, 1);

+		InstanceDescription id2 = id.getContainedInstances()[0];

+		assertEquals("Check composite instance name", id2.getName(), "empty2");

+		assertEquals("Check composite instance state", id2.getState(), ComponentInstance.VALID);

+		assertEquals("Check contained instance", id2.getContainedInstances().length, 0);

+		

+		ci2.dispose();

+		id = ci.getInstanceDescription();

+		assertEquals("Check composite instance name", id.getName(), "empty");

+		assertEquals("Check composite instance state", id.getState(), ComponentInstance.VALID);

+		assertEquals("Check contained instance", id.getContainedInstances().length, 0);

+		

+		ci.dispose();

+	}

+

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/FactoryManagementTest.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/FactoryManagementTest.java
new file mode 100644
index 0000000..8e238a3
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/FactoryManagementTest.java
@@ -0,0 +1,263 @@
+/* 

+ * 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.felix.ipojo.test.composite.infrastructure;

+

+import java.util.Dictionary;

+import java.util.List;

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.FactoryStateListener;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.UnacceptableConfiguration;

+import org.apache.felix.ipojo.architecture.ComponentTypeDescription;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.metadata.Element;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.CheckService;

+import org.osgi.framework.BundleContext;

+import org.osgi.framework.ServiceReference;

+import org.osgi.framework.ServiceRegistration;

+

+public class FactoryManagementTest extends OSGiTestCase {

+	

+	private FakeFactory fake1 = new FakeFactory("fake");

+	private FakeFactory fake2 = new FakeFactory("fake2");

+	

+	private Factory emptyFactory;

+	private ComponentInstance empty;

+	

+	private class FakeFactory implements Factory {

+		

+		private String m_name;

+		public FakeFactory(String name) { m_name = name; } 

+

+		public ComponentInstance createComponentInstance(Dictionary arg0) throws UnacceptableConfiguration { return null; }

+		public ComponentInstance createComponentInstance(Dictionary arg0, ServiceContext arg1) throws UnacceptableConfiguration { return null; }

+		public Element getDescription() { return null; }

+		public String getName() { return m_name; }

+		public boolean isAcceptable(Dictionary arg0) { return false; }

+		public void reconfigure(Dictionary arg0) throws UnacceptableConfiguration {	}

+        public void addFactoryStateListener(FactoryStateListener arg0) { }

+        public List getMissingHandlers() { return null;  }

+        public List getRequiredHandlers() { return null;  }

+        public void removeFactoryStateListener(FactoryStateListener arg0) { }

+        public ComponentTypeDescription getComponentDescription() { return null; }

+        public String getClassName() { return ""; }

+        public int getState() { return Factory.VALID; }

+        public BundleContext getBundleContext() { return context; }

+

+	}

+	

+	public void setUp() {

+		emptyFactory = Utils.getFactoryByName(context, "composite.empty");

+		Properties props = new Properties();

+		props.put("name", "empty-1");

+		try {

+			empty = emptyFactory.createComponentInstance(props);

+		} catch (Exception e) { fail("Cannot create empty instance " + e.getMessage()); }

+	}

+	

+	public void tearDown() {

+		empty.dispose();

+		empty = null;

+	}

+	

+	public void testOneLevelExposition() {

+		ServiceReference[] parentsFactoryReferences = Utils.getServiceReferences(context, Factory.class.getName(), null);

+		ServiceContext sc = Utils.getServiceContext(empty);

+		ServiceReference[] internalFactoryReferences = Utils.getServiceReferences(sc, Factory.class.getName(), null);

+		

+		assertEquals("Check the number of available factories", parentsFactoryReferences.length, internalFactoryReferences.length);

+		

+		for(int i = 0; i < parentsFactoryReferences.length; i++) {

+			Factory factory = (Factory) context.getService(parentsFactoryReferences[i]);

+			assertTrue("Check the avaibility of " + factory.getName(), isExposed(factory, internalFactoryReferences, sc));

+		}

+	}

+	

+	public void testTwoLevelExposition() {

+		ServiceReference[] parentsFactoryReferences = Utils.getServiceReferences(context, Factory.class.getName(), null);

+		ServiceContext sc1 = Utils.getServiceContext(empty);

+		ServiceReference[] Level1FactoryReferences = Utils.getServiceReferences(sc1, Factory.class.getName(), null);

+		

+		Factory fact = Utils.getFactoryByName(sc1, "composite.empty");

+		Properties p = new Properties();

+		p.put("name", "empty2");

+		ComponentInstance empty2 = null;

+		try {

+			empty2 = fact.createComponentInstance(p);

+		} catch (Exception e) {

+			fail("Cannot instantiate empty2 instance : " + e.getMessage());

+		}

+		

+		ServiceContext sc2 = Utils.getServiceContext(empty2);

+		ServiceReference[] Level2FactoryReferences = Utils.getServiceReferences(sc2, Factory.class.getName(), null);

+		

+		assertEquals("Check the number of available factories - 1", parentsFactoryReferences.length, Level1FactoryReferences.length);

+		assertEquals("Check the number of available factories - 2", parentsFactoryReferences.length, Level2FactoryReferences.length);

+		assertEquals("Check the number of available factories - 3", Level1FactoryReferences.length, Level2FactoryReferences.length);

+		

+		for(int i = 0; i < Level1FactoryReferences.length; i++) {

+			Factory factory = (Factory) context.getService(parentsFactoryReferences[i]);

+			assertTrue("Check the avaibility of " + factory.getName(), isExposed(factory, Level2FactoryReferences, sc2));

+		}

+		

+		empty2.dispose();

+	}

+	

+	public void testDynamism() {

+		ServiceReference[] parentsFactoryReferences = Utils.getServiceReferences(context, Factory.class.getName(), null);

+		ServiceContext sc1 = Utils.getServiceContext(empty);

+		ServiceReference[] Level1FactoryReferences = Utils.getServiceReferences(sc1, Factory.class.getName(), null);

+		

+		Factory fact = Utils.getFactoryByName(sc1, "composite.empty");

+		Properties p = new Properties();

+		p.put("name", "empty2");

+		ComponentInstance empty2 = null;

+		try {

+			empty2 = fact.createComponentInstance(p);

+		} catch (Exception e) {

+			fail("Cannot instantiate empty2 instance : " + e.getMessage());

+		}

+		

+		ServiceContext sc2 = Utils.getServiceContext(empty2);

+		ServiceReference[] Level2FactoryReferences = Utils.getServiceReferences(sc2, Factory.class.getName(), null);

+		

+		assertEquals("Check the number of available factories - 1", parentsFactoryReferences.length, Level1FactoryReferences.length);

+		assertEquals("Check the number of available factories - 2", parentsFactoryReferences.length, Level2FactoryReferences.length);

+		assertEquals("Check the number of available factories - 3", Level1FactoryReferences.length, Level2FactoryReferences.length);

+		

+		for(int i = 0; i < Level1FactoryReferences.length; i++) {

+			Factory factory = (Factory) context.getService(parentsFactoryReferences[i]);

+			assertTrue("Check the avaibility of " + factory.getName(), isExposed(factory, Level2FactoryReferences, sc2));

+		}

+		

+		// Publish fake1

+		ServiceRegistration reg1 = context.registerService(Factory.class.getName(), fake1, null);

+		

+		parentsFactoryReferences = Utils.getServiceReferences(context, Factory.class.getName(), null);

+		sc1 = Utils.getServiceContext(empty);

+		Level1FactoryReferences = Utils.getServiceReferences(sc1, Factory.class.getName(), null);

+		sc2 = Utils.getServiceContext(empty2);

+		Level2FactoryReferences = Utils.getServiceReferences(sc2, Factory.class.getName(), null);

+		

+		assertEquals("Check the number of available factories - 1.1", parentsFactoryReferences.length, Level1FactoryReferences.length);

+		assertEquals("Check the number of available factories - 1.2", parentsFactoryReferences.length, Level2FactoryReferences.length);

+		assertEquals("Check the number of available factories - 1.3", Level1FactoryReferences.length, Level2FactoryReferences.length);

+		

+		// 	Publish fake2

+		ServiceRegistration reg2 = context.registerService(Factory.class.getName(), fake2, null);

+		

+		parentsFactoryReferences = Utils.getServiceReferences(context, Factory.class.getName(), null);

+		sc1 = Utils.getServiceContext(empty);

+		Level1FactoryReferences = Utils.getServiceReferences(sc1, Factory.class.getName(), null);

+		sc2 = Utils.getServiceContext(empty2);

+		Level2FactoryReferences = Utils.getServiceReferences(sc2, Factory.class.getName(), null);

+		

+		assertEquals("Check the number of available factories - 1.1", parentsFactoryReferences.length, Level1FactoryReferences.length);

+		assertEquals("Check the number of available factories - 1.2", parentsFactoryReferences.length, Level2FactoryReferences.length);

+		assertEquals("Check the number of available factories - 1.3", Level1FactoryReferences.length, Level2FactoryReferences.length);

+		

+		reg1.unregister();

+		

+		parentsFactoryReferences = Utils.getServiceReferences(context, Factory.class.getName(), null);

+		sc1 = Utils.getServiceContext(empty);

+		Level1FactoryReferences = Utils.getServiceReferences(sc1, Factory.class.getName(), null);

+		sc2 = Utils.getServiceContext(empty2);

+		Level2FactoryReferences = Utils.getServiceReferences(sc2, Factory.class.getName(), null);

+		

+		assertEquals("Check the number of available factories - 1.1", parentsFactoryReferences.length, Level1FactoryReferences.length);

+		assertEquals("Check the number of available factories - 1.2", parentsFactoryReferences.length, Level2FactoryReferences.length);

+		assertEquals("Check the number of available factories - 1.3", Level1FactoryReferences.length, Level2FactoryReferences.length);

+		

+		reg2.unregister();

+		

+		parentsFactoryReferences = Utils.getServiceReferences(context, Factory.class.getName(), null);

+		sc1 = Utils.getServiceContext(empty);

+		Level1FactoryReferences = Utils.getServiceReferences(sc1, Factory.class.getName(), null);

+		sc2 = Utils.getServiceContext(empty2);

+		Level2FactoryReferences = Utils.getServiceReferences(sc2, Factory.class.getName(), null);

+		

+		assertEquals("Check the number of available factories - 1.1", parentsFactoryReferences.length, Level1FactoryReferences.length);

+		assertEquals("Check the number of available factories - 1.2", parentsFactoryReferences.length, Level2FactoryReferences.length);

+		assertEquals("Check the number of available factories - 1.3", Level1FactoryReferences.length, Level2FactoryReferences.length);

+		

+		empty2.dispose();

+	}

+	

+	public void testInvocation() {

+		ServiceContext sc1 = Utils.getServiceContext(empty);		

+		Factory fact = Utils.getFactoryByName(sc1, "composite.empty");

+		Properties p = new Properties();

+		p.put("name", "empty2");

+		ComponentInstance empty2 = null;

+		try {

+			empty2 = fact.createComponentInstance(p);

+		} catch (Exception e) {

+			fail("Cannot instantiate empty2 instance : " + e.getMessage());

+		}

+		

+		ServiceContext sc2 = Utils.getServiceContext(empty2);

+		

+		Factory fact1 = Utils.getFactoryByName(sc2, "SimpleCheckServiceProvider");

+		Properties props = new Properties();

+		props.put("name", "client");

+		ComponentInstance client = null;

+		try {

+			client = fact1.createComponentInstance(props);

+		} catch (Exception e) { e.printStackTrace(); fail("Cannot instantiate the client : " + e.getMessage()); }

+		

+		Factory fact2 = Utils.getFactoryByName(sc2, "FooProviderType-1");

+		Properties props2 = new Properties();

+		props2.put("name", "provider");

+		ComponentInstance provider = null;

+		try {

+			provider = fact2.createComponentInstance(props2);

+		} catch (Exception e) {

+			fail("Cannot instantiate the provider : " + e.getMessage());

+		}

+		

+		ServiceReference ref = sc2.getServiceReference(CheckService.class.getName());		

+		assertNotNull("Check ref existency", ref);

+		CheckService check = (CheckService) sc2.getService(ref);

+		

+		assertTrue("Check invocation", check.check());

+		client.dispose();

+		provider.dispose();

+		empty2.dispose();

+	}

+	

+	

+	

+	

+	private boolean isExposed(Factory fact, ServiceReference[] refs, ServiceContext sc) {

+		for(int i = 0; i < refs.length; i++) {

+			Factory f = (Factory) sc.getService(refs[i]);

+			if(fact.getName().equals(f.getName())) {

+				sc.ungetService(refs[i]);

+				return true; 

+			}

+			sc.ungetService(refs[i]);

+		}

+		return false;

+	}

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/InfrastructureTestSuite.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/InfrastructureTestSuite.java
new file mode 100644
index 0000000..051ba7b
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/InfrastructureTestSuite.java
@@ -0,0 +1,37 @@
+/* 

+ * 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.felix.ipojo.test.composite.infrastructure;

+

+import junit.framework.Test;

+

+import org.apache.felix.ipojo.junit4osgi.OSGiTestSuite;

+import org.osgi.framework.BundleContext;

+

+public class InfrastructureTestSuite {

+

+	public static Test suite(BundleContext bc) {

+		OSGiTestSuite ots = new OSGiTestSuite("Service Context Infrastructure Test", bc);

+		ots.addTestSuite(ServiceRegistryTest.class);

+		ots.addTestSuite(EmptyCompositeTest.class);

+		ots.addTestSuite(FactoryManagementTest.class);

+		ots.addTestSuite(ServiceRangeTest.class);

+		return ots;

+	}

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/ServiceRangeTest.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/ServiceRangeTest.java
new file mode 100644
index 0000000..740f129
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/ServiceRangeTest.java
@@ -0,0 +1,482 @@
+/* 

+ * 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.felix.ipojo.test.composite.infrastructure;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.CheckService;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.InvalidSyntaxException;

+import org.osgi.framework.ServiceReference;

+

+public class ServiceRangeTest extends OSGiTestCase {

+	

+	private Factory emptyFactory;

+	private ComponentInstance empty;

+

+	

+	public void setUp() {

+		emptyFactory = Utils.getFactoryByName(context, "composite.empty");

+		Properties props = new Properties();

+		props.put("name", "empty-1");

+		try {

+			empty = emptyFactory.createComponentInstance(props);

+		} catch(Exception e) { fail("Cannot create empty instance " + e.getMessage()); }

+	}

+	

+	public void tearDown() {

+		empty.dispose();

+		empty = null;

+	}

+	

+	public void testLevelOne1() {

+		ServiceContext sc2 = Utils.getServiceContext(empty);

+		

+		Factory fact1 = Utils.getFactoryByName(sc2, "SimpleCheckServiceProvider");

+		Properties props = new Properties();

+		props.put("name", "client");

+		ComponentInstance client = null;

+		try {

+			client = fact1.createComponentInstance(props);

+		} catch(Exception e) { fail("Cannot instantiate the client : " + e.getMessage()); }

+		

+		Factory fact2 = Utils.getFactoryByName(sc2, "FooProviderType-1");

+		Properties props2 = new Properties();

+		props2.put("name", "provider");

+		ComponentInstance provider = null;

+		try {

+			provider = fact2.createComponentInstance(props2);

+		} catch(Exception e) {

+			fail("Cannot instantiate the provider : " + e.getMessage());

+		}

+		

+		ServiceReference ref = sc2.getServiceReference(CheckService.class.getName());

+		CheckService check = (CheckService) sc2.getService(ref);

+		

+		assertTrue("Check invocation", check.check());

+		

+		sc2.ungetService(ref);

+		

+		// Check visibility 

+		assertNotNull("Check foo service visible inside the composite", sc2.getServiceReference(FooService.class.getName()));

+		assertNotNull("Check check service visible inside the composite", sc2.getServiceReference(CheckService.class.getName()));

+		// Check invisibilty

+		assertNull("Check foo service invisible inside the context", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+		

+		provider.dispose();

+		client.dispose();

+		 

+		assertNull("Check foo service invisible inside the composite", sc2.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service invisible inside the composite", sc2.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible from the context", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+	}

+	

+	public void testLevelOne2() {

+		ServiceContext sc2 = Utils.getServiceContext(empty);

+		

+		Factory fact1 = Utils.getFactoryByName(sc2, "SimpleCheckServiceProvider");

+		Properties props = new Properties();

+		props.put("name", "client");

+		ComponentInstance client = null;

+		try {

+			client = fact1.createComponentInstance(props, sc2);

+		} catch(Exception e) { fail("Cannot instantiate the client : " + e.getMessage()); }

+		

+		Factory fact2 = Utils.getFactoryByName(sc2, "FooProviderType-1");

+		Properties props2 = new Properties();

+		props2.put("name", "provider");

+		ComponentInstance provider = null;

+		try {

+			provider = fact2.createComponentInstance(props2, sc2);

+		} catch(Exception e) {

+			fail("Cannot instantiate the provider : " + e.getMessage());

+		}

+		

+		ServiceReference ref = sc2.getServiceReference(CheckService.class.getName());

+		CheckService check = (CheckService) sc2.getService(ref);

+		

+		assertTrue("Check invocation", check.check());

+		

+		sc2.ungetService(ref);

+		

+		// Check visibility 

+		assertNotNull("Check foo service visible inside the composite", sc2.getServiceReference(FooService.class.getName()));

+		assertNotNull("Check check service visible inside the composite", sc2.getServiceReference(CheckService.class.getName()));

+		// Check invisibilty

+		assertNull("Check foo service invisible inside the context", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+		

+		client.dispose();

+		provider.dispose();

+		 

+		assertNull("Check foo service visible inside the composite 2", sc2.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service visible inside the composite 2", sc2.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the global", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+	}

+	

+	public void testLevelOne3() {

+		ServiceContext sc2 = Utils.getServiceContext(empty);

+		

+		Factory fact1 = Utils.getFactoryByName(context, "SimpleCheckServiceProvider");

+		Properties props = new Properties();

+		props.put("name", "client");

+		ComponentInstance client = null;

+		try {

+			client = fact1.createComponentInstance(props, sc2);

+		} catch(Exception e) { fail("Cannot instantiate the client : " + e.getMessage()); }

+		

+		Factory fact2 = Utils.getFactoryByName(context, "FooProviderType-1");

+		Properties props2 = new Properties();

+		props2.put("name", "provider");

+		ComponentInstance provider = null;

+		try {

+			provider = fact2.createComponentInstance(props2, sc2);

+		} catch(Exception e) {

+			fail("Cannot instantiate the provider : " + e.getMessage());

+		}

+		

+		ServiceReference ref = sc2.getServiceReference(CheckService.class.getName());

+		CheckService check = (CheckService) sc2.getService(ref);

+		

+		assertTrue("Check invocation", check.check());

+		

+		sc2.ungetService(ref);

+		

+		// Check visibility 

+		assertNotNull("Check foo service visible inside the composite", sc2.getServiceReference(FooService.class.getName()));

+		assertNotNull("Check check service visible inside the composite", sc2.getServiceReference(CheckService.class.getName()));

+		// Check invisibilty

+		assertNull("Check foo service invisible inside the context", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+		

+		client.dispose();

+		provider.dispose();

+		 

+		assertNull("Check foo service visible inside the composite 2", sc2.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service visible inside the composite 2", sc2.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the global", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+	}

+	

+	public void testLevelTwo1() {

+		ServiceContext sc1 = Utils.getServiceContext(empty);		

+		Factory fact = Utils.getFactoryByName(sc1, "composite.empty");

+		Properties p = new Properties();

+		p.put("name", "empty2");

+		ComponentInstance empty2 = null;

+		try {

+			empty2 = fact.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Cannot instantiate empty2 instance : " + e.getMessage());

+		}

+		

+		ServiceContext sc2 = Utils.getServiceContext(empty2);

+		

+		Factory fact1 = Utils.getFactoryByName(sc2, "SimpleCheckServiceProvider");

+		Properties props = new Properties();

+		props.put("name", "client");

+		ComponentInstance client = null;

+		try {

+			client = fact1.createComponentInstance(props);

+		} catch(Exception e) { fail("Cannot instantiate the client : " + e.getMessage()); }

+		

+		Factory fact2 = Utils.getFactoryByName(sc2, "FooProviderType-1");

+		Properties props2 = new Properties();

+		props2.put("name", "provider");

+		ComponentInstance provider = null;

+		try {

+			provider = fact2.createComponentInstance(props2);

+		} catch(Exception e) {

+			fail("Cannot instantiate the provider : " + e.getMessage());

+		}

+		

+		ServiceReference ref = sc2.getServiceReference(CheckService.class.getName());

+		CheckService check = (CheckService) sc2.getService(ref);

+		

+		assertTrue("Check invocation", check.check());

+		

+		sc2.ungetService(ref);

+		

+		//	Check visibility 

+		assertNotNull("Check foo service visible inside the composite 2", sc2.getServiceReference(FooService.class.getName()));

+		assertNotNull("Check check service visible inside the composite 2", sc2.getServiceReference(CheckService.class.getName()));

+		// Check invisibilty

+		assertNull("Check foo service invisible inside the composite 1", sc1.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service invisible inside the composite 1", sc1.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the global", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+		

+		client.dispose();

+		provider.dispose();

+		 

+		assertNull("Check foo service visible inside the composite 2", sc2.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service visible inside the composite 2", sc2.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the composite 1", sc1.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service invisible inside the composite 1", sc1.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the global", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+		empty2.dispose();

+	}

+	

+	public void testLevelTwo2() {

+		ServiceContext sc1 = Utils.getServiceContext(empty);		

+		Factory fact = Utils.getFactoryByName(sc1, "composite.empty");

+		Properties p = new Properties();

+		p.put("name", "empty2");

+		ComponentInstance empty2 = null;

+		try {

+			empty2 = fact.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Cannot instantiate empty2 instance : " + e.getMessage());

+		}

+		

+		ServiceContext sc2 = Utils.getServiceContext(empty2);

+		

+		Factory fact1 = Utils.getFactoryByName(sc1, "SimpleCheckServiceProvider");

+		Properties props = new Properties();

+		props.put("name", "client");

+		ComponentInstance client = null;

+		try {

+			client = fact1.createComponentInstance(props, sc2);

+		} catch(Exception e) { fail("Cannot instantiate the client : " + e.getMessage()); }

+		

+		Factory fact2 = Utils.getFactoryByName(sc1, "FooProviderType-1");

+		Properties props2 = new Properties();

+		props2.put("name", "provider");

+		ComponentInstance provider = null;

+		try {

+			provider = fact2.createComponentInstance(props2, sc2);

+		} catch(Exception e) {

+			fail("Cannot instantiate the provider : " + e.getMessage());

+		}

+		

+		ServiceReference ref = sc2.getServiceReference(CheckService.class.getName());

+		CheckService check = (CheckService) sc2.getService(ref);

+		

+		assertTrue("Check invocation", check.check());

+		

+		sc2.ungetService(ref);

+		

+		//	Check visibility 

+		assertNotNull("Check foo service visible inside the composite 2", sc2.getServiceReference(FooService.class.getName()));

+		assertNotNull("Check check service visible inside the composite 2", sc2.getServiceReference(CheckService.class.getName()));

+		// Check invisibilty

+		assertNull("Check foo service invisible inside the composite 1", sc1.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service invisible inside the composite 1", sc1.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the global", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+		

+		client.dispose();

+		provider.dispose();

+		 

+		assertNull("Check foo service visible inside the composite 2", sc2.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service visible inside the composite 2", sc2.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the composite 1", sc1.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service invisible inside the composite 1", sc1.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the global", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+		empty2.dispose();

+	}

+	

+	public void testLevelTwo3() {

+		ServiceContext sc1 = Utils.getServiceContext(empty);		

+		Factory fact = Utils.getFactoryByName(sc1, "composite.empty");

+		Properties p = new Properties();

+		p.put("name", "empty2");

+		ComponentInstance empty2 = null;

+		try {

+			empty2 = fact.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Cannot instantiate empty2 instance : " + e.getMessage());

+		}

+		

+		ServiceContext sc2 = Utils.getServiceContext(empty2);

+		

+		Factory fact1 = Utils.getFactoryByName(context, "SimpleCheckServiceProvider");

+		Properties props = new Properties();

+		props.put("name", "client");

+		ComponentInstance client = null;

+		try {

+			client = fact1.createComponentInstance(props, sc2);

+		} catch(Exception e) { fail("Cannot instantiate the client : " + e.getMessage()); }

+		

+		Factory fact2 = Utils.getFactoryByName(context, "FooProviderType-1");

+		Properties props2 = new Properties();

+		props2.put("name", "provider");

+		ComponentInstance provider = null;

+		try {

+			provider = fact2.createComponentInstance(props2, sc2);

+		} catch(Exception e) {

+			fail("Cannot instantiate the provider : " + e.getMessage());

+		}

+		

+		ServiceReference ref = sc2.getServiceReference(CheckService.class.getName());

+		CheckService check = (CheckService) sc2.getService(ref);

+		

+		assertTrue("Check invocation", check.check());

+		

+		sc2.ungetService(ref);

+		

+		//	Check visibility 

+		assertNotNull("Check foo service visible inside the composite 2", sc2.getServiceReference(FooService.class.getName()));

+		assertNotNull("Check check service visible inside the composite 2", sc2.getServiceReference(CheckService.class.getName()));

+		// Check invisibilty

+		assertNull("Check foo service invisible inside the composite 1", sc1.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service invisible inside the composite 1", sc1.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the global", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+		

+		client.dispose();

+		provider.dispose();

+		 

+		assertNull("Check foo service visible inside the composite 2", sc2.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service visible inside the composite 2", sc2.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the composite 1", sc1.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service invisible inside the composite 1", sc1.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the global", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+		empty2.dispose();

+	}

+	

+	public void testLevelTwo4() {

+		ServiceContext sc1 = Utils.getServiceContext(empty);		

+		Factory fact = Utils.getFactoryByName(sc1, "composite.empty");

+		Properties p = new Properties();

+		p.put("name", "empty2");

+		ComponentInstance empty2 = null;

+		try {

+			empty2 = fact.createComponentInstance(p);

+		} catch(Exception e) {

+			fail("Cannot instantiate empty2 instance : " + e.getMessage());

+		}

+		

+		ServiceContext sc2 = Utils.getServiceContext(empty2);

+		

+		Factory fact1 = Utils.getFactoryByName(sc2, "SimpleCheckServiceProvider");

+		Properties props = new Properties();

+		props.put("name", "client");

+		ComponentInstance client = null;

+		try {

+			client = fact1.createComponentInstance(props, sc2);

+		} catch(Exception e) { fail("Cannot instantiate the client : " + e.getMessage()); }

+		

+		Factory fact2 = Utils.getFactoryByName(sc2, "FooProviderType-1");

+		Properties props2 = new Properties();

+		props2.put("name", "provider");

+		ComponentInstance provider = null;

+		try {

+			provider = fact2.createComponentInstance(props2, sc2);

+		} catch(Exception e) {

+			fail("Cannot instantiate the provider : " + e.getMessage());

+		}

+		

+		ServiceReference ref = sc2.getServiceReference(CheckService.class.getName());

+		CheckService check = (CheckService) sc2.getService(ref);

+		

+		assertTrue("Check invocation", check.check());

+		

+		sc2.ungetService(ref);

+		

+		//	Check visibility 

+		assertNotNull("Check foo service visible inside the composite 2", sc2.getServiceReference(FooService.class.getName()));

+		assertNotNull("Check check service visible inside the composite 2", sc2.getServiceReference(CheckService.class.getName()));

+		// Check invisibilty

+		assertNull("Check foo service invisible inside the composite 1", sc1.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service invisible inside the composite 1", sc1.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the global", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+		

+		client.dispose();

+		provider.dispose();

+		 

+		assertNull("Check foo service visible inside the composite 2", sc2.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service visible inside the composite 2", sc2.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the composite 1", sc1.getServiceReference(FooService.class.getName()));

+		assertNull("Check check service invisible inside the composite 1", sc1.getServiceReference(CheckService.class.getName()));

+		assertNull("Check foo service invisible inside the global", context.getServiceReference(FooService.class.getName()));

+		try {

+			assertNull("Check check service invisible inside the context", context.getServiceReferences(CheckService.class.getName(), "(instance.name=client)"));

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e);

+		}

+		empty2.dispose();

+	}

+	

+	

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/ServiceRegistryTest.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/ServiceRegistryTest.java
new file mode 100644
index 0000000..0b76bcb
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/infrastructure/ServiceRegistryTest.java
@@ -0,0 +1,245 @@
+/* 

+ * 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.felix.ipojo.test.composite.infrastructure;

+

+import java.util.Dictionary;

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.InstanceStateListener;

+import org.apache.felix.ipojo.architecture.ComponentTypeDescription;

+import org.apache.felix.ipojo.architecture.InstanceDescription;

+import org.apache.felix.ipojo.context.ServiceRegistry;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.scenarios.service.BarService;

+import org.osgi.framework.BundleContext;

+import org.osgi.framework.InvalidSyntaxException;

+import org.osgi.framework.ServiceEvent;

+import org.osgi.framework.ServiceListener;

+import org.osgi.framework.ServiceReference;

+import org.osgi.framework.ServiceRegistration;

+

+public class ServiceRegistryTest extends OSGiTestCase {

+	

+	private class svcListener implements ServiceListener {

+		public int registration = 0;

+		public int unregistration = 0;

+		public int modification = 0;

+		public void serviceChanged(ServiceEvent ev) {

+			if(ev.getType() == ServiceEvent.REGISTERED) { registration++; }

+			if(ev.getType() == ServiceEvent.UNREGISTERING) { unregistration++; }

+			if(ev.getType() == ServiceEvent.MODIFIED) { modification++; }

+		}

+	}

+	

+	private class barProvider implements BarService {

+

+		public boolean bar() { return true; }

+

+		public Properties getProps() { return null; }

+

+	}

+	

+	private class FakeComponent implements ComponentInstance {

+

+		public ComponentTypeDescription getComponentDescription() {

+			return null;

+		}

+

+		public BundleContext getContext() {

+			return null;

+		}

+

+		public ComponentFactory getFactory() {

+			return null;

+		}

+

+		public InstanceDescription getInstanceDescription() {

+			return null;

+		}

+

+		public String getInstanceName() {

+			return null;

+		}

+

+		public int getState() {

+			return 0;

+		}

+

+		public boolean isStarted() {

+			return false;

+		}

+

+		public void reconfigure(Dictionary dictionary) { }

+

+		public void start() { }

+

+		public void stop() { }

+		

+		public void dispose() { }

+

+		public void addInstanceStateListener(InstanceStateListener arg0) { }

+

+		public void removeInstanceStateListener(InstanceStateListener arg0) { }

+		

+	}

+	

+	public void testRegistrationAndListener() {

+		ComponentInstance im = new FakeComponent();

+		ComponentInstance im2 = new FakeComponent();

+		ServiceRegistry registry = new ServiceRegistry(context);

+		assertNotNull("Assert registry not null", registry);

+		svcListener all = new svcListener();

+		try {

+			assertNull("Check that there is no available service", registry.getServiceReferences(null, null));

+		} catch (InvalidSyntaxException e) { fail("Cannot query the registry : " + e.getMessage()); }

+		registry.addServiceListener(all);

+		

+		ServiceRegistration reg1 = registry.registerService(im, BarService.class.getName(), new barProvider(), null);

+		

+		try {

+			assertEquals("Check number of registred service", 1, registry.getServiceReferences(null, null).length);

+		} catch (InvalidSyntaxException e) { fail("Cannot query the registry : " + e.getMessage()); 

+		 }

+	

+	    ServiceRegistration reg2 = registry.registerService(im2, BarService.class.getName(), new barProvider(), null);

+			

+	   try {

+			assertEquals("Check number of registred service", 2, registry.getServiceReferences(null, null).length);

+		} catch (InvalidSyntaxException e) { fail("Cannot query the registry : " + e.getMessage()); }

+	    

+		assertEquals("Check the number of registration", 2, all.registration);

+		

+		Properties props = new Properties();

+		props.put("foo", "bar");

+		reg1.setProperties(props);

+		assertEquals("Check the number of modification", 1, all.modification);

+		

+		reg1.unregister();

+		assertEquals("Check the number of unregistration", 1, all.unregistration);

+		

+		reg2.setProperties(props);

+		assertEquals("Check the number of modification", 2, all.modification);

+		

+		reg2.unregister();

+		assertEquals("Check the number of unregistration", 2, all.unregistration);

+		

+		registry.removeServiceListener(all);

+	}

+	

+	public void testRegistrationAndFilter() {

+		ComponentInstance im = new FakeComponent();

+		ComponentInstance im2 = new FakeComponent();

+		ServiceRegistry registry = new ServiceRegistry(context);

+		svcListener filtered = new svcListener();

+		

+		try {

+			assertNull("Check that there is no available service", registry.getServiceReferences(null, null));

+		} catch (InvalidSyntaxException e) { fail("Cannot query the registry : " + e.getMessage()); }

+		  

+		registry.addServiceListener(filtered, "(foo=bar)");

+		

+		Properties props = new Properties();

+		props.put("foo", "bar");

+		ServiceRegistration reg1 = registry.registerService(im, BarService.class.getName(), new barProvider(), props);

+		

+		try {

+			assertEquals("Check number of registred service", 1, registry.getServiceReferences(null, null).length);

+		} catch (InvalidSyntaxException e) { fail("Cannot query the registry : " + e.getMessage()); }

+		  

+	  ServiceRegistration reg2 = registry.registerService(im2, BarService.class.getName(), new barProvider(), null);

+			

+	   try {

+			assertEquals("Check number of registred service", 2, registry.getServiceReferences(null, null).length);

+		} catch (InvalidSyntaxException e) { fail("Cannot query the registry : " + e.getMessage()); }

+			  

+		assertEquals("Check the number of registration", 1, filtered.registration);

+		

+		reg2.setProperties(props);

+		assertEquals("Check the number of modification", 1, filtered.modification);

+		// Follow the OSGi semantics of filters

+		

+		reg1.unregister();

+		reg2.unregister();

+		assertEquals("Check the number of unregistration", 2, filtered.unregistration);

+		registry.removeServiceListener(filtered);

+	}

+	

+	public void testGetService() {

+		ComponentInstance im = new FakeComponent();

+		ComponentInstance im2 = new FakeComponent();

+		ServiceRegistry registry = new ServiceRegistry(context);

+		

+		try {

+			assertNull("Check that there is no available service", registry.getServiceReferences(null, null));

+		} catch (InvalidSyntaxException e) { fail("Cannot query the registry : " + e.getMessage()); }

+		

+		Properties props = new Properties();

+		props.put("foo", "bar");

+		ServiceRegistration reg1 = registry.registerService(im, BarService.class.getName(), new barProvider(), props);

+		

+		ServiceReference ref = registry.getServiceReference(BarService.class.getName());

+		assertNotNull("Check ref not null", ref);

+		assertEquals("Test property", ref.getProperty("foo"), "bar");

+		BarService bar = (BarService) registry.getService(im2, ref);

+		assertTrue("Test invocation", bar.bar());

+		

+		reg1.unregister();

+		ref = registry.getServiceReference(BarService.class.getName());

+		assertNull("Check ref null", ref);

+	}

+	

+	public void testGetFilteredService() {

+		ComponentInstance im = new FakeComponent();

+		ComponentInstance im2 = new FakeComponent();

+		ServiceRegistry registry = new ServiceRegistry(context);

+		

+		try {

+			assertNull("Check that there is no available service", registry.getServiceReferences(null, null));

+		} catch (InvalidSyntaxException e) { fail("Cannot query the registry : " + e.getMessage()); }

+		

+		Properties props = new Properties();

+		props.put("foo", "bar");

+		ServiceRegistration reg1 = registry.registerService(im, BarService.class.getName(), new barProvider(), props);

+		ServiceRegistration reg2 = registry.registerService(im2, BarService.class.getName(), new barProvider(), null);

+		

+		ServiceReference[] ref = null;

+		try {

+			ref = registry.getServiceReferences(BarService.class.getName(), "(foo=bar)");

+		} catch (InvalidSyntaxException e) { fail("Registry query fail : " + e.getMessage()); }

+		assertNotNull("Check ref not null", ref);

+		assertEquals("Check ref count", ref.length, 1);

+		assertEquals("Test property", ref[0].getProperty("foo"), "bar");

+		BarService bar = (BarService) registry.getService(im2, ref[0]);

+		assertTrue("Test invocation", bar.bar());

+		

+		ref = null;

+		reg1.unregister();

+		try {

+			ref = registry.getServiceReferences(BarService.class.getName(), "(bar=foo)");

+		} catch (InvalidSyntaxException e) { fail("Registry query fail : " + e.getMessage()); }

+		assertNull("Check ref null", ref);

+		

+		reg2.unregister();

+	}

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instance/SimpleInstance.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instance/SimpleInstance.java
new file mode 100644
index 0000000..433f62f
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instance/SimpleInstance.java
@@ -0,0 +1,267 @@
+/* 

+ * 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.felix.ipojo.test.composite.instance;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.architecture.Architecture;

+import org.apache.felix.ipojo.architecture.InstanceDescription;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class SimpleInstance extends OSGiTestCase {

+

+	private ComponentFactory fooFactory1, fooFactory2;

+    private ComponentFactory compoFactory;

+	private ComponentInstance empty;

+	

+	

+	public void setUp() {

+        fooFactory1 = (ComponentFactory) Utils.getFactoryByName(context, "FooProviderType-1");

+        fooFactory2 = (ComponentFactory) Utils.getFactoryByName(context, "FooProviderType-Dyn2");

+        compoFactory = (ComponentFactory) Utils.getFactoryByName(context, "composite.inst.1");

+		Factory fact = Utils.getFactoryByName(context, "composite.empty");

+		Properties props = new Properties();

+		props.put("name", "empty-X");

+		try {

+			empty = fact.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot create the empty composite : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		empty.dispose();

+		empty = null;

+	}

+	

+	public void testCreation() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = compoFactory.createComponentInstance(props);

+		} catch(Exception e) {

+		    e.printStackTrace();

+			fail("Cannot instantiate under from " + compoFactory.getName() + " -> " + e.getMessage());

+		}

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		under.dispose();

+	}

+	

+	public void testServiceAvailability() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = compoFactory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}	

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(under);

+       

+		assertNotNull("Check service availability", sc.getServiceReference(FooService.class.getName()));

+        assertEquals("Check service provider", Utils.getServiceReferences(sc, FooService.class.getName(), null).length, 2);

+		

+		under.dispose();

+	}

+	

+	public void testCreationLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = compoFactory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+		    e.printStackTrace();

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		under.dispose();

+	}

+	

+	public void testServiceAvailabilityLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under-X");

+		ComponentInstance under = null;

+		try {

+			under = compoFactory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}	

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc2 = Utils.getServiceContext(under);

+        

+        assertNotNull("Check service availability", sc2.getServiceReference(FooService.class.getName()));

+        assertEquals("Check service providers", Utils.getServiceReferences(sc2, FooService.class.getName(), null).length, 2);

+		

+		under.dispose();

+	}

+	

+	public void testFactoryManagement() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = compoFactory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity - 1", under.getState() == ComponentInstance.VALID);

+		

+		fooFactory1.stop();

+		assertTrue("Check instance invalidity - 2", under.getState() == ComponentInstance.INVALID);

+        

+        fooFactory1.start();

+		assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+        

+		fooFactory2.stop();

+        assertTrue("Check instance invalidity", under.getState() == ComponentInstance.INVALID);

+		

+		fooFactory2.start();

+		assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+		

+		under.dispose();

+		fooFactory1.start();

+		fooFactory2.start();

+	}

+	

+	public void testFactoryManagementLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = compoFactory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity - 1", under.getState() == ComponentInstance.VALID);

+		

+		assertTrue("Check instance validity - 1", under.getState() == ComponentInstance.VALID);

+        

+        fooFactory1.stop();

+        assertTrue("Check instance invalidity - 2", under.getState() == ComponentInstance.INVALID);

+        

+        fooFactory1.start();

+        assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+        

+        fooFactory2.stop();

+        assertTrue("Check instance invalidity", under.getState() == ComponentInstance.INVALID);

+        

+        fooFactory2.start();

+        assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+        

+        under.dispose();

+        fooFactory1.start();

+        fooFactory2.start();

+	}

+	

+	public void atestArchitecture() { //TODO : to reactive

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = compoFactory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		ServiceReference ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		Architecture arch = (Architecture) context.getService(ref);

+		InstanceDescription id = arch.getInstanceDescription();

+		

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		InstanceDescription[] contained = id.getContainedInstances();

+		assertEquals("Check contained instances count (" + contained.length + ")", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.1");

+		

+		ComponentFactory fact1 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-1");

+		ComponentFactory fact2 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-2");

+		ComponentFactory fact3 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-3");

+		

+		fact1.stop();

+		assertTrue("Check instance validity - 2", under.getState() == ComponentInstance.VALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.1");

+		

+		fact2.stop();

+		assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.1");

+

+		fact3.stop();

+		assertTrue("Check instance invalidity", under.getState() == ComponentInstance.INVALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.INVALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 0);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.1");

+

+		fact1.start();

+		assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.1");

+

+		under.dispose();

+		fact2.start();

+		fact3.start();

+	}

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/ConfigurableInstantiation.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/ConfigurableInstantiation.java
new file mode 100644
index 0000000..a7de283
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/ConfigurableInstantiation.java
@@ -0,0 +1,101 @@
+/* 

+ * 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.felix.ipojo.test.composite.instantiator;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.ServiceReference;

+

+public class ConfigurableInstantiation extends OSGiTestCase {

+

+	private ComponentFactory acceptF;

+	private ComponentFactory refuse1F;

+	private ComponentFactory refuse2F;

+	

+	public void setUp() {

+		acceptF = (ComponentFactory) Utils.getFactoryByName(context, "composite.bar.5-accept");

+		refuse1F = (ComponentFactory) Utils.getFactoryByName(context, "composite.bar.5-refuse1");

+		refuse2F = (ComponentFactory) Utils.getFactoryByName(context, "composite.bar.5-refuse2");

+		

+	}

+	

+	public void tearDown() { }

+	

+	public void testAccept() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = acceptF.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(under);

+		ServiceReference ref = sc.getServiceReference(FooService.class.getName());

+		assertNotNull("Check refs not null", ref);

+		FooService foo = (FooService) sc.getService(ref);

+		Properties p = foo.fooProps();

+		boolean b = ((Boolean) p.get("boolProp")).booleanValue();

+		String s = (String) p.get("strProp");

+		int i = ( (Integer) p.get("intProp")).intValue();

+		assertTrue("Test boolean", b);

+		assertEquals("Test string", s, "foo");

+		

+		assertEquals("Test int", i, 5); // The code fix to 5.

+		under.dispose();

+	}

+	

+	public void testRefuse1() {

+		Properties props = new Properties();

+		props.put("name", "under-ref1");

+		ComponentInstance under = null;

+		try {

+			under = refuse1F.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		

+		assertTrue("Check that under is not valid", under.getState() == ComponentInstance.INVALID);

+        

+        under.dispose();

+	}

+	

+	public void testRefuse2() {

+		Properties props = new Properties();

+		props.put("name", "under-ref2");

+		ComponentInstance under = null;

+		try {

+			under = refuse2F.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		

+		assertTrue("Check that under is not valid", under.getState() == ComponentInstance.INVALID);

+        

+        under.dispose();

+	}

+	

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/InstantiatorTestSuite.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/InstantiatorTestSuite.java
new file mode 100644
index 0000000..7497b3a
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/InstantiatorTestSuite.java
@@ -0,0 +1,38 @@
+/* 

+ * 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.felix.ipojo.test.composite.instantiator;

+

+import junit.framework.Test;

+

+import org.apache.felix.ipojo.junit4osgi.OSGiTestSuite;

+import org.osgi.framework.BundleContext;

+

+public class InstantiatorTestSuite {

+

+	public static Test suite(BundleContext bc) {

+		OSGiTestSuite ots = new OSGiTestSuite("Composite Service Instantiation Test Suite", bc);

+		ots.addTestSuite(SimpleInstantiation.class);

+		ots.addTestSuite(OptionalInstantiation.class);

+		ots.addTestSuite(MultipleInstantiation.class);

+		ots.addTestSuite(OptionalMultipleInstantiation.class);

+		ots.addTestSuite(ConfigurableInstantiation.class);

+		return ots;

+	}

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/MultipleInstantiation.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/MultipleInstantiation.java
new file mode 100644
index 0000000..066f29d
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/MultipleInstantiation.java
@@ -0,0 +1,288 @@
+/* 

+ * 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.felix.ipojo.test.composite.instantiator;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.architecture.Architecture;

+import org.apache.felix.ipojo.architecture.InstanceDescription;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.BarService;

+import org.osgi.framework.ServiceReference;

+

+public class MultipleInstantiation extends OSGiTestCase {

+

+	private ComponentFactory bar2Factory;

+	private ComponentInstance empty;

+	

+	public void setUp() {

+		bar2Factory = (ComponentFactory) Utils.getFactoryByName(context, "composite.bar.2");

+		Factory fact = Utils.getFactoryByName(context, "composite.empty");

+		Properties props = new Properties();

+		props.put("name", "empty");

+		try {

+			empty = fact.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot create the empty composite : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		empty.dispose();

+		empty = null;

+	}

+	

+	public void testCreation() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar2Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		under.dispose();

+	}

+	

+	public void testServiceAvailability() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar2Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}	

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(under);

+		assertNotNull("Check service availability", sc.getServiceReference(BarService.class.getName()));

+		int count = Utils.getServiceReferences(sc, BarService.class.getName(), null).length;

+		assertEquals("Check service provider number : " + count, count, 3);

+		

+		under.dispose();

+	}

+	

+	public void testCreationLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar2Factory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		under.dispose();

+	}

+	

+	public void testServiceAvailabilityLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar2Factory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}	

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc2 = Utils.getServiceContext(under);

+		assertNotNull("Check service availability", sc2.getServiceReference(BarService.class.getName()));

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc2, BarService.class.getName(), null).length, 3);

+		

+		under.dispose();

+	}

+	

+	public void testFactoryManagement() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar2Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		ServiceContext sc = Utils.getServiceContext(under);

+		assertTrue("Check instance validity - 1", under.getState() == ComponentInstance.VALID);

+		

+		ComponentFactory fact1 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-1");

+		ComponentFactory fact2 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-2");

+		ComponentFactory fact3 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-3");

+		

+		fact1.stop();

+		assertTrue("Check instance validity - 2", under.getState() == ComponentInstance.VALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc, BarService.class.getName(), null).length, 2);

+		

+		fact2.stop();

+		assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc, BarService.class.getName(), null).length, 1);

+		

+		fact3.stop();

+		assertTrue("Check instance invalidity", under.getState() == ComponentInstance.INVALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc, BarService.class.getName(), null).length, 0);

+		

+		fact1.start();

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc, BarService.class.getName(), null).length, 1);

+		assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+		

+		under.dispose();

+		fact2.start();

+		fact3.start();

+	}

+	

+	public void testFactoryManagementLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar2Factory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity - 1", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc2 = Utils.getServiceContext(under);

+		

+		ComponentFactory fact1 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-1");

+		ComponentFactory fact2 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-2");

+		ComponentFactory fact3 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-3");

+		

+		fact1.stop();

+		assertTrue("Check instance validity - 2", under.getState() == ComponentInstance.VALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc2, BarService.class.getName(), null).length, 2);

+		

+		fact2.stop();

+		assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc2, BarService.class.getName(), null).length, 1);

+		

+		fact3.stop();

+		assertTrue("Check instance invalidity", under.getState() == ComponentInstance.INVALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc2, BarService.class.getName(), null).length, 0);

+		

+		fact1.start();

+		assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc2, BarService.class.getName(), null).length, 1);

+		

+		under.dispose();

+		fact2.start();

+		fact3.start();

+	}

+	public void testArchitecture() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar2Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		ServiceReference ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		Architecture arch = (Architecture) context.getService(ref);

+		InstanceDescription id = arch.getInstanceDescription();

+		

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		InstanceDescription[] contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 3);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.2");

+		

+		ComponentFactory fact1 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-1");

+		ComponentFactory fact2 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-2");

+		ComponentFactory fact3 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-3");

+		

+		fact1.stop();

+		assertTrue("Check instance validity - 2", under.getState() == ComponentInstance.VALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 2);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.2");

+		

+		fact2.stop();

+		assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.2");

+

+		fact3.stop();

+		assertTrue("Check instance invalidity", under.getState() == ComponentInstance.INVALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.INVALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 0);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.2");

+

+		fact1.start();

+		assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.2");

+

+		context.ungetService(ref);

+		under.dispose();

+		fact2.start();

+		fact3.start();

+	}

+	

+	

+	

+	

+	

+	

+	

+	

+	

+	

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/OptionalInstantiation.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/OptionalInstantiation.java
new file mode 100644
index 0000000..64f80f9
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/OptionalInstantiation.java
@@ -0,0 +1,279 @@
+/* 

+ * 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.felix.ipojo.test.composite.instantiator;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.architecture.Architecture;

+import org.apache.felix.ipojo.architecture.InstanceDescription;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.BarService;

+import org.osgi.framework.ServiceReference;

+

+public class OptionalInstantiation extends OSGiTestCase {

+

+	private ComponentFactory bar1Factory;

+	private ComponentInstance empty;

+	

+	public void setUp() {

+		bar1Factory = (ComponentFactory) Utils.getFactoryByName(context, "composite.bar.3");

+		Factory fact = Utils.getFactoryByName(context, "composite.empty");

+		Properties props = new Properties();

+		props.put("name", "empty");

+		try {

+			empty = fact.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot create the empty composite : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		empty.dispose();

+		empty = null;

+	}

+	

+	public void testCreation() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		under.dispose();

+	}

+	

+	public void testServiceAvailability() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}	

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(under);

+		assertNotNull("Check service availability", sc.getServiceReference(BarService.class.getName()));

+		

+		under.dispose();

+	}

+	

+	public void testCreationLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		under.dispose();

+	}

+	

+	public void testServiceAvailabilityLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}	

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc2 = Utils.getServiceContext(under);

+		assertNotNull("Check service availability", sc2.getServiceReference(BarService.class.getName()));

+		

+		under.dispose();

+	}

+	

+	public void testFactoryManagement() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity - 1", under.getState() == ComponentInstance.VALID);

+		

+		ComponentFactory fact1 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-1");

+		ComponentFactory fact2 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-2");

+		ComponentFactory fact3 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-3");

+		

+		fact1.stop();

+		assertTrue("Check instance validity - 2", under.getState() == ComponentInstance.VALID);

+		

+		fact2.stop();

+		assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+		

+		fact3.stop();

+		assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(under);

+		assertNull("Check that no Bar Service is available", sc.getServiceReference(BarService.class.getName()));

+		

+		fact1.start();

+		assertTrue("Check instance validity - 5", under.getState() == ComponentInstance.VALID);

+		

+		under.dispose();

+		fact2.start();

+		fact3.start();

+	}

+	

+	public void testFactoryManagementLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity - 1", under.getState() == ComponentInstance.VALID);

+		

+		ComponentFactory fact1 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-1");

+		ComponentFactory fact2 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-2");

+		ComponentFactory fact3 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-3");

+		

+		fact1.stop();

+		assertTrue("Check instance validity - 2", under.getState() == ComponentInstance.VALID);

+		

+		fact2.stop();

+		assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+		

+		fact3.stop();

+		assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+		

+		fact1.start();

+		assertTrue("Check instance validity - 5", under.getState() == ComponentInstance.VALID);

+		

+		under.dispose();

+		fact2.start();

+		fact3.start();

+	}

+	

+	public void testArchitecture() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		

+		ServiceReference ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		Architecture arch = (Architecture) context.getService(ref);

+		assertNotNull("Check architecture", arch);

+		InstanceDescription id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		InstanceDescription[] contained = id.getContainedInstances();

+		assertNotNull("Check contained not null", contained);

+		assertEquals("Check contained instances count ("+contained.length+") - 1", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.3");

+		

+		ComponentFactory fact1 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-1");

+		ComponentFactory fact2 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-2");

+		ComponentFactory fact3 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-3");

+		

+		

+		fact1.stop();

+		assertTrue("Check instance validity - 2", under.getState() == ComponentInstance.VALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.3");

+		

+		fact2.stop();

+		assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.3");

+

+		fact3.stop();

+		assertTrue("Check instance invalidity", under.getState() == ComponentInstance.VALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 0);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.3");

+

+		fact1.start();

+		assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.3");

+

+		context.ungetService(ref);

+		under.dispose();

+		fact2.start();

+		fact3.start();

+	}

+	

+	

+	

+	

+	

+	

+	

+	

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/OptionalMultipleInstantiation.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/OptionalMultipleInstantiation.java
new file mode 100644
index 0000000..19984d0
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/OptionalMultipleInstantiation.java
@@ -0,0 +1,203 @@
+/* 

+ * 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.felix.ipojo.test.composite.instantiator;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.BarService;

+

+public class OptionalMultipleInstantiation extends OSGiTestCase {

+

+	private ComponentFactory bar2Factory;

+	private ComponentInstance empty;

+	

+	public void setUp() {

+		bar2Factory = (ComponentFactory) Utils.getFactoryByName(context, "composite.bar.4");

+		assertNotNull("Check bar2factory availability", bar2Factory);

+		

+		Factory fact = Utils.getFactoryByName(context, "composite.empty");

+		Properties props = new Properties();

+		props.put("name", "empty");

+		try {

+			empty = fact.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot create the empty composite : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		empty.dispose();

+		empty = null;

+	}

+	

+	public void testCreation() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar2Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		under.dispose();

+	}

+	

+	public void testServiceAvailability() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar2Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}	

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(under);

+		assertNotNull("Check service availability", sc.getServiceReference(BarService.class.getName()));

+		int count = Utils.getServiceReferences(sc, BarService.class.getName(), null).length;

+		assertEquals("Check service provider number : " + count, count, 3);

+		

+		under.dispose();

+	}

+	

+	public void testCreationLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar2Factory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		under.dispose();

+	}

+	

+	public void testServiceAvailabilityLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar2Factory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}	

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc2 = Utils.getServiceContext(under);

+		assertNotNull("Check service availability", sc2.getServiceReference(BarService.class.getName()));

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc2, BarService.class.getName(), null).length, 3);

+		

+		under.dispose();

+	}

+	

+	public void testFactoryManagement() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar2Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		ServiceContext sc = Utils.getServiceContext(under);

+		assertTrue("Check instance validity - 1", under.getState() == ComponentInstance.VALID);

+		

+		ComponentFactory fact1 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-1");

+		ComponentFactory fact2 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-2");

+		ComponentFactory fact3 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-3");

+		

+		fact1.stop();

+		assertTrue("Check instance validity - 2", under.getState() == ComponentInstance.VALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc, BarService.class.getName(), null).length, 2);

+		

+		fact2.stop();

+		assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc, BarService.class.getName(), null).length, 1);

+		

+		fact3.stop();

+		assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc, BarService.class.getName(), null).length, 0);

+		

+		fact1.start();

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc, BarService.class.getName(), null).length, 1);

+		assertTrue("Check instance validity - 5", under.getState() == ComponentInstance.VALID);

+		

+		under.dispose();

+		fact2.start();

+		fact3.start();

+	}

+	

+	public void testFactoryManagementLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar2Factory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity - 1", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc2 = Utils.getServiceContext(under);

+		

+		ComponentFactory fact1 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-1");

+		ComponentFactory fact2 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-2");

+		ComponentFactory fact3 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-3");

+		

+		fact1.stop();

+		assertTrue("Check instance validity - 2", under.getState() == ComponentInstance.VALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc2, BarService.class.getName(), null).length, 2);

+		

+		fact2.stop();

+		assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc2, BarService.class.getName(), null).length, 1);

+		

+		fact3.stop();

+		assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc2, BarService.class.getName(), null).length, 0);

+		

+		fact1.start();

+		assertTrue("Check instance validity - 5", under.getState() == ComponentInstance.VALID);

+		assertEquals("Check service provider number", Utils.getServiceReferences(sc2, BarService.class.getName(), null).length, 1);

+		

+		under.dispose();

+		fact2.start();

+		fact3.start();

+	}

+	

+	

+	

+	

+	

+	

+	

+	

+	

+	

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/SimpleInstantiation.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/SimpleInstantiation.java
new file mode 100644
index 0000000..14b1e1d
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/instantiator/SimpleInstantiation.java
@@ -0,0 +1,265 @@
+/* 

+ * 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.felix.ipojo.test.composite.instantiator;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.architecture.Architecture;

+import org.apache.felix.ipojo.architecture.InstanceDescription;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.BarService;

+import org.osgi.framework.ServiceReference;

+

+public class SimpleInstantiation extends OSGiTestCase {

+

+	private ComponentFactory bar1Factory;

+	private ComponentInstance empty;

+	

+	public void setUp() {

+		bar1Factory = (ComponentFactory) Utils.getFactoryByName(context, "composite.bar.1");

+		Factory fact = Utils.getFactoryByName(context, "composite.empty");

+		Properties props = new Properties();

+		props.put("name", "empty-X");

+		try {

+			empty = fact.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot create the empty composite : " + e.getMessage());

+		}

+	}

+	

+	public void tearDown() {

+		empty.dispose();

+		empty = null;

+	}

+	

+	public void testCreation() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props);

+		} catch(Exception e) {

+		    e.printStackTrace();

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		under.dispose();

+	}

+	

+	public void testServiceAvailability() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}	

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc = Utils.getServiceContext(under);

+		assertNotNull("Check service availability", sc.getServiceReference(BarService.class.getName()));

+		

+		under.dispose();

+	}

+	

+	public void testCreationLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		under.dispose();

+	}

+	

+	public void testServiceAvailabilityLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under-X");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}	

+		assertTrue("Check instance validity", under.getState() == ComponentInstance.VALID);

+		ServiceContext sc2 = Utils.getServiceContext(under);

+		assertNotNull("Check service availability", sc2.getServiceReference(BarService.class.getName()));

+		

+		under.dispose();

+	}

+	

+	public void testFactoryManagement() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity - 1", under.getState() == ComponentInstance.VALID);

+		

+		ComponentFactory fact1 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-1");

+		ComponentFactory fact2 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-2");

+		ComponentFactory fact3 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-3");

+		

+		

+		fact1.stop();

+		assertTrue("Check instance validity - 2", under.getState() == ComponentInstance.VALID);

+		

+		fact2.stop();

+		assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+		

+		fact3.stop();

+		assertTrue("Check instance invalidity", under.getState() == ComponentInstance.INVALID);

+		

+		fact1.start();

+		assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+		

+		under.dispose();

+		fact2.start();

+		fact3.start();

+	}

+	

+	public void testFactoryManagementLevel2() {

+		ServiceContext sc = Utils.getServiceContext(empty);

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props, sc);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		assertTrue("Check instance validity - 1", under.getState() == ComponentInstance.VALID);

+		

+		ComponentFactory fact1 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-1");

+		ComponentFactory fact2 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-2");

+		ComponentFactory fact3 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-3");

+		

+		fact1.stop();

+		assertTrue("Check instance validity - 2", under.getState() == ComponentInstance.VALID);

+		

+		fact2.stop();

+		assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+		

+		fact3.stop();

+		assertTrue("Check instance invalidity", under.getState() == ComponentInstance.INVALID);

+		

+		fact1.start();

+		assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+		

+		under.dispose();

+		fact2.start();

+		fact3.start();

+	}

+	

+	public void testArchitecture() {

+		Properties props = new Properties();

+		props.put("name", "under");

+		ComponentInstance under = null;

+		try {

+			under = bar1Factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate under : " + e.getMessage());

+		}

+		ServiceReference ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		Architecture arch = (Architecture) context.getService(ref);

+		InstanceDescription id = arch.getInstanceDescription();

+		

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		InstanceDescription[] contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.1");

+		

+		ComponentFactory fact1 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-1");

+		ComponentFactory fact2 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-2");

+		ComponentFactory fact3 = (ComponentFactory) Utils.getFactoryByName(context, "FooBarProviderType-3");

+		

+		fact1.stop();

+		assertTrue("Check instance validity - 2", under.getState() == ComponentInstance.VALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.1");

+		

+		fact2.stop();

+		assertTrue("Check instance validity - 3", under.getState() == ComponentInstance.VALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.1");

+

+		fact3.stop();

+		assertTrue("Check instance invalidity", under.getState() == ComponentInstance.INVALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.INVALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 0);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.1");

+

+		fact1.start();

+		assertTrue("Check instance validity - 4", under.getState() == ComponentInstance.VALID);

+		ref = Utils.getServiceReferenceByName(context, Architecture.class.getName(), "under");

+		assertNotNull("Check architecture availability", ref);

+		arch = (Architecture) context.getService(ref);

+		id = arch.getInstanceDescription();

+		assertTrue("Check instance validity - 1", id.getState() == ComponentInstance.VALID);

+		contained = id.getContainedInstances();

+		assertEquals("Check contained instances count", contained.length, 1);

+		assertEquals("Check that no object are created" , id.getCreatedObjects().length, 0);

+		assertEquals("Check instance name" , id.getName(), "under");

+		assertEquals("Check component type name" , id.getComponentDescription().getName(), "composite.bar.1");

+

+		under.dispose();

+		fact2.start();

+		fact3.start();

+	}

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/ProvidesTestSuite.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/ProvidesTestSuite.java
new file mode 100644
index 0000000..413ff58
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/ProvidesTestSuite.java
@@ -0,0 +1,43 @@
+/* 

+ * 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.felix.ipojo.test.composite.provides;

+

+import junit.framework.Test;

+

+import org.apache.felix.ipojo.junit4osgi.OSGiTestSuite;

+import org.osgi.framework.BundleContext;

+

+public class ProvidesTestSuite {

+

+    public static Test suite(BundleContext bc) {

+        OSGiTestSuite ots = new OSGiTestSuite("Composite Service Providing Test Suite", bc);

+        ots.addTestSuite(TestComp0.class);

+        ots.addTestSuite(TestComp1.class);

+        ots.addTestSuite(TestComp2.class);

+        ots.addTestSuite(TestComp3.class);

+        ots.addTestSuite(TestComp4.class);

+        ots.addTestSuite(TestComp5.class);

+        ots.addTestSuite(TestComp6.class);

+        ots.addTestSuite(TestComp7.class);

+        ots.addTestSuite(TestComp8.class);

+        

+        return ots;

+    }

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp0.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp0.java
new file mode 100644
index 0000000..6d5458d
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp0.java
@@ -0,0 +1,338 @@
+/* 

+ * 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.felix.ipojo.test.composite.provides;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.architecture.Architecture;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.component.TotoProvider;

+import org.apache.felix.ipojo.test.composite.service.Tota;

+import org.apache.felix.ipojo.test.composite.service.Toto;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.osgi.framework.ServiceReference;

+

+public class TestComp0 extends OSGiTestCase {

+

+    private ComponentFactory tataFactory;

+    private ComponentFactory totoFactory;

+    private ComponentFactory tataFactory2;

+    

+    private ComponentInstance totoProv, totoProv2;

+    private ComponentInstance under;

+    

+    public void setUp() {

+        tataFactory = (ComponentFactory) Utils.getFactoryByName(context, "tata");

+        totoFactory = (ComponentFactory) Utils.getFactoryByName(context, "toto");

+        tataFactory2 = (ComponentFactory) Utils.getFactoryByName(context, "comp-6");

+        tataFactory2.stop();

+        tataFactory.stop();

+        

+        Properties props = new Properties();

+        props.put("name", "toto provider");

+        try {

+            totoProv = totoFactory.createComponentInstance(props);

+        } catch(Exception e) {

+           fail("Cannot create an instance : " + e.getMessage());

+        }

+        

+        Properties props3 = new Properties();

+        props3.put("name", "toto provider 2");

+        try {

+            totoProv2 = totoFactory.createComponentInstance(props3);

+        } catch(Exception e) {

+            fail("Cannot create an instance : " + e.getMessage());

+        }

+        

+        totoProv.stop();

+        totoProv2.stop();

+        

+        Factory factory = Utils.getFactoryByName(context, "comp-0");

+        Properties props2 = new Properties();

+        props2.put("name", "ff");

+        try {

+            under = factory.createComponentInstance(props2);

+        } catch(Exception e) {

+            fail("Cannot create an instance : " + e.getMessage());

+        }

+    }

+    

+    public void tearDown() {

+        tataFactory.start();

+        totoProv.dispose();

+        totoProv = null;

+        totoProv2.dispose();

+        totoProv2 = null;

+        tataFactory2.start();

+

+        // Reset counters

+        TotoProvider.toto = 0;

+        TotoProvider.toto_2 = 0;

+        TotoProvider.toto_3 = 0;

+        TotoProvider.toto_4 = 0;

+        TotoProvider.toto1 = 0;

+    }

+    

+    public void testSimple() {

+        // Neither factory nor instance

+        assertTrue("Assert under state - 1", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 1", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the importer

+        totoProv.start();

+        assertNotNull("Assert toto service - 1", context.getServiceReference(Toto.class.getName()));

+        assertTrue("Assert under state - 2", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 2", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the factory

+        tataFactory.start();

+        assertTrue("Assert under state - 3", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 3", context.getServiceReference(Tota.class.getName()));

+        ServiceReference ref = context.getServiceReference(Tota.class.getName());

+        Tota tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        Properties props = tota.getProps();

+        Integer toto = (Integer) props.get("toto");

+        Integer toto_2 = (Integer) props.get("toto_2");

+        Integer toto_3 = (Integer) props.get("toto_3");

+        Integer toto_4 = (Integer) props.get("toto_4");

+        assertEquals("Assert toto - 3", toto.intValue(), 1);

+        assertEquals("Assert toto_2 - 3", toto_2.intValue(), 1);

+        assertEquals("Assert toto_3 - 3", toto_3.intValue(), 1);

+        assertEquals("Assert toto_4 - 3", toto_4.intValue(), 0);

+        //Check tata

+        props = tota.getPropsTata();

+        Integer tata = (Integer) props.get("tata");

+        Integer tataStr = (Integer) props.get("tataStr");

+        Integer tataStrs = (Integer) props.get("tataStrs");

+        Integer tata_2 = (Integer) props.get("tata_2");

+        Integer tata_3 = (Integer) props.get("tata_3");

+        Integer tata1 = (Integer) props.get("tata1");

+        Integer tata1_1 = (Integer) props.get("tata1_1");

+        Integer tata5 = (Integer) props.get("tata5");

+        Integer tata5_1 = (Integer) props.get("tata5_1");

+        Integer tata5_2 = (Integer) props.get("tata5_2");

+        assertEquals("Assert tata - 3", tata.intValue(), 1);

+        assertEquals("Assert tataStr - 3", tataStr.intValue(), 1);

+        assertEquals("Assert tataStrs - 3", tataStrs.intValue(), 0);

+        assertEquals("Assert tata_2 - 3", tata_2.intValue(), 1);

+        assertEquals("Assert tata_3 - 3", tata_3.intValue(), 1);

+        assertEquals("Assert tata1 - 3", tata1.intValue(), 1);

+        assertEquals("Assert tata1_1 - 3", tata1_1.intValue(), 1);

+        assertEquals("Assert tata5 - 3", tata5.intValue(), 1);

+        assertEquals("Assert tata5_1 - 3", tata5_1.intValue(), 1);

+        assertEquals("Assert tata5_2 - 3", tata5_2.intValue(), 1);

+        

+        context.ungetService(ref);

+        tota = null;

+        

+        // Start a second import

+        totoProv2.start();

+        assertTrue("Assert under state - 4", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 4", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        props = tota.getProps();

+        toto = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        assertEquals("Assert toto - 4", toto.intValue(), 2);

+        assertEquals("Assert toto_2 - 4", toto_2.intValue(), 2);

+        assertEquals("Assert toto_3 - 4", toto_3.intValue(), 2);

+        assertEquals("Assert toto_4 - 4", toto_4.intValue(), 0);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        tataStr = (Integer) props.get("tataStr");

+        tataStrs = (Integer) props.get("tataStrs");

+        tata_2 = (Integer) props.get("tata_2");

+        tata_3 = (Integer) props.get("tata_3");

+        tata1 = (Integer) props.get("tata1");

+        tata1_1 = (Integer) props.get("tata1_1");

+        tata5 = (Integer) props.get("tata5");

+        tata5_1 = (Integer) props.get("tata5_1");

+        tata5_2 = (Integer) props.get("tata5_2");

+        assertEquals("Assert tata - 4", tata.intValue(), 2);

+        assertEquals("Assert tataStr - 4", tataStr.intValue(), 2);

+        assertEquals("Assert tataStrs - 4", tataStrs.intValue(), 0);

+        assertEquals("Assert tata_2 - 4", tata_2.intValue(), 2);

+        assertEquals("Assert tata_3 - 4", tata_3.intValue(), 2);

+        assertEquals("Assert tata1 - 4", tata1.intValue(), 2);

+        assertEquals("Assert tata1_1 - 4", tata1_1.intValue(), 2);

+        assertEquals("Assert tata5 - 4", tata5.intValue(), 2);

+        assertEquals("Assert tata5_1 - 4", tata5_1.intValue(), 2);

+        assertEquals("Assert tata5_2 - 4", tata5_2.intValue(), 2);

+        

+        context.ungetService(ref);

+        tota = null;

+        

+        tataFactory.stop();

+        assertTrue("Assert under state - 5", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 5", context.getServiceReference(Tota.class.getName()));

+        

+        totoProv2.stop();

+        tataFactory.start();

+        assertTrue("Assert under state - 6", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 6", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        props = tota.getProps();

+        toto = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        assertEquals("Assert toto - 6", toto.intValue(), 3);

+        assertEquals("Assert toto_2 - 6", toto_2.intValue(), 3);

+        assertEquals("Assert toto_3 - 6", toto_3.intValue(), 3);

+        assertEquals("Assert toto_4 - 6", toto_4.intValue(), 0);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        tataStr = (Integer) props.get("tataStr");

+        tataStrs = (Integer) props.get("tataStrs");

+        tata_2 = (Integer) props.get("tata_2");

+        tata_3 = (Integer) props.get("tata_3");

+        tata1 = (Integer) props.get("tata1");

+        tata1_1 = (Integer) props.get("tata1_1");

+        tata5 = (Integer) props.get("tata5");

+        tata5_1 = (Integer) props.get("tata5_1");

+        tata5_2 = (Integer) props.get("tata5_2");

+        assertEquals("Assert tata - 6", tata.intValue(), 1);

+        assertEquals("Assert tataStr - 6", tataStr.intValue(), 1);

+        assertEquals("Assert tataStrs - 6", tataStrs.intValue(), 0);

+        assertEquals("Assert tata_2 - 6", tata_2.intValue(), 1);

+        assertEquals("Assert tata_3 - 6", tata_3.intValue(), 1);

+        assertEquals("Assert tata1 - 6", tata1.intValue(), 1);

+        assertEquals("Assert tata1_1 - 6", tata1_1.intValue(), 1);

+        assertEquals("Assert tata5 - 6", tata5.intValue(), 1);

+        assertEquals("Assert tata5_1 - 6", tata5_1.intValue(), 1);

+        assertEquals("Assert tata5_2 - 6", tata5_2.intValue(), 1);

+        

+        context.ungetService(ref);

+        tota = null;

+        

+        // Is arch exposed

+        assertNotNull("Test arch", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        

+        totoProv.stop();

+        

+        assertTrue("Assert under state - 7", under.getState() == ComponentInstance.INVALID);

+        assertNotNull("Test arch-2", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        assertNull("Assert no tota service - 7", context.getServiceReference(Tota.class.getName()));

+        

+        under.dispose();

+        under = null;

+    }

+

+

+

+    private void invoke(Tota tota) {

+        tota.tata();

+        

+        assertEquals("Assert invoke tataint", tota.tataInt(2), 2);

+        assertEquals("Assert invoke tataLong", tota.tataLong(2), 2);

+        assertEquals("Assert invoke tataDouble", tota.tataDouble(2), 2);

+        assertEquals("Assert invoke tataChar", tota.tataChar('a'), 'a');

+        assertTrue("Assert invoke tataBoolean", tota.tataBoolean(true));

+        assertEquals("Assert invoke tataByte", tota.tataByte((byte)2), 2);

+        assertEquals("Assert invoke tataShort", tota.tataShort((short)5), 5);

+        assertEquals("Assert invoke tataFloat", tota.tataFloat(5), 5);

+        

+    }

+    

+    private void invokeArrays(Tota tota) {

+        

+        int[] a = new int[] {1,2,3};

+        assertEquals("Assert invoke tataint[]", tota.tataInts(a), a);

+        

+        long[] b = new long[] {1,2,3};

+        assertEquals("Assert invoke tataLong[]", tota.tataLongs(b), b);

+        

+        double[] c = new double[] {1,2,3};

+        assertEquals("Assert invoke tataDouble[]", tota.tataDoubles(c), c);

+        

+        char[] d = new char[] {'a','b', 'c'};

+        assertEquals("Assert invoke tataChar[]", tota.tataChars(d), d);

+        

+        boolean[] e = new boolean[] {true, false};

+        assertEquals("Assert invoke tataBoolean[]", tota.tataBooleans(e), e);

+        

+        byte[] f = new byte[] {(byte) 1};

+        assertEquals("Assert invoke tataByte[]", tota.tataBytes(f), f);

+        

+        short[] g = new short[] {(short) 1};

+        assertEquals("Assert invoke tataShort[]", tota.tataShorts(g), g);

+        

+        float[] h = new float[] {5,6,7};

+        assertEquals("Assert invoke tataFloat[]", tota.tataFloats(h), h);

+        

+    }

+    

+    private void invokeStr(Tota tota) {

+        tota.tataStr();

+    }

+    

+    private void invokeTata(Tota tota) {

+        tota.tata(1,2);

+        tota.tata("tototototo");

+    }

+    

+    private void invokeTata1(Tota tota) {

+        assertEquals("Assert tata1", tota.tata1("foo"), "foo");

+        assertEquals("Assert tata1 - 2", tota.tata1(new char[] {'a','b','c'}), "abc");

+    }

+    

+    private void invokeTata5(Tota tota) {

+        assertEquals("Assert tata5 -1", tota.tata5("foo",1), "foo"+1);

+        assertEquals("Assert tata5 - 2", tota.tata5(new String[] {"a","b","c"}, 1), "31");

+        assertEquals("Assert tata5 - 3", tota.tata5("foo", new int[] {1,2,3}), "foo3");

+    }

+    

+    private void invokeAdd(Tota tota) {

+        assertEquals("Assert add", tota.add(1,1,1), 3);

+    }

+    

+    private void invokeToto(Tota tota) {

+        tota.toto();

+        assertEquals("Assert toto", tota.toto("foo"), "foo");

+        tota.toto(1,2);

+    }

+    

+    private void invokeAll(Tota tota) {

+        invoke(tota);

+        invokeArrays(tota);

+        invokeStr(tota);

+        invokeTata(tota);

+        invokeTata1(tota);

+        invokeTata5(tota);

+        invokeAdd(tota);

+        invokeToto(tota);

+    }

+    

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp1.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp1.java
new file mode 100644
index 0000000..95d64be
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp1.java
@@ -0,0 +1,337 @@
+/* 

+ * 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.felix.ipojo.test.composite.provides;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.architecture.Architecture;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.component.TotoProvider;

+import org.apache.felix.ipojo.test.composite.service.Tota;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.osgi.framework.ServiceReference;

+

+public class TestComp1 extends OSGiTestCase {

+

+    private ComponentFactory tataFactory;

+    private ComponentFactory totoFactory;

+    

+    private ComponentInstance totoProv, totoProv2;

+    private ComponentInstance under;

+	private ComponentFactory tataFactory2;

+    

+    public void setUp() {

+        tataFactory = (ComponentFactory) Utils.getFactoryByName(context, "tata");

+        totoFactory = (ComponentFactory) Utils.getFactoryByName(context, "toto");

+        tataFactory2 = (ComponentFactory) Utils.getFactoryByName(context, "comp-6");

+        tataFactory2.stop();

+        

+        tataFactory.stop();

+        

+        Properties props = new Properties();

+        props.put("name", "toto provider");

+        try {

+            totoProv = totoFactory.createComponentInstance(props);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        Properties props3 = new Properties();

+        props3.put("name", "toto provider 2");

+        try {

+            totoProv2 = totoFactory.createComponentInstance(props3);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        totoProv.stop();

+        totoProv2.stop();

+        

+        Factory factory = Utils.getFactoryByName(context, "comp-1");

+        Properties props2 = new Properties();

+        try {

+            under = factory.createComponentInstance(props2);

+        } catch(Exception e) {

+            fail("Cannot create the instance : " + e.getMessage());

+        }

+         

+    }

+    

+    public void tearDown() {  

+        tataFactory.start();

+        totoProv.dispose();

+        totoProv = null;

+        totoProv2.dispose();

+        totoProv2 = null;

+        tataFactory2.start();

+        

+        // Reset counters

+        TotoProvider.toto = 0;

+        TotoProvider.toto_2 = 0;

+        TotoProvider.toto_3 = 0;

+        TotoProvider.toto_4 = 0;

+        TotoProvider.toto1 = 0;

+    }

+    

+    public void testSimple() {

+        // Neither factory nor instance

+        assertTrue("Assert under state - 1", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 1", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the importer

+        totoProv.start();

+        assertTrue("Assert under state - 2 ("+under.getState()+")", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 2", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the factory

+        tataFactory.start();

+        assertTrue("Assert under state - 3", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 3", context.getServiceReference(Tota.class.getName()));

+        ServiceReference ref = context.getServiceReference(Tota.class.getName());

+        Tota tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        Properties props = tota.getProps();

+        Integer toto = (Integer) props.get("toto");

+        Integer toto_2 = (Integer) props.get("toto_2");

+        Integer toto_3 = (Integer) props.get("toto_3");

+        Integer toto_4 = (Integer) props.get("toto_4");

+        assertEquals("Assert toto - 3 ("+toto.intValue()+")", toto.intValue(), 1);

+        assertEquals("Assert toto_2 - 3", toto_2.intValue(), 1);

+        assertEquals("Assert toto_3 - 3", toto_3.intValue(), 1);

+        assertEquals("Assert toto_4 - 3", toto_4.intValue(), 0);

+        //Check tata

+        props = tota.getPropsTata();

+        Integer tata = (Integer) props.get("tata");

+        Integer tataStr = (Integer) props.get("tataStr");

+        Integer tataStrs = (Integer) props.get("tataStrs");

+        Integer tata_2 = (Integer) props.get("tata_2");

+        Integer tata_3 = (Integer) props.get("tata_3");

+        Integer tata1 = (Integer) props.get("tata1");

+        Integer tata1_1 = (Integer) props.get("tata1_1");

+        Integer tata5 = (Integer) props.get("tata5");

+        Integer tata5_1 = (Integer) props.get("tata5_1");

+        Integer tata5_2 = (Integer) props.get("tata5_2");

+        assertEquals("Assert tata - 3", tata.intValue(), 1);

+        assertEquals("Assert tataStr - 3", tataStr.intValue(), 1);

+        assertEquals("Assert tataStrs - 3", tataStrs.intValue(), 0);

+        assertEquals("Assert tata_2 - 3", tata_2.intValue(), 1);

+        assertEquals("Assert tata_3 - 3", tata_3.intValue(), 1);

+        assertEquals("Assert tata1 - 3", tata1.intValue(), 1);

+        assertEquals("Assert tata1_1 - 3", tata1_1.intValue(), 1);

+        assertEquals("Assert tata5 - 3", tata5.intValue(), 1);

+        assertEquals("Assert tata5_1 - 3", tata5_1.intValue(), 1);

+        assertEquals("Assert tata5_2 - 3", tata5_2.intValue(), 1);

+        

+        context.ungetService(ref);

+        tota = null;

+        

+        // Start a second import

+        totoProv2.start();

+        assertTrue("Assert under state - 4", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 4", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        props = tota.getProps();

+        toto = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        assertEquals("Assert toto - 4", toto.intValue(), 2);

+        assertEquals("Assert toto_2 - 4", toto_2.intValue(), 2);

+        assertEquals("Assert toto_3 - 4", toto_3.intValue(), 2);

+        assertEquals("Assert toto_4 - 4", toto_4.intValue(), 0);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        tataStr = (Integer) props.get("tataStr");

+        tataStrs = (Integer) props.get("tataStrs");

+        tata_2 = (Integer) props.get("tata_2");

+        tata_3 = (Integer) props.get("tata_3");

+        tata1 = (Integer) props.get("tata1");

+        tata1_1 = (Integer) props.get("tata1_1");

+        tata5 = (Integer) props.get("tata5");

+        tata5_1 = (Integer) props.get("tata5_1");

+        tata5_2 = (Integer) props.get("tata5_2");

+        assertEquals("Assert tata - 4", tata.intValue(), 2);

+        assertEquals("Assert tataStr - 4", tataStr.intValue(), 2);

+        assertEquals("Assert tataStrs - 4", tataStrs.intValue(), 0);

+        assertEquals("Assert tata_2 - 4", tata_2.intValue(), 2);

+        assertEquals("Assert tata_3 - 4", tata_3.intValue(), 2);

+        assertEquals("Assert tata1 - 4", tata1.intValue(), 2);

+        assertEquals("Assert tata1_1 - 4", tata1_1.intValue(), 2);

+        assertEquals("Assert tata5 - 4", tata5.intValue(), 2);

+        assertEquals("Assert tata5_1 - 4", tata5_1.intValue(), 2);

+        assertEquals("Assert tata5_2 - 4", tata5_2.intValue(), 2);

+        

+        context.ungetService(ref);

+        tota = null;

+        

+        tataFactory.stop();

+        assertTrue("Assert under state - 5", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 5", context.getServiceReference(Tota.class.getName()));

+        

+        totoProv2.stop();

+        tataFactory.start();

+        assertTrue("Assert under state - 6", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 6", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        props = tota.getProps();

+        toto = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        assertEquals("Assert toto - 6", toto.intValue(), 3);

+        assertEquals("Assert toto_2 - 6", toto_2.intValue(), 3);

+        assertEquals("Assert toto_3 - 6", toto_3.intValue(), 3);

+        assertEquals("Assert toto_4 - 6", toto_4.intValue(), 0);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        tataStr = (Integer) props.get("tataStr");

+        tataStrs = (Integer) props.get("tataStrs");

+        tata_2 = (Integer) props.get("tata_2");

+        tata_3 = (Integer) props.get("tata_3");

+        tata1 = (Integer) props.get("tata1");

+        tata1_1 = (Integer) props.get("tata1_1");

+        tata5 = (Integer) props.get("tata5");

+        tata5_1 = (Integer) props.get("tata5_1");

+        tata5_2 = (Integer) props.get("tata5_2");

+        assertEquals("Assert tata - 6", tata.intValue(), 1);

+        assertEquals("Assert tataStr - 6", tataStr.intValue(), 1);

+        assertEquals("Assert tataStrs - 6", tataStrs.intValue(), 0);

+        assertEquals("Assert tata_2 - 6", tata_2.intValue(), 1);

+        assertEquals("Assert tata_3 - 6", tata_3.intValue(), 1);

+        assertEquals("Assert tata1 - 6", tata1.intValue(), 1);

+        assertEquals("Assert tata1_1 - 6", tata1_1.intValue(), 1);

+        assertEquals("Assert tata5 - 6", tata5.intValue(), 1);

+        assertEquals("Assert tata5_1 - 6", tata5_1.intValue(), 1);

+        assertEquals("Assert tata5_2 - 6", tata5_2.intValue(), 1);

+        

+        context.ungetService(ref);

+        tota = null;

+        

+        // Is arch exposed

+        assertNotNull("Test arch", Utils.getServiceReferenceByName(context, Architecture.class.getName(), under.getInstanceName()));

+        

+        totoProv.stop();

+        

+        assertTrue("Assert under state - 7", under.getState() == ComponentInstance.INVALID);

+        assertNotNull("Test arch-2", Utils.getServiceReferenceByName(context, Architecture.class.getName(), under.getInstanceName()));

+        assertNull("Assert no tota service - 7", context.getServiceReference(Tota.class.getName()));

+        

+        under.dispose();

+        under = null;

+    }

+

+

+

+    private void invoke(Tota tota) {

+        tota.tata();

+        

+        assertEquals("Assert invoke tataint", tota.tataInt(2), 2);

+        assertEquals("Assert invoke tataLong", tota.tataLong(2), 2);

+        assertEquals("Assert invoke tataDouble", tota.tataDouble(2), 2);

+        assertEquals("Assert invoke tataChar", tota.tataChar('a'), 'a');

+        assertTrue("Assert invoke tataBoolean", tota.tataBoolean(true));

+        assertEquals("Assert invoke tataByte", tota.tataByte((byte)2), 2);

+        assertEquals("Assert invoke tataShort", tota.tataShort((short)5), 5);

+        assertEquals("Assert invoke tataFloat", tota.tataFloat(5), 5);

+        

+    }

+    

+    private void invokeArrays(Tota tota) {

+        

+        int[] a = new int[] {1,2,3};

+        assertEquals("Assert invoke tataint[]", tota.tataInts(a), a);

+        

+        long[] b = new long[] {1,2,3};

+        assertEquals("Assert invoke tataLong[]", tota.tataLongs(b), b);

+        

+        double[] c = new double[] {1,2,3};

+        assertEquals("Assert invoke tataDouble[]", tota.tataDoubles(c), c);

+        

+        char[] d = new char[] {'a','b', 'c'};

+        assertEquals("Assert invoke tataChar[]", tota.tataChars(d), d);

+        

+        boolean[] e = new boolean[] {true, false};

+        assertEquals("Assert invoke tataBoolean[]", tota.tataBooleans(e), e);

+        

+        byte[] f = new byte[] {(byte) 1};

+        assertEquals("Assert invoke tataByte[]", tota.tataBytes(f), f);

+        

+        short[] g = new short[] {(short) 1};

+        assertEquals("Assert invoke tataShort[]", tota.tataShorts(g), g);

+        

+        float[] h = new float[] {5,6,7};

+        assertEquals("Assert invoke tataFloat[]", tota.tataFloats(h), h);

+        

+    }

+    

+    private void invokeStr(Tota tota) {

+        tota.tataStr();

+    }

+    

+    private void invokeTata(Tota tota) {

+        tota.tata(1,2);

+        tota.tata("tototototo");

+    }

+    

+    private void invokeTata1(Tota tota) {

+        assertEquals("Assert tata1", tota.tata1("foo"), "foo");

+        assertEquals("Assert tata1 - 2", tota.tata1(new char[] {'a','b','c'}), "abc");

+    }

+    

+    private void invokeTata5(Tota tota) {

+        assertEquals("Assert tata5 -1", tota.tata5("foo",1), "foo"+1);

+        assertEquals("Assert tata5 - 2", tota.tata5(new String[] {"a","b","c"}, 1), "31");

+        assertEquals("Assert tata5 - 3", tota.tata5("foo", new int[] {1,2,3}), "foo3");

+    }

+    

+    private void invokeAdd(Tota tota) {

+        assertEquals("Assert add", tota.add(1,1,1), 3);

+    }

+    

+    private void invokeToto(Tota tota) {

+        tota.toto();

+        assertEquals("Assert toto", tota.toto("foo"), "foo");

+        tota.toto(1,2);

+    }

+    

+    private void invokeAll(Tota tota) {

+        invoke(tota);

+        invokeArrays(tota);

+        invokeStr(tota);

+        invokeTata(tota);

+        invokeTata1(tota);

+        invokeTata5(tota);

+        invokeAdd(tota);

+        invokeToto(tota);

+    }

+    

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp2.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp2.java
new file mode 100644
index 0000000..763080f
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp2.java
@@ -0,0 +1,232 @@
+/* 

+ * 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.felix.ipojo.test.composite.provides;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.architecture.Architecture;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.component.TotoProvider;

+import org.apache.felix.ipojo.test.composite.service.Tota;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.osgi.framework.ServiceReference;

+

+public class TestComp2 extends OSGiTestCase {

+

+    private ComponentFactory tataFactory;

+    private ComponentFactory totoFactory;

+    

+    private ComponentInstance totoProv, totoProv2;

+    private ComponentInstance under;

+	private ComponentFactory tataFactory2;

+

+    public void setUp() {

+        tataFactory = (ComponentFactory) Utils.getFactoryByName(context, "tata");

+        totoFactory = (ComponentFactory) Utils.getFactoryByName(context, "toto");

+        tataFactory2 = (ComponentFactory) Utils.getFactoryByName(context, "comp-6");

+        tataFactory2.stop();

+        tataFactory.stop();

+        

+        Properties props = new Properties();

+        props.put("name", "toto provider");

+        try {

+            totoProv = totoFactory.createComponentInstance(props);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        Properties props3 = new Properties();

+        props3.put("name", "toto provider 2");

+        try {

+            totoProv2 = totoFactory.createComponentInstance(props3);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        totoProv.stop();

+        totoProv2.stop();

+        

+        Factory factory = Utils.getFactoryByName(context, "comp-2");

+        Properties props2 = new Properties();

+        props2.put("name", "ff");

+        try {

+            under = factory.createComponentInstance(props2);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+         

+    }

+    

+    public void tearDown() { 

+        tataFactory.start();

+        totoProv.dispose();

+        totoProv = null;

+        totoProv2.dispose();

+        totoProv2 = null;

+        tataFactory2.start();

+        

+        // Reset counters

+        TotoProvider.toto = 0;

+        TotoProvider.toto_2 = 0;

+        TotoProvider.toto_3 = 0;

+        TotoProvider.toto_4 = 0;

+        TotoProvider.toto1 = 0;

+    }

+    

+    public void testSimple() {

+        // Neither factory nor instance

+        assertTrue("Assert under state - 1", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 1", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the importer

+        totoProv.start();

+        assertTrue("Assert under state - 2 ("+under.getState()+")", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 2", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the factory

+        tataFactory.start();

+        assertTrue("Assert under state - 3", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 3", context.getServiceReference(Tota.class.getName()));

+        ServiceReference ref = context.getServiceReference(Tota.class.getName());

+        Tota tota = (Tota) context.getService(ref);

+        

+        invokeAll(tota);

+        

+        // Check toto

+        Properties props = tota.getProps();

+        Integer toto = (Integer) props.get("toto");

+        Integer toto_2 = (Integer) props.get("toto_2");

+        Integer toto_3 = (Integer) props.get("toto_3");

+        Integer toto_4 = (Integer) props.get("toto_4");

+        Integer toto_1 = (Integer) props.get("toto1");

+        assertEquals("Assert toto - 3 ("+toto.intValue()+")", toto.intValue(), 1);

+        assertEquals("Assert toto_2 - 3", toto_2.intValue(), 1);

+        assertEquals("Assert toto_3 - 3", toto_3.intValue(), 1);

+        assertEquals("Assert toto_4 - 3", toto_4.intValue(), 0);

+        assertEquals("Assert toto1 - 3 (" + toto_1.intValue() + ")", toto_1.intValue(), 1);

+        //Check tata

+        props = tota.getPropsTata();

+        Integer tata = (Integer) props.get("tata");

+        assertEquals("Assert tata - 3", tata.intValue(), 1);

+        

+        context.ungetService(ref);

+        tota = null;

+        

+        // Start a second import

+        totoProv2.start();

+        assertTrue("Assert under state - 4", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 4", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        props = tota.getProps();

+        toto = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        toto_1 = (Integer) props.get("toto1");

+        assertEquals("Assert toto - 4 ("+toto.intValue()+")", toto.intValue(), 2);

+        assertEquals("Assert toto_2 - 4 ("+toto_2.intValue()+")", toto_2.intValue(), 2);

+        assertEquals("Assert toto_3 - 4", toto_3.intValue(), 2);

+        assertEquals("Assert toto_4 - 4", toto_4.intValue(), 0);

+        assertEquals("Assert toto1 - 4", toto_1.intValue(), 3);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        assertEquals("Assert tata - 4", tata.intValue(), 2);

+        

+        context.ungetService(ref);

+        tota = null;

+        

+        tataFactory.stop();

+        assertTrue("Assert under state - 5", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 5", context.getServiceReference(Tota.class.getName()));

+        

+        totoProv2.stop();

+        tataFactory.start();

+        assertTrue("Assert under state - 6", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 6", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        props = tota.getProps();

+        toto = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        toto_1 = (Integer) props.get("toto1");

+        assertEquals("Assert toto - 6 ("+toto.intValue()+")", toto.intValue(), 3);

+        assertEquals("Assert toto_2 - 6 ("+toto_2.intValue()+")", toto_2.intValue(), 3);

+        assertEquals("Assert toto_3 - 6", toto_3.intValue(), 3);

+        assertEquals("Assert toto_4 - 6", toto_4.intValue(), 0);

+        assertEquals("Assert toto1 - 6", toto_1.intValue(), 4);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        assertEquals("Assert tata - 6", tata.intValue(), 1);

+        

+        context.ungetService(ref);

+        tota = null;

+        

+        // Is arch exposed

+        assertNotNull("Test arch", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        

+        totoProv.stop();

+        

+        assertTrue("Assert under state - 7", under.getState() == ComponentInstance.INVALID);

+        assertNotNull("Test arch-2", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        assertNull("Assert no tota service - 7", context.getServiceReference(Tota.class.getName()));

+        

+        under.dispose();

+        under = null;

+    }

+

+    private void invoke(Tota tota) {

+        tota.tata();

+        

+        assertEquals("Assert invoke tataint", tota.tataInt(2), 2);

+        assertEquals("Assert invoke tataLong", tota.tataLong(2), 2);

+        assertEquals("Assert invoke tataDouble", tota.tataDouble(2), 2);

+        assertEquals("Assert invoke tataChar", tota.tataChar('a'), 'a');

+        assertTrue("Assert invoke tataBoolean", tota.tataBoolean(true));

+        assertEquals("Assert invoke tataByte", tota.tataByte((byte)2), 2);

+        assertEquals("Assert invoke tataShort", tota.tataShort((short)5), 5);

+        assertEquals("Assert invoke tataFloat", tota.tataFloat(5), 5);

+        

+    }

+    

+    private void invokeToto(Tota tota) {

+        tota.toto();

+        assertEquals("Assert toto", tota.toto("foo"), "foo");

+        tota.toto(1,2);

+        tota.toto1("foo2");

+    }

+    

+    private void invokeAll(Tota tota) {

+        invoke(tota);

+        invokeToto(tota);

+    }

+    

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp3.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp3.java
new file mode 100644
index 0000000..07ac5d3
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp3.java
@@ -0,0 +1,262 @@
+/* 

+ * 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.felix.ipojo.test.composite.provides;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.architecture.Architecture;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.component.TotoProvider;

+import org.apache.felix.ipojo.test.composite.service.Tota;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.osgi.framework.ServiceReference;

+

+public class TestComp3 extends OSGiTestCase {

+

+    private ComponentFactory tataFactory;

+    private ComponentFactory totoFactory;

+    

+    private ComponentInstance totoProv, totoProv2;

+    private ComponentInstance under;

+	private ComponentFactory tataFactory2;  

+    

+    public void setUp() {

+        tataFactory = (ComponentFactory) Utils.getFactoryByName(context, "tata");

+        totoFactory = (ComponentFactory) Utils.getFactoryByName(context, "toto");

+        tataFactory2 = (ComponentFactory) Utils.getFactoryByName(context, "comp-6");

+        tataFactory2.stop();

+        tataFactory.stop();

+        

+        Properties props = new Properties();

+        props.put("name", "toto provider");

+        try {

+            totoProv = totoFactory.createComponentInstance(props);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        Properties props3 = new Properties();

+        props3.put("name", "toto provider 2");

+        try {

+            totoProv2 = totoFactory.createComponentInstance(props3);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        totoProv.stop();

+        totoProv2.stop();

+        

+        Factory factory = Utils.getFactoryByName(context, "comp-3");

+        Properties props2 = new Properties();

+        props2.put("name", "ff");

+        try {

+            under = factory.createComponentInstance(props2);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+         

+    }

+    

+    public void tearDown() {  

+        tataFactory.start();

+        totoProv.dispose();

+        totoProv = null;

+        totoProv2.dispose();

+        totoProv2 = null;

+        tataFactory2.start();

+        

+        // Reset counters

+        TotoProvider.toto = 0;

+        TotoProvider.toto_2 = 0;

+        TotoProvider.toto_3 = 0;

+        TotoProvider.toto_4 = 0;

+        TotoProvider.toto1 = 0;

+    }

+    

+    public void testSimple() {

+        // Neither factory nor instance

+        assertTrue("Assert under state - 1", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 1", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the importer

+        totoProv.start();

+        assertTrue("Assert under state - 2 ("+under.getState()+")", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 2", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the factory

+        tataFactory.start();

+        assertTrue("Assert under state - 3", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 3", context.getServiceReference(Tota.class.getName()));

+        ServiceReference ref = context.getServiceReference(Tota.class.getName());

+        Tota tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        Properties props = tota.getProps();

+        Integer toto = (Integer) props.get("toto");

+        Integer toto_2 = (Integer) props.get("toto_2");

+        Integer toto_3 = (Integer) props.get("toto_3");

+        Integer toto_4 = (Integer) props.get("toto_4");

+        Integer toto_1 = (Integer) props.get("toto1");

+        assertEquals("Assert toto - 3 ("+toto.intValue()+")", toto.intValue(), 1);

+        assertEquals("Assert toto_2 - 3", toto_2.intValue(), 1);

+        assertEquals("Assert toto_3 - 3", toto_3.intValue(), 1);

+        assertEquals("Assert toto_4 - 3", toto_4.intValue(), 0);

+        assertEquals("Assert toto1 - 3 (" + toto_1.intValue() + ")", toto_1.intValue(), 1);

+        //Check tata

+        props = tota.getPropsTata();

+        Integer tata = (Integer) props.get("tata");

+        assertEquals("Assert tata - 3", tata.intValue(), 1);

+        

+        context.ungetService(ref);

+        tota = null;

+        

+        // Start a second import

+        totoProv2.start();

+        assertTrue("Assert under state - 4", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 4", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        props = tota.getProps();

+        toto = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        toto_1 = (Integer) props.get("toto1");

+        assertEquals("Assert toto - 4 ("+toto.intValue()+")", toto.intValue(), 2);

+        assertEquals("Assert toto_2 - 4 ("+toto_2.intValue()+")", toto_2.intValue(), 2);

+        assertEquals("Assert toto_3 - 4", toto_3.intValue(), 2);

+        assertEquals("Assert toto_4 - 4", toto_4.intValue(), 0);

+        assertEquals("Assert toto1 - 4", toto_1.intValue(), 2);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        assertEquals("Assert tata - 4", tata.intValue(), 2);

+        context.ungetService(ref);

+        tota = null;

+        

+        // Stop the factory

+        tataFactory.stop();

+        assertTrue("Assert under state - 5", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 5", context.getServiceReference(Tota.class.getName()));

+        

+        totoProv2.stop();

+        totoProv.stop();

+        tataFactory.start();

+        assertTrue("Assert under state - 6", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 6", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAllOpt(tota);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        assertEquals("Assert tata - 4", tata.intValue(), 1);

+        context.ungetService(ref);

+        tota = null;

+        

+        // Is arch exposed

+        assertNotNull("Test arch", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        

+        tataFactory.stop();

+        

+        assertTrue("Assert under state - 7", under.getState() == ComponentInstance.INVALID);

+        assertNotNull("Test arch-2", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        assertNull("Assert no tota service - 7", context.getServiceReference(Tota.class.getName()));

+        

+        under.dispose();

+        under = null;

+    }

+

+    private void invoke(Tota tota) {

+        tota.tata();

+        

+        assertEquals("Assert invoke tataint", tota.tataInt(2), 2);

+        assertEquals("Assert invoke tataLong", tota.tataLong(2), 2);

+        assertEquals("Assert invoke tataDouble", tota.tataDouble(2), 2);

+        assertEquals("Assert invoke tataChar", tota.tataChar('a'), 'a');

+        assertTrue("Assert invoke tataBoolean", tota.tataBoolean(true));

+        assertEquals("Assert invoke tataByte", tota.tataByte((byte)2), 2);

+        assertEquals("Assert invoke tataShort", tota.tataShort((short)5), 5);

+        assertEquals("Assert invoke tataFloat", tota.tataFloat(5), 5);

+        

+    }

+    

+    

+    private void invokeStr(Tota tota) {

+        tota.tataStr();

+    }

+    

+    private void invokeToto(Tota tota) {

+        tota.toto();

+        assertEquals("Assert toto", tota.toto("foo"), "foo");

+        tota.toto(1,2);

+        tota.toto1("foo");

+    }

+    

+    private void invokeAll(Tota tota) {

+        invoke(tota);

+        //invokeArrays(tota);

+        invokeStr(tota);

+        //invokeTata(tota);

+        //invokeTata1(tota);

+        //invokeTata5(tota);

+        //invokeAdd(tota);

+        invokeToto(tota);

+    }

+    

+    private void invokeAllOpt(Tota tota) {

+        invoke(tota);

+        //invokeArrays(tota);

+        invokeStr(tota);

+        //invokeTata(tota);

+        //invokeTata1(tota);

+        //invokeTata5(tota);

+        //invokeAdd(tota);

+        invokeTotoOpt(tota);

+    }

+    

+    private void invokeTotoOpt(Tota tota) {

+        try {

+            tota.toto();

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+        

+        try {

+            assertEquals("Assert toto", tota.toto("foo"), "foo");

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+        

+        

+        try {

+            tota.toto(1,2);

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+        

+        try {

+            tota.toto1("foo");

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+    }

+    

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp4.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp4.java
new file mode 100644
index 0000000..0d0f36c
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp4.java
@@ -0,0 +1,261 @@
+/* 

+ * 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.felix.ipojo.test.composite.provides;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.architecture.Architecture;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.component.TotoProvider;

+import org.apache.felix.ipojo.test.composite.service.Tota;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.osgi.framework.ServiceReference;

+

+public class TestComp4 extends OSGiTestCase {

+

+    private ComponentFactory tataFactory;

+    private ComponentFactory totoFactory;

+    

+    private ComponentInstance totoProv, totoProv2;

+    private ComponentInstance under;

+	private ComponentFactory tataFactory2;

+

+    public void setUp() {

+        tataFactory = (ComponentFactory) Utils.getFactoryByName(context, "tata");

+        totoFactory = (ComponentFactory) Utils.getFactoryByName(context, "toto");

+        tataFactory2 = (ComponentFactory) Utils.getFactoryByName(context, "comp-6");

+        tataFactory2.stop();

+        tataFactory.stop();

+        

+        Properties props = new Properties();

+        props.put("name", "toto provider");

+        try {

+            totoProv = totoFactory.createComponentInstance(props);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        Properties props3 = new Properties();

+        props3.put("name", "toto provider 2");

+        try {

+            totoProv2 = totoFactory.createComponentInstance(props3);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        totoProv.stop();

+        totoProv2.stop();

+        

+        Factory factory = Utils.getFactoryByName(context, "comp-4");

+        Properties props2 = new Properties();

+        props2.put("name", "ff");

+        try {

+            under = factory.createComponentInstance(props2);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+         

+    }

+    

+    public void tearDown() {  

+    	tataFactory2.start();

+        tataFactory.start();

+        totoProv.dispose();

+        totoProv = null;

+        totoProv2.dispose();

+        totoProv2 = null;

+        

+        // Reset counters

+        TotoProvider.toto = 0;

+        TotoProvider.toto_2 = 0;

+        TotoProvider.toto_3 = 0;

+        TotoProvider.toto_4 = 0;

+        TotoProvider.toto1 = 0;

+    }

+    

+    public void testSimple() {

+        // Neither factory nor instance

+        assertTrue("Assert under state - 1", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 1", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the importer

+        totoProv.start();

+        assertTrue("Assert under state - 2 ("+under.getState()+")", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 2", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the factory

+        tataFactory.start();

+        assertTrue("Assert under state - 3", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 3", context.getServiceReference(Tota.class.getName()));

+        ServiceReference ref = context.getServiceReference(Tota.class.getName());

+        Tota tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        Properties props = tota.getProps();

+        Integer toto = (Integer) props.get("toto");

+        Integer toto_2 = (Integer) props.get("toto_2");

+        Integer toto_3 = (Integer) props.get("toto_3");

+        Integer toto_4 = (Integer) props.get("toto_4");

+        Integer toto_1 = (Integer) props.get("toto1");

+        assertEquals("Assert toto - 3 ("+toto.intValue()+")", toto.intValue(), 1);

+        assertEquals("Assert toto_2 - 3", toto_2.intValue(), 1);

+        assertEquals("Assert toto_3 - 3", toto_3.intValue(), 1);

+        assertEquals("Assert toto_4 - 3", toto_4.intValue(), 0);

+        assertEquals("Assert toto1 - 3 (" + toto_1.intValue() + ")", toto_1.intValue(), 1);

+        //Check tata

+        props = tota.getPropsTata();

+        Integer tata = (Integer) props.get("tata");

+        assertEquals("Assert tata - 3", tata.intValue(), 1);

+        context.ungetService(ref);

+        tota = null;

+        

+        // Start a second import

+        totoProv2.start();

+        assertTrue("Assert under state - 4", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 4", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        props = tota.getProps();

+        toto = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        toto_1 = (Integer) props.get("toto1");

+        assertEquals("Assert toto - 4 ("+toto.intValue()+")", toto.intValue(), 2);

+        assertEquals("Assert toto_2 - 4 ("+toto_2.intValue()+")", toto_2.intValue(), 2);

+        assertEquals("Assert toto_3 - 4", toto_3.intValue(), 2);

+        assertEquals("Assert toto_4 - 4", toto_4.intValue(), 0);

+        assertEquals("Assert toto1 - 4", toto_1.intValue(), 2);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        assertEquals("Assert tata - 4", tata.intValue(), 2);

+        context.ungetService(ref);

+        tota = null;

+        

+        // Stop the factory

+        tataFactory.stop();

+        assertTrue("Assert under state - 5", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 5", context.getServiceReference(Tota.class.getName()));

+        

+        totoProv2.stop();

+        totoProv.stop();

+        tataFactory.start();

+        assertTrue("Assert under state - 6", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 6", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAllOpt(tota);

+        // Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        assertEquals("Assert tata - 6", tata.intValue(), 1);

+        context.ungetService(ref);

+        tota = null;

+        

+        // Is arch exposed

+        assertNotNull("Test arch", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        

+        tataFactory.stop();

+        

+        assertTrue("Assert under state - 7", under.getState() == ComponentInstance.INVALID);

+        assertNotNull("Test arch-2", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        assertNull("Assert no tota service - 7", context.getServiceReference(Tota.class.getName()));

+        

+        under.dispose();

+        under = null;

+    }

+

+    private void invoke(Tota tota) {

+        tota.tata();

+        

+        assertEquals("Assert invoke tataint", tota.tataInt(2), 2);

+        assertEquals("Assert invoke tataLong", tota.tataLong(2), 2);

+        assertEquals("Assert invoke tataDouble", tota.tataDouble(2), 2);

+        assertEquals("Assert invoke tataChar", tota.tataChar('a'), 'a');

+        assertTrue("Assert invoke tataBoolean", tota.tataBoolean(true));

+        assertEquals("Assert invoke tataByte", tota.tataByte((byte)2), 2);

+        assertEquals("Assert invoke tataShort", tota.tataShort((short)5), 5);

+        assertEquals("Assert invoke tataFloat", tota.tataFloat(5), 5);

+        

+    }

+    

+    

+    private void invokeStr(Tota tota) {

+        tota.tataStr();

+    }

+    

+    private void invokeToto(Tota tota) {

+        tota.toto();

+        assertEquals("Assert toto", tota.toto("foo"), "foo");

+        tota.toto(1,2);

+        tota.toto1("foo");

+    }

+    

+    private void invokeAll(Tota tota) {

+        invoke(tota);

+        //invokeArrays(tota);

+        invokeStr(tota);

+        //invokeTata(tota);

+        //invokeTata1(tota);

+        //invokeTata5(tota);

+        //invokeAdd(tota);

+        invokeToto(tota);

+    }

+    

+    private void invokeAllOpt(Tota tota) {

+        invoke(tota);

+        //invokeArrays(tota);

+        invokeStr(tota);

+        //invokeTata(tota);

+        //invokeTata1(tota);

+        //invokeTata5(tota);

+        //invokeAdd(tota);

+        invokeTotoOpt(tota);

+    }

+    

+    private void invokeTotoOpt(Tota tota) {

+        try {

+            tota.toto();

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+        

+        try {

+            assertEquals("Assert toto", tota.toto("foo"), "foo");

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+        

+        

+        try {

+            tota.toto(1,2);

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+        

+        try {

+            tota.toto1("foo");

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+    }

+    

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp5.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp5.java
new file mode 100644
index 0000000..7dd11f7
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp5.java
@@ -0,0 +1,265 @@
+/* 

+ * 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.felix.ipojo.test.composite.provides;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.architecture.Architecture;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.component.TotoProvider;

+import org.apache.felix.ipojo.test.composite.service.Tota;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.osgi.framework.ServiceReference;

+

+public class TestComp5 extends OSGiTestCase {

+

+    private ComponentFactory tataFactory;

+    private ComponentFactory totoFactory;

+    

+    private ComponentInstance totoProv, totoProv2;

+    private ComponentInstance under;

+	private ComponentFactory tataFactory2;

+

+    public void setUp() {

+        tataFactory = (ComponentFactory) Utils.getFactoryByName(context, "tata");

+        totoFactory = (ComponentFactory) Utils.getFactoryByName(context, "toto");

+        tataFactory2 = (ComponentFactory) Utils.getFactoryByName(context, "comp-6");

+        tataFactory2.stop();

+        tataFactory.stop();

+        

+        Properties props = new Properties();

+        props.put("name", "toto provider");

+        try {

+            totoProv = totoFactory.createComponentInstance(props);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        Properties props3 = new Properties();

+        props3.put("name", "toto provider 2");

+        try {

+            totoProv2 = totoFactory.createComponentInstance(props3);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        totoProv.stop();

+        totoProv2.stop();

+        

+        Factory factory = Utils.getFactoryByName(context, "comp-5");

+        Properties props2 = new Properties();

+        props2.put("name", "ff");

+        try {

+            under = factory.createComponentInstance(props2);

+        } catch(Exception e) {

+            e.printStackTrace();

+            fail("Cannot create an instance from comp-5 : " + e.getMessage());

+        }

+         

+    }

+    

+    public void tearDown() {    

+    	tataFactory2.start();

+        tataFactory.start();

+        totoProv.dispose();

+        totoProv = null;

+        totoProv2.dispose();

+        totoProv2 = null;

+        

+        // Reset counters

+        TotoProvider.toto = 0;

+        TotoProvider.toto_2 = 0;

+        TotoProvider.toto_3 = 0;

+        TotoProvider.toto_4 = 0;

+        TotoProvider.toto1 = 0;

+    }

+    

+    public void testSimple() {

+        // Neither factory nor instance

+        assertTrue("Assert under state - 1", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 1", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the importer

+        totoProv.start();

+        assertTrue("Assert under state - 2 ("+under.getState()+")", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 2", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the factory

+        tataFactory.start();

+        assertTrue("Assert under state - 3", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 3", context.getServiceReference(Tota.class.getName()));

+        ServiceReference ref = context.getServiceReference(Tota.class.getName());

+        Tota tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        Properties props = tota.getProps();

+        Integer toto = (Integer) props.get("toto");

+        Integer toto_2 = (Integer) props.get("toto_2");

+        Integer toto_3 = (Integer) props.get("toto_3");

+        Integer toto_4 = (Integer) props.get("toto_4");

+        Integer toto_1 = (Integer) props.get("toto1");

+        assertEquals("Assert toto - 3 ("+toto.intValue()+")", toto.intValue(), 1);

+        assertEquals("Assert toto_2 - 3", toto_2.intValue(), 1);

+        assertEquals("Assert toto_3 - 3", toto_3.intValue(), 1);

+        assertEquals("Assert toto_4 - 3", toto_4.intValue(), 0);

+        assertEquals("Assert toto1 - 3 (" + toto_1.intValue() + ")", toto_1.intValue(), 1);

+        //Check tata

+        props = tota.getPropsTata();

+        Integer tata = (Integer) props.get("tata");

+        assertEquals("Assert tata - 3", tata.intValue(), 1);

+        context.ungetService(ref);

+        tota = null;

+        

+        // Start a second import

+        totoProv2.start();

+        assertTrue("Assert under state - 4", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 4", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        props = tota.getProps();

+        toto = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        toto_1 = (Integer) props.get("toto1");

+        assertEquals("Assert toto - 4 ("+toto.intValue()+")", toto.intValue(), 2);

+        assertEquals("Assert toto_2 - 4 ("+toto_2.intValue()+")", toto_2.intValue(), 2);

+        assertEquals("Assert toto_3 - 4", toto_3.intValue(), 2);

+        assertEquals("Assert toto_4 - 4", toto_4.intValue(), 0);

+        assertEquals("Assert toto1 - 4", toto_1.intValue(), 3);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        assertEquals("Assert tata - 4", tata.intValue(), 2);

+        context.ungetService(ref);

+        tota = null;

+        

+        // Stop the factory

+        tataFactory.stop();

+        assertTrue("Assert under state - 5", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 5", context.getServiceReference(Tota.class.getName()));

+        

+        totoProv2.stop();

+        totoProv.stop();

+        tataFactory.start();

+        assertTrue("Assert under state - 6", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 6", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAllOpt(tota);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        assertEquals("Assert tata - 6", tata.intValue(), 1);

+        context.ungetService(ref);

+        tota = null;

+        

+        // Is arch exposed

+        assertNotNull("Test arch", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        

+        tataFactory.stop();

+        

+        assertTrue("Assert under state - 7", under.getState() == ComponentInstance.INVALID);

+        assertNotNull("Test arch-2", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        assertNull("Assert no tota service - 7", context.getServiceReference(Tota.class.getName()));

+        

+        under.dispose();

+        under = null;

+    }

+

+

+

+    private void invoke(Tota tota) {

+        tota.tata();

+        

+        assertEquals("Assert invoke tataint", tota.tataInt(2), 2);

+        assertEquals("Assert invoke tataLong", tota.tataLong(2), 2);

+        assertEquals("Assert invoke tataDouble", tota.tataDouble(2), 2);

+        assertEquals("Assert invoke tataChar", tota.tataChar('a'), 'a');

+        assertTrue("Assert invoke tataBoolean", tota.tataBoolean(true));

+        assertEquals("Assert invoke tataByte", tota.tataByte((byte)2), 2);

+        assertEquals("Assert invoke tataShort", tota.tataShort((short)5), 5);

+        assertEquals("Assert invoke tataFloat", tota.tataFloat(5), 5);

+        

+    }

+    

+    

+    private void invokeStr(Tota tota) {

+        tota.tataStr();

+    }

+    

+    private void invokeToto(Tota tota) {

+        tota.toto();

+        assertEquals("Assert toto", tota.toto("foo"), "foo");

+        tota.toto(1,2);

+        tota.toto1("foo");

+    }

+    

+    private void invokeAll(Tota tota) {

+        invoke(tota);

+        //invokeArrays(tota);

+        invokeStr(tota);

+        //invokeTata(tota);

+        //invokeTata1(tota);

+        //invokeTata5(tota);

+        //invokeAdd(tota);

+        invokeToto(tota);

+    }

+    

+    private void invokeAllOpt(Tota tota) {

+        invoke(tota);

+        //invokeArrays(tota);

+        invokeStr(tota);

+        //invokeTata(tota);

+        //invokeTata1(tota);

+        //invokeTata5(tota);

+        //invokeAdd(tota);

+        invokeTotoOpt(tota);

+    }

+    

+    private void invokeTotoOpt(Tota tota) {

+        try {

+            tota.toto();

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+        

+        try {

+            assertEquals("Assert toto", tota.toto("foo"), "foo");

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+        

+        

+        try {

+            tota.toto(1,2);

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+        

+        try {

+        	tota.toto1("foo");

+        	fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+    }

+    

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp6.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp6.java
new file mode 100644
index 0000000..609c23c
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp6.java
@@ -0,0 +1,284 @@
+/* 

+ * 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.felix.ipojo.test.composite.provides;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.architecture.Architecture;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.component.TotoProvider;

+import org.apache.felix.ipojo.test.composite.service.Tata;

+import org.apache.felix.ipojo.test.composite.service.Toto;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.osgi.framework.ServiceReference;

+

+public class TestComp6 extends OSGiTestCase {

+

+    private ComponentFactory tataFactory;

+    private ComponentFactory totoFactory;

+    

+    private ComponentInstance totoProv, totoProv2;

+    private ComponentInstance under;

+    

+    public void setUp() {

+        tataFactory = (ComponentFactory) Utils.getFactoryByName(context, "tata");

+        totoFactory = (ComponentFactory) Utils.getFactoryByName(context, "toto");

+        

+        tataFactory.stop();

+        

+        Properties props = new Properties();

+        props.put("name", "toto provider");

+        try {

+            totoProv = totoFactory.createComponentInstance(props);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        Properties props3 = new Properties();

+        props3.put("name", "toto provider 2");

+        try {

+            totoProv2 = totoFactory.createComponentInstance(props3);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        totoProv.stop();

+        totoProv2.stop();

+        

+        Factory factory = Utils.getFactoryByName(context, "comp-6");

+        Properties props2 = new Properties();

+        props2.put("name", "ff");

+        try {

+            under = factory.createComponentInstance(props2);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+         

+    }

+    

+    public void tearDown() {       

+        tataFactory.start();

+        totoProv.dispose();

+        totoProv = null;

+        totoProv2.dispose();

+        totoProv2 = null;

+        

+        // Reset counters

+        TotoProvider.toto = 0;

+        TotoProvider.toto_2 = 0;

+        TotoProvider.toto_3 = 0;

+        TotoProvider.toto_4 = 0;

+        TotoProvider.toto1 = 0;

+    }

+    

+    public void testSimple() {

+        // Neither factory nor instance

+        assertTrue("Assert under state - 1", under.getState() == ComponentInstance.INVALID);

+        ServiceReference refToto = Utils.getServiceReferenceByName(context, Toto.class.getName(), "ff");

+        ServiceReference refTata = Utils.getServiceReferenceByName(context, Tata.class.getName(), "ff");

+        assertNull("Assert no toto service - 1", refToto);

+        assertNull("Assert no tata service - 1", refTata);

+

+        // Start the importer

+        totoProv.start();

+        assertTrue("Assert under state - 2 ("+under.getState()+")", under.getState() == ComponentInstance.INVALID);

+        refToto = Utils.getServiceReferenceByName(context, Toto.class.getName(), "ff");

+        refTata = Utils.getServiceReferenceByName(context, Tata.class.getName(), "ff");

+        assertNull("Assert no toto service - 2", refToto);

+        assertNull("Assert no tata service - 2", refTata);

+

+        // Start the factory

+        tataFactory.start();

+        assertTrue("Assert under state - 3", under.getState() == ComponentInstance.VALID);

+        refToto = Utils.getServiceReferenceByName(context, Toto.class.getName(), "ff");

+        refTata = Utils.getServiceReferenceByName(context, Tata.class.getName(), "ff");

+        assertNotNull("Assert toto service - 3", refToto);

+        assertNotNull("Assert tata service - 3", refTata);

+        Toto toto = (Toto) context.getService(refToto);

+        Tata tata = (Tata) context.getService(refTata);

+ 

+        invokeAll(tata);

+        invokeToto(toto);

+ 

+        // Check toto

+        Properties props = toto.getProps();

+        Integer toto_0 = (Integer) props.get("toto");

+        Integer toto_2 = (Integer) props.get("toto_2");

+        Integer toto_3 = (Integer) props.get("toto_3");

+        Integer toto_4 = (Integer) props.get("toto_4");

+        Integer toto_1 = (Integer) props.get("toto1");

+        assertEquals("Assert toto - 3 ("+toto_0.intValue()+")", toto_0.intValue(), 1);

+        assertEquals("Assert toto_2 - 3", toto_2.intValue(), 1);

+        assertEquals("Assert toto_3 - 3", toto_3.intValue(), 1);

+        assertEquals("Assert toto_4 - 3", toto_4.intValue(), 0);

+        assertEquals("Assert toto1 - 3 (" + toto_1.intValue() + ")", toto_1.intValue(), 1);

+        //Check tata

+        props = tata.getPropsTata();

+        Integer tata_0 = (Integer) props.get("tata");

+        assertEquals("Assert tata - 3", tata_0.intValue(), 1);

+

+        context.ungetService(refToto);

+        context.ungetService(refTata);

+        toto = null;

+        tata = null;

+        

+        // Start a second import

+        totoProv2.start();

+        assertTrue("Assert under state - 4", under.getState() == ComponentInstance.VALID);

+        refToto = Utils.getServiceReferenceByName(context, Toto.class.getName(), "ff");

+        refTata = Utils.getServiceReferenceByName(context, Tata.class.getName(), "ff");

+        assertNotNull("Assert toto service - 4", refToto);

+        assertNotNull("Assert tata service - 4", refTata);

+        

+        toto = (Toto) context.getService(refToto);

+        tata = (Tata) context.getService(refTata);

+        invokeAll(tata);

+        invokeToto(toto);

+

+        // Check toto

+        props = toto.getProps();

+        toto_0 = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        toto_1 = (Integer) props.get("toto1");

+        assertEquals("Assert toto - 4 ("+toto_0.intValue()+")", toto_0.intValue(), 2);

+        assertEquals("Assert toto_2 - 4 ("+toto_2.intValue()+")", toto_2.intValue(), 2);

+        assertEquals("Assert toto_3 - 4", toto_3.intValue(), 2);

+        assertEquals("Assert toto_4 - 4", toto_4.intValue(), 0);

+        assertEquals("Assert toto1 - 4", toto_1.intValue(), 3);

+        //Check tata

+        props = tata.getPropsTata();

+        tata_0 = (Integer) props.get("tata");

+        assertEquals("Assert tata - 4", tata_0.intValue(), 2);

+        context.ungetService(refToto);

+        context.ungetService(refTata);

+        toto = null;

+        tata = null;

+

+        // Stop the factory

+        tataFactory.stop();

+        assertTrue("Assert under state - 5", under.getState() == ComponentInstance.INVALID);

+        refToto = Utils.getServiceReferenceByName(context, Toto.class.getName(), "ff");

+        refTata = Utils.getServiceReferenceByName(context, Tata.class.getName(), "ff");

+        assertNull("Assert no toto service - 5", refToto);

+        assertNull("Assert no tata service - 5", refTata);

+ 

+        totoProv2.stop();

+        totoProv.stop();

+        tataFactory.start();

+        assertTrue("Assert under state - 6", under.getState() == ComponentInstance.VALID);

+        refToto = Utils.getServiceReferenceByName(context, Toto.class.getName(), "ff");

+        refTata = Utils.getServiceReferenceByName(context, Tata.class.getName(), "ff");

+        assertNotNull("Assert toto service - 6", refToto);

+        assertNotNull("Assert tata service - 6", refTata);

+        toto = (Toto) context.getService(refToto);

+        tata = (Tata) context.getService(refTata);

+ 

+        invokeAll(tata);

+        invokeTotoOpt(toto);

+        //  Check tata

+        props = tata.getPropsTata();

+        tata_0 = (Integer) props.get("tata");

+        assertEquals("Assert tata - 6", tata_0.intValue(), 1);

+        context.ungetService(refToto);

+        context.ungetService(refTata);

+        toto = null;

+        tata = null;

+ 

+        // Is arch exposed

+        assertNotNull("Test arch", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        

+        tataFactory.stop();

+        

+        assertTrue("Assert under state - 7", under.getState() == ComponentInstance.INVALID);

+        assertNotNull("Test arch-2", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        refToto = Utils.getServiceReferenceByName(context, Toto.class.getName(), "ff");

+        refTata = Utils.getServiceReferenceByName(context, Tata.class.getName(), "ff");

+        assertNull("Assert no toto service - 7", refToto);

+        assertNull("Assert no tata service - 7", refTata);

+        

+        under.dispose();

+        under = null;

+    }

+

+    private void invoke(Tata tota) {

+        tota.tata();

+        

+        assertEquals("Assert invoke tataint", tota.tataInt(2), 2);

+        assertEquals("Assert invoke tataLong", tota.tataLong(2), 2);

+        assertEquals("Assert invoke tataDouble", tota.tataDouble(2), 2);

+        assertEquals("Assert invoke tataChar", tota.tataChar('a'), 'a');

+        assertTrue("Assert invoke tataBoolean", tota.tataBoolean(true));

+        assertEquals("Assert invoke tataByte", tota.tataByte((byte)2), 2);

+        assertEquals("Assert invoke tataShort", tota.tataShort((short)5), 5);

+        assertEquals("Assert invoke tataFloat", tota.tataFloat(5), 5);

+        

+    }

+    

+    

+    private void invokeStr(Tata tota) {

+        tota.tataStr();

+    }

+    

+    private void invokeToto(Toto tota) {

+        tota.toto();

+        assertEquals("Assert toto", tota.toto("foo"), "foo");

+        tota.toto(1,2);

+        tota.toto1("foo");

+    }

+    

+    private void invokeAll(Tata tota) {

+        invoke(tota);

+        //invokeArrays(tota);

+        invokeStr(tota);

+        //invokeTata(tota);

+        //invokeTata1(tota);

+        //invokeTata5(tota);

+        //invokeAdd(tota);

+    }

+    

+    private void invokeTotoOpt(Toto tota) {

+        try {

+            tota.toto();

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+        

+        try {

+            assertEquals("Assert toto", tota.toto("foo"), "foo");

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+        

+        

+        try {

+            tota.toto(1,2);

+            fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+        

+        try {

+        	tota.toto1("foo");

+        	fail("UnsupportedOperationException expected");

+        } catch(UnsupportedOperationException e) { }

+    }

+    

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp7.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp7.java
new file mode 100644
index 0000000..67a6c19
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp7.java
@@ -0,0 +1,333 @@
+/* 

+ * 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.felix.ipojo.test.composite.provides;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.architecture.Architecture;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.component.TotoProvider;

+import org.apache.felix.ipojo.test.composite.service.Tota;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.osgi.framework.ServiceReference;

+

+public class TestComp7 extends OSGiTestCase {

+

+    private ComponentFactory tataFactory;

+    private ComponentFactory totoFactory;

+    private ComponentFactory tataFactory2;

+    

+    private ComponentInstance totoProv, totoProv2;

+    private ComponentInstance under;

+    

+    public void setUp() {

+        tataFactory = (ComponentFactory) Utils.getFactoryByName(context, "tata");

+        totoFactory = (ComponentFactory) Utils.getFactoryByName(context, "toto");

+        tataFactory2 = (ComponentFactory) Utils.getFactoryByName(context, "comp-6");

+        tataFactory2.stop();

+        

+        Properties props = new Properties();

+        props.put("name", "toto provider");

+        try {

+            totoProv = totoFactory.createComponentInstance(props);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        Properties props3 = new Properties();

+        props3.put("name", "toto provider 2");

+        try {

+            totoProv2 = totoFactory.createComponentInstance(props3);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        totoProv.stop();

+        totoProv2.stop();

+        

+        Factory factory = Utils.getFactoryByName(context, "comp-7");

+        Properties props2 = new Properties();

+        props2.put("name", "ff");

+        try {

+            under = factory.createComponentInstance(props2);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        tataFactory.stop();

+         

+    }

+    

+    public void tearDown() {

+        tataFactory.start();

+        totoProv.dispose();

+        totoProv = null;

+        totoProv2.dispose();

+        totoProv2 = null;

+        tataFactory2.start();

+        

+        // Reset counters

+        TotoProvider.toto = 0;

+        TotoProvider.toto_2 = 0;

+        TotoProvider.toto_3 = 0;

+        TotoProvider.toto_4 = 0;

+        TotoProvider.toto1 = 0;

+    }

+    

+    public void testSimple() {

+        // Neither factory nor instance

+        assertTrue("Assert under state - 1", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 1", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the importer

+        totoProv.start();

+        assertTrue("Assert under state - 2", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 2", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the factory

+        tataFactory.start();

+        assertTrue("Assert under state - 3", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 3", context.getServiceReference(Tota.class.getName()));

+        ServiceReference ref = context.getServiceReference(Tota.class.getName());

+        Tota tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        Properties props = tota.getProps();

+        Integer toto = (Integer) props.get("toto");

+        Integer toto_2 = (Integer) props.get("toto_2");

+        Integer toto_3 = (Integer) props.get("toto_3");

+        Integer toto_4 = (Integer) props.get("toto_4");

+        assertEquals("Assert toto - 3 ("+toto.intValue()+")", toto.intValue(), 1);

+        assertEquals("Assert toto_2 - 3", toto_2.intValue(), 1);

+        assertEquals("Assert toto_3 - 3", toto_3.intValue(), 1);

+        assertEquals("Assert toto_4 - 3", toto_4.intValue(), 0);

+        //Check tata

+        props = tota.getPropsTata();

+        Integer tata = (Integer) props.get("tata");

+        Integer tataStr = (Integer) props.get("tataStr");

+        Integer tataStrs = (Integer) props.get("tataStrs");

+        Integer tata_2 = (Integer) props.get("tata_2");

+        Integer tata_3 = (Integer) props.get("tata_3");

+        Integer tata1 = (Integer) props.get("tata1");

+        Integer tata1_1 = (Integer) props.get("tata1_1");

+        Integer tata5 = (Integer) props.get("tata5");

+        Integer tata5_1 = (Integer) props.get("tata5_1");

+        Integer tata5_2 = (Integer) props.get("tata5_2");

+        assertEquals("Assert tata - 3", tata.intValue(), 1);

+        assertEquals("Assert tataStr - 3", tataStr.intValue(), 1);

+        assertEquals("Assert tataStrs - 3", tataStrs.intValue(), 0);

+        assertEquals("Assert tata_2 - 3", tata_2.intValue(), 1);

+        assertEquals("Assert tata_3 - 3", tata_3.intValue(), 1);

+        assertEquals("Assert tata1 - 3", tata1.intValue(), 1);

+        assertEquals("Assert tata1_1 - 3", tata1_1.intValue(), 1);

+        assertEquals("Assert tata5 - 3", tata5.intValue(), 1);

+        assertEquals("Assert tata5_1 - 3", tata5_1.intValue(), 1);

+        assertEquals("Assert tata5_2 - 3", tata5_2.intValue(), 1);

+        context.ungetService(ref);

+        tota = null;

+        

+        // Start a second import

+        totoProv2.start();

+        assertTrue("Assert under state - 4", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 4", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        props = tota.getProps();

+        toto = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        assertEquals("Assert toto - 4", toto.intValue(), 2);

+        assertEquals("Assert toto_2 - 4", toto_2.intValue(), 2);

+        assertEquals("Assert toto_3 - 4", toto_3.intValue(), 2);

+        assertEquals("Assert toto_4 - 4", toto_4.intValue(), 0);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        tataStr = (Integer) props.get("tataStr");

+        tataStrs = (Integer) props.get("tataStrs");

+        tata_2 = (Integer) props.get("tata_2");

+        tata_3 = (Integer) props.get("tata_3");

+        tata1 = (Integer) props.get("tata1");

+        tata1_1 = (Integer) props.get("tata1_1");

+        tata5 = (Integer) props.get("tata5");

+        tata5_1 = (Integer) props.get("tata5_1");

+        tata5_2 = (Integer) props.get("tata5_2");

+        assertEquals("Assert tata - 4", tata.intValue(), 2);

+        assertEquals("Assert tataStr - 4", tataStr.intValue(), 2);

+        assertEquals("Assert tataStrs - 4", tataStrs.intValue(), 0);

+        assertEquals("Assert tata_2 - 4", tata_2.intValue(), 2);

+        assertEquals("Assert tata_3 - 4", tata_3.intValue(), 2);

+        assertEquals("Assert tata1 - 4", tata1.intValue(), 2);

+        assertEquals("Assert tata1_1 - 4", tata1_1.intValue(), 2);

+        assertEquals("Assert tata5 - 4", tata5.intValue(), 2);

+        assertEquals("Assert tata5_1 - 4", tata5_1.intValue(), 2);

+        assertEquals("Assert tata5_2 - 4", tata5_2.intValue(), 2);

+

+        context.ungetService(ref);

+        tota = null;

+        

+        tataFactory.stop();

+        assertTrue("Assert under state - 5", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 5", context.getServiceReference(Tota.class.getName()));

+        

+        totoProv2.stop();

+        tataFactory.start();

+        assertTrue("Assert under state - 6", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 6", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        props = tota.getProps();

+        toto = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        assertEquals("Assert toto - 6", toto.intValue(), 3);

+        assertEquals("Assert toto_2 - 6", toto_2.intValue(), 3);

+        assertEquals("Assert toto_3 - 6", toto_3.intValue(), 3);

+        assertEquals("Assert toto_4 - 6", toto_4.intValue(), 0);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        tataStr = (Integer) props.get("tataStr");

+        tataStrs = (Integer) props.get("tataStrs");

+        tata_2 = (Integer) props.get("tata_2");

+        tata_3 = (Integer) props.get("tata_3");

+        tata1 = (Integer) props.get("tata1");

+        tata1_1 = (Integer) props.get("tata1_1");

+        tata5 = (Integer) props.get("tata5");

+        tata5_1 = (Integer) props.get("tata5_1");

+        tata5_2 = (Integer) props.get("tata5_2");

+        assertEquals("Assert tata - 6", 1, tata.intValue());

+        assertEquals("Assert tataStr - 6", tataStr.intValue(), 1);

+        assertEquals("Assert tataStrs - 6", tataStrs.intValue(), 0);

+        assertEquals("Assert tata_2 - 6", tata_2.intValue(), 1);

+        assertEquals("Assert tata_3 - 6", tata_3.intValue(), 1);

+        assertEquals("Assert tata1 - 6", tata1.intValue(), 1);

+        assertEquals("Assert tata1_1 - 6", tata1_1.intValue(), 1);

+        assertEquals("Assert tata5 - 6", tata5.intValue(), 1);

+        assertEquals("Assert tata5_1 - 6", tata5_1.intValue(), 1);

+        assertEquals("Assert tata5_2 - 6", tata5_2.intValue(), 1);

+        context.ungetService(ref);

+        tota = null;

+        

+        // Is arch exposed

+        assertNotNull("Test arch", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        

+        totoProv.stop();

+        

+        assertTrue("Assert under state - 7", under.getState() == ComponentInstance.INVALID);

+        assertNotNull("Test arch-2", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        assertNull("Assert no tota service - 7", context.getServiceReference(Tota.class.getName()));

+        

+        under.dispose();

+        under = null;

+    }

+

+    private void invoke(Tota tota) {

+        tota.tata();

+        

+        assertEquals("Assert invoke tataint", tota.tataInt(2), 2);

+        assertEquals("Assert invoke tataLong", tota.tataLong(2), 2);

+        assertEquals("Assert invoke tataDouble", tota.tataDouble(2), 2);

+        assertEquals("Assert invoke tataChar", tota.tataChar('a'), 'a');

+        assertTrue("Assert invoke tataBoolean", tota.tataBoolean(true));

+        assertEquals("Assert invoke tataByte", tota.tataByte((byte)2), 2);

+        assertEquals("Assert invoke tataShort", tota.tataShort((short)5), 5);

+        assertEquals("Assert invoke tataFloat", tota.tataFloat(5), 5);

+        

+    }

+    

+    private void invokeArrays(Tota tota) {

+        

+        int[] a = new int[] {1,2,3};

+        assertEquals("Assert invoke tataint[]", tota.tataInts(a), a);

+        

+        long[] b = new long[] {1,2,3};

+        assertEquals("Assert invoke tataLong[]", tota.tataLongs(b), b);

+        

+        double[] c = new double[] {1,2,3};

+        assertEquals("Assert invoke tataDouble[]", tota.tataDoubles(c), c);

+        

+        char[] d = new char[] {'a','b', 'c'};

+        assertEquals("Assert invoke tataChar[]", tota.tataChars(d), d);

+        

+        boolean[] e = new boolean[] {true, false};

+        assertEquals("Assert invoke tataBoolean[]", tota.tataBooleans(e), e);

+        

+        byte[] f = new byte[] {(byte) 1};

+        assertEquals("Assert invoke tataByte[]", tota.tataBytes(f), f);

+        

+        short[] g = new short[] {(short) 1};

+        assertEquals("Assert invoke tataShort[]", tota.tataShorts(g), g);

+        

+        float[] h = new float[] {5,6,7};

+        assertEquals("Assert invoke tataFloat[]", tota.tataFloats(h), h);

+        

+    }

+    

+    private void invokeStr(Tota tota) {

+        tota.tataStr();

+    }

+    

+    private void invokeTata(Tota tota) {

+        tota.tata(1,2);

+        tota.tata("tototototo");

+    }

+    

+    private void invokeTata1(Tota tota) {

+        assertEquals("Assert tata1", tota.tata1("foo"), "foo");

+        assertEquals("Assert tata1 - 2", tota.tata1(new char[] {'a','b','c'}), "abc");

+    }

+    

+    private void invokeTata5(Tota tota) {

+        assertEquals("Assert tata5 -1", tota.tata5("foo",1), "foo"+1);

+        assertEquals("Assert tata5 - 2", tota.tata5(new String[] {"a","b","c"}, 1), "31");

+        assertEquals("Assert tata5 - 3", tota.tata5("foo", new int[] {1,2,3}), "foo3");

+    }

+    

+    private void invokeAdd(Tota tota) {

+        assertEquals("Assert add", tota.add(1,1,1), 3);

+    }

+    

+    private void invokeToto(Tota tota) {

+        tota.toto();

+        assertEquals("Assert toto", tota.toto("foo"), "foo");

+        tota.toto(1,2);

+    }

+    

+    private void invokeAll(Tota tota) {

+        invoke(tota);

+        invokeArrays(tota);

+        invokeStr(tota);

+        invokeTata(tota);

+        invokeTata1(tota);

+        invokeTata5(tota);

+        invokeAdd(tota);

+        invokeToto(tota);

+    }

+    

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp8.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp8.java
new file mode 100644
index 0000000..f9ceb09
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/provides/TestComp8.java
@@ -0,0 +1,365 @@
+/* 

+ * 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.felix.ipojo.test.composite.provides;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentFactory;

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.architecture.Architecture;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.component.TotoProvider;

+import org.apache.felix.ipojo.test.composite.component.TotoProviderGlue;

+import org.apache.felix.ipojo.test.composite.service.Tota;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.osgi.framework.ServiceReference;

+

+public class TestComp8 extends OSGiTestCase {

+

+    private ComponentFactory tataFactory;

+    private ComponentFactory totoFactory;

+    private ComponentFactory tataFactory2;

+    

+    private ComponentInstance totoProv, totoProv2;

+    private ComponentInstance under;

+    

+    public void setUp() {

+        tataFactory = (ComponentFactory) Utils.getFactoryByName(context, "tata");

+        totoFactory = (ComponentFactory) Utils.getFactoryByName(context, "toto");

+        tataFactory2 = (ComponentFactory) Utils.getFactoryByName(context, "comp-6");

+        tataFactory2.stop();

+        

+        Properties props = new Properties();

+        props.put("name", "toto provider");

+        try {

+            totoProv = totoFactory.createComponentInstance(props);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        Properties props3 = new Properties();

+        props3.put("name", "toto provider 2");

+        try {

+            totoProv2 = totoFactory.createComponentInstance(props3);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        

+        totoProv.stop();

+        totoProv2.stop();

+        

+        Factory factory = Utils.getFactoryByName(context, "comp-8");

+        Properties props2 = new Properties();

+        props2.put("name", "ff");

+        try {

+            under = factory.createComponentInstance(props2);

+        } catch(Exception e) {

+            e.printStackTrace();

+        }

+        tataFactory.stop();

+         

+    }

+    

+    public void tearDown() {

+        tataFactory.start();

+        totoProv.dispose();

+        totoProv = null;

+        totoProv2.dispose();

+        totoProv2 = null;

+        tataFactory2.start();

+        

+        // Reset counters

+        TotoProvider.toto = 0;

+        TotoProvider.toto_2 = 0;

+        TotoProvider.toto_3 = 0;

+        TotoProvider.toto_4 = 0;

+        TotoProvider.toto1 = 0;

+        TotoProviderGlue.toto = 0;

+        TotoProviderGlue.toto_2 = 0;

+        TotoProviderGlue.toto_3 = 0;

+        TotoProviderGlue.toto_4 = 0;

+        TotoProviderGlue.toto1 = 0;

+    }

+    

+    public void testSimple() {        

+        // Neither factory nor instance

+        assertTrue("Assert under state - 1", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 1", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the importer

+        totoProv.start();

+        assertTrue("Assert under state - 2", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 2", context.getServiceReference(Tota.class.getName()));

+        

+        // Start the factory

+        tataFactory.start();

+        assertTrue("Assert under state - 3", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 3", context.getServiceReference(Tota.class.getName()));

+        ServiceReference ref = context.getServiceReference(Tota.class.getName());

+        Tota tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        Properties props = tota.getProps();

+        Integer toto = (Integer) props.get("toto");

+        Integer toto_2 = (Integer) props.get("toto_2");

+        Integer toto_3 = (Integer) props.get("toto_3");

+        Integer toto_4 = (Integer) props.get("toto_4");

+        Integer gtoto = (Integer) props.get("gtoto");

+        Integer gtoto_2 = (Integer) props.get("gtoto_2");

+        Integer gtoto_3 = (Integer) props.get("gtoto_3");

+        Integer gtoto_4 = (Integer) props.get("gtoto_4");

+        assertEquals("Assert toto - 3 ("+toto.intValue()+")", toto.intValue(), 1);

+        assertEquals("Assert toto_2 - 3", toto_2.intValue(), 1);

+        assertEquals("Assert toto_3 - 3", toto_3.intValue(), 0);

+        assertEquals("Assert toto_4 - 3", toto_4.intValue(), 0);

+        assertEquals("Assert gtoto - 3 ("+gtoto.intValue()+")", gtoto.intValue(), 1);

+        assertEquals("Assert gtoto_2 - 3", gtoto_2.intValue(), 1);

+        assertEquals("Assert gtoto_3 - 3", gtoto_3.intValue(), 1);

+        assertEquals("Assert gtoto_4 - 3", gtoto_4.intValue(), 0);

+        //Check tata

+        props = tota.getPropsTata();

+        Integer tata = (Integer) props.get("tata");

+        Integer tataStr = (Integer) props.get("tataStr");

+        Integer tataStrs = (Integer) props.get("tataStrs");

+        Integer tata_2 = (Integer) props.get("tata_2");

+        Integer tata_3 = (Integer) props.get("tata_3");

+        Integer tata1 = (Integer) props.get("tata1");

+        Integer tata1_1 = (Integer) props.get("tata1_1");

+        Integer tata5 = (Integer) props.get("tata5");

+        Integer tata5_1 = (Integer) props.get("tata5_1");

+        Integer tata5_2 = (Integer) props.get("tata5_2");

+        assertEquals("Assert tata - 3", tata.intValue(), 1);

+        assertEquals("Assert tataStr - 3", tataStr.intValue(), 1);

+        assertEquals("Assert tataStrs - 3", tataStrs.intValue(), 0);

+        assertEquals("Assert tata_2 - 3", tata_2.intValue(), 1);

+        assertEquals("Assert tata_3 - 3", tata_3.intValue(), 1);

+        assertEquals("Assert tata1 - 3", tata1.intValue(), 1);

+        assertEquals("Assert tata1_1 - 3", tata1_1.intValue(), 1);

+        assertEquals("Assert tata5 - 3", tata5.intValue(), 1);

+        assertEquals("Assert tata5_1 - 3", tata5_1.intValue(), 1);

+        assertEquals("Assert tata5_2 - 3", tata5_2.intValue(), 1);

+        context.ungetService(ref);

+        tota = null;

+        

+        // Start a second import

+        totoProv2.start();

+        assertTrue("Assert under state - 4", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 4", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        props = tota.getProps();

+        toto = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        gtoto = (Integer) props.get("gtoto");

+        gtoto_2 = (Integer) props.get("gtoto_2");

+        gtoto_3 = (Integer) props.get("gtoto_3");

+        gtoto_4 = (Integer) props.get("gtoto_4");

+        assertEquals("Assert toto - 4", toto.intValue(), 2);

+        assertEquals("Assert toto_2 - 4", toto_2.intValue(), 2);

+        assertEquals("Assert toto_3 - 4", toto_3.intValue(), 0);

+        assertEquals("Assert toto_4 - 4", toto_4.intValue(), 0);

+        assertEquals("Assert gtoto - 4 ("+gtoto.intValue()+")", gtoto.intValue(), 2);

+        assertEquals("Assert gtoto_2 - 4", gtoto_2.intValue(), 2);

+        assertEquals("Assert gtoto_3 - 4", gtoto_3.intValue(), 2);

+        assertEquals("Assert gtoto_4 - 4", gtoto_4.intValue(), 0);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        tataStr = (Integer) props.get("tataStr");

+        tataStrs = (Integer) props.get("tataStrs");

+        tata_2 = (Integer) props.get("tata_2");

+        tata_3 = (Integer) props.get("tata_3");

+        tata1 = (Integer) props.get("tata1");

+        tata1_1 = (Integer) props.get("tata1_1");

+        tata5 = (Integer) props.get("tata5");

+        tata5_1 = (Integer) props.get("tata5_1");

+        tata5_2 = (Integer) props.get("tata5_2");

+        assertEquals("Assert tata - 4", tata.intValue(), 2);

+        assertEquals("Assert tataStr - 4", tataStr.intValue(), 2);

+        assertEquals("Assert tataStrs - 4", tataStrs.intValue(), 0);

+        assertEquals("Assert tata_2 - 4", tata_2.intValue(), 2);

+        assertEquals("Assert tata_3 - 4", tata_3.intValue(), 2);

+        assertEquals("Assert tata1 - 4", tata1.intValue(), 2);

+        assertEquals("Assert tata1_1 - 4", tata1_1.intValue(), 2);

+        assertEquals("Assert tata5 - 4", tata5.intValue(), 2);

+        assertEquals("Assert tata5_1 - 4", tata5_1.intValue(), 2);

+        assertEquals("Assert tata5_2 - 4", tata5_2.intValue(), 2);

+

+        context.ungetService(ref);

+        tota = null;

+        

+        tataFactory.stop();

+        assertTrue("Assert under state - 5", under.getState() == ComponentInstance.INVALID);

+        assertNull("Assert no tota service - 5", context.getServiceReference(Tota.class.getName()));

+        

+        totoProv2.stop();

+        tataFactory.start();

+        assertTrue("Assert under state - 6", under.getState() == ComponentInstance.VALID);

+        assertNotNull("Assert tota service - 6", context.getServiceReference(Tota.class.getName()));

+        ref = context.getServiceReference(Tota.class.getName());

+        tota = (Tota) context.getService(ref);

+        invokeAll(tota);

+        // Check toto

+        props = tota.getProps();

+        toto = (Integer) props.get("toto");

+        toto_2 = (Integer) props.get("toto_2");

+        toto_3 = (Integer) props.get("toto_3");

+        toto_4 = (Integer) props.get("toto_4");

+        gtoto = (Integer) props.get("gtoto");

+        gtoto_2 = (Integer) props.get("gtoto_2");

+        gtoto_3 = (Integer) props.get("gtoto_3");

+        gtoto_4 = (Integer) props.get("gtoto_4");

+        assertEquals("Assert toto - 6", toto.intValue(), 3);

+        assertEquals("Assert toto_2 - 6", toto_2.intValue(), 3);

+        assertEquals("Assert toto_3 - 6", toto_3.intValue(), 0);

+        assertEquals("Assert toto_4 - 6", toto_4.intValue(), 0);

+        assertEquals("Assert gtoto - 6 ("+gtoto.intValue()+")", gtoto.intValue(), 3);

+        assertEquals("Assert gtoto_2 - 6", gtoto_2.intValue(), 3);

+        assertEquals("Assert gtoto_3 - 6", gtoto_3.intValue(), 3);

+        assertEquals("Assert gtoto_4 - 6", gtoto_4.intValue(), 0);

+        //Check tata

+        props = tota.getPropsTata();

+        tata = (Integer) props.get("tata");

+        tataStr = (Integer) props.get("tataStr");

+        tataStrs = (Integer) props.get("tataStrs");

+        tata_2 = (Integer) props.get("tata_2");

+        tata_3 = (Integer) props.get("tata_3");

+        tata1 = (Integer) props.get("tata1");

+        tata1_1 = (Integer) props.get("tata1_1");

+        tata5 = (Integer) props.get("tata5");

+        tata5_1 = (Integer) props.get("tata5_1");

+        tata5_2 = (Integer) props.get("tata5_2");

+        assertEquals("Assert tata - 6", tata.intValue(), 1);

+        assertEquals("Assert tataStr - 6", tataStr.intValue(), 1);

+        assertEquals("Assert tataStrs - 6", tataStrs.intValue(), 0);

+        assertEquals("Assert tata_2 - 6", tata_2.intValue(), 1);

+        assertEquals("Assert tata_3 - 6", tata_3.intValue(), 1);

+        assertEquals("Assert tata1 - 6", tata1.intValue(), 1);

+        assertEquals("Assert tata1_1 - 6", tata1_1.intValue(), 1);

+        assertEquals("Assert tata5 - 6", tata5.intValue(), 1);

+        assertEquals("Assert tata5_1 - 6", tata5_1.intValue(), 1);

+        assertEquals("Assert tata5_2 - 6", tata5_2.intValue(), 1);

+        context.ungetService(ref);

+        tota = null;

+        

+        // Is arch exposed

+        assertNotNull("Test arch", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        

+        totoProv.stop();

+        

+        assertTrue("Assert under state - 7", under.getState() == ComponentInstance.INVALID);

+        assertNotNull("Test arch-2", Utils.getServiceReferenceByName(context, Architecture.class.getName(), "ff"));

+        assertNull("Assert no tota service - 7", context.getServiceReference(Tota.class.getName()));

+        

+        under.dispose();

+        under = null;

+    }

+

+

+

+    private void invoke(Tota tota) {

+        tota.tata();

+        

+        assertEquals("Assert invoke tataint", tota.tataInt(2), 2);

+        assertEquals("Assert invoke tataLong", tota.tataLong(2), 2);

+        assertEquals("Assert invoke tataDouble", tota.tataDouble(2), 2);

+        assertEquals("Assert invoke tataChar", tota.tataChar('a'), 'a');

+        assertTrue("Assert invoke tataBoolean", tota.tataBoolean(true));

+        assertEquals("Assert invoke tataByte", tota.tataByte((byte)2), 2);

+        assertEquals("Assert invoke tataShort", tota.tataShort((short)5), 5);

+        assertEquals("Assert invoke tataFloat", tota.tataFloat(5), 5);

+        

+    }

+    

+    private void invokeArrays(Tota tota) {

+        

+        int[] a = new int[] {1,2,3};

+        assertEquals("Assert invoke tataint[]", tota.tataInts(a), a);

+        

+        long[] b = new long[] {1,2,3};

+        assertEquals("Assert invoke tataLong[]", tota.tataLongs(b), b);

+        

+        double[] c = new double[] {1,2,3};

+        assertEquals("Assert invoke tataDouble[]", tota.tataDoubles(c), c);

+        

+        char[] d = new char[] {'a','b', 'c'};

+        assertEquals("Assert invoke tataChar[]", tota.tataChars(d), d);

+        

+        boolean[] e = new boolean[] {true, false};

+        assertEquals("Assert invoke tataBoolean[]", tota.tataBooleans(e), e);

+        

+        byte[] f = new byte[] {(byte) 1};

+        assertEquals("Assert invoke tataByte[]", tota.tataBytes(f), f);

+        

+        short[] g = new short[] {(short) 1};

+        assertEquals("Assert invoke tataShort[]", tota.tataShorts(g), g);

+        

+        float[] h = new float[] {5,6,7};

+        assertEquals("Assert invoke tataFloat[]", tota.tataFloats(h), h);

+        

+    }

+    

+    private void invokeStr(Tota tota) {

+        tota.tataStr();

+    }

+    

+    private void invokeTata(Tota tota) {

+        tota.tata(1,2);

+        tota.tata("tototototo");

+    }

+    

+    private void invokeTata1(Tota tota) {

+        assertEquals("Assert tata1", tota.tata1("foo"), "foo");

+        assertEquals("Assert tata1 - 2", tota.tata1(new char[] {'a','b','c'}), "abc");

+    }

+    

+    private void invokeTata5(Tota tota) {

+        assertEquals("Assert tata5 -1", tota.tata5("foo",1), "foo"+1);

+        assertEquals("Assert tata5 - 2", tota.tata5(new String[] {"a","b","c"}, 1), "31");

+        assertEquals("Assert tata5 - 3", tota.tata5("foo", new int[] {1,2,3}), "foo3");

+    }

+    

+    private void invokeAdd(Tota tota) {

+        assertEquals("Assert add", tota.add(1,1,1), 3);

+    }

+    

+    private void invokeToto(Tota tota) {

+        tota.toto();

+        assertEquals("Assert toto", tota.toto("foo"), "foo");

+        tota.toto(1,2);

+    }

+    

+    private void invokeAll(Tota tota) {

+        invoke(tota);

+        invokeArrays(tota);

+        invokeStr(tota);

+        invokeTata(tota);

+        invokeTata1(tota);

+        invokeTata5(tota);

+        invokeAdd(tota);

+        invokeToto(tota);

+    }

+    

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/service/A123/CheckService2.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/service/A123/CheckService2.java
new file mode 100644
index 0000000..1a745a9
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/service/A123/CheckService2.java
@@ -0,0 +1,25 @@
+/* 

+ * 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.felix.ipojo.test.composite.service.A123;

+

+public interface CheckService2 {

+	

+	public boolean check();

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/service/Tata.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/service/Tata.java
new file mode 100644
index 0000000..04fe33d
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/service/Tata.java
@@ -0,0 +1,62 @@
+/* 

+ * 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.felix.ipojo.test.composite.service;

+

+import java.util.Properties;

+

+public interface Tata {

+    

+    public Properties getPropsTata();

+    

+    public void tata();

+    

+    public int tataInt(int i);

+    public long tataLong(long l);

+    public double tataDouble(double d);

+    public char tataChar(char c);

+    public boolean tataBoolean(boolean b);

+    public short tataShort(short s);

+    public float tataFloat(float f);

+    public byte tataByte(byte b);

+    

+    public int[] tataInts(int[] its);

+    public long[] tataLongs(long[] l);

+    public double[] tataDoubles(double[] d);

+    public char[] tataChars(char[] c);

+    public boolean[] tataBooleans(boolean[] b);

+    public short[] tataShorts(short[] s);

+    public float[] tataFloats(float[] f);

+    public byte[] tataBytes(byte[] b);

+    

+    public String tataStr();

+    public String[] tataStrs();

+    

+    public void tata(int i, int j);

+    public void tata(String s);

+    

+    public String tata1(String a);

+    public String tata1(char[] a);

+    

+    public String tata5(String a, int i);

+    public String tata5(String[] a, int i);

+    public String tata5(String a, int[] i);

+    

+    public long add(int i, int j, int k);

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/service/Tota.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/service/Tota.java
new file mode 100644
index 0000000..f7481a4
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/service/Tota.java
@@ -0,0 +1,78 @@
+/* 

+ * 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.felix.ipojo.test.composite.service;

+

+import java.util.Properties;

+

+public interface Tota {

+    

+    public static final String specification="specification { " +

+    		"requires { " +

+    		    "$specification=\"org.apache.felix.ipojo.test.composite.service.Toto\" " +

+    		    "$optional=\"true\" " +

+    		    "$aggregate=\"true\" " +

+    		    "$type=\"service\" " +

+    		"} }"; 

+    

+    public Properties getProps() throws UnsupportedOperationException;;

+    public Properties getPropsTata();

+    

+    public void tata();

+    

+    public int tataInt(int i);

+    public long tataLong(long l);

+    public double tataDouble(double d);

+    public char tataChar(char c);

+    public boolean tataBoolean(boolean b);

+    public short tataShort(short s);

+    public float tataFloat(float f);

+    public byte tataByte(byte b);

+    

+    public int[] tataInts(int[] its);

+    public long[] tataLongs(long[] l);

+    public double[] tataDoubles(double[] d);

+    public char[] tataChars(char[] c);

+    public boolean[] tataBooleans(boolean[] b);

+    public short[] tataShorts(short[] s);

+    public float[] tataFloats(float[] f);

+    public byte[] tataBytes(byte[] b);

+    

+    public String tataStr();

+    public String[] tataStrs();

+    

+    public void tata(int i, int j);

+    public void tata(String s);

+    

+    public String tata1(String a);

+    public String tata1(char[] a);

+    

+    public String tata5(String a, int i);

+    public String tata5(String[] a, int i);

+    public String tata5(String a, int[] i);

+    

+    public long add(int i, int j, int k);

+    

+    public void toto() throws UnsupportedOperationException;    

+    public void toto(int i, int j) throws UnsupportedOperationException;

+    public String toto(String a) throws UnsupportedOperationException;

+    

+    public void toto1(String j) throws UnsupportedOperationException;

+    

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/service/Toto.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/service/Toto.java
new file mode 100644
index 0000000..edf6c10
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/service/Toto.java
@@ -0,0 +1,37 @@
+/* 

+ * 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.felix.ipojo.test.composite.service;

+

+import java.util.Properties;

+

+public interface Toto {

+    

+    public Properties getProps();

+    

+    public void toto();    

+    public void toto(int i, int j);

+    public String toto(String a);

+    public String toto(String[] a);

+    

+    public void toto1(String j);

+    

+    public int count();

+

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/test/CompositeTest.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/test/CompositeTest.java
new file mode 100644
index 0000000..9f7c6c4
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/test/CompositeTest.java
@@ -0,0 +1,180 @@
+/* 

+ * 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.felix.ipojo.test.composite.test;

+

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.junit4osgi.OSGiTestCase;

+import org.apache.felix.ipojo.test.composite.util.Utils;

+import org.apache.felix.ipojo.test.scenarios.service.BazService;

+import org.apache.felix.ipojo.test.scenarios.service.CheckService;

+import org.apache.felix.ipojo.test.scenarios.service.FooService;

+import org.osgi.framework.InvalidSyntaxException;

+import org.osgi.framework.ServiceReference;

+

+public class CompositeTest extends OSGiTestCase {

+	

+	public void testAPI() {

+		Factory fact1 = Utils.getFactoryByName(context, "composite.empty");

+		Properties p = new Properties();

+		p.put("name", "empty-1");

+		ComponentInstance empty = null;

+		try {

+			empty = fact1.createComponentInstance(p);

+		} catch(Exception e) {

+			e.printStackTrace();

+			fail(e.getMessage());

+		}

+		

+		ServiceContext sc = Utils.getServiceContext(empty);

+		

+		Factory fact2 = Utils.getFactoryByName(context, "composite.test.2");

+		Properties props2 = new Properties();

+		props2.put("name", "2"); // 2

+		Factory fact3 = Utils.getFactoryByName(context, "composite.test.3");

+		Properties props3 = new Properties();

+		props3.put("name", "3");

+		ComponentInstance comp2 = null;

+		ComponentInstance comp3 = null;

+		try {

+			comp2 = fact2.createComponentInstance(props2, sc);

+			comp3 = fact3.createComponentInstance(props3, sc);

+		} catch(Throwable e) {

+		    e.printStackTrace();

+		    fail(e.getMessage());

+		}

+		

+		assertTrue("Test comp3", comp3.getState() == ComponentInstance.VALID);

+		assertTrue("Test comp2", comp2.getState() == ComponentInstance.VALID);

+		

+		ServiceReference ref = null;

+

+		ref = Utils.getServiceReferenceByName(sc, CheckService.class.getName(), "2"); // 2

+

+		assertNotNull("Check ref", ref);

+		CheckService cs = (CheckService) sc.getService(ref);

+		assertTrue("Check invoke", cs.check());

+		

+		comp3.dispose();

+		comp2.dispose();

+		empty.dispose();

+	}

+	

+	public void testInstantiator() {

+		String type = "composite.instantiator";

+		Factory fact = Utils.getFactoryByName(context, type);

+		ComponentInstance ci = null;

+		Properties p = new Properties();

+		p.put("name", "mon_coeur");

+		try {

+			ci = fact.createComponentInstance(p);

+		} catch(Exception e) {

+			e.printStackTrace();

+		}

+				

+		assertTrue("Check ci", ci.getState() == ComponentInstance.VALID);

+		ServiceReference ref = Utils.getServiceReferenceByName(context, BazService.class.getName(), "mon_coeur");

+		assertNotNull("Check ref",ref);

+		BazService bs = (BazService) context.getService(ref);

+		assertTrue("Check invocation", bs.foo());

+		context.ungetService(ref);

+		ref = Utils.getServiceReferenceByName(context, FooService.class.getName(), "mon_coeur");

+		assertNotNull("Check ref 2 ",ref);

+		FooService fs = (FooService) context.getService(ref);

+		assertTrue("Check invocation", fs.foo());

+		context.ungetService(ref);

+		ci.dispose();

+	}

+	

+	public void testAPI2() {

+		Factory fact1 = Utils.getFactoryByName(context, "composite.empty");

+		Properties p = new Properties();

+		p.put("name", "empty-2");

+		ComponentInstance empty = null;

+		try {

+			empty = fact1.createComponentInstance(p);

+		} catch(Exception e) {

+			e.printStackTrace();

+		}

+		

+		ServiceContext sc = Utils.getServiceContext(empty);

+		

+		Factory fact2 = Utils.getFactoryByName(sc, "composite.test.2");

+		Properties props2 = new Properties();

+		props2.put("name", "4");

+		Factory fact3 = Utils.getFactoryByName(sc, "composite.test.3");

+		Properties props3 = new Properties();

+		props3.put("name", "5");

+		ComponentInstance comp2 = null;

+		ComponentInstance comp3 = null;

+		try {

+			comp2 = fact2.createComponentInstance(props2, sc);

+			comp3 = fact3.createComponentInstance(props3, sc);

+		} catch(Exception e) {

+			e.printStackTrace();

+		}

+		

+		assertTrue("Test comp3", comp3.getState() == ComponentInstance.VALID);

+		assertTrue("Test comp2", comp2.getState() == ComponentInstance.VALID);

+		

+		ServiceReference ref = null;

+

+		ref = Utils.getServiceReferenceByName(sc, CheckService.class.getName(), "4");

+

+		assertNotNull("Check ref", ref);

+		CheckService cs = (CheckService) sc.getService(ref);

+		assertTrue("Check invoke", cs.check());

+		

+		comp3.dispose();

+		comp2.dispose();

+		empty.dispose();

+	}

+

+	

+	public void testApplication() {

+		Factory factory = Utils.getFactoryByName(context, "composite.test.1");

+		ComponentInstance ci = null;

+		Properties props = new Properties();

+		props.put("name", "Test");

+		try {

+			ci = factory.createComponentInstance(props);

+		} catch(Exception e) {

+			fail("Cannot instantiate Test " + e.getMessage());

+		}

+		

+		assertTrue("Check ci state", ci.getState() == ComponentInstance.VALID );

+		

+		ServiceReference[] refs = null;

+		try {

+			refs = context.getServiceReferences(CheckService.class.getName(), "(instance.name=Test)");

+		} catch (InvalidSyntaxException e) {

+			fail("Invalid filter : " + e.getMessage());

+		}

+		assertNotNull("Check refs not null", refs);

+		CheckService cs = (CheckService) context.getService(refs[0]);

+		

+		assertTrue("Check invocation", cs.check());

+		ci.dispose();

+		

+	}

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/util/Utils.java b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/util/Utils.java
new file mode 100644
index 0000000..ea67fee
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/java/org/apache/felix/ipojo/test/composite/util/Utils.java
@@ -0,0 +1,288 @@
+/* 

+ * 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.felix.ipojo.test.composite.util;

+

+import java.util.Dictionary;

+import java.util.Properties;

+

+import org.apache.felix.ipojo.ComponentInstance;

+import org.apache.felix.ipojo.Factory;

+import org.apache.felix.ipojo.Handler;

+import org.apache.felix.ipojo.HandlerFactory;

+import org.apache.felix.ipojo.ServiceContext;

+import org.apache.felix.ipojo.composite.CompositeManager;

+import org.osgi.framework.BundleContext;

+import org.osgi.framework.InvalidSyntaxException;

+import org.osgi.framework.ServiceReference;

+import org.osgi.service.cm.ManagedServiceFactory;

+

+public class Utils {

+

+    public static Factory getFactoryByName(BundleContext bc, String factoryName) {

+        ServiceReference[] refs;

+        try {

+            refs = bc.getServiceReferences(Factory.class.getName(), "(factory.name=" + factoryName + ")");

+            if (refs == null) {

+                System.err.println("Cannot get the factory " + factoryName);

+                return null;

+            }

+            return ((Factory) bc.getService(refs[0]));

+        } catch (InvalidSyntaxException e) {

+            System.err.println("Cannot get the factory " + factoryName + " : " + e.getMessage());

+            return null;

+        }

+    }

+

+    public static HandlerFactory getHandlerFactoryByName(BundleContext bc, String factoryName) {

+        ServiceReference[] refs;

+        try {

+            refs = bc.getServiceReferences(Factory.class.getName(), "(" + Handler.HANDLER_NAME_PROPERTY + "=" + factoryName + ")");

+            if (refs == null) {

+                System.err.println("Cannot get the factory " + factoryName);

+                return null;

+            }

+            return (HandlerFactory) bc.getService(refs[0]);

+        } catch (InvalidSyntaxException e) {

+            System.err.println("Cannot get the factory " + factoryName + " : " + e.getMessage());

+            return null;

+        }

+    }

+

+    public static ComponentInstance getComponentInstance(BundleContext bc, String factoryName, Dictionary configuration) {

+        Factory fact = getFactoryByName(bc, factoryName);

+

+        if (fact == null) {

+            System.err.println("Factory " + factoryName + " not found");

+            return null;

+        }

+

+        // if(fact.isAcceptable(configuration)) {

+        try {

+            return fact.createComponentInstance(configuration);

+        } catch (Exception e) {

+            System.err.println("Cannot create the instance from " + factoryName + " : " + e.getMessage());

+            e.printStackTrace();

+            return null;

+        }

+        // }

+        // else {

+        // System.err.println("Configuration not accepted by : " + factoryName);

+        // return null;

+        // }

+    }

+

+    public static ComponentInstance getComponentInstanceByName(BundleContext bc, String factoryName, String name) {

+        Factory fact = getFactoryByName(bc, factoryName);

+

+        if (fact == null) {

+            System.err.println("Factory " + factoryName + " not found");

+            return null;

+        }

+

+        try {

+            Properties props = new Properties();

+            props.put("name", name);

+            return fact.createComponentInstance(props);

+        } catch (Exception e) {

+            System.err.println("Cannot create the instance from " + factoryName + " : " + e.getMessage());

+            e.printStackTrace();

+            return null;

+        }

+    }

+

+    public static ServiceReference[] getServiceReferences(BundleContext bc, String itf, String filter) {

+        ServiceReference[] refs = null;

+        try {

+            refs = bc.getServiceReferences(itf, filter);

+        } catch (InvalidSyntaxException e) {

+            System.err.println("Invalid Filter : " + filter);

+        }

+        if (refs == null) {

+            return new ServiceReference[0];

+        } else {

+            return refs;

+        }

+    }

+

+    public static ServiceReference getServiceReference(BundleContext bc, String itf, String filter) {

+        ServiceReference[] refs = null;

+        try {

+            refs = bc.getServiceReferences(itf, filter);

+        } catch (InvalidSyntaxException e) {

+            System.err.println("Invalid Filter : " + filter);

+        }

+        if (refs == null) {

+            return null;

+        } else {

+            return refs[0];

+        }

+    }

+

+    public static ServiceReference getServiceReferenceByName(BundleContext bc, String itf, String name) {

+        ServiceReference[] refs = null;

+        String filter = null;

+        if (itf.equals(Factory.class.getName()) || itf.equals(ManagedServiceFactory.class.getName())) {

+            filter = "(" + "factory.name" + "=" + name + ")";

+        } else {

+            filter = "(" + "instance.name" + "=" + name + ")";

+        }

+        try {

+            refs = bc.getServiceReferences(itf, filter);

+        } catch (InvalidSyntaxException e) {

+            System.err.println("Invalid Filter : " + filter);

+        }

+        if (refs == null) {

+            return null;

+        } else {

+            return refs[0];

+        }

+    }

+

+    public static Object getServiceObject(BundleContext bc, String itf, String filter) {

+        ServiceReference ref = getServiceReference(bc, itf, filter);

+        if (ref != null) {

+            return bc.getService(ref);

+        } else {

+            return null;

+        }

+    }

+

+    public static Object[] getServiceObjects(BundleContext bc, String itf, String filter) {

+        ServiceReference[] refs = getServiceReferences(bc, itf, filter);

+        if (refs != null) {

+            Object[] list = new Object[refs.length];

+            for (int i = 0; i < refs.length; i++) {

+                list[i] = bc.getService(refs[i]);

+            }

+            return list;

+        } else {

+            return new Object[0];

+        }

+    }

+

+    public static ServiceContext getServiceContext(ComponentInstance ci) {

+        if (ci instanceof CompositeManager) {

+            return ((CompositeManager) ci).getServiceContext();

+        } else {

+            throw new RuntimeException("Cannot get the service context from a non composite instance");

+        }

+    }

+

+    public static Factory getFactoryByName(ServiceContext bc, String factoryName) {

+        ServiceReference[] refs;

+        try {

+            refs = bc.getServiceReferences(Factory.class.getName(), "(factory.name=" + factoryName + ")");

+            if (refs == null) { return null; }

+            return ((Factory) bc.getService(refs[0]));

+        } catch (InvalidSyntaxException e) {

+            System.err.println("Cannot get the factory " + factoryName + " : " + e.getMessage());

+            return null;

+        }

+    }

+

+    public static ComponentInstance getComponentInstance(ServiceContext bc, String factoryName, Dictionary configuration) {

+        Factory fact = getFactoryByName(bc, factoryName);

+

+        if (fact == null) { return null; }

+

+        if (fact.isAcceptable(configuration)) {

+            try {

+                return fact.createComponentInstance(configuration);

+            } catch (Exception e) {

+                System.err.println(e.getMessage());

+                e.printStackTrace();

+                return null;

+            }

+        } else {

+            System.err.println("Configuration not accepted by : " + factoryName);

+            return null;

+        }

+    }

+

+    public static ServiceReference[] getServiceReferences(ServiceContext bc, String itf, String filter) {

+        ServiceReference[] refs = null;

+        try {

+            refs = bc.getServiceReferences(itf, filter);

+        } catch (InvalidSyntaxException e) {

+            System.err.println("Invalid Filter : " + filter);

+        }

+        if (refs == null) {

+            return new ServiceReference[0];

+        } else {

+            return refs;

+        }

+    }

+

+    public static ServiceReference getServiceReference(ServiceContext bc, String itf, String filter) {

+        ServiceReference[] refs = null;

+        try {

+            refs = bc.getServiceReferences(itf, filter);

+        } catch (InvalidSyntaxException e) {

+            System.err.println("Invalid Filter : " + filter);

+        }

+        if (refs == null) {

+            return null;

+        } else {

+            return refs[0];

+        }

+    }

+

+    public static ServiceReference getServiceReferenceByName(ServiceContext bc, String itf, String name) {

+        ServiceReference[] refs = null;

+        String filter = null;

+        if (itf.equals(Factory.class.getName()) || itf.equals(ManagedServiceFactory.class.getName())) {

+            filter = "(" + "factory.name" + "=" + name + ")";

+        } else {

+            filter = "(" + "instance.name" + "=" + name + ")";

+        }

+        try {

+            refs = bc.getServiceReferences(itf, filter);

+        } catch (InvalidSyntaxException e) {

+            System.err.println("Invalid Filter : " + filter);

+        }

+        if (refs == null) {

+            return null;

+        } else {

+            return refs[0];

+        }

+    }

+

+    public static Object getServiceObject(ServiceContext bc, String itf, String filter) {

+        ServiceReference ref = getServiceReference(bc, itf, filter);

+        if (ref != null) {

+            return bc.getService(ref);

+        } else {

+            return null;

+        }

+    }

+

+    public static Object[] getServiceObjects(ServiceContext bc, String itf, String filter) {

+        ServiceReference[] refs = getServiceReferences(bc, itf, filter);

+        if (refs != null) {

+            Object[] list = new Object[refs.length];

+            for (int i = 0; i < refs.length; i++) {

+                list[i] = bc.getService(refs[i]);

+            }

+            return list;

+        } else {

+            return new Object[0];

+        }

+    }

+

+}

diff --git a/ipojo/tests/tests.composite/src/main/resources/metadata.xml b/ipojo/tests/tests.composite/src/main/resources/metadata.xml
new file mode 100644
index 0000000..2357580
--- /dev/null
+++ b/ipojo/tests/tests.composite/src/main/resources/metadata.xml
@@ -0,0 +1,221 @@
+<ipojo xmlns:cs="org.apache.felix.ipojo.test.composite.handler.CheckServiceHandler">

+	<!--  Composite -->

+	<composite name="composite.empty" factory="true" architecture="true">

+	</composite>

+	

+	<composite name="composite.bar.1" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.scenarios.service.BarService"/>

+	</composite>

+	

+	<composite name="composite.bar.2" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.scenarios.service.BarService" aggregate="true"/>

+	</composite>

+	

+	<composite name="composite.bar.3" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.scenarios.service.BarService" optional="true"/>

+	</composite>

+	

+	<composite name="composite.bar.4" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.scenarios.service.FooService" aggregate="true" optional="true"/>

+	</composite>

+	

+	<composite name="composite.bar.5-accept" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.scenarios.service.FooService">

+			<property name="boolean" value="true"/>

+			<property name="string" value="foo"/>

+			<property name="strAprop" value="{foo, bar, baz}"/>

+			<property name="int" value="5"/>

+		</subservice>

+	</composite>

+	

+	<composite name="composite.bar.5-refuse1" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.scenarios.service.BarService">

+			<property name="foo" value="bar"/>

+			<property name="boolean" value="true"/>

+			<property name="string" value="foo"/>

+			<property name="strAprop" value="{foo, bar, baz}"/>

+			<property name="int" value="5"/>

+		</subservice>

+	</composite>

+	

+	<composite name="composite.bar.5-refuse2" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.scenarios.service.BarService">

+			<property name="string" value="foo"/>

+			<property name="strAprop" value="{foo, bar, baz}"/>

+		</subservice>

+	</composite>

+	

+	<composite name="composite.inst.1" factory="true" architecture="true">

+		<instance component="FooProviderType-1" /> <!-- name="FooProv"  -->

+		<instance component="FooProviderType-Dyn2">

+			<property name="boolean" value="true"/>

+			<property name="string" value="foo"/>

+			<property name="strAProp" value="{a,b,c}"/>

+		</instance>

+	</composite>

+	

+	<composite name="composite.requires.1" architecture="true">

+		<subservice action="import" specification="org.apache.felix.ipojo.test.scenarios.service.FooService" scope="composite"/>

+	</composite>

+	

+	<composite name="composite.requires.2" architecture="true">

+		<subservice action="import" specification="org.apache.felix.ipojo.test.scenarios.service.FooService" aggregate="true" scope="composite"/>

+	</composite>

+	

+	<composite name="composite.requires.3" architecture="true">

+		<subservice action="import" specification="org.apache.felix.ipojo.test.scenarios.service.FooService" optional="true" scope="composite"/>

+	</composite>

+	

+	<composite name="composite.requires.4" architecture="true">

+		<subservice action="import" specification="org.apache.felix.ipojo.test.scenarios.service.FooService" optional="true" aggregate="true" scope="composite"/>

+	</composite>

+	

+	<composite name="composite.requires.5" architecture="true">

+		<subservice action="import" specification="org.apache.felix.ipojo.test.scenarios.service.FooService" filter="(&amp;(int=2)(long=40))" scope="composite"/>

+	</composite>

+	

+	<component className="org.apache.felix.ipojo.test.composite.component.BazProviderType1" factory="BazProviderType" scope="composite">

+		<provides/>

+	</component>

+	

+	<composite name="composite.export.1" architecture="true">

+		<subservice action="import" specification="org.apache.felix.ipojo.test.scenarios.service.BazService" aggregate="true" optional="true" filter="(!(instance.name=export))" scope="composite"/>

+		<provides action="export" specification="org.apache.felix.ipojo.test.scenarios.service.BazService"/>

+	</composite>

+	

+	<composite name="composite.export.2" architecture="true">

+		<subservice action="import" specification="org.apache.felix.ipojo.test.scenarios.service.BazService" scope="composite" aggregate="true" optional="true" filter="(!(instance.name=export))"/>

+		<provides action="export" specification="org.apache.felix.ipojo.test.scenarios.service.BazService" optional="true"/>

+	</composite>

+	

+	<composite name="composite.export.3" architecture="true">

+		<subservice action="import" specification="org.apache.felix.ipojo.test.scenarios.service.BazService" scope="composite" aggregate="true" optional="true" filter="(!(instance.name=export))"/>

+		<provides action="export" specification="org.apache.felix.ipojo.test.scenarios.service.BazService" aggregate="true"/>

+	</composite>

+	

+	<composite name="composite.export.4" architecture="true">

+		<subservice action="import" specification="org.apache.felix.ipojo.test.scenarios.service.BazService" aggregate="true" optional="true" filter="(!(instance.name=export))" scope="composite"/>

+		<provides action="export" specification="org.apache.felix.ipojo.test.scenarios.service.BazService" aggregate="true" optional="true"/>

+	</composite>

+	

+	<composite name="composite.export.5" architecture="true">

+		<subservice action="import" specification="org.apache.felix.ipojo.test.scenarios.service.BazService" aggregate="true" optional="true" filter="(!(instance.name=export))" scope="composite"/>

+		<provides action="export" specification="org.apache.felix.ipojo.test.scenarios.service.BazService" filter="(instance.name=foo1)"/>

+	</composite>

+	

+	<component className="org.apache.felix.ipojo.test.composite.component.Baz2CheckProvider" factory="Baz2CheckProvider" architecture="true">

+		<requires field="fs" scope="composite"/>

+		<provides/>

+	</component>

+

+	<composite name="composite.test.3" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.scenarios.service.BazService" aggregate="true" filter="(factory.name=BazProviderType)"/>

+		<provides action="export" specification="org.apache.felix.ipojo.test.scenarios.service.BazService"/>

+	</composite>

+	

+	<composite name="composite.test.2" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.scenarios.service.CheckService" filter="(factory.name=Baz2CheckProvider)"/>

+		<provides action="export" specification="org.apache.felix.ipojo.test.scenarios.service.CheckService"/>

+		<subservice action="import" specification="org.apache.felix.ipojo.test.scenarios.service.BazService" scope="composite"/>

+	</composite>

+	

+	<composite name="composite.test.1" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.scenarios.service.BazService" filter="(factory.name=composite.test.3)" />

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.scenarios.service.CheckService" filter="(factory.name=composite.test.2)"/>

+		<provides action="export" specification="org.apache.felix.ipojo.test.scenarios.service.CheckService"/>

+	</composite>

+

+	<composite name="composite.instantiator" architecture="true">

+				<subservice action="instantiate" specification="org.apache.felix.ipojo.test.scenarios.service.BazService" filter="(factory.name=composite.test.3)"/>

+				<subservice action="instantiate" specification="org.apache.felix.ipojo.test.scenarios.service.FooService"/>

+				<provides action="export" specification="org.apache.felix.ipojo.test.scenarios.service.BazService"/>

+				<provides action="export" specification="org.apache.felix.ipojo.test.scenarios.service.FooService"/>

+	</composite>

+

+	<!-- Test composition provides -->

+	<component classname="org.apache.felix.ipojo.test.composite.component.TataProvider" factory="tata">

+		<provides/>

+	</component>

+	

+	<component classname="org.apache.felix.ipojo.test.composite.component.TotoProvider" factory="toto" architecture="true">

+		<provides/>

+	</component>

+	

+	<component classname="org.apache.felix.ipojo.test.composite.component.TotoProviderGlue" factory="totoglue">

+		<requires field="m_toto" scope="composite"/>

+	</component>

+	

+	<composite name="comp-0" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.composite.service.Tata"/>

+		<subservice action="import" specification="org.apache.felix.ipojo.test.composite.service.Toto"/>

+		<provides action="implement" specification="org.apache.felix.ipojo.test.composite.service.Tota"/>

+	</composite>

+	

+	<composite name="comp-1" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.composite.service.Tata"/>

+		<subservice action="import" specification="org.apache.felix.ipojo.test.composite.service.Toto"/>

+		<provides action="implement" specification="org.apache.felix.ipojo.test.composite.service.Tota">

+			<delegation method="tataInt" policy="One"/>

+			<delegation method="toto1" policy="All"/>

+		</provides>

+	</composite>

+

+	<composite name="comp-2" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.composite.service.Tata" aggregate="true"/>

+		<subservice action="import" specification="org.apache.felix.ipojo.test.composite.service.Toto" aggregate="true"/>

+		<provides action="implement" specification="org.apache.felix.ipojo.test.composite.service.Tota">

+			<delegation method="tataInt" policy="One"/>

+			<delegation method="toto1" policy="All"/>

+		</provides>

+	</composite>	

+	

+	<composite name="comp-3" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.composite.service.Tata"/>

+		<subservice action="import" specification="org.apache.felix.ipojo.test.composite.service.Toto" optional="true"/>

+		<provides action="implement" specification="org.apache.felix.ipojo.test.composite.service.Tota">

+		</provides>

+	</composite>

+	

+	<composite name="comp-4" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.composite.service.Tata"/>

+		<subservice action="import" specification="org.apache.felix.ipojo.test.composite.service.Toto" optional="true"/>

+		<provides action="implement" specification="org.apache.felix.ipojo.test.composite.service.Tota">

+			<delegation method="tataInt" policy="One"/>

+			<delegation method="toto1" policy="All"/>

+		</provides>

+	</composite>		

+	

+	<composite name="comp-5" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.composite.service.Tata" aggregate="true"/>

+		<!-- <subservice action="import" specification="org.apache.felix.ipojo.test.composite.service.Toto" aggregate ="true" optional="true"/> -->

+		<provides action="implement" specification="org.apache.felix.ipojo.test.composite.service.Tota">

+			<delegation method="tataInt" policy="One"/>

+			<delegation method="toto1" policy="All"/>

+		</provides>

+	</composite>	

+	

+	<composite name="comp-6" architecture="true">

+		<subservice action="instantiate" specification="org.apache.felix.ipojo.test.composite.service.Tata" aggregate="true"/>

+		<subservice action="import" specification="org.apache.felix.ipojo.test.composite.service.Toto" aggregate="true" optional="true"/>

+		<provides action="implement" specification="org.apache.felix.ipojo.test.composite.service.Toto">

+			<delegation method="toto1" policy="All"/>

+		</provides>

+ 		<provides action="implement" specification="org.apache.felix.ipojo.test.composite.service.Tata">

+			<delegation method="tataInt" policy="One"/>

+		</provides>

+	</composite>

+	

+	<composite name="comp-7" architecture="true">

+		<instance component="tata"/>

+		<subservice action="import" specification="org.apache.felix.ipojo.test.composite.service.Toto"/>

+		<provides action="implement" specification="org.apache.felix.ipojo.test.composite.service.Tota"/>

+	</composite>

+	

+	<composite name="comp-8" architecture="true">

+		<instance component="tata"/>

+		<instance component="totoglue"/>

+		<subservice action="import" specification="org.apache.felix.ipojo.test.composite.service.Toto"/>

+		<provides action="implement" specification="org.apache.felix.ipojo.test.composite.service.Tota"/>

+	</composite>

+	

+</ipojo>