Skip cache refresher operations for content blueprints (#15633)
* Skip cache refresher operations for content blueprints * Fix JsonPayload deserialization error by adding a default constructor and property initializers * Obsolete JsonPayload constructor and update usages
This commit is contained in:
committed by
Bjarke Berg
parent
ac02e97e0c
commit
4aed6a1034
@@ -18,8 +18,10 @@ public class RefresherTests
|
||||
{
|
||||
new MediaCacheRefresher.JsonPayload(1234, Guid.NewGuid(), TreeChangeTypes.None),
|
||||
};
|
||||
|
||||
var json = JsonConvert.SerializeObject(source);
|
||||
var payload = JsonConvert.DeserializeObject<MediaCacheRefresher.JsonPayload[]>(json);
|
||||
|
||||
Assert.AreEqual(source[0].Id, payload[0].Id);
|
||||
Assert.AreEqual(source[0].Key, payload[0].Key);
|
||||
Assert.AreEqual(source[0].ChangeTypes, payload[0].ChangeTypes);
|
||||
@@ -30,13 +32,21 @@ public class RefresherTests
|
||||
{
|
||||
ContentCacheRefresher.JsonPayload[] source =
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload(1234, Guid.NewGuid(), TreeChangeTypes.None),
|
||||
new ContentCacheRefresher.JsonPayload()
|
||||
{
|
||||
Id = 1234,
|
||||
Key = Guid.NewGuid(),
|
||||
ChangeTypes = TreeChangeTypes.None
|
||||
}
|
||||
};
|
||||
|
||||
var json = JsonConvert.SerializeObject(source);
|
||||
var payload = JsonConvert.DeserializeObject<ContentCacheRefresher.JsonPayload[]>(json);
|
||||
|
||||
Assert.AreEqual(source[0].Id, payload[0].Id);
|
||||
Assert.AreEqual(source[0].Key, payload[0].Key);
|
||||
Assert.AreEqual(source[0].ChangeTypes, payload[0].ChangeTypes);
|
||||
Assert.AreEqual(source[0].Blueprint, payload[0].Blueprint);
|
||||
}
|
||||
|
||||
[Test]
|
||||
@@ -46,8 +56,10 @@ public class RefresherTests
|
||||
{
|
||||
new ContentTypeCacheRefresher.JsonPayload("xxx", 1234, ContentTypeChangeTypes.None),
|
||||
};
|
||||
|
||||
var json = JsonConvert.SerializeObject(source);
|
||||
var payload = JsonConvert.DeserializeObject<ContentTypeCacheRefresher.JsonPayload[]>(json);
|
||||
|
||||
Assert.AreEqual(source[0].ItemType, payload[0].ItemType);
|
||||
Assert.AreEqual(source[0].Id, payload[0].Id);
|
||||
Assert.AreEqual(source[0].ChangeTypes, payload[0].ChangeTypes);
|
||||
@@ -60,8 +72,10 @@ public class RefresherTests
|
||||
{
|
||||
new DataTypeCacheRefresher.JsonPayload(1234, Guid.NewGuid(), true),
|
||||
};
|
||||
|
||||
var json = JsonConvert.SerializeObject(source);
|
||||
var payload = JsonConvert.DeserializeObject<DataTypeCacheRefresher.JsonPayload[]>(json);
|
||||
|
||||
Assert.AreEqual(source[0].Id, payload[0].Id);
|
||||
Assert.AreEqual(source[0].Key, payload[0].Key);
|
||||
Assert.AreEqual(source[0].Removed, payload[0].Removed);
|
||||
@@ -70,10 +84,14 @@ public class RefresherTests
|
||||
[Test]
|
||||
public void DomainCacheRefresherCanDeserializeJsonPayload()
|
||||
{
|
||||
DomainCacheRefresher.JsonPayload[]
|
||||
source = { new DomainCacheRefresher.JsonPayload(1234, DomainChangeTypes.None) };
|
||||
DomainCacheRefresher.JsonPayload[] source =
|
||||
{
|
||||
new DomainCacheRefresher.JsonPayload(1234, DomainChangeTypes.None)
|
||||
};
|
||||
|
||||
var json = JsonConvert.SerializeObject(source);
|
||||
var payload = JsonConvert.DeserializeObject<DomainCacheRefresher.JsonPayload[]>(json);
|
||||
|
||||
Assert.AreEqual(source[0].Id, payload[0].Id);
|
||||
Assert.AreEqual(source[0].ChangeType, payload[0].ChangeType);
|
||||
}
|
||||
|
||||
@@ -358,7 +358,16 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
|
||||
// notify
|
||||
SnapshotService.Notify(
|
||||
new[] { new ContentCacheRefresher.JsonPayload(10, Guid.Empty, TreeChangeTypes.RefreshBranch) }, out _, out _);
|
||||
new[]
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload()
|
||||
{
|
||||
Id = 10,
|
||||
ChangeTypes = TreeChangeTypes.RefreshBranch
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _);
|
||||
|
||||
// changes that *I* make are immediately visible on the current snapshot
|
||||
var documents = snapshot.Content.GetAtRoot().ToArray();
|
||||
@@ -392,7 +401,16 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
|
||||
// notify
|
||||
SnapshotService.Notify(
|
||||
new[] { new ContentCacheRefresher.JsonPayload(1, Guid.Empty, TreeChangeTypes.RefreshBranch) }, out _, out _);
|
||||
new[]
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload()
|
||||
{
|
||||
Id = 1,
|
||||
ChangeTypes = TreeChangeTypes.RefreshBranch
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _);
|
||||
|
||||
// changes that *I* make are immediately visible on the current snapshot
|
||||
var documents = snapshot.Content.GetAtRoot().ToArray();
|
||||
@@ -450,7 +468,11 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
SnapshotService.Notify(
|
||||
new[]
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload(kit.Node.ParentContentId, Guid.Empty, TreeChangeTypes.RefreshBranch),
|
||||
new ContentCacheRefresher.JsonPayload()
|
||||
{
|
||||
Id = kit.Node.ParentContentId,
|
||||
ChangeTypes = TreeChangeTypes.RefreshBranch
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _);
|
||||
@@ -516,11 +538,19 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
// notify
|
||||
SnapshotService.Notify(
|
||||
new[]
|
||||
{
|
||||
// removal must come first
|
||||
new ContentCacheRefresher.JsonPayload(2, Guid.Empty, TreeChangeTypes.RefreshBranch),
|
||||
new ContentCacheRefresher.JsonPayload(1, Guid.Empty, TreeChangeTypes.RefreshBranch),
|
||||
},
|
||||
{
|
||||
// removal must come first
|
||||
new ContentCacheRefresher.JsonPayload()
|
||||
{
|
||||
Id = 2,
|
||||
ChangeTypes = TreeChangeTypes.RefreshBranch
|
||||
},
|
||||
new ContentCacheRefresher.JsonPayload()
|
||||
{
|
||||
Id = 1,
|
||||
ChangeTypes = TreeChangeTypes.RefreshBranch
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _);
|
||||
|
||||
@@ -571,7 +601,16 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
|
||||
// notify - which ensures there are 2 generations in the cache meaning each LinkedNode has a Next value.
|
||||
SnapshotService.Notify(
|
||||
new[] { new ContentCacheRefresher.JsonPayload(4, Guid.Empty, TreeChangeTypes.RefreshBranch) }, out _, out _);
|
||||
new[]
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload()
|
||||
{
|
||||
Id = 4,
|
||||
ChangeTypes = TreeChangeTypes.RefreshBranch
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _);
|
||||
|
||||
// refresh the branch again, this used to show the issue where a null ref exception would occur
|
||||
// because in the ClearBranchLocked logic, when SetValueLocked was called within a recursive call
|
||||
@@ -579,7 +618,16 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
// this value before recursing.
|
||||
Assert.DoesNotThrow(() =>
|
||||
SnapshotService.Notify(
|
||||
new[] { new ContentCacheRefresher.JsonPayload(4, Guid.Empty, TreeChangeTypes.RefreshBranch) }, out _, out _));
|
||||
new[]
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload()
|
||||
{
|
||||
Id = 4,
|
||||
ChangeTypes = TreeChangeTypes.RefreshBranch
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _));
|
||||
}
|
||||
|
||||
[Test]
|
||||
@@ -759,11 +807,23 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
// notify
|
||||
SnapshotService.Notify(
|
||||
new[]
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload(3, Guid.Empty, TreeChangeTypes.Remove), // remove last
|
||||
new ContentCacheRefresher.JsonPayload(5, Guid.Empty, TreeChangeTypes.Remove), // remove middle
|
||||
new ContentCacheRefresher.JsonPayload(9, Guid.Empty, TreeChangeTypes.Remove), // remove first
|
||||
},
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload() // remove last
|
||||
{
|
||||
Id = 3,
|
||||
ChangeTypes = TreeChangeTypes.Remove
|
||||
},
|
||||
new ContentCacheRefresher.JsonPayload() // remove middle
|
||||
{
|
||||
Id = 5,
|
||||
ChangeTypes = TreeChangeTypes.Remove
|
||||
},
|
||||
new ContentCacheRefresher.JsonPayload() // remove first
|
||||
{
|
||||
Id = 9,
|
||||
ChangeTypes = TreeChangeTypes.Remove
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _);
|
||||
|
||||
@@ -779,11 +839,23 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
// notify
|
||||
SnapshotService.Notify(
|
||||
new[]
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload(1, Guid.Empty, TreeChangeTypes.Remove), // remove first
|
||||
new ContentCacheRefresher.JsonPayload(8, Guid.Empty, TreeChangeTypes.Remove), // remove
|
||||
new ContentCacheRefresher.JsonPayload(7, Guid.Empty, TreeChangeTypes.Remove), // remove
|
||||
},
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload() // remove first
|
||||
{
|
||||
Id = 1,
|
||||
ChangeTypes = TreeChangeTypes.Remove
|
||||
},
|
||||
new ContentCacheRefresher.JsonPayload() // remove
|
||||
{
|
||||
Id = 8,
|
||||
ChangeTypes = TreeChangeTypes.Remove
|
||||
},
|
||||
new ContentCacheRefresher.JsonPayload() // remove
|
||||
{
|
||||
Id = 7,
|
||||
ChangeTypes = TreeChangeTypes.Remove
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _);
|
||||
|
||||
@@ -823,8 +895,16 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
SnapshotService.Notify(
|
||||
new[]
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload(1, Guid.Empty, TreeChangeTypes.RefreshBranch),
|
||||
new ContentCacheRefresher.JsonPayload(2, Guid.Empty, TreeChangeTypes.RefreshNode),
|
||||
new ContentCacheRefresher.JsonPayload()
|
||||
{
|
||||
Id = 1,
|
||||
ChangeTypes = TreeChangeTypes.RefreshBranch
|
||||
},
|
||||
new ContentCacheRefresher.JsonPayload()
|
||||
{
|
||||
Id = 2,
|
||||
ChangeTypes = TreeChangeTypes.RefreshNode
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _);
|
||||
@@ -887,7 +967,17 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
var parentNode = parentNodes[0];
|
||||
AssertLinkedNode(parentNode.contentNode, -1, -1, -1, 2, 2);
|
||||
|
||||
SnapshotService.Notify(new[] { new ContentCacheRefresher.JsonPayload(2, Guid.Empty, TreeChangeTypes.Remove) }, out _, out _);
|
||||
SnapshotService.Notify(
|
||||
new[]
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload()
|
||||
{
|
||||
Id = 2,
|
||||
ChangeTypes = TreeChangeTypes.Remove
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _);
|
||||
|
||||
parentNodes = contentStore.Test.GetValues(1);
|
||||
parentNode = parentNodes[0];
|
||||
@@ -944,9 +1034,13 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
|
||||
SnapshotService.Notify(
|
||||
new[]
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload(3, Guid.Empty, TreeChangeTypes.Remove), // remove middle child
|
||||
},
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload() // remove middle child
|
||||
{
|
||||
Id = 3,
|
||||
ChangeTypes = TreeChangeTypes.Remove
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _);
|
||||
|
||||
@@ -1013,7 +1107,16 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
Assert.IsFalse(contentStore.Test.NextGen);
|
||||
|
||||
SnapshotService.Notify(
|
||||
new[] { new ContentCacheRefresher.JsonPayload(1, Guid.Empty, TreeChangeTypes.RefreshNode) }, out _, out _);
|
||||
new[]
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload()
|
||||
{
|
||||
Id = 1,
|
||||
ChangeTypes = TreeChangeTypes.RefreshNode
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _);
|
||||
|
||||
Assert.AreEqual(2, contentStore.Test.LiveGen);
|
||||
Assert.IsTrue(contentStore.Test.NextGen);
|
||||
@@ -1084,7 +1187,17 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
published ? rootKit.PublishedData : null);
|
||||
NuCacheContentService.ContentKits[1] = kit;
|
||||
|
||||
SnapshotService.Notify(new[] { new ContentCacheRefresher.JsonPayload(1, Guid.Empty, changeType) }, out _, out _);
|
||||
SnapshotService.Notify(
|
||||
new[]
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload()
|
||||
{
|
||||
Id = 1,
|
||||
ChangeTypes = changeType
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _);
|
||||
|
||||
Assert.AreEqual(assertGen, contentStore.Test.LiveGen);
|
||||
Assert.IsTrue(contentStore.Test.NextGen);
|
||||
@@ -1162,9 +1275,13 @@ public class PublishedSnapshotServiceCollectionTests : PublishedSnapshotServiceT
|
||||
|
||||
SnapshotService.Notify(
|
||||
new[]
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload(3, Guid.Empty, TreeChangeTypes.RefreshBranch), // remove middle child
|
||||
},
|
||||
{
|
||||
new ContentCacheRefresher.JsonPayload() // remove middle child
|
||||
{
|
||||
Id = 3,
|
||||
ChangeTypes = TreeChangeTypes.RefreshBranch
|
||||
}
|
||||
},
|
||||
out _,
|
||||
out _);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user