@aj-archipelago/cortex 1.0.5 → 1.0.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/config/default.example.json +4 -2
- package/config.js +14 -8
- package/helper_apps/WhisperX/.dockerignore +27 -0
- package/helper_apps/WhisperX/Dockerfile +31 -0
- package/helper_apps/WhisperX/app-ts.py +76 -0
- package/helper_apps/WhisperX/app.py +115 -0
- package/helper_apps/WhisperX/docker-compose.debug.yml +12 -0
- package/helper_apps/WhisperX/docker-compose.yml +10 -0
- package/helper_apps/WhisperX/requirements.txt +6 -0
- package/index.js +1 -1
- package/lib/redisSubscription.js +1 -1
- package/package.json +8 -7
- package/pathways/basePathway.js +3 -2
- package/pathways/index.js +4 -0
- package/pathways/summary.js +2 -2
- package/pathways/sys_openai_chat.js +19 -0
- package/pathways/sys_openai_completion.js +11 -0
- package/pathways/test_palm_chat.js +1 -1
- package/pathways/transcribe.js +2 -1
- package/{graphql → server}/chunker.js +48 -3
- package/{graphql → server}/graphql.js +70 -62
- package/{graphql → server}/pathwayPrompter.js +14 -17
- package/{graphql → server}/pathwayResolver.js +59 -42
- package/{graphql → server}/plugins/azureTranslatePlugin.js +2 -2
- package/{graphql → server}/plugins/localModelPlugin.js +2 -2
- package/{graphql → server}/plugins/modelPlugin.js +8 -10
- package/{graphql → server}/plugins/openAiChatPlugin.js +13 -8
- package/{graphql → server}/plugins/openAiCompletionPlugin.js +9 -3
- package/{graphql → server}/plugins/openAiWhisperPlugin.js +30 -7
- package/{graphql → server}/plugins/palmChatPlugin.js +4 -6
- package/server/plugins/palmCodeCompletionPlugin.js +46 -0
- package/{graphql → server}/plugins/palmCompletionPlugin.js +13 -15
- package/server/rest.js +321 -0
- package/{graphql → server}/typeDef.js +30 -13
- package/tests/chunkfunction.test.js +112 -26
- package/tests/config.test.js +1 -1
- package/tests/main.test.js +282 -43
- package/tests/mocks.js +43 -2
- package/tests/modelPlugin.test.js +4 -4
- package/tests/openAiChatPlugin.test.js +21 -14
- package/tests/openai_api.test.js +147 -0
- package/tests/palmChatPlugin.test.js +10 -11
- package/tests/palmCompletionPlugin.test.js +3 -4
- package/tests/pathwayResolver.test.js +1 -1
- package/tests/truncateMessages.test.js +4 -5
- package/pathways/completions.js +0 -17
- package/pathways/test_oai_chat.js +0 -18
- package/pathways/test_oai_cmpl.js +0 -13
- package/tests/chunking.test.js +0 -157
- package/tests/translate.test.js +0 -126
- /package/{graphql → server}/parser.js +0 -0
- /package/{graphql → server}/pathwayResponseParser.js +0 -0
- /package/{graphql → server}/prompt.js +0 -0
- /package/{graphql → server}/pubsub.js +0 -0
- /package/{graphql → server}/requestState.js +0 -0
- /package/{graphql → server}/resolver.js +0 -0
- /package/{graphql → server}/subscriptions.js +0 -0
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
// openai_api.test.js
|
|
2
|
+
|
|
3
|
+
import test from 'ava';
|
|
4
|
+
import got from 'got';
|
|
5
|
+
import axios from 'axios';
|
|
6
|
+
import serverFactory from '../index.js';
|
|
7
|
+
|
|
8
|
+
const API_BASE = 'http://localhost:4000/v1';
|
|
9
|
+
|
|
10
|
+
let testServer;
|
|
11
|
+
|
|
12
|
+
test.before(async () => {
|
|
13
|
+
process.env.CORTEX_ENABLE_REST = 'true';
|
|
14
|
+
const { server, startServer } = await serverFactory();
|
|
15
|
+
startServer && await startServer();
|
|
16
|
+
testServer = server;
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
test.after.always('cleanup', async () => {
|
|
20
|
+
if (testServer) {
|
|
21
|
+
await testServer.stop();
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
test('GET /models', async (t) => {
|
|
26
|
+
const response = await got(`${API_BASE}/models`, { responseType: 'json' });
|
|
27
|
+
t.is(response.statusCode, 200);
|
|
28
|
+
t.is(response.body.object, 'list');
|
|
29
|
+
t.true(Array.isArray(response.body.data));
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
test('POST /completions', async (t) => {
|
|
33
|
+
const response = await got.post(`${API_BASE}/completions`, {
|
|
34
|
+
json: {
|
|
35
|
+
model: 'gpt-3.5-turbo',
|
|
36
|
+
prompt: 'Word to your motha!',
|
|
37
|
+
stream: false,
|
|
38
|
+
},
|
|
39
|
+
responseType: 'json',
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
t.is(response.statusCode, 200);
|
|
43
|
+
t.is(response.body.object, 'text_completion');
|
|
44
|
+
t.true(Array.isArray(response.body.choices));
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
test('POST /chat/completions', async (t) => {
|
|
49
|
+
const response = await got.post(`${API_BASE}/chat/completions`, {
|
|
50
|
+
json: {
|
|
51
|
+
model: 'gpt-3.5-turbo',
|
|
52
|
+
messages: [{ role: 'user', content: 'Hello!' }],
|
|
53
|
+
stream: false,
|
|
54
|
+
},
|
|
55
|
+
responseType: 'json',
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
t.is(response.statusCode, 200);
|
|
59
|
+
t.is(response.body.object, 'chat.completion');
|
|
60
|
+
t.true(Array.isArray(response.body.choices));
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
async function connectToSSEEndpoint(url, endpoint, payload, t, customAssertions) {
|
|
64
|
+
return new Promise(async (resolve, reject) => {
|
|
65
|
+
try {
|
|
66
|
+
const instance = axios.create({
|
|
67
|
+
baseURL: url,
|
|
68
|
+
responseType: 'stream',
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
const response = await instance.post(endpoint, payload);
|
|
72
|
+
const responseData = response.data;
|
|
73
|
+
|
|
74
|
+
const incomingMessage = Array.isArray(responseData) && responseData.length > 0 ? responseData[0] : responseData;
|
|
75
|
+
|
|
76
|
+
let eventCount = 0;
|
|
77
|
+
|
|
78
|
+
incomingMessage.on('data', data => {
|
|
79
|
+
const events = data.toString().split('\n');
|
|
80
|
+
|
|
81
|
+
events.forEach(event => {
|
|
82
|
+
eventCount++;
|
|
83
|
+
|
|
84
|
+
if (event.trim() === '') return;
|
|
85
|
+
|
|
86
|
+
if (event.trim() === 'data: [DONE]') {
|
|
87
|
+
t.truthy(eventCount > 1);
|
|
88
|
+
resolve();
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
const message = event.replace(/^data: /, '');
|
|
93
|
+
const messageJson = JSON.parse(message);
|
|
94
|
+
|
|
95
|
+
customAssertions(t, messageJson);
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
} catch (error) {
|
|
100
|
+
console.error('Error connecting to SSE endpoint:', error);
|
|
101
|
+
reject(error);
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
test('POST SSE: /v1/completions should send a series of events and a [DONE] event', async (t) => {
|
|
107
|
+
const payload = {
|
|
108
|
+
model: 'gpt-3.5-turbo',
|
|
109
|
+
prompt: 'Word to your motha!',
|
|
110
|
+
stream: true,
|
|
111
|
+
};
|
|
112
|
+
|
|
113
|
+
const url = 'http://localhost:4000/v1';
|
|
114
|
+
|
|
115
|
+
const completionsAssertions = (t, messageJson) => {
|
|
116
|
+
t.truthy(messageJson.id);
|
|
117
|
+
t.is(messageJson.object, 'text_completion');
|
|
118
|
+
t.truthy(messageJson.choices[0].finish_reason === null || messageJson.choices[0].finish_reason === 'stop');
|
|
119
|
+
};
|
|
120
|
+
|
|
121
|
+
await connectToSSEEndpoint(url, '/completions', payload, t, completionsAssertions);
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
test('POST SSE: /v1/chat/completions should send a series of events and a [DONE] event', async (t) => {
|
|
125
|
+
const payload = {
|
|
126
|
+
model: 'gpt-3.5-turbo',
|
|
127
|
+
messages: [
|
|
128
|
+
{
|
|
129
|
+
role: 'user',
|
|
130
|
+
content: 'Hello!',
|
|
131
|
+
},
|
|
132
|
+
],
|
|
133
|
+
stream: true,
|
|
134
|
+
};
|
|
135
|
+
|
|
136
|
+
const url = 'http://localhost:4000/v1';
|
|
137
|
+
|
|
138
|
+
const chatCompletionsAssertions = (t, messageJson) => {
|
|
139
|
+
t.truthy(messageJson.id);
|
|
140
|
+
t.is(messageJson.object, 'chat.completion.chunk');
|
|
141
|
+
t.truthy(messageJson.choices[0].delta);
|
|
142
|
+
t.truthy(messageJson.choices[0].finish_reason === null || messageJson.choices[0].finish_reason === 'stop');
|
|
143
|
+
};
|
|
144
|
+
|
|
145
|
+
await connectToSSEEndpoint(url, '/chat/completions', payload, t, chatCompletionsAssertions);
|
|
146
|
+
});
|
|
147
|
+
|
|
@@ -1,11 +1,10 @@
|
|
|
1
1
|
// test_palmChatPlugin.js
|
|
2
2
|
import test from 'ava';
|
|
3
|
-
import PalmChatPlugin from '../
|
|
4
|
-
import {
|
|
3
|
+
import PalmChatPlugin from '../server/plugins/palmChatPlugin.js';
|
|
4
|
+
import { mockPathwayResolverMessages } from './mocks.js';
|
|
5
5
|
|
|
6
6
|
test.beforeEach((t) => {
|
|
7
|
-
const
|
|
8
|
-
const palmChatPlugin = new PalmChatPlugin(mockConfig, pathway);
|
|
7
|
+
const palmChatPlugin = new PalmChatPlugin(mockPathwayResolverMessages);
|
|
9
8
|
t.context = { palmChatPlugin };
|
|
10
9
|
});
|
|
11
10
|
|
|
@@ -18,7 +17,7 @@ test('convertMessagesToPalm', (t) => {
|
|
|
18
17
|
];
|
|
19
18
|
|
|
20
19
|
const expectedResult = {
|
|
21
|
-
|
|
20
|
+
modifiedMessages: [
|
|
22
21
|
{ author: 'user', content: 'User Message\nUser Message 2' },
|
|
23
22
|
],
|
|
24
23
|
context: 'System Message',
|
|
@@ -35,7 +34,7 @@ test('convertMessagesToPalm - already PaLM format', (t) => {
|
|
|
35
34
|
];
|
|
36
35
|
|
|
37
36
|
const expectedResult = {
|
|
38
|
-
|
|
37
|
+
modifiedMessages: [
|
|
39
38
|
{ author: 'user', content: 'User Message\nUser Message 2' },
|
|
40
39
|
],
|
|
41
40
|
context: '',
|
|
@@ -52,7 +51,7 @@ test('convertMessagesToPalm - already PaLM format', (t) => {
|
|
|
52
51
|
];
|
|
53
52
|
|
|
54
53
|
const expectedResult = {
|
|
55
|
-
|
|
54
|
+
modifiedMessages: [
|
|
56
55
|
{ author: 'user', content: 'User Message' },
|
|
57
56
|
],
|
|
58
57
|
context: '',
|
|
@@ -70,7 +69,7 @@ test('convertMessagesToPalm - already PaLM format', (t) => {
|
|
|
70
69
|
];
|
|
71
70
|
|
|
72
71
|
const expectedResult = {
|
|
73
|
-
|
|
72
|
+
modifiedMessages: [
|
|
74
73
|
{ author: 'user', content: 'User Message' },
|
|
75
74
|
],
|
|
76
75
|
context: 'System Message 1\nSystem Message 2',
|
|
@@ -90,7 +89,7 @@ test('convertMessagesToPalm - already PaLM format', (t) => {
|
|
|
90
89
|
];
|
|
91
90
|
|
|
92
91
|
const expectedResult = {
|
|
93
|
-
|
|
92
|
+
modifiedMessages: [
|
|
94
93
|
{ author: 'user1', content: 'User1 Message\nUser1 Message 2' },
|
|
95
94
|
{ author: 'user2', content: 'User2 Message' },
|
|
96
95
|
{ author: 'assistant', content: 'Assistant Message' },
|
|
@@ -106,7 +105,7 @@ test('convertMessagesToPalm - already PaLM format', (t) => {
|
|
|
106
105
|
const messages = [];
|
|
107
106
|
|
|
108
107
|
const expectedResult = {
|
|
109
|
-
|
|
108
|
+
modifiedMessages: [],
|
|
110
109
|
context: '',
|
|
111
110
|
};
|
|
112
111
|
|
|
@@ -121,7 +120,7 @@ test('convertMessagesToPalm - already PaLM format', (t) => {
|
|
|
121
120
|
];
|
|
122
121
|
|
|
123
122
|
const expectedResult = {
|
|
124
|
-
|
|
123
|
+
modifiedMessages: [],
|
|
125
124
|
context: 'System Message 1\nSystem Message 2',
|
|
126
125
|
};
|
|
127
126
|
|
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
// palmCompletionPlugin.test.js
|
|
2
2
|
|
|
3
3
|
import test from 'ava';
|
|
4
|
-
import PalmCompletionPlugin from '../
|
|
5
|
-
import {
|
|
4
|
+
import PalmCompletionPlugin from '../server/plugins/palmCompletionPlugin.js';
|
|
5
|
+
import { mockPathwayResolverString } from './mocks.js';
|
|
6
6
|
|
|
7
7
|
test.beforeEach((t) => {
|
|
8
|
-
const
|
|
9
|
-
const palmCompletionPlugin = new PalmCompletionPlugin(mockConfig, pathway);
|
|
8
|
+
const palmCompletionPlugin = new PalmCompletionPlugin(mockPathwayResolverString);
|
|
10
9
|
t.context = { palmCompletionPlugin };
|
|
11
10
|
});
|
|
12
11
|
|
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
// ModelPlugin.test.js
|
|
2
2
|
import test from 'ava';
|
|
3
|
-
import ModelPlugin from '../
|
|
3
|
+
import ModelPlugin from '../server/plugins/modelPlugin.js';
|
|
4
4
|
import { encode } from 'gpt-3-encoder';
|
|
5
|
-
import {
|
|
5
|
+
import { mockPathwayResolverString } from './mocks.js';
|
|
6
6
|
|
|
7
|
-
const config =
|
|
8
|
-
const pathway = mockPathwayString;
|
|
7
|
+
const { config, pathway } = mockPathwayResolverString;
|
|
9
8
|
|
|
10
|
-
const modelPlugin = new ModelPlugin(
|
|
9
|
+
const modelPlugin = new ModelPlugin(mockPathwayResolverString);
|
|
11
10
|
|
|
12
11
|
const generateMessage = (role, content) => ({ role, content });
|
|
13
12
|
|
package/pathways/completions.js
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
//completions.js
|
|
2
|
-
|
|
3
|
-
import { Prompt } from '../graphql/prompt.js';
|
|
4
|
-
|
|
5
|
-
export default {
|
|
6
|
-
prompt:
|
|
7
|
-
[
|
|
8
|
-
new Prompt({ messages: [
|
|
9
|
-
"{{messages}}",
|
|
10
|
-
]}),
|
|
11
|
-
],
|
|
12
|
-
inputParameters: {
|
|
13
|
-
messages: [],
|
|
14
|
-
},
|
|
15
|
-
model: 'palm-chat',
|
|
16
|
-
useInputChunking: false,
|
|
17
|
-
}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
//test_oai_chat.js
|
|
2
|
-
|
|
3
|
-
import { Prompt } from '../graphql/prompt.js';
|
|
4
|
-
|
|
5
|
-
// Description: Have a chat with a bot that uses context to understand the conversation
|
|
6
|
-
export default {
|
|
7
|
-
prompt:
|
|
8
|
-
[
|
|
9
|
-
new Prompt({ messages: [
|
|
10
|
-
"{{messages}}",
|
|
11
|
-
]}),
|
|
12
|
-
],
|
|
13
|
-
inputParameters: {
|
|
14
|
-
messages: [],
|
|
15
|
-
},
|
|
16
|
-
model: 'azure-td3',
|
|
17
|
-
useInputChunking: false,
|
|
18
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
//test_oai_cmpl.js
|
|
2
|
-
|
|
3
|
-
import { Prompt } from '../graphql/prompt.js';
|
|
4
|
-
|
|
5
|
-
// Description: Have a chat with a bot that uses context to understand the conversation
|
|
6
|
-
export default {
|
|
7
|
-
prompt: `{{prompt}}`,
|
|
8
|
-
inputParameters: {
|
|
9
|
-
prompt: '',
|
|
10
|
-
},
|
|
11
|
-
model: 'azure-td3',
|
|
12
|
-
useInputChunking: false,
|
|
13
|
-
}
|
package/tests/chunking.test.js
DELETED
|
@@ -1,157 +0,0 @@
|
|
|
1
|
-
import test from 'ava';
|
|
2
|
-
import { getTestServer, initTypeDefsResolvers } from './main.test.js';
|
|
3
|
-
|
|
4
|
-
let testServer;
|
|
5
|
-
|
|
6
|
-
test.before(async () => {
|
|
7
|
-
await initTypeDefsResolvers();
|
|
8
|
-
testServer = getTestServer();
|
|
9
|
-
});
|
|
10
|
-
|
|
11
|
-
test.after.always(async () => {
|
|
12
|
-
await testServer.stop();
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
test('chunking test of translate endpoint with huge text', async t => {
|
|
16
|
-
t.timeout(400000);
|
|
17
|
-
const response = await testServer.executeOperation({
|
|
18
|
-
query: 'query translate($text: String!, $to: String) { translate(text: $text, to: $to) { result } }',
|
|
19
|
-
variables: {
|
|
20
|
-
to: 'en',
|
|
21
|
-
text: `Lorem ipsum dolor sit amet, consectetur adipiscing elit. In id erat sem. Phasellus ac dapibus purus, in fermentum nunc. Mauris quis rutrum magna. Quisque rutrum, augue vel blandit posuere, augue magna convallis turpis, nec elementum augue mauris sit amet nunc. Aenean sit amet leo est. Nunc ante ex, blandit et felis ut, iaculis lacinia est. Phasellus dictum orci id libero ullamcorper tempor.
|
|
22
|
-
|
|
23
|
-
Vivamus id pharetra odio.Sed consectetur leo sed tortor dictum venenatis.Donec gravida libero non accumsan suscipit.Donec lectus turpis, ullamcorper eu pulvinar iaculis, ornare ut risus.Phasellus aliquam, turpis quis viverra condimentum, risus est pretium metus, in porta ipsum tortor vitae elit.Pellentesque id finibus erat.In suscipit, sapien non posuere dignissim, augue nisl ultrices tortor, sit amet eleifend nibh elit at risus.
|
|
24
|
-
|
|
25
|
-
Donec diam ligula, sagittis ut nisl tincidunt, porta sodales magna.Vestibulum ut dui arcu.Fusce at dolor ex.Aliquam eu justo non libero volutpat pulvinar at id urna.Donec nec purus sed elit bibendum faucibus.Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas.Vivamus iaculis mattis velit, ut lacinia massa lacinia quis.Phasellus porttitor gravida ex, id aliquet eros rhoncus quis.Ut fringilla, lectus a vehicula luctus, diam odio convallis dolor, sodales pharetra nulla ex dictum justo.Ut faucibus, augue quis dictum iaculis, diam leo maximus sapien, sit amet vulputate eros quam sed sem.Cras malesuada, sapien sit amet iaculis euismod, nunc odio lacinia est, dictum iaculis ante nisi in est.Fusce vehicula lorem tellus.Nullam a tempus nisi.
|
|
26
|
-
|
|
27
|
-
Sed ut lectus nec ligula blandit tempus.Donec faucibus turpis id urna vehicula imperdiet.Duis tempor vitae orci interdum dignissim.Phasellus sed efficitur sem.Nullam accumsan, turpis vitae consectetur ullamcorper, lectus purus tincidunt nisi, in pulvinar leo tortor at sem.Donec at feugiat dui, nec rhoncus nibh.Nam faucibus ultrices nisl at lobortis.Morbi congue, nisl vel fermentum tristique, dui ipsum rhoncus massa, non varius nibh massa in turpis.Vestibulum vulputate, felis quis lacinia porta, nulla ex volutpat lorem, non rhoncus neque erat quis arcu.Morbi massa nisl, hendrerit eget tortor condimentum, lobortis dapibus sem.Aliquam ut dapibus elit.Sed porta dignissim ante.Nullam interdum ligula et massa vehicula, vel gravida diam laoreet.Vivamus et enim eget turpis pellentesque laoreet.Vivamus pellentesque neque et mauris imperdiet pulvinar.
|
|
28
|
-
|
|
29
|
-
Aliquam eget ligula congue, tincidunt magna eu, rutrum urna.Sed consequat orci est, vel laoreet magna tincidunt sit amet.Curabitur eget condimentum odio, vitae condimentum elit.Duis viverra lobortis magna.Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas.Sed facilisis mi eu scelerisque pharetra.Cras et massa odio.Praesent quis nulla vitae mi blandit egestas ac vitae libero.Cras ultricies ex non consequat scelerisque.Nulla et est ac sem placerat convallis ac vitae massa.Phasellus lobortis mauris vel est vehicula lobortis.Curabitur ipsum ipsum, ullamcorper eget placerat sit amet, dapibus iaculis dui.Phasellus facilisis rutrum metus nec euismod.
|
|
30
|
-
|
|
31
|
-
Nam viverra est ac orci rhoncus, mollis mattis mi lobortis.Maecenas lectus ex, pulvinar vel mauris vel, egestas ornare massa.Nam placerat, tellus vel ullamcorper ullamcorper, enim felis egestas tellus, eu dictum augue tortor vel libero.Integer vel nunc felis.Nulla vehicula et enim non luctus.Vestibulum non odio magna.Donec vitae ipsum et nisl vestibulum maximus eu at augue.Morbi ac tristique quam.Suspendisse vestibulum nec dui et consectetur.Aliquam a dapibus dolor, sit amet fringilla eros.Nam id lorem nulla.
|
|
32
|
-
|
|
33
|
-
Proin vulputate risus purus, id tincidunt magna eleifend vel.Pellentesque et commodo leo, sit amet molestie nunc.Nunc purus lectus, interdum ut mauris ac, varius pretium magna.Etiam sollicitudin eros at pretium molestie.Cras fermentum sagittis elit at egestas.Fusce auctor lacinia nisl ac ullamcorper.Interdum et malesuada fames ac ante ipsum primis in faucibus.Fusce commodo pretium urna vel consequat.In finibus tellus vitae magna pharetra, porttitor egestas libero cursus.Donec eget tincidunt dolor, ac tristique diam.Etiam interdum dictum ex suscipit tempus.In hac habitasse platea dictumst.Nulla ornare libero a leo mollis, sed gravida leo finibus.Nunc ornare, dolor ac convallis varius, quam ipsum ultricies dui, non vehicula est eros eget ipsum.Mauris vel rhoncus ligula, non porta metus.
|
|
34
|
-
|
|
35
|
-
Ut non felis pretium leo viverra tincidunt.Vivamus et ligula commodo dolor faucibus gravida.Quisque eu dolor ac metus pretium pharetra.Integer mattis efficitur libero, sed condimentum nulla ultricies eu.Donec turpis orci, fermentum vitae imperdiet nec, luctus quis lectus.Nunc viverra ornare libero.Vestibulum elementum tempus tortor id semper.
|
|
36
|
-
|
|
37
|
-
Aliquam in dapibus risus.Praesent vitae condimentum elit, sodales pellentesque diam.Curabitur luctus pellentesque nunc, ut eleifend urna dictum ac.Aenean rhoncus lacinia quam a suscipit.Proin purus metus, egestas a pretium eu, tempus ut ante.Sed tellus turpis, hendrerit consequat porta id, porttitor non dolor.Proin volutpat massa a dui dictum facilisis a vel eros.Fusce eu efficitur odio.Aliquam interdum metus id ex dapibus dapibus.Nullam porttitor non sapien nec rhoncus.Cras iaculis fringilla cursus.Praesent at leo orci.Sed eget vulputate eros, eget auctor sapien.Nulla auctor, lectus ut tincidunt rhoncus, ante lorem volutpat eros, ac tincidunt enim ipsum at ex.Fusce dolor arcu, pretium eget elementum vel, semper at ipsum.
|
|
38
|
-
|
|
39
|
-
Integer rhoncus fringilla felis ac tincidunt.Phasellus eu ultricies tellus.Sed pharetra, eros sed dignissim mattis, mi lectus blandit elit, vitae euismod ipsum sapien a eros.Aliquam lobortis tellus venenatis, sagittis lorem non, eleifend odio.Duis ultrices urna vel commodo varius.Sed ultricies mauris ut velit dignissim, eu lobortis ex tempor.Praesent vitae iaculis nisl.Vestibulum id convallis tellus.Vivamus eu consectetur erat.Curabitur interdum est non nibh malesuada ullamcorper.Phasellus mollis arcu a pharetra lacinia.Praesent sit amet sem non dui iaculis tincidunt.Aliquam vitae libero viverra metus feugiat volutpat ut eget sem.Nam facilisis pulvinar urna, ut venenatis ligula accumsan finibus.Maecenas nec aliquam nulla.Maecenas mattis magna erat.
|
|
40
|
-
|
|
41
|
-
Nunc a nulla sed ante sollicitudin ultrices a a ante.Sed feugiat scelerisque leo, eget venenatis orci cursus eget.Ut pretium leo et nunc sodales, in luctus erat faucibus.Interdum et malesuada fames ac ante ipsum primis in faucibus.Mauris facilisis lorem quis turpis commodo, id vulputate metus molestie.Fusce id neque vestibulum, pretium elit in, ultrices justo.Praesent turpis dui, ullamcorper in vulputate ut, posuere at sapien.Etiam laoreet ultrices felis, id venenatis purus.Sed nec mauris pharetra, rhoncus sem non, interdum justo.Nulla sed tincidunt nisi.Suspendisse luctus viverra volutpat.Duis arcu nulla, euismod eu scelerisque in, vulputate eget quam.
|
|
42
|
-
|
|
43
|
-
Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia curae; Fusce at dignissim quam.Suspendisse eget metus nec sem accumsan sagittis.Suspendisse non mollis lacus.Donec ac consectetur ante.Nullam luctus, nibh ac imperdiet porta, sem felis bibendum nibh, ut sollicitudin libero nulla a sapien.Sed tristique odio enim, eget tempor enim cursus vel.Morbi tristique lobortis tortor, nec placerat lorem suscipit ac.Nullam sed sodales diam, sed tincidunt est.Quisque semper velit sed risus dictum pretium.Proin condimentum, nisi a vulputate tristique, tellus erat scelerisque nisi, tincidunt viverra est neque non magna.Quisque nibh augue, interdum non justo et, varius rutrum erat.Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas.
|
|
44
|
-
|
|
45
|
-
Vestibulum et lorem auctor, vestibulum nisl id, elementum metus.Pellentesque quis mi a augue consectetur cursus.Morbi sodales risus et faucibus dictum.Ut in lobortis nisl, et euismod nisl.Donec ornare tellus placerat, blandit justo quis, pharetra nisl.Nulla scelerisque magna at nisi suscipit commodo.Fusce pellentesque in elit et consequat.Phasellus vehicula accumsan enim, vitae pellentesque nulla.Nullam id arcu vitae nunc consectetur mattis.Fusce ac sapien vel mi congue fringilla.Nulla mattis consectetur fringilla.Morbi orci elit, tempor in rhoncus eget, fringilla eget erat.
|
|
46
|
-
|
|
47
|
-
Phasellus nec lorem lectus.Donec in cursus elit.In dictum elementum odio a scelerisque.Phasellus ac sapien eget velit accumsan elementum.Mauris odio eros, vulputate eu aliquet a, bibendum in quam.Integer euismod libero ac massa imperdiet, ullamcorper cursus risus auctor.Nam rutrum erat eget tortor suscipit semper sit amet nec mauris.Pellentesque nec semper neque.Nunc fringilla nisl erat, a sollicitudin tortor accumsan finibus.
|
|
48
|
-
|
|
49
|
-
Integer vulputate ex dui, vitae scelerisque purus viverra vel.Cras ultricies purus in nibh dapibus, non hendrerit nulla aliquam.Fusce vitae gravida urna.Mauris eleifend rutrum ex, at fermentum enim fringilla quis.Suspendisse dignissim est eget tempus condimentum.Fusce scelerisque, felis et malesuada dictum, mauris dolor cursus ex, eget pulvinar sem nulla id diam.Ut volutpat tincidunt efficitur.Nunc vel risus fringilla, lacinia urna vitae, aliquet nulla.Nunc sed pulvinar dolor, eu fermentum velit.Curabitur a pretium quam, ut consectetur neque.Nunc ultricies, ex sed mattis efficitur, nulla nunc convallis odio, sit amet pellentesque orci tortor ut sapien.Vivamus felis orci, ultricies eget lacinia at, blandit vitae quam.In lacinia dui nec tincidunt maximus.Donec feugiat consectetur bibendum.Aenean eget vestibulum lacus.
|
|
50
|
-
|
|
51
|
-
Suspendisse vel molestie magna, et viverra justo.Aenean nec mi felis.Nam lacinia purus et congue facilisis.Pellentesque eget odio sed sem tincidunt imperdiet.Proin finibus ex nec placerat aliquet.Phasellus quis sapien nunc.Mauris eu augue aliquam sem suscipit vehicula a luctus augue.Phasellus ac scelerisque nibh.Nullam eleifend eleifend sapien eget convallis.
|
|
52
|
-
|
|
53
|
-
Nunc vitae metus risus.Ut iaculis dolor accumsan bibendum posuere.Morbi vitae odio sed velit dictum consequat.Aliquam vel erat vitae lacus luctus cursus vel ut risus.Aliquam a nunc eu lorem consequat finibus.Sed non enim vestibulum, ornare dui id, dignissim turpis.Etiam fermentum rutrum porttitor.Maecenas id nisl sodales, ornare turpis placerat, tincidunt dui.
|
|
54
|
-
|
|
55
|
-
Nulla aliquam purus at leo fringilla euismod.Praesent condimentum augue nibh, sed scelerisque mauris bibendum vitae.Vivamus maximus enim non massa commodo gravida.Cras iaculis elit ac est dapibus convallis.Quisque in tortor tincidunt, placerat turpis pulvinar, rhoncus orci.In vel risus et lacus lacinia volutpat.Maecenas facilisis fermentum dictum.Lorem ipsum dolor sit amet, consectetur adipiscing elit.Praesent aliquam pretium pellentesque.In eleifend leo eros, in lobortis eros elementum maximus.Fusce in orci ut massa vehicula mollis vitae non nibh.Sed ac porttitor urna.Nulla ac venenatis sapien, eget vulputate metus.
|
|
56
|
-
|
|
57
|
-
Mauris hendrerit lacus quam, vel mollis ligula porttitor ac.Nulla ornare libero at faucibus dictum.Donec tincidunt viverra sapien nec tincidunt.Donec leo sapien, rutrum quis dui a, auctor sodales nisi.Fusce condimentum eros sit amet ligula viverra, eget ullamcorper erat dapibus.Suspendisse dignissim ligula sed luctus aliquet.Aenean consectetur enim non nibh semper volutpat.
|
|
58
|
-
|
|
59
|
-
Mauris diam dolor, maximus et ultrices sed, semper sed felis.Morbi ac eros tellus.Maecenas eget ex vitae quam lacinia eleifend non nec leo.Donec condimentum consectetur nunc, quis luctus elit commodo eu.Nunc tincidunt condimentum neque, sed porta ligula porttitor et.Suspendisse scelerisque id massa sit amet placerat.Sed eleifend aliquet facilisis.Donec ac purus nec metus vestibulum euismod.Maecenas sollicitudin consequat ornare.Suspendisse pharetra vehicula eros nec malesuada.` },
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
t.is(response.errors, undefined);
|
|
63
|
-
t.true(response.data?.translate.result.length > 1000);
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
test('chunking test of translate endpoint with single long text sentence', async t => {
|
|
67
|
-
t.timeout(400000);
|
|
68
|
-
const response = await testServer.executeOperation({
|
|
69
|
-
query: 'query translate($text: String!) { translate(text: $text) { result } }',
|
|
70
|
-
variables: {
|
|
71
|
-
text: `Lorem ipsum dolor sit amet, consectetur adipiscing elit in id erat sem phasellus ac dapibus purus, in fermentum nunc mauris quis rutrum magna Quisque rutrum, augue vel blandit posuere, augue magna convallis turpis, nec elementum augue mauris sit amet nunc Aenean sit amet leo est Nunc ante ex, blandit et felis ut, iaculis lacinia est Phasellus dictum orci id libero ullamcorper tempor Vivamus id pharetra odioSed consectetur leo sed tortor dictum venenatisDonec gravida libero non accumsan suscipitDonec lectus turpis, ullamcorper eu pulvinar iaculis, ornare ut risusPhasellus aliquam, turpis quis viverra condimentum, risus est pretium metus, in porta ipsum tortor vitae elitPellentesque id finibus eratIn suscipit, sapien non posuere dignissim, augue nisl ultrices tortor, sit amet eleifend nibh elit at risus Donec diam ligula, sagittis ut nisl tincidunt, porta sodales magnaVestibulum ut dui arcuFusce at dolor exAliquam eu justo non libero volutpat pulvinar at id urnaDonec nec purus sed elit bibendum faucibusPellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestasVivamus iaculis mattis velit, ut lacinia massa lacinia quisPhasellus porttitor gravida ex, id aliquet eros rhoncus quisUt fringilla, lectus a vehicula luctus, diam odio convallis dolor, sodales pharetra nulla ex dictum justoUt faucibus, augue quis dictum iaculis, diam leo maximus sapien, sit amet vulputate eros quam sed semCras malesuada, sapien sit amet iaculis euismod, nunc odio lacinia est, dictum iaculis ante nisi in estFusce vehicula lorem tellusNullam a tempus nisiSed ut lectus nec ligula blandit tempusDonec faucibus turpis id urna vehicula imperdietDuis tempor vitae orci interdum dignissimPhasellus sed efficitur semNullam accumsan, turpis vitae consectetur ullamcorper, lectus purus tincidunt nisi, in pulvinar leo tortor at semDonec at feugiat dui, nec rhoncus nibhNam faucibus ultrices nisl at lobortisMorbi congue, nisl vel fermentum tristique, dui ipsum rhoncus massa, non varius nibh massa in turpisVestibulum vulputate, felis quis lacinia porta, nulla ex volutpat lorem, non rhoncus neque erat quis arcuMorbi massa nisl, hendrerit eget tortor condimentum, lobortis dapibus semAliquam ut dapibus elitSed porta dignissim anteNullam interdum ligula et massa vehicula, vel gravida diam laoreetVivamus et enim eget turpis pellentesque laoreetVivamus pellentesque neque et mauris imperdiet pulvinar Aliquam eget ligula congue, tincidunt magna eu, rutrum urnaSed consequat orci est, vel laoreet magna tincidunt sit ametCurabitur eget condimentum odio, vitae condimentum elitDuis viverra lobortis magnaPellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestasSed facilisis mi eu scelerisque pharetraCras et massa odioPraesent quis nulla vitae mi blandit egestas ac vitae liberoCras ultricies ex non consequat scelerisqueNulla et est ac sem placerat convallis ac vitae massaPhasellus lobortis mauris vel est vehicula lobortisCurabitur ipsum ipsum, ullamcorper eget placerat sit amet, dapibus iaculis dui Phasellus facilisis rutrum metus nec euismod.`
|
|
72
|
-
}
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
t.is(response.errors, undefined);
|
|
76
|
-
t.true(response.data?.translate.result.length > 200);
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
test('chunking test of translate endpoint with two long text sentence', async t => {
|
|
80
|
-
t.timeout(400000);
|
|
81
|
-
const response = await testServer.executeOperation({
|
|
82
|
-
query: 'query translate($text: String!) { translate(text: $text) { result } }',
|
|
83
|
-
variables: {
|
|
84
|
-
text: `I love coding. I like coding. Lorem ipsum dolor sit amet, consectetur adipiscing elit in id erat sem phasellus ac dapibus purus, in fermentum nunc mauris quis rutrum magna Quisque rutrum, augue vel blandit posuere, augue magna convallis turpis, nec elementum augue mauris sit amet nunc Aenean sit amet leo est Nunc ante ex, blandit et felis ut, iaculis lacinia est Phasellus dictum orci id libero ullamcorper tempor Vivamus id pharetra odioSed consectetur leo sed tortor dictum venenatisDonec gravida libero non accumsan suscipitDonec lectus turpis, ullamcorper eu pulvinar iaculis, ornare ut risusPhasellus aliquam, turpis quis viverra condimentum, risus est pretium metus, in porta ipsum tortor vitae elitPellentesque id finibus eratIn suscipit, sapien non posuere dignissim, augue nisl ultrices tortor, sit amet eleifend nibh elit at risus Donec diam ligula, sagittis ut nisl tincidunt, porta sodales magnaVestibulum ut dui arcuFusce at dolor exAliquam eu justo non libero volutpat pulvinar at id urnaDonec nec purus sed elit bibendum faucibusPellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestasVivamus iaculis mattis velit, ut lacinia massa lacinia quisPhasellus porttitor gravida ex, id aliquet eros rhoncus quisUt fringilla, lectus a vehicula luctus, diam odio convallis dolor, sodales pharetra nulla ex dictum justoUt faucibus, augue quis dictum iaculis, diam leo maximus sapien, sit amet vulputate eros quam sed semCras malesuada, sapien sit amet iaculis euismod, nunc odio lacinia est, dictum iaculis ante nisi in estFusce vehicula lorem tellusNullam a tempus nisiSed ut lectus nec ligula blandit tempusDonec faucibus turpis id urna vehicula imperdietDuis tempor vitae orci interdum dignissimPhasellus sed efficitur semNullam accumsan, turpis vitae consectetur ullamcorper, lectus purus tincidunt nisi, in pulvinar leo tortor at semDonec at feugiat dui, nec rhoncus nibhNam faucibus ultrices nisl at lobortisMorbi congue, nisl vel fermentum tristique, dui ipsum rhoncus massa, non varius nibh massa in turpisVestibulum vulputate, felis quis lacinia porta, nulla ex volutpat lorem, non rhoncus neque erat quis arcuMorbi massa nisl, hendrerit eget tortor condimentum, lobortis dapibus semAliquam ut dapibus elitSed porta dignissim anteNullam interdum ligula et massa vehicula, vel gravida diam laoreetVivamus et enim eget turpis pellentesque laoreetVivamus pellentesque neque et mauris imperdiet pulvinar Aliquam eget ligula congue, tincidunt magna eu, rutrum urnaSed consequat orci est, vel laoreet magna tincidunt sit ametCurabitur eget condimentum odio, vitae condimentum elitDuis viverra lobortis magnaPellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestasSed facilisis mi eu scelerisque pharetraCras et massa odioPraesent quis nulla vitae mi blandit egestas ac vitae liberoCras ultricies ex non consequat scelerisqueNulla et est ac sem placerat convallis ac vitae massaPhasellus lobortis mauris vel est vehicula lobortisCurabitur ipsum ipsum, ullamcorper eget placerat sit amet, dapibus iaculis dui Phasellus facilisis rutrum metus nec euismod.Lorem ipsum dolor sit amet, consectetur adipiscing elit in id erat sem phasellus ac dapibus purus, in fermentum nunc mauris quis rutrum magna Quisque rutrum, augue vel blandit posuere, augue magna convallis turpis, nec elementum augue mauris sit amet nunc Aenean sit amet leo est Nunc ante ex, blandit et felis ut, iaculis lacinia est Phasellus dictum orci id libero ullamcorper tempor Vivamus id pharetra odioSed consectetur leo sed tortor dictum venenatisDonec gravida libero non accumsan suscipitDonec lectus turpis, ullamcorper eu pulvinar iaculis, ornare ut risusPhasellus aliquam, turpis quis viverra condimentum, risus est pretium metus, in porta ipsum tortor vitae elitPellentesque id finibus eratIn suscipit, sapien non posuere dignissim, augue nisl ultrices tortor, sit amet eleifend nibh elit at risus Donec diam ligula, sagittis ut nisl tincidunt, porta sodales magnaVestibulum ut dui arcuFusce at dolor exAliquam eu justo non libero volutpat pulvinar at id urnaDonec nec purus sed elit bibendum faucibusPellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestasVivamus iaculis mattis velit, ut lacinia massa lacinia quisPhasellus porttitor gravida ex, id aliquet eros rhoncus quisUt fringilla, lectus a vehicula luctus, diam odio convallis dolor, sodales pharetra nulla ex dictum justoUt faucibus, augue quis dictum iaculis, diam leo maximus sapien, sit amet vulputate eros quam sed semCras malesuada, sapien sit amet iaculis euismod, nunc odio lacinia est, dictum iaculis ante nisi in estFusce vehicula lorem tellusNullam a tempus nisiSed ut lectus nec ligula blandit tempusDonec faucibus turpis id urna vehicula imperdietDuis tempor vitae orci interdum dignissimPhasellus sed efficitur semNullam accumsan, turpis vitae consectetur ullamcorper, lectus purus tincidunt nisi, in pulvinar leo tortor at semDonec at feugiat dui, nec rhoncus nibhNam faucibus ultrices nisl at lobortisMorbi congue, nisl vel fermentum tristique, dui ipsum rhoncus massa, non varius nibh massa in turpisVestibulum vulputate, felis quis lacinia porta, nulla ex volutpat lorem, non rhoncus neque erat quis arcuMorbi massa nisl, hendrerit eget tortor condimentum, lobortis dapibus semAliquam ut dapibus elitSed porta dignissim anteNullam interdum ligula et massa vehicula, vel gravida diam laoreetVivamus et enim eget turpis pellentesque laoreetVivamus pellentesque neque et mauris imperdiet pulvinar Aliquam eget ligula congue, tincidunt magna eu, rutrum urnaSed consequat orci est, vel laoreet magna tincidunt sit ametCurabitur eget condimentum odio, vitae condimentum elitDuis viverra lobortis magnaPellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestasSed facilisis mi eu scelerisque pharetraCras et massa odioPraesent quis nulla vitae mi blandit egestas ac vitae liberoCras ultricies ex non consequat scelerisqueNulla et est ac sem placerat convallis ac vitae massaPhasellus lobortis mauris vel est vehicula lobortisCurabitur ipsum ipsum, ullamcorper eget placerat sit amet, dapibus iaculis dui Phasellus facilisis rutrum metus nec euismod.`
|
|
85
|
-
}
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
t.is(response.errors, undefined);
|
|
89
|
-
t.true(response.data?.translate.result.length > 500);
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
test('chunking test...', async t => {
|
|
93
|
-
t.timeout(400000);
|
|
94
|
-
const response = await testServer.executeOperation({
|
|
95
|
-
query: 'query translate($text: String!, $to: String) { translate(text: $text, to: $to) { result } }',
|
|
96
|
-
variables: {
|
|
97
|
-
to: 'en',
|
|
98
|
-
text: `
|
|
99
|
-
صعدت روسيا هجماتها في أنحاء أوكرانيا، بعد يوم من إعلان الغرب مدّ كييف بدبابات قتالية، واستهدفت عشرات الصواريخ والمسيّرات الروسية العاصمة الأوكرانية ومدنا في الجنوب والشرق، واعتبر الكرملين أن الدبابات لن تغيّر من طبيعة المعركة، في حين أعلنت وزارة الدفاع الأوكرانية أن هناك تحضيرات قتالية روسية انطلاقا من القرم.
|
|
100
|
-
|
|
101
|
-
فقد شنّت القوات الروسية ضربات صاروخية في أنحاء مختلفة من أوكرانيا؛ من بينها 37 غارة جوية و10 ضربات صاروخية ليلية استهدفت البنية التحتية في دنيبرو ومناطق أخرى، مما دفع الجيش الأوكراني إلى إعلان عن حالة التأهب القصوى في عموم أراضي البلاد.
|
|
102
|
-
|
|
103
|
-
كما شمل القصف والغارات العاصمة كييف التي استيقظ سكانها على وقع أصوات الانفجارات بعد استهداف القوات الروسية لها بأكثر من 15 صاروخ "كروز"، قالت السلطات الأوكرانية إن دفاعاتها الجوية نجحت في إسقاطها جميعها.
|
|
104
|
-
|
|
105
|
-
وأكدت السلطات العسكرية في كييف تصدّي الدفاعات الجوية الأوكرانية للصواريخ الروسية التي وجهت نحو المدينة، لكنها دفعت بعدد كبير من سكانها إلى النزول إلى الملاجئ والبقاء فيها، بعد تأكيد المجلس الإقليمي في كييف أن خطر الضربات الجوية لم ينته.
|
|
106
|
-
|
|
107
|
-
وفي وقت سابق، أعلن عمدة كييف فيتالي كليتشكو مقتل شخص وإصابة اثنين بهجوم صاروخي روسي استهدف مبنى غير سكني بمنطقة هولوسيفسكي بالمدينة، وأكد -في منشور على تليغرام- وقوع انفجارات متفرقة في المدينة وحث السكان على الاحتماء.
|
|
108
|
-
|
|
109
|
-
وتشتد المواجهات بين الطرفين في الجبهة الجنوبية حيث قصفت القوات الروسية مناطق عدة لا سيما في مقاطعة خيرسون جنوبا، كما أعلنت الدفاعات الأوكرانية إسقاط صواريخ روسية في سماء مقاطعة ميكولايف، واستهدفت الصواريخ الروسية كذلك منشآت للطاقة في مقاطعة أوديسا على ساحل البحر الأسود جنوبا وتسببت في انقطاع التيار الكهربائي.
|
|
110
|
-
|
|
111
|
-
وفي الجبهة الشرقية، على ضفاف نهر دنيبرو، تعرضت مدينة زاباروجيا لهجمة صاروخية روسية جديدة. كما أعلن الدفاع الجوي الأوكراني رصد صاروخين موجهين نحو مقاطعة دنيبرو، في مدينة كريفيري غربي المقاطعة.
|
|
112
|
-
|
|
113
|
-
في الأثناء، أعلنت سلطات دونيتسك الموالية لروسيا دخول القوات الروسية مدينة أوغليدار، وتعزيز مواقعها في ضواحيها.
|
|
114
|
-
|
|
115
|
-
وتزامن التصعيد العسكري الروسي أيضا مع تحذير أوكراني من تحضيرات قتالية روسية انطلاقا من القرم؛ حيث قال المتحدث باسم هيئة الأركان الأوكرانية أولكسندر شتوبون إن موسكو تعدّ لعملية تعبئة جديدة في المنطقة.
|
|
116
|
-
|
|
117
|
-
وبالتوازي مع تحركات روسية في القرم أكدت الاستخبارات الأوكرانية حاجة القوات الأوكرانية إلى مزيد من المدفعية البعيدة المدى، لضرب التعزيزات الروسية التي تصل من شبه جزيرة القرم، وقالت إن الروس ينقلون ذخيرة وعتادا إلى مستودعات تبعد عن خطوط الجبهة الجنوبية أكثر من 80 كيلومترا.
|
|
118
|
-
|
|
119
|
-
وتأتي التطورات العسكرية في أوكرانيا في ظل تأكيد عدد من الدول الأوروبية، بينهما ألمانيا، إرسال دبابات "ليوبارد2" إلى الجيش الأوكراني.
|
|
120
|
-
|
|
121
|
-
وتخشى دول حلف شمال الأطلسي (ناتو) أن تتسبب بعض الإمدادات العسكرية إلى أوكرانيا بتصعيد وتيرة الصراع وتحويله إلى حرب مباشرة مع روسيا.
|
|
122
|
-
|
|
123
|
-
دبابات.. وعيد وتصعيد
|
|
124
|
-
|
|
125
|
-
ورافق الرد العسكري الروسي على إعلان تزويد أوكرانيا بالدبابات تصعيد على مستوى التصريحات أيضا.
|
|
126
|
-
|
|
127
|
-
فبعد توعد موسكو هذه الدبابات بالحرق، اعتبر المتحدث باسم الكرملين ديمتري بيسكوف تزويد أوكرانيا بالدبابات الغربية انخراطا مباشرا في الصراع، ودليلا على التورط الأميركي والأوروبي المباشر والمتزايد في هذه الحرب، وفق تعبيره.
|
|
128
|
-
|
|
129
|
-
وأكد بيسكوف أنه لا نية لدى موسكو لتغيير وضع العملية العسكرية الخاصة في أوكرانيا، بعد إرسال الدبابات إلى كييف.
|
|
130
|
-
|
|
131
|
-
بدوره، قال رئيس لجنة مجلس الدوما الروسي للشؤون الدولية ليونيد سلوتسكي إن كتيبة الدبابات الأميركية لن تساعد الرئيس الأوكراني فولوديمير زيلينسكي على تغيير مسار العملية الروسية في أوكرانيا ولا الوضع في شبه جزيرة القرم، حسب تعبيره.
|
|
132
|
-
|
|
133
|
-
وأضاف أيضا أن أي محاولة للاستيلاء على شبه الجزيرة القرم ستلقى ردا قاسيا، مؤكدا أن الهجوم الروسي لن يوقفه إمداد آخر من الأسلحة الغربية.
|
|
134
|
-
|
|
135
|
-
تنديد أميركي
|
|
136
|
-
|
|
137
|
-
من جانبها، نددت الولايات المتحدة الأميركية، اليوم الخميس، بالهجمات الصاروخية الروسية التي استهدفت العاصمة الأوكرانية كييف.
|
|
138
|
-
|
|
139
|
-
ووصفت السفيرة الأميركية لدى كييف بريدغيت برينك، في تغريدة، الهجمات الورسية بأنها "عنيفة" وتتبع "الفشل الإستراتيجي نفسه".
|
|
140
|
-
|
|
141
|
-
وأضافت "لا يمكن لموجة الهجمات الروسية بالصواريخ والمسيرات أن توقف المدافعين الأبطال عن أوكرانيا، ولا شعبها الشجاع، ولا دعمنا الحاسم والموحد لأوكرانيا".
|
|
142
|
-
|
|
143
|
-
دبابات "تشالنجر2"
|
|
144
|
-
|
|
145
|
-
وفي تطور آخر، قال وزير الدولة البريطاني لشؤون الدفاع أليكس تشوك إن من المقرر أن تدخل دبابات "تشالنجر2" البريطانية مسرح العمليات العسكرية في أوكرانيا بنهاية مارس/آذار المقبل.
|
|
146
|
-
|
|
147
|
-
وأضاف وزير الدولة البريطاني لشؤون الدفاع، في مؤتمر صحفي، أن بلاده قدمت 200 عربة مدرعة لأوكرانيا حتى الآن، وأن تدريب القوات الأوكرانية على استخدام دبابات "تشالنجر2" سيبدأ الأسبوع المقبل.
|
|
148
|
-
|
|
149
|
-
ورحب الوزير البريطاني بقرار ألمانيا إرسال دبابات "ليوبارد2″، وقرار الولايات المتحدة إرسال دبابات "أبرامز" لأوكرانيا.
|
|
150
|
-
|
|
151
|
-
وأعلن أمس الأربعاء الرئيس الأميركي جو بايدن أن الولايات المتحدة سترسل 31 دبابة من طراز "إم1 أبرامز" القتالية إلى أوكرانيا، وذلك عقب ساعات من تأكيد ألمانيا أنها ستنقل إلى حكومة كييف 14 من دباباتها من طراز "ليوبارد2″، وإعلان مشابه من النرويج ودول أوروبية أخرى، الأمر الذي رحب به الناتو، ووصفته أوكرانيا بـ"حلف الدبابات الكبير".`
|
|
152
|
-
}
|
|
153
|
-
});
|
|
154
|
-
|
|
155
|
-
t.is(response.errors, undefined);
|
|
156
|
-
t.true(response.data?.translate.result.length > 500);
|
|
157
|
-
});
|