public async Task ParallelHashSetDuplicate() { var hashAlgorithm = new MurmurHashAlgorithmService(); var ownerId = Guid.NewGuid().ToString("N"); var scheduler = new HashSetDuplicateRemover(); await scheduler.InitializeAsync(ownerId); var requestHasher = new RequestHasher(hashAlgorithm); var r1 = new Request("http://www.a.com") { Owner = ownerId }; requestHasher.ComputeHash(r1); var isDuplicate = await scheduler.IsDuplicateAsync(r1); Assert.False(isDuplicate); Parallel.For(0, 1000, new ParallelOptions { MaxDegreeOfParallelism = 30 }, async i => { var r = new Request("http://www.a.com") { Owner = ownerId }; requestHasher.ComputeHash(r); isDuplicate = await scheduler.IsDuplicateAsync(r); Assert.True(isDuplicate); }); }
public async Task HashSetDuplicate() { var hashAlgorithm = new MurmurHashAlgorithmService(); var scheduler = new HashSetDuplicateRemover(); var requestHasher = new RequestHasher(hashAlgorithm); var ownerId = Guid.NewGuid().ToString("N"); await scheduler.InitializeAsync(ownerId); var r1 = new Request("http://www.a.com") { Owner = ownerId }; r1.Headers.Accept = ("asdfasdfasdf"); requestHasher.ComputeHash(r1); var isDuplicate = await scheduler.IsDuplicateAsync(r1); Assert.False(isDuplicate); var r2 = new Request("http://www.a.com") { Owner = ownerId }; requestHasher.ComputeHash(r2); isDuplicate = await scheduler.IsDuplicateAsync(r2); Assert.True(isDuplicate); var r3 = new Request("http://www.b.com") { Owner = ownerId }; requestHasher.ComputeHash(r3); isDuplicate = await scheduler.IsDuplicateAsync(r3); Assert.False(isDuplicate); var r4 = new Request("http://www.b.com") { Owner = ownerId }; requestHasher.ComputeHash(r4); isDuplicate = await scheduler.IsDuplicateAsync(r4); Assert.True(isDuplicate); }