Class IdSegmentDistributor.Mock

java.lang.Object
me.ahoo.cosid.segment.IdSegmentDistributor.Mock
All Implemented Interfaces:
Grouped, IdSegmentDistributor
Enclosing interface:
IdSegmentDistributor

public static class IdSegmentDistributor.Mock extends Object implements IdSegmentDistributor
Mock implementation of IdSegmentDistributor for testing purposes.

This implementation simulates network I/O delays to test the behavior of ID segment distributors under realistic conditions.

  • Constructor Details

    • Mock

      public Mock()
      Create a new Mock distributor with default configuration.
    • Mock

      public Mock(long step, int tps)
      Create a new Mock distributor with custom configuration.
      Parameters:
      step - The step size for ID segments
      tps - The transactions per second to simulate for I/O waiting
  • Method Details

    • getNamespace

      @Nonnull public String getNamespace()
      Get the namespace for this distributor.
      Specified by:
      getNamespace in interface IdSegmentDistributor
      Returns:
      The namespace
    • getName

      @Nonnull public String getName()
      Get the name for this distributor.
      Specified by:
      getName in interface IdSegmentDistributor
      Returns:
      The name
    • getStep

      public long getStep()
      Get the step size for ID segments.
      Specified by:
      getStep in interface IdSegmentDistributor
      Returns:
      The step size
    • nextMaxId

      public long nextMaxId(long step)
      Allocate the next maximum ID for the specified step size.

      This method simulates network I/O delay before allocating the ID.

      Specified by:
      nextMaxId in interface IdSegmentDistributor
      Parameters:
      step - The step size for allocation
      Returns:
      The maximum ID in the allocated range