Skip to content

Merge to main#89

Open
indrora wants to merge 28 commits into
mainfrom
break/v2.0.0
Open

Merge to main#89
indrora wants to merge 28 commits into
mainfrom
break/v2.0.0

Conversation

@indrora

@indrora indrora commented Jun 23, 2026

Copy link
Copy Markdown
Member

Merge break/v2.0.0 to main - Automated PR

spbsoluble and others added 28 commits April 15, 2026 12:34
Break domain logic out of JobBase into focused, testable services:

- StoreConfigurationParser: parses CertificateStoreDetails.Properties JSON
  into a typed StoreConfiguration, eliminating dynamic dispatch
- StorePathResolver: resolves StorePath strings (namespace/secret-name)
  into structured PathResolutionResult for all store type patterns
- JobCertificateParser: extracts certificate/key/chain from
  ManagementJobConfiguration with explicit format detection
- PasswordResolver: resolves passwords from inline values or K8S secret
  references, centralising the "buddy password" pattern
- CertificateChainExtractor: parses PEM chains into leaf + intermediates,
  handling both bundled and pre-separated chain formats
- KeystoreOperations: JKS/PKCS12 read/write operations moved out of
  handlers into a standalone service

None of these services require a Kubernetes client, making them fully
unit-testable without network access.
Replace inline switch/if chains in JobBase with a proper Strategy pattern:

- ISecretHandler: contract for Inventory, Management, Discovery, and
  Reenrollment operations on a specific secret/store type
- SecretHandlerBase: shared infrastructure (client, logging, result helpers)
- SecretHandlerFactory: creates the correct handler from SecretType enum
- Per-type handlers: TlsSecretHandler, OpaqueSecretHandler,
  JksSecretHandler, Pkcs12SecretHandler, ClusterSecretHandler,
  NamespaceSecretHandler, CertificateSecretHandler (read-only)

Supporting additions:
- SecretTypes enum: typed representation of Kubernetes secret types with
  normalisation and IsTlsType/IsOpaqueType helpers
- K8SJobCertificate model: replaces ad-hoc certificate data passing
- Exceptions: StoreNotFoundException, InvalidK8SSecretException,
  JkSisPkcs12Exception — typed errors replace bare Exception throws
- ICertificateStoreSerializer + JKS/PKCS12 serializer implementations
  moved from StoreTypes/ to Serializers/ (interface renamed for clarity)
KubeClient.cs was a 3000+ line file mixing authentication, kubeconfig
parsing, secret CRUD, and CSR operations. Split into:

- KubeconfigParser: parses kubeconfig JSON into typed configuration,
  validates required fields, provides clear error messages
- SecretOperations: Kubernetes secret CRUD (create, read, update, delete,
  list) with retry logic and structured logging
- CertificateOperations: CSR-specific operations (list, read, approve,
  inject certificate status)
- KubeClient (KubeCertificateManagerClient): now a thin coordinator
  that initialises the authenticated client and delegates to the above

Also removes unreachable code branches, converts string interpolation
log calls to structured logging throughout, and adds retry logic with
configurable backoff.
Job structure (flat → per-store-type):
- Remove Jobs/Inventory.cs, Management.cs, Discovery.cs, Reenrollment.cs
  (monolithic files with large switch statements on store type)
- Add Jobs/Base/: K8SJobBase, InventoryBase, ManagementBase, DiscoveryBase,
  ReenrollmentBase — shared logic each job type delegates to its handler
- Add Jobs/StoreTypes/<Type>/: one class per operation per store type
  (7 store types × up to 4 operations = 26 concrete job classes)
- manifest.json updated to route each capability to its dedicated class

X509Certificate2 removal:
- Replace X509Certificate2 usage throughout with BouncyCastle types
- K8SCertificateContext replaces X509Certificate2-based SerializedStoreInfo
- LoggingUtilities updated: GetCertificateSummary now accepts BouncyCastle
  X509Certificate; RedactPassword no longer leaks password length

Version logging:
- JobBase reads AssemblyInformationalVersionAttribute at startup and logs
  "K8S Orchestrator Extension version: {Version}" on every job execution
  (baked in at build time by GitHub Actions via -p:Version=<tag>)

