All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
1.9.0 - 2019-01-22
- Add the ability to shutdown Fx applications from inside the container. See the Shutdowner documentation for details.
- Add
fx.Annotatedto allow users to provide named values without creating a new constructor.
1.8.0 - 2018-11-06
- Provide DOT graph of dependencies in the container.
1.7.1 - 2018-09-26
- Make
fxtest.Newensure that the app was created successfully. Previously, it would return the app (similar tofx.New, which expects the user to verify the error). - Update dig container to defer acyclic validation until after Invoke. Application startup time should improve proportional to the size of the dependency graph.
- Fix a goroutine leak in
fxtest.Lifecycle.
1.7.0 - 2018-08-16
- Add
fx.ErrorHookoption to allow users to provideErrorHandlers on invoke failures. VisualizeErrorreturns the visualization wrapped in the error if available.
1.6.0 - 2018-06-12
- Add
fx.Erroroption to short-circuit application startup.
1.5.0 - 2018-04-11
- Add
fx.StartTimeoutandfx.StopTimeoutto make configuring application start and stop timeouts easier. - Export the default start and stop timeout as
fx.DefaultTimeout.
- Make
fxtestrespect the application's start and stop timeouts.
1.4.0 - 2017-12-07
- Add
fx.Populateto populate variables with values from the dependency injection container without requiring intermediate structs.
1.3.0 - 2017-11-28
- Improve readability of hook logging in addition to provide and invoke.
- Fix bug which caused the OnStop for a lifecycle hook to be called even if it failed to start.
1.2.0 - 2017-09-06
- Add
fx.NopLoggerwhich disables the Fx application's log output.
1.1.0 - 2017-08-22
- Improve readability of start up logging.
1.0.0 - 2017-07-31
First stable release: no breaking changes will be made in the 1.x series.
fx.Extractnow supportsfx.Intags on target structs.
- [Breaking] Rename
fx.Injecttofx.Extract. - [Breaking] Rename
fxtest.Must*tofxtest.Require*.
- [Breaking] Remove
fx.Timeoutandfx.DefaultTimeout.
1.0.0-rc2 - 2017-07-21
- [Breaking] Lifecycle hooks now take a context.
- Add
fx.Inandfx.Outwhich exposes optional and named types. Modules should embed these types instead of relying ondig.Inanddig.Out. - Add an
Errmethod to retrieve the underlying errors during the dependency graph construction. The same error is also returned fromStart. - Graph resolution now happens as part of
fx.New, rather than at the beginning ofapp.Start. This allows inspection of the graph errors throughapp.Err()before the decision to start the app. - Add a
Loggeroption, which allows users to send Fx's logs to different sink. - Add
fxtest.App, which redirects log output to the user'stesting.TBand provides some lifecycle helpers.
1.0.0-rc1 - 2017-06-20
- [Breaking] Providing types into
fx.Appand invoking functions are now options passed during application construction. This makes users' interactions with modules and collections of modules identical. - [Breaking]
TestLifecycleis now in a separatefxtestsubpackage. - Add
fx.Inject()to pull values from the container into a struct.
1.0.0-beta4 - 2017-06-12
- [Breaking] Monolithic framework, as released in initial betas, has been
broken into smaller pieces as a result of recent advances in
diglibrary. This is a radical departure from the previous direction, but it needed to be done for the long-term good of the project. - [Breaking]
Module interfacehas been scoped all the way down to being a single dig constructor. This allows for very sophisticated module compositions. Seego.uber.org/digfor more information on the constructors. - [Breaking]
package confighas been moved to its own repository. seego.uber.org/configfor more information. fx.Lifecyclehas been added for modules to hook into the framework lifecycle events.service.Hostinterface which composed a number of primitives together (configuration, metrics, tracing) has been deprecated in favor offx.App.
1.0.0-beta3 - 2017-03-28
- [Breaking] Environment config provider was removed. If you were using environment variables to override YAML values, see config documentation for more information.
- [Breaking] Simplify Provider interface: remove
Scopemethod from theconfig.Providerinterface, one can use either ScopedProvider and Value.Get() to access sub fields. - Add
task.MustRegisterconvenience function which fails fast by panicking Note that this should only be used during app initialization, and is provided to avoid repetetive error checking for services which register many tasks. - Expose options on task module to disable execution. This will allow users to enqueue and consume tasks on different clusters.
- [Breaking] Rename Backend interface
PublishtoEnqueue. Created a newExecuteAsyncmethod that will kick off workers to consume tasks and this is subsumed by module Start. - [Breaking] Rename package
uhttp/clienttouhttp/uhttpclientfor clarity. - [Breaking] Rename
PopulateStructmethod in value toPopulate. The method can now populate not only structs, but anything: slices, maps, builtin types and maps. - [Breaking]
package dighas moved fromgo.uber.org/fx/digto a new home atgo.uber.org/dig. - [Breaking] Pass a tracer the
uhttp/uhttpclientconstructor explicitly, instead of using a global tracer. This will allow to use http client in parallel tests.
1.0.0-beta2 - 2017-03-09
- [Breaking] Remove
ulog.Loggerinterface and expose*zap.Loggerdirectly. - [Breaking] Rename config and module from
modules.rpctomodules.yarpc - [Breaking] Rename config key from
modules.httptomodules.uhttpto match the module name - [Breaking] Upgrade
zaptov1.0.0-rc.3(now go.uber.org/zap, was github.com/uber-go/zap) - Remove now-unused
config.IsDevelopmentEnv()helper to encourage better testing practices. Not a breaking change as nobody is using this func themselves according to our code search tool. - Log
traceIDandspanIDin hex format to match Jaeger UI. Upgrade Jaeger to min version 2.1.0 and use jaeger's adapters for jaeger and tally initialization. - Tally now supports reporting histogram samples for a bucket. Upgrade Tally to 2.1.0
- [Breaking] Make new module naming consistent
yarpc.ThriftModuletoyarpc.New,task.NewModuletotask.New - [Breaking] Rename
yarpc.CreateThriftServiceFunctoyarpc.ServiceCreateFuncas it is not thrift-specific. - Report version metrics for company-wide version usage information.
- Allow configurable service name and module name via service options.
- DIG constructors now support returning a tuple with the second argument being an error.
This is the first beta release of the framework, where we invite users to start building services on it and provide us feedback. Warning we are not promising API compatibility between beta releases and the final 1.0.0 release. In fact, we expect our beta user feedback to require some changes to the way things work. Once we reach 1.0, we will provider proper version compatibility.