| Conditions | 4 |
| Total Lines | 63 |
| Code Lines | 59 |
| Lines | 0 |
| Ratio | 0 % |
| Changes | 0 | ||
Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.
For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.
Commonly applied refactorings include:
If many parameters/temporary variables are present:
| 1 | package tests |
||
| 69 | |||
| 70 | func TestParseEnWithOnlineFlag(t *testing.T) { |
||
| 71 | cases := []struct { |
||
| 72 | date string |
||
| 73 | result string |
||
| 74 | }{ |
||
| 75 | {smallSubTime(time.Second * 2), "Online"}, |
||
| 76 | {smallSubTime(time.Second), "Online"}, |
||
| 77 | {smallSubTime(-1 * time.Second), "Online"}, |
||
| 78 | {smallSubTime(-2 * time.Second), "Online"}, |
||
| 79 | {smallSubTime(-9 * time.Second), "Online"}, |
||
| 80 | {smallSubTime(-10 * time.Second), "Online"}, |
||
| 81 | {smallSubTime(-11 * time.Second), "Online"}, |
||
| 82 | {smallSubTime(-20 * time.Second), "Online"}, |
||
| 83 | {smallSubTime(-21 * time.Second), "Online"}, |
||
| 84 | {smallSubTime(-22 * time.Second), "Online"}, |
||
| 85 | {smallSubTime(-30 * time.Second), "Online"}, |
||
| 86 | {smallSubTime(-31 * time.Second), "Online"}, |
||
| 87 | {smallSubTime(-60 * time.Second), "1 minute ago"}, |
||
| 88 | {smallSubTime(-1 * time.Minute), "1 minute ago"}, |
||
| 89 | {smallSubTime(-2 * time.Minute), "2 minutes ago"}, |
||
| 90 | {smallSubTime(-9 * time.Minute), "9 minutes ago"}, |
||
| 91 | {smallSubTime(-10 * time.Minute), "10 minutes ago"}, |
||
| 92 | {smallSubTime(-11 * time.Minute), "11 minutes ago"}, |
||
| 93 | {smallSubTime(-20 * time.Minute), "20 minutes ago"}, |
||
| 94 | {smallSubTime(-21 * time.Minute), "21 minutes ago"}, |
||
| 95 | {smallSubTime(-22 * time.Minute), "22 minutes ago"}, |
||
| 96 | {smallSubTime(-30 * time.Minute), "30 minutes ago"}, |
||
| 97 | {smallSubTime(-31 * time.Minute), "31 minutes ago"}, |
||
| 98 | {smallSubTime(-60 * time.Minute), "1 hour ago"}, |
||
| 99 | {smallSubTime(-1 * time.Hour), "1 hour ago"}, |
||
| 100 | {smallSubTime(-2 * time.Hour), "2 hours ago"}, |
||
| 101 | {smallSubTime(-9 * time.Hour), "9 hours ago"}, |
||
| 102 | {smallSubTime(-10 * time.Hour), "10 hours ago"}, |
||
| 103 | {smallSubTime(-11 * time.Hour), "11 hours ago"}, |
||
| 104 | {smallSubTime(-20 * time.Hour), "20 hours ago"}, |
||
| 105 | {smallSubTime(-21 * time.Hour), "21 hours ago"}, |
||
| 106 | {smallSubTime(-23 * time.Hour), "23 hours ago"}, |
||
| 107 | {smallSubTime(-24 * time.Hour), "1 day ago"}, |
||
| 108 | {smallSubTime(-30 * time.Hour), "1 day ago"}, |
||
| 109 | {smallSubTime((-24 * 2) * time.Hour), "2 days ago"}, |
||
| 110 | {smallSubTime((-24 * 6) * time.Hour), "6 days ago"}, |
||
| 111 | {smallSubTime((-24 * 7) * time.Hour), "1 week ago"}, |
||
| 112 | {smallSubTime((-24 * 14) * time.Hour), "2 weeks ago"}, |
||
| 113 | {smallSubTime((-24 * 21) * time.Hour), "3 weeks ago"}, |
||
| 114 | {bigSubTime(0, 1, 1), "1 month ago"}, |
||
| 115 | {bigSubTime(0, 2, 1), "2 months ago"}, |
||
| 116 | {bigSubTime(0, 9, 1), "9 months ago"}, |
||
| 117 | {bigSubTime(0, 11, 1), "11 months ago"}, |
||
| 118 | {bigSubTime(0, 12, 1), "1 year ago"}, |
||
| 119 | {bigSubTime(1, 0, 1), "1 year ago"}, |
||
| 120 | {bigSubTime(2, 0, 1), "2 years ago"}, |
||
| 121 | {bigSubTime(21, 0, 1), "21 years ago"}, |
||
| 122 | {bigSubTime(31, 0, 1), "31 years ago"}, |
||
| 123 | {bigSubTime(100, 0, 1), "100 years ago"}, |
||
| 124 | } |
||
| 125 | |||
| 126 | for _, tc := range cases { |
||
| 127 | t.Run("result for "+tc.date, func(test *testing.T) { |
||
| 128 | |||
| 129 | SetConfig(Config{ |
||
| 130 | Language: "en", |
||
| 131 | }) |
||
| 132 | |||
| 172 |