Completed
Push — add/jshint-yarn-lint ( 33f010...8f97d1 )
by
unknown
50:01 queued 39:26
created

Jetpack_Constants   A

Complexity

Total Complexity 11

Size/Duplication

Total Lines 77
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 0

Importance

Changes 0
Metric Value
dl 0
loc 77
rs 10
c 0
b 0
f 0
wmc 11
lcom 1
cbo 0

6 Methods

Rating   Name   Duplication   Size   Complexity  
A is_defined() 0 5 2
A is_true() 0 3 2
A get_constant() 0 7 3
A set_constant() 0 3 1
A clear_single_constant() 0 8 2
A clear_constants() 0 3 1
1
<?php
2
3
/**
4
 * Class Jetpack_Constants
5
 *
6
 * Testing constants is hard. Once you define a constant, it's defined. Jetpack_Constants is an
7
 * abstraction layer so that unit tests can set "constants" for tests.
8
 *
9
 * To test your code, you'll need to swap out `defined( 'CONSTANT' )` with `Jetpack_Constants::is_defined( 'CONSTANT' )`
10
 * and replace `CONSTANT` with `Jetpack_Constants::get_constant( 'CONSTANT' )`. Then in the unit test, you can set the
11
 * constant with `Jetpack::set_constant( 'CONSTANT', $value )` and then clean up after each test with something like
12
 * this:
13
 *
14
 * function tearDown() {
15
 *     Jetpack_Constants::clear_constants();
16
 * }
17
 */
18
class Jetpack_Constants {
19
	static $set_constants = array();
0 ignored issues
show
Coding Style introduced by
The visibility should be declared for property $set_constants.

The PSR-2 coding standard requires that all properties in a class have their visibility explicitly declared. If you declare a property using

class A {
    var $property;
}

the property is implicitly global.

To learn more about the PSR-2, please see the PHP-FIG site on the PSR-2.

Loading history...
20
21
	/**
22
	 * Checks if a "constant" has been set in Jetpack_Constants, and if not,
23
	 * checks if the constant was defined with define( 'name', 'value ).
24
	 *
25
	 * @param $name string The name of the constant
26
	 *
27
	 * @return bool
28
	 */
29
	public static function is_defined( $name ) {
30
		return array_key_exists( $name, self::$set_constants )
31
			? true
32
			: defined( $name );
33
	}
34
	/**
35
	 * Checks if a "constant" has been set in Jetpack_Constants
36
	 * and has the value of true
37
	 *
38
	 * @param $name string The name of the constant
39
	 *
40
	 * @return bool
41
	 */
42
	public static function is_true( $name ) {
43
		return self::is_defined( $name) && self::get_constant( $name );
44
	}
45
46
	/**
47
	 * Attempts to retrieve the "constant" from Jetpack_Constants, and if it hasn't been set,
48
	 * then attempts to get the constant with the constant() function.
49
	 *
50
	 * @param $name
51
	 *
52
	 * @return mixed null if the constant does not exist or the value of the constant.
53
	 */
54
	public static function get_constant( $name ) {
55
		if ( array_key_exists( $name,  self::$set_constants ) ) {
56
			return self::$set_constants[ $name ];
57
		}
58
59
		return defined( $name ) ? constant( $name ) : null;
60
	}
61
62
	/**
63
	 * Sets the value of the "constant" within Jetpack_Constants.
64
	 *
65
	 * @param $name  string The name of the "constant"
66
	 * @param $value string The value of the "constant"
67
	 */
68
	public static function set_constant( $name, $value ) {
69
		self::$set_constants[ $name ] = $value;
70
	}
71
72
	/**
73
	 * Will unset a "constant" from Jetpack_Constants if the constant exists.
74
	 *
75
	 * @param $name string The name of the "constant"
76
	 *
77
	 * @return bool Whether the constant was removed.
78
	 */
79
	public static function clear_single_constant( $name ) {
80
		if ( ! array_key_exists( $name, self::$set_constants ) ) {
81
			return false;
82
		}
83
84
		unset( self::$set_constants[ $name ] );
85
		return true;
86
	}
87
88
	/**
89
	 * Resets all of the constants within Jetpack_Constants.
90
	 */
91
	public static function clear_constants() {
92
		self::$set_constants = array();
93
	}
94
}
95