Also removes TestConsole (superseded by integration test suite) and
store_types.json (superseded by integration-manifest.json).
Test infrastructure:
- CachedCertificateProvider: thread-safe cache for generated certificates;
  eliminates redundant RSA key generation across test collections (RSA 8192
  takes 30+ seconds per key — this alone cut full-suite runtime by ~60%)
- IntegrationTestFixture: shared kubeconfig loading, K8S client creation,
  namespace setup/teardown for all integration test collections
- SkipUnless attribute: skips integration tests when RUN_INTEGRATION_TESTS
  is not set, keeping unit test runs fast

New unit tests (zero network access):
- Services: StoreConfigurationParser, StorePathResolver, PasswordResolver,
  CertificateChainExtractor, JobCertificateParser, KeystoreOperations
- Handlers: SecretHandlerBase, SecretHandlerFactory, all handler types
  (no-network paths), alias routing regression
- Clients: KubeconfigParser, SecretOperations, CertificateOperations,
  KubeCertificateManagerClient
- Jobs: ManagementBase, DiscoveryBase, PAMUtilities, exception paths,
  K8SJobCertificate, K8SCertificateContext
- Utilities: LoggingUtilities (60 cases including DoesNotRevealLength),
  CertificateUtilities, LoggingSafetyTests
- Enums: SecretTypes

Updated integration tests: migrated all 7 store-type integration test
files to use IntegrationTestFixture and new job class namespaces.

Also adds scripts/analyze-coverage.py for coverage gap analysis.
…2.0.0

- CHANGELOG.md: document v2.0.0 breaking changes — new store type routing
  via per-store-type job classes, removed X509Certificate2 dependency,
  updated job configuration model
- docs/ARCHITECTURE.md: new file documenting the service/handler/job
  architecture, authentication flow, and extension points
- Development.md: updated testing guide with CachedCertificateProvider
  guidance, integration test setup, coverage targets
- README.md: regenerated from docsource/ with updated store type dialogs
- docsource/: updated content and added SVG store type dialog images for
  all 7 store types
- .github/workflows: add test-doctool workflow, update starter workflow
- scripts/store_types/: updated kfutil helper scripts
- terraform/: add Terraform module examples for all store types
Reenrollment is not a supported operation. Remove it from the overview
sentence, fix the store type operations table (K8SJKS and K8SPKCS12 were
incorrectly listed as 'All + Reenrollment'), and remove ReenrollmentBase.cs
from the base class directory listing.
Update the compatibility statement and UO version matrix to explicitly
call out support for Keyfactor Command platform versions 24.x and 25.x,
and add a net10.0 row for Command 25.x and newer.
Add explicit mention of net8.0/net10.0 dual-targeting to the
Compatibility section so users know which build to download without
having to dig into the installation table.
Add missing breaking changes (JobBase dead property removal, KeystoreManager
removal), terraform feature, and richer 1.3.0 bug fixes (create-if-missing,
buddy-secret password, alias routing) and refactor/test chores from the
break/major_refactor branch changelog.
The Serializers/ directory containing JKS and PKCS12 store serializers
was never committed, causing build failures when handler files attempted
to reference the Keyfactor.Extensions.Orchestrator.K8S.Serializers namespace.
- Fix fragile grep/awk token lookup in get_service_account_creds.sh and
  create_service_account.sh — now uses direct jsonpath lookup with a
  clear error message if the token Secret is missing (k8s v1.22+)
- Add generate_client_cert_creds.sh: end-to-end script that applies RBAC,
  generates an RSA key, submits and approves a k8s CSR, and builds a
  client-cert kubeconfig in one step
- Add kubernetes_svc_account_cert_auth.yaml: ClusterRole + ClusterRoleBinding
  for cert-based auth (kind: User subject, no ServiceAccount required)
- Add example_kubeconfig_cert.json showing client-certificate-data layout
- Rewrite scripts/kubernetes/README.md to present both auth options equally
  with comparison table, quickstart, config reference, and manual steps
- Update docsource/content.md Requirements section to document both methods
Plugin changes:
- KubeClient.GetKubeClient(): detect KUBERNETES_SERVICE_HOST and call
  InClusterConfig() when no kubeconfig is provided, using the projected
  service account token mounted by kubelet (auto-rotated every hour)
