Comments (2)
This bug is triggered when TLC is run with -generateSpecTE
or -dumpTrace
options (the former is the default). It attempts to serialize a counterexample that includes states where some variables are undefined (null). It is straightforward (see below) to make -generateSpecTE
, -dumpTrace
, and similar options as no-ops if the counterexample contains non-good states. However, I assume that some users (particularly tools) of -dumpTrace json
would prefer that TLC makes a best effort to serialize even non-good counterexamples. Thoughts?
diff --git a/tlatools/org.lamport.tlatools/src/tlc2/tool/ModelChecker.java b/tlatools/org.lamport.tlatools/src/tlc2/tool/ModelChecker.java
index 31720755f..e454ba019 100644
--- a/tlatools/org.lamport.tlatools/src/tlc2/tool/ModelChecker.java
+++ b/tlatools/org.lamport.tlatools/src/tlc2/tool/ModelChecker.java
@@ -150,7 +150,7 @@ public class ModelChecker extends AbstractChecker
if (result != EC.NO_ERROR)
{
report("exiting, because init failed");
- if (this.errState != null) {
+ if (this.errState != null && tool.isGoodState(this.errState)) {
tool.checkPostConditionWithCounterExample(new CounterExample(errState));
} else {
tool.checkPostCondition();
(Similar check would have to be added for counterexamples with length > 1)
from tlaplus.
Related Issues (20)
- Proposed refactoring goal: remove all static global variables HOT 4
- Incorrect operator precedences in either documentation or SANY HOT 1
- SANY handles operator precedence incorrectly with the negative prefix operator
- SANY should exit with nonzero error code when parsing invalid PlusCal code and `-error-codes` is given
- Feature proposal: parallelize tlatools unit tests HOT 11
- `test-verify` and `test-dist-long` Ant targets both fail HOT 2
- `pcal.trans` outputs blank lines in translation if block comments are present in PlusCal source HOT 1
- Counterexample too short with StateDeque HOT 3
- Build failure on Windows: package jdk.jfr does not exist HOT 1
- Add pointer to https://arxiv.org/abs/2311.14452 in OpenAddressing.tla
- Crash when accessing Preferences -> General -> Web Browser with version 1.8.0 HOT 2
- Add LOC counting to SANY HOT 2
- Unify version of Java targeted by the tools HOT 13
- Is TLA+ the right tool for protocol parsing? HOT 2
- tla2tex.TeX: overly restrictive \begin{document} requirement & \input support HOT 3
- Font size and gui scale for tla toolbox
- Crash when opening "Web Browser" preferences menu HOT 4
- Unicode operators break PlusCal HOT 1
- Unable to fully select error message
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 tlaplus.