File size: 3,704 Bytes
d7b3d84
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
"""Test that disable_security flag properly merges --disable-features flags without breaking extensions."""

import tempfile

from browser_use.browser.profile import BrowserProfile


class TestBrowserProfileDisableSecurity:
	"""Test disable_security flag behavior."""

	def test_disable_security_preserves_extension_features(self):
		"""Test that disable_security=True doesn't break extension features by properly merging --disable-features flags."""

		# Test with disable_security=False (baseline)
		profile_normal = BrowserProfile(disable_security=False, user_data_dir=tempfile.mkdtemp(prefix='test-normal-'))
		profile_normal.detect_display_configuration()
		args_normal = profile_normal.get_args()

		# Test with disable_security=True
		profile_security_disabled = BrowserProfile(disable_security=True, user_data_dir=tempfile.mkdtemp(prefix='test-security-'))
		profile_security_disabled.detect_display_configuration()
		args_security_disabled = profile_security_disabled.get_args()

		# Extract disable-features args
		def extract_disable_features(args):
			for arg in args:
				if arg.startswith('--disable-features='):
					return set(arg.split('=', 1)[1].split(','))
			return set()

		features_normal = extract_disable_features(args_normal)
		features_security_disabled = extract_disable_features(args_security_disabled)

		# Check that extension-related features are preserved
		extension_features = {
			'ExtensionManifestV2Disabled',
			'ExtensionDisableUnsupportedDeveloper',
			'ExtensionManifestV2Unsupported',
		}

		security_features = {'IsolateOrigins', 'site-per-process'}

		# Verify that security disabled has both extension and security features
		missing_extension_features = extension_features - features_security_disabled
		missing_security_features = security_features - features_security_disabled

		assert not missing_extension_features, (
			f'Missing extension features when disable_security=True: {missing_extension_features}'
		)
		assert not missing_security_features, f'Missing security features when disable_security=True: {missing_security_features}'

		# Verify that security disabled profile has more features than normal (due to added security features)
		assert len(features_security_disabled) > len(features_normal), (
			'Security disabled profile should have more features than normal profile'
		)

		# Verify all normal features are preserved in security disabled profile
		missing_normal_features = features_normal - features_security_disabled
		assert not missing_normal_features, f'Normal features missing from security disabled profile: {missing_normal_features}'

	def test_disable_features_flag_deduplication(self):
		"""Test that duplicate --disable-features values are properly deduplicated."""

		profile = BrowserProfile(
			disable_security=True,
			user_data_dir=tempfile.mkdtemp(prefix='test-dedup-'),
			# Add duplicate features to test deduplication
			args=['--disable-features=TestFeature1,TestFeature2', '--disable-features=TestFeature2,TestFeature3'],
		)
		profile.detect_display_configuration()
		args = profile.get_args()

		# Extract disable-features args
		disable_features_args = [arg for arg in args if arg.startswith('--disable-features=')]

		# Should only have one consolidated --disable-features flag
		assert len(disable_features_args) == 1, f'Expected 1 disable-features flag, got {len(disable_features_args)}'

		features = set(disable_features_args[0].split('=', 1)[1].split(','))

		# Should have all test features without duplicates
		expected_test_features = {'TestFeature1', 'TestFeature2', 'TestFeature3'}
		assert expected_test_features.issubset(features), f'Missing test features: {expected_test_features - features}'