2017-01-13 00:08:29 +00:00
|
|
|
// Copyright 2016 Mozilla
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License"); you may not use
|
|
|
|
// this file except in compliance with the License. You may obtain a copy of the
|
|
|
|
// License at http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
// Unless required by applicable law or agreed to in writing, software distributed
|
|
|
|
// under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
|
|
|
|
// CONDITIONS OF ANY KIND, either express or implied. See the License for the
|
|
|
|
// specific language governing permissions and limitations under the License.
|
|
|
|
|
|
|
|
extern crate edn;
|
|
|
|
extern crate combine;
|
|
|
|
extern crate mentat_tx;
|
|
|
|
extern crate mentat_tx_parser;
|
|
|
|
|
|
|
|
use edn::parse;
|
|
|
|
use edn::symbols::NamespacedKeyword;
|
|
|
|
use edn::types::Value;
|
2017-02-15 00:50:40 +00:00
|
|
|
use mentat_tx::entities::{Entid, EntidOrLookupRefOrTempId, Entity, OpType};
|
2017-01-13 00:08:29 +00:00
|
|
|
use mentat_tx_parser::Tx;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_entities() {
|
2017-02-15 00:50:40 +00:00
|
|
|
let input = r#"
|
|
|
|
[[:db/add 101 :test/a "v"]
|
|
|
|
[:db/add "tempid" :test/a "v"]
|
|
|
|
[:db/retract 102 :test/b "w"]]"#;
|
2017-01-13 00:08:29 +00:00
|
|
|
|
2017-02-14 15:43:32 +00:00
|
|
|
let edn = parse::value(input).unwrap().without_spans();
|
2017-01-13 00:08:29 +00:00
|
|
|
let input = [edn];
|
|
|
|
|
|
|
|
let result = Tx::parse(&input[..]);
|
Extract partial storage abstraction; use error-chain throughout. Fixes #328. r=rnewman (#341)
* Pre: Drop unneeded tx0 from search results.
* Pre: Don't require a schema in some of the DB code.
The idea is to separate the transaction applying code, which is
schema-aware, from the concrete storage code, which is just concerned
with getting bits onto disk.
* Pre: Only reference Schema, not DB, in debug module.
This is part of a larger separation of the volatile PartitionMap,
which is modified every transaction, from the stable Schema, which is
infrequently modified.
* Pre: Fix indentation.
* Extract part of DB to new SchemaTypeChecking trait.
* Extract part of DB to new PartitionMapping trait.
* Pre: Don't expect :db.part/tx partition to advance when tx fails.
This fails right now, because we allocate tx IDs even when we shouldn't.
* Sketch a db interface without DB.
* Add ValueParseError; use error-chain in tx-parser.
This can be simplified when
https://github.com/Marwes/combine/issues/86 makes it to a published
release, but this unblocks us for now. This converts the `combine`
error type `ParseError<&'a [edn::Value]>` to a type with owned
`Vec<edn::Value>` collections, re-using `edn::Value::Vector` for
making them `Display`.
* Pre: Accept Borrow<Schema> instead of just &Schema in debug module.
This makes it easy to use Rc<Schema> or Arc<Schema> without inserting
&* sigils throughout the code.
* Use error-chain in query-parser.
There are a few things to point out here:
- the fine grained error types have been flattened into one crate-wide
error type; it's pretty easy to regain the granularity as needed.
- edn::ParseError is automatically lifted to
mentat_query_parser::errors::Error;
- we use mentat_parser_utils::ValueParser to maintain parsing error
information from `combine`.
* Patch up top-level.
* Review comment: Only `borrow()` once.
2017-02-24 23:32:41 +00:00
|
|
|
assert_eq!(result.unwrap(),
|
|
|
|
vec![
|
2017-02-08 23:45:09 +00:00
|
|
|
Entity::AddOrRetract {
|
2017-02-15 00:50:40 +00:00
|
|
|
op: OpType::Add,
|
|
|
|
e: EntidOrLookupRefOrTempId::Entid(Entid::Entid(101)),
|
2017-01-13 00:08:29 +00:00
|
|
|
a: Entid::Ident(NamespacedKeyword::new("test", "a")),
|
2017-02-15 00:50:40 +00:00
|
|
|
v: Value::Text("v".into()),
|
|
|
|
},
|
|
|
|
Entity::AddOrRetract {
|
2017-02-08 23:45:09 +00:00
|
|
|
op: OpType::Add,
|
2017-02-15 00:50:40 +00:00
|
|
|
e: EntidOrLookupRefOrTempId::TempId("tempid".into()),
|
|
|
|
a: Entid::Ident(NamespacedKeyword::new("test", "a")),
|
|
|
|
v: Value::Text("v".into()),
|
2017-01-13 00:08:29 +00:00
|
|
|
},
|
2017-02-08 23:45:09 +00:00
|
|
|
Entity::AddOrRetract {
|
|
|
|
op: OpType::Retract,
|
2017-02-15 00:50:40 +00:00
|
|
|
e: EntidOrLookupRefOrTempId::Entid(Entid::Entid(102)),
|
|
|
|
a: Entid::Ident(NamespacedKeyword::new("test", "b")),
|
|
|
|
v: Value::Text("w".into()),
|
2017-01-13 00:08:29 +00:00
|
|
|
},
|
Extract partial storage abstraction; use error-chain throughout. Fixes #328. r=rnewman (#341)
* Pre: Drop unneeded tx0 from search results.
* Pre: Don't require a schema in some of the DB code.
The idea is to separate the transaction applying code, which is
schema-aware, from the concrete storage code, which is just concerned
with getting bits onto disk.
* Pre: Only reference Schema, not DB, in debug module.
This is part of a larger separation of the volatile PartitionMap,
which is modified every transaction, from the stable Schema, which is
infrequently modified.
* Pre: Fix indentation.
* Extract part of DB to new SchemaTypeChecking trait.
* Extract part of DB to new PartitionMapping trait.
* Pre: Don't expect :db.part/tx partition to advance when tx fails.
This fails right now, because we allocate tx IDs even when we shouldn't.
* Sketch a db interface without DB.
* Add ValueParseError; use error-chain in tx-parser.
This can be simplified when
https://github.com/Marwes/combine/issues/86 makes it to a published
release, but this unblocks us for now. This converts the `combine`
error type `ParseError<&'a [edn::Value]>` to a type with owned
`Vec<edn::Value>` collections, re-using `edn::Value::Vector` for
making them `Display`.
* Pre: Accept Borrow<Schema> instead of just &Schema in debug module.
This makes it easy to use Rc<Schema> or Arc<Schema> without inserting
&* sigils throughout the code.
* Use error-chain in query-parser.
There are a few things to point out here:
- the fine grained error types have been flattened into one crate-wide
error type; it's pretty easy to regain the granularity as needed.
- edn::ParseError is automatically lifted to
mentat_query_parser::errors::Error;
- we use mentat_parser_utils::ValueParser to maintain parsing error
information from `combine`.
* Patch up top-level.
* Review comment: Only `borrow()` once.
2017-02-24 23:32:41 +00:00
|
|
|
]);
|
2017-01-13 00:08:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: test error handling in select cases.
|