|
7 | 7 | "time" |
8 | 8 |
|
9 | 9 | "github.com/antonmedv/expr" |
| 10 | + "github.com/antonmedv/expr/builtin" |
10 | 11 | "github.com/antonmedv/expr/checker" |
11 | 12 | "github.com/antonmedv/expr/conf" |
12 | 13 | "github.com/antonmedv/expr/parser" |
@@ -218,3 +219,73 @@ func TestBuiltin_disallow_builtins_override(t *testing.T) { |
218 | 219 | }) |
219 | 220 | }) |
220 | 221 | } |
| 222 | + |
| 223 | +func TestBuiltin_DisableBuiltin(t *testing.T) { |
| 224 | + t.Run("via env", func(t *testing.T) { |
| 225 | + for _, name := range builtin.Names { |
| 226 | + t.Run(name, func(t *testing.T) { |
| 227 | + env := map[string]interface{}{ |
| 228 | + name: func() int { return 42 }, |
| 229 | + } |
| 230 | + program, err := expr.Compile(name+"()", expr.Env(env), expr.DisableBuiltin(name)) |
| 231 | + require.NoError(t, err) |
| 232 | + |
| 233 | + out, err := expr.Run(program, env) |
| 234 | + require.NoError(t, err) |
| 235 | + assert.Equal(t, 42, out) |
| 236 | + }) |
| 237 | + } |
| 238 | + }) |
| 239 | + t.Run("via expr.Function", func(t *testing.T) { |
| 240 | + for _, name := range builtin.Names { |
| 241 | + t.Run(name, func(t *testing.T) { |
| 242 | + fn := expr.Function(name, |
| 243 | + func(params ...interface{}) (interface{}, error) { |
| 244 | + return 42, nil |
| 245 | + }, |
| 246 | + new(func() int), |
| 247 | + ) |
| 248 | + program, err := expr.Compile(name+"()", fn, expr.DisableBuiltin(name)) |
| 249 | + require.NoError(t, err) |
| 250 | + |
| 251 | + out, err := expr.Run(program, nil) |
| 252 | + require.NoError(t, err) |
| 253 | + assert.Equal(t, 42, out) |
| 254 | + }) |
| 255 | + } |
| 256 | + }) |
| 257 | +} |
| 258 | + |
| 259 | +func TestBuiltin_DisableAllBuiltins(t *testing.T) { |
| 260 | + _, err := expr.Compile(`len("foo")`, expr.Env(nil), expr.DisableAllBuiltins()) |
| 261 | + require.Error(t, err) |
| 262 | + assert.Contains(t, err.Error(), "unknown name len") |
| 263 | +} |
| 264 | + |
| 265 | +func TestBuiltin_EnableBuiltin(t *testing.T) { |
| 266 | + t.Run("via env", func(t *testing.T) { |
| 267 | + env := map[string]interface{}{ |
| 268 | + "repeat": func() string { return "repeat" }, |
| 269 | + } |
| 270 | + program, err := expr.Compile(`len(repeat())`, expr.Env(env), expr.DisableAllBuiltins(), expr.EnableBuiltin("len")) |
| 271 | + require.NoError(t, err) |
| 272 | + |
| 273 | + out, err := expr.Run(program, env) |
| 274 | + require.NoError(t, err) |
| 275 | + assert.Equal(t, 6, out) |
| 276 | + }) |
| 277 | + t.Run("via expr.Function", func(t *testing.T) { |
| 278 | + fn := expr.Function("repeat", |
| 279 | + func(params ...interface{}) (interface{}, error) { |
| 280 | + return "repeat", nil |
| 281 | + }, |
| 282 | + new(func() string), |
| 283 | + ) |
| 284 | + program, err := expr.Compile(`len(repeat())`, fn, expr.DisableAllBuiltins(), expr.EnableBuiltin("len")) |
| 285 | + require.NoError(t, err) |
| 286 | + |
| 287 | + out, err := expr.Run(program, nil) |
| 288 | + require.NoError(t, err) |
| 289 | + assert.Equal(t, 6, out) |
| 290 | + }) |
| 291 | +} |
0 commit comments