|
12 | 12 | // limitations under the License. |
13 | 13 | // ---------------------------------------------------------------------------------- |
14 | 14 |
|
| 15 | +using System; |
15 | 16 | using System.IO.Abstractions; |
16 | 17 | using AzDev.Models.Inventory; |
17 | 18 |
|
18 | 19 | namespace AzDev.Services |
19 | 20 | { |
20 | 21 | internal class DefaultCodebaseProvider : ICodebaseProvider |
21 | 22 | { |
22 | | - private IContextProvider _contextProvider; |
23 | | - private IFileSystem _fs; |
| 23 | + private ILogger _logger = new NoopLogger(); |
| 24 | + private readonly IContextProvider _contextProvider; |
| 25 | + private readonly IFileSystem _fs; |
24 | 26 | private Codebase _codebase; |
25 | 27 |
|
26 | 28 | public DefaultCodebaseProvider(IContextProvider contextProvider) |
27 | 29 | : this(contextProvider, new FileSystem()) { } |
28 | 30 |
|
29 | 31 | public DefaultCodebaseProvider(IContextProvider contextProvider, IFileSystem fs) |
30 | 32 | { |
31 | | - _contextProvider = contextProvider; |
| 33 | + _contextProvider = contextProvider ?? throw new ArgumentNullException(nameof(contextProvider)); |
32 | 34 | _fs = fs; |
33 | 35 | } |
34 | 36 |
|
| 37 | + public void SetLogger(ILogger logger) |
| 38 | + { |
| 39 | + _logger = logger ?? throw new ArgumentNullException(nameof(logger)); |
| 40 | + } |
| 41 | + |
35 | 42 | public Codebase GetCodebase() |
36 | 43 | { |
| 44 | + _logger.Verbose("Loading codebase information"); |
| 45 | + |
37 | 46 | if (_codebase == null) |
38 | 47 | { |
39 | 48 | var path = _contextProvider.LoadContext().AzurePowerShellRepositoryRoot; |
| 49 | + _logger.Verbose($"Codebase path: {path}"); |
40 | 50 | var src = _fs.Path.Combine(path, FileOrDirNames.Src); |
41 | | - _codebase = _codebase ?? Codebase.FromFileSystem(_fs, src); |
| 51 | + _codebase = _codebase ?? Codebase.FromFileSystem(_fs, _logger, src); |
42 | 52 | } |
| 53 | + |
| 54 | + _logger.Verbose("Codebase loaded successfully"); |
| 55 | + |
43 | 56 | return _codebase; |
44 | 57 | } |
45 | 58 | } |
|
0 commit comments