- JobBase.InitializeProperties(): allow empty KubeSvcCreds when running
  in-cluster instead of throwing ConfigurationException

Scripts/docs:
- Add keyfactor-orchestrator-deployment.yaml: Deployment manifest that
  runs the UO as a pod using the keyfactor-orchestrator-sa ServiceAccount
- Update scripts/kubernetes/README.md: add Option 3 to comparison table
  and full setup section (apply SA YAML, deploy, leave Server Password blank)
- Update docsource/content.md: document all three auth options equally
Compliance remediations (all findings were pre-existing on branch):
- Redact certificate bytes in UpdateOpaqueSecret log traces (CRIT-1)
- Log CSR certificate length only, not content preview (CRIT-2)
- Add structured AUDIT log entries (store_access, secret_read/write/delete)
  to ManagementBase, InventoryBase, DiscoveryBase, SecretOperations (CRIT-3)
- ValidateK8SName throws ArgumentException instead of warning; 5+ segment
  paths return Success=false and fail the job (CRIT-4)
- Zero KubeSvcCreds and ServerPassword after KubeClient construction (HIGH-1)
- RedactKubeconfig validates JSON structure before applying label; non-JSON
  returns POSSIBLY_MALFORMED_CREDENTIAL (HIGH-2)
- Silent catch blocks in JKS/PKCS12 serializers now log exception type (HIGH-3)
- PAM resolution outcome promoted from LogTrace to LogInformation (HIGH-4)
- TLS skip override promoted from LogWarning to LogError with structured
  SECURITY_CONFIG_OVERRIDE field (HIGH-5)
- ReadBuddyPass: make passwordSecretName discard explicit with _ (HIGH-6)
- HandleRemove returns Warning (not Success) when store not found so job
  history distinguishes no-op from actual removal (HIGH-7)
- Remove KubeSvcCreds from storeProperties dict after client construction (MED-1)
- StorePathResolver rejects 5+ segment paths (MED-4)
- Handler NotFound catch blocks use HttpOperationException status code
  comparison instead of ex.Message string matching (MED-5)
- Discovery InitializeStore wrapped in try/catch matching Inventory/Management
  pattern (MED-6)

Bug fix:
- UseSSL value from job config (config.UseSSL) was never forwarded to
  KubeCertificateManagerClient — TLS verification was always defaulting to
  true regardless of the store's Use SSL checkbox. Now captured in each
  InitializeStore overload and passed through InitializeKubeClient.
