Series of patches to include creator ID in assets.
Contains a migration. SQLite: May contain nuts. The SQLite migration copies the entire asset table. Be prepared for quite a wait. Don't interrupt it. Back up your assets db. BasicAssetTest checks CreatorID storage, new test for weird CreatorID (now also checks that non-GUID or empty CreatorID gets stored correctly) Signed-off-by: Melanie <melanie@t-data.com>soprefactor
parent
d6a6668bd7
commit
ce787a4c41
|
@ -42,6 +42,9 @@ namespace OpenSim.Data.Tests
|
||||||
public UUID uuid1;
|
public UUID uuid1;
|
||||||
public UUID uuid2;
|
public UUID uuid2;
|
||||||
public UUID uuid3;
|
public UUID uuid3;
|
||||||
|
public string critter1 = UUID.Random().ToString();
|
||||||
|
public string critter2 = UUID.Random().ToString();
|
||||||
|
public string critter3 = UUID.Random().ToString();
|
||||||
public byte[] asset1;
|
public byte[] asset1;
|
||||||
PropertyScrambler<AssetBase> scrambler;
|
PropertyScrambler<AssetBase> scrambler;
|
||||||
|
|
||||||
|
@ -54,6 +57,7 @@ namespace OpenSim.Data.Tests
|
||||||
uuid3 = UUID.Random();
|
uuid3 = UUID.Random();
|
||||||
asset1 = new byte[100];
|
asset1 = new byte[100];
|
||||||
asset1.Initialize();
|
asset1.Initialize();
|
||||||
|
|
||||||
|
|
||||||
scrambler = new PropertyScrambler<AssetBase>()
|
scrambler = new PropertyScrambler<AssetBase>()
|
||||||
.DontScramble(x => x.ID)
|
.DontScramble(x => x.ID)
|
||||||
|
@ -76,9 +80,9 @@ namespace OpenSim.Data.Tests
|
||||||
[Test]
|
[Test]
|
||||||
public void T010_StoreSimpleAsset()
|
public void T010_StoreSimpleAsset()
|
||||||
{
|
{
|
||||||
AssetBase a1 = new AssetBase(uuid1, "asset one", (sbyte)AssetType.Texture, UUID.Zero.ToString());
|
AssetBase a1 = new AssetBase(uuid1, "asset one", (sbyte)AssetType.Texture, critter1);
|
||||||
AssetBase a2 = new AssetBase(uuid2, "asset two", (sbyte)AssetType.Texture, UUID.Zero.ToString());
|
AssetBase a2 = new AssetBase(uuid2, "asset two", (sbyte)AssetType.Texture, critter2);
|
||||||
AssetBase a3 = new AssetBase(uuid3, "asset three", (sbyte)AssetType.Texture, UUID.Zero.ToString());
|
AssetBase a3 = new AssetBase(uuid3, "asset three", (sbyte)AssetType.Texture, critter3);
|
||||||
a1.Data = asset1;
|
a1.Data = asset1;
|
||||||
a2.Data = asset1;
|
a2.Data = asset1;
|
||||||
a3.Data = asset1;
|
a3.Data = asset1;
|
||||||
|
@ -87,7 +91,6 @@ namespace OpenSim.Data.Tests
|
||||||
scrambler.Scramble(a2);
|
scrambler.Scramble(a2);
|
||||||
scrambler.Scramble(a3);
|
scrambler.Scramble(a3);
|
||||||
|
|
||||||
|
|
||||||
db.StoreAsset(a1);
|
db.StoreAsset(a1);
|
||||||
db.StoreAsset(a2);
|
db.StoreAsset(a2);
|
||||||
db.StoreAsset(a3);
|
db.StoreAsset(a3);
|
||||||
|
@ -131,5 +134,33 @@ namespace OpenSim.Data.Tests
|
||||||
Assert.That(metadata.Temporary, Is.EqualTo(a1b.Temporary));
|
Assert.That(metadata.Temporary, Is.EqualTo(a1b.Temporary));
|
||||||
Assert.That(metadata.FullID, Is.EqualTo(a1b.FullID));
|
Assert.That(metadata.FullID, Is.EqualTo(a1b.FullID));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void T020_CheckForWeirdCreatorID()
|
||||||
|
{
|
||||||
|
// It is expected that eventually the CreatorID might be an arbitrary string (an URI)
|
||||||
|
// rather than a valid UUID (?). This test is to make sure that the database layer does not
|
||||||
|
// attempt to convert CreatorID to GUID, but just passes it both ways as a string.
|
||||||
|
AssetBase a1 = new AssetBase(uuid1, "asset one", (sbyte)AssetType.Texture, critter1);
|
||||||
|
AssetBase a2 = new AssetBase(uuid2, "asset two", (sbyte)AssetType.Texture, "This is not a GUID!");
|
||||||
|
AssetBase a3 = new AssetBase(uuid3, "asset three", (sbyte)AssetType.Texture, "");
|
||||||
|
a1.Data = asset1;
|
||||||
|
a2.Data = asset1;
|
||||||
|
a3.Data = asset1;
|
||||||
|
|
||||||
|
db.StoreAsset(a1);
|
||||||
|
db.StoreAsset(a2);
|
||||||
|
db.StoreAsset(a3);
|
||||||
|
|
||||||
|
AssetBase a1a = db.GetAsset(uuid1);
|
||||||
|
Assert.That(a1a, Constraints.PropertyCompareConstraint(a1));
|
||||||
|
|
||||||
|
AssetBase a2a = db.GetAsset(uuid2);
|
||||||
|
Assert.That(a2a, Constraints.PropertyCompareConstraint(a2));
|
||||||
|
|
||||||
|
AssetBase a3a = db.GetAsset(uuid3);
|
||||||
|
Assert.That(a3a, Constraints.PropertyCompareConstraint(a3));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue