Comments (4)
I agree on the consequences but without dateFormat
static field users would have to set the date format each time they call assertThat(), with static fields dateFormat
can be set only once.
Do you think of a solution that would both simple for users and parallel safe ?
from assertj.
I think it is possible to use ThreadLocal
to avoid sharing instances between threads. That way it would be possible to set required format in @Before
/@BeforeMethod
-annotated methods for the current thread.
p.s. also I think it's worth mentioning in JavaDoc that with default format current timezone is used i.e. of the machine where tests are executed. This can cause problems.
from assertj.
I would say keeping any state between two assertions is a premature optimization.
I understand the problem to be solved was to replace:
assertThat(date).withFormat(dateFormat).isAfter(dateAsString)
assertThat(date).withFormat(dateFormat).isAfter(dateAsString)
assertThat(date).withFormat(dateFormat).isAfter(dateAsString)
with
DateAssert.setDateFormat(dateFormat);
assertThat(date).isAfter(dateAsString)
assertThat(date).isAfter(dateAsString)
assertThat(date).isAfter(dateAsString)
but user could really easily do it with wrapping the assertThat(date).withFormat(dateFormat) in some private method.
I will try to make it ThreadLocal, though, but I would vote for changing it to assertion instance, starting with marking methods as deprecated
from assertj.
I'm thinking that it might be better to take another approach similar to the way we deal with date default formats.
Instead of replacing the custom date format, we could just add it to a list of custom date formats, this should fix the problem described if code accessing custom date formats list is properly synchronized or if we use a concurrent collection (CopyOnWriteArrayList ?)
from assertj.
Related Issues (20)
- support for isImmutable() HOT 2
- `isUnmodifiable` assertion for `Iterator` instances HOT 3
- Standardize ShouldBeEqual and remove AssertionErrorFactory
- Failed containsOnlyNulls Assertion for Null-Extracted List Elements HOT 4
- Missing consistent order of Javadoc tags
- Merge assertj-core-java17 into assertj-core HOT 3
- Generating Javadoc in a Maven project using <detectLinks> does not work HOT 5
- Navigation to `assertj-core` or `guava` types from `assertj-guava` Javadoc site has unnecessary header
- `satisfiesOnlyOnce` stack trace does not point to failed nested assertion HOT 3
- Evaluate `DateTimeFormatter` as replacement of `SimpleDateFormat` for internal usage
- Support for Duration in Assertions.byLessThan, Assertions.within HOT 2
- Add an unwrap method to the API to get actual value HOT 3
- Unable to construct iterable assertions across a specific type easily HOT 7
- Ambiguous `assertThat` for `Temporal` instance implementing `Comparable` HOT 3
- 3.26 - Ambiguous assertThat with Temporal implementation HOT 1
- Extra variant for doesNotMatch
- Add an annotation Class navigation method
- Recursive Comparison With Ignored Fields Fails On Equal Collections HOT 4
- hasFieldOrPropertyWithValue accepting arrays
- reference to assertThat is ambiguous when asserting a `java.time.Year` HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from assertj.