Removes SHA-256 password correlation ID (MED-2) — low-entropy passwords
are reversible via dictionary attack and RedactPassword is already present
at all call sites. Updates CHANGELOG.md with all v2.0.0 changes from this
session including client cert auth, in-cluster auth, UseSSL fix, audit
logging, and compliance remediations.
Regenerated with fixed doctooldotnet (Keyfactor/doctooldotnet#9).
Named content.md sections were being emitted twice due to title mutation
before the custom-sections filter ran.

NOTE: Actions will revert this until doctooldotnet PR #9 is merged.
Copilot AI review requested due to automatic review settings June 23, 2026 14:26
@github-actions

Copy link
Copy Markdown

Dependency Review

✅ No vulnerabilities or license issues or OpenSSF Scorecard issues found.

Scanned Files

  • TestConsole/TestConsole.csproj

@github-actions github-actions Bot added documentation Improvements or additions to documentation dependencies Pull requests that update a dependency file ci/cd needs-review tests labels Jun 23, 2026
@github-actions

Copy link
Copy Markdown

Integration Test Results (K8s v1.29.0)

218 tests  +66   217 ✅ +65   3m 18s ⏱️ -5s
  1 suites ± 0     0 💤 ± 0 
  1 files   ± 0     1 ❌ + 1 

For more details on these failures, see this check.

Results for commit d1be4b2. ± Comparison against base commit 3ce0bb0.

This pull request removes 1 and adds 67 tests. Note that renamed tests count towards both.
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_EmptyName_ReturnsAllIssuedCSRs
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_EmptyKubeSecretName_DoesNotInferSingletonFromStorePath
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_InventoriesAllIssuedCsrs_InCurrentCluster
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_WithInjectedCertificates_ReturnsAllIssuedCSRs
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_SingletonMode_InventoriesOnlySpecifiedCsr
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Inventory_WithBuddyPassword_CustomFieldName_ReadsCorrectField
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Inventory_WithBuddyPassword_ReadsPasswordFromSeparateSecret
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Inventory_WithBuddyPassword_SecretNotFound_ReturnsSuccessWithEmptyInventory
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Inventory_WithBuddyPassword_WrongFieldName_ReturnsFailure
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Management_AddThenInventory_WithFieldPrefixedAlias_InventoryReturnsFullAlias
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Management_AddThenRemove_WithFieldPrefixedAlias_RemovesFromNamedField
…

// Verify the deployed certificate matches the input certificate
Assert.True(secret.Data.ContainsKey("tls.crt"), "Secret should have tls.crt field");
var deployedCertPem = Encoding.UTF8.GetString(secret.Data["tls.crt"]);
var parser = new Org.BouncyCastle.X509.X509CertificateParser();
// Verify the deployed certificate matches the input certificate
Assert.True(secret.Data.ContainsKey("tls.crt"), "Secret should have tls.crt field");
var deployedCertPem = Encoding.UTF8.GetString(secret.Data["tls.crt"]);
var parser = new Org.BouncyCastle.X509.X509CertificateParser();
// Get certificate bytes for the serializer
// Use PKCS12 if available (for certificates with private keys), otherwise use raw cert bytes
// (for certificate-only entries like trusted CA certs)
byte[] newCertBytes = certObj.Pkcs12 ?? certObj.CertBytes;
try
{
await _k8sClient.CoreV1.DeleteNamespacedSecretAsync(secretName, ns);
await _k8sClient.CoreV1.DeleteCollectionNamespacedSecretAsync(
}

return result;
return result!;
@github-actions

Copy link
Copy Markdown

Unit Test Results (.NET 10.0.x)

1 405 tests  +801   1 202 ✅ +735   19m 59s ⏱️ - 11m 9s
    1 suites ±  0     203 💤 + 66 
    1 files   ±  0       0 ❌ ±  0 

Results for commit d1be4b2. ± Comparison against base commit 3ce0bb0.

This pull request removes 5 and adds 806 tests. Note that renamed tests count towards both.
Keyfactor.Extensions.Orchestrator.K8S.Tests.LoggingSafetyTests ‑ LoggingUtilities_GetPasswordCorrelationId_ShouldBeConsistent
Keyfactor.Extensions.Orchestrator.K8S.Tests.LoggingSafetyTests ‑ LoggingUtilities_GetPasswordCorrelationId_ShouldBeDifferentForDifferentPasswords
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_EmptyName_ReturnsAllIssuedCSRs
Keyfactor.Orchestrators.K8S.Tests.K8SJKSStoreTests ‑ DeserializeRemoteCertificateStore_RsaKeys_SuccessfullyLoadsStore(keyType: Rsa8192)
Keyfactor.Orchestrators.K8S.Tests.K8SPKCS12StoreTests ‑ DeserializeRemoteCertificateStore_RsaKeys_SuccessfullyLoadsStore(keyType: Rsa8192)
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_Base64EncodedKubeconfig_ReturnsConfiguration
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_EmptyKubeconfig_ThrowsKubeConfigException
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_EscapedJson_HandlesBackslashesCorrectly
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_InvalidJsonStructure_ThrowsKubeConfigException
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_MultipleCluster_ParsesAll
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_NonJsonKubeconfig_ThrowsKubeConfigException
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_NullKubeconfig_ThrowsKubeConfigException
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_ValidKubeconfig_ParsesClusters
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_ValidKubeconfig_ParsesContexts
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_ValidKubeconfig_ParsesUsers
…
This pull request removes 1 skipped test and adds 67 skipped tests. Note that renamed tests count towards both.
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_EmptyName_ReturnsAllIssuedCSRs
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_EmptyKubeSecretName_DoesNotInferSingletonFromStorePath
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_InventoriesAllIssuedCsrs_InCurrentCluster
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_WithInjectedCertificates_ReturnsAllIssuedCSRs
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_SingletonMode_InventoriesOnlySpecifiedCsr
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Inventory_WithBuddyPassword_CustomFieldName_ReadsCorrectField
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Inventory_WithBuddyPassword_ReadsPasswordFromSeparateSecret
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Inventory_WithBuddyPassword_SecretNotFound_ReturnsSuccessWithEmptyInventory
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Inventory_WithBuddyPassword_WrongFieldName_ReturnsFailure
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Management_AddThenInventory_WithFieldPrefixedAlias_InventoryReturnsFullAlias
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Management_AddThenRemove_WithFieldPrefixedAlias_RemovesFromNamedField
…

Copilot AI left a comment

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copilot wasn't able to review this pull request because it exceeds the maximum number of lines (20,000). Try reducing the number of changed lines and requesting a review from Copilot again.

@github-actions

Copy link
Copy Markdown

Unit Test Results (.NET 8.0.x)

1 405 tests  +801   1 202 ✅ +735   25m 53s ⏱️ + 6m 23s
    1 suites ±  0     203 💤 + 66 
    1 files   ±  0       0 ❌ ±  0 

Results for commit d1be4b2. ± Comparison against base commit 3ce0bb0.

This pull request removes 5 and adds 806 tests. Note that renamed tests count towards both.
Keyfactor.Extensions.Orchestrator.K8S.Tests.LoggingSafetyTests ‑ LoggingUtilities_GetPasswordCorrelationId_ShouldBeConsistent
Keyfactor.Extensions.Orchestrator.K8S.Tests.LoggingSafetyTests ‑ LoggingUtilities_GetPasswordCorrelationId_ShouldBeDifferentForDifferentPasswords
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_EmptyName_ReturnsAllIssuedCSRs
Keyfactor.Orchestrators.K8S.Tests.K8SJKSStoreTests ‑ DeserializeRemoteCertificateStore_RsaKeys_SuccessfullyLoadsStore(keyType: Rsa8192)
Keyfactor.Orchestrators.K8S.Tests.K8SPKCS12StoreTests ‑ DeserializeRemoteCertificateStore_RsaKeys_SuccessfullyLoadsStore(keyType: Rsa8192)
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_Base64EncodedKubeconfig_ReturnsConfiguration
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_EmptyKubeconfig_ThrowsKubeConfigException
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_EscapedJson_HandlesBackslashesCorrectly
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_InvalidJsonStructure_ThrowsKubeConfigException
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_MultipleCluster_ParsesAll
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_NonJsonKubeconfig_ThrowsKubeConfigException
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_NullKubeconfig_ThrowsKubeConfigException
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_ValidKubeconfig_ParsesClusters
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_ValidKubeconfig_ParsesContexts
Keyfactor.Orchestrators.K8S.Tests.Clients.KubeconfigParserTests ‑ Parse_ValidKubeconfig_ParsesUsers
…
This pull request removes 1 skipped test and adds 67 skipped tests. Note that renamed tests count towards both.
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_EmptyName_ReturnsAllIssuedCSRs
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_EmptyKubeSecretName_DoesNotInferSingletonFromStorePath
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_InventoriesAllIssuedCsrs_InCurrentCluster
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_ClusterWideMode_WithInjectedCertificates_ReturnsAllIssuedCSRs
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SCertStoreIntegrationTests ‑ Inventory_SingletonMode_InventoriesOnlySpecifiedCsr
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Inventory_WithBuddyPassword_CustomFieldName_ReadsCorrectField
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Inventory_WithBuddyPassword_ReadsPasswordFromSeparateSecret
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Inventory_WithBuddyPassword_SecretNotFound_ReturnsSuccessWithEmptyInventory
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Inventory_WithBuddyPassword_WrongFieldName_ReturnsFailure
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Management_AddThenInventory_WithFieldPrefixedAlias_InventoryReturnsFullAlias
Keyfactor.Orchestrators.K8S.Tests.Integration.K8SJKSStoreIntegrationTests ‑ Management_AddThenRemove_WithFieldPrefixedAlias_RemovesFromNamedField
…

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

ci/cd dependencies Pull requests that update a dependency file documentation Improvements or additions to documentation needs-review tests

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants