mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-05-06 16:16:44 +08:00
- 新增数据与存档系统完整文档,包含核心概念、基本用法和高级功能 - 实现文件存储、槽位存档仓库和统一设置仓库的持久化行为测试 - 覆盖存档迁移、备份恢复、批量操作等关键功能的测试用例 - 添加数据版本控制和自动备份机制的详细说明 - 提供完整的 API 接口文档和使用示例代码
115 lines
3.2 KiB
C#
115 lines
3.2 KiB
C#
using System;
|
|
using GFramework.Game.Abstractions.Data;
|
|
using GFramework.Game.Abstractions.Enums;
|
|
|
|
namespace GFramework.Game.Tests.Data;
|
|
|
|
/// <summary>
|
|
/// 为持久化测试提供稳定的测试数据位置实现。
|
|
/// </summary>
|
|
internal sealed class TestDataLocation : IDataLocation
|
|
{
|
|
/// <summary>
|
|
/// 初始化测试数据位置。
|
|
/// </summary>
|
|
/// <param name="key">测试使用的存储键。</param>
|
|
/// <param name="kinds">测试使用的存储类型。</param>
|
|
/// <param name="namespaceValue">测试使用的命名空间。</param>
|
|
/// <param name="metadata">附加测试元数据。</param>
|
|
public TestDataLocation(
|
|
string key,
|
|
StorageKinds kinds = StorageKinds.Local,
|
|
string? namespaceValue = null,
|
|
IReadOnlyDictionary<string, string>? metadata = null)
|
|
{
|
|
Key = key;
|
|
Kinds = kinds;
|
|
Namespace = namespaceValue;
|
|
Metadata = metadata;
|
|
}
|
|
|
|
/// <summary>
|
|
/// 获取测试数据对应的存储键。
|
|
/// </summary>
|
|
public string Key { get; }
|
|
|
|
/// <summary>
|
|
/// 获取测试数据使用的存储类型。
|
|
/// </summary>
|
|
public StorageKinds Kinds { get; }
|
|
|
|
/// <summary>
|
|
/// 获取测试数据使用的命名空间。
|
|
/// </summary>
|
|
public string? Namespace { get; }
|
|
|
|
/// <summary>
|
|
/// 获取附加到测试位置上的元数据。
|
|
/// </summary>
|
|
public IReadOnlyDictionary<string, string>? Metadata { get; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// 为基础存档仓库测试提供的简单存档模型。
|
|
/// </summary>
|
|
internal sealed class TestSaveData : IData
|
|
{
|
|
/// <summary>
|
|
/// 获取或设置测试存档中的名称字段。
|
|
/// </summary>
|
|
public string Name { get; set; } = string.Empty;
|
|
}
|
|
|
|
/// <summary>
|
|
/// 为存档迁移测试提供的版本化存档模型。
|
|
/// </summary>
|
|
internal sealed class TestVersionedSaveData : IVersionedData
|
|
{
|
|
/// <summary>
|
|
/// 获取或设置测试存档中的名称字段。
|
|
/// </summary>
|
|
public string Name { get; set; } = string.Empty;
|
|
|
|
/// <summary>
|
|
/// 获取或设置测试存档中的等级字段。
|
|
/// </summary>
|
|
public int Level { get; set; }
|
|
|
|
/// <summary>
|
|
/// 获取或设置测试存档中的经验字段。
|
|
/// </summary>
|
|
public int Experience { get; set; }
|
|
|
|
/// <summary>
|
|
/// 获取或设置当前测试存档的版本号。
|
|
/// </summary>
|
|
public int Version { get; set; } = 3;
|
|
|
|
/// <summary>
|
|
/// 获取或设置测试存档的最后修改时间。
|
|
/// </summary>
|
|
public DateTime LastModified { get; set; } = DateTime.UtcNow;
|
|
}
|
|
|
|
/// <summary>
|
|
/// 为通用持久化测试提供的简单数据模型。
|
|
/// </summary>
|
|
internal sealed class TestSimpleData : IData
|
|
{
|
|
/// <summary>
|
|
/// 获取或设置测试数据中的整数值。
|
|
/// </summary>
|
|
public int Value { get; set; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// 为批量持久化测试提供的另一种数据模型,用于验证运行时类型不会在接口路径上退化。
|
|
/// </summary>
|
|
internal sealed class TestNamedData : IData
|
|
{
|
|
/// <summary>
|
|
/// 获取或设置测试数据中的名称值。
|
|
/// </summary>
|
|
public string Name { get; set; } = string.Empty;
|
|
}
|