Skip to content

Commit

Permalink
peer-selection: added tests for association mode
Browse files Browse the repository at this point in the history
* Extended the `GovernorMockEnvironment` with a `TimedScript UseLedgerPeers`.
* added `prop_governor_association_mode`
  • Loading branch information
coot committed Apr 29, 2024
1 parent 484734e commit a38e5a1
Show file tree
Hide file tree
Showing 4 changed files with 170 additions and 24 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,8 @@ instance Arbitrary ArbitraryLedgerStateJudgement where
shrink (ArbitraryLedgerStateJudgement TooOld) =
[]

-- TODO: import the `SlotNo` instance from
-- `Test.Ouroboros.Network.PeerSelection.Instances`
newtype ArbitrarySlotNo =
ArbitrarySlotNo {
getArbitrarySlotNo :: SlotNo
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -190,6 +190,7 @@ tests =
, testProperty "node uses ledger peers in non-sensitive mode"
prop_governor_uses_ledger_peers
]
, testProperty "association mode" prop_governor_association_mode
]
, testGroup "issues"
[ testProperty "3233" prop_issue_3233
Expand Down Expand Up @@ -761,6 +762,7 @@ envEventCredits TraceEnvActivatePeer {} = 0
envEventCredits TraceEnvDeactivatePeer {} = 0
envEventCredits TraceEnvCloseConn {} = 0

envEventCredits TraceEnvUseLedgerPeers {} = 30
envEventCredits TraceEnvSetLedgerStateJudgement {} = 30

envEventCredits TraceEnvSetUseBootstrapPeers {} = 30
Expand Down Expand Up @@ -3426,6 +3428,79 @@ prop_governor_uses_ledger_peers env =
in counterexample (intercalate "\n" $ map show $ usesLedgerPeers)
$ all snd usesLedgerPeers


prop_governor_association_mode :: GovernorMockEnvironment -> Property
prop_governor_association_mode env =
let events = Signal.eventsFromListUpToTime (Time (10 * 60 * 60))
. selectPeerSelectionTraceEvents
. runGovernorInMockEnvironment
$ env

counters :: Signal (PeerSelectionSetsWithSizes PeerAddr)
counters =
selectGovState peerSelectionStateToView events

-- accumulate local roots
localRoots :: Signal (Set PeerAddr)
localRoots =
Signal.keyedUntil
(\case
Just (GovernorEvent (TraceLocalRootPeersChanged a _)) -> LocalRootPeers.keysSet a
Just (MockEnvEvent (TraceEnvSetLocalRoots a)) -> LocalRootPeers.keysSet a
_ -> Set.empty
)
(\_ -> Set.empty)
(\_ -> False)
. Signal.fromChangeEvents Nothing
. fmap Just
$ events

publicRoots :: Signal (Set PeerAddr)
publicRoots =
Signal.keyedUntil
PublicRootPeers.toSet
(\_ -> Set.empty)
(\_ -> False)
. selectGovState Governor.publicRootPeers
$ events

associationMode :: Signal AssociationMode
associationMode =
Signal.fromChangeEvents Unrestricted
$ selectGovAssociationMode events

in counterexample (intercalate "\n" $ show <$> Signal.eventsToList events)
$ signalProperty 20 show
(\(cs, localRootSet, publicRootSet, am) ->
case am of
LocalRootsOnly ->
-- we need to remove local and public roots. They are changing
-- over time, and a node might keep using them, event though the
-- node is configured as an `Unrestricted` node.
--
-- This makes this test only effective if a node starts in
-- `LocalRootsOnly` mode, until it is reconfigured. This can
-- discover some bugs in `readAssociationMode` but certainly not
-- all.
--
-- TODO: write a more effective test.
Set.null (fst (viewKnownBootstrapPeers cs)
Set.\\ localRootSet
Set.\\ publicRootSet)
&& Set.null (fst (viewKnownBigLedgerPeers cs)
Set.\\ localRootSet
Set.\\ publicRootSet)
&& Set.null (fst (viewKnownNonRootPeers cs)
Set.\\ localRootSet
Set.\\ publicRootSet)

Unrestricted -> True
)
((,,,) <$> counters
<*> localRoots
<*> publicRoots
<*> associationMode)

--
-- Utils for properties
--
Expand All @@ -3444,6 +3519,18 @@ selectGovEvents = Signal.selectEvents
(\case GovernorEvent e -> Just $! e
_ -> Nothing)

selectGovCounters :: Events TestTraceEvent
-> Events PeerSelectionCounters
selectGovCounters = Signal.selectEvents
(\case GovernorCounters e -> Just $! e
_ -> Nothing)

selectGovAssociationMode :: Events TestTraceEvent
-> Events AssociationMode
selectGovAssociationMode = Signal.selectEvents
(\case GovernorAssociationMode e -> Just $! e
_ -> Nothing)

selectGovState :: Eq a
=> (forall peerconn. Governor.PeerSelectionState PeerAddr peerconn -> a)
-> Events TestTraceEvent
Expand Down Expand Up @@ -3601,6 +3688,7 @@ prop_issue_3550 = prop_governor_target_established_below defaultMaxTime $
pickColdPeersToForget = Script (PickFirst :| []),
peerSharingFlag = PeerSharingEnabled,
useBootstrapPeers = Script ((DontUseBootstrapPeers, NoDelay) :| []),
useLedgerPeers = Script ((UseLedgerPeers Always, NoDelay) :| []),
ledgerStateJudgement = Script ((YoungEnough, NoDelay) :| [])
}

