ROOTPLOIT
Server: LiteSpeed
System: Linux in-mum-web1878.main-hosting.eu 5.14.0-570.21.1.el9_6.x86_64 #1 SMP PREEMPT_DYNAMIC Wed Jun 11 07:22:35 EDT 2025 x86_64
User: u435929562 (435929562)
PHP: 7.4.33
Disabled: system, exec, shell_exec, passthru, mysql_list_dbs, ini_alter, dl, symlink, link, chgrp, leak, popen, apache_child_terminate, virtual, mb_send_mail
Upload Files
File: //proc/self/root/opt/go/pkg/mod/go.mongodb.org/[email protected]/mongo/readpref/readpref_test.go
// Copyright (C) MongoDB, Inc. 2017-present.
//
// Licensed under the Apache License, Version 2.0 (the "License"); you may
// not use this file except in compliance with the License. You may obtain
// a copy of the License at http://www.apache.org/licenses/LICENSE-2.0

package readpref

import (
	"testing"
	"time"

	"go.mongodb.org/mongo-driver/internal/assert"
	"go.mongodb.org/mongo-driver/internal/require"
	"go.mongodb.org/mongo-driver/tag"
)

func TestPrimary(t *testing.T) {
	subject := Primary()

	require.Equal(t, PrimaryMode, subject.Mode())
	_, set := subject.MaxStaleness()
	require.False(t, set)
	require.Len(t, subject.TagSets(), 0)
}

func TestPrimaryPreferred(t *testing.T) {
	subject := PrimaryPreferred()

	require.Equal(t, PrimaryPreferredMode, subject.Mode())
	_, set := subject.MaxStaleness()
	require.False(t, set)
	require.Len(t, subject.TagSets(), 0)
}

func TestPrimaryPreferred_with_options(t *testing.T) {
	subject := PrimaryPreferred(
		WithMaxStaleness(time.Duration(10)),
		WithTags("a", "1", "b", "2"),
	)

	require.Equal(t, PrimaryPreferredMode, subject.Mode())
	ms, set := subject.MaxStaleness()
	require.True(t, set)
	require.Equal(t, time.Duration(10), ms)
	require.Equal(t, []tag.Set{{tag.Tag{Name: "a", Value: "1"}, tag.Tag{Name: "b", Value: "2"}}}, subject.TagSets())
}

func TestSecondaryPreferred(t *testing.T) {
	subject := SecondaryPreferred()

	require.Equal(t, SecondaryPreferredMode, subject.Mode())
	_, set := subject.MaxStaleness()
	require.False(t, set)
	require.Len(t, subject.TagSets(), 0)
}

func TestSecondaryPreferred_with_options(t *testing.T) {
	subject := SecondaryPreferred(
		WithMaxStaleness(time.Duration(10)),
		WithTags("a", "1", "b", "2"),
	)

	require.Equal(t, SecondaryPreferredMode, subject.Mode())
	ms, set := subject.MaxStaleness()
	require.True(t, set)
	require.Equal(t, time.Duration(10), ms)
	require.Equal(t, []tag.Set{{tag.Tag{Name: "a", Value: "1"}, tag.Tag{Name: "b", Value: "2"}}}, subject.TagSets())
}

func TestSecondary(t *testing.T) {
	subject := Secondary()

	require.Equal(t, SecondaryMode, subject.Mode())
	_, set := subject.MaxStaleness()
	require.False(t, set)
	require.Len(t, subject.TagSets(), 0)
}

func TestSecondary_with_options(t *testing.T) {
	subject := Secondary(
		WithMaxStaleness(time.Duration(10)),
		WithTags("a", "1", "b", "2"),
	)

	require.Equal(t, SecondaryMode, subject.Mode())
	ms, set := subject.MaxStaleness()
	require.True(t, set)
	require.Equal(t, time.Duration(10), ms)
	require.Equal(t, []tag.Set{{tag.Tag{Name: "a", Value: "1"}, tag.Tag{Name: "b", Value: "2"}}}, subject.TagSets())
}

func TestNearest(t *testing.T) {
	subject := Nearest()

	require.Equal(t, NearestMode, subject.Mode())
	_, set := subject.MaxStaleness()
	require.False(t, set)
	require.Len(t, subject.TagSets(), 0)
}

func TestNearest_with_options(t *testing.T) {
	subject := Nearest(
		WithMaxStaleness(time.Duration(10)),
		WithTags("a", "1", "b", "2"),
	)

	require.Equal(t, NearestMode, subject.Mode())
	ms, set := subject.MaxStaleness()
	require.True(t, set)
	require.Equal(t, time.Duration(10), ms)
	require.Equal(t, []tag.Set{{tag.Tag{Name: "a", Value: "1"}, tag.Tag{Name: "b", Value: "2"}}}, subject.TagSets())
}

func TestHedge(t *testing.T) {
	t.Run("hedge specified with primary mode errors", func(t *testing.T) {
		_, err := New(PrimaryMode, WithHedgeEnabled(true))
		assert.Equal(t, errInvalidReadPreference, err, "expected error %v, got %v", errInvalidReadPreference, err)
	})
	t.Run("valid hedge document and mode succeeds", func(t *testing.T) {
		rp, err := New(SecondaryMode, WithHedgeEnabled(true))
		assert.Nil(t, err, "expected no error, got %v", err)
		enabled := rp.HedgeEnabled()
		assert.NotNil(t, enabled, "expected HedgeEnabled to return a non-nil value, got nil")
		assert.True(t, *enabled, "expected HedgeEnabled to return true, got false")
	})
}

func TestReadPref_String(t *testing.T) {
	t.Run("ReadPref.String() with all options", func(t *testing.T) {
		readPref := Nearest(
			WithMaxStaleness(120*time.Second),
			WithTagSets(tag.Set{{"a", "1"}, {"b", "2"}}, tag.Set{{"q", "5"}, {"r", "6"}}),
			WithHedgeEnabled(true),
		)
		expected := "nearest(maxStaleness=2m0s tagSet=a=1,b=2 tagSet=q=5,r=6 hedgeEnabled=true)"
		assert.Equal(t, expected, readPref.String(), "expected %q, got %q", expected, readPref.String())
	})
	t.Run("ReadPref.String() with one option", func(t *testing.T) {
		readPref := Secondary(WithTags("a", "1", "b", "2"))
		expected := "secondary(tagSet=a=1,b=2)"
		assert.Equal(t, expected, readPref.String(), "expected %q, got %q", expected, readPref.String())
	})
	t.Run("ReadPref.String() with no options", func(t *testing.T) {
		readPref := Primary()
		expected := "primary"
		assert.Equal(t, expected, readPref.String(), "expected %q, got %q", expected, readPref.String())
	})
}