EdjCase.ICP.PocketIC
7.0.0-rc.1
This is a prerelease version of EdjCase.ICP.PocketIC.
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package EdjCase.ICP.PocketIC --version 7.0.0-rc.1
NuGet\Install-Package EdjCase.ICP.PocketIC -Version 7.0.0-rc.1
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="EdjCase.ICP.PocketIC" Version="7.0.0-rc.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add EdjCase.ICP.PocketIC --version 7.0.0-rc.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: EdjCase.ICP.PocketIC, 7.0.0-rc.1"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install EdjCase.ICP.PocketIC as a Cake Addin #addin nuget:?package=EdjCase.ICP.PocketIC&version=7.0.0-rc.1&prerelease // Install EdjCase.ICP.PocketIC as a Cake Tool #tool nuget:?package=EdjCase.ICP.PocketIC&version=7.0.0-rc.1&prerelease
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
PocketIC
Library containing the pocket-ic server runtime and clients for interfacing for canister testing on the internet computer
- Nuget:
EdjCase.ICP.PocketIC
Supported PocketIC Server Runtimes
The pocket-ic server binary is only compatible with some operating systems:
- linux-x64
- osx-x64
Quick Start
Basic usage
// Start server
await using PocketIcServer server = await PocketIcServer.Start();
string pocketIcServerUrl = server.GetUrl();
// Create a new PocketIC instance with a default subnets
await using PocketIc pocketIc = await PocketIc.CreateAsync(pocketIcServerUrl);
// Create a new canister
CreateCanisterResponse response = await pocketIc.CreateCanisterAsync();
Principal canisterId = response.CanisterId;
// Install WASM module
byte[] wasmModule = File.ReadAllBytes("path/to/my_canister.wasm");
await pocketIc.InstallCodeAsync(
canisterId: canisterId,
wasmModule: wasmModule,
arg: CandidArg.FromCandid(),
mode: InstallCodeMode.Install
);
// Start the canister
await pocketIc.StartCanisterAsync(canisterId);
// Make calls to the canister
UnboundedUInt counter = await pocketIc.QueryCallAsync<UnboundedUInt>(
Principal.Anonymous(),
canisterId,
"my_method"
);
HTTP Gateway usage
await using HttpGateway httpGateway = await pocketIc.RunHttpGatewayAsync()
// Create an HttpAgent to interact with canisters through the gateway
HttpAgent agent = httpGateway.BuildHttpAgent();
// Make calls using the agent
QueryResponse response = await agent.QueryAsync(canisterId, "my_method", CandidArg.Empty());
CandidArg reply = response.ThrowOrGetReply();
Subnet Configuration
PocketIC instances can be created with various subnet configurations:
await PocketIc.CreateAsync(
pocketIcServerUrl,
applicationSubnets: [SubnetConfig.New()], // Application subnets
nnsSubnet: SubnetConfig.New(), // Network Nervous System subnet
iiSubnet: SubnetConfig.New(), // Internet Identity subnet
bitcoinSubnet: SubnetConfig.New(), // Bitcoin subnet
snsSubnet: SubnetConfig.New(), // Service Nervous System subnet
systemSubnets: [SubnetConfig.New()] // System subnets
);
Auto Time Progression
PocketIC provides control over the IC time for testing:
// Enable automatic time progression
await using (await pocketIc.AutoProgressTimeAsync())
{
// Time will progress automatically
}
// Disposing will stop auto progress
XUnit usage
// Fixture to create and run server for all the tests, disposing only after all tests are complete
public class PocketIcServerFixture : IDisposable
{
public PocketIcServer Server { get; private set; }
public PocketIcServerFixture()
{
// Start the server for all tests
this.Server = PocketIcServer.Start(showRuntimeLogs: true).GetAwaiter().GetResult();
}
public void Dispose()
{
// Stop the server after all tests
if (this.Server != null)
{
this.Server.DisposeAsync().GetAwaiter().GetResult();
}
}
}
// Unit tests injecting the fixture
public class PocketIcTests : IClassFixture<PocketIcServerFixture>
{
private readonly PocketIcServerFixture fixture;
private string url => this.fixture.Server.GetUrl();
public PocketIcTests(PocketIcServerFixture fixture)
{
this.fixture = fixture;
}
[Fact]
public async Task Test()
{
// Create new pocketic instance for test, then dispose it on completion
await using (PocketIc pocketIc = await PocketIc.CreateAsync(this.url));
// run test here
}
}
Call Types
Query Calls
// No arguments
TResponse result = await pocketIc.QueryCallAsync<TResponse>(
sender,
canisterId,
"method"
);
// With arguments
TResponse result = await pocketIc.QueryCallAsync<T1, TResponse>(
sender,
canisterId,
"method",
arg1
);
// Raw candid
CandidArg response = await pocketIc.QueryCallRawAsync(
sender,
canisterId,
"method",
CandidArg.FromCandid()
);
Update Calls
// No arguments
TResponse result = await pocketIc.UpdateCallAsync<TResponse>(
sender,
canisterId,
"method"
);
// With arguments
TResponse result = await pocketIc.UpdateCallAsync<T1, TResponse>(
sender,
canisterId,
"method",
arg1
);
// No response
await pocketIc.UpdateCallNoResponseAsync(
sender,
canisterId,
"method"
);
// Raw candid
CandidArg response = await pocketIc.UpdateCallRawAsync(
sender,
canisterId,
"method",
CandidArg.FromCandid()
);
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net8.0
- EdjCase.ICP.Agent (>= 7.0.0-rc.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
7.0.0 | 78 | 1/15/2025 |
7.0.0-rc.1 | 113 | 1/4/2025 |