Expand Down Expand Up @@ -3637,6 +3725,7 @@ prop_issue_3515 = prop_governor_nolivelock $
pickColdPeersToForget = Script (PickFirst :| []),
peerSharingFlag = PeerSharingEnabled,
useBootstrapPeers = Script ((DontUseBootstrapPeers, NoDelay) :| []),
useLedgerPeers = Script ((UseLedgerPeers Always, NoDelay) :| []),
ledgerStateJudgement = Script ((YoungEnough, NoDelay) :| [])
}

Expand Down Expand Up @@ -3673,6 +3762,7 @@ prop_issue_3494 = prop_governor_nofail $
pickColdPeersToForget = Script (PickFirst :| []),
peerSharingFlag = PeerSharingEnabled,
useBootstrapPeers = Script ((DontUseBootstrapPeers, NoDelay) :| []),
useLedgerPeers = Script ((UseLedgerPeers Always, NoDelay) :| []),
ledgerStateJudgement = Script ((YoungEnough, NoDelay) :| [])
}

Expand Down Expand Up @@ -3725,6 +3815,7 @@ prop_issue_3233 = prop_governor_nolivelock $
pickColdPeersToForget = Script (PickFirst :| []),
peerSharingFlag = PeerSharingEnabled,
useBootstrapPeers = Script ((DontUseBootstrapPeers, NoDelay) :| []),
useLedgerPeers = Script ((UseLedgerPeers Always, NoDelay) :| []),
ledgerStateJudgement = Script ((YoungEnough, NoDelay) :| [])
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
{-# LANGUAGE DerivingVia #-}
{-# LANGUAGE GeneralizedNewtypeDeriving #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE StandaloneDeriving #-}

{-# OPTIONS_GHC -Wno-orphans #-}

Expand All @@ -16,19 +18,22 @@ module Test.Ouroboros.Network.PeerSelection.Instances
) where

import Data.Text.Encoding (encodeUtf8)
import Data.Word (Word32)
import Data.Word (Word32, Word64)

import Cardano.Slotting.Slot (SlotNo (..))

import Ouroboros.Network.PeerSelection.Governor

import Data.Hashable
import Data.IP qualified as IP
import Ouroboros.Network.PeerSelection.Bootstrap (UseBootstrapPeers (..))
import Ouroboros.Network.PeerSelection.LedgerPeers.Type (AfterSlot (..),
UseLedgerPeers (..))
import Ouroboros.Network.PeerSelection.PeerAdvertise (PeerAdvertise (..))
import Ouroboros.Network.PeerSelection.PeerSharing (PeerSharing (..))
import Ouroboros.Network.PeerSelection.PeerTrustable (PeerTrustable (..))
import Ouroboros.Network.PeerSelection.RelayAccessPoint (DomainAccessPoint (..),
RelayAccessPoint (..))

import Ouroboros.Network.PeerSelection.Bootstrap (UseBootstrapPeers (..))
import Ouroboros.Network.PeerSelection.PeerTrustable (PeerTrustable (..))
import Ouroboros.Network.Testing.Utils (ShrinkCarefully, prop_shrink_nonequal,
prop_shrink_valid)
import Test.QuickCheck
Expand All @@ -51,7 +56,7 @@ instance Arbitrary PeerAddr where
arbitrary = PeerAddr <$> arbitrarySizedNatural
shrink _ = []


deriving via Word64 instance Arbitrary SlotNo

instance Arbitrary PeerAdvertise where
arbitrary = elements [ DoAdvertisePeer, DoNotAdvertisePeer ]
Expand All @@ -64,6 +69,11 @@ instance Arbitrary PeerSharing where
shrink PeerSharingDisabled = []
shrink PeerSharingEnabled = [PeerSharingDisabled]

instance Arbitrary AfterSlot where
arbitrary = oneof [ pure Always
, After <$> arbitrary
]

instance Arbitrary UseBootstrapPeers where
arbitrary = frequency [ (1, pure DontUseBootstrapPeers)
, (1, UseBootstrapPeers <$> arbitrary)
Expand All @@ -72,6 +82,12 @@ instance Arbitrary UseBootstrapPeers where
shrink DontUseBootstrapPeers = []
shrink (UseBootstrapPeers _) = [DontUseBootstrapPeers]

instance Arbitrary UseLedgerPeers where
arbitrary = frequency
[ (2, pure DontUseLedgerPeers)
, (8, UseLedgerPeers <$> arbitrary)
]

instance Arbitrary PeerTrustable where
arbitrary = elements [ IsNotTrustable, IsTrustable ]

Expand Down
Loading

0 comments on commit a38e5a1

Please sign in to comment.