mirror of
https://github.com/moparisthebest/spdylay
synced 2024-12-22 15:48:53 -05:00
Added spdylay_stream_add_pushed_stream
With this function and 3 new member in spdylay_stream, we can track server- pushed streams which associate them to this stream.
This commit is contained in:
parent
e1abe54a81
commit
bb6a90dc4d
@ -33,12 +33,34 @@ void spdylay_stream_init(spdylay_stream *stream, int32_t stream_id,
|
|||||||
stream->pri = pri;
|
stream->pri = pri;
|
||||||
stream->state = initial_state;
|
stream->state = initial_state;
|
||||||
stream->shut_flags = SPDYLAY_SHUT_NONE;
|
stream->shut_flags = SPDYLAY_SHUT_NONE;
|
||||||
|
stream->pushed_streams = NULL;
|
||||||
|
stream->pushed_streams_length = 0;
|
||||||
|
stream->pushed_streams_capacity = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void spdylay_stream_free(spdylay_stream *stream)
|
void spdylay_stream_free(spdylay_stream *stream)
|
||||||
{}
|
{
|
||||||
|
free(stream->pushed_streams);
|
||||||
|
}
|
||||||
|
|
||||||
void spdylay_stream_shutdown(spdylay_stream *stream, spdylay_shut_flag flag)
|
void spdylay_stream_shutdown(spdylay_stream *stream, spdylay_shut_flag flag)
|
||||||
{
|
{
|
||||||
stream->shut_flags |= flag;
|
stream->shut_flags |= flag;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int spdylay_stream_add_pushed_stream(spdylay_stream *stream, int32_t stream_id)
|
||||||
|
{
|
||||||
|
if(stream->pushed_streams_capacity == stream->pushed_streams_length) {
|
||||||
|
int32_t *streams;
|
||||||
|
size_t capacity = stream->pushed_streams_capacity == 0 ?
|
||||||
|
5 : stream->pushed_streams_capacity*2;
|
||||||
|
streams = realloc(stream->pushed_streams, capacity*sizeof(uint32_t));
|
||||||
|
if(streams == NULL) {
|
||||||
|
return SPDYLAY_ERR_NOMEM;
|
||||||
|
}
|
||||||
|
stream->pushed_streams = streams;
|
||||||
|
stream->pushed_streams_capacity = capacity;
|
||||||
|
}
|
||||||
|
stream->pushed_streams[stream->pushed_streams_length++] = stream_id;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@ -77,9 +77,14 @@ typedef struct {
|
|||||||
uint8_t pri;
|
uint8_t pri;
|
||||||
/* Bitwise OR of zero or more spdylay_shut_flag values */
|
/* Bitwise OR of zero or more spdylay_shut_flag values */
|
||||||
uint8_t shut_flags;
|
uint8_t shut_flags;
|
||||||
/* TODO spdylay_stream should remember pushed stream ID, so that if
|
/* The array of server-pushed stream IDs which associate them to
|
||||||
RST_STREAM with CANCEL (mandatory?) is sent, we can close all of
|
this stream. */
|
||||||
them. */
|
int32_t *pushed_streams;
|
||||||
|
/* The number of stored pushed stream ID in |pushed_streams| */
|
||||||
|
size_t pushed_streams_length;
|
||||||
|
/* The maximum number of stream ID the |pushed_streams| can
|
||||||
|
store. */
|
||||||
|
size_t pushed_streams_capacity;
|
||||||
} spdylay_stream;
|
} spdylay_stream;
|
||||||
|
|
||||||
void spdylay_stream_init(spdylay_stream *stream, int32_t stream_id,
|
void spdylay_stream_init(spdylay_stream *stream, int32_t stream_id,
|
||||||
@ -94,4 +99,11 @@ void spdylay_stream_free(spdylay_stream *stream);
|
|||||||
*/
|
*/
|
||||||
void spdylay_stream_shutdown(spdylay_stream *stream, spdylay_shut_flag flag);
|
void spdylay_stream_shutdown(spdylay_stream *stream, spdylay_shut_flag flag);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Add server-pushed |stream_id| to this stream. This happens when
|
||||||
|
* server-pushed stream is associated to this stream. This function
|
||||||
|
* returns 0 if it succeeds, or negative error code.
|
||||||
|
*/
|
||||||
|
int spdylay_stream_add_pushed_stream(spdylay_stream *stream, int32_t stream_id);
|
||||||
|
|
||||||
#endif /* SPDYLAY_STREAM */
|
#endif /* SPDYLAY_STREAM */
|
||||||
|
@ -27,11 +27,11 @@ check_PROGRAMS = main
|
|||||||
|
|
||||||
OBJECTS = main.c spdylay_pq_test.c spdylay_map_test.c spdylay_queue_test.c \
|
OBJECTS = main.c spdylay_pq_test.c spdylay_map_test.c spdylay_queue_test.c \
|
||||||
spdylay_buffer_test.c spdylay_zlib_test.c spdylay_session_test.c \
|
spdylay_buffer_test.c spdylay_zlib_test.c spdylay_session_test.c \
|
||||||
spdylay_frame_test.c
|
spdylay_frame_test.c spdylay_stream_test.c
|
||||||
|
|
||||||
HFILES = spdylay_pq_test.h spdylay_map_test.h spdylay_queue_test.h \
|
HFILES = spdylay_pq_test.h spdylay_map_test.h spdylay_queue_test.h \
|
||||||
spdylay_buffer_test.h spdylay_zlib_test.h spdylay_session_test.h \
|
spdylay_buffer_test.h spdylay_zlib_test.h spdylay_session_test.h \
|
||||||
spdylay_frame_test.h
|
spdylay_frame_test.h spdylay_stream_test.h
|
||||||
|
|
||||||
main_SOURCES = $(HFILES) $(OBJECTS)
|
main_SOURCES = $(HFILES) $(OBJECTS)
|
||||||
|
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
#include "spdylay_zlib_test.h"
|
#include "spdylay_zlib_test.h"
|
||||||
#include "spdylay_session_test.h"
|
#include "spdylay_session_test.h"
|
||||||
#include "spdylay_frame_test.h"
|
#include "spdylay_frame_test.h"
|
||||||
|
#include "spdylay_stream_test.h"
|
||||||
|
|
||||||
int init_suite1(void)
|
int init_suite1(void)
|
||||||
{
|
{
|
||||||
@ -104,7 +105,9 @@ int main()
|
|||||||
test_spdylay_frame_pack_headers) ||
|
test_spdylay_frame_pack_headers) ||
|
||||||
!CU_add_test(pSuite, "frame_pack_settings",
|
!CU_add_test(pSuite, "frame_pack_settings",
|
||||||
test_spdylay_frame_pack_settings) ||
|
test_spdylay_frame_pack_settings) ||
|
||||||
!CU_add_test(pSuite, "frame_nv_sort", test_spdylay_frame_nv_sort)) {
|
!CU_add_test(pSuite, "frame_nv_sort", test_spdylay_frame_nv_sort) ||
|
||||||
|
!CU_add_test(pSuite, "stream_add_pushed_stream",
|
||||||
|
test_spdylay_stream_add_pushed_stream)) {
|
||||||
CU_cleanup_registry();
|
CU_cleanup_registry();
|
||||||
return CU_get_error();
|
return CU_get_error();
|
||||||
}
|
}
|
||||||
|
45
tests/spdylay_stream_test.c
Normal file
45
tests/spdylay_stream_test.c
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
/*
|
||||||
|
* Spdylay - SPDY Library
|
||||||
|
*
|
||||||
|
* Copyright (c) 2012 Tatsuhiro Tsujikawa
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
* a copy of this software and associated documentation files (the
|
||||||
|
* "Software"), to deal in the Software without restriction, including
|
||||||
|
* without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
* distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
* permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
* the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be
|
||||||
|
* included in all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
#include "spdylay_stream_test.h"
|
||||||
|
|
||||||
|
#include <CUnit/CUnit.h>
|
||||||
|
|
||||||
|
#include "spdylay_stream.h"
|
||||||
|
|
||||||
|
void test_spdylay_stream_add_pushed_stream()
|
||||||
|
{
|
||||||
|
spdylay_stream stream;
|
||||||
|
int i, n;
|
||||||
|
spdylay_stream_init(&stream, 1, SPDYLAY_FLAG_NONE, 3, SPDYLAY_STREAM_OPENING);
|
||||||
|
n = 26;
|
||||||
|
for(i = 2; i < n; i += 2) {
|
||||||
|
CU_ASSERT(0 == spdylay_stream_add_pushed_stream(&stream, i));
|
||||||
|
CU_ASSERT(i/2 == stream.pushed_streams_length);
|
||||||
|
}
|
||||||
|
for(i = 2; i < n; i += 2) {
|
||||||
|
CU_ASSERT(i == stream.pushed_streams[i/2-1]);
|
||||||
|
}
|
||||||
|
spdylay_stream_free(&stream);
|
||||||
|
}
|
30
tests/spdylay_stream_test.h
Normal file
30
tests/spdylay_stream_test.h
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
/*
|
||||||
|
* Spdylay - SPDY Library
|
||||||
|
*
|
||||||
|
* Copyright (c) 2012 Tatsuhiro Tsujikawa
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
* a copy of this software and associated documentation files (the
|
||||||
|
* "Software"), to deal in the Software without restriction, including
|
||||||
|
* without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
* distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
* permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
* the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be
|
||||||
|
* included in all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
#ifndef SPDYLAY_STREAM_TEST_H
|
||||||
|
#define SPDYLAY_STREAM_TEST_H
|
||||||
|
|
||||||
|
void test_spdylay_stream_add_pushed_stream();
|
||||||
|
|
||||||
|
#endif /* SPDYLAY_STREAM_TEST_H */
|
Loading…
Reference in New Issue
Block a user