diff --git a/tests/AspectCore.Extensions.Autofac.Test/AspectCore.Extensions.Autofac.Test.csproj b/tests/AspectCore.Extensions.Autofac.Test/AspectCore.Extensions.Autofac.Test.csproj
index d57e83ed..a5db1aa8 100644
--- a/tests/AspectCore.Extensions.Autofac.Test/AspectCore.Extensions.Autofac.Test.csproj
+++ b/tests/AspectCore.Extensions.Autofac.Test/AspectCore.Extensions.Autofac.Test.csproj
@@ -17,22 +17,9 @@
-
-
-
-
-
-
-
-
-
-
-
+
-
-
-
all
diff --git a/tests/AspectCore.Extensions.Autofac.Test/KeyedServiceTests.cs b/tests/AspectCore.Extensions.Autofac.Test/KeyedServiceTests.cs
new file mode 100644
index 00000000..8d5da1f2
--- /dev/null
+++ b/tests/AspectCore.Extensions.Autofac.Test/KeyedServiceTests.cs
@@ -0,0 +1,73 @@
+using System.Threading.Tasks;
+using AspectCore.DependencyInjection;
+using AspectCore.DynamicProxy;
+using AspectCore.Extensions.Autofac;
+using AspectCore.Extensions.DependencyInjection;
+using Autofac;
+using Autofac.Extensions.DependencyInjection;
+using Microsoft.Extensions.DependencyInjection;
+using Xunit;
+
+namespace AspectCoreTest.Autofac;
+
+public class KeyedServiceTests
+{
+ public class InterceptKey : AbstractInterceptorAttribute
+ {
+ private int _key;
+
+ public InterceptKey(int key)
+ {
+ _key = key;
+ }
+
+ public override async Task Invoke(AspectContext context, AspectDelegate next)
+ {
+ await context.Invoke(next);
+ context.ReturnValue = _key;
+ }
+ }
+
+ public interface IKeydService
+ {
+ int Get();
+ int GetIntercept();
+ }
+
+ public class KeydService : IKeydService
+ {
+ private int _current = 0;
+ public int Get()
+ {
+ _current++;
+ return _current;
+ }
+
+ [InterceptKey(1000)]
+ public int GetIntercept()
+ {
+ return 2;
+ }
+ }
+#if NET8_0_OR_GREATER
+ [Fact]
+ public void GetKeydService_WithServiceProvider()
+ {
+ var services = new ServiceCollection();
+ var builder = new ContainerBuilder();
+ builder.RegisterDynamicProxy();
+ services.AddKeyedScoped("key1");
+ services.AddKeyedScoped("key2");
+ builder.Populate(services);
+ var serviceProvider = new AutofacServiceProvider(builder.Build());
+ var keydService = serviceProvider.GetKeyedService("key1");
+ Assert.Equal(1, keydService.Get());
+ Assert.Equal(1000, keydService.GetIntercept());
+
+ var keyd2Service = serviceProvider.GetKeyedService("key2");
+ //不同实例
+ Assert.Equal(1, keyd2Service.Get());
+ Assert.Equal(1000, keyd2Service.GetIntercept());
+ }
+#endif
+}
\ No newline at end of file