public async Task StoredProcedure_Drop_All() { var dbName = HelperDatabase.GetRandomName("tcp_lo_"); await HelperDatabase.CreateDatabaseAsync(ProviderType.Sql, dbName, true); var cs = HelperDatabase.GetConnectionString(ProviderType.Sql, dbName); var sqlProvider = new SqlSyncProvider(cs); // Create default table var ctx = new AdventureWorksContext((dbName, ProviderType.Sql, sqlProvider), true, false); await ctx.Database.EnsureCreatedAsync(); var options = new SyncOptions(); var setup = new SyncSetup(new string[] { "SalesLT.Product" }); var remoteOrchestrator = new RemoteOrchestrator(sqlProvider, options); var scopeInfo = await remoteOrchestrator.GetServerScopeInfoAsync(setup); var onCreating = 0; var onCreated = 0; var onDropping = 0; var onDropped = 0; remoteOrchestrator.OnStoredProcedureCreating(tca => onCreating++); remoteOrchestrator.OnStoredProcedureCreated(tca => onCreated++); remoteOrchestrator.OnStoredProcedureDropping(tca => onDropping++); remoteOrchestrator.OnStoredProcedureDropped(tca => onDropped++); var isCreated = await remoteOrchestrator.CreateStoredProceduresAsync(scopeInfo, "Product", "SalesLT"); Assert.True(isCreated); Assert.Equal(10, onCreating); Assert.Equal(10, onCreated); Assert.Equal(0, onDropping); Assert.Equal(0, onDropped); onCreating = 0; onCreated = 0; onDropping = 0; onDropped = 0; var isDropped = await remoteOrchestrator.DropStoredProceduresAsync(scopeInfo, "Product", "SalesLT"); Assert.True(isCreated); Assert.Equal(0, onCreating); Assert.Equal(0, onCreated); Assert.Equal(10, onDropping); Assert.Equal(10, onDropped); HelperDatabase.DropDatabase(ProviderType.Sql, dbName); }